EUI provides an ever-growing set of icons, but our set can be incomplete. If you find you need an icon that does not exist, create a new issue and tag it with the icons label. A designer from the EUI team will respond to discuss your needs.
If you are willing and able to design the icon yourself, this document describes the guidelines for designing a new icon, cleaning up the SVG, and getting it added to EUI. While designers on the EUI team are available to assist, we greatly appreciate your contributions and pull requests.
If you read through these guidelines or begin designing your icon and realize you're in too deep, then create an issue in this repo and request assistance. An EUI team member will reply and discuss options.
Note on 3rd-party / custom SVGs
- The
EuiIcon
component accepts external references to custom SVG files, so you can maintain the icon in your consuming application. - This practice should also be used for any 3rd-party logos. For a number of reasons, the EUI team as moved away from maintaining a set of 3rd party logos. Please use the custom SVG option going forward.
From a content perspective, we've taken an approach of being open to many types of icons so long as they don't duplicate an icon that already exists. Stylistically, we have more stringent requirements outlined below.
While we're pretty much open to all requests, we ask that you first try to use an existing icon as this helps us avoid having multiple versions of the same glyph. Likewise, if there is a universally known icon that represents an action, we recommend leveraging those existing patterns (e.g. a scissors for cut).
Finding and sharing reference icons is a great way to get moving if you're uncertain of the general shape. Post these examples to your issue and we'll provide feedback.
Lastly, we reserve the right to reject any icons that do not fit the EUI style or may be deemed inappropriate.
This is where things get more opinionated. To maintain a cohesive, high quality icon set, we require that all new glpyhs adhere to the following guidelines:
- Use an outline style with a 1 pixel width stroke, straight edges, rounded corners and ends
- Adhere to an overall 16 pixel square shape
- Center the glyph in the square leaving a 1 or 2 pixel trim area, where possible
- Align vertical and horizontal paths to a 16x16 pixel grid
As a reference, you can view and duplicate our Figma Icon Template. The "template" page within this project contains frames with helper grids, margins, and an example.
While we use Figma to maintain our internal design library, you can use any design tool to produce the SVG file.
Once you've designed your new icon, the last step is adding it to the EUI repo.
EUI provides SVG icon formats only. After exporting your icon as an SVG from your design tool, open it in a code or text editor and remove any unnecessary elements and attributes, such as:
<def>...</def>
<use>...</use>
id: <value>
fill: <value>
Note: Figma users can use the SVG Export plugin to optimize SVG sizes and code.
Create a new feature branch against this repo and make the following changes:
1. Add your glyph to the EuiIcon
component
- Add your SVG file to the
/packages/eui/src/components/icon/svgs
folder - Add a reference in the
/packages/eui/src/components/icon/icon_map.ts
file (in alphabetical order)
2. Display the icon in the docs
- Add the icon name to
/packages/eui/src-docs/src/views/icon/icons.js
* - Add the icon name to
/packages/website/docs/components/display/icons/icon_types.ts
*
3. Compile and test
- Go to the
packages/eui
directory - Run
yarn compile-icons
- Preview your icon locally at
http://localhost:8030/#/display/icons
** - Switch the docs to dark mode and verify that the icon is visible (all paths should be filled with the reverse color)
- Run
yarn run test-unit icon -u
to create/update the jest snapshots
If everything looks good, then commit your changes, push up your branch, and open a PR! 🙌
Opening a PR will notify the EUI team that your work is ready for review. Please include a screenshot in the description and reference the issue that your PR fixes.
Once your PR is approved, you will be able to merge it and give yourself a well-deserved pat on the back. Finally, stay tuned for the next release of EUI at which point your icon will become available to the masses and appear on the EUI docs site.
🏆 Welcome to the Official EUI Icon Design Club 🍻
* The Icons page actually contains several sections. In most cases, you will be adding your icon to the base set. However, if your icon should appear in a different set, then add it to the appropriate section file in /packages/eui/src-docs/src/views/icon
.
** Run yarn && yarn start
to view the EUI docs site locally.