Dashy

Dashy helps you organize your self-hosted services by making them accessible from a single place

User Showcase | Live Demo | Getting Started | Documentation | GitHub

Awesome Self-Hosted License MIT Current Version Docker Pulls GitHub Status Known Vulnerabilities

Contents

- **Getting Started** - [๐ŸŒˆ Features](#features-) - [โšกDemo](#demo-) - [๐Ÿš€ Getting Started](#getting-started-) - [๐Ÿ”ง Configuring](#configuring-) - **Feature Overview** - [๐ŸŽจ Theming](#theming-) - [๐Ÿงธ Icons](#icons-) - [๐Ÿšฆ Status Indicators](#status-indicators-) - [๐Ÿ’‚ Authentication](#authentication-) - [๐Ÿ–ฑ๏ธ Opening Methods](#opening-methods-%EF%B8%8F) - [๐Ÿ‘“ Alternate Views](#alternate-views-) - [๐Ÿ”Ž Searching and Shortcuts](#searching-and-shortcuts-) - [โš™๏ธ Config Editor](#config-editor-%EF%B8%8F) - [โ˜ Cloud Backup & Sync](#cloud-backup--sync-) - [๐ŸŒŽ Language Switching](#language-switching-) - [๐ŸŒณ Dashboard Info](#setting-dashboard-info-) - **Community** - [๐Ÿ“Š System Requirements](#system-requirements-) - [๐Ÿ™‹โ€โ™€๏ธ Getting Help](#getting-help-%EF%B8%8F) - [๐Ÿ› Raising Issues](#raising-issues-) - [๐Ÿ’– Supporting Dashy](#supporting-dashy-) - [๐Ÿ† Credits](#credits-) - [๐Ÿงฑ Developing](#developing-) - [๐Ÿ—ž๏ธ Release Schedule](#release-schedule-) - [๐Ÿ“˜ Documentation](#documentation-) - [๐Ÿ›ฃ๏ธ Roadmap](#roadmap-) - [๐Ÿ™Œ Alternatives](#alternatives-) - [๐Ÿ“œ License](#license-)

## Features ๐ŸŒˆ - ๐Ÿ”Ž Instant search by name, domain or tags + customizable hotkeys & keyboard shortcuts - ๐ŸŽจ Multiple built-in color themes, with UI color editor and support for custom CSS - ๐Ÿงธ Many icon options - Font-Awesome, homelab icons, auto-fetching favicon, images, emojis, etc. - ๐Ÿšฆ Status monitoring for each of your apps / links for basic availability and uptime checking - ๐Ÿ’‚ Optional authentication with multi-user access, configurable privileges and SSO support - ๐ŸŒŽ Multi-language support, with 10+ human-translated languages, and more on the way - โ˜ Optional, encrypted, free off-site cloud backup and restore feature available - ๐Ÿ’ผ A workspace view, for easily switching between multiple apps at simultaneously - ๐Ÿ›ฉ๏ธ A minimal view, for use as a fast-loading browser startpage - ๐Ÿ–ฑ๏ธ Choose app launch method, either new tab, same tab, a pop-up modal or in the workspace view - ๐Ÿ“ Customizable layout, sizes, text, component visibility, sort order, behavior etc. - ๐Ÿ–ผ๏ธ Option for full-screen background image, custom nav-bar links, html footer, title, etc. - ๐Ÿš€ Easy to setup with Docker, or on bare metal, or with 1-Click cloud deployment - โš™๏ธ Easy single-file YAML-based configuration, and option to configure app through the UI - โœจ Under active development with improvements and new features added regularly - ๐Ÿค Small bundle size, fully responsive UI and PWA for basic offline access - ๐Ÿ†“ 100% free and open source - ๐Ÿ” Strong focus on privacy - ๐ŸŒˆ And loads more... ## Demo โšก > For more examples of Dashy in action, see: [**The Showcase**](./docs/showcase.md) **Live Instances**: [Demo 1](https://demo.dashy.to) (Live Demo) โ”† [Demo 2](https://live.dashy.to) (Dashy Links) โ”† [Demo 3](https://dev.dashy.to) (Dev Preview) **Screenshots**: Checkout the [Showcase](./docs/showcase.md), to see example dashboards from the community **Spin up your own demo**: [![One-Click Deploy with PWD](https://img.shields.io/badge/Play--with--Docker-Deploy-2496ed?style=flat-square&logo=docker)](https://labs.play-with-docker.com/?stack=https://raw.githubusercontent.com/Lissy93/dashy/master/docker-compose.yml) or [`docker run -p 8080:80 lissy93/dashy`](./docs/quick-start.md)

Demo

**[โฌ†๏ธ Back to Top](#dashy)** --- ## Getting Started ๐Ÿ›ซ > For full setup instructions, see: [**Deployment**](./docs/deployment.md) ### Deploying from Docker Hub ๐Ÿณ You will need [Docker](https://docs.docker.com/get-docker/) installed on your system ``` docker run -p 8080:80 lissy93/dashy ``` Or ```docker docker run -d \ -p 4000:80 \ -v /root/my-local-conf.yml:/app/public/conf.yml \ --name my-dashboard \ --restart=always \ lissy93/dashy:latest ``` [![Dashy on Docker Hub](https://dockeri.co/image/lissy93/dashy)](https://hub.docker.com/r/lissy93/dashy) See also examples [with Docker Compose](./docs/deployment.md#using-docker-compose). Dashy is also available via GHCR, and tags for other architectures (`arm32-7`, `arm64-v8`, etc) and set versions are supported > Once you've got Dashy running, see [App Management Docs](./docs/management.md), for info on using health checks, updating, backups, web-server configs, logs, performance, security and more. ### Deploying from Source ๐Ÿš€ You will need [git](https://git-scm.com/downloads), the latest or LTS version of [Node.js](https://nodejs.org/) and (optionally) [Yarn](https://yarnpkg.com/) installed on your system. - Get Code: `git clone https://github.com/Lissy93/dashy.git` and `cd dashy` - Configuration: Fill in you're settings in `./public/conf.yml` - Install dependencies: `yarn` - Build: `yarn build` - Run: `yarn start` > See docs [Full list of Dashy's commands](./docs/management.md#basic-commands) ### Deploy to the Cloud โ˜๏ธ Dashy supports 1-Click deployments on several popular cloud platforms. To spin up a new instance, just click a link below: - [ Deploy to Netlify](https://app.netlify.com/start/deploy?repository=https://github.com/lissy93/dashy) - [ Deploy to Heroku](https://heroku.com/deploy?template=https://github.com/Lissy93/dashy) - [ Deploy to Vercel](https://vercel.com/new/project?template=https://github.com/lissy93/dashy) - [ Deploy to Render](https://render.com/deploy?repo=https://github.com/lissy93/dashy/tree/deploy_render) - [ Deploy to GCP](https://deploy.cloud.run/?git_repo=https://github.com/lissy93/dashy.git) - [ Deploy to PWD](https://labs.play-with-docker.com/?stack=https://raw.githubusercontent.com/Lissy93/dashy/master/docker-compose.yml) > For more 1-click cloud deployments, see [Cloud Deployment](./docs/deployment.md#deploy-to-cloud-service) **[โฌ†๏ธ Back to Top](#dashy)** --- ## Configuring ๐Ÿ”ง > For full configuration documentation, see: [**Configuring**](./docs/configuring.md) All of Dashy's configuration is specified in a single [YAML](https://yaml.org/) file, located at `./public/conf.yml`. You can find a complete list of available options in th [Configuring Docs](/docs/configuring.md). If you're using Docker, you'll probably want to pass this file in as a Docker volume (e.g. `-v /root/my-local-conf.yml:/app/public/conf.yml`). The config can also be edited directly through the UI with changes written to your conf.yml file. After making any modifications the app needs to be rebuilt, which will happen automatically or can be trigger with `yarn build` or directly through the UI. You can check that your config is valid and matches Dashy's [schema](https://github.com/Lissy93/dashy/blob/master/src/utils/ConfigSchema.json), by running: `yarn validate-config`. Finally, you may find these [example config](https://gist.github.com/Lissy93/000f712a5ce98f212817d20bc16bab10) helpful for getting you started. **[โฌ†๏ธ Back to Top](#dashy)** --- ## Theming ๐ŸŽจ > For full theming documentation, see: [**Theming**](./docs/theming.md)

Example Themes

Dashy comes with a number of built-in themes, but it's also easy to make your own. You can either use the color editor, or your own custom CSS. All colors, and most other CSS properties are specified using CSS variables, which are [documented here](./docs/theming.md#css-variables), thereby customizing the look and feel of Dashy. Learn more about adding your own theme in the [docs](https://github.com/Lissy93/dashy/blob/master/docs/theming.md#adding-your-own-theme).

Example Themes

**[โฌ†๏ธ Back to Top](#dashy)** --- ## Icons ๐Ÿงธ > For full iconography documentation, see: [**Icons**](./docs/icons.md) Both sections and items can have an icon associated with them, and defined under the `icon` attribute. There are many options for icons, including Font Awesome support, automatic fetching from favicon, emojis, programmatically generated icons and direct local or remote URLs.

- **Favicon**: Set `icon: favicon` to fetch a services icon automatically from the URL of the corresponding application - **Font-Awesome**: To use any font-awesome icon, specify the category, followed by the icon name, e.g. `fas fa-rocket` or `fab fa-monero`. You can also use Pro icons if you have a license key, just set it under `appConfig.fontAwesomeKey` - **Home Lab Icons**: For common self-hosted services, you can use any icon from @WalkxCode's [dashboard-icons](https://github.com/WalkxCode/dashboard-icons) repo, by preceding it with `hl-`, e.g. `icon: hl-pihole` - **Emoji**: Use an emoji as a tile icon, by putting the emoji's code as the icon attribute. Emojis can be specified either as emojis (`๐Ÿš€`), unicode (`'U+1F680'`) or shortcode (`':rocket:'`) - **Generative**: Setting `icon: generative`, will generate a unique logo for a given service, based on it's specified URL or IP - **URL**: You can also pass in a URL to an icon asset, hosted either locally or using any CDN service. E.g. `icon: https://i.ibb.co/710B3Yc/space-invader-x256.png` - **Local Image**: To use a local image, store it in `./public/item-icons/` (or create a volume in Docker: `-v /local/image/directory:/app/public/item-icons/`) , and reference it by name and extension - e.g. set `icon: image.png` to use `./public/item-icon/image.png`. You can also use sub-folders here - **Simple Icons**: Use any brand/ logo icon from [simpleicons.org](https://simpleicons.org/) by setting the icon to `si-[icon-name]` - **Material Design Icons**: You can also use any icon from [materialdesignicons.com](https://dev.materialdesignicons.com/icons) by setting the icon to `mdi-[icon-name]` **[โฌ†๏ธ Back to Top](#dashy)** --- ## Status Indicators ๐Ÿšฆ > For full monitoring documentation, see: [**Status Indicators**](./docs/status-indicators.md) Dashy has an optional feature that can display a small icon next to each of your running services, indicating it's current status. This is useful if you are using Dashy as your homelab's start page, as it gives you an overview of the health of each of your running services. Hovering over the indicator will show additional information, including average response time and an error message for services which are down. By default, this feature is off, but you can enable it globally by setting `appConfig.statusCheck: true`, or enable/ disable it for an individual item, with `item[n].statusCheck`. You can also specify an time interval in seconds under `appConfig.statusCheckInterval`, between checks, if this value is `0`, then status is only checked on initial page load, which is the default behavior. Status checks use the `url` attribute, but to call a different endpoint instead, you can set `statusCheckUrl`. Custom headers can also be specified using `statusCheckHeaders`.

Status Checks demo

**[โฌ†๏ธ Back to Top](#dashy)** --- ## Authentication ๐Ÿ’‚ > For full authentication documentation, see: [**Authentication**](./docs/authentication.md) Dashy has full support for secure single-sign-on using [Keycloak](https://www.keycloak.org/) for secure, easy authentication, see [setup docs](/docs/authentication.md#keycloak) for a full usage guide There is also a simple login feature for basic access control, which doesn't require any additional setup. To enable this feature, just add an `auth` attribute under `appConfig`, containing an array of `users`, each with a username, SHA-256 hashed password and optional user type. ```yaml appConfig: auth: users: - user: alicia hash: 4D1E58C90B3B94BCAD9848ECCACD6D2A8C9FBC5CA913304BBA5CDEAB36FEEFA3 type: admin ``` **Guest Access**: By default, when authentication is configured no user can access your dashboard without first logging in. If you would like to allow for read-only access by unauthenticated users, then you can enable guest mode, by setting `appConfig.auth.enableGuestAccess: true`. **Granular Controls**: With basic login, it is also possible to control which sections are visible to which users. Under the `displayData` property of a section, you can pass an array of usernames to one of the following attributes: - `hideForUsers` - Section will be visible to all users, except for those specified in this list - `showForUsers` - Section will be hidden from all users, except for those specified in this list - `hideForGuests` - Section will be visible for all logged in users, but not for guests (if guest access is enabled)

Example login screen, using Vapourwave theme

For setup instructions for other access control systems, please see the [Alternative Auth Methods](./docs/authentication.md#alternative-authentication-methods) docs. **[โฌ†๏ธ Back to Top](#dashy)** --- ## Opening Methods ๐Ÿ–ฑ๏ธ > For full documentation on views and opening methods, see: [**Alternate Views**](./docs/alternate-views.md) One of the primary purposes of Dashy is to make launching commonly used apps and services as quick as possible. To aid in this, there are several different options on how items can be opened. You can configure your preference by setting the `target` property of any item, to one of the following values: - `sametab` - The app will be launched in the current tab - `newtab` - The app will be launched in a new tab - `modal` - Launch app in a resizable/ movable popup modal on the current page - `workspace` - Changes to Workspace view, and launches app - `top` - Opens in the top-most browsing context, useful if your accessing Dashy through an iframe You can also set the default opening method, which will be applied to all items that don't have a specified target, using `appConfig.defaultOpeningMethod`, to one of the above values. Even if the target is not set (or is set to `sametab`), you can still launch any given app in an alternative method: Alt + Click will open the modal, and Ctrl + Click will open in a new tab. You can also right-click on any item to see all options (as seen in the screenshot below). This custom context menu can be disabled by setting `appConfig.disableContextMenu: true`. In the workspace view, you can keep previously opened websites/ apps open in the background, by setting `appConfig.enableMultiTasking: true`. This comes at the cost of performance, but does mean that your session with each app is preserved, enabling you to quickly switch between your apps.

The modal and workspace views work by rendering the target application in an iframe. If you are getting a a `Refused to Connect` error, then you need to set the HTTP response header [`X-Frame-Options`](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/X-Frame-Options) to `ALLOW [url-for-dashy]`. See [the docs](./docs/troubleshooting.md#refused-to-connect-in-modal-or-workspace-view) for instructions on how to do this. --- ## Alternate Views ๐Ÿ‘“ As well as the default homepage, there is also: - A minimal view, useful for use as a browser start page - A workspace view, useful for visiting many apps simultaneously You can change the view from the UI, using the switch icon in the top-right corner, or select a default view in the config, under `appConfig.startingView` attribute (can be either `default`, `minimal` or `workspace`). Clicking the page title on any view will take you back to your default starting view.

Example of Workspace View
Workspace view demo

Example of Minimal View
Workspace view demo

**[โฌ†๏ธ Back to Top](#dashy)** --- ## Searching and Shortcuts ๐Ÿ”Ž > For full documentation on searching, see: [**Searching & Shortcuts**](./docs/searching.md) Quickly finding and launching applications is the primary aim of Dashy. To that end instant search and customizable keyboard shortcuts are built-in. To start filtering, just start typing. No need to select the search bar or use any special key. You can then use either the tab key or arrow keys to select and move between results, and hit enter to launch the currently selected application. You can also use `Alt + Enter` on a selected app to launch it in a popup modal, `Ctrl + Enter` to open in new tab, or right-click on it to see all opening methods. You can also add custom tags to a given item, to make finding them based on keywords easier. For example, in the following example, searching for 'Movies' will show 'Plex' ```yaml items: - title: Plex description: Media library icon: favicon url: https://plex.lab.local tags: [ movies, videos, music ] ``` For apps that you use regularly, you can set a custom keybinding. Use the `hotkey` parameter on a certain item to specify a numeric key, between `0 - 9`. You can then launch that app, by just pressing that key, which is very useful for services you use frequently. Example: ```yaml - title: Bookstack icon: far fa-books url: https://bookstack.local/ hotkey: 8 ``` To search the web directly through Dashy, just press enter after typing your query. Options for web search are set under `appConfig.webSearch`. There is built in support for [10+ search engines](./docs/searching.md#setting-search-engine), or [use your own custom provider](./docs/searching.md#using-custom-search-engine) or self-hosted instance. To disable web search all together, set: `webSearch: { disableWebSearch: true }` ```yaml webSearch: searchEngine: duckduckgo openingMethod: newtab ``` With the web search, you can also define your own bangs, to redirect results to any given app, website or search engine, when the query is preceded with a certain character sequence (usually beginning in `/`, `!` or `:`). For example, with the below code, typing `:git dashy` will search GitHub for Dashy, or `/w docker` will open the Docker Wikipedia page. ```yaml webSearch: searchBangs: /r: reddit /w: wikipedia /s: https://whoogle.local/search?q= ':wolf': wolframalpha ':so': stackoverflow ':git': github ``` Hit `Esc` at anytime to close any open apps, clear the search field, or hide any modals. **[โฌ†๏ธ Back to Top](#dashy)** --- ## Config Editor โš™๏ธ > For full config documentation, see: [**Configuring**](./docs/configuring.md) As well as passing in a YAML config file, you can also configure the app directly through the UI, and preview changes live. To edit any section or item, right-click on it, and select "Edit", or enter the Edit Mode (using the Pen icon in the top-right), then click any part of the page to edit. Changes will be visible immediately, but will not be saved until you click "Save to Disk" or "Save Locally".

Interactive Editor demo

Under the config menu, you can export, view, backup, or reset app config, as well as edit the raw config file in a text editor, with built-in schema validation.

Config Editor demo

A full list of available config options can be found [here](./docs/configuring.md). It's recommend to make and keep a backup of your configuration, to easily restore it into a new instance of Dashy. **[โฌ†๏ธ Back to Top](#dashy)** --- ## Cloud Backup & Sync โ˜ > For full backup documentation, see: [**Cloud Backup & Sync**](./docs/backup-restore.md) Dashy has an **optional** built-in feature for securely backing up your config to a hosted cloud service, and then restoring it on another instance. This is useful not only for backing up your configuration off-site, but it also enables Dashy to be used without having write a YAML config file. All data is fully E2E encrypted before being sent to the backend (done in [`CloudBackup.js`](https://github.com/Lissy93/dashy/blob/master/src/utils/CloudBackup.js) using [crypto.js](https://github.com/brix/crypto-js)'s AES method). The data is then sent to a [Cloudflare worker](https://developers.cloudflare.com/workers/learning/how-workers-works), and stored in a [KV](https://developers.cloudflare.com/workers/learning/how-kv-works) data store.

**[โฌ†๏ธ Back to Top](#dashy)** --- ## Language Switching ๐ŸŒŽ > For full internationalization documentation, see: [**Multi-Language Support**](./docs/multi-language-support.md) Dashy supports multiple languages and locales. When available, you're language should be automatically detected and applied on load, based on your browser or systems settings. But you can also select a language through the UI (under Config --> Switch Language), or set `appConfig.language` to your language (specified as a 2-digit [ISO 639-1 code](https://en.wikipedia.org/wiki/List_of_ISO_639-1_codes)). #### Supported Languages - ๐Ÿ‡ฌ๐Ÿ‡ง **English**: `en` - _Default_ - ๐Ÿ‡จ๐Ÿ‡ณ **Chinese**: `cn` - Contributed by **[@FormatToday](https://github.com/FormatToday)** - ๐Ÿ‡ณ๐Ÿ‡ฑ **Dutch**: `nl` - Contributed by **[@evroon](https://github.com/evroon)** - ๐Ÿ‡ฒ๐Ÿ‡ซ **French**: `fr` - Contributed by **[@EVOTk](https://github.com/EVOTk)** - ๐Ÿ‡ฉ๐Ÿ‡ช **German**: `de` - Contributed by **[@Niklashere](https://github.com/Niklashere)** - ๐Ÿ‡ณ๐Ÿ‡ด **Norwegian Bokmรฅl**: `nb` - Contributed by **[@rubjo](https://github.com/rubjo)** - ๐Ÿ‡ต๐Ÿ‡ฑ **Polish**: `pl` - Contributed by **[@skaarj1989](https://github.com/skaarj1989)** - ๐Ÿ‡ช๐Ÿ‡ธ **Spanish**: `es` - Contributed by **[@lu4t](https://github.com/lu4t)** - ๐Ÿ‡ธ๐Ÿ‡ฎ **Slovenian**: `sl` - Contributed by **[@UrekD](https://github.com/UrekD)** - ๐Ÿ‡ฎ๐Ÿ‡น **Italian**: `it` - Machine Translated *(awaiting human review)* - ๐Ÿ‡ต๐Ÿ‡น **Portuguese**: `pt` - Machine Translated *(awaiting human review)* - ๐Ÿ‡ท๐Ÿ‡บ **Russian**: `ru` - Contributed by Anon - ๐Ÿ‡ฆ๐Ÿ‡ช **Arabic**: `ar` - Contributed by Anon - ๐Ÿ‡ฎ๐Ÿ‡ณ **Hindi**: `hi` - Contributed by Anon - ๐Ÿ‡ฏ๐Ÿ‡ต **Japanese**: `ja` - Contributed by Anon #### Add your Language I would love for Dashy to be available to everyone, without language being a barrier to entry for non-native English speakers. If you have a few minutes to spare, you're help with translating it would be very much appreciated. It's quite a quick task, all text is in [a single JSON file](https://github.com/Lissy93/dashy/tree/master/src/assets/locales), and you don't have to translate it all. For more info, see the [Adding a New Language Docs](./docs/multi-language-support.md#adding-a-new-language). **[โฌ†๏ธ Back to Top](#dashy)** --- ## Setting Dashboard Info ๐ŸŒณ Page settings are defined under [`pageInfo`](https://github.com/Lissy93/dashy/blob/master/docs/configuring.md#pageinfo). Here you can set things like title, sub-title, navigation links, footer text, etc. For example: ```yaml pageInfo: title: Home Lab description: Dashy navLinks: - title: Home path: / - title: Server Monitoring path: https://server-start.local - title: Start Page path: https://start-page.local footerText: 'My Awesome Dashboard. Built with Dashy' ``` You can also edit this through the UI, by entering Edit mode, then clicking Edit Page Info.

Edit Page Info Screenshot

**[โฌ†๏ธ Back to Top](#dashy)** --- ## System Requirements ๐Ÿ“Š The hardware requirements vary depending on where and how you are running Dashy. Generally speaking, on a bare metal system or Docker container, 1GB of memory should be more than enough, and depending on weather you are using your own assets, then 1GB of disk space should be sufficient. If you are using one of the 1-click cloud deployment methods, serving the app through a CDN or using a static hosting provider, then there are no specific requirements, as the built app is just a series of static JS files, and so is very light-weight. Dashy also wells run on low-powered ARM-based single board computers, such as a Raspberry Pi (tested on Pi 3) **Browser Support** ![Chrome](https://raw.githubusercontent.com/alrra/browser-logos/master/src/chrome/chrome_48x48.png) | ![Firefox](https://raw.githubusercontent.com/alrra/browser-logos/master/src/firefox/firefox_48x48.png) | ![IE](https://raw.githubusercontent.com/alrra/browser-logos/master/src/edge/edge_48x48.png) | ![Opera](https://raw.githubusercontent.com/alrra/browser-logos/master/src/opera/opera_48x48.png) | ![Safari](https://raw.githubusercontent.com/alrra/browser-logos/master/src/safari/safari_48x48.png) --- | --- | --- | --- | --- | Latest โœ” | Latest โœ” | 10+ โœ” | Latest โœ” | 6.1+ โœ” | --- ## Getting Help ๐Ÿ™‹โ€โ™€๏ธ > For general discussions, check out the **[Discussions Board](https://github.com/Lissy93/dashy/discussions)** If you're having trouble getting things up and running, feel free to ask a question. The best way to do so is in the [discussion](https://github.com/Lissy93/dashy/discussions), or if you think you think the issue is on Dashy's side, you can [raise a ticket](https://github.com/Lissy93/dashy/issues/new/choose). It's best to check the [docs](./docs), [previous issues](https://github.com/Lissy93/dashy/issues?q=label%3A%22%F0%9F%A4%B7%E2%80%8D%E2%99%82%EF%B8%8F+Question%22+) and [troubleshooting guide](./docs/troubleshooting.md) first, as often the solution is already there. **[โฌ†๏ธ Back to Top](#dashy)** ## Raising Issues ๐Ÿ› Found a bug, or something that isn't working as you'd expect? Please raise it as an issue so that it can be resolved. Feature requests are also welcome. Similarlty, feedback is very useful, as it helps me know what areas of Dashy need some improvement. - [Raise a Bug ๐Ÿ›](https://github.com/Lissy93/dashy/issues/new?assignees=lissy93&labels=%F0%9F%90%9B+Bug&template=bug.yml&title=%5BBUG%5D+%3Ctitle%3E) - [Submit a Feature Request ๐Ÿฆ„](https://github.com/Lissy93/dashy/issues/new?template=feature-request.yml) - [Share Feedback ๐ŸŒˆ](https://github.com/Lissy93/dashy/issues/new?assignees=&labels=%F0%9F%8C%88+Feedback&template=share-feedback.md&title=%5BFEEDBACK%5D) **Issue Status** [![Resolution Time](http://isitmaintained.com/badge/resolution/lissy93/dashy.svg)](https://isitmaintained.com/project/lissy93/dashy) [![Open Issues](http://isitmaintained.com/badge/open/lissy93/dashy.svg)](https://github.com/Lissy93/dashy/issues) [![Closed Issues](https://badgen.net/github/closed-issues/lissy93/dashy)](https://github.com/Lissy93/dashy/issues?q=is%3Aissue+is%3Aclosed) [![GitHub Discussions](https://img.shields.io/github/discussions/lissy93/dashy) ](https://github.com/Lissy93/dashy/discussions) **[โฌ†๏ธ Back to Top](#dashy)** ## Supporting Dashy ๐Ÿ’– > For full details, and other ways you can help out, see: [**Contributing**](./docs/contributing.md) If you're using Dashy, and would like to help support it's development, then that would be awesome! Contributions of any type, however small are always very much appreciated, and you will be appropriately credited for your effort. Several areas that we need a bit of help with at the moment are: - Translating - Help make Dashy available to non-native English speakers by [adding youre language](./docs/multi-language-support.md#adding-a-new-language) - Donate a small amount, by [Sponsoring @Lissy93 on GitHub](https://github.com/sponsors/Lissy93) and receive some extra perks! - Complete a [short survey](https://survey.typeform.com/to/gl0L68ou), to have your say about future features - Share your dashboard in the [Showcase](https://github.com/Lissy93/dashy/blob/master/docs/showcase.md#dashy-showcase-), to provide inspiration for others - Join the [discussion](https://github.com/Lissy93/dashy/discussions), help answer other users questions, suggest features, share tips and ask questions - Spread the word, by sharing Dashy or a screenshot of your dashboard, to help new users discover it - Submit a PR, to add a new feature, fix a bug, update the docs, add a theme or something else - Star Dashy on GitHub/ DockerHub or leave an upvote / review on [these platforms](https://github.com/Lissy93/dashy/blob/master/docs/contributing.md#star-upvote-or-leave-a-review) [![Sponsor Lissy93 on GitHub](./docs/assets/sponsor-button.svg)](https://github.com/sponsors/Lissy93) **[โฌ†๏ธ Back to Top](#dashy)** ## Credits ๐Ÿ† > For a full list of credits, and attributions to packages used within Dashy, see: [**Credits**](./docs/credits.md) Thank you so much to everyone who has helped with Dashy so far, every contribution is very much appreciated. #### Sponsors Huge thanks to the sponsors helping to support Dashy's development!
mfnalex
Mfnalex
Robert-Ernst
Robert Ernst
#### Contributors [![Auto-generated contributors](https://raw.githubusercontent.com/Lissy93/dashy/master/docs/assets/CONTRIBUTORS.svg)](./docs/credits.md) #### Packages Dashy was made possible thanks to the following packages and components. For more details on each, see [Dependency Credits](./docs/credits.md#dependencies-). Full credit to their respective authors. - **Utils**: [`crypto-js`](https://github.com/brix/crypto-js), [`axios`](https://github.com/axios/axios), [`ajv`](https://github.com/ajv-validator/ajv) - **Components**: [`vue-select`](https://github.com/sagalbot/vue-select) by @sagalbot, [`vue-js-modal`](https://github.com/euvl/vue-js-modal) by @euvl, [`v-tooltip`](https://github.com/Akryum/v-tooltip) by @Akryum, [`vue-material-tabs`](https://github.com/jairoblatt/vue-material-tabs) by @jairoblatt, [`JsonEditor`](https://github.com/josdejong/jsoneditor) by @josdejong, [`vue-toasted`](https://github.com/shakee93/vue-toasted) by @shakee93 - **Core**: Vue.js, TypeScript, SCSS, Node.js, ESLint - **Backup & sync**: This server uses [Cloudflare workers](https://workers.cloudflare.com/) plus [KV](https://developers.cloudflare.com/workers/runtime-apis/kv) and [web crypto](https://developers.cloudflare.com/workers/runtime-apis/web-crypto) - **Services**: The 1-Click demo uses [Play-with-Docker Labs](https://play-with-docker.com/). Code is hosted on [GitHub](https://github.com), Docker image is hosted on [DockerHub](https://hub.docker.com/), and the demos are hosted on [Netlify](https://www.netlify.com/). - **Actions**: [`action-autotag`](https://github.com/butlerlogic/action-autotag) by @butlerlogic, [`contributors-list`](https://github.com/bubkoo/contributors-list), [`github-pages-deploy-action`](https://github.com/JamesIves/github-pages-deploy-action), [`is-sponsor-label-action`](https://github.com/JasonEtco/is-sponsor-label-action), [`issues-translate-action`](https://github.com/tomsun28/issues-translate-action) by @tomsun28, [`pr-commenter-action`](https://github.com/exercism/pr-commenter-action) by @exercism, [`snyk node`](https://github.com/snyk/actions/node) by @snyk, and [`yarn-lock-changes`](https://github.com/Simek/yarn-lock-changes) by @Simek. See [all action credits](/docs/credits.md#actions) **[โฌ†๏ธ Back to Top](#dashy)** ## Developing ๐Ÿงฑ > For full development documentation, see: [**Developing**](./docs/developing.md) [![Open Project in VS Code](https://img.shields.io/badge/Open_in-VS_Code-863cfc?style=flat-square&logo=visualstudiocode)](https://open.vscode.dev/Lissy93/Dashy) [![Open in GitPod](https://img.shields.io/badge/Open_in-GitPod-ffae33?style=flat-square&logo=gitpod)](https://gitpod.io/#github.com/lissy93/dashy.git) [![Open in GitHub Code Spaces](https://img.shields.io/badge/Open_in-Code%20Spaces-131313?style=flat-square&logo=github)](https://github.dev/Lissy93/dashy) Before getting started, you'll need [Git](https://git-scm.com/downloads), [Node](https://nodejs.org/en/download/) and optionally [Yarn](https://yarnpkg.com/) (run `npm i -g yarn`) installed. To set up the development environment: 1. Get Code: `git clone https://github.com/Lissy93/dashy.git` and `cd dashy` 2. Install dependencies: `yarn` 3. Start dev server: `yarn dev` Hot reload is enabled, so changes will be automatically detected, compiled and refreshed. Like most Git repos, we are following the [Github Flow](https://guides.github.com/introduction/flow) standard. 1. Create a branch (or fork if you're not a collaborator) 2. Code some awesome stuff, then add and commit your changes 3. Create a Pull Request, complete the checklist and ensure the build succeeds 4. Follow up with any reviews on your code 5. Merge ๐ŸŽ‰ Branch names are specified in the following format: `[TYPE]/[TICKET]_[TITLE]`. E.g. `FEATURE/420_Awesome-feature` or `FIX/690_login-server-error`. Most commit messages use git [commit emojis](https://gist.github.com/parmentf/035de27d6ed1dce0b36a) - e.g. โœจ = New feature, ๐Ÿ› = Bug fix, ๐Ÿ’„ = UI stuff, ๐Ÿšง = Work in progress, ๐ŸŒ = Language, ๐Ÿ”– = New release, and so on. Take a look at [gitmoji.dev](https://gitmoji.dev/) for a list of what each emoji indicates Before you submit your pull request, please ensure you've checked off all the boxes in the template. For your PR to be merged, it must: - Must be backwards compatible - Any new features should be documented - The build, lint and tests (run by GH actions) should all pass (there are some exceptions) - There must not be any merge conflicts If you're new to web development, I've put together a short [list of resources](https://github.com/Lissy93/dashy/blob/master/docs/developing.md#resources-for-beginners), to help beginners get started **Repo Status**: [![Open PRs](https://flat.badgen.net/github/open-prs/lissy93/dashy?icon=github)](https://github.com/Lissy93/dashy/pulls) [![Total PRs](https://flat.badgen.net/github/prs/lissy93/dashy?icon=github)](https://github.com/Lissy93/dashy/pulls?q=) [![GitHub commit activity](https://img.shields.io/github/commit-activity/m/lissy93/dashy?style=flat-square)](https://github.com/Lissy93/dashy/commits/master) [![Last Commit](https://flat.badgen.net/github/last-commit/lissy93/dashy?icon=github)](https://github.com/Lissy93/dashy/commits/master) [![Contributors](https://flat.badgen.net/github/contributors/lissy93/dashy?icon=github)](https://github.com/Lissy93/dashy/graphs/contributors) **[โฌ†๏ธ Back to Top](#dashy)** --- ## Release Schedule ๐Ÿ—ž๏ธ > For full release, automation and CI documentation, see: [**Releases & Workflows**](./docs/release-workflow.md) Dashy is under active development, with features, improvements and changes pushed almost daily. We're using [Semantic Versioning](https://semver.org/), to indicate major, minor and patch versions. You can find the current version number in the readme, and check your apps version under the config menu. The version number is pulled from the [package.json](https://github.com/Lissy93/dashy/blob/master/package.json#L3) file. Typically there is a new major release every 2 - 4 weeks, usually on Sunday, and you can view these under the [Releases Page](https://github.com/Lissy93/dashy/releases) and [on DockerHub](https://hub.docker.com/r/lissy93/dashy/tags). New minor versions are pushed several times a week, and are [tagged here](https://github.com/Lissy93/dashy/tags). For a full breakdown of each change, you can view the [Changelog](https://github.com/Lissy93/dashy/blob/master/.github/CHANGELOG.md). Each new feature or significant change needs to be submitted through [a pull request](https://github.com/Lissy93/dashy/pulls?q=is%3Apr), which makes it easy to review and track these changes, and roll back if needed. **[โฌ†๏ธ Back to Top](#dashy)** --- ## Documentation ๐Ÿ“˜ > For full docs, see: **[Documentation Contents](./docs/readme.md)** #### Running Dashy - ๐Ÿ’จ [Quick Start](/docs/quick-start.md) - TDLR guide on getting Dashy up and running in under 5 minutes - ๐Ÿš€ [Deployment](/docs/deployment.md) - Full guide on setting up Dashy on various different environments - ๐Ÿ”ง [Configuring](/docs/configuring.md) - Complete list of all available options in the config file - ๐Ÿ’ป [Management](/docs/management.md) - Managing your app, updating, security, web server configuration, etc - ๐Ÿš’ [Troubleshooting](/docs/troubleshooting.md) - Common errors and problems, and how to fix them #### Development and Contributing - ๐Ÿงฑ [Developing](/docs/developing.md) - Running Dashy development server locally, and general workflow - ๐Ÿ›Ž๏ธ [Development Guides](/docs/development-guides.md) - Common development tasks, to help new contributors - ๐Ÿ’– [Contributing](/docs/contributing.md) - How to contribute to Dashy - ๐ŸŒŸ [Showcase](/docs/showcase.md) - See how others are using Dashy, and share your dashboard - ๐Ÿ† [Credits](/docs/credits.md) - Shout out to the amazing people who have contributed so far - ๐Ÿ—ž๏ธ [Release Workflow](/docs/release-workflow.md) - Info about releases, CI and automated tasks #### Feature Docs - ๐Ÿ›ก๏ธ [Authentication](/docs/authentication.md) - Guide to setting up authentication to protect your dashboard - ๐Ÿงฟ [Alternate Views](/docs/alternate-views.md) - Outline of available pages / views and item opening methods - ๐Ÿ’พ [Backup & Restore](/docs/backup-restore.md) - Guide to Dashy's cloud sync feature - ๐Ÿงธ [Icons](/docs/icons.md) - Outline of all available icon types for sections and items - ๐ŸŒ [Language Switching](/docs/multi-language-support.md) - How to change language, add a language, or update text - ๐Ÿšฆ [Status Indicators](/docs/status-indicators.md) - Using Dashy to monitor uptime and status of your apps - ๐Ÿ” [Searching & Shortcuts](/docs/searching.md) - Finding and launching your apps, and using keyboard shortcuts - ๐ŸŽจ [Theming](/docs/theming.md) - Complete guide to applying, writing and modifying themes and styles #### Misc - ๐Ÿ” [Privacy & Security](/docs/privacy.md) - List of requests, potential issues, and security resources - ๐Ÿ“„ [License](/LICENSE) - Copy of the MIT License - โš–๏ธ [Legal](/.github/LEGAL.md) - Licenses of direct dependencies - ๐Ÿ“ [Code of Conduct](/.github/CODE_OF_CONDUCT.md) - Contributor Covenant Code of Conduct - ๐ŸŒณ [Changelog](/.github/CHANGELOG.md) - Details of recent changes, and historical versions **[โฌ†๏ธ Back to Top](#dashy)** --- ## Roadmap ๐Ÿ›ฃ๏ธ > For past and future app updates, see: [**Changelog**](/.github/CHANGELOG.md) The following features and tasks are planned for the near future. - Widget support- cards showing live stats and interactive content from your self-hosted services - โœ… UI editor and visual configurator - Conversion to TypeScript - Improved test coverage **[โฌ†๏ธ Back to Top](#dashy)** --- ## Alternatives ๐Ÿ™Œ There are a few self-hosted web apps, that serve a similar purpose to Dashy. If you're looking for a dashboard, and Dashy doesn't meet your needs, I highly recommend you check these projects out! - [Flame](https://github.com/pawelmalak/flame) by @pawelmalak (`MIT`) - [HomeDash2](https://lamarios.github.io/Homedash2) - [Homer](https://github.com/bastienwirtz/homer) (`Apache License 2.0`) - [Organizr](https://organizr.app/) (`GPL-3.0 License`) - [Heimdall](https://github.com/linuxserver/Heimdall) (`MIT`) - [Smashing](https://github.com/Smashing/smashing) (`MIT`) - See more ๐Ÿ‘‰ [Awesome Self-Hosted](https://github.com/awesome-selfhosted/awesome-selfhosted#personal-dashboards) **[โฌ†๏ธ Back to Top](#dashy)** --- ## License ๐Ÿ“œ Dashy is License under [MIT X11](https://en.wikipedia.org/wiki/MIT_License) ``` Copyright ยฉ 2021 Alicia Sykes Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the โ€œSoftwareโ€), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED โ€œAS ISโ€, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWAREOR THE USE OR OTHER DEALINGS IN THE SOFTWARE. Except as contained in this notice, Dashy shall not be used in advertising or otherwise to promote the sale, use or other dealings in this Software without prior written authorization from the repo owner. ``` **TDLR;** _You can do whatever you like with Dashy: use it in private or commercial settings,_ _redistribute and modify it. But you must display this license and credit the author._ _There is no warranty that this app will work as expected, and the author cannot be held_ _liable for anything that goes wrong._ For more info, see TLDR Legal's [Explanation of MIT](https://tldrlegal.com/license/mit-license) [![FOSSA Status](https://app.fossa.com/api/projects/git%2Bgithub.com%2FLissy93%2Fdashy.svg?type=large)](https://app.fossa.com/projects/git%2Bgithub.com%2FLissy93%2Fdashy?ref=badge_large) **[โฌ†๏ธ Back to Top](#dashy)** ---






Thank you for Visiting