3.3.0 • Published 2 years ago

gatsby-plugin-react-svg v3.3.0

Weekly downloads
86,061
License
MIT
Repository
github
Last release
2 years ago

gatsby-plugin-react-svg npm version

Adds svg-react-loader to gatsby webpack config.

Note: the plugin can remove SVGs from the built-in url-loader config in case invalid configuration.

Install

npm install --save gatsby-plugin-react-svg

How to use

// In your gatsby-config.js

plugins: [
  {
    resolve: "gatsby-plugin-react-svg",
    options: {
      rule: {
        include: /assets/ // See below to configure properly
      }
    }
  }
];

Configuration

The rule plugin option can be used to pass rule options. If either include or exclude options are present, svg-react-loader will use them and url-loader will be re-enabled with the inverse.

The following configuration uses svg-react-loader to process SVGs from a path matching /assets/, and url-loader to process SVGs from everywhere else.

{
  resolve: 'gatsby-plugin-react-svg',
  options: {
    rule: {
      include: /assets/
    }
  }
}

From now on you can import SVGs and use them as Components:

import Icon from "./path/assets/icon.svg";

// ...

<Icon />;

Another common configuration:

  • name SVGs used in React components like something.inline.svg and process them with svg-react-loader
  • name other SVGs (e.g. used in css/scss) something.svg and process them with the default url-loader
{
  resolve: 'gatsby-plugin-react-svg',
  options: {
    rule: {
      include: /\.inline\.svg$/
    }
  }
}

In React components:

import Something from "./path/something.inline.svg";

// ...

<Something />;

In styles file:

.header-background {
  background-image: url(./path/something.svg);
}

Using with typescript

To use SVGs with Typescript, create a custom type definition like this:

declare module "*.svg" {
  const content: any;
  export default content;
}

Make sure the file is contained in your tsconfig.json include.

SVG-React-Loader options

Any of the svg-react-loader query parameters can be passed down via the webpack config by including an options prop within the rule prop.

// In your gatsby-config.js

plugins: [
  {
    resolve: "gatsby-plugin-react-svg",
      options: {
        rule: {
          include: /\.inline\.svg$/,
          options: {
            tag: "symbol",
            name: "MyIcon",
            props: {
              className: "my-class",
              title: "example"
            },
            filters: [value => console.log(value)]
          }
        }
      }
  }
];

They can also be defined at the import level:

  import Fork from "-!svg-react-loader?props[]=className:w-4 h-4!../components/Icons/Fork.inline.svg";

Removing svg props (filters)

Unwanted SVG props can be removed with filters. Since filters are quite complex this plugin adds a simple key omitKeys to allow end users to quickly remove props that are problematic from their svg files.

{
  resolve: `gatsby-plugin-react-svg`,
  options: {
    rule: {
      include: /images\/.*\.svg/,
      omitKeys: ['xmlnsDc', 'xmlnsCc', 'xmlnsRdf', 'xmlnsSvg', 'xmlnsSodipodi', 'xmlnsInkscape']
      ///OR
      filters: [(value) => { console.log(value); }]
    }
  }
},

Troubleshooting

I get "InvalidCharacterError" overlay in my browser during development

Example of this error:

InvalidCharacterError: Failed to execute 'createElement' on 'Document':
The tag name provided ('data:image/svg+xml; ...

It's likely that you use SVG in your React component, that is processed by url-loader instead of svg-react-loader due to incorrect configuration.

I get endless spinner (with an infinite loop in the background) in my browser during development

It's likely that some of your SVGs used in css/sass files are processed by svg-react-loader instead of url-loader due to incorrect configuration.

I get error "Module parse failed" in console

Example of this error:

ERROR in ./src/images/some-image.png 1:0
Module parse failed: Unexpected character '�' (1:0)

In case you see such error, it's likely that you configured exclude/include rule options incorrectly. Please check configuration section above.

@hacktion/test-libraryportfolio-gatsbysomoy-portfoliogatsby-universal@jayellul/gatsby-theme-craftcmsgatsby-fassetjam-cms-starter@afuh/gatsby-theme-up42@up42/gatsby-theme-up42@leptest/gatsby-netlify-cmstest-theme-shawacademygatsby-theme-c32brawl-capped-webpage@rodriguesmyron/gatsby-theme-podcastgatsby-theme-utopix@kimchico/gatsby-themegatsby-theme-testlandonschropp.comgatsby-theme-fencinggit-repo-blog-generator@everything-registry/sub-chunk-1722rocketbelttemp-gatsby-themejesielviana-gatsby-theme-minimal-blog@antv/gatsby-theme-antv@arturthemaslov/gatsby-theme-intro-maslov@arcblock/gatsby-config@arcblock/gatsby-theme-docs@arcblock/gatsby-theme-www@aryan03/gatsby-theme-intro@amorist/gatsby-theme-antd@arene/gatsby-theme-intro@arene/gatsby-theme-intro-academic@bridgetool/gatsby-theme-dev@ccerda0520/gatsby-theme-woocommerce@adamwebster/tabini@addono/gatsby-theme-intro@philpl/gatsby-theme-mdx-deck@hashinteractive/gatsby-theme-reactor@iamgarrett/gatsby-theme-dmcm@iamgarrett/gatsby-theme-gmcm@lambdacurry/gatsby-theme@lehnfeld/gatsby-theme-intro@lundgren/gatsby-theme-lundgren-blog@exposuredesign/gatsby-theme-seen-alpha@mknudsen01/gatsby-theme-buildo@mmintel/gatsby-theme-indiegram@jaenjs/jaen@joe-fuentes/gatsby-theme-intro@jcaguirre/gatsby-shopify-theme@indicius/design-system@octopusthink/ghost-ship@pusdn/gatsby-theme-antv@rafaelquintanilha/gatsby-theme-countdown@scaleph/scaleph-gatsby-theme@rennehir/gatsby-theme-personal-site@opensumi/gatsby-theme@packdigital/gatsby-theme-ripperoni@packdigital/gatsby-theme-ripperoni-core@spiredigital1/chameleon@spraoi/gatsby-config@somoykhan/gatsby-theme-bootstrap-portfolio@silentsky/gatsby-theme-intro@rohs/gatsby-theme-intro@cratosw/gatsby-antd@defite/gatsby-theme-defite@caldera-digital/caldera-www@prg/gatsby-theme-bedrock@robinguan/gatsby-mdx-mui-themegatsby-theme-mdx-suite-base@up42/gatsby-theme-core@whey/gatsby-theme-whey@wkocjan/gatsby-theme-intro@w3f/gatsby-test@w3f/gatsby-theme-w3f@zalastax/nolb-gatsby-plugin-r@yurb/gatsby-theme-introgatsby-sleekgatsby-theme-nestxgatsby-theme-iotgatsby-theme-materialgatsby-theme-minimalistgatsby-theme-art-graphgatsby-theme-rdfsitegatsby-theme-potatogatsby-theme-personal-bloggatsby-theme-registrygatsby-theme-sarvasyagatsby-theme-amaranthgatsby-theme-advancedgatsby-starter-unogatsby-starter-hero-bloggatsby-theme-wtfgatsby-theme-zhgatsby-theme-w3fgatsby-theme-conegatsby-theme-cone-ocgatsby-theme-consumer-sitegatsby-theme-hansingatsby-theme-documents
3.3.0

2 years ago

3.1.0

3 years ago

3.0.1

4 years ago

3.0.0

5 years ago

2.1.2

5 years ago

2.1.1

6 years ago

2.1.0

6 years ago

2.0.0

6 years ago

2.0.0-beta1

6 years ago

1.1.1

7 years ago

1.1.0

7 years ago