Skip to content

πŸ‘©β€πŸš€ Phosphor icons as Astro components

License

Notifications You must be signed in to change notification settings

SeanMcP/phosphor-astro

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

15 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

phosphor-astro

npm npm

πŸ‘©β€πŸš€ Phosphor icons as Astro components

Installation

Add phosphor-astro to your project:

npm install phosphor-astro
# or
yarn add phosphor-astro

Use

Import the icons from phoshor-astro and add it to your code:

---
import RocketLaunch from 'phosphor-astro/RocketLaunch.astro':
import ArrowRight from 'phosphor-astro/ArrowRightBold.astro':
import Sparkle from 'phosphor-astro/SparkleDuotone.astro':
---

<p>
  <RocketLaunch />
  <ArrowRight />
  <Sparkle />
</p>

Astro components

The components exported from phosphor-astro are the raw svg elements from Phosphor with {...Astro.props} added to the root element. This should enable you to customize the element as you see fit.

// Book.astro
<svg {...Astro.props} xmlns="http://www.w3.org/2000/svg" viewBox="0 0 256 256">
  <rect width="256" height="256" fill="none" />
  <path
    d="M48,216a23.9,23.9,0,0,1,24-24H208V32H72A23.9,23.9,0,0,0,48,56Z"
    fill="none"
    stroke="currentColor"
    stroke-linecap="round"
    stroke-linejoin="round"
    stroke-width="16"
  />
  <polyline
    points="48 216 48 224 192 224"
    fill="none"
    stroke="#000"
    stroke-linecap="round"
    stroke-linejoin="round"
    stroke-width="16"
  />
</svg>

Any prop that you pass to the component will be added to the top-level svg element:

// Heart.astro
<Heart class="a few classes" data-favorite="true" id="id" />

License

MIT