Hermes 284313f908
Some checks are pending
Bidi Control Character Guard / bidi-control-guard (push) Waiting to run
Circular Dependency Check / Check for new circular dependencies (push) Waiting to run
Citus Migration Smoke / Combined migrations on single-node Citus (push) Waiting to run
E2E Fresh Install Tests / fresh-install-e2e (push) Waiting to run
ext-v2 guardrails / Run ext-v2 guard and ESLint (push) Waiting to run
Integration Tests / Check for relevant changes (push) Waiting to run
Integration Tests / ${{ (github.event_name == 'schedule' || github.event.inputs.suite == 'full') && 'Full integration suite' || 'Tier-1 integration subset' }} (push) Blocked by required conditions
Mobile checks / Mobile lint + typecheck (push) Waiting to run
Mobile checks / Mobile unit tests (push) Waiting to run
Mobile checks / Mobile dependency audit (report) (push) Waiting to run
Mobile checks / Mobile reproducibility checks (push) Waiting to run
Secrets guard (env backups) / Ensure no tracked env backup files (push) Waiting to run
Temporal Readiness / fast-readiness (push) Waiting to run
Temporal Readiness / docker-parity (push) Waiting to run
TypeScript Type Check / Nx affected typecheck (push) Waiting to run
Unit Tests / Skipped-test budget (push) Waiting to run
Unit Tests / Nx affected unit tests (push) Waiting to run
Unit Tests / Server unit coverage (informational) (push) Waiting to run
Validate Tenant Management Schema / Check for relevant changes (push) Waiting to run
Validate Tenant Management Schema / Validate Tenant Management Schema (push) Blocked by required conditions
EE Workflows Build Guard / ee-workflows-build-guard (push) Waiting to run
Initial import of AlgaPSA codebase from PSA server
Excluded: .git, node_modules, secrets/, compose.env, assemblyscript tgz

Source: /opt/alga-psa on psa.joliet.tech
2026-06-22 16:12:17 -05:00

70 lines
2.1 KiB
TypeScript

import { defineConfig } from 'vite';
import path from 'path';
import { glob } from 'glob';
// Find component, page, and iframe files to be used as entry points
const entries = glob.sync('src/{components,pages,iframe}/**/*.{ts,tsx}').reduce((acc, file) => {
const name = file.replace('src/', '').replace(/\.tsx?$/, '');
acc[name] = path.resolve(__dirname, file);
return acc;
}, {});
export default defineConfig({
plugins: [],
esbuild: {
jsx: 'transform',
},
build: {
lib: {
entry: entries,
formats: ['es'],
fileName: (format, entryName) => `${entryName}.js`,
},
rollupOptions: {
onwarn(warning, defaultHandler) {
// Silence Radix "use client" module-level directive warnings
if (
warning.code === 'MODULE_LEVEL_DIRECTIVE' &&
/node_modules\/@radix-ui\//.test(String((warning as any).id || '')) &&
String(warning.message || '').includes('"use client"')
) {
return;
}
defaultHandler(warning);
},
// Leave common libs to the host app to avoid duplicate React instances
external: [
'react',
'react-dom',
'react/jsx-runtime',
'react/jsx-dev-runtime',
'react-router-dom',
'formik',
'yup',
'@tanstack/react-query',
],
output: {
format: 'es',
// Force .js extensions for entries and chunks (avoid .mjs)
entryFileNames: (chunkInfo) => `${chunkInfo.name}.js`,
chunkFileNames: (chunkInfo) => `${chunkInfo.name}.js`,
assetFileNames: (assetInfo) => `${assetInfo.name ?? '[name]'}[extname]`,
// Don't inline dynamic imports with multiple entries
inlineDynamicImports: false,
},
},
outDir: 'dist',
sourcemap: true,
emptyOutDir: true,
},
resolve: {
alias: {
// Ensure we use the same React instance
'react': path.resolve('./node_modules/react'),
'react-dom': path.resolve('./node_modules/react-dom'),
// Resolve local UI kit source without publishing/installing
'@alga/ui-kit': path.resolve(__dirname, '..', '..', 'server', 'packages', 'ui-kit', 'src'),
}
}
});