Contributing to Developer Icons

We appreciate your thought of contributing to Developer-Icons. We welcome contributions of all kinds, from bug fixes to new features and icons. Your efforts help make this project better for everyone.

๐Ÿ”– Table of Contents

  1. Getting Started
  2. Development Setup
  3. Submitting Changes
  4. Coding Conventions
  5. Adding New Icons

๐Ÿš€ Getting Started

Before you begin:

  • Make sure you have a clear understanding of the project structure for which you can check out the walkthrough doc
  • Submit an issue/discussion for your proposed changes, assuming one does not already exist
  • Clearly describe the issue including steps to reproduce when it is a bug
  • And lastly, donโ€™t forget to have fun cuz weโ€™re having fun too.

๐Ÿ’ป Development Setup

  1. Star and fork the developer-icons repository
  2. Clone your fork of the repository:
    git clone https://github.com/<your-github-username>/developer-icons.git
    
  3. Install dependencies
    • For the package: npm install in root
    • For the showcase website: npm install in /showcase
  4. Set up your development environment:
    • For the playground: npm run dev:playground
    • For the documentation: npm run dev:showcase

๐Ÿ“ Submitting Changes

  1. Create a new branch for your feature or bugfix:
    git checkout -b <your-branch-name>
    
  2. Make your changes and commit them with a clear commit message
  3. Push your branch to your fork:
    git push origin <your-branch-name>
    
  4. Submit a pull request to the main repository

๐Ÿ“ Coding Conventions

  • Write clear, readable, and well-documented code
  • Follow the existing code style and structure
  • To make commits better, you can take a look at this wonderful commit guide
  • Make sure to test that the changes youโ€™ve made works and nothing else is broken

๐ŸŽจ Adding New Icons

  1. Firstly crop the SVG icon you want to add using SVGCrop.com to ensure that there is no unnecessary space around the icon
  2. Place your SVG files in the /icons/raw directory and rename them in a consistent way according to other pre-existing icons
  3. Run the optimization script which automatically moves the icons from /icons/raw folder to /icons folder after optimization:
    npm run optimize-svgs
    
  4. Update the icons data for every icon in the /lib/iconsData.ts file in a consistent way according to rest of the data and arrange them in alphabetical order
  5. Build the project to generate the new icon components:
    npm run build
    
  6. Run the playground environment to add and test the newly added/changed icon components
    npm run dev:playground
    
  7. If everything looks good, push the changes and create a Pull Request

โ“ Questions

Open discussions in this repository to ask with the community or you can directly reach out to @xandemon for any kinds of queries.

Thank you for your contributions โค๏ธ!