|
import { cloudflareDevProxyVitePlugin as remixCloudflareDevProxy, vitePlugin as remixVitePlugin } from '@remix-run/dev'; |
|
import UnoCSS from 'unocss/vite'; |
|
import { defineConfig, type ViteDevServer } from 'vite'; |
|
import { nodePolyfills } from 'vite-plugin-node-polyfills'; |
|
import { optimizeCssModules } from 'vite-plugin-optimize-css-modules'; |
|
import tsconfigPaths from 'vite-tsconfig-paths'; |
|
|
|
import { execSync } from 'child_process'; |
|
import { readFileSync } from 'fs'; |
|
import { join } from 'path'; |
|
|
|
|
|
|
|
|
|
const getGitInfo = () => { |
|
try { |
|
return { |
|
commitHash: execSync('git rev-parse --short HEAD').toString().trim(), |
|
branch: execSync('git rev-parse --abbrev-ref HEAD').toString().trim(), |
|
commitTime: execSync('git log -1 --format=%cd').toString().trim(), |
|
author: execSync('git log -1 --format=%an').toString().trim(), |
|
email: execSync('git log -1 --format=%ae').toString().trim(), |
|
remoteUrl: execSync('git config --get remote.origin.url').toString().trim(), |
|
repoName: execSync('git config --get remote.origin.url') |
|
.toString() |
|
.trim() |
|
.replace(/^.*github.com[:/]/, '') |
|
.replace(/\.git$/, ''), |
|
}; |
|
} catch { |
|
return { |
|
commitHash: 'no-git-info', |
|
branch: 'unknown', |
|
commitTime: 'unknown', |
|
author: 'unknown', |
|
email: 'unknown', |
|
remoteUrl: 'unknown', |
|
repoName: 'unknown', |
|
}; |
|
} |
|
}; |
|
|
|
|
|
const getPackageJson = () => { |
|
try { |
|
const pkgPath = join(process.cwd(), 'package.json'); |
|
const pkg = JSON.parse(readFileSync(pkgPath, 'utf-8')); |
|
|
|
return { |
|
name: pkg.name, |
|
description: pkg.description, |
|
license: pkg.license, |
|
dependencies: pkg.dependencies || {}, |
|
devDependencies: pkg.devDependencies || {}, |
|
peerDependencies: pkg.peerDependencies || {}, |
|
optionalDependencies: pkg.optionalDependencies || {}, |
|
}; |
|
} catch { |
|
return { |
|
name: 'bolt.diy', |
|
description: 'A DIY LLM interface', |
|
license: 'MIT', |
|
dependencies: {}, |
|
devDependencies: {}, |
|
peerDependencies: {}, |
|
optionalDependencies: {}, |
|
}; |
|
} |
|
}; |
|
|
|
const pkg = getPackageJson(); |
|
const gitInfo = getGitInfo(); |
|
|
|
export default defineConfig((config) => { |
|
return { |
|
define: { |
|
__COMMIT_HASH: JSON.stringify(gitInfo.commitHash), |
|
__GIT_BRANCH: JSON.stringify(gitInfo.branch), |
|
__GIT_COMMIT_TIME: JSON.stringify(gitInfo.commitTime), |
|
__GIT_AUTHOR: JSON.stringify(gitInfo.author), |
|
__GIT_EMAIL: JSON.stringify(gitInfo.email), |
|
__GIT_REMOTE_URL: JSON.stringify(gitInfo.remoteUrl), |
|
__GIT_REPO_NAME: JSON.stringify(gitInfo.repoName), |
|
__APP_VERSION: JSON.stringify(process.env.npm_package_version), |
|
__PKG_NAME: JSON.stringify(pkg.name), |
|
__PKG_DESCRIPTION: JSON.stringify(pkg.description), |
|
__PKG_LICENSE: JSON.stringify(pkg.license), |
|
__PKG_DEPENDENCIES: JSON.stringify(pkg.dependencies), |
|
__PKG_DEV_DEPENDENCIES: JSON.stringify(pkg.devDependencies), |
|
__PKG_PEER_DEPENDENCIES: JSON.stringify(pkg.peerDependencies), |
|
__PKG_OPTIONAL_DEPENDENCIES: JSON.stringify(pkg.optionalDependencies), |
|
}, |
|
build: { |
|
target: 'esnext', |
|
}, |
|
plugins: [ |
|
nodePolyfills({ |
|
include: ['path', 'buffer', 'process'], |
|
}), |
|
config.mode !== 'test' && remixCloudflareDevProxy(), |
|
remixVitePlugin({ |
|
future: { |
|
v3_fetcherPersist: true, |
|
v3_relativeSplatPath: true, |
|
v3_throwAbortReason: true, |
|
v3_lazyRouteDiscovery: true, |
|
}, |
|
}), |
|
UnoCSS(), |
|
tsconfigPaths(), |
|
chrome129IssuePlugin(), |
|
config.mode === 'production' && optimizeCssModules({ apply: 'build' }), |
|
], |
|
envPrefix: [ |
|
'VITE_', |
|
'OPENAI_LIKE_API_BASE_URL', |
|
'OLLAMA_API_BASE_URL', |
|
'LMSTUDIO_API_BASE_URL', |
|
'TOGETHER_API_BASE_URL', |
|
], |
|
css: { |
|
preprocessorOptions: { |
|
scss: { |
|
api: 'modern-compiler', |
|
}, |
|
}, |
|
}, |
|
}; |
|
}); |
|
|
|
function chrome129IssuePlugin() { |
|
return { |
|
name: 'chrome129IssuePlugin', |
|
configureServer(server: ViteDevServer) { |
|
server.middlewares.use((req, res, next) => { |
|
const raw = req.headers['user-agent']?.match(/Chrom(e|ium)\/([0-9]+)\./); |
|
|
|
if (raw) { |
|
const version = parseInt(raw[2], 10); |
|
|
|
if (version === 129) { |
|
res.setHeader('content-type', 'text/html'); |
|
res.end( |
|
'<body><h1>Please use Chrome Canary for testing.</h1><p>Chrome 129 has an issue with JavaScript modules & Vite local development, see <a href="https://github.com/stackblitz/bolt.new/issues/86#issuecomment-2395519258">for more information.</a></p><p><b>Note:</b> This only impacts <u>local development</u>. `pnpm run build` and `pnpm run start` will work fine in this browser.</p></body>', |
|
); |
|
|
|
return; |
|
} |
|
} |
|
|
|
next(); |
|
}); |
|
}, |
|
}; |
|
} |
|
|