2024-10-27 00:22:28 +08:00
|
|
|
import { defineConfig, loadEnv } from "vite";
|
2024-07-14 20:28:44 +08:00
|
|
|
import solid from "vite-plugin-solid";
|
|
|
|
import solidStyled from "vite-plugin-solid-styled";
|
|
|
|
import suid from "@suid/vite-plugin";
|
|
|
|
import { VitePWA } from "vite-plugin-pwa";
|
2024-07-22 21:57:04 +08:00
|
|
|
import version from "vite-plugin-package-version";
|
2025-01-04 17:36:01 +08:00
|
|
|
import manifest from "./manifest.config.js";
|
2024-10-22 22:55:53 +08:00
|
|
|
import { GetManualChunk } from "rollup";
|
2024-11-13 19:27:35 +08:00
|
|
|
import devtools from "solid-devtools/vite";
|
2024-11-22 17:16:56 +08:00
|
|
|
import { resolve } from "node:path";
|
2024-10-22 22:55:53 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Put all strings (/i18n/{key}.<json|js|ts>) into separated chunks based on the key.
|
|
|
|
*/
|
|
|
|
const chunkStrs: GetManualChunk = (id, { getModuleInfo }) => {
|
|
|
|
const match = /.*\/i18n\/(.*)\.[jt]s.*$/.exec(id);
|
|
|
|
if (match) {
|
|
|
|
const key = match[1];
|
|
|
|
|
|
|
|
const dependentEntryPoints = [];
|
|
|
|
|
|
|
|
// we use a Set here so we handle each module at most once. This
|
|
|
|
// prevents infinite loops in case of circular dependencies
|
|
|
|
const idsToHandle = new Set(getModuleInfo(id)!.dynamicImporters);
|
|
|
|
|
|
|
|
for (const moduleId of idsToHandle) {
|
|
|
|
const { isEntry, dynamicImporters, importers } = getModuleInfo(moduleId)!;
|
|
|
|
if (isEntry || dynamicImporters.length > 0)
|
|
|
|
dependentEntryPoints.push(moduleId);
|
|
|
|
|
|
|
|
// The Set iterator is intelligent enough to iterate over
|
|
|
|
// elements that are added during iteration
|
|
|
|
for (const importerId of importers) idsToHandle.add(importerId);
|
|
|
|
}
|
|
|
|
|
|
|
|
// If there is a unique entry, we put it into a chunk based on the
|
|
|
|
// entry name
|
|
|
|
if (dependentEntryPoints.length === 1) {
|
|
|
|
return `${key}.${
|
|
|
|
dependentEntryPoints[0].split("/").slice(-1)[0].split(".")[0]
|
|
|
|
}.strings`;
|
|
|
|
}
|
|
|
|
// For multiple entries, we put it into a "shared" chunk
|
|
|
|
if (dependentEntryPoints.length > 1) {
|
|
|
|
return `${key}.shared.strings`;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
const manualChunks: GetManualChunk = (id, meta) => {
|
|
|
|
return chunkStrs(id, meta);
|
|
|
|
};
|
2024-07-14 20:28:44 +08:00
|
|
|
|
2024-10-27 00:22:28 +08:00
|
|
|
export default defineConfig(({ mode }) => {
|
|
|
|
const devConf = loadEnv(mode, import.meta.dirname, "DEV");
|
|
|
|
|
|
|
|
const serverHttpCertBase = devConf["DEV_SERVER_HTTP_CERT_BASE"];
|
|
|
|
const serverHttpCertPassword = devConf["DEV_SERVER_HTTP_CERT_PASS"];
|
|
|
|
|
|
|
|
const serverHttpCertKey = serverHttpCertBase
|
|
|
|
? `${serverHttpCertBase}.key`
|
|
|
|
: undefined;
|
|
|
|
const serverHttpCertCrt = serverHttpCertBase
|
|
|
|
? `${serverHttpCertBase}.crt`
|
|
|
|
: undefined;
|
|
|
|
|
2024-10-28 18:26:14 +08:00
|
|
|
const isTestBuild = ["development", "staging"].includes(mode);
|
|
|
|
|
2024-10-27 00:22:28 +08:00
|
|
|
return {
|
|
|
|
plugins: [
|
2024-11-13 19:27:35 +08:00
|
|
|
devtools({
|
|
|
|
autoname: true,
|
2025-01-04 17:36:56 +08:00
|
|
|
locator: devConf["DEV_LOCATOR_EDITOR"]
|
|
|
|
? {
|
|
|
|
targetIDE: devConf["DEV_LOCATOR_EDITOR"] as
|
|
|
|
| "vscode"
|
|
|
|
| "atom"
|
|
|
|
| "webstorm"
|
|
|
|
| "vscode-insiders",
|
|
|
|
componentLocation: true,
|
|
|
|
jsxLocation: true,
|
|
|
|
}
|
|
|
|
: undefined,
|
2024-11-13 19:27:35 +08:00
|
|
|
}),
|
2024-10-27 00:22:28 +08:00
|
|
|
suid(),
|
|
|
|
solid(),
|
|
|
|
solidStyled({
|
|
|
|
filter: {
|
|
|
|
include: "src/**/*.{tsx,jsx}",
|
|
|
|
exclude: "node_modules/**/*.{ts,js,tsx,jsx}",
|
|
|
|
},
|
|
|
|
}),
|
|
|
|
VitePWA({
|
|
|
|
strategies: "injectManifest",
|
|
|
|
registerType: "autoUpdate",
|
|
|
|
devOptions: {
|
2024-10-27 14:19:56 +08:00
|
|
|
enabled: true,
|
2024-10-27 00:22:28 +08:00
|
|
|
},
|
|
|
|
srcDir: "src/serviceworker",
|
|
|
|
filename: "main.ts",
|
|
|
|
manifest: manifest,
|
|
|
|
pwaAssets: {
|
|
|
|
config: true,
|
|
|
|
},
|
2024-10-27 14:19:56 +08:00
|
|
|
injectManifest: {
|
|
|
|
globPatterns: ["**/*.{js,wasm,css,html,svg,png,ico}"],
|
|
|
|
},
|
2024-10-27 00:22:28 +08:00
|
|
|
}),
|
|
|
|
version(),
|
|
|
|
],
|
2024-11-22 17:16:56 +08:00
|
|
|
resolve: {
|
|
|
|
alias: {
|
|
|
|
/* We don't allow directly acessing the source root,
|
|
|
|
because this encourage cross referencing between different
|
|
|
|
module and loose the isolation. (Cross referencing is still
|
|
|
|
possible, we don't stop it in any technical way.)
|
|
|
|
|
|
|
|
If the module is so important and is being referencing
|
|
|
|
everywhere in the app. Consider promoting it to the top
|
|
|
|
dir.
|
|
|
|
|
|
|
|
see docs/devnotes.md#module-isolation for details.
|
|
|
|
*/
|
|
|
|
"~platform": resolve(__dirname, "src/platform"),
|
|
|
|
"~material": resolve(__dirname, "src/material"),
|
|
|
|
},
|
|
|
|
},
|
2024-10-27 00:22:28 +08:00
|
|
|
server: {
|
2024-10-27 00:28:01 +08:00
|
|
|
https: serverHttpCertBase
|
|
|
|
? {
|
|
|
|
// This config controls https for the *dev server*.
|
|
|
|
// See docs/dev-https.md for setting up https
|
|
|
|
key: serverHttpCertKey,
|
|
|
|
cert: serverHttpCertCrt,
|
|
|
|
passphrase: serverHttpCertPassword,
|
|
|
|
}
|
|
|
|
: undefined,
|
2024-07-23 14:16:35 +08:00
|
|
|
},
|
2024-10-28 18:26:14 +08:00
|
|
|
esbuild: {
|
|
|
|
pure: isTestBuild ? undefined : ["console.debug", "console.trace"],
|
|
|
|
drop: isTestBuild ? undefined : ["debugger"],
|
|
|
|
},
|
2024-10-27 00:22:28 +08:00
|
|
|
define: {
|
|
|
|
"import.meta.env.BUILT_AT": `"${new Date().toISOString()}"`,
|
|
|
|
},
|
|
|
|
css: {
|
|
|
|
devSourcemap: true,
|
|
|
|
},
|
|
|
|
build: {
|
2025-01-04 17:51:19 +08:00
|
|
|
target: ["firefox115", "safari15.6", "ios15.6", "chrome108", "edge108"],
|
2024-10-27 00:22:28 +08:00
|
|
|
sourcemap: true,
|
|
|
|
rollupOptions: {
|
|
|
|
output: {
|
|
|
|
manualChunks,
|
|
|
|
},
|
2024-10-22 22:55:53 +08:00
|
|
|
},
|
|
|
|
},
|
2024-10-27 00:22:28 +08:00
|
|
|
};
|
|
|
|
});
|