Hello last 2 day I struggle with this SVG issue.
First problem is I cannot import svg file it says cannot find module then
I fix it about declaring problem.
Then I find a solution by writing svg data in func like that:
const notifactionIcon = (
width = 60,
height = 60
) => `<svg width="${width}" height="${height}" viewBox="0 0 60 60" fill="none" xmlns="http://www.w3.org/2000/svg"
xmlns:xlink="http://www.w3.org/1999/xlink">
<rect width="60" height="60" fill="url(#pattern0)" />
<defs>
<pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image0_18_78" transform="scale(0.01)" />
</pattern>
<image id="image0_18_78" width="100" height="100"
xlink:href="" />
</defs>
</svg>`
export { notifactionIcon }
But I want to import manually.
I search on internet. I cannot find any solution with this problem
Did anyone know why this happening?
other things
babel
module.exports = function (api) {
api.cache(true)
return {
presets: ["babel-preset-expo"],
}
}
tsconfig
{
"extends": "expo/tsconfig.base",
"compilerOptions": {
"strict": true,
}
}
webpack
import createExpoWebpackConfigAsync from "@expo/webpack-config/webpack"
import { Arguments, Environment } from "@expo/webpack-config/webpack/types"
module.exports = async function (env: Environment, argv: Arguments) {
const config = await createExpoWebpackConfigAsync(env, argv)
return config
}
package
{
"name": "cookingapp",
"version": "1.0.0",
"main": "node_modules/expo/AppEntry.js",
"scripts": {
"start": "expo start",
"android": "expo start --android",
"ios": "expo start --ios",
"web": "expo start --web",
"lint": "eslint '**/* .{js,ts,tsx,jsx}'"
},
"dependencies": {
"@expo/webpack-config": "^0.17.2",
"babel-plugin-inline-import": "^3.0.0",
"expo": "^46.0.10",
"expo-cli": "^6.0.5",
"expo-status-bar": "~1.4.0",
"firebase": "9.6.11",
"fs": "^0.0.1-security",
"idb": "^7.0.2",
"node-fs": "^0.1.7",
"react": "18.0.0",
"react-dom": "18.0.0",
"react-native": "^0.70.1",
"react-native-fs": "^2.20.0",
"react-native-paper": "^4.12.4",
"react-native-svg": "^9.13.2",
"react-native-svg-uri": "^1.2.3",
"react-native-vector-icons": "^9.2.0",
"react-native-web": "~0.18.7"
},
"devDependencies": {
"@babel/core": "^7.12.9",
"@react-native-community/eslint-config": "^3.1.0",
"@types/react": "~18.0.0",
"@types/react-dom": "17.0.14",
"@types/react-native": "~0.69.1",
"@typescript-eslint/eslint-plugin": "^5.37.0",
"@typescript-eslint/parser": "^5.37.0",
"eslint": "^8.23.1",
"eslint-config-airbnb": "19.0.4",
"eslint-config-node": "^4.1.0",
"eslint-config-prettier": "^8.5.0",
"eslint-plugin-import": "2.25.3",
"eslint-plugin-jsx-a11y": "6.5.1",
"eslint-plugin-node": "^11.1.0",
"eslint-plugin-prettier": "^4.2.1",
"eslint-plugin-react": "^7.31.8",
"eslint-plugin-react-hooks": "4.3.0",
"eslint-plugin-react-native": "^4.0.0",
"file-loader": "^6.2.0",
"prettier": "^2.7.1",
"ts-node": "^10.9.1",
"typescript": "^4.8.3"
},
"private": true
}
Thanks for answer from now…
2
Answers
Looks like you are using the
SvgXml
component to render the SVG file.Looking at their usage docs, you need to update your babel config file.
module:metro-react-native-babel-preset
preset and thebabel-plugin-inline-import
plugin.you can render your SVGs using XML strings instead of importing it :
1- import :
import { SvgXml } from 'react-native-svg';
2- go inside your SVG file, you’ll notice a bunch of XML code with an
<svg>
tag copy everything inside that<svg>
element from the SVG file’s XML code and store it inside a variable. like this3- Then, pass the icon variable to the xml prop inside your
<SvgXml>
component, like this :