-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathvite.config.ts
More file actions
76 lines (69 loc) · 1.81 KB
/
vite.config.ts
File metadata and controls
76 lines (69 loc) · 1.81 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
import { defineConfig } from "vite";
import react from "@vitejs/plugin-react";
import dts from "vite-plugin-dts";
import { patchCssModules } from "vite-css-modules";
import { basename, dirname, resolve } from "node:path";
import { fileURLToPath } from "node:url";
import pkg from "./package.json";
import crypto from "node:crypto";
const __dirname = dirname(fileURLToPath(import.meta.url));
const peerDependencies = Object.keys(pkg.peerDependencies || {});
const isBuildApp = process.env.BUILD_TARGET === "app";
function generateScopedName(
command: string,
className: string,
file: string,
): string {
const fileName = basename(file.split("?", 2)[0], ".module.css")
.replace(/([a-z])([A-Z])/g, "$1_$2")
.toLowerCase();
if (command === "build") {
const hash = crypto
.createHash("sha1")
.update(`${fileName}_${className}`)
.digest("hex")
.substring(0, 6);
return `fpe_${hash}`;
} else {
return `${fileName}_${className}`;
}
}
export default defineConfig(({ command }) => {
const baseConfig = {
plugins: [
react(),
patchCssModules({
generateSourceTypes: true,
}),
dts({
rollupTypes: true,
tsconfigPath: resolve(__dirname, "tsconfig.lib.json"),
}),
],
css: {
modules: {
generateScopedName: generateScopedName.bind(null, command),
},
},
};
if (!isBuildApp) {
return {
...baseConfig,
build: {
lib: {
entry: resolve(__dirname, "lib/index.ts"),
fileName: "index",
formats: ["es"],
},
rollupOptions: {
external: [
...peerDependencies,
...peerDependencies.map((dep) => new RegExp(`^${dep}/`)),
],
},
copyPublicDir: false,
},
};
}
return baseConfig;
});