-
Notifications
You must be signed in to change notification settings - Fork 116
/
Copy pathindex.js
75 lines (70 loc) · 2.02 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
const { resolveConfig, transform } = require("@svgr/core");
const resolveConfigDir = require("path-dirname");
/**
* `metro-react-native-babel-transformer` has recently been migrated to the React Native
* repository and published under the `@react-native/metro-babel-transformer` name.
* The new package is default on `react-native` >= 0.73.0, so we need to conditionally load it.
*/
const reactNativeTransformer = (() => {
try {
return require("@react-native/metro-babel-transformer");
} catch (error) {
return require("metro-react-native-babel-transformer");
}
})();
const expoTransformer = (() => {
try {
return require("@expo/metro-config/babel-transformer");
} catch (error) {
return null;
}
})();
const defaultSVGRConfig = {
native: true,
plugins: ["@svgr/plugin-svgo", "@svgr/plugin-jsx"],
svgoConfig: {
plugins: [
{
name: "preset-default",
params: {
overrides: {
inlineStyles: {
onlyMatchedOnce: false
},
removeViewBox: false,
removeUnknownsAndDefaults: false,
convertColors: false
}
}
}
]
}
};
function createTransformer(transformer) {
return async ({ src, filename, ...rest }) => {
if (filename.endsWith(".svg")) {
const config = await resolveConfig(resolveConfigDir(filename));
const svgrConfig = config
? { ...defaultSVGRConfig, ...config }
: defaultSVGRConfig;
return transformer.transform({
src: await transform(src, svgrConfig),
filename,
...rest
});
}
return transformer.transform({ src, filename, ...rest });
};
}
module.exports = {
reactNativeTransformer,
expoTransformer,
createTransformer,
transform: createTransformer(
/*
* Expo v50.0.0 has begun using @expo/metro-config/babel-transformer as its upstream transformer.
* To avoid breaking projects, we should prioritze that package if it is available.
**/
expoTransformer || reactNativeTransformer
)
};