forked from marp-team/marp-core
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrollup.config.mjs
116 lines (109 loc) · 3.03 KB
/
rollup.config.mjs
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
106
107
108
109
110
111
112
113
114
115
116
import { createRequire } from 'node:module'
import path from 'node:path'
import url from 'node:url'
import alias from '@rollup/plugin-alias'
import commonjs from '@rollup/plugin-commonjs'
import json from '@rollup/plugin-json'
import { nodeResolve } from '@rollup/plugin-node-resolve'
import replace from '@rollup/plugin-replace'
import terser from '@rollup/plugin-terser'
import typescript from '@rollup/plugin-typescript'
import autoprefixer from 'autoprefixer'
import cssnano from 'cssnano'
import postcssUrl from 'postcss-url'
import postcss from 'rollup-plugin-postcss'
import { string } from 'rollup-plugin-string'
import postcssOptimizeDefaultTheme from './scripts/postcss-optimize-default-theme.mjs'
const require = createRequire(import.meta.url)
const pkg = require('./package.json')
const __dirname = path.dirname(url.fileURLToPath(import.meta.url))
const plugins = ({ browser = false } = {}) => [
json({ preferConst: true }),
alias({
entries: [
{
find: /^.+browser-script$/,
replacement: path.resolve(__dirname, 'lib/browser.js'),
},
{
find: /^.*prebundles[\\/]postcss-minify-plugins$/,
replacement: path.resolve(__dirname, 'tmp/postcss-minify-plugins.mjs'),
},
],
}),
string({ include: ['lib/*.js'] }),
nodeResolve({ browser }),
commonjs(),
typescript(),
postcss({
inject: false,
plugins: [
postcssOptimizeDefaultTheme(),
postcssUrl({
filter: '**/assets/**/*.svg',
encodeType: 'base64',
url: 'inline',
}),
autoprefixer(),
cssnano({
preset: [
'default',
{
// Some minifers will apply on runtime to make debug easily.
minifyParams: false,
minifySelectors: false,
normalizeWhitespace: false,
},
],
}),
],
}),
!process.env.ROLLUP_WATCH && terser(),
]
const prebundlePlugins = () => [
alias({
entries: [
{
find: 'browserslist',
replacement: path.resolve(
__dirname,
'src/prebundles/mocks/browserslist.ts',
),
},
],
}),
...plugins(),
replace({ preventAssignment: true, __dirname: '""' }),
]
const external = (deps) => (id) =>
deps.some((dep) => dep === id || id.startsWith(`${dep}/`))
export default [
// Browser helpers
{
input: 'scripts/browser.js',
output: { file: 'lib/browser.js', format: 'iife' },
plugins: plugins({ browser: true }),
},
{
input: 'src/browser.ts',
output: { exports: 'named', file: 'lib/browser.cjs.js', format: 'cjs' },
plugins: plugins({ browser: true }),
},
// Prebundles
{
input: `src/prebundles/postcss-minify-plugins.ts`,
output: {
exports: 'named',
file: 'tmp/postcss-minify-plugins.mjs',
format: 'es',
},
plugins: prebundlePlugins(),
},
// Main bundle
{
external: external(Object.keys(pkg.dependencies)),
input: `src/${path.basename(pkg.main, '.js')}.ts`,
output: { exports: 'named', file: pkg.main, format: 'cjs' },
plugins: plugins(),
},
]