@nlabs/lex 1.52.6 → 1.52.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,6 +1,6 @@
1
1
  // Mock implementation of LexConfig
2
2
  const defaultConfigValues = {
3
- bundler: 'webpack',
3
+ bundler: 'swc',
4
4
  useTypescript: false,
5
5
  useGraphQl: false,
6
6
  targetEnvironment: 'web',
@@ -109,8 +109,6 @@ export const buildWithSWC = async (spinner, commandOptions, callback)=>{
109
109
  };
110
110
  export const buildWithWebpack = async (spinner, cmd, callback)=>{
111
111
  const { analyze, cliName = 'Lex', config, configName, defineProcessEnvNodeEnv, devtool, disableInterpret, entry, env, failOnWarnings, json, merge, mode, name, nodeEnv, noDevtool, noStats, noTarget, noWatch, noWatchOptionsStdin, outputPath, quiet = false, stats, target, watch, watchOptionsStdin } = cmd;
112
- console.log('entry:', entry, 'type:', typeof entry);
113
- console.log('outputPath:', outputPath, 'type:', typeof outputPath);
114
112
  const entryValue = Array.isArray(entry) ? entry[0] : entry;
115
113
  let webpackConfig;
116
114
  if (config) {
@@ -127,8 +125,6 @@ export const buildWithWebpack = async (spinner, cmd, callback)=>{
127
125
  webpackConfig = resolvedConfig;
128
126
  }
129
127
  }
130
- console.log('webpackConfig path:', webpackConfig);
131
- console.log('webpackConfig exists:', existsSync(webpackConfig));
132
128
  if (!existsSync(webpackConfig)) {
133
129
  const lexPackagePath = getLexPackageJsonPath();
134
130
  const lexPackageDir = dirname(lexPackagePath);
@@ -192,10 +188,6 @@ export const buildWithWebpack = async (spinner, cmd, callback)=>{
192
188
  ...webpackOptions
193
189
  ];
194
190
  }
195
- console.log('webpackPath:', webpackPath);
196
- console.log('executablePath:', executablePath);
197
- console.log('finalWebpackOptions:', JSON.stringify(finalWebpackOptions));
198
- console.log('finalWebpackOptions type:', Array.isArray(finalWebpackOptions) ? 'Array' : typeof finalWebpackOptions);
199
191
  const childProcess = execa(executablePath, finalWebpackOptions, {
200
192
  encoding: 'utf8',
201
193
  stdio: 'pipe'
@@ -398,8 +390,6 @@ What are the key optimization opportunities for this build configuration? Consid
398
390
  all: true
399
391
  });
400
392
  if (result.exitCode !== 0) {
401
- // TypeScript may have errors but still generate some declarations
402
- // Log warnings but don't fail if declarations were generated
403
393
  const hasDeclarations = result.all?.includes('Writing') || result.all?.includes('Declaration') || false;
404
394
  const errorOutput = result.stderr || result.stdout || result.all || 'Unknown error';
405
395
  if (!hasDeclarations) {
@@ -450,4 +440,4 @@ What are the key optimization opportunities for this build configuration? Consid
450
440
  };
451
441
  export default build;
452
442
 
453
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/commands/build/build.ts"],"sourcesContent":["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {transform} from '@swc/core';\nimport {execa} from 'execa';\nimport {existsSync, readFileSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport {\n  dirname,\n  relative as pathRelative,\n  resolve as pathResolve\n} from 'path';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {checkLinkedModules, copyConfiguredFiles, createSpinner, createProgressBar, handleWebpackProgress, removeFiles} from '../../utils/app.js';\nimport {\n  resolveWebpackPaths,\n  getLexPackageJsonPath,\n  resolveBinaryPath\n} from '../../utils/file.js';\nimport {log} from '../../utils/log.js';\nimport {processTranslations} from '../../utils/translations.js';\nimport {aiFunction} from '../ai/ai.js';\nimport boxen from 'boxen';\nimport chalk from 'chalk';\n\nimport type {SWCOptions} from '../../LexConfig.js';\n\nlet currentFilename: string;\nlet currentDirname: string;\n\ntry {\n  currentFilename = eval('require(\"url\").fileURLToPath(import.meta.url)');\n  currentDirname = dirname(currentFilename);\n} catch {\n  currentFilename = process.cwd();\n  currentDirname = process.cwd();\n}\n\nexport interface BuildOptions {\n  readonly assist?: boolean;\n  readonly analyze?: boolean;\n  readonly bundler?: 'webpack' | 'swc';\n  readonly cliName?: string;\n  readonly entry?: string;\n  readonly format?: string;\n  readonly outputPath?: string;\n  readonly quiet?: boolean;\n  readonly remove?: boolean;\n  readonly sourcePath?: string;\n  readonly test?: boolean;\n  readonly translations?: boolean;\n  readonly variables?: string;\n  readonly watch?: boolean;\n}\n\nexport type BuildCallback = (status: number) => void;\n\nconst displayBuildStatus = (bundler: string, outputPath: string, quiet: boolean, stats?: {modules?: number; assets?: number; size?: string}) => {\n  if(quiet) return;\n\n  let statsInfo = '';\n  if(stats && stats.modules && stats.assets) {\n    statsInfo = `\\n${chalk.green('Modules:')}    ${chalk.cyan(stats.modules)}\\n` +\n      `${chalk.green('Assets:')}     ${chalk.cyan(stats.assets)}\\n` +\n      `${chalk.green('Size:')}       ${chalk.cyan(stats.size)}\\n`;\n  }\n\n  const statusBox = boxen(\n    `${chalk.cyan.bold('🏗️  Build Completed Successfully ')}\\n\\n` +\n    `${chalk.green('Bundler:')}    ${chalk.cyan(bundler)}\\n` +\n    `${chalk.green('Output:')}     ${chalk.underline(outputPath)}${statsInfo}\\n` +\n    `${chalk.yellow('Ready for deployment! 🚀')}`,\n    {\n      padding: 1,\n      margin: 1,\n      borderStyle: 'round',\n      borderColor: 'green',\n      backgroundColor: '#1a1a1a'\n    }\n  );\n\n  console.log('\\n' + statusBox + '\\n');\n};\n\nexport const buildWithSWC = async (spinner, commandOptions: BuildOptions, callback: BuildCallback) => {\n  const {\n    cliName = 'Lex',\n    format = 'esm',\n    outputPath,\n    quiet,\n    sourcePath,\n    watch\n  } = commandOptions;\n  const {\n    outputFullPath,\n    sourceFullPath,\n    swc: swcConfig,\n    targetEnvironment,\n    useGraphQl,\n    useTypescript\n  } = LexConfig.config;\n  const sourceDir: string = sourcePath ? pathResolve(process.cwd(), `./${sourcePath}`) : sourceFullPath || '';\n\n  const globOptions = {\n    absolute: true,\n    cwd: sourceDir,\n    dot: false,\n    nodir: true,\n    nosort: true\n  };\n  const tsFiles: string[] = globSync(`**/!(*.spec|*.test).ts*`, globOptions);\n  const jsFiles: string[] = globSync(`**/!(*.spec|*.test).js`, globOptions);\n  const sourceFiles: string[] = [...tsFiles, ...jsFiles];\n\n  const outputDir: string = outputPath\n    ? pathResolve(process.cwd(), outputPath)\n    : (outputFullPath || pathResolve(process.cwd(), './lib'));\n\n  try {\n    spinner.start('Building with SWC...');\n\n    const transformPromises = sourceFiles.map(async (file) => {\n      const fileRelativeToSource = pathRelative(sourceDir, file);\n      const sourcePath = file; // file is already absolute\n      const outputFile = fileRelativeToSource.replace(/\\.(ts|tsx)$/, '.js');\n      const outputPath = pathResolve(outputDir, outputFile);\n      const outputDirPath = dirname(outputPath);\n\n      if(!existsSync(outputDirPath)) {\n        const {mkdirSync} = await import('fs');\n        mkdirSync(outputDirPath, {recursive: true});\n      }\n\n      const sourceCode = readFileSync(sourcePath, 'utf8');\n      const swcOptions = {\n        ...swcConfig,\n        filename: file,\n        module: {\n          type: format === 'cjs' ? 'commonjs' as const : (swcConfig?.module?.type as 'es6' || 'es6'),\n          ...swcConfig?.module\n        },\n      } as Partial<SWCOptions>;\n\n      const result = await transform(sourceCode, swcOptions);\n\n      const {writeFileSync} = await import('fs');\n      writeFileSync(outputPath, result.code);\n    });\n\n    await Promise.all(transformPromises);\n\n    spinner.succeed('Build completed with SWC');\n    displayBuildStatus('SWC', outputDir, quiet);\n    callback(0);\n    return 0;\n  } catch(error) {\n    log(`\\n${commandOptions.cliName || 'Lex'} Error: SWC build failed`, 'error', quiet);\n    log(`\\nError: ${error.message}`, 'error', quiet);\n\n    if(error instanceof Error) {\n      if(error.stack) {\n        log(`\\nStack Trace:\\n${error.stack}`, 'error', quiet);\n      }\n\n      if('filename' in error || 'file' in error) {\n        log(`\\nFile: ${(error as any).filename || (error as any).file}`, 'error', quiet);\n      }\n    }\n\n    spinner.fail('Build failed with SWC');\n    if(!quiet) {\n      console.error('\\nFull Error Details:', error);\n    }\n    callback(1);\n    return 1;\n  }\n};\n\nexport const buildWithWebpack = async (spinner, cmd, callback) => {\n  const {\n    analyze,\n    cliName = 'Lex',\n    config,\n    configName,\n    defineProcessEnvNodeEnv,\n    devtool,\n    disableInterpret,\n    entry,\n    env,\n    failOnWarnings,\n    json,\n    merge,\n    mode,\n    name,\n    nodeEnv,\n    noDevtool,\n    noStats,\n    noTarget,\n    noWatch,\n    noWatchOptionsStdin,\n    outputPath,\n    quiet = false,\n    stats,\n    target,\n    watch,\n    watchOptionsStdin\n  } = cmd;\n\n  console.log('entry:', entry, 'type:', typeof entry);\n  console.log('outputPath:', outputPath, 'type:', typeof outputPath);\n\n  const entryValue = Array.isArray(entry) ? entry[0] : entry;\n\n  let webpackConfig: string;\n\n  if(config) {\n    const isRelativeConfig: boolean = config.substr(0, 2) === './';\n    webpackConfig = isRelativeConfig ? pathResolve(process.cwd(), config) : config;\n  } else {\n    const projectConfigPath = pathResolve(process.cwd(), 'webpack.config.js');\n    const projectConfigPathTs = pathResolve(process.cwd(), 'webpack.config.ts');\n    const hasProjectConfig = existsSync(projectConfigPath) || existsSync(projectConfigPathTs);\n\n    if(hasProjectConfig) {\n      webpackConfig = existsSync(projectConfigPathTs) ? projectConfigPathTs : projectConfigPath;\n    } else {\n      const {webpackConfig: resolvedConfig} = resolveWebpackPaths(currentDirname);\n      webpackConfig = resolvedConfig;\n    }\n  }\n\n  console.log('webpackConfig path:', webpackConfig);\n  console.log('webpackConfig exists:', existsSync(webpackConfig));\n\n  if(!existsSync(webpackConfig)) {\n    const lexPackagePath = getLexPackageJsonPath();\n    const lexPackageDir = dirname(lexPackagePath);\n    const lexWebpackConfig = pathResolve(lexPackageDir, 'webpack.config.js');\n\n    if(existsSync(lexWebpackConfig)) {\n      webpackConfig = lexWebpackConfig;\n      console.log('Using Lex webpack config:', webpackConfig);\n    } else {\n      log(`\\n${cliName} Error: Could not find webpack.config.js`, 'error', quiet);\n      spinner.fail('Build failed.');\n      callback(1);\n      return 1;\n    }\n  }\n\n  const webpackOptions: string[] = [\n    '--color',\n    '--progress',\n    '--config', webpackConfig\n  ];\n\n  if(analyze) webpackOptions.push('--analyze');\n  if(configName) webpackOptions.push('--configName', configName);\n  if(defineProcessEnvNodeEnv) webpackOptions.push('--defineProcessEnvNodeEnv', defineProcessEnvNodeEnv);\n  if(devtool) webpackOptions.push('--devtool', devtool);\n  if(disableInterpret) webpackOptions.push('--disableInterpret');\n  if(entryValue) webpackOptions.push('--entry', entryValue.toString());\n  if(env) webpackOptions.push('--env', env);\n  if(failOnWarnings) webpackOptions.push('--failOnWarnings');\n  if(json) webpackOptions.push('--json', json);\n  if(mode) webpackOptions.push('--mode', mode);\n  if(merge) webpackOptions.push('--merge');\n  if(name) webpackOptions.push('--name', name);\n  if(noDevtool) webpackOptions.push('--noDevtool');\n  if(noStats) webpackOptions.push('--noStats');\n  if(noTarget) webpackOptions.push('--noTarget');\n  if(noWatch) webpackOptions.push('--noWatch');\n  if(noWatchOptionsStdin) webpackOptions.push('--noWatchOptionsStdin');\n  if(nodeEnv) webpackOptions.push('--nodeEnv', nodeEnv);\n  if(outputPath) webpackOptions.push('--output-path', outputPath.toString()); // Convert to string\n  if(stats) webpackOptions.push('--stats', stats);\n  if(target) webpackOptions.push('--target', target);\n  if(watch) webpackOptions.push('--watch');\n  if(watchOptionsStdin) webpackOptions.push('--watchOptionsStdin');\n\n  try {\n    const {webpackPath} = resolveWebpackPaths(currentDirname);\n\n    let executablePath = webpackPath;\n    let finalWebpackOptions: string[];\n\n    if(webpackPath === 'npx') {\n      finalWebpackOptions = ['webpack', ...webpackOptions];\n    } else if(webpackPath.endsWith('.js')) {\n      executablePath = 'node';\n      finalWebpackOptions = [webpackPath, ...webpackOptions];\n    } else {\n      finalWebpackOptions = [...webpackOptions];\n    }\n\n    console.log('webpackPath:', webpackPath);\n    console.log('executablePath:', executablePath);\n    console.log('finalWebpackOptions:', JSON.stringify(finalWebpackOptions));\n    console.log('finalWebpackOptions type:', Array.isArray(finalWebpackOptions) ? 'Array' : typeof finalWebpackOptions);\n\n    const childProcess = execa(executablePath, finalWebpackOptions, {encoding: 'utf8', stdio: 'pipe'});\n\n    let buildCompleted = false;\n    let buildStats = {\n      modules: 0,\n      assets: 0,\n      size: '0 B'\n    };\n\n    childProcess.stdout?.on('data', (data: Buffer) => {\n      const output = data.toString();\n\n      handleWebpackProgress(output, spinner, quiet, '🏗️', 'Webpack Building');\n\n      if(!buildCompleted && output.includes('compiled successfully')) {\n        buildCompleted = true;\n        spinner.succeed('Build completed successfully!');\n\n        const moduleMatch = output.match(/(\\d+) modules/);\n        const assetMatch = output.match(/(\\d+) assets/);\n        const sizeMatch = output.match(/assets by status ([\\d.]+ \\w+)/) || output.match(/assets by path.*?([\\d.]+ \\w+)/);\n\n        if(moduleMatch) buildStats.modules = parseInt(moduleMatch[1], 10);\n        if(assetMatch) buildStats.assets = parseInt(assetMatch[1], 10);\n        if(sizeMatch) buildStats.size = sizeMatch[1];\n\n        displayBuildStatus('webpack', LexConfig.config.outputFullPath || 'lib', quiet, buildStats);\n      }\n    });\n\n    childProcess.stderr?.on('data', (data: Buffer) => {\n      const output = data.toString();\n\n      handleWebpackProgress(output, spinner, quiet, '🏗️', 'Webpack Building');\n\n      if(!buildCompleted && output.includes('compiled successfully')) {\n        buildCompleted = true;\n        spinner.succeed('Build completed successfully!');\n\n        const moduleMatch = output.match(/(\\d+) modules/);\n        const assetMatch = output.match(/(\\d+) assets/);\n        const sizeMatch = output.match(/assets by status ([\\d.]+ \\w+)/) || output.match(/assets by path.*?([\\d.]+ \\w+)/);\n\n        if(moduleMatch) buildStats.modules = parseInt(moduleMatch[1], 10);\n        if(assetMatch) buildStats.assets = parseInt(assetMatch[1], 10);\n        if(sizeMatch) buildStats.size = sizeMatch[1];\n\n        displayBuildStatus('webpack', LexConfig.config.outputFullPath || 'lib', quiet, buildStats);\n      }\n    });\n\n    await childProcess;\n\n    if(!buildCompleted) {\n      spinner.succeed('Build completed successfully!');\n      displayBuildStatus('webpack', LexConfig.config.outputFullPath || 'lib', quiet, buildStats);\n    }\n\n    callback(0);\n    return 0;\n  } catch(error) {\n    log(`\\n${cliName} Error: Webpack build failed`, 'error', quiet);\n    log(`\\nError: ${error.message}`, 'error', quiet);\n\n    if(error instanceof Error) {\n      if(error.stack) {\n        log(`\\nStack Trace:\\n${error.stack}`, 'error', quiet);\n      }\n    }\n\n    log(`\\nWebpack Options: ${webpackOptions.slice(0, 5).join(' ')}...`, 'error', quiet);\n\n    spinner.fail('Build failed.');\n\n    if(cmd.assist) {\n      spinner.start('AI is analyzing the webpack error...');\n\n      try {\n        await aiFunction({\n          prompt: `Fix this webpack build error: ${error.message}\\n\\nError details:\\n${error.toString()}\\n\\nConfiguration used:\\n${JSON.stringify(webpackOptions, null, 2)}`,\n          task: 'help',\n          context: true,\n          quiet\n        });\n\n        spinner.succeed('AI analysis complete');\n      } catch(aiError) {\n        spinner.fail('Could not generate AI assistance');\n        if(!quiet) {\n          console.error('AI assistance error:', aiError);\n        }\n      }\n    }\n\n    if(!quiet) {\n      console.error('\\nFull Error Details:', error);\n    }\n\n    callback(1);\n    return 1;\n  }\n};\n\nexport const build = async (cmd: BuildOptions, callback: BuildCallback = () => ({})): Promise<number> => {\n  const {\n    bundler = 'webpack',\n    cliName = 'Lex',\n    quiet = false,\n    remove = false,\n    test = false,\n    translations = false,\n    variables = '{}'\n  } = cmd;\n\n  const spinner = createSpinner(quiet);\n\n  log(`${cliName} building...`, 'info', quiet);\n\n  await LexConfig.parseConfig(cmd);\n\n  const {outputFullPath, useTypescript} = LexConfig.config;\n\n  checkLinkedModules();\n\n  let variablesObj: object = {NODE_ENV: 'production'};\n\n  if(variables) {\n    try {\n      variablesObj = JSON.parse(variables);\n    } catch(error) {\n      log(`\\n${cliName} Error: Environment variables option is not a valid JSON object.`, 'error', quiet);\n\n      callback(1);\n      return 1;\n    }\n  }\n\n  process.env = {...process.env, ...variablesObj};\n\n  if(test) {\n    log('Test mode: Build environment loaded, exiting', 'info', quiet);\n    callback(0);\n    return 0;\n  }\n\n  if(translations) {\n    spinner.start('Processing translations...');\n\n    try {\n      const sourcePath = LexConfig.config.sourceFullPath || process.cwd();\n      const outputPath = LexConfig.config.outputFullPath || 'lib';\n\n      await processTranslations(sourcePath, outputPath, quiet);\n      spinner.succeed('Translations processed successfully!');\n    } catch(translationError) {\n      log(`\\n${cliName} Error: Failed to process translations: ${translationError.message}`, 'error', quiet);\n      spinner.fail('Failed to process translations.');\n      callback(1);\n      return 1;\n    }\n  }\n\n  spinner.start('Building code...');\n\n  if(remove) {\n    await removeFiles(outputFullPath || '');\n  }\n\n  let buildResult = 0;\n\n  if(bundler === 'swc') {\n    buildResult = await buildWithSWC(spinner, cmd, (status) => {\n      buildResult = status;\n    });\n  } else {\n    buildResult = await buildWithWebpack(spinner, cmd, (status) => {\n      buildResult = status;\n    });\n  }\n\n  if(buildResult === 0 && cmd.analyze) {\n    spinner.start('AI is analyzing the build output for optimization opportunities...');\n\n    try {\n      const stats = {\n        outputPath: LexConfig.config.outputFullPath,\n        entryPoints: bundler === 'swc' ?\n          `Source files: ${LexConfig.config.sourceFullPath}/**/*.{ts,js}` :\n          LexConfig.config.webpack?.entry || 'Unknown entry points'\n      };\n\n      await aiFunction({\n        prompt: `Analyze this build for optimization opportunities:\n\nBuild Type: ${bundler}\nFormat: ${cmd.format || 'default'}\nEnvironment: ${LexConfig.config.targetEnvironment}\n${JSON.stringify(stats, null, 2)}\n\nWhat are the key optimization opportunities for this build configuration? Consider:\n1. Bundle size optimization strategies\n2. Code splitting recommendations\n3. Tree-shaking improvements\n4. Performance enhancements\n5. Dependency optimizations`,\n        task: 'optimize',\n        context: true,\n        quiet\n      });\n\n      spinner.succeed('AI build analysis complete');\n    } catch(aiError) {\n      spinner.fail('Could not generate AI optimization analysis');\n      if(!quiet) {\n        console.error('AI analysis error:', aiError);\n      }\n    }\n  }\n\n  if(buildResult === 0) {\n    try {\n      if(useTypescript && bundler === 'swc') {\n        const typescriptPath = resolveBinaryPath('tsc', 'typescript');\n\n        if(typescriptPath) {\n          spinner.start('Generating TypeScript declarations...');\n          try {\n            const sourceFullPath = LexConfig.config.sourceFullPath || pathResolve(process.cwd(), './src');\n            const outputFullPath = LexConfig.config.outputFullPath || pathResolve(process.cwd(), './lib');\n            const globOptions = {\n              cwd: sourceFullPath,\n              dot: false,\n              nodir: true,\n              absolute: true\n            };\n            const tsFiles = globSync(`**/!(*.spec|*.test|*.integration).ts`, globOptions);\n            const tsxFiles = globSync(`**/!(*.spec|*.test|*.integration).tsx`, globOptions);\n            const allSourceFiles = [...tsFiles, ...tsxFiles];\n            const typescriptOptions = [\n              ...LexConfig.getTypeScriptDeclarationFlags(),\n              ...allSourceFiles\n            ];\n            const result = await execa(typescriptPath, typescriptOptions, {\n              encoding: 'utf8',\n              cwd: process.cwd(),\n              reject: false,\n              all: true\n            });\n\n            if(result.exitCode !== 0) {\n              // TypeScript may have errors but still generate some declarations\n              // Log warnings but don't fail if declarations were generated\n              const hasDeclarations = result.all?.includes('Writing') || result.all?.includes('Declaration') || false;\n              const errorOutput = result.stderr || result.stdout || result.all || 'Unknown error';\n\n              if(!hasDeclarations) {\n                log(`\\n${cliName} Error: TypeScript declaration generation failed`, 'error', quiet);\n                log(`\\nExit Code: ${result.exitCode}`, 'error', quiet);\n                log(`\\nTypeScript Command: ${typescriptPath} ${typescriptOptions.slice(0, 10).join(' ')}...`, 'error', quiet);\n                log(`\\nError Output:\\n${errorOutput}`, 'error', quiet);\n\n                const errorLines = errorOutput.split('\\n').filter(line =>\n                  line.includes('error TS') ||\n                  line.includes('Error:') ||\n                  line.trim().startsWith('src/') ||\n                  line.trim().startsWith('TS')\n                );\n\n                if(errorLines.length > 0) {\n                  log(`\\nKey Errors:`, 'error', quiet);\n                  errorLines.slice(0, 10).forEach(line => {\n                    log(`  ${line}`, 'error', quiet);\n                  });\n                  if(errorLines.length > 10) {\n                    log(`  ... and ${errorLines.length - 10} more errors`, 'error', quiet);\n                  }\n                }\n\n                spinner.fail('TypeScript declaration generation had errors (continuing anyway).');\n              } else {\n                log(`\\n${cliName} Warning: TypeScript declaration generation completed with errors`, 'warn', quiet);\n                if(!quiet && errorOutput) {\n                  log(`\\nWarnings:\\n${errorOutput}`, 'warn', quiet);\n                }\n                spinner.succeed('TypeScript declarations generated (with warnings).');\n              }\n            } else {\n              spinner.succeed('TypeScript declarations generated!');\n            }\n          } catch(error) {\n            log(`\\n${cliName} Error: TypeScript declaration generation exception`, 'error', quiet);\n            log(`\\nError: ${error.message}`, 'error', quiet);\n            if(error instanceof Error && error.stack) {\n              log(`\\nStack:\\n${error.stack}`, 'error', quiet);\n            }\n            spinner.fail('TypeScript declaration generation had issues (continuing anyway).');\n          }\n        }\n      }\n\n      await copyConfiguredFiles(spinner, LexConfig.config, quiet);\n    } catch(copyError) {\n      log(`\\n${cliName} Error: Failed to copy configured files: ${copyError.message}`, 'error', quiet);\n      callback(1);\n      return 1;\n    }\n  }\n\n  callback(buildResult);\n  return buildResult;\n};\n\nexport default build;\n"],"names":["transform","execa","existsSync","readFileSync","sync","globSync","dirname","relative","pathRelative","resolve","pathResolve","LexConfig","checkLinkedModules","copyConfiguredFiles","createSpinner","handleWebpackProgress","removeFiles","resolveWebpackPaths","getLexPackageJsonPath","resolveBinaryPath","log","processTranslations","aiFunction","boxen","chalk","currentFilename","currentDirname","eval","process","cwd","displayBuildStatus","bundler","outputPath","quiet","stats","statsInfo","modules","assets","green","cyan","size","statusBox","bold","underline","yellow","padding","margin","borderStyle","borderColor","backgroundColor","console","buildWithSWC","spinner","commandOptions","callback","cliName","format","sourcePath","watch","outputFullPath","sourceFullPath","swc","swcConfig","targetEnvironment","useGraphQl","useTypescript","config","sourceDir","globOptions","absolute","dot","nodir","nosort","tsFiles","jsFiles","sourceFiles","outputDir","start","transformPromises","map","file","fileRelativeToSource","outputFile","replace","outputDirPath","mkdirSync","recursive","sourceCode","swcOptions","filename","module","type","result","writeFileSync","code","Promise","all","succeed","error","message","Error","stack","fail","buildWithWebpack","cmd","analyze","configName","defineProcessEnvNodeEnv","devtool","disableInterpret","entry","env","failOnWarnings","json","merge","mode","name","nodeEnv","noDevtool","noStats","noTarget","noWatch","noWatchOptionsStdin","target","watchOptionsStdin","entryValue","Array","isArray","webpackConfig","isRelativeConfig","substr","projectConfigPath","projectConfigPathTs","hasProjectConfig","resolvedConfig","lexPackagePath","lexPackageDir","lexWebpackConfig","webpackOptions","push","toString","webpackPath","executablePath","finalWebpackOptions","endsWith","JSON","stringify","childProcess","encoding","stdio","buildCompleted","buildStats","stdout","on","data","output","includes","moduleMatch","match","assetMatch","sizeMatch","parseInt","stderr","slice","join","assist","prompt","task","context","aiError","build","remove","test","translations","variables","parseConfig","variablesObj","NODE_ENV","parse","translationError","buildResult","status","entryPoints","webpack","typescriptPath","tsxFiles","allSourceFiles","typescriptOptions","getTypeScriptDeclarationFlags","reject","exitCode","hasDeclarations","errorOutput","errorLines","split","filter","line","trim","startsWith","length","forEach","copyError"],"mappings":"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"}
443
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/commands/build/build.ts"],"sourcesContent":["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {transform} from '@swc/core';\nimport {execa} from 'execa';\nimport {existsSync, readFileSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport {\n  dirname,\n  relative as pathRelative,\n  resolve as pathResolve\n} from 'path';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {checkLinkedModules, copyConfiguredFiles, createSpinner, createProgressBar, handleWebpackProgress, removeFiles} from '../../utils/app.js';\nimport {\n  resolveWebpackPaths,\n  getLexPackageJsonPath,\n  resolveBinaryPath\n} from '../../utils/file.js';\nimport {log} from '../../utils/log.js';\nimport {processTranslations} from '../../utils/translations.js';\nimport {aiFunction} from '../ai/ai.js';\nimport boxen from 'boxen';\nimport chalk from 'chalk';\n\nimport type {SWCOptions} from '../../LexConfig.js';\n\nlet currentFilename: string;\nlet currentDirname: string;\n\ntry {\n  currentFilename = eval('require(\"url\").fileURLToPath(import.meta.url)');\n  currentDirname = dirname(currentFilename);\n} catch {\n  currentFilename = process.cwd();\n  currentDirname = process.cwd();\n}\n\nexport interface BuildOptions {\n  readonly assist?: boolean;\n  readonly analyze?: boolean;\n  readonly bundler?: 'webpack' | 'swc';\n  readonly cliName?: string;\n  readonly entry?: string;\n  readonly format?: string;\n  readonly outputPath?: string;\n  readonly quiet?: boolean;\n  readonly remove?: boolean;\n  readonly sourcePath?: string;\n  readonly test?: boolean;\n  readonly translations?: boolean;\n  readonly variables?: string;\n  readonly watch?: boolean;\n}\n\nexport type BuildCallback = (status: number) => void;\n\nconst displayBuildStatus = (bundler: string, outputPath: string, quiet: boolean, stats?: {modules?: number; assets?: number; size?: string}) => {\n  if(quiet) return;\n\n  let statsInfo = '';\n  if(stats && stats.modules && stats.assets) {\n    statsInfo = `\\n${chalk.green('Modules:')}    ${chalk.cyan(stats.modules)}\\n` +\n      `${chalk.green('Assets:')}     ${chalk.cyan(stats.assets)}\\n` +\n      `${chalk.green('Size:')}       ${chalk.cyan(stats.size)}\\n`;\n  }\n\n  const statusBox = boxen(\n    `${chalk.cyan.bold('🏗️  Build Completed Successfully ')}\\n\\n` +\n    `${chalk.green('Bundler:')}    ${chalk.cyan(bundler)}\\n` +\n    `${chalk.green('Output:')}     ${chalk.underline(outputPath)}${statsInfo}\\n` +\n    `${chalk.yellow('Ready for deployment! 🚀')}`,\n    {\n      padding: 1,\n      margin: 1,\n      borderStyle: 'round',\n      borderColor: 'green',\n      backgroundColor: '#1a1a1a'\n    }\n  );\n\n  console.log('\\n' + statusBox + '\\n');\n};\n\nexport const buildWithSWC = async (spinner, commandOptions: BuildOptions, callback: BuildCallback) => {\n  const {\n    cliName = 'Lex',\n    format = 'esm',\n    outputPath,\n    quiet,\n    sourcePath,\n    watch\n  } = commandOptions;\n  const {\n    outputFullPath,\n    sourceFullPath,\n    swc: swcConfig,\n    targetEnvironment,\n    useGraphQl,\n    useTypescript\n  } = LexConfig.config;\n  const sourceDir: string = sourcePath ? pathResolve(process.cwd(), `./${sourcePath}`) : sourceFullPath || '';\n\n  const globOptions = {\n    absolute: true,\n    cwd: sourceDir,\n    dot: false,\n    nodir: true,\n    nosort: true\n  };\n  const tsFiles: string[] = globSync(`**/!(*.spec|*.test).ts*`, globOptions);\n  const jsFiles: string[] = globSync(`**/!(*.spec|*.test).js`, globOptions);\n  const sourceFiles: string[] = [...tsFiles, ...jsFiles];\n\n  const outputDir: string = outputPath\n    ? pathResolve(process.cwd(), outputPath)\n    : (outputFullPath || pathResolve(process.cwd(), './lib'));\n\n  try {\n    spinner.start('Building with SWC...');\n\n    const transformPromises = sourceFiles.map(async (file) => {\n      const fileRelativeToSource = pathRelative(sourceDir, file);\n      const sourcePath = file; // file is already absolute\n      const outputFile = fileRelativeToSource.replace(/\\.(ts|tsx)$/, '.js');\n      const outputPath = pathResolve(outputDir, outputFile);\n      const outputDirPath = dirname(outputPath);\n\n      if(!existsSync(outputDirPath)) {\n        const {mkdirSync} = await import('fs');\n        mkdirSync(outputDirPath, {recursive: true});\n      }\n\n      const sourceCode = readFileSync(sourcePath, 'utf8');\n      const swcOptions = {\n        ...swcConfig,\n        filename: file,\n        module: {\n          type: format === 'cjs' ? 'commonjs' as const : (swcConfig?.module?.type as 'es6' || 'es6'),\n          ...swcConfig?.module\n        },\n      } as Partial<SWCOptions>;\n\n      const result = await transform(sourceCode, swcOptions);\n\n      const {writeFileSync} = await import('fs');\n      writeFileSync(outputPath, result.code);\n    });\n\n    await Promise.all(transformPromises);\n\n    spinner.succeed('Build completed with SWC');\n    displayBuildStatus('SWC', outputDir, quiet);\n    callback(0);\n    return 0;\n  } catch(error) {\n    log(`\\n${commandOptions.cliName || 'Lex'} Error: SWC build failed`, 'error', quiet);\n    log(`\\nError: ${error.message}`, 'error', quiet);\n\n    if(error instanceof Error) {\n      if(error.stack) {\n        log(`\\nStack Trace:\\n${error.stack}`, 'error', quiet);\n      }\n\n      if('filename' in error || 'file' in error) {\n        log(`\\nFile: ${(error as any).filename || (error as any).file}`, 'error', quiet);\n      }\n    }\n\n    spinner.fail('Build failed with SWC');\n    if(!quiet) {\n      console.error('\\nFull Error Details:', error);\n    }\n    callback(1);\n    return 1;\n  }\n};\n\nexport const buildWithWebpack = async (spinner, cmd, callback) => {\n  const {\n    analyze,\n    cliName = 'Lex',\n    config,\n    configName,\n    defineProcessEnvNodeEnv,\n    devtool,\n    disableInterpret,\n    entry,\n    env,\n    failOnWarnings,\n    json,\n    merge,\n    mode,\n    name,\n    nodeEnv,\n    noDevtool,\n    noStats,\n    noTarget,\n    noWatch,\n    noWatchOptionsStdin,\n    outputPath,\n    quiet = false,\n    stats,\n    target,\n    watch,\n    watchOptionsStdin\n  } = cmd;\n\n  const entryValue = Array.isArray(entry) ? entry[0] : entry;\n\n  let webpackConfig: string;\n\n  if(config) {\n    const isRelativeConfig: boolean = config.substr(0, 2) === './';\n    webpackConfig = isRelativeConfig ? pathResolve(process.cwd(), config) : config;\n  } else {\n    const projectConfigPath = pathResolve(process.cwd(), 'webpack.config.js');\n    const projectConfigPathTs = pathResolve(process.cwd(), 'webpack.config.ts');\n    const hasProjectConfig = existsSync(projectConfigPath) || existsSync(projectConfigPathTs);\n\n    if(hasProjectConfig) {\n      webpackConfig = existsSync(projectConfigPathTs) ? projectConfigPathTs : projectConfigPath;\n    } else {\n      const {webpackConfig: resolvedConfig} = resolveWebpackPaths(currentDirname);\n      webpackConfig = resolvedConfig;\n    }\n  }\n\n  if(!existsSync(webpackConfig)) {\n    const lexPackagePath = getLexPackageJsonPath();\n    const lexPackageDir = dirname(lexPackagePath);\n    const lexWebpackConfig = pathResolve(lexPackageDir, 'webpack.config.js');\n\n    if(existsSync(lexWebpackConfig)) {\n      webpackConfig = lexWebpackConfig;\n      console.log('Using Lex webpack config:', webpackConfig);\n    } else {\n      log(`\\n${cliName} Error: Could not find webpack.config.js`, 'error', quiet);\n      spinner.fail('Build failed.');\n      callback(1);\n      return 1;\n    }\n  }\n\n  const webpackOptions: string[] = [\n    '--color',\n    '--progress',\n    '--config', webpackConfig\n  ];\n\n  if(analyze) webpackOptions.push('--analyze');\n  if(configName) webpackOptions.push('--configName', configName);\n  if(defineProcessEnvNodeEnv) webpackOptions.push('--defineProcessEnvNodeEnv', defineProcessEnvNodeEnv);\n  if(devtool) webpackOptions.push('--devtool', devtool);\n  if(disableInterpret) webpackOptions.push('--disableInterpret');\n  if(entryValue) webpackOptions.push('--entry', entryValue.toString());\n  if(env) webpackOptions.push('--env', env);\n  if(failOnWarnings) webpackOptions.push('--failOnWarnings');\n  if(json) webpackOptions.push('--json', json);\n  if(mode) webpackOptions.push('--mode', mode);\n  if(merge) webpackOptions.push('--merge');\n  if(name) webpackOptions.push('--name', name);\n  if(noDevtool) webpackOptions.push('--noDevtool');\n  if(noStats) webpackOptions.push('--noStats');\n  if(noTarget) webpackOptions.push('--noTarget');\n  if(noWatch) webpackOptions.push('--noWatch');\n  if(noWatchOptionsStdin) webpackOptions.push('--noWatchOptionsStdin');\n  if(nodeEnv) webpackOptions.push('--nodeEnv', nodeEnv);\n  if(outputPath) webpackOptions.push('--output-path', outputPath.toString()); // Convert to string\n  if(stats) webpackOptions.push('--stats', stats);\n  if(target) webpackOptions.push('--target', target);\n  if(watch) webpackOptions.push('--watch');\n  if(watchOptionsStdin) webpackOptions.push('--watchOptionsStdin');\n\n  try {\n    const {webpackPath} = resolveWebpackPaths(currentDirname);\n\n    let executablePath = webpackPath;\n    let finalWebpackOptions: string[];\n\n    if(webpackPath === 'npx') {\n      finalWebpackOptions = ['webpack', ...webpackOptions];\n    } else if(webpackPath.endsWith('.js')) {\n      executablePath = 'node';\n      finalWebpackOptions = [webpackPath, ...webpackOptions];\n    } else {\n      finalWebpackOptions = [...webpackOptions];\n    }\n\n    const childProcess = execa(executablePath, finalWebpackOptions, {encoding: 'utf8', stdio: 'pipe'});\n\n    let buildCompleted = false;\n    let buildStats = {\n      modules: 0,\n      assets: 0,\n      size: '0 B'\n    };\n\n    childProcess.stdout?.on('data', (data: Buffer) => {\n      const output = data.toString();\n\n      handleWebpackProgress(output, spinner, quiet, '🏗️', 'Webpack Building');\n\n      if(!buildCompleted && output.includes('compiled successfully')) {\n        buildCompleted = true;\n        spinner.succeed('Build completed successfully!');\n\n        const moduleMatch = output.match(/(\\d+) modules/);\n        const assetMatch = output.match(/(\\d+) assets/);\n        const sizeMatch = output.match(/assets by status ([\\d.]+ \\w+)/) || output.match(/assets by path.*?([\\d.]+ \\w+)/);\n\n        if(moduleMatch) buildStats.modules = parseInt(moduleMatch[1], 10);\n        if(assetMatch) buildStats.assets = parseInt(assetMatch[1], 10);\n        if(sizeMatch) buildStats.size = sizeMatch[1];\n\n        displayBuildStatus('webpack', LexConfig.config.outputFullPath || 'lib', quiet, buildStats);\n      }\n    });\n\n    childProcess.stderr?.on('data', (data: Buffer) => {\n      const output = data.toString();\n\n      handleWebpackProgress(output, spinner, quiet, '🏗️', 'Webpack Building');\n\n      if(!buildCompleted && output.includes('compiled successfully')) {\n        buildCompleted = true;\n        spinner.succeed('Build completed successfully!');\n\n        const moduleMatch = output.match(/(\\d+) modules/);\n        const assetMatch = output.match(/(\\d+) assets/);\n        const sizeMatch = output.match(/assets by status ([\\d.]+ \\w+)/) || output.match(/assets by path.*?([\\d.]+ \\w+)/);\n\n        if(moduleMatch) buildStats.modules = parseInt(moduleMatch[1], 10);\n        if(assetMatch) buildStats.assets = parseInt(assetMatch[1], 10);\n        if(sizeMatch) buildStats.size = sizeMatch[1];\n\n        displayBuildStatus('webpack', LexConfig.config.outputFullPath || 'lib', quiet, buildStats);\n      }\n    });\n\n    await childProcess;\n\n    if(!buildCompleted) {\n      spinner.succeed('Build completed successfully!');\n      displayBuildStatus('webpack', LexConfig.config.outputFullPath || 'lib', quiet, buildStats);\n    }\n\n    callback(0);\n    return 0;\n  } catch(error) {\n    log(`\\n${cliName} Error: Webpack build failed`, 'error', quiet);\n    log(`\\nError: ${error.message}`, 'error', quiet);\n\n    if(error instanceof Error) {\n      if(error.stack) {\n        log(`\\nStack Trace:\\n${error.stack}`, 'error', quiet);\n      }\n    }\n\n    log(`\\nWebpack Options: ${webpackOptions.slice(0, 5).join(' ')}...`, 'error', quiet);\n\n    spinner.fail('Build failed.');\n\n    if(cmd.assist) {\n      spinner.start('AI is analyzing the webpack error...');\n\n      try {\n        await aiFunction({\n          prompt: `Fix this webpack build error: ${error.message}\\n\\nError details:\\n${error.toString()}\\n\\nConfiguration used:\\n${JSON.stringify(webpackOptions, null, 2)}`,\n          task: 'help',\n          context: true,\n          quiet\n        });\n\n        spinner.succeed('AI analysis complete');\n      } catch(aiError) {\n        spinner.fail('Could not generate AI assistance');\n        if(!quiet) {\n          console.error('AI assistance error:', aiError);\n        }\n      }\n    }\n\n    if(!quiet) {\n      console.error('\\nFull Error Details:', error);\n    }\n\n    callback(1);\n    return 1;\n  }\n};\n\nexport const build = async (cmd: BuildOptions, callback: BuildCallback = () => ({})): Promise<number> => {\n  const {\n    bundler = 'webpack',\n    cliName = 'Lex',\n    quiet = false,\n    remove = false,\n    test = false,\n    translations = false,\n    variables = '{}'\n  } = cmd;\n\n  const spinner = createSpinner(quiet);\n\n  log(`${cliName} building...`, 'info', quiet);\n\n  await LexConfig.parseConfig(cmd);\n\n  const {outputFullPath, useTypescript} = LexConfig.config;\n\n  checkLinkedModules();\n\n  let variablesObj: object = {NODE_ENV: 'production'};\n\n  if(variables) {\n    try {\n      variablesObj = JSON.parse(variables);\n    } catch(error) {\n      log(`\\n${cliName} Error: Environment variables option is not a valid JSON object.`, 'error', quiet);\n\n      callback(1);\n      return 1;\n    }\n  }\n\n  process.env = {...process.env, ...variablesObj};\n\n  if(test) {\n    log('Test mode: Build environment loaded, exiting', 'info', quiet);\n    callback(0);\n    return 0;\n  }\n\n  if(translations) {\n    spinner.start('Processing translations...');\n\n    try {\n      const sourcePath = LexConfig.config.sourceFullPath || process.cwd();\n      const outputPath = LexConfig.config.outputFullPath || 'lib';\n\n      await processTranslations(sourcePath, outputPath, quiet);\n      spinner.succeed('Translations processed successfully!');\n    } catch(translationError) {\n      log(`\\n${cliName} Error: Failed to process translations: ${translationError.message}`, 'error', quiet);\n      spinner.fail('Failed to process translations.');\n      callback(1);\n      return 1;\n    }\n  }\n\n  spinner.start('Building code...');\n\n  if(remove) {\n    await removeFiles(outputFullPath || '');\n  }\n\n  let buildResult = 0;\n\n  if(bundler === 'swc') {\n    buildResult = await buildWithSWC(spinner, cmd, (status) => {\n      buildResult = status;\n    });\n  } else {\n    buildResult = await buildWithWebpack(spinner, cmd, (status) => {\n      buildResult = status;\n    });\n  }\n\n  if(buildResult === 0 && cmd.analyze) {\n    spinner.start('AI is analyzing the build output for optimization opportunities...');\n\n    try {\n      const stats = {\n        outputPath: LexConfig.config.outputFullPath,\n        entryPoints: bundler === 'swc' ?\n          `Source files: ${LexConfig.config.sourceFullPath}/**/*.{ts,js}` :\n          LexConfig.config.webpack?.entry || 'Unknown entry points'\n      };\n\n      await aiFunction({\n        prompt: `Analyze this build for optimization opportunities:\n\nBuild Type: ${bundler}\nFormat: ${cmd.format || 'default'}\nEnvironment: ${LexConfig.config.targetEnvironment}\n${JSON.stringify(stats, null, 2)}\n\nWhat are the key optimization opportunities for this build configuration? Consider:\n1. Bundle size optimization strategies\n2. Code splitting recommendations\n3. Tree-shaking improvements\n4. Performance enhancements\n5. Dependency optimizations`,\n        task: 'optimize',\n        context: true,\n        quiet\n      });\n\n      spinner.succeed('AI build analysis complete');\n    } catch(aiError) {\n      spinner.fail('Could not generate AI optimization analysis');\n      if(!quiet) {\n        console.error('AI analysis error:', aiError);\n      }\n    }\n  }\n\n  if(buildResult === 0) {\n    try {\n      if(useTypescript && bundler === 'swc') {\n        const typescriptPath = resolveBinaryPath('tsc', 'typescript');\n\n        if(typescriptPath) {\n          spinner.start('Generating TypeScript declarations...');\n          try {\n            const sourceFullPath = LexConfig.config.sourceFullPath || pathResolve(process.cwd(), './src');\n            const outputFullPath = LexConfig.config.outputFullPath || pathResolve(process.cwd(), './lib');\n            const globOptions = {\n              cwd: sourceFullPath,\n              dot: false,\n              nodir: true,\n              absolute: true\n            };\n            const tsFiles = globSync(`**/!(*.spec|*.test|*.integration).ts`, globOptions);\n            const tsxFiles = globSync(`**/!(*.spec|*.test|*.integration).tsx`, globOptions);\n            const allSourceFiles = [...tsFiles, ...tsxFiles];\n            const typescriptOptions = [\n              ...LexConfig.getTypeScriptDeclarationFlags(),\n              ...allSourceFiles\n            ];\n            const result = await execa(typescriptPath, typescriptOptions, {\n              encoding: 'utf8',\n              cwd: process.cwd(),\n              reject: false,\n              all: true\n            });\n\n            if(result.exitCode !== 0) {\n              const hasDeclarations = result.all?.includes('Writing') || result.all?.includes('Declaration') || false;\n              const errorOutput = result.stderr || result.stdout || result.all || 'Unknown error';\n\n              if(!hasDeclarations) {\n                log(`\\n${cliName} Error: TypeScript declaration generation failed`, 'error', quiet);\n                log(`\\nExit Code: ${result.exitCode}`, 'error', quiet);\n                log(`\\nTypeScript Command: ${typescriptPath} ${typescriptOptions.slice(0, 10).join(' ')}...`, 'error', quiet);\n                log(`\\nError Output:\\n${errorOutput}`, 'error', quiet);\n\n                const errorLines = errorOutput.split('\\n').filter(line =>\n                  line.includes('error TS') ||\n                  line.includes('Error:') ||\n                  line.trim().startsWith('src/') ||\n                  line.trim().startsWith('TS')\n                );\n\n                if(errorLines.length > 0) {\n                  log(`\\nKey Errors:`, 'error', quiet);\n                  errorLines.slice(0, 10).forEach(line => {\n                    log(`  ${line}`, 'error', quiet);\n                  });\n                  if(errorLines.length > 10) {\n                    log(`  ... and ${errorLines.length - 10} more errors`, 'error', quiet);\n                  }\n                }\n\n                spinner.fail('TypeScript declaration generation had errors (continuing anyway).');\n              } else {\n                log(`\\n${cliName} Warning: TypeScript declaration generation completed with errors`, 'warn', quiet);\n                if(!quiet && errorOutput) {\n                  log(`\\nWarnings:\\n${errorOutput}`, 'warn', quiet);\n                }\n                spinner.succeed('TypeScript declarations generated (with warnings).');\n              }\n            } else {\n              spinner.succeed('TypeScript declarations generated!');\n            }\n          } catch(error) {\n            log(`\\n${cliName} Error: TypeScript declaration generation exception`, 'error', quiet);\n            log(`\\nError: ${error.message}`, 'error', quiet);\n            if(error instanceof Error && error.stack) {\n              log(`\\nStack:\\n${error.stack}`, 'error', quiet);\n            }\n            spinner.fail('TypeScript declaration generation had issues (continuing anyway).');\n          }\n        }\n      }\n\n      await copyConfiguredFiles(spinner, LexConfig.config, quiet);\n    } catch(copyError) {\n      log(`\\n${cliName} Error: Failed to copy configured files: ${copyError.message}`, 'error', quiet);\n      callback(1);\n      return 1;\n    }\n  }\n\n  callback(buildResult);\n  return buildResult;\n};\n\nexport default build;\n"],"names":["transform","execa","existsSync","readFileSync","sync","globSync","dirname","relative","pathRelative","resolve","pathResolve","LexConfig","checkLinkedModules","copyConfiguredFiles","createSpinner","handleWebpackProgress","removeFiles","resolveWebpackPaths","getLexPackageJsonPath","resolveBinaryPath","log","processTranslations","aiFunction","boxen","chalk","currentFilename","currentDirname","eval","process","cwd","displayBuildStatus","bundler","outputPath","quiet","stats","statsInfo","modules","assets","green","cyan","size","statusBox","bold","underline","yellow","padding","margin","borderStyle","borderColor","backgroundColor","console","buildWithSWC","spinner","commandOptions","callback","cliName","format","sourcePath","watch","outputFullPath","sourceFullPath","swc","swcConfig","targetEnvironment","useGraphQl","useTypescript","config","sourceDir","globOptions","absolute","dot","nodir","nosort","tsFiles","jsFiles","sourceFiles","outputDir","start","transformPromises","map","file","fileRelativeToSource","outputFile","replace","outputDirPath","mkdirSync","recursive","sourceCode","swcOptions","filename","module","type","result","writeFileSync","code","Promise","all","succeed","error","message","Error","stack","fail","buildWithWebpack","cmd","analyze","configName","defineProcessEnvNodeEnv","devtool","disableInterpret","entry","env","failOnWarnings","json","merge","mode","name","nodeEnv","noDevtool","noStats","noTarget","noWatch","noWatchOptionsStdin","target","watchOptionsStdin","entryValue","Array","isArray","webpackConfig","isRelativeConfig","substr","projectConfigPath","projectConfigPathTs","hasProjectConfig","resolvedConfig","lexPackagePath","lexPackageDir","lexWebpackConfig","webpackOptions","push","toString","webpackPath","executablePath","finalWebpackOptions","endsWith","childProcess","encoding","stdio","buildCompleted","buildStats","stdout","on","data","output","includes","moduleMatch","match","assetMatch","sizeMatch","parseInt","stderr","slice","join","assist","prompt","JSON","stringify","task","context","aiError","build","remove","test","translations","variables","parseConfig","variablesObj","NODE_ENV","parse","translationError","buildResult","status","entryPoints","webpack","typescriptPath","tsxFiles","allSourceFiles","typescriptOptions","getTypeScriptDeclarationFlags","reject","exitCode","hasDeclarations","errorOutput","errorLines","split","filter","line","trim","startsWith","length","forEach","copyError"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nlabs/lex",
3
- "version": "1.52.6",
3
+ "version": "1.52.10",
4
4
  "description": "Lex",
5
5
  "license": "MIT",
6
6
  "type": "module",
@@ -160,12 +160,15 @@
160
160
  "latest-version": "9.0.0",
161
161
  "lodash": "^4.17.21",
162
162
  "luxon": "^3.7.2",
163
+ "math-expression-evaluator": "^2.0.7",
164
+ "mini-css-extract-plugin": "^2.9.4",
163
165
  "net": "^1.0.2",
164
166
  "npm-check-updates": "^19.1.2",
165
167
  "openai": "^6.10.0",
166
168
  "ora": "9.0.0",
167
169
  "os-browserify": "^0.3.0",
168
170
  "path-browserify": "^1.0.1",
171
+ "postcss": "^8.5.6",
169
172
  "postcss-browser-reporter": "^0.7.0",
170
173
  "postcss-cli": "^11.0.1",
171
174
  "postcss-custom-properties": "^14.0.6",
@@ -177,12 +180,10 @@
177
180
  "postcss-nesting": "^13.0.2",
178
181
  "postcss-percentage": "^0.0.0",
179
182
  "postcss-preset-env": "^10.5.0",
180
- "postcss-value-parser": "^4.2.0",
181
- "math-expression-evaluator": "^2.0.7",
182
183
  "postcss-simple-vars": "^7.0.1",
183
184
  "postcss-svgo": "7.1.0",
184
185
  "postcss-url": "10.1.3",
185
- "postcss": "^8.5.6",
186
+ "postcss-value-parser": "^4.2.0",
186
187
  "process": "^0.11.10",
187
188
  "randombytes": "^2.1.0",
188
189
  "react": "^19.2.1",
package/webpack.config.js CHANGED
@@ -14,6 +14,7 @@ import FaviconsWebpackPlugin from 'favicons-webpack-plugin';
14
14
  import {existsSync} from 'fs';
15
15
  import {sync as globSync} from 'glob';
16
16
  import HtmlWebPackPlugin from 'html-webpack-plugin';
17
+ import MiniCssExtractPlugin from 'mini-css-extract-plugin';
17
18
  import isEmpty from 'lodash/isEmpty.js';
18
19
  import {resolve as pathResolve} from 'path';
19
20
  import postcssBrowserReporter from 'postcss-browser-reporter';
@@ -25,6 +26,7 @@ import postcssPresetEnv from 'postcss-preset-env';
25
26
  import postcssUrl from 'postcss-url';
26
27
  import SVGSpriteMapPlugin from 'svg-spritemap-webpack-plugin';
27
28
  import TsconfigPathsPlugin from 'tsconfig-paths-webpack-plugin';
29
+ import {createRequire} from 'module';
28
30
  import {URL} from 'url';
29
31
  import {default as webpack} from 'webpack';
30
32
  import {BundleAnalyzerPlugin} from 'webpack-bundle-analyzer';
@@ -40,6 +42,7 @@ const {ProgressPlugin, ProvidePlugin} = webpack;
40
42
  const isProduction = process.env.NODE_ENV === 'production';
41
43
  const lexConfig = JSON.parse(process.env.LEX_CONFIG) || {};
42
44
  const dirName = new URL('.', import.meta.url).pathname;
45
+ const require = createRequire(import.meta.url);
43
46
 
44
47
  const {
45
48
  isStatic,
@@ -231,38 +234,13 @@ if(staticPaths.length) {
231
234
  if(existsSync(`${sourceFullPath}/${lexConfig.entryHTML}`)) {
232
235
  plugins.push(
233
236
  new HtmlWebPackPlugin({
234
- chunks: ['index'],
235
- filename: lexConfig.entryHTML || './index.html',
237
+ filename: 'index.html',
236
238
  minify: isProduction,
237
- scriptLoading: 'defer',
238
239
  showErrors: !isProduction,
239
240
  template: `${sourceFullPath}/${lexConfig.entryHTML}`,
240
241
  inject: true
241
242
  })
242
243
  );
243
-
244
- const missingAssets = [];
245
- const requiredAssets = ['favicon.ico', 'images/logo-icon-64.png', 'manifest.json'];
246
-
247
- requiredAssets.forEach(asset => {
248
- if (!existsSync(`${sourceFullPath}/${asset}`)) {
249
- missingAssets.push(asset);
250
- }
251
- });
252
-
253
- if (missingAssets.length > 0) {
254
- plugins.push(
255
- new CopyWebpackPlugin({
256
- patterns: missingAssets.map(asset => ({
257
- from: pathResolve(dirName, 'emptyModule.js'),
258
- to: `${outputFullPath}/${asset}`,
259
- transform() {
260
- return '';
261
- }
262
- }))
263
- })
264
- );
265
- }
266
244
  }
267
245
 
268
246
  let outputFilename = outputFile;
@@ -286,6 +264,7 @@ const swcLoaderPath = relativeNodePath('swc-loader', dirName);
286
264
  const cssLoaderPath = relativeNodePath('css-loader', dirName);
287
265
  const graphqlLoaderPath = relativeNodePath('graphql-tag/loader', dirName);
288
266
  const htmlLoaderPath = relativeNodePath('html-loader', dirName);
267
+ const miniCssExtractPluginPath = relativeNodePath('mini-css-extract-plugin', dirName);
289
268
  const postcssLoaderPath = relativeNodePath('postcss-loader', dirName);
290
269
  const sourceMapLoaderPath = relativeNodePath('source-map-loader', dirName);
291
270
  const styleLoaderPath = relativeNodePath('style-loader', dirName);
@@ -486,7 +465,13 @@ export default (webpackEnv, webpackOptions) => {
486
465
  {
487
466
  test: /\.css$/,
488
467
  use: [
489
- styleLoaderPath,
468
+ // In production, extract CSS to separate files for injection into HTML
469
+ // In development, inject CSS via style-loader for HMR
470
+ ...(isProduction && isWeb
471
+ ? [{
472
+ loader: require(miniCssExtractPluginPath).loader
473
+ }]
474
+ : [styleLoaderPath]),
490
475
  {
491
476
  loader: cssLoaderPath,
492
477
  options: {
@@ -684,7 +669,7 @@ export default (webpackEnv, webpackOptions) => {
684
669
  historyFallback: {
685
670
  disableDotRule: true,
686
671
  htmlAcceptHeaders: ['text/html', '*/*'],
687
- index: '/index.html', // Always point to the output HTML file (webpack always outputs index.html)
672
+ index: '/index.html',
688
673
  logger: console.log.bind(console),
689
674
  rewrites: [
690
675
  {
@@ -755,7 +740,7 @@ export default (webpackEnv, webpackOptions) => {
755
740
  open: process.env.WEBPACK_DEV_OPEN === 'true',
756
741
  port: finalPort,
757
742
  progress: 'minimal',
758
- static: outputFullPath ? [outputFullPath] : [], // Always include output path to serve generated HTML
743
+ static: outputFullPath ? [outputFullPath] : [],
759
744
  status: true
760
745
  })
761
746
  );
@@ -774,6 +759,18 @@ export default (webpackEnv, webpackOptions) => {
774
759
  };
775
760
  }
776
761
  } else {
762
+ // In production, extract CSS to separate files for injection into HTML
763
+ if(isProduction && isWeb) {
764
+ const MiniCssExtractPlugin = require(miniCssExtractPluginPath);
765
+ plugins.push(
766
+ new MiniCssExtractPlugin({
767
+ filename: outputHash ? 'css/[name].[contenthash].css' : 'css/[name].css',
768
+ chunkFilename: outputHash ? 'css/[name].[contenthash].chunk.css' : 'css/[name].chunk.css'
769
+ })
770
+ );
771
+ webpackConfig.optimization.moduleIds = 'deterministic';
772
+ }
773
+
777
774
  const siteLogo = `${sourceFullPath}/images/logo.png`;
778
775
 
779
776
  if(existsSync(siteLogo)) {
@@ -801,10 +798,6 @@ export default (webpackEnv, webpackOptions) => {
801
798
  new StaticSitePlugin()
802
799
  );
803
800
  }
804
-
805
- if(isProduction && isWeb) {
806
- webpackConfig.optimization.moduleIds = 'deterministic';
807
- }
808
801
  }
809
802
 
810
803
  if (process.env.LEX_CONFIG_DEBUG) {
@@ -853,19 +846,16 @@ export default (webpackEnv, webpackOptions) => {
853
846
 
854
847
  const mergedConfig = merge(webpackConfig, webpackConfigFiltered);
855
848
 
856
- // Filter out PostCSS plugin objects from webpack plugins array
857
- // PostCSS plugins have 'postcssPlugin' property and should only be in postcssOptions
858
849
  if (Array.isArray(mergedConfig.plugins)) {
859
850
  mergedConfig.plugins = mergedConfig.plugins.filter((plugin) => {
860
- // Keep webpack plugins (have 'apply' method or are instances with constructor)
861
851
  if (typeof plugin === 'function' || (plugin && typeof plugin.apply === 'function')) {
862
852
  return true;
863
853
  }
864
- // Filter out PostCSS plugin objects (have 'postcssPlugin' property)
854
+
865
855
  if (plugin && typeof plugin === 'object' && 'postcssPlugin' in plugin) {
866
856
  return false;
867
857
  }
868
- // Keep other valid webpack plugins
858
+
869
859
  return true;
870
860
  });
871
861
  }