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".
Here is an example for a JS file index.js
:
// index.js
import { generateIconFonts } from "@db-ux/icon-font-tools";
void generateIconFonts({
fontName,
src: "./icons",
ignore: ["**/node_modules/**"],
variants: ["filled"],
withSizes: true,
});
Example:
npx @db-ux/icon-font-tools generate-icon-fonts --src ./my-path-to/icons --fontName my-name
For more information run:
npx @db-ux/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";
}