π An accessible Emoji component for Astro applications
Emojis can add a light playfulness to your project but require some specific formatting in order to ensure they are accessible for all users. astro-emoji
's reusable Emoji
component helps you do that quickly and painlessly.
Add astro-emoji
to your project:
npm install astro-emoji
# or
yarn add astro-emoji
Import the default Emoji
from astro-emoji
and add it to your code:
---
import Emoji from 'astro-emoji';
---
<footer>
Made with
{' '}
<Emoji symbol="π" label="love" />
{' '}
by Sean McPherson
</footer>
The resulting markup for that component signature will be:
<span aria-label="love" role="img">π</span>
Emoji
s with no label
prop are rendered with aria-hidden="true"
:
<Emoji symbol="π€" />
<!-- Renders -->
<span aria-hidden="true" role="img">π€</span>
The Emoji
component consumes two props: symbol
and label
. Every other prop is spread to the top-level <span>
element.
The following properties are managed internally, and therefore ignored if passes as props to Emoji
:
aria-hidden
aria-label
role
The main benefit of using astro-emoji
is that you don't need to worry about setting these HTML attributes correctly yourself.