element-web/docs/icons.md

56 lines
1.3 KiB
Markdown
Raw Normal View History

# Icons
2023-01-09 08:11:32 +01:00
Icons are loaded using [@svgr/webpack](https://www.npmjs.com/package/@svgr/webpack).
This is configured in [element-web](https://github.com/vector-im/element-web/blob/develop/webpack.config.js#L458).
2023-01-09 08:11:32 +01:00
Each `.svg` exports a `ReactComponent` at the named export `Icon`.
Icons have `role="presentation"` and `aria-hidden` automatically applied. These can be overriden by passing props to the icon component.
2023-01-09 08:11:32 +01:00
SVG file recommendations:
- Colours should not be defined absolutely. Use `currentColor` instead.
- There should not be a padding in SVG files. It should be added by CSS.
Example usage:
2022-12-12 12:24:14 +01:00
```
import { Icon as FavoriteIcon } from 'res/img/element-icons/favorite.svg';
const MyComponent = () => {
return <>
2023-01-09 08:11:32 +01:00
<FavoriteIcon className="mx_Icon mx_Icon_16">
</>;
}
```
2023-01-09 08:11:32 +01:00
If possible, use the icon classes from [here](../res/css/compound/_Icon.pcss).
2023-01-09 08:11:32 +01:00
## Custom styling
2023-01-09 08:11:32 +01:00
Icon components are svg elements and may be custom styled as usual.
`_MyComponents.pcss`:
```css
.mx_MyComponent-icon {
height: 20px;
width: 20px;
* {
fill: $accent;
}
}
2023-01-09 08:11:32 +01:00
```
`MyComponent.tsx`:
2023-01-09 08:11:32 +01:00
```typescript
import { Icon as FavoriteIcon } from 'res/img/element-icons/favorite.svg';
const MyComponent = () => {
return <>
<FavoriteIcon className="mx_MyComponent-icon" role="img" aria-hidden="false">
</>;
}
```