diff --git a/docs/icons.md b/docs/icons.md index aa8d6881..892e1836 100644 --- a/docs/icons.md +++ b/docs/icons.md @@ -3,8 +3,9 @@ Both sections and items can have an icon, which is specified using the `icon` attribute. Using icons improves the aesthetics of your UI and makes the app more intuitive to use. There are several options when it comes to setting icons, and this article outlines each of them - [Font Awesome Icons](#font-awesome) -- [Favicons](#favicons) +- [Auto-Fetched Favicons](#favicons) - [Generative Icons](#generative-icons) +- [Emoji Icons](#emoji-icons) - [Icons by URL](#icons-by-url) - [Local Icons](#local-icons) - [No Icon](#no-icon) @@ -21,6 +22,10 @@ Font-Awesome has a wide variety of free icons, but you can also use their pro ic ### Favicons Dashy can auto-fetch the favicon for a given service using it's URL. Just set `icon: favicon` to use this feature. If the services URL is a local IP, then Dashy will attempt to find the favicon from `http://[ip]/favicon.ico`. This has two issues, favicons are not always hosted at the same location for every service, and often the default favicon is a low resolution. Therefore to fix this, for remote services an API is used to return a high-quality icon for any online service. +<p align="center"> + <img width="400" src="https://i.ibb.co/k6wyhnB/favicon-icons.png" /> +</p> + The default favicon API is [Favicon Kit](https://faviconkit.com/), a free and reliable service for returning images from any given URL. However several other API's are supported. To change the API used, under `appConfig`, set `faviconApi` to one of the following values: - `faviconkit` - [faviconkit.com](https://faviconkit.com/) (Recommend) @@ -34,12 +39,17 @@ You can also force Dashy to always get favicons from the root of the domain, and ### Generative Icons Uses a unique and programmatically generated icon for a given service. This is particularly useful when you have a lot of similar services with a different IP or port, and no specific icon. These icons are generated with [ipsicon.io](https://ipsicon.io/). To use this option, just set an item's to: `icon: generative`. -### Icons by URL -You can also set an icon by passing in a valid URL pointing to the icons location. For example `icon: https://i.ibb.co/710B3Yc/space-invader-x256.png`, this can be in .png, .jpg or .svg format, and hosted anywhere- so long as it's accessible from where you are hosting Dashy. The icon will be automatically scaled to fit, however loading in a lot of large icons may have a negative impact on performance, especially if you visit Dashy from new devices often. +<p align="center"> + <img width="400" src="https://i.ibb.co/qrNNNcm/generative-icons.png" /> +</p> -### Emoji Icon +### Emoji Icons You can use almost any emoji as an icon for items or sections. You can specify the emoji either by pasting it directly, using it's unicode ( e.g. `'U+1F680'`) or shortcode (e.g. `':rocket:'`). You can find these codes for any emoji using [Emojipedia](https://emojipedia.org/) (near the bottom of emoji each page), or for a quick reference to emoji shortcodes, check out [emojis.ninja](https://emojis.ninja/) by @nomanoff. +<p align="center"> + <img width="400" src="https://i.ibb.co/YLwgTf9/emoji-icons-1.png" /> +</p> + The following example shows the unicode options available, all three will render the 🚀 emoji. ```yaml @@ -52,6 +62,9 @@ items: icon: 🚀 ``` +### Icons by URL +You can also set an icon by passing in a valid URL pointing to the icons location. For example `icon: https://i.ibb.co/710B3Yc/space-invader-x256.png`, this can be in .png, .jpg or .svg format, and hosted anywhere- so long as it's accessible from where you are hosting Dashy. The icon will be automatically scaled to fit, however loading in a lot of large icons may have a negative impact on performance, especially if you visit Dashy from new devices often. + ### Local Icons You may also want to store your icons locally, bundled within Dashy so that there is no reliance on outside services. This can be done by putting the icons within Dashy's `./public/item-icons/` directory. If you are using Docker, then the easiest option is to map a volume from your host system, for example: `-v /local/image/directory:/app/public/item-icons/`. To reference an icon stored locally, just specify it's name and extension. For example, if my icon was stored in `/app/public/item-icons/maltrail.png`, then I would just set `icon: maltrail.png`.