Examples
The <SvgIcon> component is a re-usable component that wraps its children in an <svg> element.
This component is used by each individual icon component listed below.
Changing icon color
Icon components support a few built-in color options that can be applied by using one of the following utility classes.
If you need a different color for an icon, you can pass a custom class to an icon component through the class prop. Then, in your application CSS, set the color prop.
| Color | CSS utility Class | Example |
|---|---|---|
| Primary | ds-c-icon-color--primary | |
| Inverse | ds-c-icon-color--inverse | |
| Error | ds-c-icon-color--error | |
| Warn | ds-c-icon-color--warn | |
| Success | ds-c-icon-color--success |
Changing icon size
Icon components use ems for their height and width and can thereby be sized by changing the font-size of the SVG element.
It is recommended that the font-size utilities be used.
| Size | Example |
|---|---|
| Small | |
| Default | |
| Large | |
| Extra Large | |
| 2x Large | |
| 3x Large | |
| 4x Large | |
| 5x Large |
Creating custom icons
The <SvgIcon> component can be used for other custom icons. It allows you to pass in the SVG child elements. This component is recommended if you want built-in accessibility features and standard icon styles.
In the example below, the <SvgIcon> component is used with a custom path.
Code
React
See Storybook for React guidance of this component.
Guidance
Accessibility
The <SvgIcon> component has built-in accessibility features including:
- a built-in
titleattribute. For any specific exported icon, thetitleattribute is defaulted, but can be overwritten. focusable="false"which prevents the icon from being focusablerole="img"which tells assistive technologies that the icon's purpose is as an image- optional
descriptionattribute which can be used for a more detailed explanation of the icon's contents. Meant to be used to provide more detail than just thetitle - an available
ariaHiddenattribute which can be used if the icon's context is described elsewhere. For example, if the icon is part of a button with text, the text may provide the text description instead of the icon component.
Component maturity
For more information about how we tested and validated our work for each checklist item, read our component maturity documentation.