Skip to content

Commit 26edde1

Browse files
committed
fix: externalize Emotion
1 parent 6fb4597 commit 26edde1

File tree

2 files changed

+13
-14
lines changed

2 files changed

+13
-14
lines changed

package.json

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -54,6 +54,7 @@
5454
"coverage": "vitest --coverage",
5555
"upgrade-interactive": "npm-check -u"
5656
},
57+
"dependencies": {},
5758
"peerDependencies": {
5859
"@emotion/react": "^11.9.0",
5960
"react": "^17.0.0 || ^18.0.0",

vite.config.ts

Lines changed: 12 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -3,6 +3,14 @@ import react from '@vitejs/plugin-react';
33
import dts from 'vite-plugin-dts';
44
import packageJson from './package.json';
55

6+
const makeExternalPredicate = (externals: string[]) => {
7+
if (externals.length === 0) {
8+
return () => false;
9+
}
10+
const pattern = new RegExp(`^(${externals.join('|')})($|/)`);
11+
return (id: string) => pattern.test(id);
12+
};
13+
614
// https://vitejs.dev/config/
715
export default defineConfig({
816
build: {
@@ -12,20 +20,10 @@ export default defineConfig({
1220
fileName: (format) => `react-section-dividers.${format}.js`,
1321
},
1422
rollupOptions: {
15-
external: [
16-
'react',
17-
'react-dom',
18-
'@emotion/cache',
19-
'@emotion/hash',
20-
'@emotion/is-prop-valid',
21-
'@emotion/memoize',
22-
'@emotion/react',
23-
'@emotion/serialize',
24-
'@emotion/styled',
25-
'@emotion/styled/base',
26-
'@emotion/unitless',
27-
'@emotion/utils',
28-
],
23+
external: makeExternalPredicate([
24+
...Object.keys(packageJson.dependencies),
25+
...Object.keys(packageJson.peerDependencies)
26+
]),
2927
output: {
3028
globals: {
3129
react: 'React',

0 commit comments

Comments
 (0)