Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hugozap/react-svgmt
SVG Loading and Manipulation Tools for React
https://github.com/hugozap/react-svgmt
Last synced: about 1 month ago
JSON representation
SVG Loading and Manipulation Tools for React
- Host: GitHub
- URL: https://github.com/hugozap/react-svgmt
- Owner: hugozap
- License: mit
- Created: 2018-03-31T18:30:31.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2023-05-04T14:30:12.000Z (over 1 year ago)
- Last Synced: 2024-10-30T21:02:08.571Z (about 1 month ago)
- Language: JavaScript
- Homepage: https://hugozap.github.io/react-svgmt/
- Size: 13.7 MB
- Stars: 119
- Watchers: 3
- Forks: 17
- Open Issues: 31
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# react-svgmt
react-svgmt (SVG Management Tools for React)
### Installation
```
npm install react-svgmt@latest```
[Api and Docs](https://hugozap.github.io/react-svgmt/#api)
### Usage
Import the `SvgLoader` and `SvgProxy` elements
```js
import { SvgLoader, SvgProxy } from 'react-svgmt';
```Example: Create a list CSS selectors and update each one
[![Edit react-svgmt-nth-child](https://codesandbox.io/static/img/play-codesandbox.svg)](https://codesandbox.io/s/react-svgmt-nth-child-rh48e?fontsize=14)```js
function App() {
//We want to update only elements that match this selectors
const selectors = ["rect:nth-child(1)", "rect:nth-child(4)"];
return (
{selectors.map((selector, ix) => (
))}
);
}
```#### Loading and manipulating and SVG
If the `path` prop is used, then the asset will be fetched from the url.
```jsx
```
There are two ways to load an SVG file:
1) From a URL (using the `path` prop)
2) From a string with the SVG file contents (using the `svgXML` prop)More features, API and examples see [https://hugozap.github.io/react-svgmt](https://hugozap.github.io/react-svgmt)
#### How to change the selectors and reset previous elements?
This library doesn't store previous elements state. Say you want
to update some elements fill color and then change the selector
to update another set of elements.Don't expect the original element attributes to be reset back to their original state.
You need to add a "reset" SvgProxy so all elements attributes are reseted before
the additional SvgProxies are processed.Check this [CodeSandbox](https://codesandbox.io/s/7w81wm0z11?file=/src/index.js:0-1182_) for an example.
#### Credits
This project is sponsored by [Diagram.codes Studio](https://studio.diagram.codes)
Author:
- [Hugo Zapata](https://hugozap.com)
Special thanks (for contributing to the first version of this library) to:
- [https://github.com/lifeiscontent](https://github.com/lifeiscontent)
- [https://github.com/tokyoincode](https://github.com/tokyoincode)The ajax loading bits are based on:
- [https://github.com/iconic/SVGInjector](https://github.com/iconic/SVGInjector)
- [https://github.com/atomic-app/react-svg](https://github.com/atomic-app/react-svg)