# Contributing To Simple Icons Simple Icons welcomes contributions and corrections. Before contributing, please make sure you have read the guidelines below. ## Table of contents * [Requesting An Icon](#requesting-an-icon) * [Adding or Updating An Icon](#adding-or-updating-an-icon) * [Labeling Issues](#labeling-issues) * [Building Locally](#building-locally) ## Requesting An Icon We welcome icon requests. Before you submit a new issue please make sure the icon: * Is of a _popular_ brand. * Has not already been requested. When submitting a request for a new or updated icon include helpful information such as: * **Issue Title:** The brand name. For example: * New Icons: `Request: GitHub Icon` * Icon Updates: `Update: GitHub Color` or `Update: GitHub Icon` * **Issue Body:** Links to official sources for the brand's icon and colors (e.g. media kits, brand guidelines, SVG files etc.) ## Adding or Updating An Icon ### 1. Identify Official Logos and Colors Most of the icons and brand colors on SimpleIcons have been derived from official sources. Using official sources helps ensure that the icons and colors in SimpleIcons accurately match the brand they represent. Thankfully, this is usually a simple process as organizations often provide brand guides and high quality versions of their logo for download. Official high quality brand logos and brand colors can usually be found in the following locations: 1. About pages, Press pages, Media Kits, and Brand Guidelines. 1. Website headers 1. Favicons 1. Wikimedia (which should provide a source) Working with an SVG version of the logo is best. In the absence of an SVG version, other vector filetypes may work as well (e.g. EPS, AI, PDF). In the absence of vector logos, a vector can be created from a high quality rasterized image, however this is much more labor intensive. For color, the brand's primary color should be used. The official color of a brand is usually found in their brand guidelines, media kits, or some of the other locations mentioned above. If no official color can be identified, use the brand's primary web color or the most prominent color in the logo itself (please indicate why you choose the particular color in your pull request). Simple Icons stores brand colors in the standard 6 character hexadecimal format. ### 2. Extract The Icon From The Logo There are many different tools for editing SVG files, some options include: | Name | Description | Platform | Price | | :---- | :---- | :----: | :----: | | [Inkscape](https://inkscape.org/en/)| Vector Graphics Editor | Windows, Mac, Linux | Free | | [Adobe Illustrator](https://www.adobe.com/products/illustrator.html) | Vector Graphics Editor | Windows, Mac | $ - $$$ | | [IcoMoon](https://icomoon.io/) | Icon Editing/Management Tool | Online | Free | Using your preferred tool you should: 1. Isolate the icon from any text or extraneous items. 1. Change the icon's viewbox/canvas/page size to 24x24. 1. Scale the icon to fit the viewbox, while preserving the icon's original proportions. This means the icon should be touching at least two sides of the viewbox. 1. Center the icon horizontally and vertically. 1. Remove all colors. The icon should be monochromatic. 1. Export the icon as an SVG. ### 3. Optimize The Icon All icons in Simple Icons have been optimized with the [SVGO tool](https://github.com/svg/svgo). This can be done in one of two ways: * The [SVGO Command Line Tool](https://github.com/svg/svgo) * Install SVGO * With npm: `npm install -g svgo` * With Homebrew: `brew install svgo` * Run the following command `svgo -p 3 icon.svg icon.min.svg` * The [SVGOMG Online Tool](https://jakearchibald.github.io/svgomg/) * Click "Open SVG" and select an SVG file. * Set the precision to 3, leave the remaining settings at the default values. * Click the download button. ### 4. Annotate The Icon Each icon in Simple Icons has been annotated with a number of attributes and elements to increase accessibility. These include: * An svg element with: * An aria label (Note the format). * `aria-labelledby="simpleicons-adobephotoshop-icon"` * An img role attribute. * `role="img"` * A 24x24 viewbox. * `viewBox="0 0 24 24"` * The svg namespace. * `xmlns="http://www.w3.org/2000/svg"` * A title element with id attribute (Note the format). * `