Giter Club home page Giter Club logo

react-native-svg-transformer's Introduction

react-native-svg-transformer NPM version Downloads per month contributions welcome

React Native SVG transformer allows you to import SVG files in your React Native project the same way that you would in a Web application when using a library like SVGR to transform your imported SVG images into React components.

This makes it possible to use the same code for React Native and Web.

Usage

Import your .svg file inside a React component:

import Logo from "./logo.svg";

You can then use your image as a component:

<Logo width={120} height={40} />

Demo / Expo demo (iOS/Android/Web)

Installation and configuration

Step 1: Install react-native-svg library

Make sure that you have installed the react-native-svg library:

Step 2: Install react-native-svg-transformer library

yarn add --dev react-native-svg-transformer

Step 3: Configure the react native packager

For Expo SDK v41.0.0 or newer

Merge the contents from your project's metro.config.js file with this config (create the file if it does not exist already).

metro.config.js:

const { getDefaultConfig } = require("expo/metro-config");

module.exports = (() => {
  const config = getDefaultConfig(__dirname);

  const { transformer, resolver } = config;

  config.transformer = {
    ...transformer,
    babelTransformerPath: require.resolve("react-native-svg-transformer")
  };
  config.resolver = {
    ...resolver,
    assetExts: resolver.assetExts.filter((ext) => ext !== "svg"),
    sourceExts: [...resolver.sourceExts, "svg"]
  };

  return config;
})();

For React Native v0.72.1 or newer

Merge the contents from your project's metro.config.js file with this config (create the file if it does not exist already).

metro.config.js:

const { getDefaultConfig, mergeConfig } = require("@react-native/metro-config");

const defaultConfig = getDefaultConfig(__dirname);
const { assetExts, sourceExts } = defaultConfig.resolver;

/**
 * Metro configuration
 * https://reactnative.dev/docs/metro
 *
 * @type {import('metro-config').MetroConfig}
 */
const config = {
  transformer: {
    babelTransformerPath: require.resolve("react-native-svg-transformer")
  },
  resolver: {
    assetExts: assetExts.filter((ext) => ext !== "svg"),
    sourceExts: [...sourceExts, "svg"]
  }
};

module.exports = mergeConfig(defaultConfig, config);

For React Native v0.59 or newer

Merge the contents from your project's metro.config.js file with this config (create the file if it does not exist already).

metro.config.js:

const { getDefaultConfig } = require("metro-config");

module.exports = (async () => {
  const {
    resolver: { sourceExts, assetExts }
  } = await getDefaultConfig();
  return {
    transformer: {
      babelTransformerPath: require.resolve("react-native-svg-transformer")
    },
    resolver: {
      assetExts: assetExts.filter((ext) => ext !== "svg"),
      sourceExts: [...sourceExts, "svg"]
    }
  };
})();

Using TypeScript

If you are using TypeScript, you need to add this to your declarations.d.ts file (create one if you don't have one already):

declare module "*.svg" {
  import React from "react";
  import { SvgProps } from "react-native-svg";
  const content: React.FC<SvgProps>;
  export default content;
}

Configuring SVGR (how SVG images get transformed)

SVGR has a configuration file, which makes it possible for you to customize how SVG images get transformed to React/React Native.

Read more about the configuration options: Configuring SVGR and SVGR options.

For example, if you want to change SVG image's fill color from red to currentColor (keep in mind that this will be used for all SVG images in your app).

.svgrrc (create the file in your project's root folder if it does not exist)

{
  "replaceAttrValues": {
    "red": "currentColor"
  }
}

Changing SVG fill color in JS Code

Edit your .svgrrc file and include a line for replaceAttrValues that matching a hex code to {props.fill}

{
  "replaceAttrValues": {
    "#000": "{props.fill}"
  }
}

And then make sure your path tag inside the SVG file fill attribute is the hex code (in this case #000).

<svg width="14" height="14" viewBox="0 0 14 14" fill="none" xmlns="http://www.w3.org/2000/svg">
  <path d="M2.965 6.0925C4.045 8.215 ..." fill="#000"/>
</svg>

You can then use your image as a component:

<Logo width={120} height={40} fill={"any color"} />

Usage with Jest

To use Jest to test your React Native components that import .svg images, you need to add this configuration that mocks the SVG images that are transformed to React components:

// __mocks__/svgMock.js
module.exports = "SvgMock";

Then, depending on where you have your Jest configuration:

// package.json
{
  "jest": {
    "moduleNameMapper": {
      "\\.svg": "<rootDir>/__mocks__/svgMock.js"
    }
  }
}

or

// jest.config.js
module.exports = {
  moduleNameMapper: {
    "\\.svg": "<rootDir>/__mocks__/svgMock.js"
  }
};

Rendering custom fonts in iOS

At the moment react-native-svg does not support custom font families in iOS right out of the box. A workaround is to take your .svg with custom fonts and convert it to outlines. This will replace text tags for path tags in your .svg file.

Dependencies

In addition to React Native, this transformer depends on the following libraries:

react-native-svg-transformer's People

Contributors

abumalick avatar adsalihac avatar andrzejpolis-dna avatar chin8628 avatar christophby avatar cylim avatar danbockapps avatar dependabot[bot] avatar gasolin avatar gvarandas avatar illassad avatar inf3cti0n95 avatar kristerkari avatar l2hyunwoo avatar mitramejia avatar msand avatar rbright avatar rphlmr avatar wintus avatar xcarpentier avatar yvocilon avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

react-native-svg-transformer's Issues

[QUESTION] Is it possible to change "fill" property of a "Path" inside?

Hi. I was wondering if it'd be possible to change "fill" property of a svg. I have the following svg:

<svg xmlns="http://www.w3.org/2000/svg" width="24.431" height="24.431" viewBox="0 0 24.431 24.431">
  <g id="backspace" opacity="0.3">
    <path id="path" d="M0,0H24.431V24.431H0Z" fill="none"/>
    <path id="path-2" data-name="path" d="M22.4,3H7.126a1.916,1.916,0,0,0-1.619.9L0,12.162l5.507,8.256a1.925,1.925,0,0,0,1.619.906H22.4a2.042,2.042,0,0,0,2.036-2.036V5.036A2.042,2.042,0,0,0,22.4,3ZM19.341,15.816l-1.435,1.435L14.251,13.6,10.6,17.251,9.162,15.816l3.654-3.654L9.162,8.507,10.6,7.072l3.654,3.654,3.654-3.654,1.435,1.435-3.654,3.654Z" transform="translate(0 0.054)" fill="#CCC"/>
  </g>
</svg>

I've imported this svg and changed its width and height:

import Backspace from '../../../Customization/assets/backspace.svg';

<Backspace width='39' height='39' />

Is it possible to change the "fill" property of the "path" with id="path-2" without changing svg file?

Thank you.

Does not work with react Native 0.59.x

I just grabbed your example app and upgraded RN to version 0.59.2.

Application does not work at all either on IOS and Android.
Screenshot_1554058909

Dependencies:

"react": "16.8.3",
"react-native": "0.59.2",
"react-native-svg": "^9.3.5",
"react-native-svg-transformer": "^0.12.1",

ENOENT: no such file or directory, scandir due to metro.config.js

This works fine
module.exports = { transformer: { getTransformOptions: async () => ({ transform: { experimentalImportSupport: false, inlineRequires: false, }, }), }}

But when i update metro.config.js with
const { getDefaultConfig } = require('metro-config'); module.exports = (async () => { const { resolver: { sourceExts, assetExts, }, } = await getDefaultConfig(); return { resolver: { assetExts: assetExts.filter((ext) => ext !== 'svg'), sourceExts: [...sourceExts, 'svg', 'json'], }, transformer: { babelTransformerPath: require.resolve('react-native-svg-transformer'), getTransformOptions: async () => ({ transform: { experimentalImportSupport: false, inlineRequires: false, }, }), }, }; })();

This throws error ENOENT: no such file or directory, scandir

RN Version - 0.59.4
react-native-svg-transformer - 0.13.0

react-native-svg-transformer not working with expo

"react-native-svg": "8.0.10", (inside expo's package.json)
react-native "version": "0.57.1"
expo "version": "32.0.6"
"react-native-svg-transformer": "^0.12.1"

metro.config.js:


module.exports = (async () => {
    const {
        resolver: { sourceExts, assetExts }
    } = await getDefaultConfig();
    console.log('source exts: ', sourceExts);
    return {
        transformer: {
            babelTransformerPath: require.resolve("react-native-svg-transformer")
        },
        resolver: {
            assetExts: assetExts.filter(ext => ext !== "svg"),
            sourceExts: [...sourceExts, "svg"]
        }
    };
})();

packagerOpts inside app.json:

{
  "expo": {
    "packagerOpts": {
      "config": "metro.config.js"
    },
    "name": "Plogalong",
    "slug": "plogalong",
    "privacy": "public",
    "sdkVersion": "32.0.0",
    "platforms": [
      "ios",
      "android"
    ],
    "version": "1.0.0",
    "orientation": "portrait",
    "icon": "./assets/images/icon.png",
    "splash": {
      "image": "./assets/images/splash.png",
      "resizeMode": "contain",
      "backgroundColor": "#ffffff"
    },
    "updates": {
      "fallbackToCacheTimeout": 0
    },
    "assetBundlePatterns": [
      "**/*"
    ],
    "ios": {
      "supportsTablet": true
    }
  }
}

metro.config.js and app.json are at the same level.

Inside the component:
import { BackPacker } from '../assets/icons/backpacker.svg';

This is resulting in the following error:
image

react-native-web support

Hi @kristerkari,

Thank you for your plugin it is working great for React native projects,

We are trying to share our codebase across react-native and web(using react-native-web), our codebase is originally developed for React native CLI project, now we would like to add web support and using CRA with CRA-rewired but we are facing a problem:

According to CRA docs if you want to import SVG as react component you should use:
import { ReactComponent as Logo } from './logo.svg';

but SVGR is making only export default SvgComponent so we cannot use this approach, to fix this we could add a small fix here which should not break anything:

var jsCode = svgr.sync(src, svgrConfig) + '\nexport const ReactComponent = SvgComponent;';

which gives us needed support to work in react-native and web projects(also definitions.d.ts should be updated accordingly).

Maybe we could make a PR for this, or what do you think?

Here is a quick fix for postinstall npm/yarn script:

"postinstall": "sed -e \"s:var jsCode = svgr.sync(src, svgrConfig);:var jsCode = svgr.sync(src, svgrConfig) + 'export const ReactComponent = SvgComponent;';:g\" -i.bak ./node_modules/react-native-svg-transformer/index.js"

Warning while Interpolating animated SVG: '"###.###" is not a valid color or brush'

I am attempting to import svgs from a class template and animating their colors:

My .svgrrc.js:

/* eslint-disable no-shadow */
module.exports = {
  native: true,
  template(
    { template },
    opts,
    {
      imports, componentName, props, jsx, exports,
    },
  ) {
    const flowTpl = template.smart({ plugins: ['flow'] })
    return flowTpl.ast`
      ${imports}
      class ${componentName} extends React.Component<any, any> {
        render () {
          const ${props} = this.props;
          return ${jsx}
        }
  
      }
      ${exports}
    `;
  },
  dimensions: false,
  replaceAttrValues: {
    color: "{props.color}",
    color1: "{props.color1}",
    color2: "{props.color2}",
    color3: "{props.color3}",
    color4: "{props.color4}",
    color5: "{props.color5}",
    opacity: "{props.opacity}",
    opacity1: "{props.opacity1}",
    opacity2: "{props.opacity2}",
    opacity3: "{props.opacity3}",
    opacity4: "{props.opacity4}",
    opacity5: "{props.opacity5}",
    opt: "{props.opt}",
    opt1: "{props.opt1}",
    opt2: "{props.opt2}",
    opt3: "{props.opt3}",
    opt4: "{props.opt4}",
    opt5: "{props.opt5}"
  }
}

I can then animate the imported svgs like so:

import SmileSvg from './SmileSvg.svg';
const AnimatedSmileSvg = Animated.createAnimatedComponent(SmileSvg);

SmileSvg.svg replaces the named attributes (color, color1, opacity1):

<svg width="80" height="80" viewBox="0 0 80 80" fill="none" xmlns="http://www.w3.org/2000/svg">
<rect opacity="opacity1" width="80" height="80" rx="40" fill="color1"/>
<path fill-rule="evenodd" clip-rule="evenodd" d="..." fill="color"/>
</svg>

However, when I interpolate I get warnings that appear like the following:

"42853378097.68554577" is not a valid number or brush.
The color then does not interpolate.

This occurs only on iOS where I have to process the color,

const colorMap = Platform.select({
  ios: {
    enabled: [processColor(COLORS.WHITE), processColor(COLORS.WHITE), 0.2],
    selected: [processColor(COLORS.PRIMARY_TEAL), processColor(COLORS.WHITE), 1],
  }, 
  android: {
    enabled: [COLORS.WHITE, COLORS.WHITE, 0.2],
    selected: [COLORS.WHITE, COLORS.PRIMARY_TEAL, 1],
  },
});
...
export default class GridIcon extends Component<GridIconProps, GridIconState> {
... // GridIcon constructor
this.state = {
      pressAnim: new Animated.Value(0),
};
...
// GridIcon onPress
Animated.timing(
  this.state.pressAnim,
  { toValue, duration: 200 },
);
...
<AnimatedSmileSvg
      color1={this.state.pressAnim.interpolate({
        inputRange: [0, 1],
        outputRange: [colorMap.enabled[0], colorMap.selected[0]],
      }},
      color={this.state.pressAnim.interpolate({
        inputRange: [0, 1],
        outputRange: [colorMap.enabled[1], colorMap.selected[1]],
      }},
      opacity1={this.state.pressAnim.interpolate({
        inputRange: [0, 1],
        outputRange: [colorMap.enabled[2], colorMap.selected[2]],
      })}
/>

Does anyone have a similar issue?

Notes:

Calling useNativeDriver = true on the Animated.timing function causes an invariant violation:

"Attempt to get native tag from node not marked as 'native'"

Add documentation to create svgMock with ts extension

I believe that could be helpful to add documentation to create a svgMock file for typescript project. Maybe people want to add just .ts files in your folder structure.

To fix on my current project I did it:

const exported = 'SvgMock';
export const ReactComponent = exported;
export default exported;

If sounds good I can contribute to the project with this adding it on the documentation.

Unable to resolve SVG file

Hi, I've been trying to import SVG file to use in my react-navigation file as an icon. I installed the library as you write in the readme file. But, I got an error.

Unable to resolve "./assets/icons/bottom_tab/profile_active.svg" from "MainNavigation.js" Failed building JavaScript bundle.

I've been checked my file, and I'm really sure that the svg file is in right directory.

My environment:

  • expo: 33
  • react-native-svg: 9.4.0
  • react-native-svg-transformer: 0.13.0

I got this error on both android and ios.

Setting color through fill prop not working properly on 0.14.1

Using fill on svgs containing groups <g> with fill="none" and actual fill color set deeper in the tree doesn't work. In order to make it work, I have to set the fill color on the top most group.

This will work:

<svg width="11px" height="13px" viewBox="0 0 11 13" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
    <g id="Page-1" stroke="none" stroke-width="1" fill="#000000" fill-rule="evenodd">
        <path d="M10.260805,9.55......" fill="#000000"></path>
    </g>
</svg>

But this wont:

<svg width="11px" height="13px" viewBox="0 0 11 13" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
    <g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
        <path d="M10.260805,9.55......" fill="#000000"></path>
    </g>
</svg>

On 0.13 its is working fine! Is there any breaking change which is not mentioned?

Can't import svgs

If I want to import my svg like import Star from '../../assets/svgs/pinnedStar.svg';
I get this error

Warning: React.createElement: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: number.

my rn-cli.config.js:

const { getDefaultConfig, mergeConfig } = require('metro-config');

module.exports = mergeConfig(
  async () => {
    const {
      resolver: { sourceExts, assetExts },
    } = await getDefaultConfig();
    console.log(sourceExts);

    return {
      transformer: {
        babelTransformerPath: require.resolve('react-native-svg-transformer'),
      },
      resolver: {
        assetExts: assetExts.filter(ext => ext !== 'svg'),
        sourceExts: [...sourceExts, 'svg'],
      },
    };
  },
  {
    transformer: {
      babelTransformerPath: require.resolve(
        'react-native-typescript-transformer'
      ),
    },
  }
);

Update color of SVG?

Is it possible to change the color of an imported svg image based on state updates?
This doesn't work. The style is always primaryBlue even when the active value is true and the textSubdued should be applied.

<Home color={active ? primaryBlue : textSubdued} />;

SVG file don't render on Android device

Hi,

I have a svg file to render. I'm constructing a component and import to my screens.

My packages versions:

So, I have this first:

import React from 'react';
import { SvgProps } from 'react-native-svg';
import { StyleSheet, ViewProps } from 'react-native';
import { View } from 'native-base';

interface ImageBackgroundProps {
  background: React.StatelessComponent<SvgProps> | number,
  height: number,
  width: number,
  children: React.ReactNode,
  style?: ViewProps['style'],
}

export type ImageComponent = React.FunctionComponent<ImageBackgroundProps>;

export const ImageBackground: ImageComponent = ({ background, children, width, height, style }) => {
  const Image = background;
  return (
    <View style={[styles.wrapped, height, style]}>
      <Image height={height} width={width} style={styles.image} />
      {children}
    </View>
  );
}

const styles = StyleSheet.create({
  wrapped: {
    alignItems: 'center',
    marginBottom: 80,
  },
  image: {
    position: 'absolute',
  },
});

So, when I import my new component on screen and call the svg file, I have this:

<ImageBackground background={CardSVG} width={270} height={168}>
  <View>
    <Text>
      Bla bla bla
    </Text>
  </View>
  <View>
    <Text>Bla bla bla</Text>
    <Text>Bla bla bla</Text>
  </View>
  <View>
    <View>
      <Icon
        name="questioncircleo"
        size={20}
        color="white"
      />
    </View>
  </View>
</ImageBackground>

My svg looks like this:

<?xml version="1.0" encoding="UTF-8"?>
<svg width="270px" height="168px" viewBox="0 0 270 168" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
    <!-- Generator: Sketch 58 (84663) - https://sketch.com -->
    <title>mdpi/Background</title>
    <desc>Created with Sketch.</desc>
    <defs>
        <linearGradient x1="100%" y1="30.6419753%" x2="0%" y2="69.3580247%" id="linearGradient-1">
            <stop stop-color="#E62284" offset="0%"></stop>
            <stop stop-color="#264480" offset="100%"></stop>
        </linearGradient>
        <linearGradient x1="-2.22044605e-14%" y1="50%" x2="100%" y2="50%" id="linearGradient-2">
            <stop stop-color="#FFFFFF" stop-opacity="0" offset="0%"></stop>
            <stop stop-color="#FFFFFF" offset="100%"></stop>
        </linearGradient>
    </defs>
    <g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
        <g id="6.4.2---Single-CC" transform="translate(-45.000000, -100.000000)">
            <g id="CREDIT-CARD" transform="translate(45.000000, 100.000000)">
                <g id="Background">
                    <rect id="BG" fill="url(#linearGradient-1)" x="0" y="0" width="270" height="168" rx="10"></rect>
                    <path d="M10,0 L267,0 C268.656854,-3.04359188e-16 270,1.34314575 270,3 L270,168 L270,168 L6,168 C2.6862915,168 4.05812251e-16,165.313708 0,162 L0,10 C-6.76353751e-16,4.4771525 4.4771525,1.01453063e-15 10,0 Z" id="Light" fill-opacity="0.15" fill="url(#linearGradient-2)"></path>
                </g>
            </g>
        </g>
    </g>
</svg>

What would be the possible problem I am facing? I have done numerous tests. I believe the problem is in the structure of this particular svg, since when I import any other svg, I have no rendering problem.

Remember that this svg is not being rendered only on Android. On iOS devices the same problem does not occur.

Invariant Violation: View config not found for name <svg width

61540727-18a60480-aa36-11e9-9b69-09b661061c9a

React native info output:

System:
    OS: Linux 4.15 Ubuntu 18.04.2 LTS (Bionic Beaver)
    CPU: (4) x64 Intel(R) Core(TM) i7-5500U CPU @ 2.40GHz
    Memory: 1.40 GB / 11.60 GB
    Shell: 4.4.20 - /bin/bash
  Binaries:
    Node: 10.16.0 - /usr/bin/node
    Yarn: 1.17.3 - /usr/bin/yarn
    npm: 6.9.0 - /usr/local/bin/npm
  IDEs:
    Android Studio: 3.3 AI-182.5107.16.33.5314842
  npmPackages:
    react: 16.8.6 => 16.8.6 
    react-native: ^0.60.4 => 0.60.4

Steps To Reproduce
Before:
yarn add react-native-svg
yarn add react-native-svg-transformer -D

After
Enable hermes
yarn add babel-plugin-inline-import -D

myComponent.js

import React from "react";
import { Platform } from "react-native";

import IconHome from "./../imgs/icon/home.svg";
export const Home = props => ( <IconHome { ...props } width={22} height={22} /> );
...

screen.js

import { Search, Genero, MinhasMusicas, Home } from "./../components/Icon";
<Home key={1} />

Stroke color is not transformed correctly

I tried to change color by passing color code to stroke prop like this:

<Logo stroke={colorCodeVariable} />

It works as I expected in local development (I'm using expo), but in production stroke color is not changed whatsoever.

The svg file is like:

<svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
  <path d="..." stroke="#000" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
  <path d="M22.7896 1.21045L10.4673 13.5352" stroke="#000" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
</svg>

Flow type error on created components

Hi @kristerkari

Thanks for this package, it's very handy.

When using it and Flow together, I always get these errors from Flow:

React$Element<number>
import EmailIllustration
Cannot create `View` element because in type argument  `Yield` [1] of the return value of property `children.@@iterator`: Either  `React.Element` [2] is incompatible with  `React.Portal` [3]. Or property `@@iterator` is missing in  `React.Element` [2] but exists in  `$Iterable` [4].Flow(InferError)

Here's my metro.config.js:

/**
 * Metro configuration for React Native
 * https://github.com/facebook/react-native
 *
 * @format
 */

const { getDefaultConfig } = require("metro-config")

module.exports = (async () => {
  const {
    resolver: { sourceExts, assetExts }
  } = await getDefaultConfig()
  return {
    transformer: {
      transform: {
        experimentalImportSupport: false,
        inlineRequires: false,
      },
      babelTransformerPath: require.resolve("react-native-svg-transformer")
    },
    resolver: {
      assetExts: assetExts.filter(ext => ext !== "svg"),
      sourceExts: [...sourceExts, "svg"]
    }
  }
})()

And a simplified sample of how I'm using it:

import EmailIllustration from '../../../assets/illustrations/email.svg'

class ConfirmYourEmail extends React.Component {
render () {
  return (
    <View>
      <EmailIllustration />
    </View>
    )
  }
}

Thoughts?

Invariant Violation: Element type is invalid

I'm getting the following error when importing SVG's:

Invariant Violation: Element type is invalid: expected a string (for built-in components) or a class/function (for composite components) but got: number.

Check the render method of `MySVG`.

My metro config: (the one from the example app does not work for me)

const { getDefaultConfig, mergeConfig } = require("metro-config");

const svgConfig = (async () => {
    const {
        resolver: { sourceExts, assetExts }
    } = await getDefaultConfig();
    return {
        transformer: {
            babelTransformerPath: require.resolve("react-native-svg-transformer")
        },
        resolver: {
            assetExts: assetExts.filter(ext => ext !== "svg"),
            sourceExts: [...sourceExts, "svg"]
        }
    };
})();

const defaultConfig = {
    transformer: {
        getTransformOptions: async () => ({
            transform: {
                experimentalImportSupport: false,
                inlineRequires: false,
            },
        }),
    },
};

module.exports = mergeConfig(svgConfig, defaultConfig);

I can get the example app to work fine. I tried to alter a few things there, to see if I could break it. No clues yet. I suspect this is a config issue.

work on the web, Warning: </static/media/splashScreen.0f923900.svg /> is using incorrect casing. Use PascalCase for React components, or lowercase for HTML elements.

I have installed in my project expo install react-native-svg.

I have exported the svg as a component by doing:

import Logo from './logo.svg';
export default Logo;

It can render on native but fail on the web.

bundle.js:69367 Warning: </static/media/splashScreen.0f923900.svg /> is using incorrect casing. Use PascalCase for React components, or lowercase for HTML elements.

I have followed that configuration https://github.com/react-native-community/react-native-svg#use-with-svg-files

My metro.config.js is equal:

const { getDefaultConfig } = require('metro-config');

module.exports = (async () => {
  const {
    resolver: { sourceExts, assetExts },
  } = await getDefaultConfig();
  return {
    transformer: {
      babelTransformerPath: require.resolve('react-native-svg-transformer'),
    },
    resolver: {
      assetExts: assetExts.filter(ext => ext !== 'svg'),
      sourceExts: [...sourceExts, 'svg'],
    },
  };
})();

My app.json got added

{
+    "packagerOpts": {
+      "config": "metro.config.js",
+      "sourceExts": ["js", "jsx", "ts", "tsx", "svg"]
+    },
}

Existing default Metro transforms interfere with `react-native-svg-transformer`

Filing this issue equally for investigation and documentation for those whom may have been experience similar issues. This information may be useful in troubleshooting various configurations.

experimentalImportSupport: false and inlineRequires: false appear to break react-native-svg-transformer

  transformer: {
    getTransformOptions: async () => ({
      transform: {
        experimentalImportSupport: false,
        inlineRequires: false,
      },
    }),
  },

I found an issue within styled-components produces when these are present with babelTransformerPath: require.resolve("react-native-svg-transformer"), see styled-components/styled-components#2536

Not catching the style/classes correctly (Black shape)

Hi, I have an SVG file with <style> tags, and the conversion is not going well. That renders as a black shape of the SVG. I think that it doesn't catch the <styles> tag well... what I can do? I have so much SVG Files...

SVG File:

<?xml version="1.0" encoding="utf-8"?>
<!-- Generator: Adobe Illustrator 23.0.2, SVG Export Plug-In . SVG Version: 6.00 Build 0)  -->
<svg version="1.1" id="Capa_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
	 viewBox="0 0 96 96" style="enable-background:new 0 0 96 96;" xml:space="preserve">
<style type="text/css">
	.st0{fill:#FFFFFF;}
	.st1{fill:#222FFF;}
</style>
<path class="st0" d="M48,96c26.5,0,48-21.5,48-48S74.5,0,48,0S0,21.5,0,48S21.5,96,48,96"/>
<path class="st0" d="M48,95c26,0,47-21,47-47S74,1,48,1S1,22,1,48S22,95,48,95"/>
<g>
	<g id="Navigation">
		<g>
			<path class="st1" d="M24,30.9h48.6c1.8,0,3.2-1.5,3.2-3.3c0-1.8-1.4-3.3-3.2-3.3H24c-1.8,0-3.2,1.5-3.2,3.3
				C20.8,29.4,22.2,30.9,24,30.9z M72.6,44.3H24c-1.8,0-3.2,1.5-3.2,3.3c0,1.8,1.4,3.3,3.2,3.3h48.6c1.8,0,3.2-1.5,3.2-3.3
				C75.8,45.7,74.3,44.3,72.6,44.3z M72.6,64.2H24c-1.8,0-3.2,1.5-3.2,3.3c0,1.8,1.4,3.3,3.2,3.3h48.6c1.8,0,3.2-1.5,3.2-3.3
				C75.8,65.6,74.3,64.2,72.6,64.2z"/>
		</g>
	</g>
</g>
</svg>

Thanks.

Can't make it work at all

Seems like this package doesn't work at all. Moreover, I've broken my project because of that.

I tried it with react-native 55-59 and every time I see only
Cannot find module 'metro/src/transformer'

What's wrong with that? What the hell is that transformer? Where should I get it from?

Some svg images not transformed properly

First of all thanks for the great work! Was very helpful and I must say it works for most of the images that I use in my app, except for one.

Here is a reproducible demo

FYI: There are some semi-transparent objects in this svg.

Any help will be appreciated.
Thanks!

react: 16.8.3
react-native: 0.59.8
react-native-svg: ^9.4.0
react-native-svg-transformer: ^0.13.0

Unable to resolve "react-native-svg" from "assets/icon/cancel-exit.svg"

After migrate from Expo SDK32 to Expo SDK35 I get an error - 'Unable to resolve "react-native-svg" from "assets / icon / cancel-exit.svg"'. I installed the library as you write in the readme file.

My package.json is the following:
"dependencies": {
"expo": "^35.0.0",
"expo-asset": "~7.0.0",
"expo-camera": "~7.0.0",
"expo-constants": "~7.0.0",
"expo-file-system": "~7.0.0",
"expo-font": "~7.0.0",
"expo-image-picker": "~7.0.0",
"expo-localization": "~7.0.0",
"expo-permissions": "~7.0.0",
"key-mirror": "^1.0.1",
"prop-types": "^15.7.2",
"react": "16.9.0",
"react-native": "https://github.com/expo/react-native/archive/sdk-35.0.0.tar.gz",
"react-native-flash-message": "^0.1.13",
"react-native-gesture-handler": "~1.3.0",
"react-native-image-gallery": "^2.1.5",
"react-native-indicator": "^1.0.0",
"react-native-progress-bar-animated": "^1.0.6",
"react-navigation": "^4.0.7",
"react-navigation-stack": "^1.9.0",
"react-redux": "6.0.0",
"redux": "^4.0.1",
"redux-devtools-extension": "^2.13.8",
"redux-thunk": "^2.3.0",
"remote-redux-devtools": "0.5.16",
"scheduler": "^0.15.0"
},
"devDependencies": {
"@babel/plugin-transform-react-jsx-source": "^7.2.0",
"babel-plugin-module-resolver": "^3.2.0",
"babel-preset-expo": "^7.0.0",
"react-native-svg-transformer": "^0.13.0"
},

My app.json is the following:
"packagerOpts": {
"config": "metro.config.js",
"sourceExts": ["js", "jsx", "ts", "tsx", "svg"]
},
"assetBundlePatterns": ["**/*"]

My metro.config.js:
const { getDefaultConfig } = require('metro-config');

module.exports = (async () => {
const {
resolver: { sourceExts, assetExts }
} = await getDefaultConfig();
return {
transformer: {
babelTransformerPath: require.resolve('react-native-svg-transformer')
},
resolver: {
assetExts: assetExts.filter(ext => ext !== 'svg'),
sourceExts: [...sourceExts, 'svg']
}
};
})();

Please help, Tks!

SVG with react native Animated

Hi, any idea how to use Animated (react native) with svgs? Setting it's height and width to an animated value does not seem to work.

letter-spacing causes app to crash

I've been trying to figure this issue out for a while now but it seems that adding a letter-spacing attribute to any element causes the app to crash.

This looks like an issue with react-native-svg itself, using a numeric value causes the crash as mentioned here:

software-mansion/react-native-svg#568

Here's an example adapted from the issue above:

<Svg width={300} height={320} viewBox="0 0 32 32"> <G fill="none" fillRule="evenodd"> <Text fontFamily="Raleway-Bold, Raleway" fontSize={12} fontWeight="bold" letterSpacing={1} fill="#FF1E4F" > <TSpan x={10} y={20}> {15} </TSpan> </Text> </G> </Svg>

The fix is to use a string as the value (letterSpacing={1} to letterSpacing="1") but since this transform automatically converts the value to a number, it will always crash. I'm not sure where the fix should be, in this library or in react-native-svg itself.

Any workarounds for it?

0.12.0 - application freezes while rendering SVG

Hey,

Thanks for great work on the svg-transformer!

After upgrade from 0.11.3 to 0.12.0 my application freezes when I'm navigating to screen, that contains imported SVG.

Tested on React Native 0.57.5.

Example SVG, that app freezes on, below:

<svg width="30px" height="52px" viewBox="0 0 30 52" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
    <defs>
        <linearGradient x1="-6.16521421%" y1="14.7934649%" x2="100%" y2="91.4270586%" id="linearGradient-1">
            <stop stop-color="#FAA461" offset="0%"></stop>
            <stop stop-color="#F75C1C" offset="100%"></stop>
        </linearGradient>
    </defs>
    <g id="ONBOARDING-FULL" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
        <g id="000-B" transform="translate(-287.000000, -462.000000)" fill="url(#linearGradient-1)">
            <g id="smartphone-(1)" transform="translate(287.000000, 462.000000)">
                <path d="M16.411208,47.8814655 C16.411208,48.6383688 15.7792968,49.2521215 15,49.2521215 C14.2207032,49.2521215 13.588792,48.6383688 13.588792,47.8814655 C13.588792,47.1245623 14.2207032,46.5108095 15,46.5108095 C15.7792968,46.5108095 16.411208,47.1245623 16.411208,47.8814655 Z M3.46153846,9.18965517 L26.5384615,9.18965517 L26.5384615,41.8017241 L3.46153846,41.8017241 L3.46153846,9.18965517 Z M26.3076923,0 C28.3458533,0.00218884138 29.9977464,1.60661374 30,3.5862069 L30,48.4137931 C29.9977464,50.3933863 28.3458533,51.9978112 26.3076923,52 L3.69230769,52 C1.65414669,51.9978112 0.0022536,50.3933863 0,48.4137931 L0,3.5862069 C0.0022536,1.60661374 1.65414669,0.00218884138 3.69230769,0 L26.3076923,0 Z M9.80769231,2.9137931 C9.29792665,2.9137931 8.88461538,3.31522761 8.88461538,3.81034483 C8.88461538,4.30546204 9.29792665,4.70689655 9.80769231,4.70689655 L20.1923077,4.70689655 C20.7020733,4.70689655 21.1153846,4.30546204 21.1153846,3.81034483 C21.1153846,3.31522761 20.7020733,2.9137931 20.1923077,2.9137931 L9.80769231,2.9137931 Z M15,51.045225 C16.7983775,51.0430362 18.2551082,49.6281655 18.2573618,47.8814655 C18.2573618,46.1343278 16.7988282,44.7177061 15,44.7177061 C13.2011718,44.7177061 11.7426382,46.1343278 11.7426382,47.8814655 C11.7426382,49.6286032 13.2011718,51.045225 15,51.045225 Z M28.3846154,42.6982759 L28.3846154,8.29310345 C28.3846154,7.79798623 27.9713041,7.39655172 27.4615385,7.39655172 L2.53846154,7.39655172 C2.02869588,7.39655172 1.61538462,7.79798623 1.61538462,8.29310345 L1.61538462,42.6982759 C1.61538462,43.1933931 2.02869588,43.5948276 2.53846154,43.5948276 L27.4615385,43.5948276 C27.9713041,43.5948276 28.3846154,43.1933931 28.3846154,42.6982759 Z" id="Combined-Shape"></path>
            </g>
        </g>
    </g>
</svg>

[Request] support for getTransformOptions in >0.60

What's the status on getting support for the getTransformOptions in metro.config.js?

			getTransformOptions: async () => ({
				transform: {
					experimentalImportSupport: false,
					inlineRequires: false,
				},
			}),

Expected Node Error

Hi guys,

I encounter some error.

I followed everything on the docs.

"expokit": "^35.0.3"
"expo": "^35.0.0",
"react-native-svg": "^9.9.2",

Screen Shot 2019-11-03 at 11 29 15 PM

thanks for helping :D

SVGR config

Hi, have problem with svgr config. Works configuration params which has been added to package.json. Stand alone files like svgr.config.js or .svgrrc - doesn't work.
Thank you.

An SVG is no longer rendered correctly after the update

Hi, after updating from react-native-svg-transformer 0.13.0 to 0.14.0 at the moment one of the svg that I have in the application is not rendering well, in the previous version everything was perfect.

Attached photos

My environment:
"@svgr/core": "^4.3.3",
"react": "16.11.0",
"react-native": "0.61.4",
"react-native-svg-transformer": "^0.14.0",

My application is only in iOS, I don't know if Android has the same behavior

with 0.13.0
Screenshot 2019-11-15 at 17 11 27

with 0.14.0
Screenshot 2019-11-15 at 17 10 43

I do the import and render this way:

import UserIcon from '../../assets/icons/ico-user.svg';

< UserIcon width={11} height={11} />

Thanks

Changing SVG fill color in JS Code -- need processColor() for IOS

Followed the steps under https://github.com/kristerkari/react-native-svg-transformer#changing-svg-fill-color-in-js-code.

Called my svg element like so:
<Account width={100} height={100} color={'red'} />

Works fine in Android. SVG icon is red yay. Problem is in IOS I get this error:
`JSON value of 'red' of type NSString cannot be converted to a UIColor. Did you forget to call processColor() on the JS side?

Changed to:

import {processColor} from 'react-native';
...
<Account width={100} height={100} color={processColor('red')} />

and then it worked in IOS, but causes issues in Android.
Only way I can see to do it now is:

import {processColor, Platform} from 'react-native';
...
<Account width={100} height={100} color={Platform.OS === 'ios' ? processColor('red') : 'red'} />

Anyone experienced this or have a better idea of how to solve this? End of day tired and haven't looked through this package source code to investigate further.

Does not work with customized project root

Hiya, I have a RN 0.59.2 project with config that looks like this:

const path = require("path");

const { getDefaultConfig } = require("metro-config");

module.exports = (async () => {
  const {
    resolver: { sourceExts, assetExts }
  } = await getDefaultConfig();

  return {
    transformer: {
      getTransformOptions: async () => ({
        transform: {
          experimentalImportSupport: false,
          inlineRequires: false
        }
      }),
      babelTransformerPath: require.resolve("react-native-svg-transformer")
    },
    resolver: {
      assetExts: assetExts.filter(ext => ext !== "svg"),
      sourceExts: [...sourceExts, "svg"],

      extraNodeModules: {
        shared: path.resolve(__dirname, "../shared")
      }
    },
    // Move the project root up a level so we can access /shared, otherwise the packager can't access those assets.
    projectRoot: path.resolve(__dirname, "../")
  };
})();

I'm seeing the same issue from #14, but as far as I can tell the only difference between our configs is the moved project root and extra node module. Any ideas?

Dependencies:

"react": "16.8.3",
"react-native": "^0.59.2",
"react-native-svg": "^9.3.7",
"react-native-svg-transformer": "^0.12.1",

[Question] How mock imports with jest

When testing my application, jest can't mock the imports:

 FAIL  __tests__/common/componnents/Button.test.js
  โ— Test suite failed to run

    Jest encountered an unexpected token

    This usually means that you are trying to import a file which Jest cannot parse, e.g. it's not plain JavaScript.

    By default, if Jest sees a Babel config, it will use that to transform your files, ignoring "node_modules".

    Here's what you can do:
     โ€ข To have some of your "node_modules" files transformed, you can specify a custom "transformIgnorePatterns" in your config.
     โ€ข If you need a custom transformation specify a "transform" option in your config.
     โ€ข If you simply want to mock your non-JS modules (e.g. binary assets) you can stub them out with the "moduleNameMapper" config option.

    You'll find more details and examples of these config options in the docs:
    https://jestjs.io/docs/en/configuration.html

    Details:

    /home/marcos/git/it-happens/mateusapp/appcrm_v2/shared/common/components/CartaoDepartamento/CartaoDepartamento.component.js:21
      return import('../../res/Departamentos/mercearia.svg');
             ^^^^^^

    SyntaxError: Unexpected token import

I've tried several things (since I'm new to testing), like using this gist, I created a file named react-native-svg-mock.js inside the project_root/__mock__/ and my jest.config.js looked like this.

// jest.config.js
const {defaults} = require('jest-config');

module.exports = {
    verbose: true,
    moduleFileExtensions:[...defaults.moduleFileExtensions],
    transform: {
        "\\.svg$": "<rootDir>/__mocks__/react-native-svg-mock.js"
      },
    preset: 'react-native',

};

I've tried as well configs like this one bellow, since inside the metro.config.js , it's associated with babelTransformerPath, but when using it, jest complains about a process function missing

// jest.config.js
const {defaults} = require('jest-config');

module.exports = {
    verbose: true,
    moduleFileExtensions:[...defaults.moduleFileExtensions],
    transform: {
        "\\.svg$": require.resolve("react-native-svg-transformer")
      },
    preset: 'react-native',

};

output

yarn run v1.17.3
$ jest
 FAIL  __tests__/common/componnents/Button.test.js
  โ— Test suite failed to run

    TypeError: Jest: a transform must export a `process` function.

      1 | import React from 'react'
    > 2 | import VoltarAndroid from './../res/botao_voltar.svg'
        | ^
      3 | import VoltarIos from './../res/back_ios.svg'
      4 | import { Platform, View } from 'react-native'
      5 | 

      at ScriptTransformer._getTransformer (node_modules/@jest/transform/build/ScriptTransformer.js:291:15)
      at ScriptTransformer.transformSource (node_modules/@jest/transform/build/ScriptTransformer.js:353:28)
      at ScriptTransformer._transformAndBuildScript (node_modules/@jest/transform/build/ScriptTransformer.js:457:40)
      at ScriptTransformer.transform (node_modules/@jest/transform/build/ScriptTransformer.js:513:25)
      at Object.<anonymous> (shared/common/components/BackButton.js:2:1)

Can anyone help me to use this module with jest properly?


Edit

How to reproduce the error:

Clone the example repo:

git clone https://github.com/kristerkari/react-native-svg-example

go inside the project folder and add Jest as dependency:

yarn add --dev jest

or using npm

npm install --save-dev jest

create a folder and file with the following structure __test__/app.test.js inside the root folder.

Add the following code to app.test.js:

import Hostgator from "./logos/hostgator.svg";

const sum = (a,b)=> a + b

test('adds 1 + 2 to equal 3', () => {
  expect(sum(1, 2)).toBe(3);
});

Now that we have a simple test, if we try to run

yarn test

The test won't passed because because of this import.

If we comment the import as following:

//import Hostgator from "./logos/hostgator.svg";

const sum = (a,b)=> a + b

test('adds 1 + 2 to equal 3', () => {
  expect(sum(1, 2)).toBe(3);
});

The test will pass.

File not working

First off, thanks for the package, it works a treat with most SVG files.

I have trouble with one file, no errors it just doesn't show, the svg file seems ok, it works on other svg viewers, there is no base64 data, just paths and circles.

After a few hours of tying different things I am at a loss, I'll attach the file and hope someone can help me know if it's a bug or a problem with the file and help me find a solution ๐Ÿ˜

The problem SVG: http://beau-carrel.com:1778/problem.svg

React Native 0.59.9
react-native-svg: 9.5.3
react-native-svg-transformer: 0.13.0

metro.config.js
`const { getDefaultConfig } = require("metro-config");

module.exports = (async () => {
const {
resolver: { sourceExts, assetExts }
} = await getDefaultConfig();
return {
transformer: {
babelTransformerPath: require.resolve("react-native-svg-transformer"),
getTransformOptions: async () => ({
transform: {
experimentalImportSupport: false,
inlineRequires: false,
},
}),
},
resolver: {
assetExts: assetExts.filter(ext => ext !== "svg"),
sourceExts: [...sourceExts, "svg"]
}
};
})();`

I looked through the issues but couldn't find anything that helped, thanks in advance for your advice!
Beau

Problem with one particular SVG file

Thanks for this library! It works great for almost all my SVGs. However, one particular one just crashes Expo. No error message, just crashes simulator or Expo client on actual device. Tried it in iOS and Android with the same result.
SVG works fine in React.

My configs:

package.json

{
  "main": "node_modules/expo/AppEntry.js",
  "scripts": {
    "start": "expo start",
    "android": "expo start --android",
    "ios": "expo start --ios",
    "eject": "expo eject",
    "test": "node ./node_modules/jest/bin/jest.js --watchAll"
  },
  "jest": {
    "preset": "jest-expo"
  },
  "dependencies": {
    "@expo/samples": "2.1.1",
    "axios": "^0.18.0",
    "expo": "^32.0.0",
    "react": "16.5.0",
    "react-native": "https://github.com/expo/react-native/archive/sdk-32.0.0.tar.gz",
    "react-native-elements": "^1.1.0",
    "react-native-svg-transformer": "^0.12.1",
    "react-native-vector-icons": "^6.3.0",
    "react-navigation": "^3.0.9"
  },
  "devDependencies": {
    "babel-eslint": "^10.0.1",
    "babel-preset-expo": "^5.0.0",
    "eslint": "^5.15.0",
    "eslint-config-airbnb": "^17.1.0",
    "eslint-plugin-import": "^2.16.0",
    "eslint-plugin-jsx-a11y": "^6.2.1",
    "eslint-plugin-react": "^7.12.4",
    "jest-expo": "^32.0.0"
  },
  "private": true
}

app.json and metro.config.js are identical to Readme.

problematic SVG:

<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="284" height="73" viewBox="0 0 284 73">
  <defs>
    <pattern id="pattern" preserveAspectRatio="none" width="100%" height="100%" viewBox="0 0 1642 423">
      <image width="1642" height="423" xlink:href=""/>
    </pattern>
  </defs>
  <rect id="starsona_sidelock_empty" width="284" height="73" fill="url(#pattern)"/>
</svg>

Semi dynamic import

Sorry if this is documented somewhere in an Issue but I can't seem to find it.

I'm trying to do something like this and get an Invariant Violation.

const ListItem = ({ icon: Icon }) => (
  <View>
    <Icon />
  <View>
);
<ListItem icon={require('../path/to/yo-that.svg')} />

I'm also open to other ways of doing this as well that allow for a smidge of code reuse.

Some SVGs rendering improperly

Most of my SVGs work fine. However some are not rendering properly. They work fine in React though.

My config:

package.json

{
  "main": "node_modules/expo/AppEntry.js",
  "scripts": {
    "start": "expo start",
    "android": "expo start --android",
    "ios": "expo start --ios",
    "eject": "expo eject",
    "test": "node ./node_modules/jest/bin/jest.js --watchAll"
  },
  "jest": {
    "preset": "jest-expo"
  },
  "dependencies": {
    "@expo/samples": "2.1.1",
    "axios": "^0.18.0",
    "expo": "^32.0.0",
    "react": "16.5.0",
    "react-native": "https://github.com/expo/react-native/archive/sdk-32.0.0.tar.gz",
    "react-native-elements": "^1.1.0",
    "react-native-svg-transformer": "^0.12.1",
    "react-native-vector-icons": "^6.3.0",
    "react-navigation": "^3.0.9"
  },
  "devDependencies": {
    "babel-eslint": "^10.0.1",
    "babel-preset-expo": "^5.0.0",
    "eslint": "^5.15.0",
    "eslint-config-airbnb": "^17.1.0",
    "eslint-plugin-import": "^2.16.0",
    "eslint-plugin-jsx-a11y": "^6.2.1",
    "eslint-plugin-react": "^7.12.4",
    "jest-expo": "^32.0.0"
  },
  "private": true
}

app.json and metro.config.js are identical to Readme.

correct SVG image:

image

my React Native (expo) app shows:

image

SVG file:

<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="333.044" height="236" viewBox="0 0 333.044 236">
  <defs>
    <clipPath id="clip-path">
      <path id="Path_277" data-name="Path 277" d="M14.142-666.312,6.3-660.862l2.76-9.143L1.452-675.78l9.549-.2L14.142-685l3.142,9.019,9.549.2-7.607,5.775,2.76,9.143Z" transform="translate(0 0)" fill="#ee7460" clip-rule="evenodd"/>
    </clipPath>
    <clipPath id="clip-path-2">
      <path id="Path_287" data-name="Path 287" d="M23.8-652.095l-13.81,9.6,4.86-16.1L1.452-668.766l16.813-.353L23.8-685l5.532,15.881,16.813.353L32.747-658.6l4.86,16.1Z" transform="translate(0 0)" fill="#46829a" clip-rule="evenodd"/>
    </clipPath>
    <clipPath id="clip-path-3">
      <path id="Path_279" data-name="Path 279" d="M14.142-666.312,6.3-660.862l2.76-9.143L1.452-675.78l9.549-.2L14.142-685l3.142,9.019,9.549.2-7.607,5.775,2.76,9.143Z" transform="translate(0 0)" fill="#6dafc8" clip-rule="evenodd"/>
    </clipPath>
    <clipPath id="clip-path-4">
      <path id="Path_281" data-name="Path 281" d="M20.385-657.118l-11.7,8.132L12.8-662.628l-11.35-8.616,14.247-.3L20.385-685l4.687,13.457,14.247.3-11.35,8.616,4.118,13.642Z" transform="translate(0 0)" fill="#cee8f0" clip-rule="evenodd"/>
    </clipPath>
    <clipPath id="clip-path-7">
      <path id="Path_289" data-name="Path 289" d="M18.468-659.942,7.951-652.634l3.7-12.26-10.2-7.743,12.8-.269L18.468-685l4.212,12.094,12.8.269-10.2,7.743,3.7,12.26Z" transform="translate(0 0)" fill="#ee7460" clip-rule="evenodd"/>
    </clipPath>
  </defs>
  <g id="Symbol_3_1" data-name="Symbol 3 โ€“ 1" transform="translate(-185.141 -73)">
    <image id="Image_25" data-name="Image 25" width="250" height="236" transform="translate(225 73)" xlink:href=""/>
    <g id="Group_220" data-name="Group 220" transform="matrix(0.829, -0.559, 0.559, 0.829, 603.122, 768.793)" clip-path="url(#clip-path)">
      <path id="Path_276" data-name="Path 276" d="M-3.548-690H22.186v24.492H-3.548Z" transform="translate(4.823 4.823)" fill="#ee7460"/>
    </g>
    <g id="Group_225" data-name="Group 225" transform="matrix(0.829, -0.559, 0.559, 0.829, 566.984, 703.58)" clip-path="url(#clip-path-2)">
      <path id="Path_286" data-name="Path 286" d="M-3.548-690H41.765v43.126H-3.548Z" transform="translate(4.688 4.689)" fill="#46829a"/>
    </g>
    <g id="Group_221" data-name="Group 221" transform="matrix(0.97, -0.242, 0.242, 0.97, 399.623, 907.363)" clip-path="url(#clip-path-3)">
      <path id="Path_278" data-name="Path 278" d="M-3.548-690H22.186v24.492H-3.548Z" transform="translate(4.823 4.823)" fill="#6dafc8"/>
    </g>
    <g id="Group_222" data-name="Group 222" transform="translate(39.268 759.796) rotate(20)" clip-path="url(#clip-path-4)">
      <path id="Path_280" data-name="Path 280" d="M-3.548-690h38.4v36.542h-38.4Z" transform="translate(4.736 4.736)" fill="#cee8f0"/>
    </g>
    <g id="Group_224" data-name="Group 224" transform="translate(177.268 753.796) rotate(20)" clip-path="url(#clip-path-4)">
      <path id="Path_284" data-name="Path 284" d="M-3.548-690h38.4v36.542h-38.4Z" transform="translate(4.736 4.736)" fill="#cee8f0"/>
    </g>
    <g id="Group_223" data-name="Group 223" transform="translate(-193.885 125.763) rotate(99)" clip-path="url(#clip-path-3)">
      <path id="Path_282" data-name="Path 282" d="M-3.548-690H22.186v24.492H-3.548Z" transform="translate(4.823 4.823)" fill="#6dafc8"/>
    </g>
    <g id="Group_226" data-name="Group 226" transform="matrix(-0.515, 0.857, -0.857, -0.515, -68.228, -210.296)" clip-path="url(#clip-path-7)">
      <path id="Path_288" data-name="Path 288" d="M-3.548-690H30.958v32.841H-3.548Z" transform="translate(4.763 4.763)" fill="#ee7460"/>
    </g>
  </g>
</svg>

Does not working with react native 0.60.4 - Invariant Violation

Facing a issue with react-native-svg-transformer with react native latest version 0.60.4

  • react-native-svg is working fine with react-native 0.60.4

This is public git repo I have created for example react-native-svg-transformer with react-native 0.60.4 - https://github.com/dilipchandima/reactNative6SVG

following are my configurations for react native

package.json

{
  "name": "svg",
  "version": "0.0.1",
  "private": true,
  "scripts": {
    "start": "react-native start",
    "test": "jest",
    "lint": "eslint ."
  },
  "dependencies": {
    "react": "16.8.6",
    "react-native": "0.60.4",
    "react-native-svg": "^9.5.3"
  },
  "devDependencies": {
    "@babel/core": "^7.5.5",
    "@babel/runtime": "^7.5.5",
    "@react-native-community/eslint-config": "^0.0.5",
    "babel-jest": "^24.8.0",
    "eslint": "^6.1.0",
    "jest": "^24.8.0",
    "metro-react-native-babel-preset": "^0.55.0",
    "react-native-svg-transformer": "^0.13.0",
    "react-test-renderer": "16.8.6"
  },
  "jest": {
    "preset": "react-native"
  }
}

metro.config

const { getDefaultConfig, mergeConfig } = require("metro-config");

const svgModule = (async () => {
  const {
    resolver: { sourceExts, assetExts }
  } = await getDefaultConfig();
  return {
    transformer: {
      getTransformOptions: async () => ({
        transform: {
          experimentalImportSupport: false,
          inlineRequires: false
        }
      }),
      babelTransformerPath: require.resolve("react-native-svg-transformer")
    },
    resolver: {
      assetExts: assetExts.filter(ext => ext !== "svg"),
      sourceExts: [...sourceExts, "svg"]
    }
  };
})();

const defaultModule = {
  transformer: {
    getTransformOptions: async () => ({
      transform: {
        experimentalImportSupport: false,
        inlineRequires: false,
      },
    }),
  },
};

module.exports = mergeConfig(svgModule, defaultModule);

Screen Shot 2019-08-01 at 11 50 37 AM

Does work with react-native 0.59.4 & react-native-svg 9.4.0

facing issues while integration of latest react-native and svg version.

bundling failed: Error: ENOENT: no such file or directory, scandir

"react-native": "0.59.4",
"react-native-svg": "^9.4.0",
"react-native-svg-transformer": "^0.12.1",

How to dynamically change color of SVG Images instead the app?

According to #4

The previous pull request accepted the solution to change color before transform using the config file instead of changing it dynamically. Is there any other workaround for changing color(fill)?

I don't think adding a file for dev dependencies are as critical as we need to have multiple SVG files in added to the release app because of the color differences? Or are there any other concerns?

svg with animate is not useful

I have a svg file some code like:
<circle transform="translate(8 0)" cx="0" cy="16" r="10" fill="#fff"> <animate attributeName="r" values="0; 4; 0; 0" dur="1.2s" repeatCount="indefinite" begin="0" keytimes="0;0.2;0.7;1" keySplines="0.2 0.2 0.4 0.8;0.2 0.6 0.4 0.8;0.2 0.6 0.4 0.8" calcMode="spline" /> </circle>
but animate is not active

Svg not showing correctly

Hi, I've been using react-native-svg and react-native-svg-transformer to render svg files in my app and it's worked fine.
However, It didn't work for one specific svg file.
The file size is only about 281 kb, while the other worked file size is about 1.61 mb.
The fils is supposed to look like this, which has all the color.
image
However, it looks like this, which only shows black and white.
image

Here's a screenshot of the file that doesn't work.
image
I've noticed some differences between this file and other files that actually work.
However, I'm not sure how to fix it.

Please help, Tks!

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.