forked from hashicorp/next-mdx-remote
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrollup.config.js
105 lines (99 loc) · 2.8 KB
/
rollup.config.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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
import resolve from '@rollup/plugin-node-resolve'
import cjs from '@rollup/plugin-commonjs'
import json from '@rollup/plugin-json'
import ts from '@rollup/plugin-typescript'
import alias from '@rollup/plugin-alias'
// These extensions are not being used
const extensions = ['.js', '.jsx', '.ts', '.tsx']
function getEsbuildModulePath() {
/**
* The idea here is grasp Node require.resolve (which finds the dependency no matter
* where in the root the dependency is) to find `esbuild`.
*
* Although require.resolve returns the file specified in the `main` package.json, e.g.:
* /home/raulmelo/development/raulmelo-studio/node_modules/esbuild/lib/main.js
*/
const fullPath = require.resolve('esbuild')
/**
* Since we just want the relative (til esbuild), we could simple filter everything
* AFTER the word "esbuild"
*/
const regexEverythingAfterWord = /(?<=esbuild).*$/gm
/**
* and strip it out.
*
* Final result will be:
* /home/raulmelo/development/raulmelo-studio/node_modules/esbuild
*/
return fullPath.replace(regexEverythingAfterWord, '')
}
/**
* This plugin injects a process env in build time.
*
* We could move the logic to determine the `ESBUILD_BINARY_PATH` at this point
* but it's totally up to you decide the best strategy.
*/
const injectPluginConfigured = injectProcessEnv({
ESBUILD_PATH: getEsbuildModulePath(),
})
/**
* And finally this approach solves duplicated react version.
* Here we use `alias` strategy combined with node require.resolve
* to the users versions of `react` and `react-dom`.
*/
const aliasPluginConfigured = alias({
entires: {
react: require.resolve('react'),
'react-dom': require.resolve('react-dom'),
},
})
export default [
{
input: './src/index.tsx',
output: {
dir: './dist',
format: 'cjs',
},
external: ['react', '@mdx-js/react'],
plugins: [
injectPluginConfigured,
aliasPluginConfigured,
ts({
tsconfig: './tsconfig.json',
declaration: true,
declarationDir: './dist',
}),
resolve(),
{
// ensure that the requestIdleCallback polyfill file is marked as having
// side-effects so that it gets bundled
name: 'ensure-idle-callback-polyfill',
transform(code, id) {
if (id.includes('idle-callback-polyfill.js')) {
return { code, moduleSideEffects: true }
}
},
},
],
},
{
input: './src/serialize.ts',
output: {
dir: './dist',
format: 'cjs',
},
external: ['@mdx-js/mdx', 'esbuild', 'pkg-dir'],
plugins: [
injectPluginConfigured,
aliasPluginConfigured,
ts({
tsconfig: './tsconfig.json',
declaration: true,
declarationDir: './dist',
}),
json(),
resolve(),
cjs(),
],
},
]