-
Notifications
You must be signed in to change notification settings - Fork 0
/
rollup.config.mjs
58 lines (51 loc) · 1.32 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
import peerDepsExternal from "rollup-plugin-peer-deps-external";
import resolve from "@rollup/plugin-node-resolve";
import typescript from "rollup-plugin-typescript2";
import postcss from "rollup-plugin-postcss";
import terser from "@rollup/plugin-terser";
// import { Button } from "najwer23storybook/lib/Button";
// https://rollupjs.org/configuration-options/
// https://prateeksurana.me/blog/react-component-library-using-storybook-7/
import * as fs from "fs";
const getFiles = (dir, filesIn, query) => {
const files = filesIn || [];
const fsFiles = fs.readdirSync(dir);
for (var i in fsFiles) {
const name = dir + "/" + fsFiles[i];
if (fs.statSync(name).isDirectory()) {
getFiles(name, files, query);
} else if (name.includes(query)) {
files.push(name);
}
}
return files;
};
const filesIndexTs = getFiles("src/stories/", [], "index.ts").map(
(v) => v.split("//").at(-1).split("/")[0]
);
const Input = Object.fromEntries(
filesIndexTs.map((v) => [
`${v.slice(0, 1).toUpperCase() + v.slice(1)}`,
`src/stories/${v}/index.ts`,
])
);
// console.log(Input);
export default {
input: Input,
output: {
dir: "lib",
format: "esm",
// sourcemap: true,
},
plugins: [
peerDepsExternal(),
resolve(),
typescript(),
postcss({
extensions: [".css"],
minimize: true,
modules: true
}),
terser(),
],
};