@nlabs/lex 1.55.2 → 1.56.1

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.
@@ -2,7 +2,6 @@ const config = {
2
2
  addons: [
3
3
  '@storybook/addon-docs',
4
4
  '@storybook/addon-links',
5
- '@storybook/addon-postcss',
6
5
  {
7
6
  name: '@storybook/addon-styling-webpack',
8
7
  options: {
@@ -56,4 +55,4 @@ const config = {
56
55
  }
57
56
  };
58
57
 
59
- export default config;
58
+ export default config;
@@ -33,7 +33,7 @@ export interface LexConfigType {
33
33
  dev?: DevConfig;
34
34
  entryHTML?: string;
35
35
  entryJs?: string;
36
- env?: object;
36
+ env?: object | null;
37
37
  eslint?: ESLintConfig;
38
38
  gitUrl?: string;
39
39
  vitest?: VitestConfig;
@@ -62,8 +62,8 @@ export declare class LexConfig {
62
62
  static set useTypescript(value: boolean);
63
63
  static getLexDir(): string;
64
64
  static updateConfig(updatedConfig: LexConfigType): LexConfigType;
65
- static addConfigParams(cmd: any, params: LexConfigType): void;
66
- static parseConfig(cmd: any, isRoot?: boolean): Promise<void>;
65
+ static addConfigParams(cmd: Record<string, any>, params: LexConfigType): void;
66
+ static parseConfig(cmd: Record<string, any>, isRoot?: boolean): Promise<void>;
67
67
  static checkTypescriptConfig(): void;
68
68
  static getTypeScriptDeclarationFlags(): string[];
69
69
  static checkLintTypescriptConfig(): void;
package/lib/LexConfig.js CHANGED
@@ -175,7 +175,7 @@ export class LexConfig {
175
175
  LexConfig.config.useTypescript = value;
176
176
  const { entryJs, sourceFullPath, targetEnvironment } = LexConfig.config;
177
177
  if (entryJs === 'index.js' && value) {
178
- const indexPath = pathResolve(cwd, sourceFullPath, 'index.tsx');
178
+ const indexPath = pathResolve(cwd, sourceFullPath || cwd, 'index.tsx');
179
179
  const hasIndexTsx = existsSync(indexPath);
180
180
  if (hasIndexTsx) {
181
181
  LexConfig.config.entryJs = 'index.tsx';
@@ -183,6 +183,12 @@ export class LexConfig {
183
183
  LexConfig.config.entryJs = 'index.ts';
184
184
  }
185
185
  }
186
+ LexConfig.config.swc = LexConfig.config.swc || {
187
+ ...defaultConfigValues.swc
188
+ };
189
+ LexConfig.config.swc.jsc = LexConfig.config.swc.jsc || {
190
+ ...defaultConfigValues.swc.jsc
191
+ };
186
192
  LexConfig.config.swc.jsc.parser = {
187
193
  syntax: 'typescript',
188
194
  tsx: true
@@ -414,4 +420,4 @@ _define_property(LexConfig, "config", {
414
420
  ...defaultConfigValues
415
421
  });
416
422
 
417
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/LexConfig.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 findFileUp from 'find-file-up';\nimport {existsSync, readFileSync, writeFileSync} from 'fs';\nimport {\n  dirname,\n  extname as pathExtname,\n  relative as pathRelative,\n  resolve as pathResolve\n} from 'path';\nimport {URL} from 'url';\n\nimport {getLexPackageJsonPath, relativeFilePath} from './utils/file.js';\nimport {log} from './utils/log.js';\n\nimport type {Options} from '@swc/core';\nimport type {Linter} from 'eslint';\n\nconst cwd: string = process.cwd();\n\n\nexport interface VitestConfig {\n  [key: string]: unknown;\n}\n\nexport interface WebpackConfig {\n  [key: string]: unknown;\n  entry?: string | string[];\n  output?: Record<string, unknown>;\n  module?: Record<string, unknown>;\n  plugins?: unknown[];\n  staticPath?: string;\n}\n\nexport interface AIConfig {\n  provider?: 'cursor' | 'copilot' | 'openai' | 'anthropic' | 'none';\n  apiKey?: string;\n  model?: string;\n  maxTokens?: number;\n  temperature?: number;\n}\n\nexport interface DevConfig {\n  port?: number;\n}\n\nexport interface ESLintConfig {\n  [key: string]: unknown;\n  extends?: string[];\n  rules?: Linter.RulesRecord;\n}\n\nexport interface LexConfigType {\n  ai?: AIConfig;\n  configFiles?: string[];\n  copyFiles?: string[];\n  dev?: DevConfig;\n  entryHTML?: string;\n  entryJs?: string;\n  env?: object;\n  eslint?: ESLintConfig;\n  gitUrl?: string;\n  vitest?: VitestConfig;\n  libraryName?: string;\n  libraryTarget?: string;\n  outputFile?: string;\n  outputFullPath?: string;\n  outputHash?: boolean;\n  outputPath?: string;\n  packageManager?: 'npm' | 'yarn';\n  preset?: 'web' | 'node' | 'lambda' | 'mobile';\n  sourceFullPath?: string;\n  sourcePath?: string;\n  swc?: SWCOptions;\n  targetEnvironment?: 'node' | 'web';\n  useGraphQl?: boolean;\n  useTypescript?: boolean;\n  webpack?: WebpackConfig;\n}\n\nexport type Config = LexConfigType;\n\nexport const defaultConfigValues: LexConfigType = {\n  ai: {\n    maxTokens: 4000,\n    model: 'gpt-4o',\n    provider: 'none',\n    temperature: 0.1\n  },\n  configFiles: [],\n  copyFiles: [],\n  entryHTML: 'index.html',\n  entryJs: 'index.js',\n  env: null,\n  eslint: {},\n  vitest: {},\n  outputFullPath: pathResolve(cwd, './lib'),\n  outputHash: false,\n  outputPath: './lib',\n  packageManager: 'npm',\n  preset: 'web',\n  sourceFullPath: pathResolve(cwd, './src'),\n  sourcePath: './src',\n  swc: {\n    inlineSourcesContent: true,\n    isModule: true,\n    jsc: {\n      externalHelpers: false,\n      keepClassNames: false,\n      loose: false,\n      parser: {\n        decorators: true,\n        dynamicImport: true,\n        syntax: 'typescript',\n        tsx: true\n      },\n      target: 'es2023',\n      transform: {\n        react: {\n          runtime: 'automatic'\n        }\n      }\n    },\n    minify: false,\n    module: {\n      lazy: false,\n      noInterop: false,\n      strict: false,\n      strictMode: true,\n      type: 'es6'\n    },\n    sourceMaps: 'inline'\n  },\n  targetEnvironment: 'web',\n  useGraphQl: false,\n  useTypescript: false,\n  webpack: {\n    staticPath: './src/static'\n  }\n};\n\nexport const getPackageDir = (): string => {\n  const cwd = process.cwd();\n  const currentPkgPath = pathResolve(cwd, 'package.json');\n\n  if(existsSync(currentPkgPath)) {\n    try {\n      const pkg = JSON.parse(readFileSync(currentPkgPath, 'utf8'));\n      if(!pkg.workspaces) {\n        return cwd;\n      }\n    } catch{\n      return cwd;\n    }\n  }\n\n  let searchDir = cwd;\n\n  for(let i = 0; i < 10; i++) {\n    const pkgPath = pathResolve(searchDir, 'package.json');\n    if(existsSync(pkgPath)) {\n      try {\n        const pkg = JSON.parse(readFileSync(pkgPath, 'utf8'));\n\n        if(!pkg.workspaces) {\n          return searchDir;\n        }\n      } catch{\n        // Continue searching\n      }\n    }\n\n    const parent = dirname(searchDir);\n\n    if(parent === searchDir) {\n      break;\n    }\n    searchDir = parent;\n  }\n\n  const configFormats = ['js', 'mjs', 'cjs', 'ts', 'json'];\n\n  for(const format of configFormats) {\n    const configPath = findFileUp.sync(`lex.config.${format}`, cwd, 5);\n\n    if(configPath) {\n      return dirname(configPath);\n    }\n  }\n\n  return cwd;\n};\n\nexport const getTypeScriptConfigPath = (configName: string): string => {\n  const packageDir = getPackageDir();\n  const cwd = process.cwd();\n\n  if(configName === 'tsconfig.build.json') {\n    const projectBuildConfig = pathResolve(packageDir, 'tsconfig.build.json');\n\n    if(existsSync(projectBuildConfig)) {\n      return projectBuildConfig;\n    }\n\n    const rootBuildConfig = pathResolve(cwd, 'tsconfig.build.json');\n    if(existsSync(rootBuildConfig)) {\n      return rootBuildConfig;\n    }\n  }\n\n  if(configName === 'tsconfig.lint.json') {\n    const projectLintConfig = pathResolve(packageDir, 'tsconfig.eslint.json');\n    if(existsSync(projectLintConfig)) {\n      return projectLintConfig;\n    }\n\n    const rootLintConfig = pathResolve(cwd, 'tsconfig.eslint.json');\n\n    if(existsSync(rootLintConfig)) {\n      return rootLintConfig;\n    }\n  }\n\n  if(configName === 'tsconfig.test.json') {\n    const projectTestConfig = pathResolve(packageDir, 'tsconfig.test.json');\n    if(existsSync(projectTestConfig)) {\n      return projectTestConfig;\n    }\n\n    const rootTestConfig = pathResolve(cwd, 'tsconfig.test.json');\n\n    if(existsSync(rootTestConfig)) {\n      return rootTestConfig;\n    }\n  }\n\n  const projectConfigPath = pathResolve(packageDir, configName);\n\n  if(existsSync(projectConfigPath)) {\n    return projectConfigPath;\n  }\n\n  const rootConfigPath = pathResolve(cwd, configName);\n\n  if(existsSync(rootConfigPath)) {\n    return rootConfigPath;\n  }\n\n  const lexDir = LexConfig.getLexDir();\n\n  return pathResolve(lexDir, configName);\n};\n\nexport class LexConfig {\n  static config: LexConfigType = {\n    ...defaultConfigValues\n  };\n\n  static set useTypescript(value: boolean) {\n    LexConfig.config.useTypescript = value;\n    const {entryJs, sourceFullPath, targetEnvironment} = LexConfig.config;\n\n    if(entryJs === 'index.js' && value) {\n      const indexPath: string = pathResolve(cwd, sourceFullPath, 'index.tsx');\n      const hasIndexTsx: boolean = existsSync(indexPath);\n\n      if(hasIndexTsx) {\n        LexConfig.config.entryJs = 'index.tsx';\n      } else {\n        LexConfig.config.entryJs = 'index.ts';\n      }\n    }\n\n    LexConfig.config.swc.jsc.parser = {\n      syntax: 'typescript',\n      tsx: true\n    };\n\n    if(targetEnvironment === 'web') {\n      LexConfig.config.swc.jsc.transform = {\n        react: {\n          runtime: 'automatic'\n        }\n      };\n    }\n  }\n\n  static getLexDir(): string {\n    return dirname(getLexPackageJsonPath());\n  }\n\n  static updateConfig(updatedConfig: LexConfigType): LexConfigType {\n    const {outputFullPath, outputPath, sourcePath, sourceFullPath, useTypescript, ai} = updatedConfig;\n    const packageDir = getPackageDir();\n\n    if(useTypescript !== undefined) {\n      LexConfig.useTypescript = useTypescript;\n    }\n\n    if(outputPath !== undefined && outputFullPath === undefined) {\n      updatedConfig.outputFullPath = pathResolve(packageDir, outputPath);\n    }\n\n    if(sourcePath !== undefined && sourceFullPath === undefined) {\n      updatedConfig.sourceFullPath = pathResolve(packageDir, sourcePath);\n    }\n\n    if(ai) {\n      LexConfig.config.ai = {...LexConfig.config.ai, ...ai};\n\n      if(process.env.CURSOR_IDE === 'true' && LexConfig.config.ai.provider === 'none') {\n        LexConfig.config.ai.provider = 'cursor';\n      }\n    }\n\n    LexConfig.config = {...LexConfig.config, ...updatedConfig};\n\n    return LexConfig.config;\n  }\n\n  static addConfigParams(cmd, params: LexConfigType) {\n    const nameProperty: string = '_name';\n    const {environment, outputPath, sourcePath, typescript} = cmd;\n    const packageDir = getPackageDir();\n\n    if(outputPath !== undefined) {\n      params.outputPath = outputPath;\n      params.outputFullPath = pathResolve(packageDir, outputPath);\n    } else if(params.outputPath && !params.outputFullPath) {\n      params.outputFullPath = pathResolve(packageDir, params.outputPath);\n    }\n\n    if(sourcePath !== undefined) {\n      params.sourcePath = sourcePath;\n      params.sourceFullPath = pathResolve(packageDir, sourcePath);\n    } else if(params.sourcePath && !params.sourceFullPath) {\n      params.sourceFullPath = pathResolve(packageDir, params.sourcePath);\n    }\n\n    if(typescript !== undefined) {\n      params.useTypescript = true;\n    }\n\n    if(environment !== undefined) {\n      params.targetEnvironment = environment === 'web' ? 'web' : 'node';\n    }\n\n    process.env.LEX_CONFIG = JSON.stringify(\n      {\n        ...LexConfig.updateConfig(params),\n        commandName: cmd[nameProperty],\n        isStatic: cmd.static\n      }, null, 0\n    );\n  }\n\n  static async parseConfig(cmd, isRoot: boolean = true): Promise<void> {\n    const {cliName = 'Lex', lexConfig, lexConfigName, quiet, typescript, debug = false} = cmd;\n    const configFormats = ['js', 'mjs', 'cjs', 'ts', 'json'];\n    const configBaseName: string = lexConfigName || 'lex.config';\n    let configPath: string = lexConfig || '';\n    let configExists: boolean = lexConfig ? existsSync(configPath) : false;\n\n    if(!configPath || !configExists) {\n      if(debug) {\n        log(`Searching for config files with base name: ${configBaseName}`, 'info', quiet);\n      }\n\n      for(const format of configFormats) {\n        const potentialPath = isRoot\n          ? pathResolve(cwd, `./${configBaseName}.${format}`)\n          : relativeFilePath(`${configBaseName}.${format}`, cwd);\n\n        if(debug) {\n          log(`Checking for config file: ${potentialPath}`, 'info', quiet);\n        }\n\n        if(existsSync(potentialPath)) {\n          configPath = potentialPath;\n          configExists = true;\n          break;\n        }\n      }\n    }\n\n    if(configExists) {\n      log(`Using ${cliName} configuration file: ${configPath}`, 'note', quiet);\n      const ext: string = pathExtname(configPath);\n\n      if(ext === '.json') {\n        const configContent: string = readFileSync(configPath, 'utf8');\n\n        if(configContent) {\n          let configJson: LexConfigType;\n\n          try {\n            configJson = JSON.parse(configContent)?.default || {};\n          } catch(error) {\n            log(`\\n${cliName} Error: Failed to parse JSON config: ${error.message}`, 'error', quiet);\n            configJson = {};\n          }\n\n          LexConfig.addConfigParams(cmd, configJson);\n        } else {\n          log(`\\n${cliName} Error: Config file malformed, ${configPath}`, 'error', quiet);\n        }\n      } else if(['.js', '.mjs', '.cjs', '.ts'].includes(ext)) {\n        try {\n          let lexCustomConfig;\n\n          if(ext === '.cjs') {\n            const fileUrl = new URL(`file:///${pathResolve(configPath)}`).href;\n\n            if(debug) {\n              log(`Loading CommonJS config from: ${fileUrl}`, 'info', quiet);\n            }\n            lexCustomConfig = await import(fileUrl);\n          } else {\n            if(debug) {\n              log(`Loading ESM/TS config from: ${configPath}`, 'info', quiet);\n            }\n\n            lexCustomConfig = await import(configPath);\n          }\n\n          const config = lexCustomConfig.default || lexCustomConfig;\n\n          if(debug) {\n            log(`Loaded config: ${JSON.stringify(config, null, 2)}`, 'info', quiet);\n          }\n\n          if(!config) {\n            log(`\\n${cliName} Warning: Config file loaded but no configuration found`, 'warn', quiet);\n          }\n\n          LexConfig.addConfigParams(cmd, config || {});\n        } catch(error) {\n          log(`\\n${cliName} Error: Failed to load config file: ${error.message}`, 'error', quiet);\n          if(debug) {\n            // eslint-disable-next-line no-console\n            console.error(error);\n          }\n        }\n      } else {\n        log(`\\n${cliName} Error: Config file must be a JS, CJS, MJS, TS, or JSON file.`, 'error', quiet);\n      }\n    } else {\n      if(debug) {\n        log('No config file found. Using default configuration.', 'info', quiet);\n      }\n\n      LexConfig.useTypescript = !!typescript;\n      LexConfig.addConfigParams(cmd, LexConfig.config);\n    }\n  }\n\n  static checkTypescriptConfig() {\n    const packageDir = getPackageDir();\n    const tsconfigPath: string = pathResolve(packageDir, './tsconfig.json');\n\n    if(!existsSync(tsconfigPath)) {\n      const lexDir = LexConfig.getLexDir();\n      const baseConfigPath = pathResolve(lexDir, 'tsconfig.base.json');\n      const templateConfigPath = pathResolve(lexDir, 'tsconfig.template.json');\n      const sourcePath = existsSync(baseConfigPath) ? baseConfigPath : templateConfigPath;\n\n      if(existsSync(sourcePath)) {\n        writeFileSync(tsconfigPath, readFileSync(sourcePath));\n      }\n    }\n  }\n\n  static getTypeScriptDeclarationFlags(): string[] {\n    const cwd = process.cwd();\n    const outputPath = LexConfig.config.outputPath || './lib';\n    const outputFullPath = LexConfig.config.outputFullPath || pathResolve(cwd, outputPath);\n    const sourcePath = LexConfig.config.sourcePath || './src';\n    const sourceFullPath = LexConfig.config.sourceFullPath || pathResolve(cwd, sourcePath);\n    const relativeOutDir = pathRelative(cwd, outputFullPath) || './lib';\n    const relativeRootDir = pathRelative(cwd, sourceFullPath) || './src';\n\n    return [\n      '--emitDeclarationOnly', // CRITICAL: Only emit .d.ts files, no JS files\n      '--declaration', // Generate declaration files\n      '--declarationMap', // Generate source maps for declarations\n      '--outDir', relativeOutDir,\n      '--rootDir', relativeRootDir,\n      '--skipLibCheck', // Skip type checking of declaration files (faster, more lenient)\n      '--esModuleInterop',\n      '--allowSyntheticDefaultImports',\n      '--module', 'NodeNext',\n      '--moduleResolution', 'NodeNext',\n      '--target', 'ESNext',\n      '--jsx', 'react-jsx',\n      '--isolatedModules',\n      '--resolveJsonModule',\n      '--allowJs'\n      // Note: --noUnusedLocals and --noUnusedParameters are not needed for declaration generation\n      // and would actually enable strict checking, which we want to avoid for faster declaration generation\n    ];\n  }\n\n  static checkLintTypescriptConfig() {\n    const lexDir = LexConfig.getLexDir();\n    const tsconfigLintPath: string = pathResolve(lexDir, './tsconfig.lint.json');\n\n    if(!existsSync(tsconfigLintPath)) {\n      const templatePath = pathResolve(lexDir, 'tsconfig.lint.json');\n      if(existsSync(templatePath)) {\n        writeFileSync(tsconfigLintPath, readFileSync(templatePath));\n      }\n    }\n  }\n\n  static checkTestTypescriptConfig() {\n    const lexDir = LexConfig.getLexDir();\n    const tsconfigTestPath: string = pathResolve(lexDir, './tsconfig.test.json');\n\n    if(!existsSync(tsconfigTestPath)) {\n      const templatePath = pathResolve(lexDir, 'tsconfig.test.json');\n      if(existsSync(templatePath)) {\n        writeFileSync(tsconfigTestPath, readFileSync(templatePath));\n      }\n    }\n  }\n}\n\nexport type SWCOptions = Options;\n"],"names":["findFileUp","existsSync","readFileSync","writeFileSync","dirname","extname","pathExtname","relative","pathRelative","resolve","pathResolve","URL","getLexPackageJsonPath","relativeFilePath","log","cwd","process","defaultConfigValues","ai","maxTokens","model","provider","temperature","configFiles","copyFiles","entryHTML","entryJs","env","eslint","vitest","outputFullPath","outputHash","outputPath","packageManager","preset","sourceFullPath","sourcePath","swc","inlineSourcesContent","isModule","jsc","externalHelpers","keepClassNames","loose","parser","decorators","dynamicImport","syntax","tsx","target","transform","react","runtime","minify","module","lazy","noInterop","strict","strictMode","type","sourceMaps","targetEnvironment","useGraphQl","useTypescript","webpack","staticPath","getPackageDir","currentPkgPath","pkg","JSON","parse","workspaces","searchDir","i","pkgPath","parent","configFormats","format","configPath","sync","getTypeScriptConfigPath","configName","packageDir","projectBuildConfig","rootBuildConfig","projectLintConfig","rootLintConfig","projectTestConfig","rootTestConfig","projectConfigPath","rootConfigPath","lexDir","LexConfig","getLexDir","value","config","indexPath","hasIndexTsx","updateConfig","updatedConfig","undefined","CURSOR_IDE","addConfigParams","cmd","params","nameProperty","environment","typescript","LEX_CONFIG","stringify","commandName","isStatic","static","parseConfig","isRoot","cliName","lexConfig","lexConfigName","quiet","debug","configBaseName","configExists","potentialPath","ext","configContent","configJson","default","error","message","includes","lexCustomConfig","fileUrl","href","console","checkTypescriptConfig","tsconfigPath","baseConfigPath","templateConfigPath","getTypeScriptDeclarationFlags","relativeOutDir","relativeRootDir","checkLintTypescriptConfig","tsconfigLintPath","templatePath","checkTestTypescriptConfig","tsconfigTestPath"],"mappings":";;;;;;;;;;;;;AAAA;;;CAGC,GACD,OAAOA,gBAAgB,eAAe;AACtC,SAAQC,UAAU,EAAEC,YAAY,EAAEC,aAAa,QAAO,KAAK;AAC3D,SACEC,OAAO,EACPC,WAAWC,WAAW,EACtBC,YAAYC,YAAY,EACxBC,WAAWC,WAAW,QACjB,OAAO;AACd,SAAQC,GAAG,QAAO,MAAM;AAExB,SAAQC,qBAAqB,EAAEC,gBAAgB,QAAO,kBAAkB;AACxE,SAAQC,GAAG,QAAO,iBAAiB;AAKnC,MAAMC,MAAcC,QAAQD,GAAG;AAgE/B,OAAO,MAAME,sBAAqC;IAChDC,IAAI;QACFC,WAAW;QACXC,OAAO;QACPC,UAAU;QACVC,aAAa;IACf;IACAC,aAAa,EAAE;IACfC,WAAW,EAAE;IACbC,WAAW;IACXC,SAAS;IACTC,KAAK;IACLC,QAAQ,CAAC;IACTC,QAAQ,CAAC;IACTC,gBAAgBpB,YAAYK,KAAK;IACjCgB,YAAY;IACZC,YAAY;IACZC,gBAAgB;IAChBC,QAAQ;IACRC,gBAAgBzB,YAAYK,KAAK;IACjCqB,YAAY;IACZC,KAAK;QACHC,sBAAsB;QACtBC,UAAU;QACVC,KAAK;YACHC,iBAAiB;YACjBC,gBAAgB;YAChBC,OAAO;YACPC,QAAQ;gBACNC,YAAY;gBACZC,eAAe;gBACfC,QAAQ;gBACRC,KAAK;YACP;YACAC,QAAQ;YACRC,WAAW;gBACTC,OAAO;oBACLC,SAAS;gBACX;YACF;QACF;QACAC,QAAQ;QACRC,QAAQ;YACNC,MAAM;YACNC,WAAW;YACXC,QAAQ;YACRC,YAAY;YACZC,MAAM;QACR;QACAC,YAAY;IACd;IACAC,mBAAmB;IACnBC,YAAY;IACZC,eAAe;IACfC,SAAS;QACPC,YAAY;IACd;AACF,EAAE;AAEF,OAAO,MAAMC,gBAAgB;IAC3B,MAAMnD,MAAMC,QAAQD,GAAG;IACvB,MAAMoD,iBAAiBzD,YAAYK,KAAK;IAExC,IAAGd,WAAWkE,iBAAiB;QAC7B,IAAI;YACF,MAAMC,MAAMC,KAAKC,KAAK,CAACpE,aAAaiE,gBAAgB;YACpD,IAAG,CAACC,IAAIG,UAAU,EAAE;gBAClB,OAAOxD;YACT;QACF,EAAE,OAAK;YACL,OAAOA;QACT;IACF;IAEA,IAAIyD,YAAYzD;IAEhB,IAAI,IAAI0D,IAAI,GAAGA,IAAI,IAAIA,IAAK;QAC1B,MAAMC,UAAUhE,YAAY8D,WAAW;QACvC,IAAGvE,WAAWyE,UAAU;YACtB,IAAI;gBACF,MAAMN,MAAMC,KAAKC,KAAK,CAACpE,aAAawE,SAAS;gBAE7C,IAAG,CAACN,IAAIG,UAAU,EAAE;oBAClB,OAAOC;gBACT;YACF,EAAE,OAAK;YACL,qBAAqB;YACvB;QACF;QAEA,MAAMG,SAASvE,QAAQoE;QAEvB,IAAGG,WAAWH,WAAW;YACvB;QACF;QACAA,YAAYG;IACd;IAEA,MAAMC,gBAAgB;QAAC;QAAM;QAAO;QAAO;QAAM;KAAO;IAExD,KAAI,MAAMC,UAAUD,cAAe;QACjC,MAAME,aAAa9E,WAAW+E,IAAI,CAAC,CAAC,WAAW,EAAEF,QAAQ,EAAE9D,KAAK;QAEhE,IAAG+D,YAAY;YACb,OAAO1E,QAAQ0E;QACjB;IACF;IAEA,OAAO/D;AACT,EAAE;AAEF,OAAO,MAAMiE,0BAA0B,CAACC;IACtC,MAAMC,aAAahB;IACnB,MAAMnD,MAAMC,QAAQD,GAAG;IAEvB,IAAGkE,eAAe,uBAAuB;QACvC,MAAME,qBAAqBzE,YAAYwE,YAAY;QAEnD,IAAGjF,WAAWkF,qBAAqB;YACjC,OAAOA;QACT;QAEA,MAAMC,kBAAkB1E,YAAYK,KAAK;QACzC,IAAGd,WAAWmF,kBAAkB;YAC9B,OAAOA;QACT;IACF;IAEA,IAAGH,eAAe,sBAAsB;QACtC,MAAMI,oBAAoB3E,YAAYwE,YAAY;QAClD,IAAGjF,WAAWoF,oBAAoB;YAChC,OAAOA;QACT;QAEA,MAAMC,iBAAiB5E,YAAYK,KAAK;QAExC,IAAGd,WAAWqF,iBAAiB;YAC7B,OAAOA;QACT;IACF;IAEA,IAAGL,eAAe,sBAAsB;QACtC,MAAMM,oBAAoB7E,YAAYwE,YAAY;QAClD,IAAGjF,WAAWsF,oBAAoB;YAChC,OAAOA;QACT;QAEA,MAAMC,iBAAiB9E,YAAYK,KAAK;QAExC,IAAGd,WAAWuF,iBAAiB;YAC7B,OAAOA;QACT;IACF;IAEA,MAAMC,oBAAoB/E,YAAYwE,YAAYD;IAElD,IAAGhF,WAAWwF,oBAAoB;QAChC,OAAOA;IACT;IAEA,MAAMC,iBAAiBhF,YAAYK,KAAKkE;IAExC,IAAGhF,WAAWyF,iBAAiB;QAC7B,OAAOA;IACT;IAEA,MAAMC,SAASC,UAAUC,SAAS;IAElC,OAAOnF,YAAYiF,QAAQV;AAC7B,EAAE;AAEF,OAAO,MAAMW;IAKX,WAAW7B,cAAc+B,KAAc,EAAE;QACvCF,UAAUG,MAAM,CAAChC,aAAa,GAAG+B;QACjC,MAAM,EAACpE,OAAO,EAAES,cAAc,EAAE0B,iBAAiB,EAAC,GAAG+B,UAAUG,MAAM;QAErE,IAAGrE,YAAY,cAAcoE,OAAO;YAClC,MAAME,YAAoBtF,YAAYK,KAAKoB,gBAAgB;YAC3D,MAAM8D,cAAuBhG,WAAW+F;YAExC,IAAGC,aAAa;gBACdL,UAAUG,MAAM,CAACrE,OAAO,GAAG;YAC7B,OAAO;gBACLkE,UAAUG,MAAM,CAACrE,OAAO,GAAG;YAC7B;QACF;QAEAkE,UAAUG,MAAM,CAAC1D,GAAG,CAACG,GAAG,CAACI,MAAM,GAAG;YAChCG,QAAQ;YACRC,KAAK;QACP;QAEA,IAAGa,sBAAsB,OAAO;YAC9B+B,UAAUG,MAAM,CAAC1D,GAAG,CAACG,GAAG,CAACU,SAAS,GAAG;gBACnCC,OAAO;oBACLC,SAAS;gBACX;YACF;QACF;IACF;IAEA,OAAOyC,YAAoB;QACzB,OAAOzF,QAAQQ;IACjB;IAEA,OAAOsF,aAAaC,aAA4B,EAAiB;QAC/D,MAAM,EAACrE,cAAc,EAAEE,UAAU,EAAEI,UAAU,EAAED,cAAc,EAAE4B,aAAa,EAAE7C,EAAE,EAAC,GAAGiF;QACpF,MAAMjB,aAAahB;QAEnB,IAAGH,kBAAkBqC,WAAW;YAC9BR,UAAU7B,aAAa,GAAGA;QAC5B;QAEA,IAAG/B,eAAeoE,aAAatE,mBAAmBsE,WAAW;YAC3DD,cAAcrE,cAAc,GAAGpB,YAAYwE,YAAYlD;QACzD;QAEA,IAAGI,eAAegE,aAAajE,mBAAmBiE,WAAW;YAC3DD,cAAchE,cAAc,GAAGzB,YAAYwE,YAAY9C;QACzD;QAEA,IAAGlB,IAAI;YACL0E,UAAUG,MAAM,CAAC7E,EAAE,GAAG;gBAAC,GAAG0E,UAAUG,MAAM,CAAC7E,EAAE;gBAAE,GAAGA,EAAE;YAAA;YAEpD,IAAGF,QAAQW,GAAG,CAAC0E,UAAU,KAAK,UAAUT,UAAUG,MAAM,CAAC7E,EAAE,CAACG,QAAQ,KAAK,QAAQ;gBAC/EuE,UAAUG,MAAM,CAAC7E,EAAE,CAACG,QAAQ,GAAG;YACjC;QACF;QAEAuE,UAAUG,MAAM,GAAG;YAAC,GAAGH,UAAUG,MAAM;YAAE,GAAGI,aAAa;QAAA;QAEzD,OAAOP,UAAUG,MAAM;IACzB;IAEA,OAAOO,gBAAgBC,GAAG,EAAEC,MAAqB,EAAE;QACjD,MAAMC,eAAuB;QAC7B,MAAM,EAACC,WAAW,EAAE1E,UAAU,EAAEI,UAAU,EAAEuE,UAAU,EAAC,GAAGJ;QAC1D,MAAMrB,aAAahB;QAEnB,IAAGlC,eAAeoE,WAAW;YAC3BI,OAAOxE,UAAU,GAAGA;YACpBwE,OAAO1E,cAAc,GAAGpB,YAAYwE,YAAYlD;QAClD,OAAO,IAAGwE,OAAOxE,UAAU,IAAI,CAACwE,OAAO1E,cAAc,EAAE;YACrD0E,OAAO1E,cAAc,GAAGpB,YAAYwE,YAAYsB,OAAOxE,UAAU;QACnE;QAEA,IAAGI,eAAegE,WAAW;YAC3BI,OAAOpE,UAAU,GAAGA;YACpBoE,OAAOrE,cAAc,GAAGzB,YAAYwE,YAAY9C;QAClD,OAAO,IAAGoE,OAAOpE,UAAU,IAAI,CAACoE,OAAOrE,cAAc,EAAE;YACrDqE,OAAOrE,cAAc,GAAGzB,YAAYwE,YAAYsB,OAAOpE,UAAU;QACnE;QAEA,IAAGuE,eAAeP,WAAW;YAC3BI,OAAOzC,aAAa,GAAG;QACzB;QAEA,IAAG2C,gBAAgBN,WAAW;YAC5BI,OAAO3C,iBAAiB,GAAG6C,gBAAgB,QAAQ,QAAQ;QAC7D;QAEA1F,QAAQW,GAAG,CAACiF,UAAU,GAAGvC,KAAKwC,SAAS,CACrC;YACE,GAAGjB,UAAUM,YAAY,CAACM,OAAO;YACjCM,aAAaP,GAAG,CAACE,aAAa;YAC9BM,UAAUR,IAAIS,MAAM;QACtB,GAAG,MAAM;IAEb;IAEA,aAAaC,YAAYV,GAAG,EAAEW,SAAkB,IAAI,EAAiB;QACnE,MAAM,EAACC,UAAU,KAAK,EAAEC,SAAS,EAAEC,aAAa,EAAEC,KAAK,EAAEX,UAAU,EAAEY,QAAQ,KAAK,EAAC,GAAGhB;QACtF,MAAM3B,gBAAgB;YAAC;YAAM;YAAO;YAAO;YAAM;SAAO;QACxD,MAAM4C,iBAAyBH,iBAAiB;QAChD,IAAIvC,aAAqBsC,aAAa;QACtC,IAAIK,eAAwBL,YAAYnH,WAAW6E,cAAc;QAEjE,IAAG,CAACA,cAAc,CAAC2C,cAAc;YAC/B,IAAGF,OAAO;gBACRzG,IAAI,CAAC,2CAA2C,EAAE0G,gBAAgB,EAAE,QAAQF;YAC9E;YAEA,KAAI,MAAMzC,UAAUD,cAAe;gBACjC,MAAM8C,gBAAgBR,SAClBxG,YAAYK,KAAK,CAAC,EAAE,EAAEyG,eAAe,CAAC,EAAE3C,QAAQ,IAChDhE,iBAAiB,GAAG2G,eAAe,CAAC,EAAE3C,QAAQ,EAAE9D;gBAEpD,IAAGwG,OAAO;oBACRzG,IAAI,CAAC,0BAA0B,EAAE4G,eAAe,EAAE,QAAQJ;gBAC5D;gBAEA,IAAGrH,WAAWyH,gBAAgB;oBAC5B5C,aAAa4C;oBACbD,eAAe;oBACf;gBACF;YACF;QACF;QAEA,IAAGA,cAAc;YACf3G,IAAI,CAAC,MAAM,EAAEqG,QAAQ,qBAAqB,EAAErC,YAAY,EAAE,QAAQwC;YAClE,MAAMK,MAAcrH,YAAYwE;YAEhC,IAAG6C,QAAQ,SAAS;gBAClB,MAAMC,gBAAwB1H,aAAa4E,YAAY;gBAEvD,IAAG8C,eAAe;oBAChB,IAAIC;oBAEJ,IAAI;wBACFA,aAAaxD,KAAKC,KAAK,CAACsD,gBAAgBE,WAAW,CAAC;oBACtD,EAAE,OAAMC,OAAO;wBACbjH,IAAI,CAAC,EAAE,EAAEqG,QAAQ,qCAAqC,EAAEY,MAAMC,OAAO,EAAE,EAAE,SAASV;wBAClFO,aAAa,CAAC;oBAChB;oBAEAjC,UAAUU,eAAe,CAACC,KAAKsB;gBACjC,OAAO;oBACL/G,IAAI,CAAC,EAAE,EAAEqG,QAAQ,+BAA+B,EAAErC,YAAY,EAAE,SAASwC;gBAC3E;YACF,OAAO,IAAG;gBAAC;gBAAO;gBAAQ;gBAAQ;aAAM,CAACW,QAAQ,CAACN,MAAM;gBACtD,IAAI;oBACF,IAAIO;oBAEJ,IAAGP,QAAQ,QAAQ;wBACjB,MAAMQ,UAAU,IAAIxH,IAAI,CAAC,QAAQ,EAAED,YAAYoE,aAAa,EAAEsD,IAAI;wBAElE,IAAGb,OAAO;4BACRzG,IAAI,CAAC,8BAA8B,EAAEqH,SAAS,EAAE,QAAQb;wBAC1D;wBACAY,kBAAkB,MAAM,MAAM,CAACC;oBACjC,OAAO;wBACL,IAAGZ,OAAO;4BACRzG,IAAI,CAAC,4BAA4B,EAAEgE,YAAY,EAAE,QAAQwC;wBAC3D;wBAEAY,kBAAkB,MAAM,MAAM,CAACpD;oBACjC;oBAEA,MAAMiB,SAASmC,gBAAgBJ,OAAO,IAAII;oBAE1C,IAAGX,OAAO;wBACRzG,IAAI,CAAC,eAAe,EAAEuD,KAAKwC,SAAS,CAACd,QAAQ,MAAM,IAAI,EAAE,QAAQuB;oBACnE;oBAEA,IAAG,CAACvB,QAAQ;wBACVjF,IAAI,CAAC,EAAE,EAAEqG,QAAQ,uDAAuD,CAAC,EAAE,QAAQG;oBACrF;oBAEA1B,UAAUU,eAAe,CAACC,KAAKR,UAAU,CAAC;gBAC5C,EAAE,OAAMgC,OAAO;oBACbjH,IAAI,CAAC,EAAE,EAAEqG,QAAQ,oCAAoC,EAAEY,MAAMC,OAAO,EAAE,EAAE,SAASV;oBACjF,IAAGC,OAAO;wBACR,sCAAsC;wBACtCc,QAAQN,KAAK,CAACA;oBAChB;gBACF;YACF,OAAO;gBACLjH,IAAI,CAAC,EAAE,EAAEqG,QAAQ,6DAA6D,CAAC,EAAE,SAASG;YAC5F;QACF,OAAO;YACL,IAAGC,OAAO;gBACRzG,IAAI,sDAAsD,QAAQwG;YACpE;YAEA1B,UAAU7B,aAAa,GAAG,CAAC,CAAC4C;YAC5Bf,UAAUU,eAAe,CAACC,KAAKX,UAAUG,MAAM;QACjD;IACF;IAEA,OAAOuC,wBAAwB;QAC7B,MAAMpD,aAAahB;QACnB,MAAMqE,eAAuB7H,YAAYwE,YAAY;QAErD,IAAG,CAACjF,WAAWsI,eAAe;YAC5B,MAAM5C,SAASC,UAAUC,SAAS;YAClC,MAAM2C,iBAAiB9H,YAAYiF,QAAQ;YAC3C,MAAM8C,qBAAqB/H,YAAYiF,QAAQ;YAC/C,MAAMvD,aAAanC,WAAWuI,kBAAkBA,iBAAiBC;YAEjE,IAAGxI,WAAWmC,aAAa;gBACzBjC,cAAcoI,cAAcrI,aAAakC;YAC3C;QACF;IACF;IAEA,OAAOsG,gCAA0C;QAC/C,MAAM3H,MAAMC,QAAQD,GAAG;QACvB,MAAMiB,aAAa4D,UAAUG,MAAM,CAAC/D,UAAU,IAAI;QAClD,MAAMF,iBAAiB8D,UAAUG,MAAM,CAACjE,cAAc,IAAIpB,YAAYK,KAAKiB;QAC3E,MAAMI,aAAawD,UAAUG,MAAM,CAAC3D,UAAU,IAAI;QAClD,MAAMD,iBAAiByD,UAAUG,MAAM,CAAC5D,cAAc,IAAIzB,YAAYK,KAAKqB;QAC3E,MAAMuG,iBAAiBnI,aAAaO,KAAKe,mBAAmB;QAC5D,MAAM8G,kBAAkBpI,aAAaO,KAAKoB,mBAAmB;QAE7D,OAAO;YACL;YACA;YACA;YACA;YAAYwG;YACZ;YAAaC;YACb;YACA;YACA;YACA;YAAY;YACZ;YAAsB;YACtB;YAAY;YACZ;YAAS;YACT;YACA;YACA;SAGD;IACH;IAEA,OAAOC,4BAA4B;QACjC,MAAMlD,SAASC,UAAUC,SAAS;QAClC,MAAMiD,mBAA2BpI,YAAYiF,QAAQ;QAErD,IAAG,CAAC1F,WAAW6I,mBAAmB;YAChC,MAAMC,eAAerI,YAAYiF,QAAQ;YACzC,IAAG1F,WAAW8I,eAAe;gBAC3B5I,cAAc2I,kBAAkB5I,aAAa6I;YAC/C;QACF;IACF;IAEA,OAAOC,4BAA4B;QACjC,MAAMrD,SAASC,UAAUC,SAAS;QAClC,MAAMoD,mBAA2BvI,YAAYiF,QAAQ;QAErD,IAAG,CAAC1F,WAAWgJ,mBAAmB;YAChC,MAAMF,eAAerI,YAAYiF,QAAQ;YACzC,IAAG1F,WAAW8I,eAAe;gBAC3B5I,cAAc8I,kBAAkB/I,aAAa6I;YAC/C;QACF;IACF;AACF;AA/QE,iBADWnD,WACJG,UAAwB;IAC7B,GAAG9E,mBAAmB;AACxB"}
423
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/LexConfig.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 findFileUp from 'find-file-up';\nimport {existsSync, readFileSync, writeFileSync} from 'fs';\nimport {\n  dirname,\n  extname as pathExtname,\n  relative as pathRelative,\n  resolve as pathResolve\n} from 'path';\nimport {URL} from 'url';\n\nimport {getLexPackageJsonPath, relativeFilePath} from './utils/file.js';\nimport {log} from './utils/log.js';\n\nimport type {Options} from '@swc/core';\nimport type {Linter} from 'eslint';\n\nconst cwd: string = process.cwd();\n\n\nexport interface VitestConfig {\n  [key: string]: unknown;\n}\n\nexport interface WebpackConfig {\n  [key: string]: unknown;\n  entry?: string | string[];\n  output?: Record<string, unknown>;\n  module?: Record<string, unknown>;\n  plugins?: unknown[];\n  staticPath?: string;\n}\n\nexport interface AIConfig {\n  provider?: 'cursor' | 'copilot' | 'openai' | 'anthropic' | 'none';\n  apiKey?: string;\n  model?: string;\n  maxTokens?: number;\n  temperature?: number;\n}\n\nexport interface DevConfig {\n  port?: number;\n}\n\nexport interface ESLintConfig {\n  [key: string]: unknown;\n  extends?: string[];\n  rules?: Linter.RulesRecord;\n}\n\nexport interface LexConfigType {\n  ai?: AIConfig;\n  configFiles?: string[];\n  copyFiles?: string[];\n  dev?: DevConfig;\n  entryHTML?: string;\n  entryJs?: string;\n  env?: object | null;\n  eslint?: ESLintConfig;\n  gitUrl?: string;\n  vitest?: VitestConfig;\n  libraryName?: string;\n  libraryTarget?: string;\n  outputFile?: string;\n  outputFullPath?: string;\n  outputHash?: boolean;\n  outputPath?: string;\n  packageManager?: 'npm' | 'yarn';\n  preset?: 'web' | 'node' | 'lambda' | 'mobile';\n  sourceFullPath?: string;\n  sourcePath?: string;\n  swc?: SWCOptions;\n  targetEnvironment?: 'node' | 'web';\n  useGraphQl?: boolean;\n  useTypescript?: boolean;\n  webpack?: WebpackConfig;\n}\n\nexport type Config = LexConfigType;\n\nexport const defaultConfigValues: LexConfigType = {\n  ai: {\n    maxTokens: 4000,\n    model: 'gpt-4o',\n    provider: 'none',\n    temperature: 0.1\n  },\n  configFiles: [],\n  copyFiles: [],\n  entryHTML: 'index.html',\n  entryJs: 'index.js',\n  env: null,\n  eslint: {},\n  vitest: {},\n  outputFullPath: pathResolve(cwd, './lib'),\n  outputHash: false,\n  outputPath: './lib',\n  packageManager: 'npm',\n  preset: 'web',\n  sourceFullPath: pathResolve(cwd, './src'),\n  sourcePath: './src',\n  swc: {\n    inlineSourcesContent: true,\n    isModule: true,\n    jsc: {\n      externalHelpers: false,\n      keepClassNames: false,\n      loose: false,\n      parser: {\n        decorators: true,\n        dynamicImport: true,\n        syntax: 'typescript',\n        tsx: true\n      },\n      target: 'es2023',\n      transform: {\n        react: {\n          runtime: 'automatic'\n        }\n      }\n    },\n    minify: false,\n    module: {\n      lazy: false,\n      noInterop: false,\n      strict: false,\n      strictMode: true,\n      type: 'es6'\n    },\n    sourceMaps: 'inline'\n  },\n  targetEnvironment: 'web',\n  useGraphQl: false,\n  useTypescript: false,\n  webpack: {\n    staticPath: './src/static'\n  }\n};\n\nexport const getPackageDir = (): string => {\n  const cwd = process.cwd();\n  const currentPkgPath = pathResolve(cwd, 'package.json');\n\n  if(existsSync(currentPkgPath)) {\n    try {\n      const pkg = JSON.parse(readFileSync(currentPkgPath, 'utf8'));\n      if(!pkg.workspaces) {\n        return cwd;\n      }\n    } catch{\n      return cwd;\n    }\n  }\n\n  let searchDir = cwd;\n\n  for(let i = 0; i < 10; i++) {\n    const pkgPath = pathResolve(searchDir, 'package.json');\n    if(existsSync(pkgPath)) {\n      try {\n        const pkg = JSON.parse(readFileSync(pkgPath, 'utf8'));\n\n        if(!pkg.workspaces) {\n          return searchDir;\n        }\n      } catch{\n        // Continue searching\n      }\n    }\n\n    const parent = dirname(searchDir);\n\n    if(parent === searchDir) {\n      break;\n    }\n    searchDir = parent;\n  }\n\n  const configFormats = ['js', 'mjs', 'cjs', 'ts', 'json'];\n\n  for(const format of configFormats) {\n    const configPath = findFileUp.sync(`lex.config.${format}`, cwd, 5);\n\n    if(configPath) {\n      return dirname(configPath);\n    }\n  }\n\n  return cwd;\n};\n\nexport const getTypeScriptConfigPath = (configName: string): string => {\n  const packageDir = getPackageDir();\n  const cwd = process.cwd();\n\n  if(configName === 'tsconfig.build.json') {\n    const projectBuildConfig = pathResolve(packageDir, 'tsconfig.build.json');\n\n    if(existsSync(projectBuildConfig)) {\n      return projectBuildConfig;\n    }\n\n    const rootBuildConfig = pathResolve(cwd, 'tsconfig.build.json');\n    if(existsSync(rootBuildConfig)) {\n      return rootBuildConfig;\n    }\n  }\n\n  if(configName === 'tsconfig.lint.json') {\n    const projectLintConfig = pathResolve(packageDir, 'tsconfig.eslint.json');\n    if(existsSync(projectLintConfig)) {\n      return projectLintConfig;\n    }\n\n    const rootLintConfig = pathResolve(cwd, 'tsconfig.eslint.json');\n\n    if(existsSync(rootLintConfig)) {\n      return rootLintConfig;\n    }\n  }\n\n  if(configName === 'tsconfig.test.json') {\n    const projectTestConfig = pathResolve(packageDir, 'tsconfig.test.json');\n    if(existsSync(projectTestConfig)) {\n      return projectTestConfig;\n    }\n\n    const rootTestConfig = pathResolve(cwd, 'tsconfig.test.json');\n\n    if(existsSync(rootTestConfig)) {\n      return rootTestConfig;\n    }\n  }\n\n  const projectConfigPath = pathResolve(packageDir, configName);\n\n  if(existsSync(projectConfigPath)) {\n    return projectConfigPath;\n  }\n\n  const rootConfigPath = pathResolve(cwd, configName);\n\n  if(existsSync(rootConfigPath)) {\n    return rootConfigPath;\n  }\n\n  const lexDir = LexConfig.getLexDir();\n\n  return pathResolve(lexDir, configName);\n};\n\nexport class LexConfig {\n  static config: LexConfigType = {\n    ...defaultConfigValues\n  };\n\n  static set useTypescript(value: boolean) {\n    LexConfig.config.useTypescript = value;\n    const {entryJs, sourceFullPath, targetEnvironment} = LexConfig.config;\n\n    if(entryJs === 'index.js' && value) {\n      const indexPath: string = pathResolve(cwd, sourceFullPath || cwd, 'index.tsx');\n      const hasIndexTsx: boolean = existsSync(indexPath);\n\n      if(hasIndexTsx) {\n        LexConfig.config.entryJs = 'index.tsx';\n      } else {\n        LexConfig.config.entryJs = 'index.ts';\n      }\n    }\n\n    LexConfig.config.swc = LexConfig.config.swc || {...defaultConfigValues.swc!};\n    LexConfig.config.swc.jsc = LexConfig.config.swc.jsc || {...defaultConfigValues.swc!.jsc!};\n    LexConfig.config.swc.jsc.parser = {\n      syntax: 'typescript',\n      tsx: true\n    };\n\n    if(targetEnvironment === 'web') {\n      LexConfig.config.swc.jsc.transform = {\n        react: {\n          runtime: 'automatic'\n        }\n      };\n    }\n  }\n\n  static getLexDir(): string {\n    return dirname(getLexPackageJsonPath());\n  }\n\n  static updateConfig(updatedConfig: LexConfigType): LexConfigType {\n    const {outputFullPath, outputPath, sourcePath, sourceFullPath, useTypescript, ai} = updatedConfig;\n    const packageDir = getPackageDir();\n\n    if(useTypescript !== undefined) {\n      LexConfig.useTypescript = useTypescript;\n    }\n\n    if(outputPath !== undefined && outputFullPath === undefined) {\n      updatedConfig.outputFullPath = pathResolve(packageDir, outputPath);\n    }\n\n    if(sourcePath !== undefined && sourceFullPath === undefined) {\n      updatedConfig.sourceFullPath = pathResolve(packageDir, sourcePath);\n    }\n\n    if(ai) {\n      LexConfig.config.ai = {...LexConfig.config.ai, ...ai};\n\n      if(process.env.CURSOR_IDE === 'true' && LexConfig.config.ai.provider === 'none') {\n        LexConfig.config.ai.provider = 'cursor';\n      }\n    }\n\n    LexConfig.config = {...LexConfig.config, ...updatedConfig};\n\n    return LexConfig.config;\n  }\n\n  static addConfigParams(cmd: Record<string, any>, params: LexConfigType) {\n    const nameProperty: string = '_name';\n    const {environment, outputPath, sourcePath, typescript} = cmd;\n    const packageDir = getPackageDir();\n\n    if(outputPath !== undefined) {\n      params.outputPath = outputPath;\n      params.outputFullPath = pathResolve(packageDir, outputPath);\n    } else if(params.outputPath && !params.outputFullPath) {\n      params.outputFullPath = pathResolve(packageDir, params.outputPath);\n    }\n\n    if(sourcePath !== undefined) {\n      params.sourcePath = sourcePath;\n      params.sourceFullPath = pathResolve(packageDir, sourcePath);\n    } else if(params.sourcePath && !params.sourceFullPath) {\n      params.sourceFullPath = pathResolve(packageDir, params.sourcePath);\n    }\n\n    if(typescript !== undefined) {\n      params.useTypescript = true;\n    }\n\n    if(environment !== undefined) {\n      params.targetEnvironment = environment === 'web' ? 'web' : 'node';\n    }\n\n    process.env.LEX_CONFIG = JSON.stringify(\n      {\n        ...LexConfig.updateConfig(params),\n        commandName: cmd[nameProperty],\n        isStatic: cmd.static\n      }, null, 0\n    );\n  }\n\n  static async parseConfig(cmd: Record<string, any>, isRoot: boolean = true): Promise<void> {\n    const {cliName = 'Lex', lexConfig, lexConfigName, quiet, typescript, debug = false} = cmd;\n    const configFormats = ['js', 'mjs', 'cjs', 'ts', 'json'];\n    const configBaseName: string = lexConfigName || 'lex.config';\n    let configPath: string = lexConfig || '';\n    let configExists: boolean = lexConfig ? existsSync(configPath) : false;\n\n    if(!configPath || !configExists) {\n      if(debug) {\n        log(`Searching for config files with base name: ${configBaseName}`, 'info', quiet);\n      }\n\n      for(const format of configFormats) {\n        const potentialPath = isRoot\n          ? pathResolve(cwd, `./${configBaseName}.${format}`)\n          : relativeFilePath(`${configBaseName}.${format}`, cwd);\n\n        if(debug) {\n          log(`Checking for config file: ${potentialPath}`, 'info', quiet);\n        }\n\n        if(existsSync(potentialPath)) {\n          configPath = potentialPath;\n          configExists = true;\n          break;\n        }\n      }\n    }\n\n    if(configExists) {\n      log(`Using ${cliName} configuration file: ${configPath}`, 'note', quiet);\n      const ext: string = pathExtname(configPath);\n\n      if(ext === '.json') {\n        const configContent: string = readFileSync(configPath, 'utf8');\n\n        if(configContent) {\n          let configJson: LexConfigType;\n\n          try {\n            configJson = JSON.parse(configContent)?.default || {};\n          } catch(error) {\n            log(`\\n${cliName} Error: Failed to parse JSON config: ${error.message}`, 'error', quiet);\n            configJson = {};\n          }\n\n          LexConfig.addConfigParams(cmd, configJson);\n        } else {\n          log(`\\n${cliName} Error: Config file malformed, ${configPath}`, 'error', quiet);\n        }\n      } else if(['.js', '.mjs', '.cjs', '.ts'].includes(ext)) {\n        try {\n          let lexCustomConfig;\n\n          if(ext === '.cjs') {\n            const fileUrl = new URL(`file:///${pathResolve(configPath)}`).href;\n\n            if(debug) {\n              log(`Loading CommonJS config from: ${fileUrl}`, 'info', quiet);\n            }\n            lexCustomConfig = await import(fileUrl);\n          } else {\n            if(debug) {\n              log(`Loading ESM/TS config from: ${configPath}`, 'info', quiet);\n            }\n\n            lexCustomConfig = await import(configPath);\n          }\n\n          const config = lexCustomConfig.default || lexCustomConfig;\n\n          if(debug) {\n            log(`Loaded config: ${JSON.stringify(config, null, 2)}`, 'info', quiet);\n          }\n\n          if(!config) {\n            log(`\\n${cliName} Warning: Config file loaded but no configuration found`, 'warn', quiet);\n          }\n\n          LexConfig.addConfigParams(cmd, config || {});\n        } catch(error) {\n          log(`\\n${cliName} Error: Failed to load config file: ${error.message}`, 'error', quiet);\n          if(debug) {\n            // eslint-disable-next-line no-console\n            console.error(error);\n          }\n        }\n      } else {\n        log(`\\n${cliName} Error: Config file must be a JS, CJS, MJS, TS, or JSON file.`, 'error', quiet);\n      }\n    } else {\n      if(debug) {\n        log('No config file found. Using default configuration.', 'info', quiet);\n      }\n\n      LexConfig.useTypescript = !!typescript;\n      LexConfig.addConfigParams(cmd, LexConfig.config);\n    }\n  }\n\n  static checkTypescriptConfig() {\n    const packageDir = getPackageDir();\n    const tsconfigPath: string = pathResolve(packageDir, './tsconfig.json');\n\n    if(!existsSync(tsconfigPath)) {\n      const lexDir = LexConfig.getLexDir();\n      const baseConfigPath = pathResolve(lexDir, 'tsconfig.base.json');\n      const templateConfigPath = pathResolve(lexDir, 'tsconfig.template.json');\n      const sourcePath = existsSync(baseConfigPath) ? baseConfigPath : templateConfigPath;\n\n      if(existsSync(sourcePath)) {\n        writeFileSync(tsconfigPath, readFileSync(sourcePath));\n      }\n    }\n  }\n\n  static getTypeScriptDeclarationFlags(): string[] {\n    const cwd = process.cwd();\n    const outputPath = LexConfig.config.outputPath || './lib';\n    const outputFullPath = LexConfig.config.outputFullPath || pathResolve(cwd, outputPath);\n    const sourcePath = LexConfig.config.sourcePath || './src';\n    const sourceFullPath = LexConfig.config.sourceFullPath || pathResolve(cwd, sourcePath);\n    const relativeOutDir = pathRelative(cwd, outputFullPath) || './lib';\n    const relativeRootDir = pathRelative(cwd, sourceFullPath) || './src';\n\n    return [\n      '--emitDeclarationOnly', // CRITICAL: Only emit .d.ts files, no JS files\n      '--declaration', // Generate declaration files\n      '--declarationMap', // Generate source maps for declarations\n      '--outDir', relativeOutDir,\n      '--rootDir', relativeRootDir,\n      '--skipLibCheck', // Skip type checking of declaration files (faster, more lenient)\n      '--esModuleInterop',\n      '--allowSyntheticDefaultImports',\n      '--module', 'NodeNext',\n      '--moduleResolution', 'NodeNext',\n      '--target', 'ESNext',\n      '--jsx', 'react-jsx',\n      '--isolatedModules',\n      '--resolveJsonModule',\n      '--allowJs'\n      // Note: --noUnusedLocals and --noUnusedParameters are not needed for declaration generation\n      // and would actually enable strict checking, which we want to avoid for faster declaration generation\n    ];\n  }\n\n  static checkLintTypescriptConfig() {\n    const lexDir = LexConfig.getLexDir();\n    const tsconfigLintPath: string = pathResolve(lexDir, './tsconfig.lint.json');\n\n    if(!existsSync(tsconfigLintPath)) {\n      const templatePath = pathResolve(lexDir, 'tsconfig.lint.json');\n      if(existsSync(templatePath)) {\n        writeFileSync(tsconfigLintPath, readFileSync(templatePath));\n      }\n    }\n  }\n\n  static checkTestTypescriptConfig() {\n    const lexDir = LexConfig.getLexDir();\n    const tsconfigTestPath: string = pathResolve(lexDir, './tsconfig.test.json');\n\n    if(!existsSync(tsconfigTestPath)) {\n      const templatePath = pathResolve(lexDir, 'tsconfig.test.json');\n      if(existsSync(templatePath)) {\n        writeFileSync(tsconfigTestPath, readFileSync(templatePath));\n      }\n    }\n  }\n}\n\nexport type SWCOptions = Options;\n"],"names":["findFileUp","existsSync","readFileSync","writeFileSync","dirname","extname","pathExtname","relative","pathRelative","resolve","pathResolve","URL","getLexPackageJsonPath","relativeFilePath","log","cwd","process","defaultConfigValues","ai","maxTokens","model","provider","temperature","configFiles","copyFiles","entryHTML","entryJs","env","eslint","vitest","outputFullPath","outputHash","outputPath","packageManager","preset","sourceFullPath","sourcePath","swc","inlineSourcesContent","isModule","jsc","externalHelpers","keepClassNames","loose","parser","decorators","dynamicImport","syntax","tsx","target","transform","react","runtime","minify","module","lazy","noInterop","strict","strictMode","type","sourceMaps","targetEnvironment","useGraphQl","useTypescript","webpack","staticPath","getPackageDir","currentPkgPath","pkg","JSON","parse","workspaces","searchDir","i","pkgPath","parent","configFormats","format","configPath","sync","getTypeScriptConfigPath","configName","packageDir","projectBuildConfig","rootBuildConfig","projectLintConfig","rootLintConfig","projectTestConfig","rootTestConfig","projectConfigPath","rootConfigPath","lexDir","LexConfig","getLexDir","value","config","indexPath","hasIndexTsx","updateConfig","updatedConfig","undefined","CURSOR_IDE","addConfigParams","cmd","params","nameProperty","environment","typescript","LEX_CONFIG","stringify","commandName","isStatic","static","parseConfig","isRoot","cliName","lexConfig","lexConfigName","quiet","debug","configBaseName","configExists","potentialPath","ext","configContent","configJson","default","error","message","includes","lexCustomConfig","fileUrl","href","console","checkTypescriptConfig","tsconfigPath","baseConfigPath","templateConfigPath","getTypeScriptDeclarationFlags","relativeOutDir","relativeRootDir","checkLintTypescriptConfig","tsconfigLintPath","templatePath","checkTestTypescriptConfig","tsconfigTestPath"],"mappings":"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"}
@@ -1,3 +1,4 @@
1
+ import type { Spinner } from '../../utils/app.js';
1
2
  export interface BuildOptions {
2
3
  readonly assist?: boolean;
3
4
  readonly analyze?: boolean;
@@ -15,7 +16,7 @@ export interface BuildOptions {
15
16
  readonly watch?: boolean;
16
17
  }
17
18
  export type BuildCallback = (status: number) => void;
18
- export declare const buildWithSWC: (spinner: any, commandOptions: BuildOptions, callback: BuildCallback) => Promise<1 | 0>;
19
- export declare const buildWithWebpack: (spinner: any, cmd: any, callback: any) => Promise<1 | 0>;
19
+ export declare const buildWithSWC: (spinner: Spinner, commandOptions: BuildOptions, callback: BuildCallback) => Promise<1 | 0>;
20
+ export declare const buildWithWebpack: (spinner: Spinner, cmd: Record<string, any>, callback: BuildCallback) => Promise<1 | 0>;
20
21
  export declare const build: (cmd: BuildOptions, callback?: BuildCallback) => Promise<number>;
21
22
  export default build;
@@ -85,7 +85,7 @@ export const buildWithSWC = async (spinner, commandOptions, callback)=>{
85
85
  });
86
86
  await Promise.all(transformPromises);
87
87
  spinner.succeed('Build completed with SWC');
88
- displayBuildStatus('SWC', outputDir, quiet);
88
+ displayBuildStatus('SWC', outputDir, quiet ?? false);
89
89
  callback(0);
90
90
  return 0;
91
91
  } catch (error) {
@@ -440,4 +440,4 @@ What are the key optimization opportunities for this build configuration? Consid
440
440
  };
441
441
  export default build;
442
442
 
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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"}
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';\nimport type {Spinner} from '../../utils/app.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: 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 ?? false);\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 (\n  spinner: Spinner,\n  cmd: Record<string, any>,\n  callback: BuildCallback\n) => {\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: number) => {\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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"}