forked from mondaycom/vibe
-
Notifications
You must be signed in to change notification settings - Fork 0
/
rollup.config.js
112 lines (103 loc) · 3.6 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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
import * as path from "path";
import nodeResolve from "@rollup/plugin-node-resolve";
import babel from "@rollup/plugin-babel";
import commonjs from "@rollup/plugin-commonjs";
import typescript from "rollup-plugin-typescript2";
import { terser } from "rollup-plugin-terser";
import postcss from "rollup-plugin-postcss";
import postCssImport from "postcss-import";
import autoprefixer from "autoprefixer";
import { sha256 } from "js-sha256";
import * as fs from "fs";
import ejs from "ejs";
const EXTENSIONS = [".js", ".jsx", ".ts", ".tsx"];
const ROOT_PATH = path.join(__dirname);
const SRC_PATH = path.join(ROOT_PATH, "src");
const DIST_PATH = path.join(ROOT_PATH, "dist");
const injectStyle = fs.readFileSync("./rollup/styleInject.ejs", "utf8");
const shouldMockModularClassnames = process.env.mock_classnames === "on";
function replaceDotWithUnderscore(verNum) {
return verNum.replace(/\./g, "_");
}
function getShortSha(content, length = 10) {
return sha256(content).slice(0, length);
}
function loadPackageJson() {
const packageJson = fs.readFileSync("./package.json", "utf8");
return JSON.parse(packageJson);
}
function generateCssModulesScopedName(name, filename, css) {
const start = css.indexOf(`${name} {`);
const end = css.indexOf("}", start);
const content = css.slice(start + name.length + 1, end).replace(/[\r\n]/, "");
const loadPackageJsonResult = loadPackageJson();
return `${name}_${getShortSha(content + replaceDotWithUnderscore(loadPackageJsonResult.version))}`;
}
function generateCssModulesMockName(name) {
return name;
}
export default {
output: {
dir: shouldMockModularClassnames ? path.join(DIST_PATH, "mocked_classnames_esm") : path.join(DIST_PATH, "esm"),
indent: false,
strict: false,
exports: "named",
preserveModules: true,
sourcemap: true
},
input: {
index: path.join(SRC_PATH, "index.js"),
icons: path.join(SRC_PATH, "components/Icon/Icons/index.ts"),
interactionsTests: path.join(SRC_PATH, "tests/interactions-utils.ts"),
testIds: path.join(SRC_PATH, "tests/test-ids-utils.ts"),
next: path.join(SRC_PATH, "next/next.ts")
},
external: [/node_modules\/(?!monday-ui-style)(.*)/],
plugins: [
commonjs(),
nodeResolve({
extensions: [...EXTENSIONS, ".json", ".css"]
}),
typescript({
tsconfig: path.join(ROOT_PATH, "tsconfig.esm.json")
}),
babel({
babelHelpers: "bundled",
extensions: EXTENSIONS
}),
terser({
compress: {
pure_getters: true,
unsafe: true,
unsafe_comps: true
}
}),
postcss({
/**
* Normally, this plugin expects a local version of "node_modules" to be present, but since
* we're externalizing all "node_modules", it doesn't exist.
* This little hack makes sure we're using "node_modules" instead of what the plugin expects.
*/
inject: function (cssVariableName, filename) {
if (!injectStyle) return null;
let shaKey = filename;
try {
const data = fs.readFileSync(filename, "utf8");
shaKey = getShortSha(data, 12);
} catch (err) {
console.error(err);
}
const version = replaceDotWithUnderscore(loadPackageJson().version);
const hashValue = `s_id-${shaKey}`;
return ejs.render(injectStyle, { cssVariableName, hashValue, version });
},
plugins: [autoprefixer(), postCssImport()],
modules: {
generateScopedName: (name, filename, css) =>
shouldMockModularClassnames
? generateCssModulesMockName(name)
: generateCssModulesScopedName(name, filename, css)
}
})
]
};