If you have custom icons and want to use them for foundations and/or in components, you need to generate a woff2
file.
To check the complete CLI API goto API.
For icon font generation each icon should be a single path. To clean up your icons run:
npx @db-ui/icon-font-tools clean-icons --src ./my-path-to/icons
We use svg-fixer to clean up the icons. This will slightly increase the file size but ensures that the icons are displayed correctly.
For this run:
npx @db-ui/icon-font-tools generate-icon-fonts --src ./my-path-to/icons --fontName my-name
We search for all **/*.svg
files inside the --src
directory and create a new icon font with the provided name. You can preview all generated icons here: ./my-path-to/icons/fonts/all/index.html
.
NOTE: We use four different sizes for components (16, 20, 24, 32) to show more or less details. You can do the same by providing another file with a size suffix for example "icon_file_name_16.svg".
For more information run:
npx @db-ui/icon-font-tools --help
In your app you need to include some of the generated files:
./my-path-to/icons/fonts/my-name.woff2 ./my-path-to/icons/fonts/font-face.css
NOTE: In case you put the files in a separate folder of your
public
directory be aware to adopt the path in your generatedfont-face.css
file:url("/{YOUR_FOLDER}}/my-name.woff2?t=1698750286189") format("woff2");
NOTE: The source files need to provide the following attributes: width, height and viewbox to generate the icon font correctly
Now you can use your icons with your font-family: my-name
, e.g.:
<!--example.html-->
<i class="my-name">icon_file_name</i>
When using scss
you can also use @forward
to include the generated files:
@forward "public/font-face";
If you like to use a custom icon in one of our components you can do it by overwriting the default font-family like this:
<!--example.html-->
<p class="icon-family-my-name" data-icon="icon_file_name">Test</p>
<!-- or -->
<p data-icon-family="my-name" data-icon="icon_file_name">Test</p>
You can overwrite custom-icons for our components with CSS as well:
.db-button {
--db-icon-font-family: "my-name";
}