-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathrollup.config.js
More file actions
86 lines (80 loc) · 2.95 KB
/
Copy pathrollup.config.js
File metadata and controls
86 lines (80 loc) · 2.95 KB
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
import { builtinModules } from 'module';
import json from '@rollup/plugin-json';
import ts from '@rollup/plugin-typescript';
import { nodeResolve } from '@rollup/plugin-node-resolve';
import commonjs from '@rollup/plugin-commonjs';
import terser from '@rollup/plugin-terser';
import cleanup from 'rollup-plugin-cleanup';
import summary from 'rollup-plugin-summary';
import { visualizer } from 'rollup-plugin-visualizer';
import { readFileSync } from 'fs';
const pkg = JSON.parse(readFileSync('./package.json', 'utf8'));
const IS_PROD = !process.env.ROLLUP_WATCH;
/**
* @description 获取构建插件
* @param {Record<'json'|'ts'|'nodeResolve'|'commonjs'|'terser'|'cleanup'|'summary'|'visualizer', object>} [options]
* @param {('json'|'ts'|'nodeResolve'|'commonjs'|'terser'|'cleanup'|'summary'|'visualizer')[]} [ignorePlugins]
* @returns
*/
function getPlugins(options = {}, ignorePlugins = []) {
return [
!ignorePlugins.includes('json') && json(options.json || undefined),
!ignorePlugins.includes('ts') && ts(options.ts || undefined),
// todo: 如果部分包导入异常,可启用该项. 如果目标是node环境,需要提供选项{ browser: false, exportConditions: ['node'] }以支持构建
!ignorePlugins.includes('nodeResolve') && nodeResolve(options.nodeResolve || undefined),
!ignorePlugins.includes('commonjs') && commonjs(options.commonjs || undefined),
IS_PROD && !ignorePlugins.includes('terser') && terser(options.terser || undefined),
IS_PROD && !ignorePlugins.includes('cleanup') && cleanup({ comments: 'none', ...(options.cleanup || {}) }),
IS_PROD &&
!ignorePlugins.includes('summary') &&
summary({
showGzippedSize: true,
...(options.summary || {}),
}),
IS_PROD &&
!ignorePlugins.includes('visualizer') &&
visualizer({
gzipSize: true,
// template: 'treemap', // network, treemap,sunburst, default: treemap
...(options.visualizer || {}),
}),
].filter((item) => !!item);
}
/**
* @description 获取要排除的外部选项
* @param {string[]} additionalExternal
* @return {string[]}
*/
function getExternal(additionalExternal = []) {
return [...builtinModules].concat(additionalExternal || []);
}
/**
* @description 获取输出配置项
* @param options 文档: https://www.rollupjs.com/guide/big-list-of-options
* @return {Record<string, unknown>}
*/
function getOutput(options = {}) {
return {
dir: 'dist',
format: 'es',
chunkFileNames: 'bundle/chunk.[format].[hash].js',
entryFileNames: '[name].[format].js',
sourcemap: IS_PROD,
...options,
};
}
export default [
// esm
{
input: 'src/main.ts',
output: getOutput({ entryFileNames: '[name].js' }),
external: getExternal(Object.keys(pkg.dependencies)),
plugins: getPlugins({
nodeResolve: { browser: false, exportConditions: ['node'] },
ts: { tsconfig: './tsconfig.json' },
}),
watch: {
include: ['src/**'],
},
},
].filter((item) => !!item);