Skip to content

Latest commit

 

History

History
executable file
·
68 lines (47 loc) · 1.62 KB

README.md

File metadata and controls

executable file
·
68 lines (47 loc) · 1.62 KB

svg2svelte-rs

Logo

Easily turn an SVG file into a Svelte component, Rewritten in Rust.

How It Works

svg2svelte parses the svg file's ids for bind: in the name and converts them into variables we can manipulate later on with an animation library (e.g. anime.js)

Dependencies

  • svgo will need to be installed globally.
npm i -g svgo           # npm
yarn global add svgo    # yarn
pnpm add -g svgo        # pnpm

Installation

Build from source

git clone https://github.com/derektata/svg2svelte-rs
cd svg2svelte-rs
make

Using Cargo

cargo install svg2svelte

Usage/Examples

USAGE:
    svg2svelte [OPTIONS] [SVG_FILE]

ARGS:
    <SVG_FILE>    File to be processed

OPTIONS:
    -h, --help          Print help information
    -t, --typescript    Create a Typescript component
    -v, --verbose       Print the generated component to stdout
    -V, --version       Print version information

EXAMPLES:
    svg2svelte ball.svg
    svg2svelte -t ball.svg

Screenshot

screenshot

Why?

The previous implementation I had written up in shell had issues running cross-platform and only worked on Linux, so I decided to start learning more Rust and this project was born.

License

AGPL-3.0 License

Author

Derek Tata