This repository has been archived by the owner on Aug 30, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 7
/
rollup.config.js
91 lines (85 loc) · 2.14 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
import svelte from "rollup-plugin-svelte";
import commonjs from "@rollup/plugin-commonjs";
import resolve from "@rollup/plugin-node-resolve";
import { terser } from "rollup-plugin-terser";
import sveltePreprocess from "svelte-preprocess";
import typescript from "@rollup/plugin-typescript";
import fs from "fs";
import path from "path";
import replace from "@rollup/plugin-replace";
const production = !process.env.ROLLUP_WATCH;
const network = process.env.NETWORK || "dev";
const targetWeblets = process.env.TARGET_WEBLETS;
/**
*
* @param { {
* src: string,
* outdir: string,
* element?: boolean,
* keepCss?: boolean
* } } options
*/
function build(options) {
options = {
element: false,
keepCss: false,
...options,
};
const configs = {
input: options.src, // 'src/main.ts',
output: {
sourcemap: false,
format: "iife",
name: "app",
file: options.outdir, // 'public/build/bundle.js'
},
plugins: [
svelte({
preprocess: sveltePreprocess({ sourceMap: !production }),
compilerOptions: {
dev: !production,
customElement: true,
},
}),
resolve({
browser: true,
dedupe: ["svelte"],
}),
commonjs(),
typescript({
sourceMap: !production,
inlineSources: !production,
}),
production && terser(),
replace({
preventAssignment: true,
values: {
"process.env.NETWORK": `"${network}"`,
"process.env.VERSION": `"${process.env.VERSION || "No version to show"}"`,
},
}),
],
watch: {
clearScreen: false,
},
};
return configs;
}
function buildElements() {
const dir = path.join(__dirname, "src", "elements");
const outDir = `.build/build/elements/`;
let files = fs.readdirSync(dir);
if (targetWeblets) {
files = targetWeblets.split(" ");
}
return files.map(f => {
const name = f.replace(".wc.svelte", "").toLocaleLowerCase();
return build({
src: `src/elements/${f}/index.ts`,
outdir: outDir + `${name}.wc.js`,
element: true,
keepCss: true,
});
});
}
export default buildElements();