forked from atomiks/tippyjs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrollup.pre-build.js
114 lines (100 loc) · 2.9 KB
/
rollup.pre-build.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
106
107
108
109
110
111
112
113
114
/* eslint-disable @typescript-eslint/no-var-requires */
const fs = require('fs');
const {rollup} = require('rollup');
const babel = require('rollup-plugin-babel');
const sass = require('rollup-plugin-sass');
const postcss = require('postcss');
const autoprefixer = require('autoprefixer');
const cssnano = require('cssnano');
const resolve = require('rollup-plugin-node-resolve');
const json = require('rollup-plugin-json');
const cssOnly = require('rollup-plugin-css-only');
const replace = require('rollup-plugin-replace');
const NAMESPACE_PREFIX = process.env.NAMESPACE || 'tippy';
const THEME = process.env.THEME;
const BASE_OUTPUT_CONFIG = {
name: 'tippy',
globals: {'popper.js': 'Popper'},
sourcemap: true,
};
const PLUGINS = {
babel: babel({
exclude: 'node_modules/**',
extensions: ['.js', '.ts'],
}),
replaceNamespace: replace({
__NAMESPACE_PREFIX__: NAMESPACE_PREFIX,
}),
resolve: resolve({extensions: ['.js', '.ts']}),
css: cssOnly({output: false}),
json: json(),
};
const PLUGIN_CONFIG = [
PLUGINS.babel,
PLUGINS.replaceNamespace,
PLUGINS.resolve,
PLUGINS.json,
PLUGINS.css,
];
function createPluginSCSS(output, shouldInjectNodeEnvTheme = false) {
let data = `$namespace-prefix: ${NAMESPACE_PREFIX};`;
if (shouldInjectNodeEnvTheme && THEME) {
data += `@import './themes/${THEME}.scss';`;
}
return sass({
output,
options: {data},
processor(css) {
return postcss([autoprefixer, cssnano])
.process(css, {from: undefined})
.then(result => result.css);
},
});
}
function createRollupConfig(inputFile, plugins) {
return {
input: `./build/${inputFile}`,
external: ['popper.js'],
plugins,
};
}
async function build() {
// Create `index.d.ts` file from `src/types.ts`
fs.copyFileSync('./src/types.ts', './index.d.ts');
// Create base CSS files
for (const filename of fs.readdirSync(`./build/css`)) {
const cssConfig = createRollupConfig(
`css/${filename}`,
PLUGIN_CONFIG.concat(
createPluginSCSS(`./dist/${filename.replace('.js', '.css')}`, true),
),
);
const cssBundle = await rollup(cssConfig);
await cssBundle.write({
...BASE_OUTPUT_CONFIG,
sourcemap: false,
format: 'umd',
file: './index.js',
});
}
// Themes + animations
for (const folder of ['themes', 'animations']) {
for (const filename of fs.readdirSync(`./build/${folder}`)) {
const filenameWithCSSExtension = filename.replace('.js', '.css');
const outputFile = `./${folder}/${filenameWithCSSExtension}`;
const config = createRollupConfig(
`${folder}/${filename}`,
PLUGIN_CONFIG.concat(createPluginSCSS(outputFile)),
);
const bundle = await rollup(config);
await bundle.write({
...BASE_OUTPUT_CONFIG,
format: 'umd',
sourcemap: false,
file: 'index.js',
});
}
}
fs.unlinkSync('./index.js');
}
build();