import { build, InlineConfig } from 'vite'; import { resolve } from 'path'; import { fileURLToPath } from 'url'; import jisonPlugin from './jisonPlugin.js'; import { readFileSync } from 'fs'; const watch = process.argv.includes('--watch'); const mermaidOnly = process.argv.includes('--mermaid'); const __dirname = fileURLToPath(new URL('.', import.meta.url)); type OutputOptions = Exclude< Exclude['rollupOptions'], undefined >['output']; const packageOptions = { mermaid: { name: 'mermaid', packageName: 'mermaid', file: 'mermaid.ts', }, 'mermaid-mindmap': { name: 'mermaid-mindmap', packageName: 'mermaid-mindmap', file: 'detector.ts', }, // 'mermaid-example-diagram-detector': { // name: 'mermaid-example-diagram-detector', // packageName: 'mermaid-example-diagram', // file: 'detector.ts', // }, }; interface BuildOptions { minify: boolean | 'esbuild'; core?: boolean; watch?: boolean; entryName: keyof typeof packageOptions; } export const getBuildConfig = ({ minify, core, watch, entryName }: BuildOptions): InlineConfig => { const external = ['require', 'fs', 'path']; console.log(entryName, packageOptions[entryName]); const { name, file, packageName } = packageOptions[entryName]; let output: OutputOptions = [ { name, format: 'esm', sourcemap: true, entryFileNames: `${name}.esm${minify ? '.min' : ''}.mjs`, }, { name, format: 'umd', sourcemap: true, entryFileNames: `${name}${minify ? '.min' : ''}.js`, }, ]; if (core) { const { dependencies } = JSON.parse( readFileSync(resolve(__dirname, `../packages/${packageName}/package.json`), 'utf-8') ); // Core build is used to generate file without bundled dependencies. // This is used by downstream projects to bundle dependencies themselves. external.push(...Object.keys(dependencies)); // This needs to be an array. Otherwise vite will build esm & umd with same name and overwrite esm with umd. output = [ { name, format: 'esm', sourcemap: true, entryFileNames: `${name}.core.mjs`, }, ]; } const config: InlineConfig = { configFile: false, build: { emptyOutDir: false, outDir: resolve(__dirname, `../packages/${packageName}/dist`), lib: { entry: resolve(__dirname, `../packages/${packageName}/src/${file}`), name, // the proper extensions will be added fileName: name, }, minify, rollupOptions: { external, output, }, }, resolve: { extensions: ['.jison', '.js', '.ts', '.json'], }, plugins: [jisonPlugin()], }; if (watch && config.build) { config.build.watch = { include: [ 'packages/mermaid-mindmap/src/**', 'packages/mermaid/src/**', // 'packages/mermaid-example-diagram/src/**', ], }; } return config; }; const buildPackage = async (entryName: keyof typeof packageOptions) => { return Promise.allSettled([ build(getBuildConfig({ minify: false, entryName })), build(getBuildConfig({ minify: 'esbuild', entryName })), build(getBuildConfig({ minify: false, core: true, entryName })), ]); }; const main = async () => { const packageNames = Object.keys(packageOptions) as (keyof typeof packageOptions)[]; for (const pkg of packageNames) { if (mermaidOnly && pkg !== 'mermaid') { continue; } await buildPackage(pkg); } }; if (watch) { build(getBuildConfig({ minify: false, watch, core: true, entryName: 'mermaid' })); if (!mermaidOnly) { build(getBuildConfig({ minify: false, watch, entryName: 'mermaid-mindmap' })); // build(getBuildConfig({ minify: false, watch, entryName: 'mermaid-example-diagram' })); } } else { void main(); }