diff --git a/readme.md b/readme.md index 0596f30..a76992d 100644 --- a/readme.md +++ b/readme.md @@ -18,6 +18,21 @@ Inspired by [Ben Phelps' Homepage](https://gethomepage.dev/) and [Umbrel](https: # Icons +## Options + +- Set a background by providing an "iconBG" from the [list of Tailwind colors](https://tailwindcss.com/docs/background-color). Do not prefix with "bg-". +- Turn off the bubble and shadow by setting `"iconBubble": false`. +- Turn off background color by setting `"iconBG": "transparent"`. +- Hide the icon entirely by setting `"icon": ""`. + +```bash +# Specify an icon in config.json +"icon": "/icons/jellyfin.jpg", +"iconColor": "blue-500", # optional, defaults to a contrasting color +"iconBG": "gray-200", # optional, defaults to a complementary color +"iconBubble": false, # optional, defaults to true +``` + ## Use your own Create a volume or bind mount to a subfolder of `/app/public` and specify a relative path. @@ -51,20 +66,9 @@ Use any [Material Design icon](https://icon-sets.iconify.design/mdi/) by prefixi Fill the icon by providing an "iconColor" from the [list of Tailwind colors](https://tailwindcss.com/docs/background-color). Do not prefix with "bg-". -Set a background by providing an "iconBG" from the [list of Tailwind colors](https://tailwindcss.com/docs/background-color). Do not prefix with "bg-". - -Turn off the bubble and shadow by setting `"iconBubble": false`. - -Turn off background color by setting `"iconBG": "transparent"`. - -Hide the icon entirely by setting `"icon": ""`. - ```bash # Specify an icon in config.json -"icon": "mdi-cloud", -"iconColor": "blue-500", # optional, defaults to a contrasting color -"iconBG": "gray-200", # optional, defaults to a complementary color -"iconBubble": false, # optional, defaults to true +"icon": "mdi-cloud" ``` # Docker compose diff --git a/src/components/icon.tsx b/src/components/icon.tsx index 0179470..675d540 100644 --- a/src/components/icon.tsx +++ b/src/components/icon.tsx @@ -70,6 +70,12 @@ const IconBlank: React.FunctionComponent = ({ index }) => { ); }; +enum IconType { + uri, + material, + dashboard, +} + interface IIconBaseProps { icon: string; iconColor?: string; @@ -78,51 +84,74 @@ interface IIconBaseProps { } const IconBase: React.FunctionComponent = ({ icon, iconBG, iconBubble, iconColor }) => { + let iconType: IconType = IconType.uri; + if (icon.startsWith("http") || icon.startsWith("/")) { - /* Relative or absolute icon URI */ - return ( - - ); + iconType = IconType.uri; + } else if (icon.startsWith("mdi-")) { + iconType = IconType.material; + } else { + iconType = IconType.dashboard; } - if (icon.startsWith("mdi-")) { - /* Material Design icon */ - const iconName = icon.replace("mdi-", "").replace(".svg", ""); - let iconClassName = - iconBubble === false - ? "block w-16 h-16 overflow-hidden" - : "block w-16 h-16 rounded-2xl border border-black/5 shadow-sm overflow-hidden"; + // Everyone starts the same size + let iconClassName = "block w-16 h-16 overflow-hidden bg-contain"; - if (is.null(iconBG)) { - iconClassName += ` bg-slate-200`; - } else { - iconClassName += ` bg-${iconBG}`; - } + if (is.null(iconBubble) || iconBubble !== false) { + iconClassName += " rounded-2xl border border-black/5 shadow-sm"; + } - return ( -
-
; + case IconType.dashboard: + icon = icon.replace(".png", "").replace(".jpg", "").replace(".svg", ""); + return ( + -
- ); - } + ); + case IconType.material: + icon = icon.replace("mdi-", "").replace(".svg", ""); - /* Dashboard icon */ - const iconName = icon.replace(".png", "").replace(".jpg", "").replace(".svg", ""); - return ( - - ); + return ( +
+
+
+ ); + } };