mirror of
https://github.com/actualbudget/actual.git
synced 2026-03-21 15:36:50 -05:00
200 lines
5.2 KiB
TypeScript
200 lines
5.2 KiB
TypeScript
// @ts-strict-ignore
|
|
import * as path from 'path';
|
|
|
|
import inject from '@rollup/plugin-inject';
|
|
import basicSsl from '@vitejs/plugin-basic-ssl';
|
|
import react from '@vitejs/plugin-react-swc';
|
|
import { visualizer } from 'rollup-plugin-visualizer';
|
|
/// <reference types="vitest" />
|
|
import { defineConfig, loadEnv, Plugin } from 'vite';
|
|
import { VitePWA } from 'vite-plugin-pwa';
|
|
import viteTsconfigPaths from 'vite-tsconfig-paths';
|
|
|
|
const addWatchers = (): Plugin => ({
|
|
name: 'add-watchers',
|
|
configureServer(server) {
|
|
server.watcher
|
|
.add([
|
|
path.resolve('../loot-core/lib-dist/electron/*.js'),
|
|
path.resolve('../loot-core/lib-dist/browser/*.js'),
|
|
])
|
|
.on('all', function () {
|
|
for (const wsc of server.ws.clients) {
|
|
wsc.send(JSON.stringify({ type: 'static-changed' }));
|
|
}
|
|
});
|
|
},
|
|
});
|
|
|
|
// Inject build shims using the inject plugin
|
|
const injectShims = (): Plugin[] => {
|
|
const buildShims = path.resolve('./src/build-shims.js');
|
|
const commonInject = {
|
|
exclude: ['src/setupTests.js'],
|
|
global: [buildShims, 'global'],
|
|
};
|
|
|
|
return [
|
|
{
|
|
name: 'inject-build-process',
|
|
config: () => ({
|
|
// rename process.env in build mode so it doesn't get set to an empty object up by the vite:define plugin
|
|
// this isn't needed in serve mode, because vite:define doesn't empty it in serve mode. And defines also happen last anyways in serve mode.
|
|
define: {
|
|
'process.env': `_process.env`,
|
|
},
|
|
}),
|
|
apply: 'build',
|
|
},
|
|
{
|
|
...inject({
|
|
...commonInject,
|
|
process: [buildShims, 'process'],
|
|
}),
|
|
enforce: 'post',
|
|
apply: 'serve',
|
|
},
|
|
{
|
|
...inject({
|
|
...commonInject,
|
|
_process: [buildShims, 'process'],
|
|
}),
|
|
enforce: 'post',
|
|
apply: 'build',
|
|
},
|
|
];
|
|
};
|
|
|
|
// https://vitejs.dev/config/
|
|
|
|
export default defineConfig(async ({ mode }) => {
|
|
const env = loadEnv(mode, process.cwd(), '');
|
|
const devHeaders = {
|
|
'Cross-Origin-Opener-Policy': 'same-origin',
|
|
'Cross-Origin-Embedder-Policy': 'require-corp',
|
|
};
|
|
|
|
// Forward Netlify env variables
|
|
if (process.env.REVIEW_ID) {
|
|
process.env.REACT_APP_REVIEW_ID = process.env.REVIEW_ID;
|
|
}
|
|
|
|
let resolveExtensions = [
|
|
'.web.js',
|
|
'.web.jsx',
|
|
'.web.ts',
|
|
'.web.tsx',
|
|
'.mjs',
|
|
'.js',
|
|
'.mts',
|
|
'.ts',
|
|
'.jsx',
|
|
'.tsx',
|
|
'.json',
|
|
];
|
|
|
|
if (env.IS_GENERIC_BROWSER) {
|
|
resolveExtensions = [
|
|
'.browser.js',
|
|
'.browser.jsx',
|
|
'.browser.ts',
|
|
'.browser.tsx',
|
|
...resolveExtensions,
|
|
];
|
|
}
|
|
|
|
const browserOpen = env.BROWSER_OPEN ? `//${env.BROWSER_OPEN}` : true;
|
|
|
|
return {
|
|
base: '/',
|
|
envPrefix: 'REACT_APP_',
|
|
build: {
|
|
terserOptions: {
|
|
compress: false,
|
|
mangle: false,
|
|
},
|
|
target: 'es2022',
|
|
sourcemap: true,
|
|
outDir: mode === 'desktop' ? 'build-electron' : 'build',
|
|
assetsDir: 'static',
|
|
manifest: true,
|
|
assetsInlineLimit: 0,
|
|
chunkSizeWarningLimit: 1500,
|
|
rollupOptions: {
|
|
output: {
|
|
assetFileNames: assetInfo => {
|
|
const info = assetInfo.name.split('.');
|
|
let extType = info[info.length - 1];
|
|
if (/png|jpe?g|svg|gif|tiff|bmp|ico/i.test(extType)) {
|
|
extType = 'img';
|
|
} else if (/woff|woff2/.test(extType)) {
|
|
extType = 'media';
|
|
}
|
|
return `static/${extType}/[name].[hash][extname]`;
|
|
},
|
|
chunkFileNames: 'static/js/[name].[hash].chunk.js',
|
|
entryFileNames: 'static/js/[name].[hash].js',
|
|
},
|
|
},
|
|
},
|
|
server: {
|
|
host: true,
|
|
headers: mode === 'development' ? devHeaders : undefined,
|
|
port: +env.PORT || 5173,
|
|
open: env.BROWSER
|
|
? ['chrome', 'firefox', 'edge', 'browser', 'browserPrivate'].includes(
|
|
env.BROWSER,
|
|
)
|
|
: browserOpen,
|
|
watch: {
|
|
disableGlobbing: false,
|
|
},
|
|
},
|
|
resolve: {
|
|
extensions: resolveExtensions,
|
|
},
|
|
plugins: [
|
|
// electron (desktop) builds do not support PWA
|
|
mode === 'desktop'
|
|
? undefined
|
|
: VitePWA({
|
|
registerType: 'prompt',
|
|
workbox: {
|
|
globPatterns: [
|
|
'**/*.{js,css,html,txt,wasm,sql,sqlite,ico,png,woff2,webmanifest}',
|
|
],
|
|
ignoreURLParametersMatching: [/^v$/],
|
|
navigateFallback: '/index.html',
|
|
maximumFileSizeToCacheInBytes: 5 * 1024 * 1024, // 5MB
|
|
navigateFallbackDenylist: [
|
|
/^\/account\/.*$/,
|
|
/^\/admin\/.*$/,
|
|
/^\/secret\/.*$/,
|
|
/^\/openid\/.*$/,
|
|
],
|
|
},
|
|
}),
|
|
injectShims(),
|
|
addWatchers(),
|
|
react({
|
|
plugins: [
|
|
[
|
|
'@swc/plugin-react-remove-properties',
|
|
{ properties: ['^data-debug'] },
|
|
],
|
|
],
|
|
devTarget: 'es2022',
|
|
}),
|
|
viteTsconfigPaths({ root: '../..' }),
|
|
visualizer({ template: 'raw-data' }),
|
|
!!env.HTTPS && basicSsl(),
|
|
],
|
|
test: {
|
|
include: ['src/**/*.{test,spec}.?(c|m)[jt]s?(x)'],
|
|
environment: 'jsdom',
|
|
globals: true,
|
|
setupFiles: './src/setupTests.js',
|
|
},
|
|
};
|
|
});
|