Compare commits

..

1 Commits

Author SHA1 Message Date
Meier Lukas
8b85db06ec fix(metadata): align color scheme of icons to look good for background 2025-04-18 16:35:26 +02:00
2294 changed files with 30445 additions and 60857 deletions

4
.github/FUNDING.yml vendored
View File

@@ -1,4 +0,0 @@
# These are supported funding model platforms
open_collective: homarr
github: lammersbjorn

View File

@@ -14,30 +14,22 @@ body:
label: Icon name
description: The name has to be unique and should be kebab-case.
placeholder: e.g. "icon-name"
validations:
required: true
- type: textarea
attributes:
label: Paste light mode icon
description: |
Please paste the icon here. It will automatically upload it to github. This icon should be visible on a light background.
validations:
required: true
- type: textarea
attributes:
label: Paste dark mode icon
description: |
Please paste the icon here. It will automatically upload it to github. This icon should be visible on a dark background.
validations:
required: true
- type: dropdown
attributes:
label: Icon type
options:
- SVG
- PNG
validations:
required: true
- type: dropdown
attributes:
label: Categories

View File

@@ -10,30 +10,21 @@ body:
Once you've submitted the issue, sombody from the team will review it, before adding a label which automatically creates a pull request with the other filetypes.
If you submit a PNG icon, please note, that the SVG can not be generated from it.
- type: input
id: name
attributes:
label: Icon name
description: The name has to be unique and should be kebab-case.
placeholder: e.g. "icon-name"
validations:
required: true
- type: textarea
id: icon
attributes:
label: Paste icon
description: |
Please paste the icon here. It will automatically upload it to github.
validations:
required: true
- type: dropdown
id: type
attributes:
label: Icon type
options:
- SVG
- PNG
validations:
required: true
- type: dropdown
attributes:
label: Categories

View File

@@ -13,30 +13,22 @@ body:
label: Icon name
description: The name has to be unique and should be kebab-case.
placeholder: e.g. "icon-name"
validations:
required: true
- type: textarea
attributes:
label: Paste light mode icon
description: |
Please paste the icon here. It will automatically upload it to github. This icon should be visible on a light background.
validations:
required: true
- type: textarea
attributes:
label: Paste dark mode icon
description: |
Please paste the icon here. It will automatically upload it to github. This icon should be visible on a dark background.
validations:
required: true
- type: dropdown
attributes:
label: Icon type
options:
- SVG
- PNG
validations:
required: true
- type: textarea
attributes:
label: Additional information

View File

@@ -13,23 +13,17 @@ body:
label: Icon name
description: The name has to match the existing icon name.
placeholder: e.g. "icon-name"
validations:
required: true
- type: textarea
attributes:
label: Paste icon
description: |
Please paste the icon here. It will automatically upload it to github.
validations:
required: true
- type: dropdown
attributes:
label: Icon type
options:
- SVG
- PNG
validations:
required: true
- type: textarea
attributes:
label: Additional information

View File

@@ -11,7 +11,7 @@ jobs:
steps:
- name: Checkout Repository
uses: actions/checkout@v5
uses: actions/checkout@v3
with:
ref: ${{ github.ref_name }}

View File

@@ -1,15 +0,0 @@
name: Trigger Cloudflare Pages Build
on:
schedule:
- cron: '0 0 * * *' # Runs every day at midnight UTC
workflow_dispatch:
jobs:
cron_job:
runs-on: ubuntu-latest
steps:
- name: Run Your Cron Job
run: |
curl -X POST "${{ secrets.CLOUDFLARE_DEPLOY_HOOK_URL }}"

View File

@@ -8,7 +8,7 @@ jobs:
runs-on: ubuntu-latest
# This condition ensures the job only runs when the 'approved' label is added and the issue title starts with 'feat(icons): add '
if: |
contains(github.event.issue.labels.*.name, 'approved') &&
contains(github.event.issue.labels.*.name, 'approved') &&
startsWith(github.event.issue.title, 'feat(icons): add ')
env:
ICON_TYPE: ${{ contains(github.event.issue.labels.*.name, 'normal-icon') && 'normal' || 'monochrome' }}
@@ -20,13 +20,13 @@ jobs:
private_key: ${{ secrets.DASHBOARD_ICONS_MANAGER_APP_PRIVATE_KEY }}
app_id: ${{ vars.DASHBOARD_ICONS_MANAGER_APP_ID }}
- name: Checkout repository
uses: actions/checkout@v5
uses: actions/checkout@v4
env:
GITHUB_TOKEN: ${{ steps.obtainToken.outputs.token }}
- name: Set Up Python
uses: actions/setup-python@v4
with:
python-version: "3.14.0"
python-version: "3.11"
- name: Install Dependencies
run: |
pip install cairosvg pillow requests
@@ -49,6 +49,8 @@ jobs:
INPUT_ISSUE_FORM: ${{ steps.parse_issue_form.outputs.ISSUE_FORM }}
- name: Generate File Tree
run: python scripts/generate_file_tree.py svg png webp
- name: Generate ICONS.md
run: python scripts/generate_icons_page.py
- name: Generate full metadata file
run: python scripts/generate_metadata.py
- name: Extract icon name

View File

@@ -8,7 +8,7 @@ jobs:
runs-on: ubuntu-latest
# This condition ensures the job only runs when the 'approved' label is updated and the issue title starts with 'feat(icons): update '
if: |
contains(github.event.issue.labels.*.name, 'approved') &&
contains(github.event.issue.labels.*.name, 'approved') &&
startsWith(github.event.issue.title, 'feat(icons): update ')
env:
ICON_TYPE: ${{ contains(github.event.issue.labels.*.name, 'normal-icon') && 'normal' || 'monochrome' }}
@@ -20,13 +20,13 @@ jobs:
private_key: ${{ secrets.DASHBOARD_ICONS_MANAGER_APP_PRIVATE_KEY }}
app_id: ${{ vars.DASHBOARD_ICONS_MANAGER_APP_ID }}
- name: Checkout repository
uses: actions/checkout@v5
uses: actions/checkout@v4
env:
GITHUB_TOKEN: ${{ steps.obtainToken.outputs.token }}
- name: Set Up Python
uses: actions/setup-python@v4
with:
python-version: "3.14.0"
python-version: "3.11"
- name: Install Dependencies
run: |
pip install cairosvg pillow requests
@@ -49,6 +49,8 @@ jobs:
INPUT_ISSUE_FORM: ${{ steps.parse_issue_form.outputs.ISSUE_FORM }}
- name: Generate File Tree
run: python scripts/generate_file_tree.py svg png webp
- name: Generate ICONS.md
run: python scripts/generate_icons_page.py
- name: Generate full metadata file
run: python scripts/generate_metadata.py
- name: Extract icon name

View File

@@ -10,14 +10,14 @@ jobs:
contents: write
steps:
- name: Checkout Repository
uses: actions/checkout@v5
uses: actions/checkout@v3
with:
ref: ${{ github.ref_name }}
- name: Set Up Python
uses: actions/setup-python@v4
with:
python-version: "3.14.0"
python-version: "3.9"
- name: Install Dependencies
run: |
@@ -43,14 +43,14 @@ jobs:
contents: write
steps:
- name: Checkout Repository
uses: actions/checkout@v5
uses: actions/checkout@v3
with:
ref: ${{ github.ref_name }}
- name: Set Up Python
uses: actions/setup-python@v4
with:
python-version: "3.14.0"
python-version: "3.9"
- name: Commit and Push Changes
run: |
@@ -68,18 +68,23 @@ jobs:
contents: write
steps:
- name: Checkout Repository
uses: actions/checkout@v5
uses: actions/checkout@v3
with:
ref: ${{ github.ref_name }}
- name: Set Up Python
uses: actions/setup-python@v4
with:
python-version: "3.14.0"
python-version: "3.9"
- name: Generate ICONS.md
run: python scripts/generate_icons_page.py
- name: Commit and Push Changes
run: |
git config --global user.email "homarr-labs@proton.me"
git config --global user.name "Dashboard Icons Bot"
git add ICONS.md
git commit -m "ci(github-actions): generate ICONS.md" || exit 0
git pull --rebase origin ${{ github.ref_name }}
git push origin HEAD:${{ github.ref_name }}

View File

@@ -10,12 +10,12 @@ jobs:
steps:
- name: Checkout Repository
uses: actions/checkout@v5
uses: actions/checkout@v3
- name: Set Up Python
uses: actions/setup-python@v4
with:
python-version: "3.14.0"
python-version: "3.9"
- name: Install Dependencies
run: |
@@ -25,7 +25,7 @@ jobs:
run: python scripts/convert_svg_assets.py
- name: Upload Converted Icons
uses: actions/upload-artifact@v4
uses: actions/upload-artifact@v3
with:
name: converted-icons
path: |

View File

@@ -1,42 +1,30 @@
# Code of Conduct
## Code of Conduct
## Our Commitment
We are committed to creating a welcoming and harassment-free environment for everyone who contributes to our icon repository. This includes people of all genders, gender identities, sexual orientations, disabilities, appearances, body sizes, races, ages, religions, and nationalities.
We are committed to maintaining a welcoming and inclusive environment for everyone who contributes to our icon collection. This includes people of all backgrounds, identities, and experiences.
### Communication
## Expected Behavior
All communication should be appropriate for a professional audience, respectful, constructive, and considerate of people from different backgrounds. Please aim to create a positive and inclusive atmosphere.
- Be respectful and constructive in all communications
- Focus on what's best for the community
- Show empathy towards other community members
- Be open to different viewpoints and experiences
### Prohibited Behavior
## Unacceptable Behavior
We do not tolerate harassment, intimidation, discrimination, or any other inappropriate conduct, whether in communication or behavior. Prohibited actions include:
The following behaviors are unacceptable:
- The use of sexual language or imagery
- Deliberate intimidation or stalking
- Unwelcome sexual attention or harassment
- Inappropriate physical contact
- Disruptions during events or conversations
- Discrimination of any kind
- Harassment, discrimination, or intimidation
- Offensive comments related to personal characteristics
- Unwelcome sexual attention or advances
- Disruptive behavior in community spaces
- Any other conduct that could reasonably be considered inappropriate
### Reporting
## Reporting
If you witness or experience behavior that violates this code of conduct, please report it immediately to [homarr-labs@proton.me](mailto:homarr-labs@proton.me). All reports will be reviewed confidentially and promptly, and appropriate actions will be taken.
If you experience or witness behavior that violates this code:
### Consequences
1. Contact us at [homarr-labs@proton.me](mailto:homarr-labs@proton.me)
2. Provide as much detail as possible about the incident
3. All reports will be reviewed confidentially
Anyone violating this code of conduct may face consequences, such as warnings, removal from the repository, or a ban from future participation. We take violations seriously to ensure a safe and welcoming environment for everyone.
## Enforcement
### Acknowledgment
Violations of this code may result in:
- Warning
- Temporary suspension
- Permanent ban from the community
## Attribution
This Code of Conduct is adapted from the [Contributor Covenant](https://www.contributor-covenant.org/), version 2.0.
By contributing to this repository, you agree to adhere to this code of conduct. Thank you for helping us create an inclusive and supportive environment for all contributors.

View File

@@ -1,104 +1,104 @@
# Contributing to Dashboard Icons
![Contributions Welcome](https://img.shields.io/badge/contributions-welcome-brightgreen?style=flat-square)
Thank you for your interest in contributing to our icon collection! These guidelines will help ensure smooth collaboration and maintain the quality of our collection.
## Contribution Guidelines
Thank you for your interest in contributing to the icon repository! To ensure smooth collaboration, please follow these guidelines. Your contributions help make this project better.
## Table of Contents
- [Contributing to Dashboard Icons](#contributing-to-dashboard-icons)
- [Table of Contents](#table-of-contents)
- [Icon Specifications](#icon-specifications)
- [Format Requirements](#format-requirements)
- [Quality Standards](#quality-standards)
- [Light \& Dark Variants](#light--dark-variants)
- [File Naming](#file-naming)
- [Requesting New Icons](#requesting-new-icons)
- [Improving the Repository](#improving-the-repository)
- [Code of Conduct](#code-of-conduct)
- [Questions?](#questions)
- [Contribution Guidelines](#contribution-guidelines)
- [Table of Contents](#table-of-contents)
- [Icon Specifications](#icon-specifications)
- [Format](#format)
- [Cropping](#cropping)
- [Light and Dark Versions](#light-and-dark-versions)
- [File Naming](#file-naming)
- [Quality Requirements](#quality-requirements)
- [Git Commit Messages](#git-commit-messages)
- [Contribution Process](#contribution-process)
- [Code of Conduct](#code-of-conduct)
- [Contact](#contact)
## Icon Specifications
### Format Requirements
### Format
- **SVG Format**: All icons must be submitted in SVG format
- **Auto-Generated Formats**: PNG and WEBP versions are generated automatically with:
- Height: 512 pixels
- Width: Auto (maintaining aspect ratio)
- Transparency: Enabled
- **SVG Format Required**: All icons should be submitted in SVG format. If an SVG version is unavailable, a PNG version will suffice, and a WEBP version will be generated accordingly.
- **Automatic PNG and WEBP Generation**: PNG and WEBP versions are generated automatically from the SVG (or PNG) files using the following settings:
- **Dimensions**:
- Height: 512 pixels
- Width: Auto (maintaining aspect ratio)
- **Transparency**: Enabled
### Quality Standards
### Cropping
- **Clean SVG**: No embedded raster images in SVG files
- **Proper Cropping**: Remove empty space for proper centering
- Use [SVG Crop](https://svgcrop.com/) for assistance
- **No Upscaling**: Maintain original quality without artificial enlargement
- **Remove Empty Space**: Crop any empty space from your SVG files to ensure the icon is properly centered and sized. You can use [SVG Crop](https://svgcrop.com/) to assist with this.
### Light & Dark Variants
### Light and Dark Versions
For monochrome or single-color icons:
- **Light Variant**: Required for dark backgrounds
- Invert black elements
- Adjust colors for visibility
- **Dark Variant**: Required for light backgrounds
- Invert white elements
- Adjust colors for visibility
**Tool Recommendation**: [DEEditor](https://deeditor.com/) for color adjustments
- **Monochrome or Single Primary Color Icons**:
- If your icon is monochrome, please provide additional versions if applicable:
- **`-light` Version**: For icons primarily dark or using black as a main color, provide a `-light` version for light backgrounds.
- **`-dark` Version**: For icons primarily light or using white as a main color, provide a `-dark` version for dark backgrounds.
- **Examples**:
- A black logo should include a `-light` version where black is inverted.
- A multicolored logo using black should provide a `-light` version with the black replaced.
- **Tool Recommendation**: [DEEditor](https://deeditor.com/) can help adjust icon colors if needed.
### File Naming
- **Kebab Case**: Use lowercase with hyphens
- Example: "Nextcloud Calendar" → `nextcloud-calendar.svg`
- **Variant Suffixes**:
- `-light` for dark backgrounds
- `-dark` for light backgrounds
- **Kebab Case**: Name your files using kebab case (lowercase words separated by hyphens). For example, "Nextcloud Calendar" becomes `nextcloud-calendar.svg`.
- **Note**: Filenames are automatically converted to kebab case, but please double-check your naming to avoid conflicts or errors.
## Requesting New Icons
### Quality Requirements
To request a new icon:
- **No Upscaled Images**: Icons should maintain their original quality without artificial enlargement.
- **No Embedded Raster Images in SVGs**: Ensure that SVG files are true vector graphics without embedded raster images.
1. **Create an Issue**:
- Use the appropriate [issue template](https://github.com/homarr-labs/dashboard-icons/issues/new/choose)
- Choose between "Light & dark icon" or "Normal icon" template
## Git Commit Messages
2. **Provide Information**:
- Service/application name
- Official logo or icon source
- Any specific requirements or notes
- **Use Semantic Commits**: Follow the format <type>(scope): description:
- `feat(icons): add nextcloud-calendar` when adding new icons.
3. **Upload Icon** (optional):
- Attach the SVG file directly to the issue
- Include both light and dark variants if applicable
## Contribution Process
4. **Wait for Review**:
- Our team will review your request
- We may request adjustments if needed
- Once approved, we'll add the icon to the collection
### Adding an icon
## Improving the Repository
To add an icon to the repository, follow these steps:
To contribute to the repository itself:
1. **Create issue**: Create an issue from one of the add [templates](https://github.com/homarr-labs/dashboard-icons/issues/new/choose):
- **Light & dark icon**: Use this template to request a new icon with both light and dark versions.
- **Normal icon**: Use this template to request a new icon with a single version.
2. **Fill out the template**: Provide the requested information in the template. You can upload the icons directly to the issue.
3. **Wait for approval**: Wait for the issue to be approved by a maintainer. If any changes are needed, they will be requested in the issue.
4. **Maintainer approves & merges**: Once the issue is approved, a pull request with all the necessary changes will be created and merged by a maintainer.
1. **Fork the Repository**
2. **Make Your Changes**:
- Documentation improvements
- Website enhancements
- Repository maintenance
- Bug fixes
### Updating an icon
3. **Submit a Pull Request**:
- Use semantic commit messages following the format: `<type>(scope): description`
- `feat(icons): add nextcloud-calendar`
- `fix(website): correct icon preview`
- `docs(readme): update installation instructions`
- Reference any related issues
- Follow our [Code of Conduct](CODE_OF_CONDUCT.md)
To update an icon in the repository, follow these steps:
1. **Create issue**: Create an issue from the update [template](https://github.com/homarr-labs/dashboard-icons/issues/new/choose).
- **Light & dark icon**: Use this template to request a new icon with both light and dark versions.
- **Normal icon**: Use this template to request a new icon with a single version.
2. **Fill out the template**: Provide the requested information in the template. You can upload the icons directly to the issue.
3. **Wait for approval**: Wait for the issue to be approved by a maintainer. If any changes are needed, they will be requested in the issue.
4. **Maintainer approves & merges**: Once the issue is approved, a pull request with all the necessary changes will be created and merged by a maintainer.
### Change metadata / any other change
To change the metadata of an existing icon or any other change, follow these steps:
1. **Fork the Repository**: Create a fork of this repository on your GitHub account.
2. **Clone the Repository**: Clone your forked repository to your local machine.
3. **Add Your Icons**: Place your SVG icon(s) into the appropriate directory, following the specifications above.
4. **Commit Your Changes**: Commit your additions with clear and descriptive commit messages using Gitmoji.
5. **Push to Your Fork**: Push your committed changes to your forked repository on GitHub.
6. **Create a Pull Request**: Submit a pull request to the main repository for review.
## Code of Conduct
By contributing, you agree to abide by our [Code of Conduct](CODE_OF_CONDUCT.md). Please review it to understand the expectations for all participants.
## Questions?
## Contact
If you have any questions or need assistance, contact us at [homarr-labs@proton.me](mailto:homarr-labs@proton.me).
If you have any questions or need assistance, feel free to reach out at [homarr-labs@proton.me](mailto:homarr-labs@proton.me). I'm happy to help.

2228
ICONS.md Normal file

File diff suppressed because it is too large Load Diff

184
README.md
View File

@@ -1,126 +1,116 @@
# Dashboard Icons
> [!WARNING]
> The repository has been migrated from `walkxcode` to `homarr-labs` as I no longer have the capacity to maintain it. The Homarr team will now handle management and maintenance, ensuring that functionality remains unchanged. The project will always be usable outside of Homarr and no breaking changes will be introduced.
> ― *Bjorn*
>
> The license and guidelines have been updated, so please review them. To help with maintenance, contact us at [homarr-labs@proton.me](mailto:homarr-labs@proton.me).
[![jsDelivr hits](https://img.shields.io/jsdelivr/gh/hy/walkxcode/dashboard-icons?style=flat-square&color=%23A020F0)](https://www.jsdelivr.com/package/gh/walkxcode/dashboard-icons)
[![jsDelivr hits](https://img.shields.io/jsdelivr/gh/hy/homarr-labs/dashboard-icons?style=flat-square&color=%23A020F0)](https://www.jsdelivr.com/package/gh/homarr-labs/dashboard-icons)
[![GitHub Stars](https://img.shields.io/github/stars/homarr-labs/dashboard-icons?style=flat-square&color=yellow)](https://github.com/homarr-labs/dashboard-icons/stargazers)
[![Contributors](https://img.shields.io/github/contributors/homarr-labs/dashboard-icons?style=flat-square&color=blue)](https://github.com/homarr-labs/dashboard-icons/graphs/contributors)
[![jsDelivr hits (GitHub)](https://img.shields.io/jsdelivr/gh/hy/homarr-labs/dashboard-icons?style=flat-square&color=%23A020F0)](https://www.jsdelivr.com/package/gh/homarr-labs/dashboard-icons)
[![jsDelivr hits (GitHub)](https://img.shields.io/jsdelivr/gh/hy/walkxcode/dashboard-icons?style=flat-square&color=%23A020F0)](https://www.jsdelivr.com/package/gh/walkxcode/dashboard-icons)
> **Your definitive source for dashboard icons.**
[https://icons.homarr.dev](https://icons.homarr.dev)
A collection of over 1800 curated icons for services, applications and tools, designed specifically for dashboards and app directories.
## Dashboard Icons
**[→ Browse the collection at dashboardicons.com](https://dashboardicons.com)**
Your definitive source for dashboard icons.
[**View icons →**](https://icons.homarr.dev)
## Why Dashboard Icons?
## Table of Contents
- **Comprehensive Collection**: 1800+ icons for all popular services and tools
- **Consistent Style**: Uniform visual language across different services
- **Multiple Formats**: Available in SVG, PNG, and WEBP to suit your needs
- **Light & Dark Variants**: Icons optimized for both light and dark themes
- **Community-Driven**: Easy process to request missing icons
- [Dashboard Icons](#dashboard-icons)
- [Table of Contents](#table-of-contents)
- [Icon Requests](#icon-requests)
- [Supported Dashboards](#supported-dashboards)
- [Usage and Details](#usage-and-details)
- [Direct Links](#direct-links)
- [Base URL](#base-url)
- [Icon Name](#icon-name)
- [Formats](#formats)
- [Dark/Light Variants](#darklight-variants)
- [Downloading Icons](#downloading-icons)
- [Disclaimer](#disclaimer)
<p align="center">
<a href="https://dashboardicons.com">
<video width="650" autoplay loop muted playsinline>
<source src="assets/preview.mp4" type="video/mp4">
Your browser does not support the video tag.
</video>
</a>
</p>
## Icon Requests
## Using the Icons
If youd like to add a new icon, please review our [Contribution Guidelines](CONTRIBUTING.md) and then submit a request using [our issue templates](https://github.com/homarr-labs/dashboard-icons/issues/new/choose).
### Website
## Supported Dashboards
Find and download icons at [dashboardicons.com](https://dashboardicons.com):
1. Search for the icon you need
2. Click on an icon to view details
3. Choose your preferred format
4. Download or copy the direct link
### Direct Links
Use icons from CDN with this pattern:
```
<Base URL>/<Format>/<Icon Name>.<Format>
```
**Base URL options:**
- jsDelivr (recommended): `https://cdn.jsdelivr.net/gh/homarr-labs/dashboard-icons`
- GitHub Direct: `https://raw.githubusercontent.com/homarr-labs/dashboard-icons/main`
**Example:**
```html
<img src="https://cdn.jsdelivr.net/gh/homarr-labs/dashboard-icons/svg/plex.svg" alt="Plex">
```
### Technical Details
- **Naming Convention**: Kebab-case (lowercase with hyphens)
- Example: "Nextcloud Calendar" → `nextcloud-calendar`
- **Available Formats**:
- SVG: Vector format (original source)
- PNG: 512px height (auto-generated)
- WEBP: 512px height (auto-generated)
- **Variants**:
- `-light` suffix for dark backgrounds (e.g., `github-light.svg`)
- `-dark` suffix for light backgrounds (e.g., `github-dark.svg`)
- **Command Line**:
```bash
# Download with curl
curl -O https://cdn.jsdelivr.net/gh/homarr-labs/dashboard-icons/svg/nextcloud.svg
# Download with wget
wget https://cdn.jsdelivr.net/gh/homarr-labs/dashboard-icons/svg/nextcloud.svg
```
## Dashboard Integration
These icons integrate seamlessly with popular dashboard applications:
Dashboard Icons integrate seamlessly with several popular dashboards, including:
- [Homarr](https://github.com/ajnart/homarr)
- [Homepage](https://github.com/gethomepage/homepage)
- [Dashy](https://github.com/Lissy93/dashy)
...and many others!
## Usage and Details
## Contributing
### Direct Links
### Request Icons
You can use icons directly from GitHub or through the lightning-fast jsDelivr CDN. The structure of a direct link is as follows:
Need an icon that's not in our collection?
```
https://<Base URL>/<Format>/<Name>.<Format>
```
1. Check the [Contribution Guidelines](CONTRIBUTING.md) for specifications
2. Submit a request using our [issue templates](https://github.com/homarr-labs/dashboard-icons/issues/new/choose)
3. Provide service details and optionally upload the icon
4. Our team will review, optimize, and add it to the collection
For example, the WEBP version of the Nextcloud Calendar icon is available at:
### Improve the Repository
```
https://cdn.jsdelivr.net/gh/homarr-labs/dashboard-icons/webp/nextcloud-calendar.webp
```
Want to help with the repository itself?
#### Base URL
- Review our [Contribution Guidelines](CONTRIBUTING.md)
- Fork the repository, make your changes, and submit a pull request
- We welcome help with documentation, website improvements, and maintenance
We recommend using jsDelivr:
## Support
- `https://cdn.jsdelivr.net/gh/homarr-labs/dashboard-icons`
- **GitHub Issues**: Report bugs or request icons
- **Email**: [homarr-labs@proton.me](mailto:homarr-labs@proton.me)
Alternatively, you can reference the repository directly:
## Legal
- `https://raw.githubusercontent.com/homarr-labs/dashboard-icons/refs/heads/main`
**Disclaimer**: All product names, trademarks, and registered trademarks are the property of their respective owners. Icons are used for identification purposes only and do not imply endorsement.
#### Icon Name
**License**: This project is available under the terms of the [LICENSE](LICENSE) file.
Icons follow kebab-case formatting (all lowercase words separated by hyphens). For example, "Nextcloud Calendar" becomes `nextcloud-calendar`.
---
#### Formats
<p align="center">
Made with ♥ by the <a href="https://github.com/homarr-labs">Homarr Labs</a> team and contributors
</p>
Icons are available in these formats:
- SVG
- PNG
- WEBP
*All icons are generated from the base SVG file. For more details, see the [Contribution Guidelines](CONTRIBUTING.md).*
### Dark/Light Variants
Some icons may have very light or dark colors, which might reduce visibility on certain backgrounds. In such cases, a `-light` or `-dark` suffix is appended—for instance, "2fauth" becomes `2fauth-light`.
*More specifics are available in the [Contribution Guidelines](CONTRIBUTING.md).*
### Downloading Icons
1. **Browse & Download:**
Visit [https://icons.homarr.dev](https://icons.homarr.dev) to easily view and download icons.
2. **Using the Browser:**
On the icons page ([ICONS.md](ICONS.md)), right-click any icon link and select "Save link as".
**Note:** Loading the icons page displays every icon in the repository, which may lead to high data usage, slow performance, or even browser crashes on less powerful devices. For faster access, use the direct links or download icons individually.
3. **Using the Terminal:**
Download icons via `curl` or `wget` by using the following structure:
```bash
curl -O https://<Base URL>/<Format>/<Name>.<Format>
```
or
```bash
wget https://<Base URL>/<Format>/<Name>.<Format>
```
## Disclaimer
Unless stated otherwise, all images and assets in this repository—including product names, trademarks, and registered trademarks—belong to their respective owners and are used solely for identification purposes. Their inclusion does not imply endorsement.
For more details, please review the [LICENSE](LICENSE). If you have any questions or concerns, contact us at [homarr-labs@proton.me](mailto:homarr-labs@proton.me).

Binary file not shown.

View File

@@ -1,14 +0,0 @@
{
"base": "svg",
"aliases": [],
"categories": [
"Media"
],
"update": {
"timestamp": "2025-08-18T21:15:20.394373",
"author": {
"id": 150935816,
"login": "Dvorinka"
}
}
}

View File

@@ -1,14 +0,0 @@
{
"base": "svg",
"aliases": [],
"categories": [
"Development"
],
"update": {
"timestamp": "2025-06-18T05:14:18.987936",
"author": {
"id": 98148330,
"login": "YuSung-2022"
}
}
}

View File

@@ -10,7 +10,7 @@
}
},
"colors": {
"dark": "1password-dark",
"light": "1password"
"dark": "1password",
"light": "1password-dark"
}
}

View File

@@ -15,7 +15,7 @@
}
},
"colors": {
"dark": "2fauth",
"light": "2fauth-light"
"dark": "2fauth-light",
"light": "2fauth"
}
}

View File

@@ -10,7 +10,7 @@
}
},
"colors": {
"dark": "3cx",
"light": "3cx-light"
"dark": "3cx-light",
"light": "3cx"
}
}

View File

@@ -1,17 +0,0 @@
{
"base": "svg",
"aliases": [
"chan",
"luck"
],
"categories": [
"Communication"
],
"update": {
"timestamp": "2025-10-04T13:23:43.208364",
"author": {
"id": 123755552,
"login": "jashanpbpb"
}
}
}

View File

@@ -4,7 +4,7 @@
"7-zip"
],
"categories": [
"Developer-Tools"
"Developper-Tools"
],
"update": {
"timestamp": "2025-01-05T00:02:27Z",

View File

@@ -1,12 +0,0 @@
{
"base": "svg",
"aliases": [],
"categories": [],
"update": {
"timestamp": "2025-06-30T18:55:02.066881",
"author": {
"id": 1392556,
"login": "vitofasano"
}
}
}

View File

@@ -1,14 +0,0 @@
{
"base": "svg",
"aliases": [
"aboardhr"
],
"categories": [],
"update": {
"timestamp": "2025-09-06T18:26:21.574041",
"author": {
"id": 412615,
"login": "johanekhager"
}
}
}

View File

@@ -1,12 +0,0 @@
{
"base": "svg",
"aliases": [],
"categories": [],
"update": {
"timestamp": "2025-06-30T19:04:39.456692",
"author": {
"id": 2733215,
"login": "bakito"
}
}
}

View File

@@ -5,7 +5,7 @@
],
"categories": [
"Databases",
"Developer-Tools"
"Developper-Tools"
],
"update": {
"timestamp": "2022-08-16T17:22:56Z",

View File

@@ -1,14 +0,0 @@
{
"base": "png",
"aliases": [],
"categories": [
"Logistics"
],
"update": {
"timestamp": "2025-08-18T21:33:40.843973",
"author": {
"id": 442966,
"login": "hanjo"
}
}
}

View File

@@ -3,10 +3,10 @@
"aliases": [],
"categories": [],
"update": {
"timestamp": "2025-07-01T04:17:50.642999",
"timestamp": "2024-10-20T17:24:03Z",
"author": {
"id": 98704938,
"login": "seanmorley15"
"id": 71191962,
"name": "walkxcode"
}
}
}

View File

@@ -10,7 +10,7 @@
}
},
"colors": {
"dark": "affine",
"light": "affine-light"
"dark": "affine-light",
"light": "affine"
}
}

View File

@@ -1,14 +0,0 @@
{
"base": "png",
"aliases": [],
"categories": [
"Organization"
],
"update": {
"timestamp": "2025-09-10T18:16:01.315508",
"author": {
"id": 679198,
"login": "alexandru-calinoiu"
}
}
}

View File

@@ -1,14 +0,0 @@
{
"base": "svg",
"aliases": [],
"categories": [
"Media"
],
"update": {
"timestamp": "2025-09-08T13:09:10.678938",
"author": {
"id": 13280079,
"login": "jjbobzin"
}
}
}

View File

@@ -1,16 +0,0 @@
{
"base": "svg",
"aliases": [
"airtrail"
],
"categories": [
"Travel"
],
"update": {
"timestamp": "2025-09-08T12:23:51.466615",
"author": {
"id": 1340823,
"login": "b12e"
}
}
}

View File

@@ -1,14 +0,0 @@
{
"base": "svg",
"aliases": [],
"categories": [
"Cloud"
],
"update": {
"timestamp": "2025-10-18T13:50:38.466025",
"author": {
"id": 19624259,
"login": "seeharrison"
}
}
}

View File

@@ -1,14 +0,0 @@
{
"base": "svg",
"aliases": [],
"categories": [
"Finance"
],
"update": {
"timestamp": "2025-05-11T20:01:41.455664",
"author": {
"id": 10255587,
"login": "SteffeyDev"
}
}
}

View File

@@ -10,7 +10,7 @@
}
},
"colors": {
"dark": "akkoma",
"light": "akkoma-light"
"dark": "akkoma-light",
"light": "akkoma"
}
}

View File

@@ -1,12 +0,0 @@
{
"base": "png",
"aliases": [],
"categories": [],
"update": {
"timestamp": "2025-09-28T10:30:53.395293",
"author": {
"id": 127128984,
"login": "Ray2023m"
}
}
}

View File

@@ -1,18 +0,0 @@
{
"base": "svg",
"aliases": [
"ali-yun",
"alibaba",
"cloud"
],
"categories": [
"Cloud"
],
"update": {
"timestamp": "2025-10-22T14:29:45.111918",
"author": {
"id": 177024972,
"login": "AaronYang0628"
}
}
}

View File

@@ -5,7 +5,7 @@
"app-builder"
],
"categories": [
"Developer-Tools",
"Developper-Tools",
"Cloud-Computing"
],
"update": {

View File

@@ -14,7 +14,7 @@
}
},
"colors": {
"dark": "alltube",
"light": "alltube-light"
"dark": "alltube-light",
"light": "alltube"
}
}

View File

@@ -10,7 +10,7 @@
}
},
"colors": {
"dark": "amazon-web-services",
"light": "amazon-web-services-light"
"dark": "amazon-web-services-light",
"light": "amazon-web-services"
}
}

View File

@@ -15,7 +15,7 @@
}
},
"colors": {
"dark": "amazon",
"light": "amazon-light"
"dark": "amazon-light",
"light": "amazon"
}
}

View File

@@ -16,7 +16,7 @@
}
},
"colors": {
"dark": "amd",
"light": "amd-light"
"dark": "amd-light",
"light": "amd"
}
}

View File

@@ -15,7 +15,7 @@
}
},
"colors": {
"dark": "ami-alt",
"light": "ami-alt-light"
"dark": "ami-alt-light",
"light": "ami-alt"
}
}

View File

@@ -12,7 +12,7 @@
}
},
"colors": {
"dark": "android-auto-dark",
"light": "android-auto"
"dark": "android-auto",
"light": "android-auto-dark"
}
}

View File

@@ -1,14 +0,0 @@
{
"base": "svg",
"aliases": [],
"categories": [
"Development"
],
"update": {
"timestamp": "2025-09-08T12:56:41.622583",
"author": {
"id": 109094587,
"login": "Yarnacle"
}
}
}

View File

@@ -4,7 +4,7 @@
"Automation Tool"
],
"categories": [
"Developer-Tools",
"Developper-Tools",
"DevOps"
],
"update": {
@@ -15,7 +15,7 @@
}
},
"colors": {
"dark": "ansible",
"light": "ansible-light"
"dark": "ansible-light",
"light": "ansible"
}
}

View File

@@ -1,14 +0,0 @@
{
"base": "svg",
"aliases": [],
"categories": [
"Music"
],
"update": {
"timestamp": "2025-09-26T20:59:46.315320",
"author": {
"id": 23657968,
"login": "springsunx"
}
}
}

View File

@@ -10,7 +10,7 @@
}
},
"colors": {
"dark": "anything-llm",
"light": "anything-llm-light"
"dark": "anything-llm-light",
"light": "anything-llm"
}
}

View File

@@ -10,7 +10,7 @@
}
},
"colors": {
"dark": "apache-tomcat",
"light": "apache-tomcat-light"
"dark": "apache-tomcat-light",
"light": "apache-tomcat"
}
}

View File

@@ -1,21 +0,0 @@
{
"base": "svg",
"aliases": [
"apple",
"maps",
"apple-maps",
"applemaps",
"mapsapple",
"maps-apple"
],
"categories": [
"Location"
],
"update": {
"timestamp": "2025-10-14T20:27:33.730998",
"author": {
"id": 58250719,
"login": "Okaza03"
}
}
}

View File

@@ -1,16 +0,0 @@
{
"base": "svg",
"aliases": [
"podcast"
],
"categories": [
"Media"
],
"update": {
"timestamp": "2025-10-14T20:36:03.418327",
"author": {
"id": 111296018,
"login": "ARandomPigeon"
}
}
}

View File

@@ -15,7 +15,7 @@
}
},
"colors": {
"dark": "apple-tv-plus",
"light": "apple-tv-plus-light"
"dark": "apple-tv-plus-light",
"light": "apple-tv-plus"
}
}

View File

@@ -1,14 +0,0 @@
{
"base": "svg",
"aliases": [],
"categories": [
"Development"
],
"update": {
"timestamp": "2025-10-15T20:43:42.346161",
"author": {
"id": 25576967,
"login": "kmendell"
}
}
}

View File

@@ -5,7 +5,7 @@
"site-scraper"
],
"categories": [
"Developer-Tools"
"Developper-Tools"
],
"update": {
"timestamp": "2024-10-20T19:32:46Z",

View File

@@ -10,7 +10,7 @@
}
},
"colors": {
"dark": "archiveteam-warrior",
"light": "archiveteam-warrior-light"
"dark": "archiveteam-warrior-light",
"light": "archiveteam-warrior"
}
}

View File

@@ -4,7 +4,7 @@
"GitOps Tool"
],
"categories": [
"Developer-Tools",
"Developper-Tools",
"DevOps",
"Containerization-&-Orchestration"
],

View File

@@ -10,7 +10,7 @@
}
},
"colors": {
"dark": "arris",
"light": "arris-light"
"dark": "arris-light",
"light": "arris"
}
}

View File

@@ -6,7 +6,7 @@
],
"categories": [
"File-Sharing-&-Sync",
"Developer-Tools"
"Developper-Tools"
],
"update": {
"timestamp": "2024-10-20T19:32:46Z",

View File

@@ -5,7 +5,7 @@
],
"categories": [
"Office-Suites",
"Developer-Tools"
"Developper-Tools"
],
"update": {
"timestamp": "2024-10-20T17:24:03Z",
@@ -15,7 +15,7 @@
}
},
"colors": {
"dark": "astuto",
"light": "astuto-light"
"dark": "astuto-light",
"light": "astuto"
}
}

View File

@@ -1,12 +0,0 @@
{
"base": "svg",
"aliases": [],
"categories": [],
"update": {
"timestamp": "2023-04-13T13:56:18Z",
"author": {
"id": 71191962,
"name": "walkxcode"
}
}
}

View File

@@ -3,10 +3,10 @@
"aliases": [],
"categories": [],
"update": {
"timestamp": "2025-05-21T09:09:56.753640",
"timestamp": "2023-04-13T13:56:18Z",
"author": {
"id": 652463,
"login": "verglor"
"id": 71191962,
"name": "walkxcode"
}
}
}

View File

@@ -5,7 +5,7 @@
"build-server"
],
"categories": [
"Developer-Tools",
"Developper-Tools",
"Version-Control-Systems"
],
"update": {

View File

@@ -4,7 +4,7 @@
"Issue Tracker"
],
"categories": [
"Developer-Tools",
"Developper-Tools",
"Office-Suites"
],
"update": {

View File

@@ -1,16 +1,16 @@
{
"base": "svg",
"aliases": [
"atuin-sh"
],
"categories": [
"Development"
],
"aliases": [],
"categories": [],
"update": {
"timestamp": "2025-04-28T18:58:39.840943",
"timestamp": "2024-10-20T17:24:03Z",
"author": {
"id": 71191962,
"login": "lammersbjorn"
"name": "walkxcode"
}
},
"colors": {
"dark": "atuin-light",
"light": "atuin"
}
}

View File

@@ -1,14 +0,0 @@
{
"base": "svg",
"aliases": [],
"categories": [
"Media"
],
"update": {
"timestamp": "2025-06-30T18:45:27.729531",
"author": {
"id": 82271911,
"login": "Khyzer10"
}
}
}

View File

@@ -1,17 +0,0 @@
{
"base": "svg",
"aliases": [
"autocad",
"autodesk"
],
"categories": [
"Development"
],
"update": {
"timestamp": "2025-10-04T13:20:51.894933",
"author": {
"id": 230745655,
"login": "stillkool"
}
}
}

View File

@@ -1,18 +0,0 @@
{
"base": "svg",
"aliases": [],
"categories": [
"Media"
],
"update": {
"timestamp": "2025-05-12T16:23:45.630840",
"author": {
"id": 63781622,
"login": "Meierschlumpf"
}
},
"colors": {
"light": "autobangumi",
"dark": "autobangumi-dark"
}
}

View File

@@ -10,7 +10,7 @@
}
},
"colors": {
"dark": "automad",
"light": "automad-light"
"dark": "automad-light",
"light": "automad"
}
}

View File

@@ -10,7 +10,7 @@
}
},
"colors": {
"dark": "aws",
"light": "aws-light"
"dark": "aws-light",
"light": "aws"
}
}

View File

@@ -1,14 +0,0 @@
{
"base": "png",
"aliases": [],
"categories": [
"Hardware"
],
"update": {
"timestamp": "2025-06-19T05:11:03.846604",
"author": {
"id": 68505869,
"login": "adriantankodev"
}
}
}

View File

@@ -1,5 +1,5 @@
{
"base": "svg",
"base": "png",
"aliases": [
"security-camera-company",
"video-surveillance"
@@ -9,10 +9,14 @@
"Hardware"
],
"update": {
"timestamp": "2025-09-28T09:38:41.752362",
"timestamp": "2025-01-07T17:54:03Z",
"author": {
"id": 63781622,
"login": "Meierschlumpf"
"id": 71191962,
"name": "walkxcode"
}
},
"colors": {
"dark": "axis",
"light": "axis-light"
}
}

View File

@@ -1,12 +0,0 @@
{
"base": "png",
"aliases": [],
"categories": [],
"update": {
"timestamp": "2025-05-21T08:40:49.961984",
"author": {
"id": 48109134,
"login": "jdcool00"
}
}
}

View File

@@ -5,7 +5,7 @@
],
"categories": [
"Databases",
"Developer-Tools"
"Developper-Tools"
],
"update": {
"timestamp": "2024-10-20T17:24:03Z",
@@ -15,7 +15,7 @@
}
},
"colors": {
"dark": "backrest",
"light": "backrest-light"
"dark": "backrest-light",
"light": "backrest"
}
}

View File

@@ -5,7 +5,7 @@
"data-backup"
],
"categories": [
"Developer-Tools"
"Developper-Tools"
],
"update": {
"timestamp": "2025-01-07T17:54:03Z",

View File

@@ -1,14 +0,0 @@
{
"base": "svg",
"aliases": [],
"categories": [
"SocialMedia"
],
"update": {
"timestamp": "2025-08-30T13:35:57.844729",
"author": {
"id": 92841831,
"login": "pourya22334415"
}
}
}

View File

@@ -1,14 +0,0 @@
{
"base": "svg",
"aliases": [],
"categories": [
"Development"
],
"update": {
"timestamp": "2025-10-18T14:05:18.134102",
"author": {
"id": 74367192,
"login": "th33k"
}
}
}

View File

@@ -1,14 +0,0 @@
{
"base": "svg",
"aliases": [],
"categories": [
"Music"
],
"update": {
"timestamp": "2025-10-17T16:46:50.127333",
"author": {
"id": 155105197,
"login": "LuizFelipeOliver"
}
}
}

View File

@@ -5,7 +5,7 @@
],
"categories": [
"Security",
"Developer-Tools",
"Developper-Tools",
"Networking-Tools"
],
"update": {

View File

@@ -1,14 +0,0 @@
{
"base": "png",
"aliases": [],
"categories": [
"Gaming"
],
"update": {
"timestamp": "2025-09-26T21:35:05.132584",
"author": {
"id": 18689323,
"login": "davidlav"
}
}
}

View File

@@ -1,12 +0,0 @@
{
"base": "svg",
"aliases": [],
"categories": [],
"update": {
"timestamp": "2025-09-08T12:02:55.867500",
"author": {
"id": 165560954,
"login": "Serster"
}
}
}

View File

@@ -1,14 +0,0 @@
{
"base": "svg",
"aliases": [
"bequiet"
],
"categories": [],
"update": {
"timestamp": "2025-09-26T21:38:50.375046",
"author": {
"id": 58707896,
"login": "bannert1337"
}
}
}

View File

@@ -15,7 +15,7 @@
}
},
"colors": {
"dark": "beaver-habit-tracker",
"light": "beaver-habit-tracker-light"
"dark": "beaver-habit-tracker-light",
"light": "beaver-habit-tracker"
}
}

View File

@@ -1,14 +0,0 @@
{
"base": "svg",
"aliases": [],
"categories": [
"E-Commerce"
],
"update": {
"timestamp": "2025-06-16T21:17:22.434178",
"author": {
"id": 114433629,
"login": "Deisling"
}
}
}

View File

@@ -4,7 +4,7 @@
"php-web-framework"
],
"categories": [
"Developer-Tools"
"Developper-Tools"
],
"update": {
"timestamp": "2024-10-20T17:24:03Z",
@@ -14,7 +14,7 @@
}
},
"colors": {
"dark": "beef",
"light": "beef-light"
"dark": "beef-light",
"light": "beef"
}
}

View File

@@ -1,14 +0,0 @@
{
"base": "svg",
"aliases": [],
"categories": [
"Development"
],
"update": {
"timestamp": "2025-10-17T16:56:04.816102",
"author": {
"id": 38050638,
"login": "angeloschat"
}
}
}

View File

@@ -10,7 +10,7 @@
}
},
"colors": {
"dark": "biblioreads",
"light": "biblioreads-light"
"dark": "biblioreads-light",
"light": "biblioreads"
}
}

View File

@@ -1,14 +0,0 @@
{
"base": "svg",
"aliases": [],
"categories": [
"Video"
],
"update": {
"timestamp": "2025-09-28T09:50:10.194608",
"author": {
"id": 127128984,
"login": "Ray2023m"
}
}
}

View File

@@ -1,14 +0,0 @@
{
"base": "svg",
"aliases": [],
"categories": [
"Communication"
],
"update": {
"timestamp": "2025-06-17T17:03:33.578957",
"author": {
"id": 33011496,
"login": "Zachmoore111"
}
}
}

View File

@@ -1,22 +0,0 @@
{
"base": "png",
"aliases": [
"bitwig",
"studio",
"bitwig-music"
],
"categories": [
"Music"
],
"update": {
"timestamp": "2025-09-09T20:49:37.952500",
"author": {
"id": 160300441,
"login": "BuilderBoy163"
}
},
"colors": {
"light": "bitwig-studio",
"dark": "bitwig-studio-dark"
}
}

View File

@@ -1,16 +0,0 @@
{
"base": "png",
"aliases": [
"bible-study"
],
"categories": [
"Education"
],
"update": {
"timestamp": "2025-10-14T19:49:57.787938",
"author": {
"id": 40521502,
"login": "TheArtForm"
}
}
}

View File

@@ -1,14 +0,0 @@
{
"base": "png",
"aliases": [],
"categories": [
"Organization"
],
"update": {
"timestamp": "2025-05-08T21:13:01.765713",
"author": {
"id": 1506555,
"login": "danielkoster"
}
}
}

View File

@@ -1,14 +0,0 @@
{
"base": "svg",
"aliases": [],
"categories": [
"Media"
],
"update": {
"timestamp": "2025-08-06T18:14:48.266125",
"author": {
"id": 82271911,
"login": "Khyzer10"
}
}
}

View File

@@ -15,7 +15,7 @@
}
},
"colors": {
"dark": "booklogr",
"light": "booklogr-light"
"dark": "booklogr-light",
"light": "booklogr"
}
}

View File

@@ -10,7 +10,7 @@
}
},
"colors": {
"dark": "borgmatic",
"light": "borgmatic-light"
"dark": "borgmatic-light",
"light": "borgmatic"
}
}

View File

@@ -1,12 +0,0 @@
{
"base": "png",
"aliases": [],
"categories": [],
"update": {
"timestamp": "2025-09-12T20:28:01.211968",
"author": {
"id": 231333728,
"login": "nuno2229"
}
}
}

View File

@@ -1,14 +0,0 @@
{
"base": "svg",
"aliases": [],
"categories": [
"Logistics"
],
"update": {
"timestamp": "2025-05-08T20:55:30.191802",
"author": {
"id": 31495062,
"login": "jeremywillans"
}
}
}

View File

@@ -1,18 +0,0 @@
{
"base": "svg",
"aliases": [
"brightmove",
"bright-move-ats",
"brightmove-ats"
],
"categories": [
"Organization"
],
"update": {
"timestamp": "2025-09-06T18:33:28.889668",
"author": {
"id": 4467101,
"login": "prowave"
}
}
}

View File

@@ -1,15 +0,0 @@
{
"base": "png",
"aliases": [],
"categories": [
"Development",
"Communication"
],
"update": {
"timestamp": "2025-08-19T20:55:02.659790",
"author": {
"id": 80293250,
"login": "9izmos"
}
}
}

View File

@@ -10,7 +10,7 @@
}
},
"colors": {
"dark": "broadcastchannel",
"light": "broadcastchannel-light"
"dark": "broadcastchannel-light",
"light": "broadcastchannel"
}
}

Some files were not shown because too many files have changed in this diff Show More