@nlabs/lex 1.52.0 → 1.52.2

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.
package/lib/LexConfig.js CHANGED
@@ -153,13 +153,18 @@ export class LexConfig {
153
153
  static addConfigParams(cmd, params) {
154
154
  const nameProperty = '_name';
155
155
  const { environment, outputPath, sourcePath, typescript } = cmd;
156
+ const currentCwd = process.cwd();
156
157
  if (outputPath !== undefined) {
157
158
  params.outputPath = outputPath;
158
- params.outputFullPath = pathResolve(cwd, outputPath);
159
+ params.outputFullPath = pathResolve(currentCwd, outputPath);
160
+ } else if (params.outputPath && !params.outputFullPath) {
161
+ params.outputFullPath = pathResolve(currentCwd, params.outputPath);
159
162
  }
160
163
  if (sourcePath !== undefined) {
161
164
  params.sourcePath = sourcePath;
162
- params.sourceFullPath = pathResolve(cwd, sourcePath);
165
+ params.sourceFullPath = pathResolve(currentCwd, sourcePath);
166
+ } else if (params.sourcePath && !params.sourceFullPath) {
167
+ params.sourceFullPath = pathResolve(currentCwd, params.sourcePath);
163
168
  }
164
169
  if (typescript !== undefined) {
165
170
  params.useTypescript = true;
@@ -328,4 +333,4 @@ _define_property(LexConfig, "config", {
328
333
  ...defaultConfigValues
329
334
  });
330
335
 
331
- //# 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 {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 {getDirName, getLexPackageJsonPath, relativeFilePath} from './utils/file.js';\nimport {log} from './utils/log.js';\n\nimport type {Linter} from 'eslint';\n\nconst cwd: string = process.cwd();\n\n\nexport interface JestConfig {\n  [key: string]: unknown;\n  roots?: string[];\n  testEnvironment?: string;\n  transform?: Record<string, [string, Record<string, unknown>]>;\n  transformIgnorePatterns?: string[];\n  moduleNameMapper?: Record<string, string>;\n  extensionsToTreatAsEsm?: string[];\n  preset?: string;\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 ESLintConfig {\n  [key: string]: unknown;\n  extends?: string[];\n  rules?: Linter.RulesRecord;\n}\n\nexport interface SWCConfig {\n  jsc?: {\n    parser?: {\n      syntax?: 'typescript' | 'ecmascript';\n      tsx?: boolean;\n      decorators?: boolean;\n      dynamicImport?: boolean;\n    };\n    target?: 'es3' | 'es5' | 'es2015' | 'es2016' | 'es2017' | 'es2018' | 'es2019' | 'es2020' | 'es2021' | 'es2022' | 'es2023';\n    transform?: {\n      react?: {\n        runtime?: 'automatic' | 'classic';\n        pragma?: string;\n        pragmaFrag?: string;\n        throwIfNamespace?: boolean;\n        development?: boolean;\n        useBuiltins?: boolean;\n        refresh?: boolean;\n      };\n    };\n    externalHelpers?: boolean;\n    keepClassNames?: boolean;\n    loose?: boolean;\n    minify?: {\n      compress?: boolean;\n      mangle?: boolean;\n    };\n  };\n  module?: {\n    type?: 'es6' | 'commonjs' | 'amd' | 'umd' | 'systemjs';\n    strict?: boolean;\n    strictMode?: boolean;\n    lazy?: boolean;\n    noInterop?: boolean;\n  };\n  minify?: boolean;\n  sourceMaps?: boolean | 'inline';\n  inlineSourcesContent?: boolean;\n  isModule?: boolean;\n  filename?: string;\n  configFile?: string;\n  swcrc?: boolean;\n  env?: {\n    targets?: string | string[] | Record<string, string>;\n    mode?: 'usage' | 'entry';\n    coreJs?: string;\n    path?: string;\n    debug?: boolean;\n    dynamicImport?: boolean;\n    loose?: boolean;\n    bugfixes?: boolean;\n    include?: string[];\n    exclude?: string[];\n    forceAllTransforms?: boolean;\n    modules?: 'amd' | 'umd' | 'systemjs' | 'auto' | false;\n    shippedProposals?: boolean;\n  };\n}\n\nexport interface LexConfigType {\n  ai?: AIConfig;\n  configFiles?: string[];\n  copyFiles?: string[];\n  entryHTML?: string;\n  entryJs?: string;\n  env?: object;\n  eslint?: ESLintConfig;\n  gitUrl?: string;\n  jest?: JestConfig;\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?: SWCConfig;\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  jest: {},\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: 'es2020',\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 getTypeScriptConfigPath = (configName: string): string => {\n  const cwd = process.cwd();\n\n  if(configName === 'tsconfig.build.json') {\n    const projectBuildConfig = pathResolve(cwd, 'tsconfig.build.json');\n    if(existsSync(projectBuildConfig)) {\n      return projectBuildConfig;\n    }\n  }\n\n  if(configName === 'tsconfig.lint.json') {\n    const projectLintConfig = pathResolve(cwd, 'tsconfig.eslint.json');\n    if(existsSync(projectLintConfig)) {\n      return projectLintConfig;\n    }\n  }\n\n  if(configName === 'tsconfig.test.json') {\n    const projectTestConfig = pathResolve(cwd, 'tsconfig.test.json');\n    if(existsSync(projectTestConfig)) {\n      return projectTestConfig;\n    }\n  }\n\n  const projectConfigPath = pathResolve(cwd, configName);\n  if(existsSync(projectConfigPath)) {\n    return projectConfigPath;\n  }\n\n  const lexDir = LexConfig.getLexDir();\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 {sourceFullPath} = LexConfig.config;\n\n    const {entryJs} = 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\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 cwd: string = process.cwd();\n\n    if(useTypescript !== undefined) {\n      LexConfig.useTypescript = useTypescript;\n    }\n\n    if(outputPath !== undefined && outputFullPath === undefined) {\n      updatedConfig.outputFullPath = pathResolve(cwd, outputPath);\n    }\n\n    if(sourcePath !== undefined && sourceFullPath === undefined) {\n      updatedConfig.sourceFullPath = pathResolve(cwd, 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\n    if(outputPath !== undefined) {\n      params.outputPath = outputPath;\n      params.outputFullPath = pathResolve(cwd, outputPath);\n    }\n\n    if(sourcePath !== undefined) {\n      params.sourcePath = sourcePath;\n      params.sourceFullPath = pathResolve(cwd, 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 tsconfigPath: string = pathResolve(cwd, './tsconfig.json');\n\n    if(!existsSync(tsconfigPath)) {\n      const dirName = getDirName();\n      writeFileSync(tsconfigPath, readFileSync(pathResolve(dirName, '../../../tsconfig.base.json')));\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}"],"names":["existsSync","readFileSync","writeFileSync","dirname","extname","pathExtname","relative","pathRelative","resolve","pathResolve","URL","getDirName","getLexPackageJsonPath","relativeFilePath","log","cwd","process","defaultConfigValues","ai","maxTokens","model","provider","temperature","configFiles","copyFiles","entryHTML","entryJs","env","eslint","jest","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","getTypeScriptConfigPath","configName","projectBuildConfig","projectLintConfig","projectTestConfig","projectConfigPath","lexDir","LexConfig","getLexDir","value","config","indexPath","hasIndexTsx","updateConfig","updatedConfig","undefined","CURSOR_IDE","addConfigParams","cmd","params","nameProperty","environment","typescript","LEX_CONFIG","JSON","stringify","commandName","isStatic","static","parseConfig","isRoot","cliName","lexConfig","lexConfigName","quiet","debug","configFormats","configBaseName","configPath","configExists","format","potentialPath","ext","configContent","configJson","parse","default","error","message","includes","lexCustomConfig","fileUrl","href","console","checkTypescriptConfig","tsconfigPath","dirName","getTypeScriptDeclarationFlags","relativeOutDir","relativeRootDir","checkLintTypescriptConfig","tsconfigLintPath","templatePath","checkTestTypescriptConfig","tsconfigTestPath"],"mappings":"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"}
336
+ //# 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 {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 {getDirName, getLexPackageJsonPath, relativeFilePath} from './utils/file.js';\nimport {log} from './utils/log.js';\n\nimport type {Linter} from 'eslint';\n\nconst cwd: string = process.cwd();\n\n\nexport interface JestConfig {\n  [key: string]: unknown;\n  roots?: string[];\n  testEnvironment?: string;\n  transform?: Record<string, [string, Record<string, unknown>]>;\n  transformIgnorePatterns?: string[];\n  moduleNameMapper?: Record<string, string>;\n  extensionsToTreatAsEsm?: string[];\n  preset?: string;\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 ESLintConfig {\n  [key: string]: unknown;\n  extends?: string[];\n  rules?: Linter.RulesRecord;\n}\n\nexport interface SWCConfig {\n  jsc?: {\n    parser?: {\n      syntax?: 'typescript' | 'ecmascript';\n      tsx?: boolean;\n      decorators?: boolean;\n      dynamicImport?: boolean;\n    };\n    target?: 'es3' | 'es5' | 'es2015' | 'es2016' | 'es2017' | 'es2018' | 'es2019' | 'es2020' | 'es2021' | 'es2022' | 'es2023';\n    transform?: {\n      react?: {\n        runtime?: 'automatic' | 'classic';\n        pragma?: string;\n        pragmaFrag?: string;\n        throwIfNamespace?: boolean;\n        development?: boolean;\n        useBuiltins?: boolean;\n        refresh?: boolean;\n      };\n    };\n    externalHelpers?: boolean;\n    keepClassNames?: boolean;\n    loose?: boolean;\n    minify?: {\n      compress?: boolean;\n      mangle?: boolean;\n    };\n  };\n  module?: {\n    type?: 'es6' | 'commonjs' | 'amd' | 'umd' | 'systemjs';\n    strict?: boolean;\n    strictMode?: boolean;\n    lazy?: boolean;\n    noInterop?: boolean;\n  };\n  minify?: boolean;\n  sourceMaps?: boolean | 'inline';\n  inlineSourcesContent?: boolean;\n  isModule?: boolean;\n  filename?: string;\n  configFile?: string;\n  swcrc?: boolean;\n  env?: {\n    targets?: string | string[] | Record<string, string>;\n    mode?: 'usage' | 'entry';\n    coreJs?: string;\n    path?: string;\n    debug?: boolean;\n    dynamicImport?: boolean;\n    loose?: boolean;\n    bugfixes?: boolean;\n    include?: string[];\n    exclude?: string[];\n    forceAllTransforms?: boolean;\n    modules?: 'amd' | 'umd' | 'systemjs' | 'auto' | false;\n    shippedProposals?: boolean;\n  };\n}\n\nexport interface LexConfigType {\n  ai?: AIConfig;\n  configFiles?: string[];\n  copyFiles?: string[];\n  entryHTML?: string;\n  entryJs?: string;\n  env?: object;\n  eslint?: ESLintConfig;\n  gitUrl?: string;\n  jest?: JestConfig;\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?: SWCConfig;\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  jest: {},\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: 'es2020',\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 getTypeScriptConfigPath = (configName: string): string => {\n  const cwd = process.cwd();\n\n  if(configName === 'tsconfig.build.json') {\n    const projectBuildConfig = pathResolve(cwd, 'tsconfig.build.json');\n    if(existsSync(projectBuildConfig)) {\n      return projectBuildConfig;\n    }\n  }\n\n  if(configName === 'tsconfig.lint.json') {\n    const projectLintConfig = pathResolve(cwd, 'tsconfig.eslint.json');\n    if(existsSync(projectLintConfig)) {\n      return projectLintConfig;\n    }\n  }\n\n  if(configName === 'tsconfig.test.json') {\n    const projectTestConfig = pathResolve(cwd, 'tsconfig.test.json');\n    if(existsSync(projectTestConfig)) {\n      return projectTestConfig;\n    }\n  }\n\n  const projectConfigPath = pathResolve(cwd, configName);\n  if(existsSync(projectConfigPath)) {\n    return projectConfigPath;\n  }\n\n  const lexDir = LexConfig.getLexDir();\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 {sourceFullPath} = LexConfig.config;\n\n    const {entryJs} = 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\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 cwd: string = process.cwd();\n\n    if(useTypescript !== undefined) {\n      LexConfig.useTypescript = useTypescript;\n    }\n\n    if(outputPath !== undefined && outputFullPath === undefined) {\n      updatedConfig.outputFullPath = pathResolve(cwd, outputPath);\n    }\n\n    if(sourcePath !== undefined && sourceFullPath === undefined) {\n      updatedConfig.sourceFullPath = pathResolve(cwd, 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 currentCwd = process.cwd();\n\n    if(outputPath !== undefined) {\n      params.outputPath = outputPath;\n      params.outputFullPath = pathResolve(currentCwd, outputPath);\n    } else if(params.outputPath && !params.outputFullPath) {\n      params.outputFullPath = pathResolve(currentCwd, params.outputPath);\n    }\n\n    if(sourcePath !== undefined) {\n      params.sourcePath = sourcePath;\n      params.sourceFullPath = pathResolve(currentCwd, sourcePath);\n    } else if(params.sourcePath && !params.sourceFullPath) {\n      params.sourceFullPath = pathResolve(currentCwd, 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 tsconfigPath: string = pathResolve(cwd, './tsconfig.json');\n\n    if(!existsSync(tsconfigPath)) {\n      const dirName = getDirName();\n      writeFileSync(tsconfigPath, readFileSync(pathResolve(dirName, '../../../tsconfig.base.json')));\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}"],"names":["existsSync","readFileSync","writeFileSync","dirname","extname","pathExtname","relative","pathRelative","resolve","pathResolve","URL","getDirName","getLexPackageJsonPath","relativeFilePath","log","cwd","process","defaultConfigValues","ai","maxTokens","model","provider","temperature","configFiles","copyFiles","entryHTML","entryJs","env","eslint","jest","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","getTypeScriptConfigPath","configName","projectBuildConfig","projectLintConfig","projectTestConfig","projectConfigPath","lexDir","LexConfig","getLexDir","value","config","indexPath","hasIndexTsx","updateConfig","updatedConfig","undefined","CURSOR_IDE","addConfigParams","cmd","params","nameProperty","environment","typescript","currentCwd","LEX_CONFIG","JSON","stringify","commandName","isStatic","static","parseConfig","isRoot","cliName","lexConfig","lexConfigName","quiet","debug","configFormats","configBaseName","configPath","configExists","format","potentialPath","ext","configContent","configJson","parse","default","error","message","includes","lexCustomConfig","fileUrl","href","console","checkTypescriptConfig","tsconfigPath","dirName","getTypeScriptDeclarationFlags","relativeOutDir","relativeRootDir","checkLintTypescriptConfig","tsconfigLintPath","templatePath","checkTestTypescriptConfig","tsconfigTestPath"],"mappings":"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"}
@@ -5,7 +5,7 @@
5
5
  import { execa } from 'execa';
6
6
  import { existsSync, readFileSync } from 'fs';
7
7
  import { sync as globSync } from 'glob';
8
- import { dirname, resolve as pathResolve } from 'path';
8
+ import { dirname, relative as pathRelative, resolve as pathResolve } from 'path';
9
9
  import { LexConfig } from '../../LexConfig.js';
10
10
  import { checkLinkedModules, copyConfiguredFiles, createSpinner, handleWebpackProgress, removeFiles } from '../../utils/app.js';
11
11
  import { resolveWebpackPaths, getLexPackageJsonPath, resolveBinaryPath } from '../../utils/file.js';
@@ -38,17 +38,16 @@ const displayBuildStatus = (bundler, outputPath, quiet, stats)=>{
38
38
  });
39
39
  console.log('\n' + statusBox + '\n');
40
40
  };
41
- // Removed buildWithEsBuild function - using SWC instead
42
41
  export const buildWithSWC = async (spinner, commandOptions, callback)=>{
43
42
  const { cliName = 'Lex', format = 'esm', outputPath, quiet, sourcePath, watch } = commandOptions;
44
43
  const { outputFullPath, sourceFullPath, swc: swcConfig, targetEnvironment, useGraphQl, useTypescript } = LexConfig.config;
45
44
  const sourceDir = sourcePath ? pathResolve(process.cwd(), `./${sourcePath}`) : sourceFullPath || '';
46
45
  const globOptions = {
46
+ absolute: true,
47
47
  cwd: sourceDir,
48
48
  dot: false,
49
49
  nodir: true,
50
- nosort: true,
51
- absolute: true
50
+ nosort: true
52
51
  };
53
52
  const tsFiles = globSync(`**/!(*.spec|*.test).ts*`, globOptions);
54
53
  const jsFiles = globSync(`**/!(*.spec|*.test).js`, globOptions);
@@ -56,12 +55,14 @@ export const buildWithSWC = async (spinner, commandOptions, callback)=>{
56
55
  ...tsFiles,
57
56
  ...jsFiles
58
57
  ];
59
- const outputDir = outputPath || outputFullPath || '';
58
+ const outputDir = outputPath ? pathResolve(process.cwd(), outputPath) : outputFullPath || pathResolve(process.cwd(), './lib');
60
59
  try {
61
60
  spinner.start('Building with SWC...');
62
- for (const file of sourceFiles){
63
- const sourcePath = pathResolve(sourceDir, file);
64
- const outputPath = pathResolve(outputDir, file.replace(/\.(ts|tsx)$/, '.js'));
61
+ const transformPromises = sourceFiles.map(async (file)=>{
62
+ const fileRelativeToSource = pathRelative(sourceDir, file);
63
+ const sourcePath = file; // file is already absolute
64
+ const outputFile = fileRelativeToSource.replace(/\.(ts|tsx)$/, '.js');
65
+ const outputPath = pathResolve(outputDir, outputFile);
65
66
  const outputDirPath = dirname(outputPath);
66
67
  if (!existsSync(outputDirPath)) {
67
68
  const { mkdirSync } = await import('fs');
@@ -77,12 +78,13 @@ export const buildWithSWC = async (spinner, commandOptions, callback)=>{
77
78
  jsc: {
78
79
  ...swcConfig?.jsc,
79
80
  parser: {
80
- syntax: 'typescript',
81
- tsx: isTSX,
81
+ comments: false,
82
82
  decorators: swcConfig?.jsc?.parser?.decorators ?? true,
83
83
  dynamicImport: swcConfig?.jsc?.parser?.dynamicImport ?? true,
84
- comments: false // Remove comments during transformation
84
+ syntax: 'typescript',
85
+ tsx: isTSX
85
86
  },
87
+ preserveAllComments: false,
86
88
  target: swcConfig?.jsc?.target ?? 'es2020',
87
89
  transform: isTSX ? {
88
90
  ...swcConfig?.jsc?.transform,
@@ -90,20 +92,20 @@ export const buildWithSWC = async (spinner, commandOptions, callback)=>{
90
92
  runtime: 'automatic',
91
93
  ...swcConfig?.jsc?.transform?.react
92
94
  }
93
- } : swcConfig?.jsc?.transform,
94
- preserveAllComments: false
95
+ } : swcConfig?.jsc?.transform
95
96
  },
97
+ minify: false,
96
98
  module: {
97
99
  ...swcConfig?.module,
98
100
  type: format === 'cjs' ? 'commonjs' : swcConfig?.module?.type || 'es6'
99
101
  },
100
- minify: false,
101
102
  sourceMaps: swcConfig?.sourceMaps || 'inline'
102
103
  };
103
104
  const result = await transform(sourceCode, swcOptions);
104
105
  const { writeFileSync } = await import('fs');
105
106
  writeFileSync(outputPath, result.code);
106
- }
107
+ });
108
+ await Promise.all(transformPromises);
107
109
  spinner.succeed('Build completed with SWC');
108
110
  displayBuildStatus('SWC', outputDir, quiet);
109
111
  callback(0);
@@ -115,7 +117,6 @@ export const buildWithSWC = async (spinner, commandOptions, callback)=>{
115
117
  if (error.stack) {
116
118
  log(`\nStack Trace:\n${error.stack}`, 'error', quiet);
117
119
  }
118
- // Try to extract file information if available
119
120
  if ('filename' in error || 'file' in error) {
120
121
  log(`\nFile: ${error.filename || error.file}`, 'error', quiet);
121
122
  }
@@ -175,7 +176,6 @@ export const buildWithWebpack = async (spinner, cmd, callback)=>{
175
176
  if (defineProcessEnvNodeEnv) webpackOptions.push('--defineProcessEnvNodeEnv', defineProcessEnvNodeEnv);
176
177
  if (devtool) webpackOptions.push('--devtool', devtool);
177
178
  if (disableInterpret) webpackOptions.push('--disableInterpret');
178
- // Pass entry directly as CLI flag
179
179
  if (entryValue) webpackOptions.push('--entry', entryValue.toString());
180
180
  if (env) webpackOptions.push('--env', env);
181
181
  if (failOnWarnings) webpackOptions.push('--failOnWarnings');
@@ -218,7 +218,6 @@ export const buildWithWebpack = async (spinner, cmd, callback)=>{
218
218
  console.log('executablePath:', executablePath);
219
219
  console.log('finalWebpackOptions:', JSON.stringify(finalWebpackOptions));
220
220
  console.log('finalWebpackOptions type:', Array.isArray(finalWebpackOptions) ? 'Array' : typeof finalWebpackOptions);
221
- // Make sure we're passing an array of strings to execa
222
221
  const childProcess = execa(executablePath, finalWebpackOptions, {
223
222
  encoding: 'utf8',
224
223
  stdio: 'pipe'
@@ -323,13 +322,11 @@ export const build = async (cmd, callback = ()=>({}))=>{
323
322
  ...process.env,
324
323
  ...variablesObj
325
324
  };
326
- // If in test mode, exit early
327
325
  if (test) {
328
326
  log('Test mode: Build environment loaded, exiting', 'info', quiet);
329
327
  callback(0);
330
328
  return 0;
331
329
  }
332
- // Process translations if flag is enabled (before building)
333
330
  if (translations) {
334
331
  spinner.start('Processing translations...');
335
332
  try {
@@ -420,7 +417,7 @@ What are the key optimization opportunities for this build configuration? Consid
420
417
  encoding: 'utf8',
421
418
  cwd: process.cwd(),
422
419
  reject: false,
423
- all: true // Capture both stdout and stderr
420
+ all: true
424
421
  });
425
422
  if (result.exitCode !== 0) {
426
423
  // TypeScript may have errors but still generate some declarations
@@ -428,12 +425,10 @@ What are the key optimization opportunities for this build configuration? Consid
428
425
  const hasDeclarations = result.all?.includes('Writing') || result.all?.includes('Declaration') || false;
429
426
  const errorOutput = result.stderr || result.stdout || result.all || 'Unknown error';
430
427
  if (!hasDeclarations) {
431
- // Show detailed error information
432
428
  log(`\n${cliName} Error: TypeScript declaration generation failed`, 'error', quiet);
433
429
  log(`\nExit Code: ${result.exitCode}`, 'error', quiet);
434
430
  log(`\nTypeScript Command: ${typescriptPath} ${typescriptOptions.slice(0, 10).join(' ')}...`, 'error', quiet);
435
431
  log(`\nError Output:\n${errorOutput}`, 'error', quiet);
436
- // Try to extract and highlight specific errors
437
432
  const errorLines = errorOutput.split('\n').filter((line)=>line.includes('error TS') || line.includes('Error:') || line.trim().startsWith('src/') || line.trim().startsWith('TS'));
438
433
  if (errorLines.length > 0) {
439
434
  log(`\nKey Errors:`, 'error', quiet);
@@ -456,14 +451,12 @@ What are the key optimization opportunities for this build configuration? Consid
456
451
  spinner.succeed('TypeScript declarations generated!');
457
452
  }
458
453
  } catch (error) {
459
- // If execa throws (shouldn't with reject: false), log and continue
460
454
  log(`\n${cliName} Error: TypeScript declaration generation exception`, 'error', quiet);
461
455
  log(`\nError: ${error.message}`, 'error', quiet);
462
456
  if (error instanceof Error && error.stack) {
463
457
  log(`\nStack:\n${error.stack}`, 'error', quiet);
464
458
  }
465
459
  spinner.fail('TypeScript declaration generation had issues (continuing anyway).');
466
- // Don't fail the build if declarations fail
467
460
  }
468
461
  }
469
462
  }
@@ -479,4 +472,4 @@ What are the key optimization opportunities for this build configuration? Consid
479
472
  };
480
473
  export default build;
481
474
 
482
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/commands/build/build.ts"],"sourcesContent":["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {transform} from '@swc/core';\nimport {execa} from 'execa';\nimport {existsSync, readFileSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport {dirname, resolve as pathResolve} from 'path';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {checkLinkedModules, copyConfiguredFiles, createSpinner, createProgressBar, handleWebpackProgress, removeFiles} from '../../utils/app.js';\nimport {\n  resolveWebpackPaths,\n  getLexPackageJsonPath,\n  resolveBinaryPath\n} from '../../utils/file.js';\nimport {log} from '../../utils/log.js';\nimport {processTranslations} from '../../utils/translations.js';\nimport {aiFunction} from '../ai/ai.js';\nimport boxen from 'boxen';\nimport chalk from 'chalk';\n\nlet currentFilename: string;\nlet currentDirname: string;\n\ntry {\n  currentFilename = eval('require(\"url\").fileURLToPath(import.meta.url)');\n  currentDirname = dirname(currentFilename);\n} catch {\n  currentFilename = process.cwd();\n  currentDirname = process.cwd();\n}\n\nexport interface BuildOptions {\n  readonly assist?: boolean;\n  readonly analyze?: boolean;\n  readonly bundler?: 'webpack' | 'swc';\n  readonly cliName?: string;\n  readonly entry?: string; // <-- add entry\n  readonly format?: string;\n  readonly outputPath?: string; // <-- already present\n  readonly quiet?: boolean;\n  readonly remove?: boolean;\n  readonly sourcePath?: string;\n  readonly test?: boolean;\n  readonly translations?: boolean;\n  readonly variables?: string;\n  readonly watch?: boolean;\n}\n\nexport type BuildCallback = (status: number) => void;\n\nconst displayBuildStatus = (bundler: string, outputPath: string, quiet: boolean, stats?: {modules?: number; assets?: number; size?: string}) => {\n  if(quiet) return;\n\n  let statsInfo = '';\n  if(stats && stats.modules && stats.assets) {\n    statsInfo = `\\n${chalk.green('Modules:')}    ${chalk.cyan(stats.modules)}\\n` +\n      `${chalk.green('Assets:')}     ${chalk.cyan(stats.assets)}\\n` +\n      `${chalk.green('Size:')}       ${chalk.cyan(stats.size)}\\n`;\n  }\n\n  const statusBox = boxen(\n    `${chalk.cyan.bold('🏗️  Build Completed Successfully')}\\n\\n` +\n    `${chalk.green('Bundler:')}    ${chalk.cyan(bundler)}\\n` +\n    `${chalk.green('Output:')}     ${chalk.underline(outputPath)}${statsInfo}\\n` +\n    `${chalk.yellow('Ready for deployment! 🚀')}`,\n    {\n      padding: 1,\n      margin: 1,\n      borderStyle: 'round',\n      borderColor: 'green',\n      backgroundColor: '#1a1a1a'\n    }\n  );\n\n  console.log('\\n' + statusBox + '\\n');\n};\n\n// Removed buildWithEsBuild function - using SWC instead\n\nexport const buildWithSWC = async (spinner, commandOptions: BuildOptions, callback: BuildCallback) => {\n  const {\n    cliName = 'Lex',\n    format = 'esm',\n    outputPath,\n    quiet,\n    sourcePath,\n    watch\n  } = commandOptions;\n  const {\n    outputFullPath,\n    sourceFullPath,\n    swc: swcConfig,\n    targetEnvironment,\n    useGraphQl,\n    useTypescript\n  } = LexConfig.config;\n  const sourceDir: string = sourcePath ? pathResolve(process.cwd(), `./${sourcePath}`) : sourceFullPath || '';\n\n  const globOptions = {\n    cwd: sourceDir,\n    dot: false,\n    nodir: true,\n    nosort: true,\n    absolute: true\n  };\n  const tsFiles: string[] = globSync(`**/!(*.spec|*.test).ts*`, globOptions);\n  const jsFiles: string[] = globSync(`**/!(*.spec|*.test).js`, globOptions);\n  const sourceFiles: string[] = [...tsFiles, ...jsFiles];\n\n  const outputDir: string = outputPath || outputFullPath || '';\n\n  try {\n    spinner.start('Building with SWC...');\n\n    for(const file of sourceFiles) {\n      const sourcePath = pathResolve(sourceDir, file);\n      const outputPath = pathResolve(outputDir, file.replace(/\\.(ts|tsx)$/, '.js'));\n      const outputDirPath = dirname(outputPath);\n\n      if(!existsSync(outputDirPath)) {\n        const {mkdirSync} = await import('fs');\n        mkdirSync(outputDirPath, {recursive: true});\n      }\n\n      const sourceCode = readFileSync(sourcePath, 'utf8');\n      const isTSX = file.endsWith('.tsx');\n      const swcOptions = {\n        filename: file,\n        ...swcConfig,\n        jsc: {\n          ...swcConfig?.jsc,\n          parser: {\n            syntax: 'typescript' as const,\n            tsx: isTSX,\n            decorators: swcConfig?.jsc?.parser?.decorators ?? true,\n            dynamicImport: swcConfig?.jsc?.parser?.dynamicImport ?? true,\n            comments: false // Remove comments during transformation\n          },\n          target: swcConfig?.jsc?.target ?? 'es2020',\n          transform: isTSX ? {\n            ...swcConfig?.jsc?.transform,\n            react: {\n              runtime: 'automatic' as const,\n              ...swcConfig?.jsc?.transform?.react\n            }\n          } : swcConfig?.jsc?.transform,\n          preserveAllComments: false\n        },\n        module: {\n          ...swcConfig?.module,\n          type: format === 'cjs' ? 'commonjs' as const : (swcConfig?.module?.type as 'es6' || 'es6')\n        },\n        minify: false,\n        sourceMaps: swcConfig?.sourceMaps || 'inline'\n      };\n\n      const result = await transform(sourceCode, swcOptions);\n\n      const {writeFileSync} = await import('fs');\n      writeFileSync(outputPath, result.code);\n    }\n\n    spinner.succeed('Build completed with SWC');\n    displayBuildStatus('SWC', outputDir, quiet);\n    callback(0);\n    return 0;\n  } catch(error) {\n    log(`\\n${commandOptions.cliName || 'Lex'} Error: SWC build failed`, 'error', quiet);\n    log(`\\nError: ${error.message}`, 'error', quiet);\n\n    if(error instanceof Error) {\n      if(error.stack) {\n        log(`\\nStack Trace:\\n${error.stack}`, 'error', quiet);\n      }\n\n      // Try to extract file information if available\n      if('filename' in error || 'file' in error) {\n        log(`\\nFile: ${(error as any).filename || (error as any).file}`, 'error', quiet);\n      }\n    }\n\n    spinner.fail('Build failed with SWC');\n    if(!quiet) {\n      console.error('\\nFull Error Details:', error);\n    }\n    callback(1);\n    return 1;\n  }\n};\n\nexport const buildWithWebpack = async (spinner, cmd, callback) => {\n  const {\n    analyze,\n    cliName = 'Lex',\n    config,\n    configName,\n    defineProcessEnvNodeEnv,\n    devtool,\n    disableInterpret,\n    entry,\n    env,\n    failOnWarnings,\n    json,\n    merge,\n    mode,\n    name,\n    nodeEnv,\n    noDevtool,\n    noStats,\n    noTarget,\n    noWatch,\n    noWatchOptionsStdin,\n    outputPath,\n    quiet = false,\n    stats,\n    target,\n    watch,\n    watchOptionsStdin\n  } = cmd;\n\n  console.log('entry:', entry, 'type:', typeof entry);\n  console.log('outputPath:', outputPath, 'type:', typeof outputPath);\n\n  const entryValue = Array.isArray(entry) ? entry[0] : entry;\n\n  let webpackConfig: string;\n\n  if(config) {\n    const isRelativeConfig: boolean = config.substr(0, 2) === './';\n    webpackConfig = isRelativeConfig ? pathResolve(process.cwd(), config) : config;\n  } else {\n    const projectConfigPath = pathResolve(process.cwd(), 'webpack.config.js');\n    const projectConfigPathTs = pathResolve(process.cwd(), 'webpack.config.ts');\n    const hasProjectConfig = existsSync(projectConfigPath) || existsSync(projectConfigPathTs);\n\n    if(hasProjectConfig) {\n      webpackConfig = existsSync(projectConfigPathTs) ? projectConfigPathTs : projectConfigPath;\n    } else {\n      const {webpackConfig: resolvedConfig} = resolveWebpackPaths(currentDirname);\n      webpackConfig = resolvedConfig;\n    }\n  }\n\n  console.log('webpackConfig path:', webpackConfig);\n  console.log('webpackConfig exists:', existsSync(webpackConfig));\n\n  if(!existsSync(webpackConfig)) {\n    const lexPackagePath = getLexPackageJsonPath();\n    const lexPackageDir = dirname(lexPackagePath);\n    const lexWebpackConfig = pathResolve(lexPackageDir, 'webpack.config.js');\n\n    if(existsSync(lexWebpackConfig)) {\n      webpackConfig = lexWebpackConfig;\n      console.log('Using Lex webpack config:', webpackConfig);\n    } else {\n      log(`\\n${cliName} Error: Could not find webpack.config.js`, 'error', quiet);\n      spinner.fail('Build failed.');\n      callback(1);\n      return 1;\n    }\n  }\n\n  const webpackOptions: string[] = [\n    '--color',\n    '--progress',\n    '--config', webpackConfig\n  ];\n\n  if(analyze) webpackOptions.push('--analyze');\n  if(configName) webpackOptions.push('--configName', configName);\n  if(defineProcessEnvNodeEnv) webpackOptions.push('--defineProcessEnvNodeEnv', defineProcessEnvNodeEnv);\n  if(devtool) webpackOptions.push('--devtool', devtool);\n  if(disableInterpret) webpackOptions.push('--disableInterpret');\n  // Pass entry directly as CLI flag\n  if(entryValue) webpackOptions.push('--entry', entryValue.toString());\n  if(env) webpackOptions.push('--env', env);\n  if(failOnWarnings) webpackOptions.push('--failOnWarnings');\n  if(json) webpackOptions.push('--json', json);\n  if(mode) webpackOptions.push('--mode', mode);\n  if(merge) webpackOptions.push('--merge');\n  if(name) webpackOptions.push('--name', name);\n  if(noDevtool) webpackOptions.push('--noDevtool');\n  if(noStats) webpackOptions.push('--noStats');\n  if(noTarget) webpackOptions.push('--noTarget');\n  if(noWatch) webpackOptions.push('--noWatch');\n  if(noWatchOptionsStdin) webpackOptions.push('--noWatchOptionsStdin');\n  if(nodeEnv) webpackOptions.push('--nodeEnv', nodeEnv);\n  if(outputPath) webpackOptions.push('--output-path', outputPath.toString()); // Convert to string\n  if(stats) webpackOptions.push('--stats', stats);\n  if(target) webpackOptions.push('--target', target);\n  if(watch) webpackOptions.push('--watch');\n  if(watchOptionsStdin) webpackOptions.push('--watchOptionsStdin');\n\n  try {\n    const {webpackPath} = resolveWebpackPaths(currentDirname);\n\n    let executablePath = webpackPath;\n    let finalWebpackOptions: string[];\n\n    if(webpackPath === 'npx') {\n      finalWebpackOptions = ['webpack', ...webpackOptions];\n    } else if(webpackPath.endsWith('.js')) {\n      executablePath = 'node';\n      finalWebpackOptions = [webpackPath, ...webpackOptions];\n    } else {\n      finalWebpackOptions = [...webpackOptions];\n    }\n\n    console.log('webpackPath:', webpackPath);\n    console.log('executablePath:', executablePath);\n    console.log('finalWebpackOptions:', JSON.stringify(finalWebpackOptions));\n    console.log('finalWebpackOptions type:', Array.isArray(finalWebpackOptions) ? 'Array' : typeof finalWebpackOptions);\n\n    // Make sure we're passing an array of strings to execa\n    const childProcess = execa(executablePath, finalWebpackOptions, {encoding: 'utf8', stdio: 'pipe'});\n\n    let buildCompleted = false;\n    let buildStats = {\n      modules: 0,\n      assets: 0,\n      size: '0 B'\n    };\n\n    childProcess.stdout?.on('data', (data: Buffer) => {\n      const output = data.toString();\n\n      handleWebpackProgress(output, spinner, quiet, '🏗️', 'Webpack Building');\n\n      if(!buildCompleted && output.includes('compiled successfully')) {\n        buildCompleted = true;\n        spinner.succeed('Build completed successfully!');\n\n        const moduleMatch = output.match(/(\\d+) modules/);\n        const assetMatch = output.match(/(\\d+) assets/);\n        const sizeMatch = output.match(/assets by status ([\\d.]+ \\w+)/) || output.match(/assets by path.*?([\\d.]+ \\w+)/);\n\n        if(moduleMatch) buildStats.modules = parseInt(moduleMatch[1], 10);\n        if(assetMatch) buildStats.assets = parseInt(assetMatch[1], 10);\n        if(sizeMatch) buildStats.size = sizeMatch[1];\n\n        displayBuildStatus('webpack', LexConfig.config.outputFullPath || 'lib', quiet, buildStats);\n      }\n    });\n\n    childProcess.stderr?.on('data', (data: Buffer) => {\n      const output = data.toString();\n\n      handleWebpackProgress(output, spinner, quiet, '🏗️', 'Webpack Building');\n\n      if(!buildCompleted && output.includes('compiled successfully')) {\n        buildCompleted = true;\n        spinner.succeed('Build completed successfully!');\n\n        const moduleMatch = output.match(/(\\d+) modules/);\n        const assetMatch = output.match(/(\\d+) assets/);\n        const sizeMatch = output.match(/assets by status ([\\d.]+ \\w+)/) || output.match(/assets by path.*?([\\d.]+ \\w+)/);\n\n        if(moduleMatch) buildStats.modules = parseInt(moduleMatch[1], 10);\n        if(assetMatch) buildStats.assets = parseInt(assetMatch[1], 10);\n        if(sizeMatch) buildStats.size = sizeMatch[1];\n\n        displayBuildStatus('webpack', LexConfig.config.outputFullPath || 'lib', quiet, buildStats);\n      }\n    });\n\n    await childProcess;\n\n    if(!buildCompleted) {\n      spinner.succeed('Build completed successfully!');\n      displayBuildStatus('webpack', LexConfig.config.outputFullPath || 'lib', quiet, buildStats);\n    }\n\n    callback(0);\n    return 0;\n  } catch(error) {\n    log(`\\n${cliName} Error: Webpack build failed`, 'error', quiet);\n    log(`\\nError: ${error.message}`, 'error', quiet);\n\n    if(error instanceof Error) {\n      if(error.stack) {\n        log(`\\nStack Trace:\\n${error.stack}`, 'error', quiet);\n      }\n    }\n\n    log(`\\nWebpack Options: ${webpackOptions.slice(0, 5).join(' ')}...`, 'error', quiet);\n\n    spinner.fail('Build failed.');\n\n    if(cmd.assist) {\n      spinner.start('AI is analyzing the webpack error...');\n\n      try {\n        await aiFunction({\n          prompt: `Fix this webpack build error: ${error.message}\\n\\nError details:\\n${error.toString()}\\n\\nConfiguration used:\\n${JSON.stringify(webpackOptions, null, 2)}`,\n          task: 'help',\n          context: true,\n          quiet\n        });\n\n        spinner.succeed('AI analysis complete');\n      } catch(aiError) {\n        spinner.fail('Could not generate AI assistance');\n        if(!quiet) {\n          console.error('AI assistance error:', aiError);\n        }\n      }\n    }\n\n    if(!quiet) {\n      console.error('\\nFull Error Details:', error);\n    }\n\n    callback(1);\n    return 1;\n  }\n};\n\nexport const build = async (cmd: BuildOptions, callback: BuildCallback = () => ({})): Promise<number> => {\n  const {\n    bundler = 'webpack',\n    cliName = 'Lex',\n    quiet = false,\n    remove = false,\n    test = false,\n    translations = false,\n    variables = '{}'\n  } = cmd;\n\n  const spinner = createSpinner(quiet);\n\n  log(`${cliName} building...`, 'info', quiet);\n\n  await LexConfig.parseConfig(cmd);\n\n  const {outputFullPath, useTypescript} = LexConfig.config;\n\n  checkLinkedModules();\n\n  let variablesObj: object = {NODE_ENV: 'production'};\n\n  if(variables) {\n    try {\n      variablesObj = JSON.parse(variables);\n    } catch(error) {\n      log(`\\n${cliName} Error: Environment variables option is not a valid JSON object.`, 'error', quiet);\n\n      callback(1);\n      return 1;\n    }\n  }\n\n  process.env = {...process.env, ...variablesObj};\n\n  // If in test mode, exit early\n  if(test) {\n    log('Test mode: Build environment loaded, exiting', 'info', quiet);\n    callback(0);\n    return 0;\n  }\n\n  // Process translations if flag is enabled (before building)\n  if(translations) {\n    spinner.start('Processing translations...');\n\n    try {\n      const sourcePath = LexConfig.config.sourceFullPath || process.cwd();\n      const outputPath = LexConfig.config.outputFullPath || 'lib';\n\n      await processTranslations(sourcePath, outputPath, quiet);\n      spinner.succeed('Translations processed successfully!');\n    } catch(translationError) {\n      log(`\\n${cliName} Error: Failed to process translations: ${translationError.message}`, 'error', quiet);\n      spinner.fail('Failed to process translations.');\n      callback(1);\n      return 1;\n    }\n  }\n\n  spinner.start('Building code...');\n\n  if(remove) {\n    await removeFiles(outputFullPath || '');\n  }\n\n  let buildResult = 0;\n\n  if(bundler === 'swc') {\n    buildResult = await buildWithSWC(spinner, cmd, (status) => {\n      buildResult = status;\n    });\n  } else {\n    buildResult = await buildWithWebpack(spinner, cmd, (status) => {\n      buildResult = status;\n    });\n  }\n\n  if(buildResult === 0 && cmd.analyze) {\n    spinner.start('AI is analyzing the build output for optimization opportunities...');\n\n    try {\n      const stats = {\n        outputPath: LexConfig.config.outputFullPath,\n        entryPoints: bundler === 'swc' ?\n          `Source files: ${LexConfig.config.sourceFullPath}/**/*.{ts,js}` :\n          LexConfig.config.webpack?.entry || 'Unknown entry points'\n      };\n\n      await aiFunction({\n        prompt: `Analyze this build for optimization opportunities:\n\nBuild Type: ${bundler}\nFormat: ${cmd.format || 'default'}\nEnvironment: ${LexConfig.config.targetEnvironment}\n${JSON.stringify(stats, null, 2)}\n\nWhat are the key optimization opportunities for this build configuration? Consider:\n1. Bundle size optimization strategies\n2. Code splitting recommendations\n3. Tree-shaking improvements\n4. Performance enhancements\n5. Dependency optimizations`,\n        task: 'optimize',\n        context: true,\n        quiet\n      });\n\n      spinner.succeed('AI build analysis complete');\n    } catch(aiError) {\n      spinner.fail('Could not generate AI optimization analysis');\n      if(!quiet) {\n        console.error('AI analysis error:', aiError);\n      }\n    }\n  }\n\n  if(buildResult === 0) {\n    try {\n      if(useTypescript && bundler === 'swc') {\n        const typescriptPath = resolveBinaryPath('tsc', 'typescript');\n\n        if(typescriptPath) {\n          spinner.start('Generating TypeScript declarations...');\n          try {\n            const sourceFullPath = LexConfig.config.sourceFullPath || pathResolve(process.cwd(), './src');\n            const outputFullPath = LexConfig.config.outputFullPath || pathResolve(process.cwd(), './lib');\n            const globOptions = {\n              cwd: sourceFullPath,\n              dot: false,\n              nodir: true,\n              absolute: true\n            };\n            const tsFiles = globSync(`**/!(*.spec|*.test|*.integration).ts`, globOptions);\n            const tsxFiles = globSync(`**/!(*.spec|*.test|*.integration).tsx`, globOptions);\n            const allSourceFiles = [...tsFiles, ...tsxFiles];\n            const typescriptOptions = [\n              ...LexConfig.getTypeScriptDeclarationFlags(),\n              ...allSourceFiles\n            ];\n            const result = await execa(typescriptPath, typescriptOptions, {\n              encoding: 'utf8',\n              cwd: process.cwd(),\n              reject: false, // Don't throw on errors, we'll check exit code\n              all: true // Capture both stdout and stderr\n            });\n\n            if(result.exitCode !== 0) {\n              // TypeScript may have errors but still generate some declarations\n              // Log warnings but don't fail if declarations were generated\n              const hasDeclarations = result.all?.includes('Writing') || result.all?.includes('Declaration') || false;\n              const errorOutput = result.stderr || result.stdout || result.all || 'Unknown error';\n\n              if(!hasDeclarations) {\n                // Show detailed error information\n                log(`\\n${cliName} Error: TypeScript declaration generation failed`, 'error', quiet);\n                log(`\\nExit Code: ${result.exitCode}`, 'error', quiet);\n                log(`\\nTypeScript Command: ${typescriptPath} ${typescriptOptions.slice(0, 10).join(' ')}...`, 'error', quiet);\n                log(`\\nError Output:\\n${errorOutput}`, 'error', quiet);\n\n                // Try to extract and highlight specific errors\n                const errorLines = errorOutput.split('\\n').filter(line =>\n                  line.includes('error TS') ||\n                  line.includes('Error:') ||\n                  line.trim().startsWith('src/') ||\n                  line.trim().startsWith('TS')\n                );\n\n                if(errorLines.length > 0) {\n                  log(`\\nKey Errors:`, 'error', quiet);\n                  errorLines.slice(0, 10).forEach(line => {\n                    log(`  ${line}`, 'error', quiet);\n                  });\n                  if(errorLines.length > 10) {\n                    log(`  ... and ${errorLines.length - 10} more errors`, 'error', quiet);\n                  }\n                }\n\n                spinner.fail('TypeScript declaration generation had errors (continuing anyway).');\n              } else {\n                log(`\\n${cliName} Warning: TypeScript declaration generation completed with errors`, 'warn', quiet);\n                if(!quiet && errorOutput) {\n                  log(`\\nWarnings:\\n${errorOutput}`, 'warn', quiet);\n                }\n                spinner.succeed('TypeScript declarations generated (with warnings).');\n              }\n            } else {\n              spinner.succeed('TypeScript declarations generated!');\n            }\n          } catch(error) {\n            // If execa throws (shouldn't with reject: false), log and continue\n            log(`\\n${cliName} Error: TypeScript declaration generation exception`, 'error', quiet);\n            log(`\\nError: ${error.message}`, 'error', quiet);\n            if(error instanceof Error && error.stack) {\n              log(`\\nStack:\\n${error.stack}`, 'error', quiet);\n            }\n            spinner.fail('TypeScript declaration generation had issues (continuing anyway).');\n            // Don't fail the build if declarations fail\n          }\n        }\n      }\n\n      await copyConfiguredFiles(spinner, LexConfig.config, quiet);\n    } catch(copyError) {\n      log(`\\n${cliName} Error: Failed to copy configured files: ${copyError.message}`, 'error', quiet);\n      callback(1);\n      return 1;\n    }\n  }\n\n  callback(buildResult);\n  return buildResult;\n};\n\nexport default build;\n"],"names":["transform","execa","existsSync","readFileSync","sync","globSync","dirname","resolve","pathResolve","LexConfig","checkLinkedModules","copyConfiguredFiles","createSpinner","handleWebpackProgress","removeFiles","resolveWebpackPaths","getLexPackageJsonPath","resolveBinaryPath","log","processTranslations","aiFunction","boxen","chalk","currentFilename","currentDirname","eval","process","cwd","displayBuildStatus","bundler","outputPath","quiet","stats","statsInfo","modules","assets","green","cyan","size","statusBox","bold","underline","yellow","padding","margin","borderStyle","borderColor","backgroundColor","console","buildWithSWC","spinner","commandOptions","callback","cliName","format","sourcePath","watch","outputFullPath","sourceFullPath","swc","swcConfig","targetEnvironment","useGraphQl","useTypescript","config","sourceDir","globOptions","dot","nodir","nosort","absolute","tsFiles","jsFiles","sourceFiles","outputDir","start","file","replace","outputDirPath","mkdirSync","recursive","sourceCode","isTSX","endsWith","swcOptions","filename","jsc","parser","syntax","tsx","decorators","dynamicImport","comments","target","react","runtime","preserveAllComments","module","type","minify","sourceMaps","result","writeFileSync","code","succeed","error","message","Error","stack","fail","buildWithWebpack","cmd","analyze","configName","defineProcessEnvNodeEnv","devtool","disableInterpret","entry","env","failOnWarnings","json","merge","mode","name","nodeEnv","noDevtool","noStats","noTarget","noWatch","noWatchOptionsStdin","watchOptionsStdin","entryValue","Array","isArray","webpackConfig","isRelativeConfig","substr","projectConfigPath","projectConfigPathTs","hasProjectConfig","resolvedConfig","lexPackagePath","lexPackageDir","lexWebpackConfig","webpackOptions","push","toString","webpackPath","executablePath","finalWebpackOptions","JSON","stringify","childProcess","encoding","stdio","buildCompleted","buildStats","stdout","on","data","output","includes","moduleMatch","match","assetMatch","sizeMatch","parseInt","stderr","slice","join","assist","prompt","task","context","aiError","build","remove","test","translations","variables","parseConfig","variablesObj","NODE_ENV","parse","translationError","buildResult","status","entryPoints","webpack","typescriptPath","tsxFiles","allSourceFiles","typescriptOptions","getTypeScriptDeclarationFlags","reject","all","exitCode","hasDeclarations","errorOutput","errorLines","split","filter","line","trim","startsWith","length","forEach","copyError"],"mappings":"AAAA;;;CAGC,GACD,SAAQA,SAAS,QAAO,YAAY;AACpC,SAAQC,KAAK,QAAO,QAAQ;AAC5B,SAAQC,UAAU,EAAEC,YAAY,QAAO,KAAK;AAC5C,SAAQC,QAAQC,QAAQ,QAAO,OAAO;AACtC,SAAQC,OAAO,EAAEC,WAAWC,WAAW,QAAO,OAAO;AAErD,SAAQC,SAAS,QAAO,qBAAqB;AAC7C,SAAQC,kBAAkB,EAAEC,mBAAmB,EAAEC,aAAa,EAAqBC,qBAAqB,EAAEC,WAAW,QAAO,qBAAqB;AACjJ,SACEC,mBAAmB,EACnBC,qBAAqB,EACrBC,iBAAiB,QACZ,sBAAsB;AAC7B,SAAQC,GAAG,QAAO,qBAAqB;AACvC,SAAQC,mBAAmB,QAAO,8BAA8B;AAChE,SAAQC,UAAU,QAAO,cAAc;AACvC,OAAOC,WAAW,QAAQ;AAC1B,OAAOC,WAAW,QAAQ;AAE1B,IAAIC;AACJ,IAAIC;AAEJ,IAAI;IACFD,kBAAkBE,KAAK;IACvBD,iBAAiBlB,QAAQiB;AAC3B,EAAE,OAAM;IACNA,kBAAkBG,QAAQC,GAAG;IAC7BH,iBAAiBE,QAAQC,GAAG;AAC9B;AAqBA,MAAMC,qBAAqB,CAACC,SAAiBC,YAAoBC,OAAgBC;IAC/E,IAAGD,OAAO;IAEV,IAAIE,YAAY;IAChB,IAAGD,SAASA,MAAME,OAAO,IAAIF,MAAMG,MAAM,EAAE;QACzCF,YAAY,CAAC,EAAE,EAAEX,MAAMc,KAAK,CAAC,YAAY,IAAI,EAAEd,MAAMe,IAAI,CAACL,MAAME,OAAO,EAAE,EAAE,CAAC,GAC1E,GAAGZ,MAAMc,KAAK,CAAC,WAAW,KAAK,EAAEd,MAAMe,IAAI,CAACL,MAAMG,MAAM,EAAE,EAAE,CAAC,GAC7D,GAAGb,MAAMc,KAAK,CAAC,SAAS,OAAO,EAAEd,MAAMe,IAAI,CAACL,MAAMM,IAAI,EAAE,EAAE,CAAC;IAC/D;IAEA,MAAMC,YAAYlB,MAChB,GAAGC,MAAMe,IAAI,CAACG,IAAI,CAAC,qCAAqC,IAAI,CAAC,GAC7D,GAAGlB,MAAMc,KAAK,CAAC,YAAY,IAAI,EAAEd,MAAMe,IAAI,CAACR,SAAS,EAAE,CAAC,GACxD,GAAGP,MAAMc,KAAK,CAAC,WAAW,KAAK,EAAEd,MAAMmB,SAAS,CAACX,cAAcG,UAAU,EAAE,CAAC,GAC5E,GAAGX,MAAMoB,MAAM,CAAC,6BAA6B,EAC7C;QACEC,SAAS;QACTC,QAAQ;QACRC,aAAa;QACbC,aAAa;QACbC,iBAAiB;IACnB;IAGFC,QAAQ9B,GAAG,CAAC,OAAOqB,YAAY;AACjC;AAEA,wDAAwD;AAExD,OAAO,MAAMU,eAAe,OAAOC,SAASC,gBAA8BC;IACxE,MAAM,EACJC,UAAU,KAAK,EACfC,SAAS,KAAK,EACdxB,UAAU,EACVC,KAAK,EACLwB,UAAU,EACVC,KAAK,EACN,GAAGL;IACJ,MAAM,EACJM,cAAc,EACdC,cAAc,EACdC,KAAKC,SAAS,EACdC,iBAAiB,EACjBC,UAAU,EACVC,aAAa,EACd,GAAGtD,UAAUuD,MAAM;IACpB,MAAMC,YAAoBV,aAAa/C,YAAYkB,QAAQC,GAAG,IAAI,CAAC,EAAE,EAAE4B,YAAY,IAAIG,kBAAkB;IAEzG,MAAMQ,cAAc;QAClBvC,KAAKsC;QACLE,KAAK;QACLC,OAAO;QACPC,QAAQ;QACRC,UAAU;IACZ;IACA,MAAMC,UAAoBlE,SAAS,CAAC,uBAAuB,CAAC,EAAE6D;IAC9D,MAAMM,UAAoBnE,SAAS,CAAC,sBAAsB,CAAC,EAAE6D;IAC7D,MAAMO,cAAwB;WAAIF;WAAYC;KAAQ;IAEtD,MAAME,YAAoB5C,cAAc2B,kBAAkB;IAE1D,IAAI;QACFP,QAAQyB,KAAK,CAAC;QAEd,KAAI,MAAMC,QAAQH,YAAa;YAC7B,MAAMlB,aAAa/C,YAAYyD,WAAWW;YAC1C,MAAM9C,aAAatB,YAAYkE,WAAWE,KAAKC,OAAO,CAAC,eAAe;YACtE,MAAMC,gBAAgBxE,QAAQwB;YAE9B,IAAG,CAAC5B,WAAW4E,gBAAgB;gBAC7B,MAAM,EAACC,SAAS,EAAC,GAAG,MAAM,MAAM,CAAC;gBACjCA,UAAUD,eAAe;oBAACE,WAAW;gBAAI;YAC3C;YAEA,MAAMC,aAAa9E,aAAaoD,YAAY;YAC5C,MAAM2B,QAAQN,KAAKO,QAAQ,CAAC;YAC5B,MAAMC,aAAa;gBACjBC,UAAUT;gBACV,GAAGhB,SAAS;gBACZ0B,KAAK;oBACH,GAAG1B,WAAW0B,GAAG;oBACjBC,QAAQ;wBACNC,QAAQ;wBACRC,KAAKP;wBACLQ,YAAY9B,WAAW0B,KAAKC,QAAQG,cAAc;wBAClDC,eAAe/B,WAAW0B,KAAKC,QAAQI,iBAAiB;wBACxDC,UAAU,MAAM,wCAAwC;oBAC1D;oBACAC,QAAQjC,WAAW0B,KAAKO,UAAU;oBAClC7F,WAAWkF,QAAQ;wBACjB,GAAGtB,WAAW0B,KAAKtF,SAAS;wBAC5B8F,OAAO;4BACLC,SAAS;4BACT,GAAGnC,WAAW0B,KAAKtF,WAAW8F,KAAK;wBACrC;oBACF,IAAIlC,WAAW0B,KAAKtF;oBACpBgG,qBAAqB;gBACvB;gBACAC,QAAQ;oBACN,GAAGrC,WAAWqC,MAAM;oBACpBC,MAAM5C,WAAW,QAAQ,aAAuBM,WAAWqC,QAAQC,QAAiB;gBACtF;gBACAC,QAAQ;gBACRC,YAAYxC,WAAWwC,cAAc;YACvC;YAEA,MAAMC,SAAS,MAAMrG,UAAUiF,YAAYG;YAE3C,MAAM,EAACkB,aAAa,EAAC,GAAG,MAAM,MAAM,CAAC;YACrCA,cAAcxE,YAAYuE,OAAOE,IAAI;QACvC;QAEArD,QAAQsD,OAAO,CAAC;QAChB5E,mBAAmB,OAAO8C,WAAW3C;QACrCqB,SAAS;QACT,OAAO;IACT,EAAE,OAAMqD,OAAO;QACbvF,IAAI,CAAC,EAAE,EAAEiC,eAAeE,OAAO,IAAI,MAAM,wBAAwB,CAAC,EAAE,SAAStB;QAC7Eb,IAAI,CAAC,SAAS,EAAEuF,MAAMC,OAAO,EAAE,EAAE,SAAS3E;QAE1C,IAAG0E,iBAAiBE,OAAO;YACzB,IAAGF,MAAMG,KAAK,EAAE;gBACd1F,IAAI,CAAC,gBAAgB,EAAEuF,MAAMG,KAAK,EAAE,EAAE,SAAS7E;YACjD;YAEA,+CAA+C;YAC/C,IAAG,cAAc0E,SAAS,UAAUA,OAAO;gBACzCvF,IAAI,CAAC,QAAQ,EAAE,AAACuF,MAAcpB,QAAQ,IAAI,AAACoB,MAAc7B,IAAI,EAAE,EAAE,SAAS7C;YAC5E;QACF;QAEAmB,QAAQ2D,IAAI,CAAC;QACb,IAAG,CAAC9E,OAAO;YACTiB,QAAQyD,KAAK,CAAC,yBAAyBA;QACzC;QACArD,SAAS;QACT,OAAO;IACT;AACF,EAAE;AAEF,OAAO,MAAM0D,mBAAmB,OAAO5D,SAAS6D,KAAK3D;IACnD,MAAM,EACJ4D,OAAO,EACP3D,UAAU,KAAK,EACfW,MAAM,EACNiD,UAAU,EACVC,uBAAuB,EACvBC,OAAO,EACPC,gBAAgB,EAChBC,KAAK,EACLC,GAAG,EACHC,cAAc,EACdC,IAAI,EACJC,KAAK,EACLC,IAAI,EACJC,IAAI,EACJC,OAAO,EACPC,SAAS,EACTC,OAAO,EACPC,QAAQ,EACRC,OAAO,EACPC,mBAAmB,EACnBnG,UAAU,EACVC,QAAQ,KAAK,EACbC,KAAK,EACL6D,MAAM,EACNrC,KAAK,EACL0E,iBAAiB,EAClB,GAAGnB;IAEJ/D,QAAQ9B,GAAG,CAAC,UAAUmG,OAAO,SAAS,OAAOA;IAC7CrE,QAAQ9B,GAAG,CAAC,eAAeY,YAAY,SAAS,OAAOA;IAEvD,MAAMqG,aAAaC,MAAMC,OAAO,CAAChB,SAASA,KAAK,CAAC,EAAE,GAAGA;IAErD,IAAIiB;IAEJ,IAAGtE,QAAQ;QACT,MAAMuE,mBAA4BvE,OAAOwE,MAAM,CAAC,GAAG,OAAO;QAC1DF,gBAAgBC,mBAAmB/H,YAAYkB,QAAQC,GAAG,IAAIqC,UAAUA;IAC1E,OAAO;QACL,MAAMyE,oBAAoBjI,YAAYkB,QAAQC,GAAG,IAAI;QACrD,MAAM+G,sBAAsBlI,YAAYkB,QAAQC,GAAG,IAAI;QACvD,MAAMgH,mBAAmBzI,WAAWuI,sBAAsBvI,WAAWwI;QAErE,IAAGC,kBAAkB;YACnBL,gBAAgBpI,WAAWwI,uBAAuBA,sBAAsBD;QAC1E,OAAO;YACL,MAAM,EAACH,eAAeM,cAAc,EAAC,GAAG7H,oBAAoBS;YAC5D8G,gBAAgBM;QAClB;IACF;IAEA5F,QAAQ9B,GAAG,CAAC,uBAAuBoH;IACnCtF,QAAQ9B,GAAG,CAAC,yBAAyBhB,WAAWoI;IAEhD,IAAG,CAACpI,WAAWoI,gBAAgB;QAC7B,MAAMO,iBAAiB7H;QACvB,MAAM8H,gBAAgBxI,QAAQuI;QAC9B,MAAME,mBAAmBvI,YAAYsI,eAAe;QAEpD,IAAG5I,WAAW6I,mBAAmB;YAC/BT,gBAAgBS;YAChB/F,QAAQ9B,GAAG,CAAC,6BAA6BoH;QAC3C,OAAO;YACLpH,IAAI,CAAC,EAAE,EAAEmC,QAAQ,wCAAwC,CAAC,EAAE,SAAStB;YACrEmB,QAAQ2D,IAAI,CAAC;YACbzD,SAAS;YACT,OAAO;QACT;IACF;IAEA,MAAM4F,iBAA2B;QAC/B;QACA;QACA;QAAYV;KACb;IAED,IAAGtB,SAASgC,eAAeC,IAAI,CAAC;IAChC,IAAGhC,YAAY+B,eAAeC,IAAI,CAAC,gBAAgBhC;IACnD,IAAGC,yBAAyB8B,eAAeC,IAAI,CAAC,6BAA6B/B;IAC7E,IAAGC,SAAS6B,eAAeC,IAAI,CAAC,aAAa9B;IAC7C,IAAGC,kBAAkB4B,eAAeC,IAAI,CAAC;IACzC,kCAAkC;IAClC,IAAGd,YAAYa,eAAeC,IAAI,CAAC,WAAWd,WAAWe,QAAQ;IACjE,IAAG5B,KAAK0B,eAAeC,IAAI,CAAC,SAAS3B;IACrC,IAAGC,gBAAgByB,eAAeC,IAAI,CAAC;IACvC,IAAGzB,MAAMwB,eAAeC,IAAI,CAAC,UAAUzB;IACvC,IAAGE,MAAMsB,eAAeC,IAAI,CAAC,UAAUvB;IACvC,IAAGD,OAAOuB,eAAeC,IAAI,CAAC;IAC9B,IAAGtB,MAAMqB,eAAeC,IAAI,CAAC,UAAUtB;IACvC,IAAGE,WAAWmB,eAAeC,IAAI,CAAC;IAClC,IAAGnB,SAASkB,eAAeC,IAAI,CAAC;IAChC,IAAGlB,UAAUiB,eAAeC,IAAI,CAAC;IACjC,IAAGjB,SAASgB,eAAeC,IAAI,CAAC;IAChC,IAAGhB,qBAAqBe,eAAeC,IAAI,CAAC;IAC5C,IAAGrB,SAASoB,eAAeC,IAAI,CAAC,aAAarB;IAC7C,IAAG9F,YAAYkH,eAAeC,IAAI,CAAC,iBAAiBnH,WAAWoH,QAAQ,KAAK,oBAAoB;IAChG,IAAGlH,OAAOgH,eAAeC,IAAI,CAAC,WAAWjH;IACzC,IAAG6D,QAAQmD,eAAeC,IAAI,CAAC,YAAYpD;IAC3C,IAAGrC,OAAOwF,eAAeC,IAAI,CAAC;IAC9B,IAAGf,mBAAmBc,eAAeC,IAAI,CAAC;IAE1C,IAAI;QACF,MAAM,EAACE,WAAW,EAAC,GAAGpI,oBAAoBS;QAE1C,IAAI4H,iBAAiBD;QACrB,IAAIE;QAEJ,IAAGF,gBAAgB,OAAO;YACxBE,sBAAsB;gBAAC;mBAAcL;aAAe;QACtD,OAAO,IAAGG,YAAYhE,QAAQ,CAAC,QAAQ;YACrCiE,iBAAiB;YACjBC,sBAAsB;gBAACF;mBAAgBH;aAAe;QACxD,OAAO;YACLK,sBAAsB;mBAAIL;aAAe;QAC3C;QAEAhG,QAAQ9B,GAAG,CAAC,gBAAgBiI;QAC5BnG,QAAQ9B,GAAG,CAAC,mBAAmBkI;QAC/BpG,QAAQ9B,GAAG,CAAC,wBAAwBoI,KAAKC,SAAS,CAACF;QACnDrG,QAAQ9B,GAAG,CAAC,6BAA6BkH,MAAMC,OAAO,CAACgB,uBAAuB,UAAU,OAAOA;QAE/F,uDAAuD;QACvD,MAAMG,eAAevJ,MAAMmJ,gBAAgBC,qBAAqB;YAACI,UAAU;YAAQC,OAAO;QAAM;QAEhG,IAAIC,iBAAiB;QACrB,IAAIC,aAAa;YACf1H,SAAS;YACTC,QAAQ;YACRG,MAAM;QACR;QAEAkH,aAAaK,MAAM,EAAEC,GAAG,QAAQ,CAACC;YAC/B,MAAMC,SAASD,KAAKb,QAAQ;YAE5BrI,sBAAsBmJ,QAAQ9G,SAASnB,OAAO,OAAO;YAErD,IAAG,CAAC4H,kBAAkBK,OAAOC,QAAQ,CAAC,0BAA0B;gBAC9DN,iBAAiB;gBACjBzG,QAAQsD,OAAO,CAAC;gBAEhB,MAAM0D,cAAcF,OAAOG,KAAK,CAAC;gBACjC,MAAMC,aAAaJ,OAAOG,KAAK,CAAC;gBAChC,MAAME,YAAYL,OAAOG,KAAK,CAAC,oCAAoCH,OAAOG,KAAK,CAAC;gBAEhF,IAAGD,aAAaN,WAAW1H,OAAO,GAAGoI,SAASJ,WAAW,CAAC,EAAE,EAAE;gBAC9D,IAAGE,YAAYR,WAAWzH,MAAM,GAAGmI,SAASF,UAAU,CAAC,EAAE,EAAE;gBAC3D,IAAGC,WAAWT,WAAWtH,IAAI,GAAG+H,SAAS,CAAC,EAAE;gBAE5CzI,mBAAmB,WAAWnB,UAAUuD,MAAM,CAACP,cAAc,IAAI,OAAO1B,OAAO6H;YACjF;QACF;QAEAJ,aAAae,MAAM,EAAET,GAAG,QAAQ,CAACC;YAC/B,MAAMC,SAASD,KAAKb,QAAQ;YAE5BrI,sBAAsBmJ,QAAQ9G,SAASnB,OAAO,OAAO;YAErD,IAAG,CAAC4H,kBAAkBK,OAAOC,QAAQ,CAAC,0BAA0B;gBAC9DN,iBAAiB;gBACjBzG,QAAQsD,OAAO,CAAC;gBAEhB,MAAM0D,cAAcF,OAAOG,KAAK,CAAC;gBACjC,MAAMC,aAAaJ,OAAOG,KAAK,CAAC;gBAChC,MAAME,YAAYL,OAAOG,KAAK,CAAC,oCAAoCH,OAAOG,KAAK,CAAC;gBAEhF,IAAGD,aAAaN,WAAW1H,OAAO,GAAGoI,SAASJ,WAAW,CAAC,EAAE,EAAE;gBAC9D,IAAGE,YAAYR,WAAWzH,MAAM,GAAGmI,SAASF,UAAU,CAAC,EAAE,EAAE;gBAC3D,IAAGC,WAAWT,WAAWtH,IAAI,GAAG+H,SAAS,CAAC,EAAE;gBAE5CzI,mBAAmB,WAAWnB,UAAUuD,MAAM,CAACP,cAAc,IAAI,OAAO1B,OAAO6H;YACjF;QACF;QAEA,MAAMJ;QAEN,IAAG,CAACG,gBAAgB;YAClBzG,QAAQsD,OAAO,CAAC;YAChB5E,mBAAmB,WAAWnB,UAAUuD,MAAM,CAACP,cAAc,IAAI,OAAO1B,OAAO6H;QACjF;QAEAxG,SAAS;QACT,OAAO;IACT,EAAE,OAAMqD,OAAO;QACbvF,IAAI,CAAC,EAAE,EAAEmC,QAAQ,4BAA4B,CAAC,EAAE,SAAStB;QACzDb,IAAI,CAAC,SAAS,EAAEuF,MAAMC,OAAO,EAAE,EAAE,SAAS3E;QAE1C,IAAG0E,iBAAiBE,OAAO;YACzB,IAAGF,MAAMG,KAAK,EAAE;gBACd1F,IAAI,CAAC,gBAAgB,EAAEuF,MAAMG,KAAK,EAAE,EAAE,SAAS7E;YACjD;QACF;QAEAb,IAAI,CAAC,mBAAmB,EAAE8H,eAAewB,KAAK,CAAC,GAAG,GAAGC,IAAI,CAAC,KAAK,GAAG,CAAC,EAAE,SAAS1I;QAE9EmB,QAAQ2D,IAAI,CAAC;QAEb,IAAGE,IAAI2D,MAAM,EAAE;YACbxH,QAAQyB,KAAK,CAAC;YAEd,IAAI;gBACF,MAAMvD,WAAW;oBACfuJ,QAAQ,CAAC,8BAA8B,EAAElE,MAAMC,OAAO,CAAC,oBAAoB,EAAED,MAAMyC,QAAQ,GAAG,yBAAyB,EAAEI,KAAKC,SAAS,CAACP,gBAAgB,MAAM,IAAI;oBAClK4B,MAAM;oBACNC,SAAS;oBACT9I;gBACF;gBAEAmB,QAAQsD,OAAO,CAAC;YAClB,EAAE,OAAMsE,SAAS;gBACf5H,QAAQ2D,IAAI,CAAC;gBACb,IAAG,CAAC9E,OAAO;oBACTiB,QAAQyD,KAAK,CAAC,wBAAwBqE;gBACxC;YACF;QACF;QAEA,IAAG,CAAC/I,OAAO;YACTiB,QAAQyD,KAAK,CAAC,yBAAyBA;QACzC;QAEArD,SAAS;QACT,OAAO;IACT;AACF,EAAE;AAEF,OAAO,MAAM2H,QAAQ,OAAOhE,KAAmB3D,WAA0B,IAAO,CAAA,CAAC,CAAA,CAAE;IACjF,MAAM,EACJvB,UAAU,SAAS,EACnBwB,UAAU,KAAK,EACftB,QAAQ,KAAK,EACbiJ,SAAS,KAAK,EACdC,OAAO,KAAK,EACZC,eAAe,KAAK,EACpBC,YAAY,IAAI,EACjB,GAAGpE;IAEJ,MAAM7D,UAAUtC,cAAcmB;IAE9Bb,IAAI,GAAGmC,QAAQ,YAAY,CAAC,EAAE,QAAQtB;IAEtC,MAAMtB,UAAU2K,WAAW,CAACrE;IAE5B,MAAM,EAACtD,cAAc,EAAEM,aAAa,EAAC,GAAGtD,UAAUuD,MAAM;IAExDtD;IAEA,IAAI2K,eAAuB;QAACC,UAAU;IAAY;IAElD,IAAGH,WAAW;QACZ,IAAI;YACFE,eAAe/B,KAAKiC,KAAK,CAACJ;QAC5B,EAAE,OAAM1E,OAAO;YACbvF,IAAI,CAAC,EAAE,EAAEmC,QAAQ,gEAAgE,CAAC,EAAE,SAAStB;YAE7FqB,SAAS;YACT,OAAO;QACT;IACF;IAEA1B,QAAQ4F,GAAG,GAAG;QAAC,GAAG5F,QAAQ4F,GAAG;QAAE,GAAG+D,YAAY;IAAA;IAE9C,8BAA8B;IAC9B,IAAGJ,MAAM;QACP/J,IAAI,gDAAgD,QAAQa;QAC5DqB,SAAS;QACT,OAAO;IACT;IAEA,4DAA4D;IAC5D,IAAG8H,cAAc;QACfhI,QAAQyB,KAAK,CAAC;QAEd,IAAI;YACF,MAAMpB,aAAa9C,UAAUuD,MAAM,CAACN,cAAc,IAAIhC,QAAQC,GAAG;YACjE,MAAMG,aAAarB,UAAUuD,MAAM,CAACP,cAAc,IAAI;YAEtD,MAAMtC,oBAAoBoC,YAAYzB,YAAYC;YAClDmB,QAAQsD,OAAO,CAAC;QAClB,EAAE,OAAMgF,kBAAkB;YACxBtK,IAAI,CAAC,EAAE,EAAEmC,QAAQ,wCAAwC,EAAEmI,iBAAiB9E,OAAO,EAAE,EAAE,SAAS3E;YAChGmB,QAAQ2D,IAAI,CAAC;YACbzD,SAAS;YACT,OAAO;QACT;IACF;IAEAF,QAAQyB,KAAK,CAAC;IAEd,IAAGqG,QAAQ;QACT,MAAMlK,YAAY2C,kBAAkB;IACtC;IAEA,IAAIgI,cAAc;IAElB,IAAG5J,YAAY,OAAO;QACpB4J,cAAc,MAAMxI,aAAaC,SAAS6D,KAAK,CAAC2E;YAC9CD,cAAcC;QAChB;IACF,OAAO;QACLD,cAAc,MAAM3E,iBAAiB5D,SAAS6D,KAAK,CAAC2E;YAClDD,cAAcC;QAChB;IACF;IAEA,IAAGD,gBAAgB,KAAK1E,IAAIC,OAAO,EAAE;QACnC9D,QAAQyB,KAAK,CAAC;QAEd,IAAI;YACF,MAAM3C,QAAQ;gBACZF,YAAYrB,UAAUuD,MAAM,CAACP,cAAc;gBAC3CkI,aAAa9J,YAAY,QACvB,CAAC,cAAc,EAAEpB,UAAUuD,MAAM,CAACN,cAAc,CAAC,aAAa,CAAC,GAC/DjD,UAAUuD,MAAM,CAAC4H,OAAO,EAAEvE,SAAS;YACvC;YAEA,MAAMjG,WAAW;gBACfuJ,QAAQ,CAAC;;YAEL,EAAE9I,QAAQ;QACd,EAAEkF,IAAIzD,MAAM,IAAI,UAAU;aACrB,EAAE7C,UAAUuD,MAAM,CAACH,iBAAiB,CAAC;AAClD,EAAEyF,KAAKC,SAAS,CAACvH,OAAO,MAAM,GAAG;;;;;;;2BAON,CAAC;gBACpB4I,MAAM;gBACNC,SAAS;gBACT9I;YACF;YAEAmB,QAAQsD,OAAO,CAAC;QAClB,EAAE,OAAMsE,SAAS;YACf5H,QAAQ2D,IAAI,CAAC;YACb,IAAG,CAAC9E,OAAO;gBACTiB,QAAQyD,KAAK,CAAC,sBAAsBqE;YACtC;QACF;IACF;IAEA,IAAGW,gBAAgB,GAAG;QACpB,IAAI;YACF,IAAG1H,iBAAiBlC,YAAY,OAAO;gBACrC,MAAMgK,iBAAiB5K,kBAAkB,OAAO;gBAEhD,IAAG4K,gBAAgB;oBACjB3I,QAAQyB,KAAK,CAAC;oBACd,IAAI;wBACF,MAAMjB,iBAAiBjD,UAAUuD,MAAM,CAACN,cAAc,IAAIlD,YAAYkB,QAAQC,GAAG,IAAI;wBACrF,MAAM8B,iBAAiBhD,UAAUuD,MAAM,CAACP,cAAc,IAAIjD,YAAYkB,QAAQC,GAAG,IAAI;wBACrF,MAAMuC,cAAc;4BAClBvC,KAAK+B;4BACLS,KAAK;4BACLC,OAAO;4BACPE,UAAU;wBACZ;wBACA,MAAMC,UAAUlE,SAAS,CAAC,oCAAoC,CAAC,EAAE6D;wBACjE,MAAM4H,WAAWzL,SAAS,CAAC,qCAAqC,CAAC,EAAE6D;wBACnE,MAAM6H,iBAAiB;+BAAIxH;+BAAYuH;yBAAS;wBAChD,MAAME,oBAAoB;+BACrBvL,UAAUwL,6BAA6B;+BACvCF;yBACJ;wBACD,MAAM1F,SAAS,MAAMpG,MAAM4L,gBAAgBG,mBAAmB;4BAC5DvC,UAAU;4BACV9H,KAAKD,QAAQC,GAAG;4BAChBuK,QAAQ;4BACRC,KAAK,KAAK,iCAAiC;wBAC7C;wBAEA,IAAG9F,OAAO+F,QAAQ,KAAK,GAAG;4BACxB,kEAAkE;4BAClE,6DAA6D;4BAC7D,MAAMC,kBAAkBhG,OAAO8F,GAAG,EAAElC,SAAS,cAAc5D,OAAO8F,GAAG,EAAElC,SAAS,kBAAkB;4BAClG,MAAMqC,cAAcjG,OAAOkE,MAAM,IAAIlE,OAAOwD,MAAM,IAAIxD,OAAO8F,GAAG,IAAI;4BAEpE,IAAG,CAACE,iBAAiB;gCACnB,kCAAkC;gCAClCnL,IAAI,CAAC,EAAE,EAAEmC,QAAQ,gDAAgD,CAAC,EAAE,SAAStB;gCAC7Eb,IAAI,CAAC,aAAa,EAAEmF,OAAO+F,QAAQ,EAAE,EAAE,SAASrK;gCAChDb,IAAI,CAAC,sBAAsB,EAAE2K,eAAe,CAAC,EAAEG,kBAAkBxB,KAAK,CAAC,GAAG,IAAIC,IAAI,CAAC,KAAK,GAAG,CAAC,EAAE,SAAS1I;gCACvGb,IAAI,CAAC,iBAAiB,EAAEoL,aAAa,EAAE,SAASvK;gCAEhD,+CAA+C;gCAC/C,MAAMwK,aAAaD,YAAYE,KAAK,CAAC,MAAMC,MAAM,CAACC,CAAAA,OAChDA,KAAKzC,QAAQ,CAAC,eACdyC,KAAKzC,QAAQ,CAAC,aACdyC,KAAKC,IAAI,GAAGC,UAAU,CAAC,WACvBF,KAAKC,IAAI,GAAGC,UAAU,CAAC;gCAGzB,IAAGL,WAAWM,MAAM,GAAG,GAAG;oCACxB3L,IAAI,CAAC,aAAa,CAAC,EAAE,SAASa;oCAC9BwK,WAAW/B,KAAK,CAAC,GAAG,IAAIsC,OAAO,CAACJ,CAAAA;wCAC9BxL,IAAI,CAAC,EAAE,EAAEwL,MAAM,EAAE,SAAS3K;oCAC5B;oCACA,IAAGwK,WAAWM,MAAM,GAAG,IAAI;wCACzB3L,IAAI,CAAC,UAAU,EAAEqL,WAAWM,MAAM,GAAG,GAAG,YAAY,CAAC,EAAE,SAAS9K;oCAClE;gCACF;gCAEAmB,QAAQ2D,IAAI,CAAC;4BACf,OAAO;gCACL3F,IAAI,CAAC,EAAE,EAAEmC,QAAQ,iEAAiE,CAAC,EAAE,QAAQtB;gCAC7F,IAAG,CAACA,SAASuK,aAAa;oCACxBpL,IAAI,CAAC,aAAa,EAAEoL,aAAa,EAAE,QAAQvK;gCAC7C;gCACAmB,QAAQsD,OAAO,CAAC;4BAClB;wBACF,OAAO;4BACLtD,QAAQsD,OAAO,CAAC;wBAClB;oBACF,EAAE,OAAMC,OAAO;wBACb,mEAAmE;wBACnEvF,IAAI,CAAC,EAAE,EAAEmC,QAAQ,mDAAmD,CAAC,EAAE,SAAStB;wBAChFb,IAAI,CAAC,SAAS,EAAEuF,MAAMC,OAAO,EAAE,EAAE,SAAS3E;wBAC1C,IAAG0E,iBAAiBE,SAASF,MAAMG,KAAK,EAAE;4BACxC1F,IAAI,CAAC,UAAU,EAAEuF,MAAMG,KAAK,EAAE,EAAE,SAAS7E;wBAC3C;wBACAmB,QAAQ2D,IAAI,CAAC;oBACb,4CAA4C;oBAC9C;gBACF;YACF;YAEA,MAAMlG,oBAAoBuC,SAASzC,UAAUuD,MAAM,EAAEjC;QACvD,EAAE,OAAMgL,WAAW;YACjB7L,IAAI,CAAC,EAAE,EAAEmC,QAAQ,yCAAyC,EAAE0J,UAAUrG,OAAO,EAAE,EAAE,SAAS3E;YAC1FqB,SAAS;YACT,OAAO;QACT;IACF;IAEAA,SAASqI;IACT,OAAOA;AACT,EAAE;AAEF,eAAeV,MAAM"}
475
+ //# 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  join as pathJoin\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\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 isTSX = file.endsWith('.tsx');\n      const swcOptions = {\n        filename: file,\n        ...swcConfig,\n        jsc: {\n          ...swcConfig?.jsc,\n          parser: {\n            comments: false,\n            decorators: swcConfig?.jsc?.parser?.decorators ?? true,\n            dynamicImport: swcConfig?.jsc?.parser?.dynamicImport ?? true,\n            syntax: 'typescript' as const,\n            tsx: isTSX\n          },\n          preserveAllComments: false,\n          target: swcConfig?.jsc?.target ?? 'es2020',\n          transform: isTSX ? {\n            ...swcConfig?.jsc?.transform,\n            react: {\n              runtime: 'automatic' as const,\n              ...swcConfig?.jsc?.transform?.react\n            }\n          } : swcConfig?.jsc?.transform\n        },\n        minify: false,\n        module: {\n          ...swcConfig?.module,\n          type: format === 'cjs' ? 'commonjs' as const : (swcConfig?.module?.type as 'es6' || 'es6')\n        },\n        sourceMaps: swcConfig?.sourceMaps || 'inline'\n      };\n\n      const result = await transform(sourceCode, swcOptions);\n\n      const {writeFileSync} = await import('fs');\n      writeFileSync(outputPath, result.code);\n    });\n\n    await Promise.all(transformPromises);\n\n    spinner.succeed('Build completed with SWC');\n    displayBuildStatus('SWC', outputDir, quiet);\n    callback(0);\n    return 0;\n  } catch(error) {\n    log(`\\n${commandOptions.cliName || 'Lex'} Error: SWC build failed`, 'error', quiet);\n    log(`\\nError: ${error.message}`, 'error', quiet);\n\n    if(error instanceof Error) {\n      if(error.stack) {\n        log(`\\nStack Trace:\\n${error.stack}`, 'error', quiet);\n      }\n\n      if('filename' in error || 'file' in error) {\n        log(`\\nFile: ${(error as any).filename || (error as any).file}`, 'error', quiet);\n      }\n    }\n\n    spinner.fail('Build failed with SWC');\n    if(!quiet) {\n      console.error('\\nFull Error Details:', error);\n    }\n    callback(1);\n    return 1;\n  }\n};\n\nexport const buildWithWebpack = async (spinner, cmd, callback) => {\n  const {\n    analyze,\n    cliName = 'Lex',\n    config,\n    configName,\n    defineProcessEnvNodeEnv,\n    devtool,\n    disableInterpret,\n    entry,\n    env,\n    failOnWarnings,\n    json,\n    merge,\n    mode,\n    name,\n    nodeEnv,\n    noDevtool,\n    noStats,\n    noTarget,\n    noWatch,\n    noWatchOptionsStdin,\n    outputPath,\n    quiet = false,\n    stats,\n    target,\n    watch,\n    watchOptionsStdin\n  } = cmd;\n\n  console.log('entry:', entry, 'type:', typeof entry);\n  console.log('outputPath:', outputPath, 'type:', typeof outputPath);\n\n  const entryValue = Array.isArray(entry) ? entry[0] : entry;\n\n  let webpackConfig: string;\n\n  if(config) {\n    const isRelativeConfig: boolean = config.substr(0, 2) === './';\n    webpackConfig = isRelativeConfig ? pathResolve(process.cwd(), config) : config;\n  } else {\n    const projectConfigPath = pathResolve(process.cwd(), 'webpack.config.js');\n    const projectConfigPathTs = pathResolve(process.cwd(), 'webpack.config.ts');\n    const hasProjectConfig = existsSync(projectConfigPath) || existsSync(projectConfigPathTs);\n\n    if(hasProjectConfig) {\n      webpackConfig = existsSync(projectConfigPathTs) ? projectConfigPathTs : projectConfigPath;\n    } else {\n      const {webpackConfig: resolvedConfig} = resolveWebpackPaths(currentDirname);\n      webpackConfig = resolvedConfig;\n    }\n  }\n\n  console.log('webpackConfig path:', webpackConfig);\n  console.log('webpackConfig exists:', existsSync(webpackConfig));\n\n  if(!existsSync(webpackConfig)) {\n    const lexPackagePath = getLexPackageJsonPath();\n    const lexPackageDir = dirname(lexPackagePath);\n    const lexWebpackConfig = pathResolve(lexPackageDir, 'webpack.config.js');\n\n    if(existsSync(lexWebpackConfig)) {\n      webpackConfig = lexWebpackConfig;\n      console.log('Using Lex webpack config:', webpackConfig);\n    } else {\n      log(`\\n${cliName} Error: Could not find webpack.config.js`, 'error', quiet);\n      spinner.fail('Build failed.');\n      callback(1);\n      return 1;\n    }\n  }\n\n  const webpackOptions: string[] = [\n    '--color',\n    '--progress',\n    '--config', webpackConfig\n  ];\n\n  if(analyze) webpackOptions.push('--analyze');\n  if(configName) webpackOptions.push('--configName', configName);\n  if(defineProcessEnvNodeEnv) webpackOptions.push('--defineProcessEnvNodeEnv', defineProcessEnvNodeEnv);\n  if(devtool) webpackOptions.push('--devtool', devtool);\n  if(disableInterpret) webpackOptions.push('--disableInterpret');\n  if(entryValue) webpackOptions.push('--entry', entryValue.toString());\n  if(env) webpackOptions.push('--env', env);\n  if(failOnWarnings) webpackOptions.push('--failOnWarnings');\n  if(json) webpackOptions.push('--json', json);\n  if(mode) webpackOptions.push('--mode', mode);\n  if(merge) webpackOptions.push('--merge');\n  if(name) webpackOptions.push('--name', name);\n  if(noDevtool) webpackOptions.push('--noDevtool');\n  if(noStats) webpackOptions.push('--noStats');\n  if(noTarget) webpackOptions.push('--noTarget');\n  if(noWatch) webpackOptions.push('--noWatch');\n  if(noWatchOptionsStdin) webpackOptions.push('--noWatchOptionsStdin');\n  if(nodeEnv) webpackOptions.push('--nodeEnv', nodeEnv);\n  if(outputPath) webpackOptions.push('--output-path', outputPath.toString()); // Convert to string\n  if(stats) webpackOptions.push('--stats', stats);\n  if(target) webpackOptions.push('--target', target);\n  if(watch) webpackOptions.push('--watch');\n  if(watchOptionsStdin) webpackOptions.push('--watchOptionsStdin');\n\n  try {\n    const {webpackPath} = resolveWebpackPaths(currentDirname);\n\n    let executablePath = webpackPath;\n    let finalWebpackOptions: string[];\n\n    if(webpackPath === 'npx') {\n      finalWebpackOptions = ['webpack', ...webpackOptions];\n    } else if(webpackPath.endsWith('.js')) {\n      executablePath = 'node';\n      finalWebpackOptions = [webpackPath, ...webpackOptions];\n    } else {\n      finalWebpackOptions = [...webpackOptions];\n    }\n\n    console.log('webpackPath:', webpackPath);\n    console.log('executablePath:', executablePath);\n    console.log('finalWebpackOptions:', JSON.stringify(finalWebpackOptions));\n    console.log('finalWebpackOptions type:', Array.isArray(finalWebpackOptions) ? 'Array' : typeof finalWebpackOptions);\n\n    const childProcess = execa(executablePath, finalWebpackOptions, {encoding: 'utf8', stdio: 'pipe'});\n\n    let buildCompleted = false;\n    let buildStats = {\n      modules: 0,\n      assets: 0,\n      size: '0 B'\n    };\n\n    childProcess.stdout?.on('data', (data: Buffer) => {\n      const output = data.toString();\n\n      handleWebpackProgress(output, spinner, quiet, '🏗️', 'Webpack Building');\n\n      if(!buildCompleted && output.includes('compiled successfully')) {\n        buildCompleted = true;\n        spinner.succeed('Build completed successfully!');\n\n        const moduleMatch = output.match(/(\\d+) modules/);\n        const assetMatch = output.match(/(\\d+) assets/);\n        const sizeMatch = output.match(/assets by status ([\\d.]+ \\w+)/) || output.match(/assets by path.*?([\\d.]+ \\w+)/);\n\n        if(moduleMatch) buildStats.modules = parseInt(moduleMatch[1], 10);\n        if(assetMatch) buildStats.assets = parseInt(assetMatch[1], 10);\n        if(sizeMatch) buildStats.size = sizeMatch[1];\n\n        displayBuildStatus('webpack', LexConfig.config.outputFullPath || 'lib', quiet, buildStats);\n      }\n    });\n\n    childProcess.stderr?.on('data', (data: Buffer) => {\n      const output = data.toString();\n\n      handleWebpackProgress(output, spinner, quiet, '🏗️', 'Webpack Building');\n\n      if(!buildCompleted && output.includes('compiled successfully')) {\n        buildCompleted = true;\n        spinner.succeed('Build completed successfully!');\n\n        const moduleMatch = output.match(/(\\d+) modules/);\n        const assetMatch = output.match(/(\\d+) assets/);\n        const sizeMatch = output.match(/assets by status ([\\d.]+ \\w+)/) || output.match(/assets by path.*?([\\d.]+ \\w+)/);\n\n        if(moduleMatch) buildStats.modules = parseInt(moduleMatch[1], 10);\n        if(assetMatch) buildStats.assets = parseInt(assetMatch[1], 10);\n        if(sizeMatch) buildStats.size = sizeMatch[1];\n\n        displayBuildStatus('webpack', LexConfig.config.outputFullPath || 'lib', quiet, buildStats);\n      }\n    });\n\n    await childProcess;\n\n    if(!buildCompleted) {\n      spinner.succeed('Build completed successfully!');\n      displayBuildStatus('webpack', LexConfig.config.outputFullPath || 'lib', quiet, buildStats);\n    }\n\n    callback(0);\n    return 0;\n  } catch(error) {\n    log(`\\n${cliName} Error: Webpack build failed`, 'error', quiet);\n    log(`\\nError: ${error.message}`, 'error', quiet);\n\n    if(error instanceof Error) {\n      if(error.stack) {\n        log(`\\nStack Trace:\\n${error.stack}`, 'error', quiet);\n      }\n    }\n\n    log(`\\nWebpack Options: ${webpackOptions.slice(0, 5).join(' ')}...`, 'error', quiet);\n\n    spinner.fail('Build failed.');\n\n    if(cmd.assist) {\n      spinner.start('AI is analyzing the webpack error...');\n\n      try {\n        await aiFunction({\n          prompt: `Fix this webpack build error: ${error.message}\\n\\nError details:\\n${error.toString()}\\n\\nConfiguration used:\\n${JSON.stringify(webpackOptions, null, 2)}`,\n          task: 'help',\n          context: true,\n          quiet\n        });\n\n        spinner.succeed('AI analysis complete');\n      } catch(aiError) {\n        spinner.fail('Could not generate AI assistance');\n        if(!quiet) {\n          console.error('AI assistance error:', aiError);\n        }\n      }\n    }\n\n    if(!quiet) {\n      console.error('\\nFull Error Details:', error);\n    }\n\n    callback(1);\n    return 1;\n  }\n};\n\nexport const build = async (cmd: BuildOptions, callback: BuildCallback = () => ({})): Promise<number> => {\n  const {\n    bundler = 'webpack',\n    cliName = 'Lex',\n    quiet = false,\n    remove = false,\n    test = false,\n    translations = false,\n    variables = '{}'\n  } = cmd;\n\n  const spinner = createSpinner(quiet);\n\n  log(`${cliName} building...`, 'info', quiet);\n\n  await LexConfig.parseConfig(cmd);\n\n  const {outputFullPath, useTypescript} = LexConfig.config;\n\n  checkLinkedModules();\n\n  let variablesObj: object = {NODE_ENV: 'production'};\n\n  if(variables) {\n    try {\n      variablesObj = JSON.parse(variables);\n    } catch(error) {\n      log(`\\n${cliName} Error: Environment variables option is not a valid JSON object.`, 'error', quiet);\n\n      callback(1);\n      return 1;\n    }\n  }\n\n  process.env = {...process.env, ...variablesObj};\n\n  if(test) {\n    log('Test mode: Build environment loaded, exiting', 'info', quiet);\n    callback(0);\n    return 0;\n  }\n\n  if(translations) {\n    spinner.start('Processing translations...');\n\n    try {\n      const sourcePath = LexConfig.config.sourceFullPath || process.cwd();\n      const outputPath = LexConfig.config.outputFullPath || 'lib';\n\n      await processTranslations(sourcePath, outputPath, quiet);\n      spinner.succeed('Translations processed successfully!');\n    } catch(translationError) {\n      log(`\\n${cliName} Error: Failed to process translations: ${translationError.message}`, 'error', quiet);\n      spinner.fail('Failed to process translations.');\n      callback(1);\n      return 1;\n    }\n  }\n\n  spinner.start('Building code...');\n\n  if(remove) {\n    await removeFiles(outputFullPath || '');\n  }\n\n  let buildResult = 0;\n\n  if(bundler === 'swc') {\n    buildResult = await buildWithSWC(spinner, cmd, (status) => {\n      buildResult = status;\n    });\n  } else {\n    buildResult = await buildWithWebpack(spinner, cmd, (status) => {\n      buildResult = status;\n    });\n  }\n\n  if(buildResult === 0 && cmd.analyze) {\n    spinner.start('AI is analyzing the build output for optimization opportunities...');\n\n    try {\n      const stats = {\n        outputPath: LexConfig.config.outputFullPath,\n        entryPoints: bundler === 'swc' ?\n          `Source files: ${LexConfig.config.sourceFullPath}/**/*.{ts,js}` :\n          LexConfig.config.webpack?.entry || 'Unknown entry points'\n      };\n\n      await aiFunction({\n        prompt: `Analyze this build for optimization opportunities:\n\nBuild Type: ${bundler}\nFormat: ${cmd.format || 'default'}\nEnvironment: ${LexConfig.config.targetEnvironment}\n${JSON.stringify(stats, null, 2)}\n\nWhat are the key optimization opportunities for this build configuration? Consider:\n1. Bundle size optimization strategies\n2. Code splitting recommendations\n3. Tree-shaking improvements\n4. Performance enhancements\n5. Dependency optimizations`,\n        task: 'optimize',\n        context: true,\n        quiet\n      });\n\n      spinner.succeed('AI build analysis complete');\n    } catch(aiError) {\n      spinner.fail('Could not generate AI optimization analysis');\n      if(!quiet) {\n        console.error('AI analysis error:', aiError);\n      }\n    }\n  }\n\n  if(buildResult === 0) {\n    try {\n      if(useTypescript && bundler === 'swc') {\n        const typescriptPath = resolveBinaryPath('tsc', 'typescript');\n\n        if(typescriptPath) {\n          spinner.start('Generating TypeScript declarations...');\n          try {\n            const sourceFullPath = LexConfig.config.sourceFullPath || pathResolve(process.cwd(), './src');\n            const outputFullPath = LexConfig.config.outputFullPath || pathResolve(process.cwd(), './lib');\n            const globOptions = {\n              cwd: sourceFullPath,\n              dot: false,\n              nodir: true,\n              absolute: true\n            };\n            const tsFiles = globSync(`**/!(*.spec|*.test|*.integration).ts`, globOptions);\n            const tsxFiles = globSync(`**/!(*.spec|*.test|*.integration).tsx`, globOptions);\n            const allSourceFiles = [...tsFiles, ...tsxFiles];\n            const typescriptOptions = [\n              ...LexConfig.getTypeScriptDeclarationFlags(),\n              ...allSourceFiles\n            ];\n            const result = await execa(typescriptPath, typescriptOptions, {\n              encoding: 'utf8',\n              cwd: process.cwd(),\n              reject: false,\n              all: true\n            });\n\n            if(result.exitCode !== 0) {\n              // TypeScript may have errors but still generate some declarations\n              // Log warnings but don't fail if declarations were generated\n              const hasDeclarations = result.all?.includes('Writing') || result.all?.includes('Declaration') || false;\n              const errorOutput = result.stderr || result.stdout || result.all || 'Unknown error';\n\n              if(!hasDeclarations) {\n                log(`\\n${cliName} Error: TypeScript declaration generation failed`, 'error', quiet);\n                log(`\\nExit Code: ${result.exitCode}`, 'error', quiet);\n                log(`\\nTypeScript Command: ${typescriptPath} ${typescriptOptions.slice(0, 10).join(' ')}...`, 'error', quiet);\n                log(`\\nError Output:\\n${errorOutput}`, 'error', quiet);\n\n                const errorLines = errorOutput.split('\\n').filter(line =>\n                  line.includes('error TS') ||\n                  line.includes('Error:') ||\n                  line.trim().startsWith('src/') ||\n                  line.trim().startsWith('TS')\n                );\n\n                if(errorLines.length > 0) {\n                  log(`\\nKey Errors:`, 'error', quiet);\n                  errorLines.slice(0, 10).forEach(line => {\n                    log(`  ${line}`, 'error', quiet);\n                  });\n                  if(errorLines.length > 10) {\n                    log(`  ... and ${errorLines.length - 10} more errors`, 'error', quiet);\n                  }\n                }\n\n                spinner.fail('TypeScript declaration generation had errors (continuing anyway).');\n              } else {\n                log(`\\n${cliName} Warning: TypeScript declaration generation completed with errors`, 'warn', quiet);\n                if(!quiet && errorOutput) {\n                  log(`\\nWarnings:\\n${errorOutput}`, 'warn', quiet);\n                }\n                spinner.succeed('TypeScript declarations generated (with warnings).');\n              }\n            } else {\n              spinner.succeed('TypeScript declarations generated!');\n            }\n          } catch(error) {\n            log(`\\n${cliName} Error: TypeScript declaration generation exception`, 'error', quiet);\n            log(`\\nError: ${error.message}`, 'error', quiet);\n            if(error instanceof Error && error.stack) {\n              log(`\\nStack:\\n${error.stack}`, 'error', quiet);\n            }\n            spinner.fail('TypeScript declaration generation had issues (continuing anyway).');\n          }\n        }\n      }\n\n      await copyConfiguredFiles(spinner, LexConfig.config, quiet);\n    } catch(copyError) {\n      log(`\\n${cliName} Error: Failed to copy configured files: ${copyError.message}`, 'error', quiet);\n      callback(1);\n      return 1;\n    }\n  }\n\n  callback(buildResult);\n  return buildResult;\n};\n\nexport default build;\n"],"names":["transform","execa","existsSync","readFileSync","sync","globSync","dirname","relative","pathRelative","resolve","pathResolve","LexConfig","checkLinkedModules","copyConfiguredFiles","createSpinner","handleWebpackProgress","removeFiles","resolveWebpackPaths","getLexPackageJsonPath","resolveBinaryPath","log","processTranslations","aiFunction","boxen","chalk","currentFilename","currentDirname","eval","process","cwd","displayBuildStatus","bundler","outputPath","quiet","stats","statsInfo","modules","assets","green","cyan","size","statusBox","bold","underline","yellow","padding","margin","borderStyle","borderColor","backgroundColor","console","buildWithSWC","spinner","commandOptions","callback","cliName","format","sourcePath","watch","outputFullPath","sourceFullPath","swc","swcConfig","targetEnvironment","useGraphQl","useTypescript","config","sourceDir","globOptions","absolute","dot","nodir","nosort","tsFiles","jsFiles","sourceFiles","outputDir","start","transformPromises","map","file","fileRelativeToSource","outputFile","replace","outputDirPath","mkdirSync","recursive","sourceCode","isTSX","endsWith","swcOptions","filename","jsc","parser","comments","decorators","dynamicImport","syntax","tsx","preserveAllComments","target","react","runtime","minify","module","type","sourceMaps","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","watchOptionsStdin","entryValue","Array","isArray","webpackConfig","isRelativeConfig","substr","projectConfigPath","projectConfigPathTs","hasProjectConfig","resolvedConfig","lexPackagePath","lexPackageDir","lexWebpackConfig","webpackOptions","push","toString","webpackPath","executablePath","finalWebpackOptions","JSON","stringify","childProcess","encoding","stdio","buildCompleted","buildStats","stdout","on","data","output","includes","moduleMatch","match","assetMatch","sizeMatch","parseInt","stderr","slice","join","assist","prompt","task","context","aiError","build","remove","test","translations","variables","parseConfig","variablesObj","NODE_ENV","parse","translationError","buildResult","status","entryPoints","webpack","typescriptPath","tsxFiles","allSourceFiles","typescriptOptions","getTypeScriptDeclarationFlags","reject","exitCode","hasDeclarations","errorOutput","errorLines","split","filter","line","trim","startsWith","length","forEach","copyError"],"mappings":"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"}
@@ -31,7 +31,7 @@ export const compile = async (cmd, callback = ()=>({}))=>{
31
31
  log(`${cliName} compiling...`, 'info', quiet);
32
32
  await LexConfig.parseConfig(cmd);
33
33
  const { outputFullPath, sourceFullPath, swc: swcConfig, useTypescript } = LexConfig.config;
34
- const outputDir = outputPath || outputFullPath;
34
+ const outputDir = outputPath ? pathResolve(process.cwd(), outputPath) : outputFullPath || pathResolve(process.cwd(), './lib');
35
35
  const sourceDir = sourcePath ? pathResolve(process.cwd(), `./${sourcePath}`) : sourceFullPath || '';
36
36
  const dirName = getDirName();
37
37
  checkLinkedModules();
@@ -216,9 +216,9 @@ export const compile = async (cmd, callback = ()=>({}))=>{
216
216
  }
217
217
  spinner.start(watch ? 'Watching for changes...' : 'Compiling with SWC...');
218
218
  try {
219
- for (const file of sourceFiles){
220
- const fileRelativeToSource = pathRelative(sourceDir, pathResolve(sourceDir, file));
221
- const sourcePath = pathResolve(sourceDir, fileRelativeToSource);
219
+ const transformPromises = sourceFiles.map(async (file)=>{
220
+ const fileRelativeToSource = pathRelative(sourceDir, file);
221
+ const sourcePath = file;
222
222
  const outputFile = fileRelativeToSource.replace(/\.(ts|tsx)$/, '.js');
223
223
  const outputPath = pathResolve(outputDir, outputFile);
224
224
  const outputDirPath = dirname(outputPath);
@@ -260,7 +260,8 @@ export const compile = async (cmd, callback = ()=>({}))=>{
260
260
  };
261
261
  const result = await transform(sourceCode, swcOptions);
262
262
  writeFileSync(outputPath, result.code);
263
- }
263
+ });
264
+ await Promise.all(transformPromises);
264
265
  spinner.succeed('Compile completed successfully!');
265
266
  } catch (error) {
266
267
  log(`\n${cliName} Error: SWC compilation failed`, 'error', quiet);
@@ -274,6 +275,7 @@ export const compile = async (cmd, callback = ()=>({}))=>{
274
275
  }
275
276
  }
276
277
  if (!quiet) {
278
+ // eslint-disable-next-line no-console
277
279
  console.error('\nFull Error Details:', error);
278
280
  }
279
281
  spinner.fail('Code compiling failed.');
@@ -292,4 +294,4 @@ export const compile = async (cmd, callback = ()=>({}))=>{
292
294
  return 0;
293
295
  };
294
296
 
295
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/commands/compile/compile.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, lstatSync, readdirSync, readFileSync, writeFileSync, mkdirSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport {extname as pathExtname, join as pathJoin, relative as pathRelative, resolve as pathResolve, dirname} from 'path';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {checkLinkedModules, copyConfiguredFiles, copyFiles, createSpinner, getFilesByExt, removeFiles} from '../../utils/app.js';\nimport {getDirName, resolveBinaryPath} from '../../utils/file.js';\nimport {log} from '../../utils/log.js';\n\nexport const hasFileType = (startPath: string, ext: string[]): boolean => {\n  if(!existsSync(startPath)) {\n    return false;\n  }\n\n  const files: string[] = readdirSync(startPath);\n\n  return files.some((file: string) => {\n    const filename: string = pathJoin(startPath, file);\n    const fileExt: string = pathExtname(filename);\n    const stat = lstatSync(filename);\n\n    if(stat.isDirectory()) {\n      return hasFileType(filename, ext);\n    }\n\n    return ext.includes(fileExt);\n  });\n};\n\nexport const compile = async (cmd: any, callback: any = () => ({})): Promise<number> => {\n  const {\n    cliName = 'Lex',\n    config,\n    format = 'esm',\n    outputPath,\n    quiet,\n    remove,\n    sourcePath,\n    watch\n  } = cmd;\n\n  const spinner = createSpinner(quiet);\n\n  log(`${cliName} compiling...`, 'info', quiet);\n\n  await LexConfig.parseConfig(cmd);\n\n  const {outputFullPath, sourceFullPath, swc: swcConfig, useTypescript} = LexConfig.config;\n  const outputDir: string = outputPath || outputFullPath;\n  const sourceDir: string = sourcePath ? pathResolve(process.cwd(), `./${sourcePath}`) : sourceFullPath || '';\n  const dirName = getDirName();\n\n  checkLinkedModules();\n\n  if(remove) {\n    await removeFiles(outputDir);\n  }\n\n  if(useTypescript) {\n    const typescriptPath: string = resolveBinaryPath('tsc', 'typescript');\n\n    if(!typescriptPath) {\n      log(`\\n${cliName} Error: TypeScript binary not found in Lex's node_modules or monorepo root`, 'error', quiet);\n      log('Please reinstall Lex or check your installation.', 'info', quiet);\n      return 1;\n    }\n\n    const typescriptOptions: string[] = config\n      ? ['-p', config, '--emitDeclarationOnly', '--skipLibCheck'] // User provided custom config, but still only emit declarations\n      : (() => {\n        const globOptions = {\n          absolute: true,\n          cwd: sourceDir,\n          dot: false,\n          nodir: 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\n        return [\n          ...LexConfig.getTypeScriptDeclarationFlags(),\n          ...allSourceFiles\n        ];\n      })();\n\n    spinner.start('Generating TypeScript declarations...');\n\n    try {\n      const result = await execa(typescriptPath, typescriptOptions, {\n        all: true,\n        cwd: process.cwd(),\n        encoding: 'utf8',\n        reject: false\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.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\n            errorLines.slice(0, 10).forEach((line) => {\n              log(`  ${line}`, 'error', quiet);\n            });\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 failed.');\n        } else {\n          log(`\\n${cliName} Warning: TypeScript declaration generation completed with errors`, 'warn', quiet);\n\n          if(!quiet && errorOutput) {\n            log(`\\nWarnings:\\n${errorOutput}`, 'warn', quiet);\n          }\n\n          spinner.succeed('TypeScript declarations generated (with warnings).');\n        }\n      } else {\n        spinner.succeed('Successfully generated TypeScript declarations!');\n      }\n    } catch(error) {\n      log(`\\n${cliName} Error: TypeScript declaration generation exception`, 'error', quiet);\n      log(`\\nError: ${error.message}`, 'error', quiet);\n\n      if(error instanceof Error && error.stack) {\n        log(`\\nStack:\\n${error.stack}`, 'error', quiet);\n      }\n\n      spinner.fail('TypeScript declaration generation had issues, continuing...');\n    }\n  }\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|*.integration).ts*', globOptions);\n  const jsFiles: string[] = globSync('**/!(*.spec|*.test|*.integration).js', globOptions);\n  const sourceFiles: string[] = [...tsFiles, ...jsFiles];\n\n  const cssFiles: string[] = getFilesByExt('.css', LexConfig.config);\n\n  if(cssFiles.length) {\n    const postcssPath: string = resolveBinaryPath('postcss', 'postcss-cli');\n\n    if(!postcssPath) {\n      log(`\\n${cliName} Error: PostCSS binary not found in Lex's node_modules or monorepo root`, 'error', quiet);\n      log('Please reinstall Lex or check your installation.', 'info', quiet);\n      return 1;\n    }\n\n    const postcssOptions: string[] = [\n      `${sourceDir}/**/**.css`,\n      '--base',\n      sourceDir,\n      '--dir',\n      outputDir,\n      '--config',\n      pathResolve(dirName, '../../postcss.config.js')\n    ];\n\n    try {\n      await execa(postcssPath, postcssOptions, {encoding: 'utf8'});\n      spinner.succeed(`Successfully formatted ${cssFiles.length} css files!`);\n    } catch(error) {\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      spinner.fail('Failed formatting css.');\n\n      callback(1);\n      return 1;\n    }\n  }\n\n  const gifFiles: string[] = getFilesByExt('.gif', LexConfig.config);\n  const jpgFiles: string[] = getFilesByExt('.jpg', LexConfig.config);\n  const pngFiles: string[] = getFilesByExt('.png', LexConfig.config);\n  const svgFiles: string[] = getFilesByExt('.svg', LexConfig.config);\n  const imageFiles: string[] = [...gifFiles, ...jpgFiles, ...pngFiles, ...svgFiles];\n\n  if(imageFiles.length) {\n    try {\n      await copyFiles(imageFiles, 'image', spinner, LexConfig.config);\n    } catch(error) {\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      spinner.fail('Failed to move images to output directory.');\n\n      callback(1);\n      return 1;\n    }\n  }\n\n  const ttfFiles: string[] = getFilesByExt('.ttf', LexConfig.config);\n  const otfFiles: string[] = getFilesByExt('.otf', LexConfig.config);\n  const woffFiles: string[] = getFilesByExt('.woff', LexConfig.config);\n  const woff2Files: string[] = getFilesByExt('.woff2', LexConfig.config);\n  const fontFiles: string[] = [...ttfFiles, ...otfFiles, ...woffFiles, ...woff2Files];\n\n  if(fontFiles.length) {\n    try {\n      await copyFiles(fontFiles, 'font', spinner, LexConfig.config);\n    } catch(error) {\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      spinner.fail('Failed to move fonts to output directory.');\n\n      callback(1);\n      return 1;\n    }\n  }\n\n  const mdFiles: string[] = getFilesByExt('.md', LexConfig.config);\n\n  if(mdFiles.length) {\n    try {\n      await copyFiles(mdFiles, 'documents', spinner, LexConfig.config);\n    } catch(error) {\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      spinner.fail('Failed to move docs to output directory.');\n\n      callback(1);\n      return 1;\n    }\n  }\n\n  if(sourceFiles.length === 0) {\n    log(`\\n${cliName} Warning: No source files found to compile in ${sourceDir}`, 'warn', quiet);\n    spinner.succeed('No files to compile.');\n    callback(0);\n    return 0;\n  }\n\n  spinner.start(watch ? 'Watching for changes...' : 'Compiling with SWC...');\n\n  try {\n    for(const file of sourceFiles) {\n      const fileRelativeToSource = pathRelative(sourceDir, pathResolve(sourceDir, file));\n      const sourcePath = pathResolve(sourceDir, fileRelativeToSource);\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        mkdirSync(outputDirPath, {recursive: true});\n      }\n\n      const sourceCode = readFileSync(sourcePath, 'utf8');\n      const isTSX = file.endsWith('.tsx');\n      const swcOptions = {\n        filename: file,\n        ...swcConfig,\n        jsc: {\n          ...swcConfig?.jsc,\n          parser: {\n            comments: false,\n            decorators: swcConfig?.jsc?.parser?.decorators ?? true,\n            dynamicImport: swcConfig?.jsc?.parser?.dynamicImport ?? true,\n            syntax: 'typescript' as const,\n            tsx: isTSX\n          },\n          preserveAllComments: false,\n          target: swcConfig?.jsc?.target ?? 'es2020',\n          transform: isTSX ? {\n            ...swcConfig?.jsc?.transform,\n            react: {\n              runtime: 'automatic' as const,\n              ...swcConfig?.jsc?.transform?.react\n            }\n          } : swcConfig?.jsc?.transform\n        },\n        minify: false,\n        module: {\n          ...swcConfig?.module,\n          type: format === 'cjs' ? 'commonjs' as const : (swcConfig?.module?.type as 'es6' || 'es6')\n        },\n        sourceMaps: swcConfig?.sourceMaps || 'inline'\n      };\n\n      const result = await transform(sourceCode, swcOptions);\n\n      writeFileSync(outputPath, result.code);\n    }\n\n    spinner.succeed('Compile completed successfully!');\n  } catch(error) {\n    log(`\\n${cliName} Error: SWC compilation 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    if(!quiet) {\n      console.error('\\nFull Error Details:', error);\n    }\n\n    spinner.fail('Code compiling failed.');\n\n    callback(1);\n    return 1;\n  }\n\n  try {\n    await copyConfiguredFiles(spinner, LexConfig.config, quiet);\n  } catch(copyError) {\n    log(`\\n${cliName} Error: Failed to copy configured files: ${copyError.message}`, 'error', quiet);\n\n    spinner.fail('Failed to copy configured files.');\n\n    callback(1);\n    return 1;\n  }\n\n  callback(0);\n  return 0;\n};"],"names":["transform","execa","existsSync","lstatSync","readdirSync","readFileSync","writeFileSync","mkdirSync","sync","globSync","extname","pathExtname","join","pathJoin","relative","pathRelative","resolve","pathResolve","dirname","LexConfig","checkLinkedModules","copyConfiguredFiles","copyFiles","createSpinner","getFilesByExt","removeFiles","getDirName","resolveBinaryPath","log","hasFileType","startPath","ext","files","some","file","filename","fileExt","stat","isDirectory","includes","compile","cmd","callback","cliName","config","format","outputPath","quiet","remove","sourcePath","watch","spinner","parseConfig","outputFullPath","sourceFullPath","swc","swcConfig","useTypescript","outputDir","sourceDir","process","cwd","dirName","typescriptPath","typescriptOptions","globOptions","absolute","dot","nodir","tsFiles","tsxFiles","allSourceFiles","getTypeScriptDeclarationFlags","start","result","all","encoding","reject","exitCode","hasDeclarations","errorOutput","stderr","stdout","errorLines","split","filter","line","trim","startsWith","length","slice","forEach","fail","succeed","error","message","Error","stack","nosort","jsFiles","sourceFiles","cssFiles","postcssPath","postcssOptions","gifFiles","jpgFiles","pngFiles","svgFiles","imageFiles","ttfFiles","otfFiles","woffFiles","woff2Files","fontFiles","mdFiles","fileRelativeToSource","outputFile","replace","outputDirPath","recursive","sourceCode","isTSX","endsWith","swcOptions","jsc","parser","comments","decorators","dynamicImport","syntax","tsx","preserveAllComments","target","react","runtime","minify","module","type","sourceMaps","code","console","copyError"],"mappings":"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"}
297
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/commands/compile/compile.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, lstatSync, readdirSync, readFileSync, writeFileSync, mkdirSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport {extname as pathExtname, join as pathJoin, relative as pathRelative, resolve as pathResolve, dirname} from 'path';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {checkLinkedModules, copyConfiguredFiles, copyFiles, createSpinner, getFilesByExt, removeFiles} from '../../utils/app.js';\nimport {getDirName, resolveBinaryPath} from '../../utils/file.js';\nimport {log} from '../../utils/log.js';\n\nexport const hasFileType = (startPath: string, ext: string[]): boolean => {\n  if(!existsSync(startPath)) {\n    return false;\n  }\n\n  const files: string[] = readdirSync(startPath);\n\n  return files.some((file: string) => {\n    const filename: string = pathJoin(startPath, file);\n    const fileExt: string = pathExtname(filename);\n    const stat = lstatSync(filename);\n\n    if(stat.isDirectory()) {\n      return hasFileType(filename, ext);\n    }\n\n    return ext.includes(fileExt);\n  });\n};\n\nexport const compile = async (cmd: any, callback: any = () => ({})): Promise<number> => {\n  const {\n    cliName = 'Lex',\n    config,\n    format = 'esm',\n    outputPath,\n    quiet,\n    remove,\n    sourcePath,\n    watch\n  } = cmd;\n\n  const spinner = createSpinner(quiet);\n\n  log(`${cliName} compiling...`, 'info', quiet);\n\n  await LexConfig.parseConfig(cmd);\n\n  const {outputFullPath, sourceFullPath, swc: swcConfig, useTypescript} = LexConfig.config;\n  const outputDir: string = outputPath\n    ? pathResolve(process.cwd(), outputPath)\n    : (outputFullPath || pathResolve(process.cwd(), './lib'));\n  const sourceDir: string = sourcePath ? pathResolve(process.cwd(), `./${sourcePath}`) : sourceFullPath || '';\n  const dirName = getDirName();\n\n  checkLinkedModules();\n\n  if(remove) {\n    await removeFiles(outputDir);\n  }\n\n  if(useTypescript) {\n    const typescriptPath: string = resolveBinaryPath('tsc', 'typescript');\n\n    if(!typescriptPath) {\n      log(`\\n${cliName} Error: TypeScript binary not found in Lex's node_modules or monorepo root`, 'error', quiet);\n      log('Please reinstall Lex or check your installation.', 'info', quiet);\n      return 1;\n    }\n\n    const typescriptOptions: string[] = config\n      ? ['-p', config, '--emitDeclarationOnly', '--skipLibCheck'] // User provided custom config, but still only emit declarations\n      : (() => {\n        const globOptions = {\n          absolute: true,\n          cwd: sourceDir,\n          dot: false,\n          nodir: 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\n        return [\n          ...LexConfig.getTypeScriptDeclarationFlags(),\n          ...allSourceFiles\n        ];\n      })();\n\n    spinner.start('Generating TypeScript declarations...');\n\n    try {\n      const result = await execa(typescriptPath, typescriptOptions, {\n        all: true,\n        cwd: process.cwd(),\n        encoding: 'utf8',\n        reject: false\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.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\n            errorLines.slice(0, 10).forEach((line) => {\n              log(`  ${line}`, 'error', quiet);\n            });\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 failed.');\n        } else {\n          log(`\\n${cliName} Warning: TypeScript declaration generation completed with errors`, 'warn', quiet);\n\n          if(!quiet && errorOutput) {\n            log(`\\nWarnings:\\n${errorOutput}`, 'warn', quiet);\n          }\n\n          spinner.succeed('TypeScript declarations generated (with warnings).');\n        }\n      } else {\n        spinner.succeed('Successfully generated TypeScript declarations!');\n      }\n    } catch(error) {\n      log(`\\n${cliName} Error: TypeScript declaration generation exception`, 'error', quiet);\n      log(`\\nError: ${error.message}`, 'error', quiet);\n\n      if(error instanceof Error && error.stack) {\n        log(`\\nStack:\\n${error.stack}`, 'error', quiet);\n      }\n\n      spinner.fail('TypeScript declaration generation had issues, continuing...');\n    }\n  }\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|*.integration).ts*', globOptions);\n  const jsFiles: string[] = globSync('**/!(*.spec|*.test|*.integration).js', globOptions);\n  const sourceFiles: string[] = [...tsFiles, ...jsFiles];\n\n  const cssFiles: string[] = getFilesByExt('.css', LexConfig.config);\n\n  if(cssFiles.length) {\n    const postcssPath: string = resolveBinaryPath('postcss', 'postcss-cli');\n\n    if(!postcssPath) {\n      log(`\\n${cliName} Error: PostCSS binary not found in Lex's node_modules or monorepo root`, 'error', quiet);\n      log('Please reinstall Lex or check your installation.', 'info', quiet);\n      return 1;\n    }\n\n    const postcssOptions: string[] = [\n      `${sourceDir}/**/**.css`,\n      '--base',\n      sourceDir,\n      '--dir',\n      outputDir,\n      '--config',\n      pathResolve(dirName, '../../postcss.config.js')\n    ];\n\n    try {\n      await execa(postcssPath, postcssOptions, {encoding: 'utf8'});\n      spinner.succeed(`Successfully formatted ${cssFiles.length} css files!`);\n    } catch(error) {\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      spinner.fail('Failed formatting css.');\n\n      callback(1);\n      return 1;\n    }\n  }\n\n  const gifFiles: string[] = getFilesByExt('.gif', LexConfig.config);\n  const jpgFiles: string[] = getFilesByExt('.jpg', LexConfig.config);\n  const pngFiles: string[] = getFilesByExt('.png', LexConfig.config);\n  const svgFiles: string[] = getFilesByExt('.svg', LexConfig.config);\n  const imageFiles: string[] = [...gifFiles, ...jpgFiles, ...pngFiles, ...svgFiles];\n\n  if(imageFiles.length) {\n    try {\n      await copyFiles(imageFiles, 'image', spinner, LexConfig.config);\n    } catch(error) {\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      spinner.fail('Failed to move images to output directory.');\n\n      callback(1);\n      return 1;\n    }\n  }\n\n  const ttfFiles: string[] = getFilesByExt('.ttf', LexConfig.config);\n  const otfFiles: string[] = getFilesByExt('.otf', LexConfig.config);\n  const woffFiles: string[] = getFilesByExt('.woff', LexConfig.config);\n  const woff2Files: string[] = getFilesByExt('.woff2', LexConfig.config);\n  const fontFiles: string[] = [...ttfFiles, ...otfFiles, ...woffFiles, ...woff2Files];\n\n  if(fontFiles.length) {\n    try {\n      await copyFiles(fontFiles, 'font', spinner, LexConfig.config);\n    } catch(error) {\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      spinner.fail('Failed to move fonts to output directory.');\n\n      callback(1);\n      return 1;\n    }\n  }\n\n  const mdFiles: string[] = getFilesByExt('.md', LexConfig.config);\n\n  if(mdFiles.length) {\n    try {\n      await copyFiles(mdFiles, 'documents', spinner, LexConfig.config);\n    } catch(error) {\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      spinner.fail('Failed to move docs to output directory.');\n\n      callback(1);\n      return 1;\n    }\n  }\n\n  if(sourceFiles.length === 0) {\n    log(`\\n${cliName} Warning: No source files found to compile in ${sourceDir}`, 'warn', quiet);\n    spinner.succeed('No files to compile.');\n    callback(0);\n    return 0;\n  }\n\n  spinner.start(watch ? 'Watching for changes...' : 'Compiling with SWC...');\n\n  try {\n    const transformPromises = sourceFiles.map(async (file) => {\n      const fileRelativeToSource = pathRelative(sourceDir, file);\n      const sourcePath = file;\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        mkdirSync(outputDirPath, {recursive: true});\n      }\n\n      const sourceCode = readFileSync(sourcePath, 'utf8');\n      const isTSX = file.endsWith('.tsx');\n      const swcOptions = {\n        filename: file,\n        ...swcConfig,\n        jsc: {\n          ...swcConfig?.jsc,\n          parser: {\n            comments: false,\n            decorators: swcConfig?.jsc?.parser?.decorators ?? true,\n            dynamicImport: swcConfig?.jsc?.parser?.dynamicImport ?? true,\n            syntax: 'typescript' as const,\n            tsx: isTSX\n          },\n          preserveAllComments: false,\n          target: swcConfig?.jsc?.target ?? 'es2020',\n          transform: isTSX ? {\n            ...swcConfig?.jsc?.transform,\n            react: {\n              runtime: 'automatic' as const,\n              ...swcConfig?.jsc?.transform?.react\n            }\n          } : swcConfig?.jsc?.transform\n        },\n        minify: false,\n        module: {\n          ...swcConfig?.module,\n          type: format === 'cjs' ? 'commonjs' as const : (swcConfig?.module?.type as 'es6' || 'es6')\n        },\n        sourceMaps: swcConfig?.sourceMaps || 'inline'\n      };\n\n      const result = await transform(sourceCode, swcOptions);\n\n      writeFileSync(outputPath, result.code);\n    });\n\n    await Promise.all(transformPromises);\n\n    spinner.succeed('Compile completed successfully!');\n  } catch(error) {\n    log(`\\n${cliName} Error: SWC compilation 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    if(!quiet) {\n      // eslint-disable-next-line no-console\n      console.error('\\nFull Error Details:', error);\n    }\n\n    spinner.fail('Code compiling failed.');\n\n    callback(1);\n    return 1;\n  }\n\n  try {\n    await copyConfiguredFiles(spinner, LexConfig.config, quiet);\n  } catch(copyError) {\n    log(`\\n${cliName} Error: Failed to copy configured files: ${copyError.message}`, 'error', quiet);\n\n    spinner.fail('Failed to copy configured files.');\n\n    callback(1);\n    return 1;\n  }\n\n  callback(0);\n  return 0;\n};"],"names":["transform","execa","existsSync","lstatSync","readdirSync","readFileSync","writeFileSync","mkdirSync","sync","globSync","extname","pathExtname","join","pathJoin","relative","pathRelative","resolve","pathResolve","dirname","LexConfig","checkLinkedModules","copyConfiguredFiles","copyFiles","createSpinner","getFilesByExt","removeFiles","getDirName","resolveBinaryPath","log","hasFileType","startPath","ext","files","some","file","filename","fileExt","stat","isDirectory","includes","compile","cmd","callback","cliName","config","format","outputPath","quiet","remove","sourcePath","watch","spinner","parseConfig","outputFullPath","sourceFullPath","swc","swcConfig","useTypescript","outputDir","process","cwd","sourceDir","dirName","typescriptPath","typescriptOptions","globOptions","absolute","dot","nodir","tsFiles","tsxFiles","allSourceFiles","getTypeScriptDeclarationFlags","start","result","all","encoding","reject","exitCode","hasDeclarations","errorOutput","stderr","stdout","errorLines","split","filter","line","trim","startsWith","length","slice","forEach","fail","succeed","error","message","Error","stack","nosort","jsFiles","sourceFiles","cssFiles","postcssPath","postcssOptions","gifFiles","jpgFiles","pngFiles","svgFiles","imageFiles","ttfFiles","otfFiles","woffFiles","woff2Files","fontFiles","mdFiles","transformPromises","map","fileRelativeToSource","outputFile","replace","outputDirPath","recursive","sourceCode","isTSX","endsWith","swcOptions","jsc","parser","comments","decorators","dynamicImport","syntax","tsx","preserveAllComments","target","react","runtime","minify","module","type","sourceMaps","code","Promise","console","copyError"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nlabs/lex",
3
- "version": "1.52.0",
3
+ "version": "1.52.2",
4
4
  "description": "Lex",
5
5
  "license": "MIT",
6
6
  "type": "module",
package/webpack.config.js CHANGED
@@ -652,6 +652,9 @@ export default (webpackEnv, webpackOptions) => {
652
652
  '.gql',
653
653
  '.graphql'
654
654
  ],
655
+ extensionAlias: {
656
+ '.js': ['.ts', '.tsx', '.js', '.jsx']
657
+ },
655
658
  fallback: {
656
659
  assert: relativeNodePath('assert', dirName),
657
660
  buffer: relativeNodePath('buffer', dirName),