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
Excluded: .git, node_modules, secrets/, compose.env, assemblyscript tgz Source: /opt/alga-psa on psa.joliet.tech
70 lines
2.1 KiB
TypeScript
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'),
|
|
}
|
|
}
|
|
});
|