A dynamically-populated homepage that uses Starbase 80's config-template rendering, in combination with consul-template's dynamic service rendering, to create live dashboards for users.
.github/workflows | ||
.vscode | ||
public | ||
src | ||
.dockerignore | ||
.gitignore | ||
compose.yml | ||
default.conf | ||
docker-entrypoint.sh | ||
dockerfile | ||
index.html | ||
license | ||
package-lock.json | ||
package.json | ||
postcss.config.js | ||
preview-dark.jpg | ||
preview.jpg | ||
readme.md | ||
start.js | ||
tailwind.config.js | ||
tsconfig.json | ||
version |
Starbase 80
DR T'ANA: (to Mariner) "You wanna goof around, go work on Starbase 80!"
JET: "Damn, Starbase 80?!"
About
A nice looking homepage for Docker containers or any services and links.
No actual integration with Docker. Loads instantly. Dark mode follows your OS.
If you make a change to the config JSON, restart this container and refresh.
Inspired by Ben Phelps' Homepage and Umbrel. Dedicated to Star Trek: Lower Decks.
Docker and source code
Live demo
Preview
Change history
1.3.0
- Removed all JavaScript as part of the build step. The image will be slightly larger and take longer to start up and shut down, but the page will be even lighter.
1.2.0
- Moved
config.json
bind mount destination to/app/src/config/config.json
for improved Portainer and volume support. The previous bind mount location will continue to work, but we recommend updating your bind mounts.
Docker
Sample Docker compose
services:
starbase80:
image: jordanroher/starbase-80
ports:
- 80:4173
environment:
- TITLE=Starbase 80
- LOGO=/starbase80.jpg
volumes:
- ./config.json:/app/src/config/config.json
- ./public/favicon.ico:/app/public/favicon.ico
- ./public/logo.png:/app/public/logo.png
- ./public/icons:/app/public/icons
Environment variables
Variable | Default | Notes |
---|---|---|
TITLE | My Website | Set to TITLE= to hide the title |
LOGO | /logo.png | Set to LOGO= to hide the logo |
HEADER | true | Set to false to hide the title and logo |
HEADERLINE | true | Set to false to turn off the header border line |
CATEGORIES | normal | Set to "small" for smaller, uppercase category labels |
BGCOLOR | theme(colors.slate.50) | Background color for light mode. Set to any hex color or Tailwind color using the theme syntax. |
BGCOLORDARK | theme(colors.gray.950) | Background color for dark mode. Set to any hex color or Tailwind color using the theme syntax. |
NEWWINDOW | true | Set to false to not have links open in a new window |
Volumes (bind mounts)
Path | Required | Notes |
---|---|---|
/app/src/config/config.json | true | Configuration with list of sites and links |
/app/public/favicon.ico | false | Website favicon |
/app/public/logo.png | false | Logo in the header |
/app/public/icons | false | Or wherever you want to put them, JSON icon paths are relative to /app/public |
Configuration
Sample config.json
[
{
"category": "Services",
"services": [
{
"name": "Archivebox",
"uri": "https://archivebox.mywebsite.com",
"description": "Backup webpages",
"icon": "/icons/archivebox.jpg"
},
{
"name": "Authelia",
"uri": "https://auth.mywebsite.com",
"description": "Authentication",
"icon": "/icons/authelia.png"
},
{
"name": "Calibre",
"uri": "https://calibre.mywebsite.com",
"description": "eBook library",
"icon": "/icons/calibre.png"
}
]
},
{
"category": "Devices",
"bubble": true,
"services": [
{
"name": "Router",
"uri": "http://192.168.1.1/",
"description": "Netgear Orbi",
"icon": "/icons/router.png"
},
{
"name": "Home Assistant",
"uri": "http://homeassistant.local:8123/",
"description": "Home automation",
"icon": "home-assistant",
"iconBubble": false
},
{
"name": "Synology",
"uri": "http://synology:5000",
"description": "Network storage",
"icon": "/icons/synology.png"
}
]
}
]
Category variables
Name | Default | Required | Notes |
---|---|---|---|
category | false | Displays above the list of services | |
bubble | false | false | Shows a bubble around category |
services | true | Array of services |
Service variables
Name | Default | Required | Notes |
---|---|---|---|
name | true | Title of service | |
uri | true | Hyperlink to resource | |
description | false | 2-3 words which appear below the title | |
icon | false | Relative URI, absolute URI, service name (Dashboard icon) or mdi- service name (Material Design icon) |
|
iconBG | false | Background color for icons. Hex code or Tailwind color (do not prefix with bg- ). |
|
iconColor | false | Only used as the fill color for Material Design icons. Hex code or Tailwind color (do not prefix with bg- ). |
|
iconBubble | true | false | If false the bubble and shadow are removed from the icon |
iconAspect | square | false | Set to "width" or "height" to constrain the icon to the width or height of the icon, respectively |
newWindow | false | Set to true or false to override the environment variable NEWWINDOW for this service |
Icons
Volume / bind mount
Create a volume or bind mount to a subfolder of /app/public
and specify a relative path.
# Your folder
compose.yml
- icons
- jellyfin.jpg
- ghost.jpg
- etc
# Bind mount
./icons:/app/public/icons
# Icon in config.json
"icon": "/icons/jellyfin.jpg"
Dashboard icons
Use Dashboard icons by specifying a name without any prefix.
# Icon in config.json
"icon": "jellyfin"
Material design
Use any Material Design icon by prefixing the name with mdi-
.
Fill the icon by providing an "iconColor."
Use "black" or "white" for those colors.
# Icon in config.json
"icon": "mdi-cloud",
"iconColor": "black"