cobalt/web/vite.config.ts
jj 2273bb388f
Some checks failed
CodeQL / Analyze (${{ matrix.language }}) (none, javascript-typescript) (push) Has been cancelled
Run tests / check lockfile correctness (push) Has been cancelled
Run tests / web sanity check (push) Has been cancelled
Run tests / api sanity check (push) Has been cancelled
web/vite: split transformers.js into separate chunk
2025-01-16 20:42:58 +00:00

120 lines
3.6 KiB
TypeScript

import { defineConfig, searchForWorkspaceRoot, type PluginOption } from "vite";
import { sveltekit } from "@sveltejs/kit/vite";
import basicSSL from "@vitejs/plugin-basic-ssl";
import { glob } from "glob";
import mime from "mime";
import { createSitemap } from 'svelte-sitemap/src/index'
import { cp, readdir, mkdir } from "node:fs/promises";
import { createReadStream } from "node:fs";
import { join, basename } from "node:path";
const exposeLibAV: PluginOption = (() => {
const IMPUT_MODULE_DIR = join(__dirname, 'node_modules/@imput');
return {
name: "vite-libav.js",
configureServer(server) {
server.middlewares.use(async (req, res, next) => {
if (!req.url?.startsWith('/_libav/')) return next();
const filename = basename(req.url).split('?')[0];
if (!filename) return next();
const [ file ] = await glob(join(IMPUT_MODULE_DIR, '/**/dist/', filename));
if (!file) return next();
const fileType = mime.getType(filename);
if (!fileType) return next();
res.setHeader('Content-Type', fileType);
return createReadStream(file).pipe(res);
});
},
generateBundle: async (options) => {
if (!options.dir) {
return;
}
const assets = join(options.dir, '_libav');
await mkdir(assets, { recursive: true });
const modules = await readdir(IMPUT_MODULE_DIR).then(
modules => modules.filter(m => m.startsWith('libav.js'))
);
for (const module of modules) {
const distFolder = join(IMPUT_MODULE_DIR, module, 'dist/');
await cp(distFolder, assets, { recursive: true });
}
}
}
})();
const enableCOEP: PluginOption = {
name: "isolation",
configureServer(server) {
server.middlewares.use((_req, res, next) => {
res.setHeader("Cross-Origin-Opener-Policy", "same-origin");
res.setHeader("Cross-Origin-Embedder-Policy", "require-corp");
next();
})
}
};
const generateSitemap: PluginOption = {
name: "generate-sitemap",
async writeBundle(bundle) {
if (!process.env.WEB_HOST || !bundle.dir?.endsWith('server')) {
return;
}
await createSitemap(`https://${process.env.WEB_HOST}`, {
changeFreq: 'monthly',
outDir: '.svelte-kit/output/prerendered/pages',
resetTime: true
});
}
}
export default defineConfig({
plugins: [
basicSSL(),
sveltekit(),
enableCOEP,
exposeLibAV,
generateSitemap
],
build: {
rollupOptions: {
output: {
manualChunks: (id) => {
if (id.includes('huggingface/transformers'))
return 'hf_transformers';
if (id.includes('/web/i18n') && id.endsWith('.json')) {
const lang = id.split('/web/i18n/')?.[1].split('/')?.[0];
if (lang) {
return `i18n_${lang}`;
}
}
}
}
}
},
server: {
headers: {
"Cross-Origin-Opener-Policy": "same-origin",
"Cross-Origin-Embedder-Policy": "require-corp"
},
fs: {
allow: [
searchForWorkspaceRoot(process.cwd())
]
},
proxy: {}
},
optimizeDeps: {
exclude: [ "@imput/libav.js-remux-cli" ]
},
});