@carbon/pictograms-react
Version:
React components for pictograms in digital and software products using the Carbon Design System
124 lines (89 loc) • 4.05 kB
Markdown
# @carbon/pictograms-react
> React components for pictograms in digital and software products using the
> Carbon Design System
## Getting started
To install `@carbon/pictograms-react` in your project, you will need to run the
following command using [npm](https://www.npmjs.com/):
```bash
npm install -S @carbon/pictograms-react
```
If you prefer [Yarn](https://yarnpkg.com/en/), use the following command
instead:
```bash
yarn add @carbon/pictograms-react
```
## Usage
You can import a pictogram component into your project by referring to its name:
```jsx
import { Airplane } from '@carbon/pictograms-react';
```
We also provide CommonJS and UMD files in the `lib` and `umd` directories,
respectively.
To import using CommonJS, you can do the following:
```js
const { Airplane } = require('@carbon/pictograms-react');
```
_Note: if you would like to find the import path for a pictogram, you can
reference our
[Pictogram Library](https://www.carbondesignsystem.com/guidelines/pictograms/library)_
### Icon fill
All icons from the library support being styled by the `fill` property. You can
change the color of an icon by passing in a custom class name that sets this
property (preferred), or by passing in an inline style. For example:
```css
// CSS custom class name to set the fill of the icon to `rebeccapurple`
svg.my-custom-class {
fill: rebeccapurple;
}
```
```jsx
import { Airplane } from '@carbon/pictograms-react';
function MyComponent() {
return (
<button>
<Airplane aria-label="Add" className="my-custom-class" />
</button>
);
}
```
### Focus and `aria-label`
By default, the icon components from `@carbon/pictograms-react` are treated as
decorative content. This means that we set `aria-hidden="true"` unless certain
props are passed to the component.
If you would like the icon to be announced by a screen reader, you can supply an
`aria-label` or `aria-labelledby`. For example:
```jsx
import { Airplane } from '@carbon/pictograms-react';
function MyComponent() {
return (
<button>
<Airplane aria-label="Add" />
</button>
);
}
```
Doing this will add the appropriate `role` to the `<svg>` node, as well.
If you would like the `<svg>` to receive focus, you will need to pass in a
`tabIndex` value. For example:
```jsx
import { Airplane } from '@carbon/pictograms-react';
function MyComponent() {
return <Airplane aria-label="Add" tabIndex="0" />;
}
```
Including `tabIndex` and `aria-label` (or `aria-labelledby`) will set the
corresponding `tabindex` on the underlying `<svg>` and verify support in older
browsers like Internet Explorer 11 by setting `focusable` to `true`.
## 🙌 Contributing
We're always looking for contributors to help us fix bugs, build new features,
or help us improve the project documentation. If you're interested, definitely
check out our [Contributing Guide](/.github/CONTRIBUTING.md)! 👀
## 📝 License
Licensed under the [Apache 2.0 License](/LICENSE).
## <picture><source height="20" width="20" media="(prefers-color-scheme: dark)" srcset="https://raw.githubusercontent.com/ibm-telemetry/telemetry-js/main/docs/images/ibm-telemetry-dark.svg"><source height="20" width="20" media="(prefers-color-scheme: light)" srcset="https://raw.githubusercontent.com/ibm-telemetry/telemetry-js/main/docs/images/ibm-telemetry-light.svg"><img height="20" width="20" alt="IBM Telemetry" src="https://raw.githubusercontent.com/ibm-telemetry/telemetry-js/main/docs/images/ibm-telemetry-light.svg"></picture> IBM Telemetry
This package uses IBM Telemetry to collect de-identified and anonymized metrics
data. By installing this package as a dependency you are agreeing to telemetry
collection. To opt out, see
[Opting out of IBM Telemetry data collection](https://github.com/ibm-telemetry/telemetry-js/tree/main#opting-out-of-ibm-telemetry-data-collection).
For more information on the data being collected, please see the
[IBM Telemetry documentation](https://github.com/ibm-telemetry/telemetry-js/tree/main#ibm-telemetry-collection-basics).