Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/shgysk8zer0/svg-use-symbols
An npm package for use with `<svg><use xlink:href=""></use></svg>`
https://github.com/shgysk8zer0/svg-use-symbols
svg svg-icons svg-sprites svg-symbols svg-use
Last synced: 4 months ago
JSON representation
An npm package for use with `<svg><use xlink:href=""></use></svg>`
- Host: GitHub
- URL: https://github.com/shgysk8zer0/svg-use-symbols
- Owner: shgysk8zer0
- License: mit
- Created: 2023-06-01T16:01:58.000Z (over 1 year ago)
- Default Branch: master
- Last Pushed: 2024-09-24T18:26:27.000Z (5 months ago)
- Last Synced: 2024-10-05T14:40:40.201Z (5 months ago)
- Topics: svg, svg-icons, svg-sprites, svg-symbols, svg-use
- Language: JavaScript
- Homepage: https://www.npmjs.com/package/@shgysk8zer0/svg-use-symbols
- Size: 251 KB
- Stars: 4
- Watchers: 3
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: .github/CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Code of conduct: .github/CODE_OF_CONDUCT.md
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
README
# @shgysk8zer0/svg-use-symbols
An npm package for use with ``- - -
[data:image/s3,"s3://crabby-images/a6497/a6497afa6fb15016bbe8844e6a607ff7df81c204" alt="CodeQL"](https://github.com/shgysk8zer0/svg-use-symbols/actions/workflows/codeql-analysis.yml)
data:image/s3,"s3://crabby-images/0a9f5/0a9f521715cda9a09d79d4f1c9ab0a22e4eeb362" alt="Node CI"
data:image/s3,"s3://crabby-images/9185a/9185ae84f7ead02e4c9a09b408f976e5a68bbaa6" alt="Lint Code Base"[data:image/s3,"s3://crabby-images/32988/32988be9f78057d3295a21aa140e3978262c819e" alt="GitHub license"](https://github.com/shgysk8zer0/svg-use-symbols/blob/master/LICENSE)
[data:image/s3,"s3://crabby-images/87ada/87adabca81408664395b96e11f1f7f91b5516fb2" alt="GitHub last commit"](https://github.com/shgysk8zer0/svg-use-symbols/commits/master)
[data:image/s3,"s3://crabby-images/ab17e/ab17ef5736fd8c42e1e849df2850a0521aa3dd5f" alt="GitHub release"](https://github.com/shgysk8zer0/svg-use-symbols/releases)
[data:image/s3,"s3://crabby-images/46ee3/46ee3047d5122b6628ddee5c1199ec88442c5699" alt="GitHub Sponsors"](https://github.com/sponsors/shgysk8zer0)[data:image/s3,"s3://crabby-images/d7f61/d7f61e7e45eaf3b1d5a77d262a6bd98124189929" alt="npm"](https://www.npmjs.com/package/@shgysk8zer0/svg-use-symbols)
data:image/s3,"s3://crabby-images/61c54/61c542b059b6d6538e22a5b87a9963203ea3a3de" alt="node-current"
data:image/s3,"s3://crabby-images/95f6e/95f6e81d364ecaae5a9f94936b3396d65779f465" alt="npm bundle size gzipped"
[data:image/s3,"s3://crabby-images/601bc/601bcefc8096e9999e7c0d526fcef85fb6a34276" alt="npm"](https://www.npmjs.com/package/@shgysk8zer0/svg-use-symbols)[data:image/s3,"s3://crabby-images/62b97/62b97f086fda7a59a880c020f8b9c858da42b510" alt="GitHub followers"](https://github.com/shgysk8zer0)
data:image/s3,"s3://crabby-images/7268f/7268f40fecb42536339783a3451c398028f04579" alt="GitHub forks"
data:image/s3,"s3://crabby-images/a3b36/a3b3627916274189c2a417ae476babc24471e048" alt="GitHub stars"
[data:image/s3,"s3://crabby-images/c48d0/c48d0f67813da2e935be5b8c6b3eee90504a8df7" alt="Twitter Follow"](https://twitter.com/shgysk8zer0)[data:image/s3,"s3://crabby-images/84684/84684719846190cf436968d4080334af5fe64fc8" alt="Donate using Liberapay"](https://liberapay.com/shgysk8zer0/donate "Donate using Liberapay")
- - -- [Code of Conduct](./.github/CODE_OF_CONDUCT.md)
- [Contributing](./.github/CONTRIBUTING.md)## Installation
```bash
npm i @shgysk8zer0/svg-use-symbols
```## Supports
- Parsing from JSON and YAML files
- Creating multiple outputs by using an array of objects with `output` and `icons`
- Creating a single output file by using simple `id` and `path` object
- Creating from directories
- Fetching SVGs from URLs
- Migrating from `svg-sprite-generate` (converts CSV to JSON or YAML)## Usage
### In HTML
This generates a series of ``s, which have the counterpart of `` for
using the icons on a webiste:```html
```
### CLI
```
Usage: @shgysk8zer0/svg-use-symbols [options]An npm package for use with ``
Options:
-V, --version output the version number
-c, --config [config] JSON or YAML config file
-d, --directory [directory] path to directory of SVGs
-e, --encoding [encoding] encoding (default: "utf8")
-f, --format [format] output format for migrating from CSV (default: "json")
-l, --list [list] comma separated list of SVGs
-m, --migrate [migrate] path to deprecated CSV config file
-o, --output [output] output file
-h, --help display help for command
``````bash
svg-use-symbols -c path/to/config.yml -o img/icons.svg
svg use-symbols -d path/to/svgs/ -o img/icons.svg
svg-use-symbols -l icons/1.svg,icons/2.svg -o img/icons.svg
```## Node
### Simple usage
```js
import { generateSymbols } from '@shgysk8zer0/svg-use-symbols';await generateSymbols('config.json');
```### Using `require()`
```js
const { generateSymbols } = require('@shgysk8zer0/svg-use-symbols');// Top-level await not allowed
generateSymbols('config.json').catch(console.error);
```### Advanced usage
```js
import { generateSymbol, writeSVG } from '@shgysk8zer0/svg-use-symbols';
const controller = new AbortController();const config = {
"file-media": "octicons/file-media.svg",
"external": "https://example.com/external.svg",
};const symbols = await Promise.all(
Object.entries(config).map(async ([id, path]) => {
try {
const symbol = await generateSymbol(id, path, { encoding: 'utf8', signal });
// Mutate symbol, perhaps?
return symbol;
} catch(err) {
console.error(err);
controller.abort();
}
})
);await writeSVG('output.svg', symbols, { encoding: 'utf8' });
```## Config files
This supports YAML, JSON, and *to a limited extent*, CSV. CSV is temporarily
offered for those migrating from `svg-sprite-generator` and will be removed in v2.
Please see the section on migrating.For JSON and YAML, two different formats are supported:
```json
{
"id": "path/to/icon.svg",
"another": "https://example.com/path/to/icon.svg"
}
```This will create ``s with `id` taken from the key and contents
from the SVG file at the given path/URL. This **MUST** have output (`-o` or `--output`)
set. This also applies for the temporarily supported CSV config files.It may also use:
```json
[
{
"output": "path/to/output.svg",
"icons": {
"id": "path/to/icon.svg",
"another": "https://example.com/path/to/icon.svg"
}
},
{
"output": "path/to/output2.svg",
"icons": {
"id": "path/to/another-icon.svg",
"another": "https://example.com/path/to/another-icon.svg"
}
}
]
```This will create output files `output.svg` and `output2.svg`, each containing
there respective ``s.## Migrating from `svg-sprite-generator`
```bash
svg-use-symbols -m path/to/config.csv -o path/to/config.json
# Or
svg-use-symbols --migrate path/to/config.csv --format json --output /path/to/config.json
# Or
svg-use-symbols --migrate path/to/config.csv --format yaml --output /path/to/config.yaml
```