2022-11-04 17:41:12 -04:00
---
group: Customization
title: Adding Custom Icons
weight: 100
---
The Static CMS exposes a `window.CMS` global object that you can use to register custom icons via `registerIcon`. The same object is also the default export if you import Static CMS as an npm module.
Custom icons can be used with [Collections](/docs/collection-overview) or [Custom Links & Pages](/docs/additional-links)
## Params
| Param | Type | Description |
| ----- | ------------------------------------------------------------------------------ | -------------------------------------------------- |
| name | string | A unique name for the icon |
| name | [React Function Component](https://reactjs.org/docs/components-and-props.html) | A React functional component that renders the icon |
## Example
This example uses Font Awesome to supply the icon.
```js
import { faHouse } from '@fortawesome/free-solid-svg-icons';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
2022-11-07 15:21:37 -05:00
import CMS from '@staticcms/core';
2022-11-04 17:41:12 -04:00
2022-11-07 15:21:37 -05:00
CMS.registerIcon('house', <FontAwesomeIcon icon={faHouse} size="lg" />);
2022-11-04 17:41:12 -04:00
```
2022-11-07 10:27:58 -05:00
## Usage
### Collection
<CodeTabs>
```yaml
collections:
- name: homepage
icon: house
```
```js
collections: [
{
name: 'homepage',
icon: 'house'
},
],
```
</CodeTabs>
### Additional Links
See [Additional Links](/docs/additional-links#examples) for details.