-
-
Notifications
You must be signed in to change notification settings - Fork 229
/
Copy pathvite.config-common.mts
92 lines (90 loc) · 3.93 KB
/
vite.config-common.mts
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
import { defineConfig } from "vite"
import pluginReact from "@vitejs/plugin-react"
import pluginChecker from "vite-plugin-checker"
import { sentryVitePlugin } from "@sentry/vite-plugin"
import * as clientSettings from "./settings/clientSettings.js"
import {
VITE_ASSET_SITE_ENTRY,
VITE_ENTRYPOINT_INFO,
ViteEntryPoint,
} from "./site/viteUtils.js"
// https://vitejs.dev/config/
export const defineViteConfigForEntrypoint = (entrypoint: ViteEntryPoint) => {
const entrypointInfo = VITE_ENTRYPOINT_INFO[entrypoint]
return defineConfig({
publicDir: false, // don't copy public folder to dist
resolve: {
// prettier-ignore
alias: {
"@ourworldindata/grapher/src": "@ourworldindata/grapher/src", // need this for imports of @ourworldindata/grapher/src/core/grapher.scss to work
// we alias to the packages source files in dev and prod:
// this means we get instant dev updates when we change one of them,
// and the prod build builds them all as esm modules, which helps with tree shaking
// Idea from https://github.com/LinusBorg/vue-lib-template/blob/3775e49b20a7c3349dd49321cad2ed7f9d575057/packages/playground/vite.config.ts
"@ourworldindata/components": "@ourworldindata/components/src/index.ts",
"@ourworldindata/core-table": "@ourworldindata/core-table/src/index.ts",
"@ourworldindata/explorer": "@ourworldindata/explorer/src/index.ts",
"@ourworldindata/grapher": "@ourworldindata/grapher/src/index.ts",
"@ourworldindata/types": "@ourworldindata/types/src/index.ts",
"@ourworldindata/utils": "@ourworldindata/utils/src/index.ts",
},
},
css: {
devSourcemap: true,
},
define: {
// Replace all clientSettings with their respective values, i.e. assign e.g. EXAMPLE_ENV_VAR to process.env.EXAMPLE_ENV_VAR
// it's important to note that we only expose values that are present in the clientSettings file - not any other things that are stored in .env
...Object.fromEntries(
Object.entries(clientSettings).map(([key, value]) => [
`process.env.${key}`,
JSON.stringify(value),
])
),
},
build: {
manifest: true, // creates a manifest.json file, which we use to determine which files to load in prod
emptyOutDir: true,
outDir: `dist/${entrypointInfo.outDir}`,
sourcemap: true,
target: ["chrome80", "firefox78", "safari13.1"], // see docs/browser-support.md
rollupOptions: {
input: {
[entrypointInfo.outName]: entrypointInfo.entryPointFile,
},
output: {
assetFileNames: `${entrypointInfo.outName}.css`,
entryFileNames: `${entrypointInfo.outName}.mjs`,
},
},
},
plugins: [
pluginReact({
babel: {
parserOpts: {
plugins: ["decorators-legacy"], // needed so mobx decorators work correctly
},
},
}),
pluginChecker({
typescript: {
buildMode: true,
tsconfigPath: "tsconfig.vite-checker.json",
},
}),
// Put the Sentry vite plugin after all other plugins.
sentryVitePlugin({
authToken: process.env.SENTRY_AUTH_TOKEN,
org: process.env.SENTRY_ORG,
project: entrypoint === "admin" ? "admin" : "website",
}),
],
server: {
port: 8090,
warmup: { clientFiles: [VITE_ASSET_SITE_ENTRY] },
},
preview: {
port: 8090,
},
})
}