npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

babel-plugin-jsx-svg-inject

v5.0.2

Published

Add SVG file imports for React components

Downloads

82

Readme

babel-plugin-jsx-svg-inject

Add SVG file imports for React components

This plugin can transform this:

<Icon svgName="eye" />

into this:

var _svgContents = <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 200 200"><circle cx="100" cy="100" r="100"/></svg>;
<Icon svgName="eye" svgContents={_svgContents} />;

The main benefit here is that explicit imports for the images are not needed and instead a single component can be used.

The plugin includes the contents of the file as a JSX element, so there is no need for additional plugins or loaders. There is also an option to have the imports added instead (useImports).

How does it work?

The plugin searches for a specific prop on JSX Elements (by default it's 'svgName') and adds the contents of the file as a JSX element (or a file import) for each one. The exported value is put in an additional prop (by default it's 'svgContents').

Upgrading to v.5

The plugin now outputs JSX elements instead of text. This has the benefit of not needing to use dangerouslySetInnerHTML, which in turn solves a problem React has with swapping SVGs in IE 11. The plugin encourages a use of very few (in most cases one) image components, so the changes should be minimal.

For example, if you previously had a component like this:

export default function Image({ svgName, svgContents, ...props }) {
  return <svg {...props} dangerouslySetInnerHTML={{ __html: svgContents }} />;
}

Image.propTypes = {
  svgContents: PropTypes.string.isRequired,
  svgName: PropTypes.string.isRequired,
};

it could be rewritten like so:

export default function Image({ svgName, svgContents, ...props }) {
  return <svg {...props}>{svgContents}</svg>;  // svgContents is used the same as React children
}

Image.propTypes = {
  svgContents: PropTypes.node.isRequired,  // The type has changed
  svgName: PropTypes.string.isRequired,
};

Upgrading to v.4

The plugin now inlines the source of the image by default. Previously another plugin or loader was needed for that (an import was added instead), which could be quite bothersome.

The upgrade should be painless if no complicated logic was used for importing the files. In case the imports are preferred, please use the useImports option.

Upgrading to v.3

In version 2.x and below the plugin looked for a JSX element with a specific name. This was less flexible - there was no simple way of having SVG injected into different tags. This was changed in version 3.0.0 and the JSX property now has the role that the tag previously had.

Usage

Install from the npm and then add this to .babelrc:

{
  "plugins": [
    "jsx-svg-inject"
  ]
}

Options

root

Default: '.'

The path to the icons.

In case root is a relative path (e.g. ./some-path), it will be resolved using the current working directory.

nameProp

Default: 'svgName'

The value of the prop with this name will be used for getting the SVG path.

contentsProp

Default: 'svgContents'

The value of the prop with this name will be used for passing the SVG contents.

unwrap

Default: false

If set to true, the <svg> element will be stripped and its props will be passed to the resulting element.

For example, with this option enabled and a file like this:

<SVG svgName="some-path/foo" />

the output might be something similar to this:

var _svgContents = <rect x=\"10\" y=\"10\" width=\"100\" height=\"100\" />;
<SVG svgName="some-path/foo" svgContents={_svgContents} viewBox="0 0 120 120" height="120" width="120" xmlns="http://www.w3.org/2000/svg" />;

When the <svg> element has multiple children, they have keys provided automatically.

useImports

Default: false

If true, a relative import will be added instead of an inlined content. This was the default behavior before v.4.

License

Copyright (c) 2017 Rafał Ruciński. Licensed under the MIT license.