Appearance
Icons
Icons are specified by using a text string to describe an icon.
Try it out! Type in the box to see the icon it makes.
An icon specifier string describes an icon using a simple text-based format. The string consists of a series of space-separated keywords, with the final keyword specifying the base icon (see Base icon formats), and the preceding keywords (if any) specifying modifiers (see Icon modifiers).
Here are some examples:
Specifier string | Icon generated | Notes |
---|---|---|
T | Here, T specifies the base icon as a text icon. | |
square T | Here, square is a modifier that encloses the base icon in a square. | |
square filled T | Combining two modifiers; filled specifies that the square is a solid shape. | |
circle filled T | Here we use a non-Ascii character as the base icon. The circle modifier encloses the base icon in a circle. | |
search filled T | The search modifier encloses the base icon in a magnifying glass shape. | |
iconify:mdi:home | Here, the base icon is an Iconify icon. | |
square filled iconify:mdi:home | We put the home icon in a filled square. | |
strike iconify:mdi:home | The strike modifier draws a strike-through line over the base icon. | |
symbol:hand.raised | Here, the base icon as an SF Symbols icon. | |
flip-x symbol:hand.raised | The flip-x modifier flips the base icon horizontally. |
Base icon formats
File icons
File icons can only be used in packages. The icon is specified as a path to a .png
or .svg
image file in the package.
json
{
"icon": "icon.png"
}
A good icon will feature a monochrome shape on a transparent background. Variable opacity can be used for shading. PNG icons should be at least 256 pixels high.
File icons with modifiers
File icons can be used with modifiers by adding the prefix file:
, for example:
{
"icon": "strike file:icon.png"
}
Text icons
Text icons can include up to 3 characters and are specified as the text itself. The prefix text:
can optionally be used.
json
{
"icon": "T"
}
Text icons are drawn using the system font. Adding the monospaced
modifier will draw the icon in a monospaced variant.
If the text icon is a single emoji without modifiers, it rendered in color.
Examples:
Specifier string | Icon generated |
---|---|
ABC (or text:ABC ) | |
@ | |
本 | |
() | |
monospaced () | |
😵💫 |
💡 Tip: Monospaced font
Punctuation symbols often look better in icons when drawn with the monospaced
modifier.
Iconify icons
Iconify provides access to over 200,000 icons from a variety of open-source icon sets, using a unified naming system.
The Iconify website provides a catalog of available icons.
The format is iconify:<icon set prefix>:<icon name>
.
Some Iconify icons contain color information. These are automatically recognized by PopClip and will be rendered in color.
Examples:
Specifier string | Icon generated |
---|---|
iconify:ion:fish | |
iconify:solar:flag-bold | |
iconify:logos:spotify-icon |
SF Symbols icons
Apple SF Symbols are available on macOS 11.0 and above. (Symbol availability may vary by macOS version). The icon catalog can be viewed by installing Apple's SF Symbols app on your Mac.
The format is symbol:<symbol name>
.
Symbols are always drawn in the monochrome variant.
Examples:
Specifier string | Icon generated |
---|---|
symbol:flame | |
symbol:hand.raised | |
symbol:signpost.right |
SVG Icons
The icon string can supply SVG source code for an icon. The format is svg:<svg string>
.
Example
svg:<svg xmlns="http://www.w3.org/2000/svg" width="1em" height="1em" viewBox="0 0 24 24"><path fill="currentColor" d="m6 10.95l-1.875 1.025l-2.975-5.2L7.75 3H10v1q0 .825.588 1.413T12 6q.825 0 1.413-.587T14 4V3h2.25l6.6 3.775l-2.95 5.15l-1.9-.95V21H6z"/></svg>
generates:
Data icons
The icon string can include raw image data as a data URL.
The format is: data:<mediatype>[;base64],<data>
, where <mediatype>
may be either image/svg+xml
or image/png
.
SVG Example
Specifier string:

generates:
Icon modifiers
The following modifiers can be prefixed to the specifier string to alter how the icon is drawn.
Style modifiers
Keyword | Description |
---|---|
square | Enclose the icon in a square. |
circle | Enclose the icon in a circle. |
search | Enclose the icon in a magnifying glass shape. |
strike | Draw a strike-through line over the icon. |
filled | Draw the enclosing shape as a solid shape. |
monospaced | For text icons only. Draw the text using a monospaced font. |
Geometric transformations
Keyword | Description |
---|---|
flip-x | Flip the icon horizontally. |
flip-y | Flip the icon vertically. |
move-x=<percent> | Move the icon horizontally by the specified distance, expressed as percentage of the icon's width. For example move-x=10 to move 10% right or move-x=-5 to move 5% left. |
move-y=<percent> | Move the icon vertically by the specified distance, expressed as percentage of the icon's height. |
scale=<percent> | Adjust the scale at which the icon is drawn. For example scale=120 to enlarge to 120%, or scale=90 to shrink to 90%. |
rotate=<degrees> | Rotate the icon by the specified number of degrees. For example rotate=90 to rotate 90 degrees anticlockwise. |
Examples:
Specifier string | Icon generated |
---|---|
symbol:signpost.right | |
flip-x symbol:signpost.right | |
move-y=-50 symbol:signpost.right | |
scale=50 symbol:signpost.right | |
rotate=90 symbol:signpost.right | |
square filled move-x=4 move-y=-4 scale=115 rotate=45 T |
Color and aspect
Keyword | Description |
---|---|
preserve-color | The base icon will be displayed in its original colors instead of used as a monochrome mask. (This is applied implicitly to emoji and color Iconify icons.) |
preserve-aspect | If the base icon is not square, it by default rendered into a square canvas. With this modifier, the icon will be rendered with its original aspect ratio. |
Example:
json
{
"icon": "preserve-color file:rainbow.png"
}
Negative modifiers
In some cases it may be useful to explicitly negate a modifier. This is done by appending =0
. For example, to remove the implicit color rendering from an Iconify icon, use preserve-color=0
.
Icon Preview tool
As a handy tool, the following snippet defines an extension that will display the icon for any text string you select. (To see how to install this, see Snippets.)
javascript
// #popclip
// name: Icon Preview
// entitlements: [dynamic]
// language: javascript
// module: true
exports.actions = () => {
return [
{
icon: popclip.input.text,
},
];
};