Files
the-other-dude/frontend/vite.config.ts
Jason Staack 1b1d527226 chore: unify version to 9.7.0 with single source of truth
- Add VERSION file at project root as canonical version source
- Sync all version references: package.json, pyproject.toml, config.py,
  Chart.yaml, docs/CONFIGURATION.md (all were out of sync: 9.0.1, v9.6, 0.1.0)
- Replace hardcoded v9.6 in SettingsPage and About page with dynamic
  APP_VERSION import from @/lib/version.ts
- Add Vite define for __APP_VERSION__ reading from package.json at build time
- Add TypeScript global declaration for __APP_VERSION__

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-03-19 11:25:34 -05:00

75 lines
2.3 KiB
TypeScript

import { defineConfig } from 'vite'
import react from '@vitejs/plugin-react'
import { TanStackRouterVite } from '@tanstack/router-plugin/vite'
import { sri } from 'vite-plugin-sri3'
import path from 'path'
import fs from 'fs'
// Read version from package.json for global define
const pkg = JSON.parse(fs.readFileSync(path.resolve(__dirname, 'package.json'), 'utf-8'))
// https://vite.dev/config/
export default defineConfig({
define: {
__APP_VERSION__: JSON.stringify(pkg.version),
},
plugins: [
TanStackRouterVite({ target: 'react', autoCodeSplitting: true }),
react(),
sri(), // SRI hashes on production builds only (apply: 'build' by default)
],
resolve: {
alias: {
'@': path.resolve(__dirname, './src'),
},
},
build: {
chunkSizeWarningLimit: 1800,
rollupOptions: {
output: {
manualChunks(id) {
// Topology chunk: reactflow + dagre
if (id.includes('reactflow') || id.includes('@dagrejs/dagre')) {
return 'topology'
}
// Config panels chunk: config + config-editor + network components
// These are co-loaded in the device detail route
if (
id.includes('/components/config/') ||
id.includes('/components/config-editor/') ||
id.includes('/components/network/')
) {
return 'config-panels'
}
// Chart libraries
if (id.includes('recharts') || id.includes('d3-')) {
return 'charts'
}
// Animation library
if (id.includes('node_modules/framer-motion')) {
return 'animations'
}
},
},
},
},
server: {
host: '0.0.0.0',
// HTTPS required for Web Crypto API (crypto.subtle) on non-localhost origins.
// Self-signed cert — click through browser warning once.
https: fs.existsSync(path.resolve(__dirname, 'certs/dev-key.pem'))
? {
key: fs.readFileSync(path.resolve(__dirname, 'certs/dev-key.pem')),
cert: fs.readFileSync(path.resolve(__dirname, 'certs/dev-cert.pem')),
}
: undefined,
proxy: {
'/api': {
target: process.env.VITE_API_URL || 'http://localhost:8001',
changeOrigin: true,
secure: false,
},
},
},
})