phosphor-svelte
Version:
A clean and friendly icon family for Svelte
135 lines (98 loc) • 4.43 kB
Markdown
<img src="./meta/phosphor-mark-tight-yellow.png" width="128" align="right" />
# phosphor-svelte
Phosphor is a flexible icon family for interfaces, diagrams, presentations — whatever, really. More icons at [phosphoricons.com](https://phosphoricons.com).
[](https://npm.im/phosphor-svelte)
## Installation
```bash
yarn add --dev phosphor-svelte
```
or
```bash
npm install --save-dev phosphor-svelte
```
## Usage
```html
<script>
import { Horse, Heart } from "phosphor-svelte";
// or
import Cube from "phosphor-svelte/lib/Cube"; // Recommended for faster compiling
</script>
<Horse />
<Heart color="#AE2983" weight="fill" size="{32}" />
<Cube color="teal" weight="duotone" />
```
> [!WARNING]
> You might encounter slower compilation when importing components using named import (`import { X } from "phosphor-svelte"`).
### Props
- **color?**: `string` – Icon stroke/fill color. Can be any CSS color string, including `hex`, `rgb`, `rgba`, `hsl`, `hsla`, named colors, or the special `currentColor` variable.
- **size?**: `number | string` – Icon height & width. As with standard React elements, this can be a number, or a string with units in `px`, `%`, `em`, `rem`, `pt`, `cm`, `mm`, `in`.
- **weight?**: `"thin" | "light" | "regular" | "bold" | "fill" | "duotone"` – Icon weight/style. Can also be used, for example, to "toggle" an icon's state: a rating component could use Stars with `weight="regular"` to denote an empty star, and `weight="fill"` to denote a filled star.
- **mirrored?**: `boolean` – Flip the icon horizontally. Can be useful in RTL languages where normal icon orientation is not appropriate.
### Context
Apply default style to all icons. Create an IconContext at the root of the app (or anywhere above the icons in the tree) and pass in a configuration object with props to be applied by default to all icons inside context:
```html
<script>
import IconContext from "phosphor-svelte/lib/IconContext";
// or
// import { IconContext } from "phosphor-svelte";
import Cube from "phosphor-svelte/lib/Cube";
import Horse from "phosphor-svelte/lib/Horse";
import Heart from "phosphor-svelte/lib/Heart";
</script>
<IconContext
values={{ color: 'limegreen', size: 32, mirrored: false, weight: 'bold' }}>
<Horse /> <!-- I'm lime-green, 32px, and bold! -->
<Heart /> <!-- Me too! -->
<Cube color="red" /> <!-- red -->
</IconContext>
```
### Composability
<img src="./meta/cube-rotate.svg" width="128" align="right" />
Components can accept arbitrary SVG elements as children, so long as they are valid children of the `<svg>` element. This can be used to modify an icon with background layers or shapes, filters, animations and more. The children will be placed _below_ the normal icon contents.
The following will cause the Cube icon to rotate and pulse:
```html
<Cube color="darkorchid" weight="duotone">
<animate
attributeName="opacity"
values="0;1;0"
dur="4s"
repeatCount="indefinite"
></animate>
<animateTransform
attributeName="transform"
attributeType="XML"
type="rotate"
dur="5s"
from="0 0 0"
to="360 0 0"
repeatCount="indefinite"
></animateTransform>
</Cube>
```
> **Note:** The coordinate space of slotted elements is relative to the contents of the icon `viewBox`, which is a 256x256 square. Only [valid SVG elements](https://developer.mozilla.org/en-US/docs/Web/SVG/Element#SVG_elements_by_category) will be rendered.
### Import Optimizer
A Vite plugin that transforms named import to default import. This will speed up compile times during development.
```diff
<script>
- import { Cube, Heart, Horse } from "phosphor-svelte";
+ import Cube from "phosphor-svelte/lib/Cube";
+ import Heart from "phosphor-svelte/lib/Heart";
+ import Horse from "phosphor-svelte/lib/Horse";
</script>
```
#### Usage
Add the plugin into your vite config file.
```javascript
// vite.config.ts
import { sveltekit } from "@sveltejs/kit/vite";
import { defineConfig } from "vite";
import { sveltePhosphorOptimize } from "phosphor-svelte/vite";
export default defineConfig({
plugins: [sveltePhosphorOptimize(), sveltekit()],
});
```
## License
MIT © [Phosphor Icons](https://github.com/phosphor-icons)
## Knowledge
- [Phosphor React](https://github.com/phosphor-icons/phosphor-react/)
- [Carbon Icons Svelte](https://github.com/IBM/carbon-icons-svelte/)