@nlabs/lex 1.51.7 → 1.52.0

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.
@@ -6,9 +6,9 @@ import { execa } from 'execa';
6
6
  import { existsSync, readFileSync } from 'fs';
7
7
  import { sync as globSync } from 'glob';
8
8
  import { dirname, resolve as pathResolve } from 'path';
9
- import { LexConfig, getTypeScriptConfigPath } from '../../LexConfig.js';
9
+ import { LexConfig } from '../../LexConfig.js';
10
10
  import { checkLinkedModules, copyConfiguredFiles, createSpinner, handleWebpackProgress, removeFiles } from '../../utils/app.js';
11
- import { resolveWebpackPaths, getLexPackageJsonPath } from '../../utils/file.js';
11
+ import { resolveWebpackPaths, getLexPackageJsonPath, resolveBinaryPath } from '../../utils/file.js';
12
12
  import { log } from '../../utils/log.js';
13
13
  import { processTranslations } from '../../utils/translations.js';
14
14
  import { aiFunction } from '../ai/ai.js';
@@ -47,10 +47,11 @@ export const buildWithSWC = async (spinner, commandOptions, callback)=>{
47
47
  cwd: sourceDir,
48
48
  dot: false,
49
49
  nodir: true,
50
- nosort: true
50
+ nosort: true,
51
+ absolute: true
51
52
  };
52
- const tsFiles = globSync(`${sourceDir}/**/!(*.spec|*.test).ts*`, globOptions);
53
- const jsFiles = globSync(`${sourceDir}/**/!(*.spec|*.test).js`, globOptions);
53
+ const tsFiles = globSync(`**/!(*.spec|*.test).ts*`, globOptions);
54
+ const jsFiles = globSync(`**/!(*.spec|*.test).js`, globOptions);
54
55
  const sourceFiles = [
55
56
  ...tsFiles,
56
57
  ...jsFiles
@@ -61,7 +62,6 @@ export const buildWithSWC = async (spinner, commandOptions, callback)=>{
61
62
  for (const file of sourceFiles){
62
63
  const sourcePath = pathResolve(sourceDir, file);
63
64
  const outputPath = pathResolve(outputDir, file.replace(/\.(ts|tsx)$/, '.js'));
64
- // Ensure output directory exists
65
65
  const outputDirPath = dirname(outputPath);
66
66
  if (!existsSync(outputDirPath)) {
67
67
  const { mkdirSync } = await import('fs');
@@ -71,7 +71,6 @@ export const buildWithSWC = async (spinner, commandOptions, callback)=>{
71
71
  }
72
72
  const sourceCode = readFileSync(sourcePath, 'utf8');
73
73
  const isTSX = file.endsWith('.tsx');
74
- // Merge SWC config with command-specific overrides
75
74
  const swcOptions = {
76
75
  filename: file,
77
76
  ...swcConfig,
@@ -81,7 +80,8 @@ export const buildWithSWC = async (spinner, commandOptions, callback)=>{
81
80
  syntax: 'typescript',
82
81
  tsx: isTSX,
83
82
  decorators: swcConfig?.jsc?.parser?.decorators ?? true,
84
- dynamicImport: swcConfig?.jsc?.parser?.dynamicImport ?? true
83
+ dynamicImport: swcConfig?.jsc?.parser?.dynamicImport ?? true,
84
+ comments: false // Remove comments during transformation
85
85
  },
86
86
  target: swcConfig?.jsc?.target ?? 'es2020',
87
87
  transform: isTSX ? {
@@ -90,12 +90,15 @@ export const buildWithSWC = async (spinner, commandOptions, callback)=>{
90
90
  runtime: 'automatic',
91
91
  ...swcConfig?.jsc?.transform?.react
92
92
  }
93
- } : swcConfig?.jsc?.transform
93
+ } : swcConfig?.jsc?.transform,
94
+ preserveAllComments: false
94
95
  },
95
96
  module: {
96
97
  ...swcConfig?.module,
97
98
  type: format === 'cjs' ? 'commonjs' : swcConfig?.module?.type || 'es6'
98
- }
99
+ },
100
+ minify: false,
101
+ sourceMaps: swcConfig?.sourceMaps || 'inline'
99
102
  };
100
103
  const result = await transform(sourceCode, swcOptions);
101
104
  const { writeFileSync } = await import('fs');
@@ -106,9 +109,20 @@ export const buildWithSWC = async (spinner, commandOptions, callback)=>{
106
109
  callback(0);
107
110
  return 0;
108
111
  } catch (error) {
112
+ log(`\n${commandOptions.cliName || 'Lex'} Error: SWC build failed`, 'error', quiet);
113
+ log(`\nError: ${error.message}`, 'error', quiet);
114
+ if (error instanceof Error) {
115
+ if (error.stack) {
116
+ log(`\nStack Trace:\n${error.stack}`, 'error', quiet);
117
+ }
118
+ // Try to extract file information if available
119
+ if ('filename' in error || 'file' in error) {
120
+ log(`\nFile: ${error.filename || error.file}`, 'error', quiet);
121
+ }
122
+ }
109
123
  spinner.fail('Build failed with SWC');
110
124
  if (!quiet) {
111
- console.error(error);
125
+ console.error('\nFull Error Details:', error);
112
126
  }
113
127
  callback(1);
114
128
  return 1;
@@ -253,7 +267,14 @@ export const buildWithWebpack = async (spinner, cmd, callback)=>{
253
267
  callback(0);
254
268
  return 0;
255
269
  } catch (error) {
256
- log(`\n${cliName} Error: ${error.message}`, 'error', quiet);
270
+ log(`\n${cliName} Error: Webpack build failed`, 'error', quiet);
271
+ log(`\nError: ${error.message}`, 'error', quiet);
272
+ if (error instanceof Error) {
273
+ if (error.stack) {
274
+ log(`\nStack Trace:\n${error.stack}`, 'error', quiet);
275
+ }
276
+ }
277
+ log(`\nWebpack Options: ${webpackOptions.slice(0, 5).join(' ')}...`, 'error', quiet);
257
278
  spinner.fail('Build failed.');
258
279
  if (cmd.assist) {
259
280
  spinner.start('AI is analyzing the webpack error...');
@@ -272,6 +293,9 @@ export const buildWithWebpack = async (spinner, cmd, callback)=>{
272
293
  }
273
294
  }
274
295
  }
296
+ if (!quiet) {
297
+ console.error('\nFull Error Details:', error);
298
+ }
275
299
  callback(1);
276
300
  return 1;
277
301
  }
@@ -324,14 +348,6 @@ export const build = async (cmd, callback = ()=>({}))=>{
324
348
  if (remove) {
325
349
  await removeFiles(outputFullPath || '');
326
350
  }
327
- if (useTypescript) {
328
- const compileConfigPath = getTypeScriptConfigPath('tsconfig.build.json');
329
- if (existsSync(compileConfigPath)) {
330
- log('Using tsconfig.build.json for build...', 'info', quiet);
331
- } else {
332
- LexConfig.checkCompileTypescriptConfig();
333
- }
334
- }
335
351
  let buildResult = 0;
336
352
  if (bundler === 'swc') {
337
353
  buildResult = await buildWithSWC(spinner, cmd, (status)=>{
@@ -377,6 +393,80 @@ What are the key optimization opportunities for this build configuration? Consid
377
393
  }
378
394
  if (buildResult === 0) {
379
395
  try {
396
+ if (useTypescript && bundler === 'swc') {
397
+ const typescriptPath = resolveBinaryPath('tsc', 'typescript');
398
+ if (typescriptPath) {
399
+ spinner.start('Generating TypeScript declarations...');
400
+ try {
401
+ const sourceFullPath = LexConfig.config.sourceFullPath || pathResolve(process.cwd(), './src');
402
+ const outputFullPath = LexConfig.config.outputFullPath || pathResolve(process.cwd(), './lib');
403
+ const globOptions = {
404
+ cwd: sourceFullPath,
405
+ dot: false,
406
+ nodir: true,
407
+ absolute: true
408
+ };
409
+ const tsFiles = globSync(`**/!(*.spec|*.test|*.integration).ts`, globOptions);
410
+ const tsxFiles = globSync(`**/!(*.spec|*.test|*.integration).tsx`, globOptions);
411
+ const allSourceFiles = [
412
+ ...tsFiles,
413
+ ...tsxFiles
414
+ ];
415
+ const typescriptOptions = [
416
+ ...LexConfig.getTypeScriptDeclarationFlags(),
417
+ ...allSourceFiles
418
+ ];
419
+ const result = await execa(typescriptPath, typescriptOptions, {
420
+ encoding: 'utf8',
421
+ cwd: process.cwd(),
422
+ reject: false,
423
+ all: true // Capture both stdout and stderr
424
+ });
425
+ if (result.exitCode !== 0) {
426
+ // TypeScript may have errors but still generate some declarations
427
+ // Log warnings but don't fail if declarations were generated
428
+ const hasDeclarations = result.all?.includes('Writing') || result.all?.includes('Declaration') || false;
429
+ const errorOutput = result.stderr || result.stdout || result.all || 'Unknown error';
430
+ if (!hasDeclarations) {
431
+ // Show detailed error information
432
+ log(`\n${cliName} Error: TypeScript declaration generation failed`, 'error', quiet);
433
+ log(`\nExit Code: ${result.exitCode}`, 'error', quiet);
434
+ log(`\nTypeScript Command: ${typescriptPath} ${typescriptOptions.slice(0, 10).join(' ')}...`, 'error', quiet);
435
+ log(`\nError Output:\n${errorOutput}`, 'error', quiet);
436
+ // Try to extract and highlight specific errors
437
+ const errorLines = errorOutput.split('\n').filter((line)=>line.includes('error TS') || line.includes('Error:') || line.trim().startsWith('src/') || line.trim().startsWith('TS'));
438
+ if (errorLines.length > 0) {
439
+ log(`\nKey Errors:`, 'error', quiet);
440
+ errorLines.slice(0, 10).forEach((line)=>{
441
+ log(` ${line}`, 'error', quiet);
442
+ });
443
+ if (errorLines.length > 10) {
444
+ log(` ... and ${errorLines.length - 10} more errors`, 'error', quiet);
445
+ }
446
+ }
447
+ spinner.fail('TypeScript declaration generation had errors (continuing anyway).');
448
+ } else {
449
+ log(`\n${cliName} Warning: TypeScript declaration generation completed with errors`, 'warn', quiet);
450
+ if (!quiet && errorOutput) {
451
+ log(`\nWarnings:\n${errorOutput}`, 'warn', quiet);
452
+ }
453
+ spinner.succeed('TypeScript declarations generated (with warnings).');
454
+ }
455
+ } else {
456
+ spinner.succeed('TypeScript declarations generated!');
457
+ }
458
+ } catch (error) {
459
+ // If execa throws (shouldn't with reject: false), log and continue
460
+ log(`\n${cliName} Error: TypeScript declaration generation exception`, 'error', quiet);
461
+ log(`\nError: ${error.message}`, 'error', quiet);
462
+ if (error instanceof Error && error.stack) {
463
+ log(`\nStack:\n${error.stack}`, 'error', quiet);
464
+ }
465
+ spinner.fail('TypeScript declaration generation had issues (continuing anyway).');
466
+ // Don't fail the build if declarations fail
467
+ }
468
+ }
469
+ }
380
470
  await copyConfiguredFiles(spinner, LexConfig.config, quiet);
381
471
  } catch (copyError) {
382
472
  log(`\n${cliName} Error: Failed to copy configured files: ${copyError.message}`, 'error', quiet);
@@ -389,4 +479,4 @@ What are the key optimization opportunities for this build configuration? Consid
389
479
  };
390
480
  export default build;
391
481
 
392
- //# 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 {dirname, resolve as pathResolve} from 'path';\n\nimport {LexConfig, getTypeScriptConfigPath} from '../../LexConfig.js';\nimport {checkLinkedModules, copyConfiguredFiles, createSpinner, createProgressBar, handleWebpackProgress, removeFiles} from '../../utils/app.js';\nimport {getDirName, relativeNodePath, resolveWebpackPaths, getLexPackageJsonPath} 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\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; // <-- add entry\n  readonly format?: string;\n  readonly outputPath?: string; // <-- already present\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\n// Removed buildWithEsBuild function - using SWC instead\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    cwd: sourceDir,\n    dot: false,\n    nodir: true,\n    nosort: true\n  };\n  const tsFiles: string[] = globSync(`${sourceDir}/**/!(*.spec|*.test).ts*`, globOptions);\n  const jsFiles: string[] = globSync(`${sourceDir}/**/!(*.spec|*.test).js`, globOptions);\n  const sourceFiles: string[] = [...tsFiles, ...jsFiles];\n\n  const outputDir: string = outputPath || outputFullPath || '';\n\n  try {\n    spinner.start('Building with SWC...');\n\n    for(const file of sourceFiles) {\n      const sourcePath = pathResolve(sourceDir, file);\n      const outputPath = pathResolve(outputDir, file.replace(/\\.(ts|tsx)$/, '.js'));\n\n      // Ensure output directory exists\n      const outputDirPath = dirname(outputPath);\n      if(!existsSync(outputDirPath)) {\n        const {mkdirSync} = await import('fs');\n        mkdirSync(outputDirPath, {recursive: true});\n      }\n\n      const sourceCode = readFileSync(sourcePath, 'utf8');\n\n      const isTSX = file.endsWith('.tsx');\n\n      // Merge SWC config with command-specific overrides\n      const swcOptions = {\n        filename: file,\n        ...swcConfig,\n        jsc: {\n          ...swcConfig?.jsc,\n          parser: {\n            syntax: 'typescript' as const,\n            tsx: isTSX,\n            decorators: swcConfig?.jsc?.parser?.decorators ?? true,\n            dynamicImport: swcConfig?.jsc?.parser?.dynamicImport ?? true\n          },\n          target: swcConfig?.jsc?.target ?? 'es2020',\n          transform: isTSX ? {\n            ...swcConfig?.jsc?.transform,\n            react: {\n              runtime: 'automatic' as const,\n              ...swcConfig?.jsc?.transform?.react\n            }\n          } : swcConfig?.jsc?.transform\n        },\n        module: {\n          ...swcConfig?.module,\n          type: format === 'cjs' ? 'commonjs' as const : (swcConfig?.module?.type as 'es6' || 'es6')\n        }\n      };\n\n      const result = await transform(sourceCode, swcOptions);\n\n      const {writeFileSync} = await import('fs');\n      writeFileSync(outputPath, result.code);\n    }\n\n    spinner.succeed('Build completed with SWC');\n    displayBuildStatus('SWC', outputDir, quiet);\n    callback(0);\n    return 0;\n  } catch(error) {\n    spinner.fail('Build failed with SWC');\n    if(!quiet) {\n      console.error(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  // Pass entry directly as CLI flag\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    // Make sure we're passing an array of strings to execa\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: ${error.message}`, '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    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 in test mode, exit early\n  if(test) {\n    log('Test mode: Build environment loaded, exiting', 'info', quiet);\n    callback(0);\n    return 0;\n  }\n\n  // Process translations if flag is enabled (before building)\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  if(useTypescript) {\n    const compileConfigPath = getTypeScriptConfigPath('tsconfig.build.json');\n    if(existsSync(compileConfigPath)) {\n      log('Using tsconfig.build.json for build...', 'info', quiet);\n    } else {\n      LexConfig.checkCompileTypescriptConfig();\n    }\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      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","resolve","pathResolve","LexConfig","getTypeScriptConfigPath","checkLinkedModules","copyConfiguredFiles","createSpinner","handleWebpackProgress","removeFiles","resolveWebpackPaths","getLexPackageJsonPath","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","dot","nodir","nosort","tsFiles","jsFiles","sourceFiles","outputDir","start","file","replace","outputDirPath","mkdirSync","recursive","sourceCode","isTSX","endsWith","swcOptions","filename","jsc","parser","syntax","tsx","decorators","dynamicImport","target","react","runtime","module","type","result","writeFileSync","code","succeed","error","fail","buildWithWebpack","cmd","analyze","configName","defineProcessEnvNodeEnv","devtool","disableInterpret","entry","env","failOnWarnings","json","merge","mode","name","nodeEnv","noDevtool","noStats","noTarget","noWatch","noWatchOptionsStdin","watchOptionsStdin","entryValue","Array","isArray","webpackConfig","isRelativeConfig","substr","projectConfigPath","projectConfigPathTs","hasProjectConfig","resolvedConfig","lexPackagePath","lexPackageDir","lexWebpackConfig","webpackOptions","push","toString","webpackPath","executablePath","finalWebpackOptions","JSON","stringify","childProcess","encoding","stdio","buildCompleted","buildStats","stdout","on","data","output","includes","moduleMatch","match","assetMatch","sizeMatch","parseInt","stderr","message","assist","prompt","task","context","aiError","build","remove","test","translations","variables","parseConfig","variablesObj","NODE_ENV","parse","translationError","compileConfigPath","checkCompileTypescriptConfig","buildResult","status","entryPoints","webpack","copyError"],"mappings":"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"}
482
+ //# 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 {dirname, resolve as pathResolve} 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\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; // <-- add entry\n  readonly format?: string;\n  readonly outputPath?: string; // <-- already present\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\n// Removed buildWithEsBuild function - using SWC instead\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    cwd: sourceDir,\n    dot: false,\n    nodir: true,\n    nosort: true,\n    absolute: 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 || outputFullPath || '';\n\n  try {\n    spinner.start('Building with SWC...');\n\n    for(const file of sourceFiles) {\n      const sourcePath = pathResolve(sourceDir, file);\n      const outputPath = pathResolve(outputDir, file.replace(/\\.(ts|tsx)$/, '.js'));\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 isTSX = file.endsWith('.tsx');\n      const swcOptions = {\n        filename: file,\n        ...swcConfig,\n        jsc: {\n          ...swcConfig?.jsc,\n          parser: {\n            syntax: 'typescript' as const,\n            tsx: isTSX,\n            decorators: swcConfig?.jsc?.parser?.decorators ?? true,\n            dynamicImport: swcConfig?.jsc?.parser?.dynamicImport ?? true,\n            comments: false // Remove comments during transformation\n          },\n          target: swcConfig?.jsc?.target ?? 'es2020',\n          transform: isTSX ? {\n            ...swcConfig?.jsc?.transform,\n            react: {\n              runtime: 'automatic' as const,\n              ...swcConfig?.jsc?.transform?.react\n            }\n          } : swcConfig?.jsc?.transform,\n          preserveAllComments: false\n        },\n        module: {\n          ...swcConfig?.module,\n          type: format === 'cjs' ? 'commonjs' as const : (swcConfig?.module?.type as 'es6' || 'es6')\n        },\n        minify: false,\n        sourceMaps: swcConfig?.sourceMaps || 'inline'\n      };\n\n      const result = await transform(sourceCode, swcOptions);\n\n      const {writeFileSync} = await import('fs');\n      writeFileSync(outputPath, result.code);\n    }\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      // Try to extract file information if available\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  // Pass entry directly as CLI flag\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    // Make sure we're passing an array of strings to execa\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 in test mode, exit early\n  if(test) {\n    log('Test mode: Build environment loaded, exiting', 'info', quiet);\n    callback(0);\n    return 0;\n  }\n\n  // Process translations if flag is enabled (before building)\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, // Don't throw on errors, we'll check exit code\n              all: true // Capture both stdout and stderr\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                // Show detailed error information\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                // Try to extract and highlight specific errors\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            // If execa throws (shouldn't with reject: false), log and continue\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            // Don't fail the build if declarations fail\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","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","dot","nodir","nosort","absolute","tsFiles","jsFiles","sourceFiles","outputDir","start","file","replace","outputDirPath","mkdirSync","recursive","sourceCode","isTSX","endsWith","swcOptions","filename","jsc","parser","syntax","tsx","decorators","dynamicImport","comments","target","react","runtime","preserveAllComments","module","type","minify","sourceMaps","result","writeFileSync","code","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","watchOptionsStdin","entryValue","Array","isArray","webpackConfig","isRelativeConfig","substr","projectConfigPath","projectConfigPathTs","hasProjectConfig","resolvedConfig","lexPackagePath","lexPackageDir","lexWebpackConfig","webpackOptions","push","toString","webpackPath","executablePath","finalWebpackOptions","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","all","exitCode","hasDeclarations","errorOutput","errorLines","split","filter","line","trim","startsWith","length","forEach","copyError"],"mappings":"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"}
@@ -46,4 +46,4 @@ export const clean = async (cmd, callback = (_status)=>({}))=>{
46
46
  }
47
47
  };
48
48
 
49
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21tYW5kcy9jbGVhbi9jbGVhbi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtMZXhDb25maWd9IGZyb20gJy4uLy4uL0xleENvbmZpZy5qcyc7XG5pbXBvcnQge2NyZWF0ZVNwaW5uZXIsIHJlbW92ZUZpbGVzLCByZW1vdmVNb2R1bGVzfSBmcm9tICcuLi8uLi91dGlscy9hcHAuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uLy4uL3V0aWxzL2xvZy5qcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2xlYW5PcHRpb25zIHtcbiAgcmVhZG9ubHkgY2xpTmFtZT86IHN0cmluZztcbiAgcmVhZG9ubHkgcXVpZXQ/OiBib29sZWFuO1xuICByZWFkb25seSBzbmFwc2hvdHM/OiBib29sZWFuO1xufVxuXG5leHBvcnQgdHlwZSBDbGVhbkNhbGxiYWNrID0gKHN0YXR1czogbnVtYmVyKSA9PiB2b2lkO1xuXG5leHBvcnQgY29uc3QgY2xlYW4gPSBhc3luYyAoY21kOiBDbGVhbk9wdGlvbnMsIGNhbGxiYWNrOiBDbGVhbkNhbGxiYWNrID0gKF9zdGF0dXM6IG51bWJlcikgPT4gKHt9KSk6IFByb21pc2U8bnVtYmVyPiA9PiB7XG4gIGNvbnN0IHtjbGlOYW1lID0gJ0xleCcsIHF1aWV0LCBzbmFwc2hvdHN9ID0gY21kO1xuXG4gIC8vIFNwaW5uZXJcbiAgY29uc3Qgc3Bpbm5lciA9IGNyZWF0ZVNwaW5uZXIocXVpZXQpO1xuXG4gIC8vIERpc3BsYXkgc3RhdHVzXG4gIGxvZyhgJHtjbGlOYW1lfSBjbGVhbmluZyBkaXJlY3RvcnkuLi5gLCAnaW5mbycsIHF1aWV0KTtcblxuICAvLyBHZXQgY3VzdG9tIGNvbmZpZ3VyYXRpb25cbiAgYXdhaXQgTGV4Q29uZmlnLnBhcnNlQ29uZmlnKGNtZCk7XG5cbiAgLy8gU3RhcnQgY2xlYW5pbmcgc3Bpbm5lclxuICBpZihzcGlubmVyKSB7XG4gICAgc3Bpbm5lci5zdGFydCgnQ2xlYW5pbmcgZmlsZXMuLi4nKTtcbiAgfVxuXG4gIHRyeSB7XG4gICAgLy8gUmVtb3ZlIG5vZGVfbW9kdWxlc1xuICAgIGF3YWl0IHJlbW92ZU1vZHVsZXMoKTtcblxuICAgIC8vIFJlbW92ZSB0ZXN0IGNvdmVyYWdlIHJlcG9ydHNcbiAgICBhd2FpdCByZW1vdmVGaWxlcygnLi9jb3ZlcmFnZScsIHRydWUpO1xuXG4gICAgLy8gUmVtb3ZlIG5wbSBsb2dzXG4gICAgYXdhaXQgcmVtb3ZlRmlsZXMoJy4vbnBtLWRlYnVnLmxvZycsIHRydWUpO1xuXG4gICAgaWYoc25hcHNob3RzKSB7XG4gICAgICBhd2FpdCByZW1vdmVGaWxlcygnLi8qKi9fX3NuYXBzaG90c19fJywgdHJ1ZSk7XG4gICAgfVxuXG4gICAgLy8gU3RvcCBzcGlubmVyXG4gICAgaWYoc3Bpbm5lcikge1xuICAgICAgc3Bpbm5lci5zdWNjZWVkKCdTdWNjZXNzZnVsbHkgY2xlYW5lZCEnKTtcbiAgICB9XG5cbiAgICAvLyBTdG9wIHByb2Nlc3NcbiAgICBjYWxsYmFjaygwKTtcbiAgICByZXR1cm4gMDtcbiAgfSBjYXRjaChlcnJvcikge1xuICAgIC8vIERpc3BsYXkgZXJyb3IgbWVzc2FnZVxuICAgIGxvZyhgXFxuJHtjbGlOYW1lfSBFcnJvcjogJHtlcnJvci5tZXNzYWdlfWAsICdlcnJvcicsIHF1aWV0KTtcblxuICAgIC8vIFN0b3Agc3Bpbm5lclxuICAgIGlmKHNwaW5uZXIpIHtcbiAgICAgIHNwaW5uZXIuZmFpbCgnRmFpbGVkIHRvIGNsZWFuIHByb2plY3QuJyk7XG4gICAgfVxuXG4gICAgLy8gS2lsbCBwcm9jZXNzXG4gICAgY2FsbGJhY2soMSk7XG4gICAgcmV0dXJuIDE7XG4gIH1cbn07Il0sIm5hbWVzIjpbIkxleENvbmZpZyIsImNyZWF0ZVNwaW5uZXIiLCJyZW1vdmVGaWxlcyIsInJlbW92ZU1vZHVsZXMiLCJsb2ciLCJjbGVhbiIsImNtZCIsImNhbGxiYWNrIiwiX3N0YXR1cyIsImNsaU5hbWUiLCJxdWlldCIsInNuYXBzaG90cyIsInNwaW5uZXIiLCJwYXJzZUNvbmZpZyIsInN0YXJ0Iiwic3VjY2VlZCIsImVycm9yIiwibWVzc2FnZSIsImZhaWwiXSwibWFwcGluZ3MiOiJBQUFBOzs7Q0FHQyxHQUNELFNBQVFBLFNBQVMsUUFBTyxxQkFBcUI7QUFDN0MsU0FBUUMsYUFBYSxFQUFFQyxXQUFXLEVBQUVDLGFBQWEsUUFBTyxxQkFBcUI7QUFDN0UsU0FBUUMsR0FBRyxRQUFPLHFCQUFxQjtBQVV2QyxPQUFPLE1BQU1DLFFBQVEsT0FBT0MsS0FBbUJDLFdBQTBCLENBQUNDLFVBQXFCLENBQUEsQ0FBQyxDQUFBLENBQUU7SUFDaEcsTUFBTSxFQUFDQyxVQUFVLEtBQUssRUFBRUMsS0FBSyxFQUFFQyxTQUFTLEVBQUMsR0FBR0w7SUFFNUMsVUFBVTtJQUNWLE1BQU1NLFVBQVVYLGNBQWNTO0lBRTlCLGlCQUFpQjtJQUNqQk4sSUFBSSxHQUFHSyxRQUFRLHNCQUFzQixDQUFDLEVBQUUsUUFBUUM7SUFFaEQsMkJBQTJCO0lBQzNCLE1BQU1WLFVBQVVhLFdBQVcsQ0FBQ1A7SUFFNUIseUJBQXlCO0lBQ3pCLElBQUdNLFNBQVM7UUFDVkEsUUFBUUUsS0FBSyxDQUFDO0lBQ2hCO0lBRUEsSUFBSTtRQUNGLHNCQUFzQjtRQUN0QixNQUFNWDtRQUVOLCtCQUErQjtRQUMvQixNQUFNRCxZQUFZLGNBQWM7UUFFaEMsa0JBQWtCO1FBQ2xCLE1BQU1BLFlBQVksbUJBQW1CO1FBRXJDLElBQUdTLFdBQVc7WUFDWixNQUFNVCxZQUFZLHNCQUFzQjtRQUMxQztRQUVBLGVBQWU7UUFDZixJQUFHVSxTQUFTO1lBQ1ZBLFFBQVFHLE9BQU8sQ0FBQztRQUNsQjtRQUVBLGVBQWU7UUFDZlIsU0FBUztRQUNULE9BQU87SUFDVCxFQUFFLE9BQU1TLE9BQU87UUFDYix3QkFBd0I7UUFDeEJaLElBQUksQ0FBQyxFQUFFLEVBQUVLLFFBQVEsUUFBUSxFQUFFTyxNQUFNQyxPQUFPLEVBQUUsRUFBRSxTQUFTUDtRQUVyRCxlQUFlO1FBQ2YsSUFBR0UsU0FBUztZQUNWQSxRQUFRTSxJQUFJLENBQUM7UUFDZjtRQUVBLGVBQWU7UUFDZlgsU0FBUztRQUNULE9BQU87SUFDVDtBQUNGLEVBQUUifQ==
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21tYW5kcy9jbGVhbi9jbGVhbi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtMZXhDb25maWd9IGZyb20gJy4uLy4uL0xleENvbmZpZy5qcyc7XG5pbXBvcnQge2NyZWF0ZVNwaW5uZXIsIHJlbW92ZUZpbGVzLCByZW1vdmVNb2R1bGVzfSBmcm9tICcuLi8uLi91dGlscy9hcHAuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uLy4uL3V0aWxzL2xvZy5qcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2xlYW5PcHRpb25zIHtcbiAgcmVhZG9ubHkgY2xpTmFtZT86IHN0cmluZztcbiAgcmVhZG9ubHkgcXVpZXQ/OiBib29sZWFuO1xuICByZWFkb25seSBzbmFwc2hvdHM/OiBib29sZWFuO1xufVxuXG5leHBvcnQgdHlwZSBDbGVhbkNhbGxiYWNrID0gKHN0YXR1czogbnVtYmVyKT0+IHZvaWQ7XG5cbmV4cG9ydCBjb25zdCBjbGVhbiA9IGFzeW5jIChcbiAgY21kOiBDbGVhbk9wdGlvbnMsXG4gIGNhbGxiYWNrOiBDbGVhbkNhbGxiYWNrID0gKF9zdGF0dXM6IG51bWJlcikgPT4gKHt9KVxuKTogUHJvbWlzZTxudW1iZXI+ID0+IHtcbiAgY29uc3Qge2NsaU5hbWUgPSAnTGV4JywgcXVpZXQsIHNuYXBzaG90c30gPSBjbWQ7XG5cbiAgLy8gU3Bpbm5lclxuICBjb25zdCBzcGlubmVyID0gY3JlYXRlU3Bpbm5lcihxdWlldCk7XG5cbiAgLy8gRGlzcGxheSBzdGF0dXNcbiAgbG9nKGAke2NsaU5hbWV9IGNsZWFuaW5nIGRpcmVjdG9yeS4uLmAsICdpbmZvJywgcXVpZXQpO1xuXG4gIC8vIEdldCBjdXN0b20gY29uZmlndXJhdGlvblxuICBhd2FpdCBMZXhDb25maWcucGFyc2VDb25maWcoY21kKTtcblxuICAvLyBTdGFydCBjbGVhbmluZyBzcGlubmVyXG4gIGlmKHNwaW5uZXIpIHtcbiAgICBzcGlubmVyLnN0YXJ0KCdDbGVhbmluZyBmaWxlcy4uLicpO1xuICB9XG5cbiAgdHJ5IHtcbiAgICAvLyBSZW1vdmUgbm9kZV9tb2R1bGVzXG4gICAgYXdhaXQgcmVtb3ZlTW9kdWxlcygpO1xuXG4gICAgLy8gUmVtb3ZlIHRlc3QgY292ZXJhZ2UgcmVwb3J0c1xuICAgIGF3YWl0IHJlbW92ZUZpbGVzKCcuL2NvdmVyYWdlJywgdHJ1ZSk7XG5cbiAgICAvLyBSZW1vdmUgbnBtIGxvZ3NcbiAgICBhd2FpdCByZW1vdmVGaWxlcygnLi9ucG0tZGVidWcubG9nJywgdHJ1ZSk7XG5cbiAgICBpZihzbmFwc2hvdHMpIHtcbiAgICAgIGF3YWl0IHJlbW92ZUZpbGVzKCcuLyoqL19fc25hcHNob3RzX18nLCB0cnVlKTtcbiAgICB9XG5cbiAgICAvLyBTdG9wIHNwaW5uZXJcbiAgICBpZihzcGlubmVyKSB7XG4gICAgICBzcGlubmVyLnN1Y2NlZWQoJ1N1Y2Nlc3NmdWxseSBjbGVhbmVkIScpO1xuICAgIH1cblxuICAgIC8vIFN0b3AgcHJvY2Vzc1xuICAgIGNhbGxiYWNrKDApO1xuICAgIHJldHVybiAwO1xuICB9IGNhdGNoKGVycm9yKSB7XG4gICAgLy8gRGlzcGxheSBlcnJvciBtZXNzYWdlXG4gICAgbG9nKGBcXG4ke2NsaU5hbWV9IEVycm9yOiAke2Vycm9yLm1lc3NhZ2V9YCwgJ2Vycm9yJywgcXVpZXQpO1xuXG4gICAgLy8gU3RvcCBzcGlubmVyXG4gICAgaWYoc3Bpbm5lcikge1xuICAgICAgc3Bpbm5lci5mYWlsKCdGYWlsZWQgdG8gY2xlYW4gcHJvamVjdC4nKTtcbiAgICB9XG5cbiAgICAvLyBLaWxsIHByb2Nlc3NcbiAgICBjYWxsYmFjaygxKTtcbiAgICByZXR1cm4gMTtcbiAgfVxufTsiXSwibmFtZXMiOlsiTGV4Q29uZmlnIiwiY3JlYXRlU3Bpbm5lciIsInJlbW92ZUZpbGVzIiwicmVtb3ZlTW9kdWxlcyIsImxvZyIsImNsZWFuIiwiY21kIiwiY2FsbGJhY2siLCJfc3RhdHVzIiwiY2xpTmFtZSIsInF1aWV0Iiwic25hcHNob3RzIiwic3Bpbm5lciIsInBhcnNlQ29uZmlnIiwic3RhcnQiLCJzdWNjZWVkIiwiZXJyb3IiLCJtZXNzYWdlIiwiZmFpbCJdLCJtYXBwaW5ncyI6IkFBQUE7OztDQUdDLEdBQ0QsU0FBUUEsU0FBUyxRQUFPLHFCQUFxQjtBQUM3QyxTQUFRQyxhQUFhLEVBQUVDLFdBQVcsRUFBRUMsYUFBYSxRQUFPLHFCQUFxQjtBQUM3RSxTQUFRQyxHQUFHLFFBQU8scUJBQXFCO0FBVXZDLE9BQU8sTUFBTUMsUUFBUSxPQUNuQkMsS0FDQUMsV0FBMEIsQ0FBQ0MsVUFBcUIsQ0FBQSxDQUFDLENBQUEsQ0FBRTtJQUVuRCxNQUFNLEVBQUNDLFVBQVUsS0FBSyxFQUFFQyxLQUFLLEVBQUVDLFNBQVMsRUFBQyxHQUFHTDtJQUU1QyxVQUFVO0lBQ1YsTUFBTU0sVUFBVVgsY0FBY1M7SUFFOUIsaUJBQWlCO0lBQ2pCTixJQUFJLEdBQUdLLFFBQVEsc0JBQXNCLENBQUMsRUFBRSxRQUFRQztJQUVoRCwyQkFBMkI7SUFDM0IsTUFBTVYsVUFBVWEsV0FBVyxDQUFDUDtJQUU1Qix5QkFBeUI7SUFDekIsSUFBR00sU0FBUztRQUNWQSxRQUFRRSxLQUFLLENBQUM7SUFDaEI7SUFFQSxJQUFJO1FBQ0Ysc0JBQXNCO1FBQ3RCLE1BQU1YO1FBRU4sK0JBQStCO1FBQy9CLE1BQU1ELFlBQVksY0FBYztRQUVoQyxrQkFBa0I7UUFDbEIsTUFBTUEsWUFBWSxtQkFBbUI7UUFFckMsSUFBR1MsV0FBVztZQUNaLE1BQU1ULFlBQVksc0JBQXNCO1FBQzFDO1FBRUEsZUFBZTtRQUNmLElBQUdVLFNBQVM7WUFDVkEsUUFBUUcsT0FBTyxDQUFDO1FBQ2xCO1FBRUEsZUFBZTtRQUNmUixTQUFTO1FBQ1QsT0FBTztJQUNULEVBQUUsT0FBTVMsT0FBTztRQUNiLHdCQUF3QjtRQUN4QlosSUFBSSxDQUFDLEVBQUUsRUFBRUssUUFBUSxRQUFRLEVBQUVPLE1BQU1DLE9BQU8sRUFBRSxFQUFFLFNBQVNQO1FBRXJELGVBQWU7UUFDZixJQUFHRSxTQUFTO1lBQ1ZBLFFBQVFNLElBQUksQ0FBQztRQUNmO1FBRUEsZUFBZTtRQUNmWCxTQUFTO1FBQ1QsT0FBTztJQUNUO0FBQ0YsRUFBRSJ9