👩🚀 Heroicons as Astro components
Add astro-heroicons
to your project:
npm install astro-heroicons
# or
yarn add astro-heroicons
Import the icons from astro-heroicons
and add it to your code:
---
import Bold from 'astro-heroicons/solid/Bold.astro';
import Italic from 'astro-heroicons/outline/Italic.astro';
import Underline from 'astro-heroicons/mini/Underline.astro';
import Strikethrough from 'astro-heroicons/micro/Strikethrough.astro';
---
<p>
<Bold />
<Italic />
<Underline />
<Strikethrough>
</p>
The components exported from astro-heroicons
are the raw svg
elements from Hericons with {...Astro.props}
added to the root element. This should enable you to customize the element as you see fit.
// mini/Bolt.astro
<svg
{...Astro.props}
xmlns="http://www.w3.org/2000/svg"
viewBox="0 0 20 20"
fill="currentColor"
aria-hidden="true"
>
<path d="M11.983 1.907a.75.75 0 00-1.292-.657l-8.5 9.5A.75.75 0 002.75 12h6.572l-1.305 6.093a.75.75 0 001.292.657l8.5-9.5A.75.75 0 0017.25 8h-6.572l1.305-6.093z" />
</svg>
Any prop that you pass to the component will be added to the top-level svg
element:
<Heart class="a few classes" data-favorite="true" id="id" />
aria-hidden
Heroicons adds aria-hidden="true"
to its top-level svg
elements by default. If you want those elements to be accessible to screenreaders, you need to manually pass aria-hidden="false"
to the component:
<Bolt aria-hidden="false" aria-label="Live" />