sendou.ink/vite.config.ts
2026-03-26 17:23:34 +02:00

76 lines
2.1 KiB
TypeScript

import { tanstackStart } from "@tanstack/react-start/plugin/vite";
import viteReact from "@vitejs/plugin-react";
import { defineConfig, loadEnv } from "vite";
import { configDefaults } from "vitest/config";
export default defineConfig(({ mode }) => {
const env = loadEnv(mode, process.cwd(), "");
return {
server: {
port: Number(env.PORT) || 5173,
},
ssr: {
noExternal: ["react-charts", "react-use"],
},
esbuild: {
supported: {
"top-level-await": true, //browsers can handle top-level-await features
},
},
plugins: [
{
// Wraps CSS modules in @layer components so utility classes always win.
// The layer order declaration is prepended to each module because in Vite
// dev mode, module <style> tags are injected before global stylesheets —
// without it the implicit first @layer components would get lowest priority.
name: "css-modules-layer",
enforce: "pre",
transform(code, id) {
if (!id.endsWith(".module.css")) return;
const layerOrder =
"@layer reset, base, elements, components, utilities;";
const layer = id.includes("/components/elements/")
? "elements"
: "components";
return {
code: `${layerOrder}\n@layer ${layer} {\n${code}\n}`,
};
},
},
tanstackStart(),
// xxx: verify has react compiler
viteReact(),
],
test: {
projects: [
{
extends: true,
test: {
name: "unit",
include: ["**/*.test.{ts,tsx}"],
exclude: [
...configDefaults.exclude,
"e2e/**",
"**/*.browser.test.{ts,tsx}",
],
setupFiles: ["./app/test-setup.ts"],
},
},
{
extends: "./vitest.browser.config.ts",
},
],
},
build: {
// this is mostly done so that i18n jsons as defined in ./app/modules/i18n/loader.ts
// do not end up in the js bundle as minimized strings
// if we decide later that this is a useful optimization in some cases then we can
// switch the value to a callback one that checks the file path
assetsInlineLimit: 0,
},
resolve: {
tsconfigPaths: true,
},
};
});