mirror of
https://github.com/thelounge/thelounge.git
synced 2026-06-11 15:14:25 -04:00
``` Webpack vs Vite Build Comparison ┌────────────┬──────────────────────┬────────────────────┬───────────────┐ │ Metric │ Webpack 5 │ Vite 8 (Rolldown) │ Change │ ├────────────┼──────────────────────┼────────────────────┼───────────────┤ │ Build time │ 1,961ms (2.96s wall) │ 612ms (0.82s wall) │ 3.2x faster │ ├────────────┼──────────────────────┼────────────────────┼───────────────┤ │ CPU time │ 11.0s user │ 1.3s user │ 8.5x less CPU │ └────────────┴──────────────────────┴────────────────────┴───────────────┘ Bundle sizes (gzipped) ┌────────────────┬─────────┬────────┬────────┐ │ Asset │ Webpack │ Vite │ Change │ ├────────────────┼─────────┼────────┼────────┤ │ App JS │ 152.6K │ 104.9K │ -31% │ ├────────────────┼─────────┼────────┼────────┤ │ Vendor JS │ 251.1K │ 81.6K │ -68% │ ├────────────────┼─────────┼────────┼────────┤ │ Runtime JS │ — │ 0.5K │ new │ ├────────────────┼─────────┼────────┼────────┤ │ Total JS │ 403.7K │ 187.0K │ -54% │ ├────────────────┼─────────┼────────┼────────┤ │ CSS │ 12.5K │ 11.9K │ -5% │ ├────────────────┼─────────┼────────┼────────┤ │ Total transfer │ 416.2K │ 198.9K │ -52% │ └────────────────┴─────────┴────────┴────────┘ Raw (uncompressed) ┌───────────────┬─────────┬──────┬────────┐ │ Asset │ Webpack │ Vite │ Change │ ├───────────────┼─────────┼──────┼────────┤ │ App JS │ 1.3M │ 304K │ -77% │ ├───────────────┼─────────┼──────┼────────┤ │ Vendor JS │ 1.1M │ 236K │ -79% │ ├───────────────┼─────────┼──────┼────────┤ │ CSS │ 64K │ 56K │ -13% │ ├───────────────┼─────────┼──────┼────────┤ │ Total public/ │ 5.1M │ 3.4M │ -33% │ └───────────────┴─────────┴──────┴────────┘ ``` --------- Co-authored-by: Copilot Autofix powered by AI <62310815+github-advanced-security[bot]@users.noreply.github.com>
29 lines
921 B
TypeScript
29 lines
921 B
TypeScript
// @ts-expect-error -- vite uses "exports" which requires moduleResolution: "bundler"
|
|
import {createServer as createViteServer} from "vite";
|
|
import express from "express";
|
|
import fs from "fs";
|
|
|
|
import log from "../log";
|
|
import fromRoot from "../rootpath";
|
|
import {injectServerConfig} from "./html-config";
|
|
|
|
export default async (app: express.Application) => {
|
|
log.debug("Starting server in development mode");
|
|
|
|
const vite = await createViteServer({
|
|
configFile: fromRoot("vite.config.ts"),
|
|
server: {middlewareMode: true},
|
|
appType: "custom",
|
|
});
|
|
|
|
app.use(vite.middlewares);
|
|
|
|
// eslint-disable-next-line @typescript-eslint/no-misused-promises
|
|
app.get("/", async (req, res) => {
|
|
const rawHtml = fs.readFileSync(fromRoot("client", "index.html"), "utf-8");
|
|
const html = await vite.transformIndexHtml(req.url, rawHtml);
|
|
res.setHeader("Content-Type", "text/html");
|
|
res.send(injectServerConfig(html));
|
|
});
|
|
};
|