@nlabs/lex 1.48.0 → 1.48.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,86 +1,19 @@
1
- import type { StorybookConfig } from '@storybook/react-webpack5';
2
- import { dirname, resolve } from 'path';
3
-
4
- const getLexNodeModulesPath = () => {
5
- const lexPackageRoot = dirname(__dirname); // Go up from .storybook to lex root
6
- return resolve(lexPackageRoot, 'node_modules');
7
- };
8
-
9
- const lexModule = (modulePath: string) => resolve(getLexNodeModulesPath(), modulePath);
10
-
11
- const config: StorybookConfig = {
1
+ const config = {
12
2
  addons: [
13
- lexModule('@storybook/addon-docs'),
14
- lexModule('@storybook/addon-links'),
15
- lexModule('@storybook/addon-themes')
3
+ '@storybook/addon-docs',
4
+ '@storybook/addon-links',
5
+ '@storybook/addon-postcss',
6
+ '@storybook/addon-themes'
16
7
  ],
17
8
  framework: {
18
- name: lexModule('@storybook/react-webpack5'),
9
+ name: '@storybook/react-webpack5',
19
10
  options: {
20
11
  builder: {
21
12
  useSWC: true
22
13
  }
23
14
  }
24
15
  },
25
- stories: ['../src/**/*.mdx', '../src/**/*.stories.@(ts|tsx)'],
26
- webpackFinal: async (config) => ({
27
- ...config,
28
- module: {
29
- ...config.module,
30
- rules: [
31
- ...(config.module?.rules || []),
32
- {
33
- loader: lexModule('babel-loader/lib/index.js'),
34
- options: {
35
- babelrc: false,
36
- plugins: [
37
- ['@babel/plugin-transform-nullish-coalescing-operator'],
38
- ['@babel/plugin-transform-optional-chaining']
39
- ],
40
- presets: [
41
- '@babel/preset-typescript',
42
- [
43
- '@babel/preset-react',
44
- {
45
- runtime: 'automatic'
46
- }
47
- ]
48
- ]
49
- },
50
- test: /\.(ts|tsx)$/
51
- }
52
- ]
53
- },
54
- resolve: {
55
- ...config.resolve,
56
- extensions: ['.js', '.ts', '.tsx'],
57
- plugins: [
58
- ...(config.resolve?.plugins || [])
59
- ],
60
- fallback: {
61
- ...config.resolve?.fallback,
62
- "process": require.resolve("process/browser"),
63
- "buffer": require.resolve("buffer"),
64
- "util": require.resolve("util"),
65
- "stream": require.resolve("stream-browserify"),
66
- "crypto": require.resolve("crypto-browserify"),
67
- "path": require.resolve("path-browserify"),
68
- "os": require.resolve("os-browserify/browser"),
69
- "vm": require.resolve("vm-browserify"),
70
- "fs": false,
71
- "net": false,
72
- "tls": false
73
- }
74
- },
75
- plugins: [
76
- ...(config.plugins || []),
77
- new (require('webpack')).ProvidePlugin({
78
- process: 'process/browser',
79
- Buffer: ['buffer', 'Buffer']
80
- })
81
- ],
82
- stats: 'verbose'
83
- })
16
+ stories: ['../src/**/*.stories.@(js|ts|tsx)', '../src/**/*.mdx']
84
17
  };
85
18
 
86
19
  export default config;
@@ -0,0 +1,36 @@
1
+ import React from 'react';
2
+ import '../src/styles/tailwind.css';
3
+
4
+ const preview = {
5
+ parameters: {
6
+ actions: { argTypesRegex: '^on[A-Z].*' },
7
+ controls: {
8
+ matchers: {
9
+ color: /(background|color)$/i,
10
+ date: /Date$/,
11
+ },
12
+ },
13
+ backgrounds: {
14
+ default: 'light',
15
+ values: [
16
+ {
17
+ name: 'light',
18
+ value: '#ffffff',
19
+ },
20
+ {
21
+ name: 'dark',
22
+ value: '#1a1a1a',
23
+ },
24
+ ],
25
+ },
26
+ },
27
+ decorators: [
28
+ (Story) => (
29
+ <div className="p-4">
30
+ <Story />
31
+ </div>
32
+ ),
33
+ ],
34
+ };
35
+
36
+ export default preview;
@@ -21,7 +21,7 @@
21
21
  "editor.autoClosingBrackets": "never",
22
22
  "editor.codeActionsOnSave": {
23
23
  "source.fixAll.eslint": "explicit",
24
- "source.organizeImports": "explicit"
24
+ "source.organizeImports": false
25
25
  },
26
26
  "editor.detectIndentation": false,
27
27
  "editor.formatOnSave": true,
package/dist/LexConfig.js CHANGED
@@ -41,10 +41,8 @@ const defaultConfigValues = {
41
41
  };
42
42
  function findLexRoot(startDir) {
43
43
  let dir = startDir;
44
- console.log("DEBUG: findLexRoot starting with dir:", dir);
45
44
  while (dir !== "/" && dir !== ".") {
46
45
  const pkgPath = pathResolve(dir, "package.json");
47
- console.log("DEBUG: findLexRoot checking", pkgPath);
48
46
  if (existsSync(pkgPath)) {
49
47
  try {
50
48
  const pkg = JSON.parse(readFileSync(pkgPath, "utf8"));
@@ -55,7 +53,6 @@ function findLexRoot(startDir) {
55
53
  }
56
54
  }
57
55
  const parent = dirname(dir);
58
- console.log("DEBUG: findLexRoot parent of", dir, "is", parent);
59
56
  if (parent === dir) {
60
57
  break;
61
58
  }
@@ -289,4 +286,4 @@ export {
289
286
  defaultConfigValues,
290
287
  getTypeScriptConfigPath
291
288
  };
292
- //# 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 {dirname, extname as pathExtname, resolve as pathResolve} from 'path';\nimport {URL} from 'url';\n\nimport {getDirName, getLexPackageJsonPath, relativeFilePath} from './utils/file.js';\nimport {log} from './utils/log.js';\n\nconst cwd: string = process.cwd();\n\nexport interface EsbuildConfig {\n  entryPoints?: string[];\n  outdir?: string;\n  platform?: 'node' | 'browser';\n  target?: string;\n  format?: 'cjs' | 'esm';\n  minify?: boolean;\n  treeShaking?: boolean;\n  drop?: string[];\n  pure?: string[];\n  external?: string[];\n  splitting?: boolean;\n  metafile?: boolean;\n  sourcemap?: boolean | 'inline' | 'external';\n  legalComments?: 'none' | 'inline' | 'eof' | 'linked' | 'separate';\n  banner?: Record<string, string>;\n  footer?: Record<string, string>;\n  define?: Record<string, string>;\n  [key: string]: unknown;\n}\n\nexport interface JestConfig {\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  [key: string]: unknown;\n}\n\nexport interface WebpackConfig {\n  entry?: string | string[];\n  output?: Record<string, unknown>;\n  module?: Record<string, unknown>;\n  plugins?: unknown[];\n  [key: string]: unknown;\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}\nexport interface LexConfigType {\n  ai?: AIConfig;\n  configFiles?: string[];\n  copyFiles?: string[];\n  entryHTML?: string;\n  entryJs?: string;\n  esbuild?: EsbuildConfig;\n  env?: object;\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  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    provider: 'none',\n    model: 'gpt-4o',\n    maxTokens: 4000,\n    temperature: 0.1\n  },\n  configFiles: [],\n  copyFiles: [],\n  entryHTML: 'index.html',\n  entryJs: 'index.js',\n  esbuild: {\n    minify: true,\n    treeShaking: true,\n    drop: ['console', 'debugger'],\n    pure: ['console.log', 'console.warn', 'console.error'],\n    legalComments: 'none',\n    splitting: true,\n    metafile: false,\n    sourcemap: false\n  },\n  env: null,\n  jest: {},\n  outputFullPath: pathResolve(cwd, './dist'),\n  outputHash: false,\n  outputPath: './dist',\n  packageManager: 'npm',\n  preset: 'web',\n  sourceFullPath: pathResolve(cwd, './src'),\n  sourcePath: './src',\n  targetEnvironment: 'web',\n  useGraphQl: false,\n  useTypescript: false,\n  webpack: {}\n};\n\nfunction findLexRoot(startDir: string): string {\n  let dir = startDir;\n  console.log('DEBUG: findLexRoot starting with dir:', dir); // TEMP DEBUG\n  while(dir !== '/' && dir !== '.') {\n    const pkgPath = pathResolve(dir, 'package.json');\n    console.log('DEBUG: findLexRoot checking', pkgPath); // TEMP DEBUG\n    if(existsSync(pkgPath)) {\n      try {\n        const pkg = JSON.parse(readFileSync(pkgPath, 'utf8'));\n        if(pkg.name === '@nlabs/lex') {\n          return dir;\n        }\n      } catch{}\n    }\n    const parent = dirname(dir);\n    console.log('DEBUG: findLexRoot parent of', dir, 'is', parent); // TEMP DEBUG\n    if(parent === dir) {\n      break;\n    }\n    dir = parent;\n  }\n  throw new Error('Could not find @nlabs/lex root');\n}\n\n/**\n * Get the appropriate TypeScript config path, prioritizing project configs over Lex configs\n */\nexport function getTypeScriptConfigPath(configName: string): string {\n  const cwd = process.cwd();\n\n  // For compile command, check for project's build config first\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  // For lint command, check for project's lint config first\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  // For test command, check for project's test config first\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  // Check for the exact config name in the project\n  const projectConfigPath = pathResolve(cwd, configName);\n  if(existsSync(projectConfigPath)) {\n    return projectConfigPath;\n  }\n\n  // Otherwise, use Lex's config\n  const lexDir = LexConfig.getLexDir();\n  return pathResolve(lexDir, configName);\n}\n\nexport class LexConfig {\n  static config: LexConfigType = {\n    ...defaultConfigValues\n  };\n\n  /**\n   * Get the Lex package root directory, handling both development and installed environments\n   */\n  static getLexDir(): string {\n    // Always use the directory of Lex's own package.json\n    return dirname(getLexPackageJsonPath());\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 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            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 checkCompileTypescriptConfig() {\n    const lexDir = LexConfig.getLexDir();\n    const tsconfigCompilePath: string = pathResolve(lexDir, './tsconfig.build.json');\n\n    if(!existsSync(tsconfigCompilePath)) {\n      // Try to copy from the template location\n      const templatePath = pathResolve(lexDir, 'tsconfig.build.json');\n      if(existsSync(templatePath)) {\n        writeFileSync(tsconfigCompilePath, readFileSync(templatePath));\n      }\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      // Try to copy from the template location\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      // Try to copy from the template location\n      const templatePath = pathResolve(lexDir, 'tsconfig.test.json');\n      if(existsSync(templatePath)) {\n        writeFileSync(tsconfigTestPath, readFileSync(templatePath));\n      }\n    }\n  }\n}"],
  "mappings": "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",
  "names": ["cwd"]
}

289
+ //# 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 {dirname, extname as pathExtname, resolve as pathResolve} from 'path';\nimport {URL} from 'url';\n\nimport {getDirName, getLexPackageJsonPath, relativeFilePath} from './utils/file.js';\nimport {log} from './utils/log.js';\n\nconst cwd: string = process.cwd();\n\nexport interface EsbuildConfig {\n  entryPoints?: string[];\n  outdir?: string;\n  platform?: 'node' | 'browser';\n  target?: string;\n  format?: 'cjs' | 'esm';\n  minify?: boolean;\n  treeShaking?: boolean;\n  drop?: string[];\n  pure?: string[];\n  external?: string[];\n  splitting?: boolean;\n  metafile?: boolean;\n  sourcemap?: boolean | 'inline' | 'external';\n  legalComments?: 'none' | 'inline' | 'eof' | 'linked' | 'separate';\n  banner?: Record<string, string>;\n  footer?: Record<string, string>;\n  define?: Record<string, string>;\n  [key: string]: unknown;\n}\n\nexport interface JestConfig {\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  [key: string]: unknown;\n}\n\nexport interface WebpackConfig {\n  entry?: string | string[];\n  output?: Record<string, unknown>;\n  module?: Record<string, unknown>;\n  plugins?: unknown[];\n  [key: string]: unknown;\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}\nexport interface LexConfigType {\n  ai?: AIConfig;\n  configFiles?: string[];\n  copyFiles?: string[];\n  entryHTML?: string;\n  entryJs?: string;\n  esbuild?: EsbuildConfig;\n  env?: object;\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  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    provider: 'none',\n    model: 'gpt-4o',\n    maxTokens: 4000,\n    temperature: 0.1\n  },\n  configFiles: [],\n  copyFiles: [],\n  entryHTML: 'index.html',\n  entryJs: 'index.js',\n  esbuild: {\n    minify: true,\n    treeShaking: true,\n    drop: ['console', 'debugger'],\n    pure: ['console.log', 'console.warn', 'console.error'],\n    legalComments: 'none',\n    splitting: true,\n    metafile: false,\n    sourcemap: false\n  },\n  env: null,\n  jest: {},\n  outputFullPath: pathResolve(cwd, './dist'),\n  outputHash: false,\n  outputPath: './dist',\n  packageManager: 'npm',\n  preset: 'web',\n  sourceFullPath: pathResolve(cwd, './src'),\n  sourcePath: './src',\n  targetEnvironment: 'web',\n  useGraphQl: false,\n  useTypescript: false,\n  webpack: {}\n};\n\nfunction findLexRoot(startDir: string): string {\n  let dir = startDir;\n  while(dir !== '/' && dir !== '.') {\n    const pkgPath = pathResolve(dir, 'package.json');\n    if(existsSync(pkgPath)) {\n      try {\n        const pkg = JSON.parse(readFileSync(pkgPath, 'utf8'));\n        if(pkg.name === '@nlabs/lex') {\n          return dir;\n        }\n      } catch {}\n    }\n    const parent = dirname(dir);\n    if(parent === dir) {\n      break;\n    }\n    dir = parent;\n  }\n  throw new Error('Could not find @nlabs/lex root');\n}\n\n/**\n * Get the appropriate TypeScript config path, prioritizing project configs over Lex configs\n */\nexport function getTypeScriptConfigPath(configName: string): string {\n  const cwd = process.cwd();\n\n  // For compile command, check for project's build config first\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  // For lint command, check for project's lint config first\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  // For test command, check for project's test config first\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  // Check for the exact config name in the project\n  const projectConfigPath = pathResolve(cwd, configName);\n  if(existsSync(projectConfigPath)) {\n    return projectConfigPath;\n  }\n\n  // Otherwise, use Lex's config\n  const lexDir = LexConfig.getLexDir();\n  return pathResolve(lexDir, configName);\n}\n\nexport class LexConfig {\n  static config: LexConfigType = {\n    ...defaultConfigValues\n  };\n\n  /**\n   * Get the Lex package root directory, handling both development and installed environments\n   */\n  static getLexDir(): string {\n    // Always use the directory of Lex's own package.json\n    return dirname(getLexPackageJsonPath());\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 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            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 checkCompileTypescriptConfig() {\n    const lexDir = LexConfig.getLexDir();\n    const tsconfigCompilePath: string = pathResolve(lexDir, './tsconfig.build.json');\n\n    if(!existsSync(tsconfigCompilePath)) {\n      // Try to copy from the template location\n      const templatePath = pathResolve(lexDir, 'tsconfig.build.json');\n      if(existsSync(templatePath)) {\n        writeFileSync(tsconfigCompilePath, readFileSync(templatePath));\n      }\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      // Try to copy from the template location\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      // Try to copy from the template location\n      const templatePath = pathResolve(lexDir, 'tsconfig.test.json');\n      if(existsSync(templatePath)) {\n        writeFileSync(tsconfigTestPath, readFileSync(templatePath));\n      }\n    }\n  }\n}"],
  "mappings": "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",
  "names": ["cwd"]
}

@@ -808,4 +808,4 @@ ${cliName} Error: ${error.message}`, "error", quiet);
808
808
  export {
809
809
  lint
810
810
  };
811
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/commands/lint/lint.ts"],
  "sourcesContent": ["/**\n * Copyright (c) 2022-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {execa} from 'execa';\nimport {existsSync, readFileSync, unlinkSync, writeFileSync} from 'fs';\nimport {dirname, resolve as pathResolve} from 'path';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {createSpinner} from '../../utils/app.js';\nimport {resolveBinaryPath} from '../../utils/file.js';\nimport {log} from '../../utils/log.js';\n\nlet currentFilename: string;\nlet currentDirname: string;\n\ntry {\n  currentFilename = eval('require(\"url\").fileURLToPath(import.meta.url)');\n  currentDirname = dirname(currentFilename);\n} catch {\n  currentFilename = process.cwd();\n  currentDirname = process.cwd();\n}\n\nexport interface LintOptions {\n  readonly cache?: boolean;\n  readonly cacheFile?: string;\n  readonly cacheLocation?: string;\n  readonly cliName?: string;\n  readonly color?: boolean;\n  readonly config?: string;\n  readonly debug?: boolean;\n  readonly env?: string;\n  readonly envInfo?: boolean;\n  readonly ext?: string;\n  readonly fix?: boolean;\n  readonly fixDryRun?: boolean;\n  readonly fixType?: string;\n  readonly format?: string;\n  readonly global?: string;\n  readonly ignorePath?: string;\n  readonly ignorePattern?: string;\n  readonly init?: boolean;\n  readonly maxWarnings?: string;\n  readonly noColor?: boolean;\n  readonly noEslintrc?: boolean;\n  readonly noIgnore?: boolean;\n  readonly noInlineConfig?: boolean;\n  readonly outputFile?: string;\n  readonly parser?: string;\n  readonly parserOptions?: string;\n  readonly plugin?: string;\n  readonly printConfig?: string;\n  readonly quiet?: boolean;\n  readonly reportUnusedDisableDirectives?: boolean;\n  readonly resolvePluginsRelativeTo?: string;\n  readonly rule?: string;\n  readonly rulesdir?: string;\n  readonly stdin?: boolean;\n  readonly stdinFilename?: string;\n}\n\nexport type LintCallback = typeof process.exit;\n\ninterface ConfigResult {\n  configPath: string;\n  originalConfig: string | null;\n}\n\nconst createDefaultESLintConfig = (useTypescript: boolean, cwd: string): ConfigResult => {\n  const configPath = pathResolve(cwd, 'eslint.config.ts');\n  let originalConfig;\n\n  if(existsSync(configPath)) {\n    try {\n      originalConfig = readFileSync(configPath, 'utf8');\n    } catch(_error) {\n      // Ignore errors\n    }\n  }\n\n  const possiblePaths = [\n    pathResolve(currentDirname, '../../../../eslint.config.ts'),\n    pathResolve(process.env.LEX_HOME || '/usr/local/lib/node_modules/@nlabs/lex', 'eslint.config.ts')\n  ];\n\n  let foundConfig = '';\n\n  for(const path of possiblePaths) {\n    if(existsSync(path)) {\n      foundConfig = path;\n      break;\n    }\n  }\n\n  let eslintConfig;\n\n  if(foundConfig) {\n    try {\n      eslintConfig = readFileSync(foundConfig, 'utf8');\n    } catch(_error) {\n      eslintConfig = createBasicESLintConfig(useTypescript);\n    }\n  } else {\n    eslintConfig = createBasicESLintConfig(useTypescript);\n  }\n\n  writeFileSync(configPath, eslintConfig, 'utf8');\n\n  return {\n    configPath,\n    originalConfig\n  };\n};\n\nconst createBasicESLintConfig = (useTypescript: boolean): string => {\n  let config = `// ESLint configuration\nimport { typescriptConfig } from 'eslint-config-styleguidejs';\n\nconst config = [\n  {\n    ignores: ['**/node_modules/**', '**/dist/**', '**/build/**']\n  },\n  // Config for JavaScript files\n  {\n    files: ['**/*.{js,jsx}'],\n    languageOptions: {\n      ecmaVersion: 'latest',\n      sourceType: 'module'\n    },\n    rules: {\n      'indent': ['error', 2],\n      'quotes': ['error', 'single'],\n      'semi': ['error', 'always'],\n      'no-unused-vars': ['warn', { 'argsIgnorePattern': '^_', 'varsIgnorePattern': '^_', 'caughtErrors': 'all', 'caughtErrorsIgnorePattern': '^_' }],\n      'eqeqeq': ['error', 'always']\n    }\n  }`;\n\n  // Add TypeScript configuration if needed\n  if(useTypescript) {\n    config += `,\n  // Config for TypeScript files\n  {\n    files: ['**/*.{ts,tsx}'],\n    languageOptions: {\n      ecmaVersion: 'latest',\n      sourceType: 'module',\n      parser: {\n        importSource: '@typescript-eslint/parser'\n      },\n              parserOptions: {\n          project: getTypeScriptConfigPath('tsconfig.lint.json')\n        }\n    },\n    plugins: {\n      '@typescript-eslint': {\n        importSource: '@typescript-eslint/eslint-plugin'\n      }\n    },\n    rules: {\n      'indent': ['error', 2],\n      'quotes': ['error', 'single'],\n      'semi': ['error', 'always'],\n      'no-unused-vars': 'off',\n      '@typescript-eslint/no-unused-vars': ['warn', { 'argsIgnorePattern': '^_', 'varsIgnorePattern': '^_', 'caughtErrors': 'all', 'caughtErrorsIgnorePattern': '^_' }],\n      'eqeqeq': ['error', 'always']\n    }\n  }`;\n  }\n\n  // Close the array and export\n  config += `\n];\n\nexport default config;`;\n\n  return config;\n};\n\n/**\n * Check if TypeScript is being used by looking for tsconfig.json\n */\nconst detectTypeScript = (cwd: string): boolean => existsSync(pathResolve(cwd, 'tsconfig.json'));\n\n/**\n * Ensure package.json has type: module for ESM support\n */\nconst ensureModuleType = (cwd: string): void => {\n  const packageJsonPath = pathResolve(cwd, 'package.json');\n\n  if(existsSync(packageJsonPath)) {\n    try {\n      const packageJsonContent = readFileSync(packageJsonPath, 'utf8');\n      const packageJson = JSON.parse(packageJsonContent);\n\n      // If type is not set to module, warn instead of auto-modifying\n      if(packageJson.type !== 'module') {\n        log('Warning: package.json should have \"type\": \"module\" for ESM support. Please add this manually.', 'warn', false);\n      }\n    } catch(_error) {\n      // Ignore errors\n    }\n  }\n};\n\nconst installDependencies = async (cwd: string, useTypescript: boolean, quiet: boolean): Promise<void> => {\n  if(useTypescript) {\n    log('Using TypeScript ESLint from Lex...', 'info', quiet);\n  } else {\n    log('Using ESLint from Lex...', 'info', quiet);\n  }\n};\n\nconst runEslintWithLex = async (\n  cwd: string,\n  quiet: boolean,\n  cliName: string,\n  fix: boolean,\n  debug: boolean,\n  useTypescript: boolean,\n  captureOutput?: (output: string) => void\n): Promise<number> => {\n  const spinner = createSpinner(quiet);\n\n  try {\n    const projectConfigPath = pathResolve(cwd, 'eslint.config.js');\n    const projectConfigPathTs = pathResolve(cwd, 'eslint.config.ts');\n    const hasProjectConfig = existsSync(projectConfigPath) || existsSync(projectConfigPathTs);\n\n    const possiblePaths = [\n      pathResolve(currentDirname, '../../../../eslint.config.ts'),\n      pathResolve(process.env.LEX_HOME || '/usr/local/lib/node_modules/@nlabs/lex', 'eslint.config.ts')\n    ];\n\n    let lexConfigPath = '';\n    for(const path of possiblePaths) {\n      if(existsSync(path)) {\n        lexConfigPath = path;\n        break;\n      }\n    }\n\n    const configPath = hasProjectConfig ? (existsSync(projectConfigPathTs) ? projectConfigPathTs : projectConfigPath) : (lexConfigPath || projectConfigPath);\n\n    const eslintBinary = resolveBinaryPath('eslint', 'eslint');\n\n    if(!eslintBinary) {\n      log(`\\n${cliName} Error: ESLint binary not found in Lex's node_modules`, 'error', quiet);\n      log('Please reinstall Lex or check your installation.', 'info', quiet);\n      return 1;\n    }\n\n    const jsResult = await execa(eslintBinary, [\n      'src/**/*.{js,jsx}',\n      '--config', configPath,\n      ...(fix ? ['--fix'] : []),\n      ...(debug ? ['--debug'] : []),\n      '--no-error-on-unmatched-pattern'\n    ], {\n      reject: false,\n      stdio: 'pipe',\n      cwd,\n      shell: true\n    });\n\n    if(jsResult.stdout) {\n      console.log(jsResult.stdout);\n      if(captureOutput) {\n        captureOutput(jsResult.stdout);\n      }\n    }\n\n    if(jsResult.stderr) {\n      console.error(jsResult.stderr);\n      if(captureOutput) {\n        captureOutput(jsResult.stderr);\n      }\n    }\n\n    let tsResult: any = {exitCode: 0, stdout: '', stderr: ''};\n    if(useTypescript) {\n      tsResult = await execa(eslintBinary, [\n        'src/**/*.{ts,tsx}',\n        '--config', configPath,\n        ...(fix ? ['--fix'] : []),\n        ...(debug ? ['--debug'] : []),\n        '--no-error-on-unmatched-pattern'\n      ], {\n        reject: false,\n        stdio: 'pipe',\n        cwd,\n        shell: true\n      });\n\n      if(tsResult.stdout) {\n        console.log(tsResult.stdout);\n      }\n\n      if(tsResult.stderr) {\n        console.error(tsResult.stderr);\n      }\n    }\n\n    const eslintNotFound = jsResult.stderr?.includes('command not found') || jsResult.stderr?.includes('eslint: command not found');\n    if(eslintNotFound) {\n      spinner.fail('ESLint not found!');\n      log(`\\n${cliName} Error: Lex's ESLint binary not found. Please reinstall Lex or check your installation.`, 'error', quiet);\n      return 1;\n    }\n\n    if(jsResult.exitCode === 0 && tsResult.exitCode === 0) {\n      spinner.succeed('Linting completed!');\n      return 0;\n    }\n\n    const noFilesFound =\n      (jsResult.stderr?.includes('No such file or directory') || jsResult.stdout?.includes('No such file or directory')) &&\n      (!useTypescript || tsResult.stderr?.includes('No such file or directory') || tsResult.stdout?.includes('No such file or directory'));\n\n    if(noFilesFound) {\n      spinner.succeed('No files found to lint');\n      return 0;\n    }\n    spinner.fail('Linting failed!');\n    log(`\\n${cliName} Error: ESLint found issues in your code.`, 'error', quiet);\n    return 1;\n  } catch(error) {\n    spinner.fail('Linting failed!');\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n    return 1;\n  }\n};\n\nconst applyAIFix = async (\n  cwd: string,\n  errors: string,\n  quiet: boolean\n): Promise<void> => {\n  const spinner = createSpinner(quiet);\n  spinner.start('Using AI to fix remaining lint issues...');\n\n  try {\n    const fileErrorMap = new Map<string, string[]>();\n    const lines = errors.split('\\n');\n    let currentFile = '';\n\n    for(const line of lines) {\n      if(line.match(/^(\\/|[A-Z]:\\\\).*?\\.(js|jsx|ts|tsx)$/)) {\n        currentFile = line.trim();\n        if(!fileErrorMap.has(currentFile)) {\n          fileErrorMap.set(currentFile, []);\n        }\n      } else if(currentFile && line.trim() && line.match(/\\s+\\d+:\\d+\\s+(error|warning)\\s+/)) {\n        const errorArray = fileErrorMap.get(currentFile);\n        if(errorArray) {\n          errorArray.push(line.trim());\n        }\n      }\n    }\n\n    if(fileErrorMap.size === 0) {\n      log('Using alternative error parsing strategy', 'info', quiet);\n\n      const sections = errors.split('\\n\\n');\n\n      for(const section of sections) {\n        if(section.trim() === '') {\n          continue;\n        }\n\n        const lines = section.split('\\n');\n        const filePath = lines[0].trim();\n\n        if(filePath.match(/\\.(js|jsx|ts|tsx)$/)) {\n          fileErrorMap.set(filePath, []);\n\n          for(let i = 1; i < lines.length; i++) {\n            if(lines[i].trim() !== '') {\n              fileErrorMap.get(filePath)?.push(lines[i].trim());\n            }\n          }\n        }\n      }\n    }\n\n    if(fileErrorMap.size === 0) {\n      log('Using direct file path extraction', 'info', quiet);\n\n      const filePathRegex = /(?:\\/|[A-Z]:\\\\)(?:[^:\\n]+\\/)*[^:\\n]+\\.(js|jsx|ts|tsx)/g;\n      const filePaths = errors.match(filePathRegex) || [];\n\n      for(const filePath of filePaths) {\n        if(!fileErrorMap.has(filePath) && existsSync(filePath)) {\n          fileErrorMap.set(filePath, []);\n        }\n      }\n\n      const knownFiles = [\n        pathResolve(cwd, 'src/create/changelog.ts'),\n        pathResolve(cwd, 'src/utils/aiService.ts'),\n        pathResolve(cwd, 'src/utils/app.ts'),\n        pathResolve(cwd, 'src/utils/reactShim.ts'),\n        pathResolve(cwd, 'src/commands/lint/autofix.js')\n      ];\n\n      for(const file of knownFiles) {\n        if(existsSync(file) && !fileErrorMap.has(file)) {\n          fileErrorMap.set(file, []);\n        }\n      }\n    }\n\n    for(const filePath of fileErrorMap.keys()) {\n      if(!existsSync(filePath)) {\n        log(`File not found: ${filePath}`, 'warn', quiet);\n        continue;\n      }\n\n      log(`Processing file: ${filePath}`, 'info', quiet);\n\n      const isCursorIDE = LexConfig.config.ai?.provider === 'cursor' || process.env.CURSOR_IDE === 'true';\n\n      if(isCursorIDE) {\n        try {\n          const prompt = `Fix all ESLint errors in this file. Focus on:\n1. Fixing naming conventions\n2. Fixing sort-keys issues\n3. Replacing console.log with log utility\n4. Fixing no-plusplus issues\n5. Fixing unnecessary escape characters\n6. Fixing other ESLint errors\n\nCRITICAL REQUIREMENTS:\n- ONLY fix the specific lines with ESLint errors\n- DO NOT modify any other lines of code\n- DO NOT remove line breaks unless they are specifically causing ESLint errors\n- DO NOT condense multi-line structures to single lines\n- PRESERVE all existing line breaks and formatting that is not causing errors\n\nSPECIFIC FORMATTING RULES:\n- Maintain proper indentation (2 spaces)\n- Keep line breaks between class/interface declaration and their members\n- Keep line breaks between methods\n- Ensure there is a line break after opening braces for classes, interfaces, and methods\n- DO NOT place class/interface properties or methods on the same line as the opening brace\n- Preserve empty lines between logical code blocks\n- PRESERVE multi-line imports - do not condense them to single lines\n- PRESERVE multi-line object/array declarations - do not condense them to single lines\n\nSORT-KEYS RULE (HIGHEST PRIORITY):\n- All object literal keys MUST be sorted alphabetically in ascending order\n- This applies to ALL objects in the file, not just those with explicit sort-keys errors\n- Example: {b: 2, a: 1, c: 3} should become {a: 1, b: 2, c: 3}\n- Preserve the original formatting and line breaks when sorting\n\nExample of CORRECT formatting (DO NOT CHANGE):\nexport class UserConstants {\n  static readonly ADD_ITEM_ERROR: string = 'USER_ADD_ITEM_ERROR';\n  static readonly OTHER_CONSTANT: string = 'OTHER_CONSTANT';\n}\n\nconstructor(flux: FluxFramework, CustomAdapter: typeof Event = Event) {\n  this.CustomAdapter = CustomAdapter;\n  this.flux = flux;\n}\n\nimport {\n  app,\n  events,\n  images,\n  locations,\n  messages,\n  posts,\n  tags,\n  users,\n  websocket\n} from './stores';\n\nconst config = {\n  apiKey: 'value',\n  baseUrl: 'https://api.example.com',\n  timeout: 5000\n};\n\nExample of INCORRECT formatting (FIX THIS):\nexport class UserConstants {static readonly ADD_ITEM_ERROR: string = 'USER_ADD_ITEM_ERROR';\n  static readonly OTHER_CONSTANT: string = 'OTHER_CONSTANT';\n}\n\nconstructor(flux: FluxFramework, CustomAdapter: typeof Event = Event) {this.CustomAdapter = CustomAdapter;\n  this.flux = flux;}\n\nimport {app, events, images, locations, messages, posts, tags, users, websocket} from './stores';\n\nconst config = {baseUrl: 'https://api.example.com', apiKey: 'value', timeout: 5000};\n\nFix ONLY the specific ESLint errors. Return the properly formatted code.`;\n\n          try {\n            const promptFile = pathResolve(cwd, '.cursor_prompt_temp.txt');\n            writeFileSync(promptFile, prompt, 'utf8');\n\n            // Use Cursor CLI to fix the file\n            await execa('cursor', ['edit', '--file', filePath, '--prompt-file', promptFile], {\n              reject: false,\n              stdio: 'pipe',\n              cwd\n            });\n\n            try {\n              unlinkSync(promptFile);\n            } catch(_error) {\n            }\n\n            log(`Applied Cursor AI fixes to ${filePath}`, 'info', quiet);\n          } catch(error) {\n            const wasModified = await applyDirectFixes(filePath, quiet);\n            if(wasModified) {\n              log(`Applied direct fixes to ${filePath}`, 'info', quiet);\n            }\n          }\n        } catch(error) {\n          log(`Error using Cursor AI: ${error.message}`, 'error', quiet);\n          await applyDirectFixes(filePath, quiet);\n        }\n      } else {\n        const wasModified = await applyDirectFixes(filePath, quiet);\n        if(wasModified) {\n          log(`Applied direct fixes to ${filePath}`, 'info', quiet);\n        }\n\n        const fileErrors = fileErrorMap.get(filePath) || [];\n        if(fileErrors.length > 0) {\n          try {\n            const {callAIService} = await import('../../utils/aiService.js');\n\n            const fileContent = readFileSync(filePath, 'utf8');\n\n            const prompt = `Fix the following ESLint errors in this code:\n${fileErrors.join('\\n')}\n\nHere's the code:\n\\`\\`\\`\n${fileContent}\n\\`\\`\\`\n\nCRITICAL REQUIREMENTS:\n- ONLY fix the specific lines with ESLint errors\n- DO NOT modify any other lines of code\n- DO NOT remove line breaks unless they are specifically causing ESLint errors\n- DO NOT condense multi-line structures to single lines\n- PRESERVE all existing line breaks and formatting that is not causing errors\n\nSPECIFIC FORMATTING RULES:\n- Maintain proper indentation (2 spaces)\n- Keep line breaks between class/interface declaration and their members\n- Keep line breaks between methods\n- Ensure there is a line break after opening braces for classes, interfaces, and methods\n- DO NOT place class/interface properties or methods on the same line as the opening brace\n- Preserve empty lines between logical code blocks\n- PRESERVE multi-line imports - do not condense them to single lines\n- PRESERVE multi-line object/array declarations - do not condense them to single lines\n\nSORT-KEYS RULE (HIGHEST PRIORITY):\n- All object literal keys MUST be sorted alphabetically in ascending order\n- This applies to ALL objects in the file, not just those with explicit sort-keys errors\n- Example: {b: 2, a: 1, c: 3} should become {a: 1, b: 2, c: 3}\n- Preserve the original formatting and line breaks when sorting\n\nWHAT TO FIX:\n1. Sorting all object keys alphabetically (sort-keys rule) - ALL objects must have sorted keys\n2. Fixing naming conventions - ONLY for variables/functions with naming errors\n3. Replacing console.log with log utility - ONLY for console.log statements\n4. Fixing no-plusplus issues - ONLY for ++/-- operators\n5. Fixing unnecessary escape characters - ONLY for escaped characters that don't need escaping\n6. Proper indentation and spacing - ONLY where specifically required by errors\n7. String quotes consistency (use single quotes) - ONLY for string literals with quote errors\n8. Import order and spacing - ONLY for imports with order/spacing errors\n9. Function parameter formatting - ONLY for functions with parameter errors\n10. Variable naming conventions - ONLY for variables with naming errors\n11. No unused variables or imports - ONLY for unused variables/imports\n12. Avoiding nested ternaries - ONLY for nested ternary expressions\n13. Any other ESLint errors - ONLY for the specific errors listed above\n\nWHAT NOT TO FIX:\n- Do not change properly formatted multi-line structures\n- Do not remove line breaks that are not causing errors\n- Do not change indentation that is already correct\n- Do not modify spacing that is already correct\n- Do not condense readable multi-line code to single lines\n- Do not modify code that is not mentioned in the ESLint errors\n\nExample of CORRECT formatting (DO NOT CHANGE):\nexport class UserConstants {\n  static readonly ADD_ITEM_ERROR: string = 'USER_ADD_ITEM_ERROR';\n  static readonly OTHER_CONSTANT: string = 'OTHER_CONSTANT';\n}\n\nconstructor(flux: FluxFramework, CustomAdapter: typeof Event = Event) {\n  this.CustomAdapter = CustomAdapter;\n  this.flux = flux;\n}\n\nimport {\n  app,\n  events,\n  images,\n  locations,\n  messages,\n  posts,\n  tags,\n  users,\n  websocket\n} from './stores';\n\nconst config = {\n  apiKey: 'value',\n  baseUrl: 'https://api.example.com',\n  timeout: 5000\n};\n\nExample of INCORRECT formatting (FIX THIS):\nexport class UserConstants {static readonly ADD_ITEM_ERROR: string = 'USER_ADD_ITEM_ERROR';\n  static readonly OTHER_CONSTANT: string = 'OTHER_CONSTANT';\n}\n\nconstructor(flux: FluxFramework, CustomAdapter: typeof Event = Event) {this.CustomAdapter = CustomAdapter;\n  this.flux = flux;}\n\nimport {app, events, images, locations, messages, posts, tags, users, websocket} from './stores';\n\nconst config = {baseUrl: 'https://api.example.com', apiKey: 'value', timeout: 5000};\n\nFix ONLY the specific ESLint errors listed above. Review the entire file for compliance with all ESLint rules.\nReturn only the properly formatted fixed code without any explanations.`;\n\n            const fixedContent = await callAIService(prompt, quiet);\n\n            if(fixedContent && fixedContent !== fileContent) {\n              writeFileSync(filePath, fixedContent, 'utf8');\n              log(`Applied AI fixes to ${filePath}`, 'info', quiet);\n            }\n          } catch(error) {\n            log(`Error applying AI fixes to ${filePath}: ${error.message}`, 'error', quiet);\n          }\n        }\n      }\n    }\n\n    spinner.succeed('AI fixes applied successfully!');\n  } catch(error) {\n    spinner.fail('Failed to apply AI fixes');\n    log(`Error: ${error.message}`, 'error', quiet);\n    if(!quiet) {\n      console.error(error);\n    }\n  }\n};\n\nconst applyDirectFixes = async (filePath: string, quiet: boolean): Promise<boolean> => {\n  let wasModified = false;\n\n  try {\n    const fileContent = readFileSync(filePath, 'utf8');\n    let newContent = fileContent;\n\n    if(filePath.includes('aiService.ts')) {\n      log('Fixing issues in aiService.ts', 'info', quiet);\n\n      newContent = newContent.replace(\n        /'Content-Type': 'application\\/json',\\s*'Authorization': `Bearer/g,\n        '\\'Authorization\\': `Bearer\\', \\'Content-Type\\': \\'application/json\\''\n      );\n\n      newContent = newContent.replace(\n        /headers: {([^}]*)},\\s*method: 'POST'/g,\n        'method: \\'POST\\',\\n      headers: {$1}'\n      );\n\n      newContent = newContent.replace(\n        /{role: 'system', content:/g,\n        '{content:, role: \\'system\\','\n      );\n      newContent = newContent.replace(\n        /{role: 'user', content:/g,\n        '{content:, role: \\'user\\','\n      );\n\n      newContent = newContent.replace(\n        /\\(([^)]*?)_([a-zA-Z0-9]+)(\\s*:[^)]*)\\)/g,\n        '($1$2$3)'\n      );\n\n      newContent = newContent.replace(/console\\.log\\(/g, 'log(');\n\n      if(!newContent.includes('import {log}') && newContent.includes('log(')) {\n        newContent = newContent.replace(\n          /import {([^}]*)} from '(.*)';/,\n          'import {$1} from \\'$2\\';\\nimport {log} from \\'./log.js\\';'\n        );\n      }\n    }\n\n    if(filePath.includes('reactShim.ts')) {\n      log('Fixing naming-convention issues in reactShim.ts', 'info', quiet);\n\n      newContent = newContent.replace(\n        'import * as React from',\n        'import * as react from'\n      );\n\n      newContent = newContent.replace(/React\\./g, 'react.');\n    }\n\n    if(filePath.includes('changelog.ts')) {\n      log('Fixing issues in changelog.ts', 'info', quiet);\n\n      newContent = newContent.replace(/(\\w+)\\+\\+/g, '$1 += 1');\n\n      newContent = newContent.replace(/\\\\\\$/g, '$');\n      newContent = newContent.replace(/\\\\\\./g, '.');\n      newContent = newContent.replace(/\\\\\\*/g, '*');\n      newContent = newContent.replace(/\\\\:/g, ':');\n    }\n\n    if(filePath.includes('app.ts')) {\n      log('Fixing issues in app.ts', 'info', quiet);\n\n      newContent = newContent.replace(/console\\.log\\(/g, 'log(');\n\n      if(!newContent.includes('import {log}') && newContent.includes('log(')) {\n        newContent = newContent.replace(\n          /import boxen from 'boxen';/,\n          'import boxen from \\'boxen\\';\\nimport {log} from \\'./log.js\\';'\n        );\n      }\n\n      newContent = newContent.replace(/\\\\\\//g, '/');\n    }\n\n    if(filePath.includes('autofix.js')) {\n      log('Fixing issues in autofix.js', 'info', quiet);\n\n      newContent = newContent.replace(\n        /import {([^}]*)} from 'path';[\\s\\n]*import {([^}]*)} from 'path';/,\n        'import {$1, $2} from \\'path\\';'\n      );\n\n      newContent = newContent.replace(\n        /__filename/g,\n        'currentFilename'\n      );\n      newContent = newContent.replace(\n        /__dirname/g,\n        'currentDirname'\n      );\n\n      newContent = newContent.replace(\n        /const prefix = type === 'error' \\? '\u274C ' : type === 'success' \\? '\u2705 ' : '\u2139\uFE0F ';/,\n        'let prefix = \\'\u2139\uFE0F \\';\\nif(type === \\'error\\') {\\n  prefix = \\'\u274C \\';\\n} else if(type === \\'success\\') {\\n  prefix = \\'\u2705 \\';\\n}'\n      );\n\n      newContent = newContent.replace(\n        /async function runEslintFix\\(\\)/g,\n        'const runEslintFix = async ()'\n      );\n      newContent = newContent.replace(\n        /async function getFilesWithErrors\\(\\)/g,\n        'const getFilesWithErrors = async ()'\n      );\n      newContent = newContent.replace(\n        /async function isCursorAvailable\\(\\)/g,\n        'const isCursorAvailable = async ()'\n      );\n      newContent = newContent.replace(\n        /async function fixFileWithCursorAI\\(filePath\\)/g,\n        'const fixFileWithCursorAI = async (filePath)'\n      );\n      newContent = newContent.replace(\n        /async function main\\(\\)/g,\n        'const main = async ()'\n      );\n\n      newContent = newContent.replace(\n        /import {existsSync, readFileSync, writeFileSync}/g,\n        'import {writeFileSync}'\n      );\n\n      newContent = newContent.replace(\n        /console\\.log\\(`\\${prefix} \\${message}`\\);/g,\n        'process.stdout.write(`${prefix} ${message}\\\\n`);'\n      );\n\n      newContent = newContent.replace(\n        /} catch\\(error\\) {[\\s\\n]*\\/\\/ Ignore cleanup errors/g,\n        '} catch(_) {\\n      // Ignore cleanup errors'\n      );\n      newContent = newContent.replace(\n        /} catch\\(error\\) {[\\s\\n]*log\\(/g,\n        '} catch(err) {\\n    log('\n      );\n      newContent = newContent.replace(\n        /} catch\\(error\\) {[\\s\\n]*return false;/g,\n        '} catch(_) {\\n    return false;'\n      );\n\n      newContent = newContent.replace(\n        /for\\(const filePath of filesWithErrors\\) {[\\s\\n]*const success = await fixFileWithCursorAI\\(filePath\\);/g,\n        'const fixResults = await Promise.all(filesWithErrors.map(filePath => fixFileWithCursorAI(filePath)));\\nfor(const success of fixResults) {'\n      );\n\n      newContent = newContent.replace(\n        /fixedCount\\+\\+;/g,\n        'fixedCount += 1;'\n      );\n    }\n\n    if(newContent !== fileContent) {\n      writeFileSync(filePath, newContent, 'utf8');\n      log(`Fixed issues in ${filePath}`, 'info', quiet);\n      wasModified = true;\n    }\n\n    return wasModified;\n  } catch(error) {\n    log(`Error applying direct fixes to ${filePath}: ${error.message}`, 'error', quiet);\n    return false;\n  }\n};\n\nconst loadAIConfig = async (cwd: string, quiet: boolean): Promise<void> => {\n  const configFormats = ['js', 'mjs', 'cjs', 'ts', 'json'];\n  const configBaseName = 'lex.config';\n  let lexConfigPath = '';\n\n  for(const format of configFormats) {\n    const potentialPath = pathResolve(cwd, `./${configBaseName}.${format}`);\n    if(existsSync(potentialPath)) {\n      lexConfigPath = potentialPath;\n      break;\n    }\n  }\n\n  if(lexConfigPath) {\n    try {\n      const lexConfig = await import(lexConfigPath);\n      if(lexConfig.default && lexConfig.default.ai) {\n        log(`Found AI configuration in ${pathResolve(cwd, lexConfigPath)}, applying settings...`, 'info', quiet);\n        LexConfig.config.ai = {...LexConfig.config.ai, ...lexConfig.default.ai};\n      }\n    } catch(error) {\n      log(`Error loading AI configuration from ${lexConfigPath}: ${error.message}`, 'warn', quiet);\n    }\n  }\n};\n\nexport const lint = async (cmd: LintOptions, callback: LintCallback = process.exit): Promise<number> => {\n  const {\n    cliName = 'Lex',\n    fix = false,\n    debug = false,\n    quiet = false,\n    config = null\n  } = cmd;\n\n  log(`${cliName} linting...`, 'info', quiet);\n\n  const cwd = process.cwd();\n  const spinner = createSpinner(quiet);\n\n  await loadAIConfig(cwd, quiet);\n\n  let originalConfig: string | null = null;\n  let tempConfigPath: string | null = null;\n\n  try {\n    const useTypescript = detectTypeScript(cwd);\n    log(`TypeScript ${useTypescript ? 'detected' : 'not detected'} from tsconfig.json`, 'info', quiet);\n\n    if(useTypescript) {\n      LexConfig.checkLintTypescriptConfig();\n    }\n\n    ensureModuleType(cwd);\n\n    await installDependencies(cwd, useTypescript, quiet);\n\n    const projectConfigPath = pathResolve(cwd, 'eslint.config.js');\n    const projectConfigPathTs = pathResolve(cwd, 'eslint.config.ts');\n    const hasEslintConfig = existsSync(projectConfigPath) ||\n      existsSync(projectConfigPathTs) ||\n      existsSync(pathResolve(cwd, '.eslintrc.js')) ||\n      existsSync(pathResolve(cwd, '.eslintrc.json')) ||\n      existsSync(pathResolve(cwd, '.eslintrc.yml')) ||\n      existsSync(pathResolve(cwd, '.eslintrc.yaml')) ||\n      existsSync(pathResolve(cwd, '.eslintrc'));\n\n    if(existsSync(pathResolve(cwd, '.eslintrc.json'))) {\n      unlinkSync(pathResolve(cwd, '.eslintrc.json'));\n    }\n\n    let lexConfigPath = '';\n    let shouldCreateTempConfig = false;\n\n    if(!hasEslintConfig) {\n      const possiblePaths = [\n        pathResolve(currentDirname, '../../../../eslint.config.ts'),\n        pathResolve(process.env.LEX_HOME || '/usr/local/lib/node_modules/@nlabs/lex', 'eslint.config.ts')\n      ];\n\n      for(const path of possiblePaths) {\n        if(existsSync(path)) {\n          lexConfigPath = path;\n          break;\n        }\n      }\n\n      if(debug) {\n        log(`Current directory: ${currentDirname}`, 'info', quiet);\n        log(`Project config path: ${projectConfigPath}`, 'info', quiet);\n        log(`Project config exists: ${hasEslintConfig}`, 'info', quiet);\n        log(`Found Lex config: ${lexConfigPath}`, 'info', quiet);\n        log(`Lex config exists: ${!!lexConfigPath && existsSync(lexConfigPath)}`, 'info', quiet);\n      }\n\n      if(lexConfigPath && existsSync(lexConfigPath)) {\n        log('No ESLint configuration found in project. Using Lex\\'s default configuration.', 'info', quiet);\n      } else {\n        shouldCreateTempConfig = true;\n      }\n    }\n\n    if(config) {\n      const userConfigPath = pathResolve(cwd, config);\n      if(existsSync(userConfigPath)) {\n        log(`Using specified ESLint configuration: ${config}`, 'info', quiet);\n        shouldCreateTempConfig = false;\n      } else {\n        log(`Specified ESLint configuration not found: ${config}. Using Lex's default configuration.`, 'warn', quiet);\n      }\n    }\n\n    if(shouldCreateTempConfig) {\n      log('No ESLint configuration found. Creating a temporary configuration...', 'info', quiet);\n      const configResult = createDefaultESLintConfig(useTypescript, cwd);\n      tempConfigPath = configResult.configPath;\n      originalConfig = configResult.originalConfig;\n    }\n\n    let eslintOutput = '';\n    const captureOutput = (output: string) => {\n      eslintOutput += `${output}\\n`;\n    };\n\n    const result = await runEslintWithLex(cwd, quiet, cliName, true, debug, useTypescript, captureOutput);\n\n    if(result !== 0 && fix) {\n      const aiConfigured = LexConfig.config.ai?.provider && LexConfig.config.ai.provider !== 'none';\n\n      if(aiConfigured) {\n        log('Applying AI fixes to remaining issues...', 'info', quiet);\n        await applyAIFix(cwd, eslintOutput, quiet);\n\n        const afterFixResult = await runEslintWithLex(cwd, quiet, cliName, false, debug, useTypescript);\n\n        callback(afterFixResult);\n        return afterFixResult;\n      }\n      log('ESLint could not fix all issues automatically.', 'warn', quiet);\n      log('To enable AI-powered fixes, add AI configuration to your lex.config file:', 'info', quiet);\n      log(`\n// In lex.config.js (or lex.config.mjs, lex.config.cjs, etc.)\nexport default {\n  // Your existing config\n  ai: {\n    provider: 'cursor' // or 'openai', 'anthropic', etc.\n    // Additional provider-specific settings\n  }\n};`, 'info', quiet);\n    }\n\n    callback(result);\n    return result;\n  } catch(error) {\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n    if(spinner) {\n      spinner.fail('Linting failed!');\n    }\n    callback(1);\n    return 1;\n  } finally {\n    if(tempConfigPath && originalConfig) {\n      try {\n        writeFileSync(tempConfigPath, originalConfig, 'utf8');\n      } catch(_error) {\n      }\n    } else if(tempConfigPath) {\n      try {\n        unlinkSync(tempConfigPath);\n      } catch(_error) {\n      }\n    }\n  }\n};"],
  "mappings": "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",
  "names": ["lines"]
}

811
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/commands/lint/lint.ts"],
  "sourcesContent": ["/**\n * Copyright (c) 2022-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {execa} from 'execa';\nimport {existsSync, readFileSync, unlinkSync, writeFileSync} from 'fs';\nimport {dirname, resolve as pathResolve} from 'path';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {createSpinner} from '../../utils/app.js';\nimport {resolveBinaryPath} from '../../utils/file.js';\nimport {log} from '../../utils/log.js';\n\nlet currentFilename: string;\nlet currentDirname: string;\n\ntry {\n  currentFilename = eval('require(\"url\").fileURLToPath(import.meta.url)');\n  currentDirname = dirname(currentFilename);\n} catch{\n  currentFilename = process.cwd();\n  currentDirname = process.cwd();\n}\n\nexport interface LintOptions {\n  readonly cache?: boolean;\n  readonly cacheFile?: string;\n  readonly cacheLocation?: string;\n  readonly cliName?: string;\n  readonly color?: boolean;\n  readonly config?: string;\n  readonly debug?: boolean;\n  readonly env?: string;\n  readonly envInfo?: boolean;\n  readonly ext?: string;\n  readonly fix?: boolean;\n  readonly fixDryRun?: boolean;\n  readonly fixType?: string;\n  readonly format?: string;\n  readonly global?: string;\n  readonly ignorePath?: string;\n  readonly ignorePattern?: string;\n  readonly init?: boolean;\n  readonly maxWarnings?: string;\n  readonly noColor?: boolean;\n  readonly noEslintrc?: boolean;\n  readonly noIgnore?: boolean;\n  readonly noInlineConfig?: boolean;\n  readonly outputFile?: string;\n  readonly parser?: string;\n  readonly parserOptions?: string;\n  readonly plugin?: string;\n  readonly printConfig?: string;\n  readonly quiet?: boolean;\n  readonly reportUnusedDisableDirectives?: boolean;\n  readonly resolvePluginsRelativeTo?: string;\n  readonly rule?: string;\n  readonly rulesdir?: string;\n  readonly stdin?: boolean;\n  readonly stdinFilename?: string;\n}\n\nexport type LintCallback = typeof process.exit;\n\ninterface ConfigResult {\n  configPath: string;\n  originalConfig: string | null;\n}\n\nconst createDefaultESLintConfig = (useTypescript: boolean, cwd: string): ConfigResult => {\n  const configPath = pathResolve(cwd, 'eslint.config.ts');\n  let originalConfig;\n\n  if(existsSync(configPath)) {\n    try {\n      originalConfig = readFileSync(configPath, 'utf8');\n    } catch(_error) {\n      // Ignore errors\n    }\n  }\n\n  const possiblePaths = [\n    pathResolve(currentDirname, '../../../../eslint.config.ts'),\n    pathResolve(process.env.LEX_HOME || '/usr/local/lib/node_modules/@nlabs/lex', 'eslint.config.ts')\n  ];\n\n  let foundConfig = '';\n\n  for(const path of possiblePaths) {\n    if(existsSync(path)) {\n      foundConfig = path;\n      break;\n    }\n  }\n\n  let eslintConfig;\n\n  if(foundConfig) {\n    try {\n      eslintConfig = readFileSync(foundConfig, 'utf8');\n    } catch(_error) {\n      eslintConfig = createBasicESLintConfig(useTypescript);\n    }\n  } else {\n    eslintConfig = createBasicESLintConfig(useTypescript);\n  }\n\n  writeFileSync(configPath, eslintConfig, 'utf8');\n\n  return {\n    configPath,\n    originalConfig\n  };\n};\n\nconst createBasicESLintConfig = (useTypescript: boolean): string => {\n  let config = `// ESLint configuration\nimport { typescriptConfig } from 'eslint-config-styleguidejs';\n\nconst config = [\n  {\n    ignores: ['**/node_modules/**', '**/dist/**', '**/build/**']\n  },\n  // Config for JavaScript files\n  {\n    files: ['**/*.{js,jsx}'],\n    languageOptions: {\n      ecmaVersion: 'latest',\n      sourceType: 'module'\n    },\n    rules: {\n      'indent': ['error', 2],\n      'quotes': ['error', 'single'],\n      'semi': ['error', 'always'],\n      'no-unused-vars': ['warn', { 'argsIgnorePattern': '^_', 'varsIgnorePattern': '^_', 'caughtErrors': 'all', 'caughtErrorsIgnorePattern': '^_' }],\n      'eqeqeq': ['error', 'always']\n    }\n  }`;\n\n  // Add TypeScript configuration if needed\n  if(useTypescript) {\n    config += `,\n  // Config for TypeScript files\n  {\n    files: ['**/*.{ts,tsx}'],\n    languageOptions: {\n      ecmaVersion: 'latest',\n      sourceType: 'module',\n      parser: {\n        importSource: '@typescript-eslint/parser'\n      },\n              parserOptions: {\n          project: getTypeScriptConfigPath('tsconfig.lint.json')\n        }\n    },\n    plugins: {\n      '@typescript-eslint': {\n        importSource: '@typescript-eslint/eslint-plugin'\n      }\n    },\n    rules: {\n      'indent': ['error', 2],\n      'quotes': ['error', 'single'],\n      'semi': ['error', 'always'],\n      'no-unused-vars': 'off',\n      '@typescript-eslint/no-unused-vars': ['warn', { 'argsIgnorePattern': '^_', 'varsIgnorePattern': '^_', 'caughtErrors': 'all', 'caughtErrorsIgnorePattern': '^_' }],\n      'eqeqeq': ['error', 'always']\n    }\n  }`;\n  }\n\n  // Close the array and export\n  config += `\n];\n\nexport default config;`;\n\n  return config;\n};\n\n/**\n * Check if TypeScript is being used by looking for tsconfig.json\n */\nconst detectTypeScript = (cwd: string): boolean => existsSync(pathResolve(cwd, 'tsconfig.json'));\n\n/**\n * Ensure package.json has type: module for ESM support\n */\nconst ensureModuleType = (cwd: string): void => {\n  const packageJsonPath = pathResolve(cwd, 'package.json');\n\n  if(existsSync(packageJsonPath)) {\n    try {\n      const packageJsonContent = readFileSync(packageJsonPath, 'utf8');\n      const packageJson = JSON.parse(packageJsonContent);\n\n      // If type is not set to module, warn instead of auto-modifying\n      if(packageJson.type !== 'module') {\n        log('Warning: package.json should have \"type\": \"module\" for ESM support. Please add this manually.', 'warn', false);\n      }\n    } catch(_error) {\n      // Ignore errors\n    }\n  }\n};\n\nconst installDependencies = async (cwd: string, useTypescript: boolean, quiet: boolean): Promise<void> => {\n  if(useTypescript) {\n    log('Using TypeScript ESLint from Lex...', 'info', quiet);\n  } else {\n    log('Using ESLint from Lex...', 'info', quiet);\n  }\n};\n\nconst runEslintWithLex = async (\n  cwd: string,\n  quiet: boolean,\n  cliName: string,\n  fix: boolean,\n  debug: boolean,\n  useTypescript: boolean,\n  captureOutput?: (output: string) => void\n): Promise<number> => {\n  const spinner = createSpinner(quiet);\n\n  try {\n    const projectConfigPath = pathResolve(cwd, 'eslint.config.js');\n    const projectConfigPathTs = pathResolve(cwd, 'eslint.config.ts');\n    const hasProjectConfig = existsSync(projectConfigPath) || existsSync(projectConfigPathTs);\n\n    const possiblePaths = [\n      pathResolve(currentDirname, '../../../../eslint.config.ts'),\n      pathResolve(process.env.LEX_HOME || '/usr/local/lib/node_modules/@nlabs/lex', 'eslint.config.ts')\n    ];\n\n    let lexConfigPath = '';\n    for(const path of possiblePaths) {\n      if(existsSync(path)) {\n        lexConfigPath = path;\n        break;\n      }\n    }\n\n    const configPath = hasProjectConfig ? (existsSync(projectConfigPathTs) ? projectConfigPathTs : projectConfigPath) : (lexConfigPath || projectConfigPath);\n\n    const eslintBinary = resolveBinaryPath('eslint', 'eslint');\n\n    if(!eslintBinary) {\n      log(`\\n${cliName} Error: ESLint binary not found in Lex's node_modules`, 'error', quiet);\n      log('Please reinstall Lex or check your installation.', 'info', quiet);\n      return 1;\n    }\n\n    const jsResult = await execa(eslintBinary, [\n      'src/**/*.{js,jsx}',\n      '--config', configPath,\n      ...(fix ? ['--fix'] : []),\n      ...(debug ? ['--debug'] : []),\n      '--no-error-on-unmatched-pattern'\n    ], {\n      reject: false,\n      stdio: 'pipe',\n      cwd,\n      shell: true\n    });\n\n    if(jsResult.stdout) {\n      console.log(jsResult.stdout);\n      if(captureOutput) {\n        captureOutput(jsResult.stdout);\n      }\n    }\n\n    if(jsResult.stderr) {\n      console.error(jsResult.stderr);\n      if(captureOutput) {\n        captureOutput(jsResult.stderr);\n      }\n    }\n\n    let tsResult: any = {exitCode: 0, stdout: '', stderr: ''};\n    if(useTypescript) {\n      tsResult = await execa(eslintBinary, [\n        'src/**/*.{ts,tsx}',\n        '--config', configPath,\n        ...(fix ? ['--fix'] : []),\n        ...(debug ? ['--debug'] : []),\n        '--no-error-on-unmatched-pattern'\n      ], {\n        reject: false,\n        stdio: 'pipe',\n        cwd,\n        shell: true\n      });\n\n      if(tsResult.stdout) {\n        console.log(tsResult.stdout);\n      }\n\n      if(tsResult.stderr) {\n        console.error(tsResult.stderr);\n      }\n    }\n\n    const eslintNotFound = jsResult.stderr?.includes('command not found') || jsResult.stderr?.includes('eslint: command not found');\n    if(eslintNotFound) {\n      spinner.fail('ESLint not found!');\n      log(`\\n${cliName} Error: Lex's ESLint binary not found. Please reinstall Lex or check your installation.`, 'error', quiet);\n      return 1;\n    }\n\n    if(jsResult.exitCode === 0 && tsResult.exitCode === 0) {\n      spinner.succeed('Linting completed!');\n      return 0;\n    }\n\n    const noFilesFound =\n      (jsResult.stderr?.includes('No such file or directory') || jsResult.stdout?.includes('No such file or directory')) &&\n      (!useTypescript || tsResult.stderr?.includes('No such file or directory') || tsResult.stdout?.includes('No such file or directory'));\n\n    if(noFilesFound) {\n      spinner.succeed('No files found to lint');\n      return 0;\n    }\n    spinner.fail('Linting failed!');\n    log(`\\n${cliName} Error: ESLint found issues in your code.`, 'error', quiet);\n    return 1;\n  } catch(error) {\n    spinner.fail('Linting failed!');\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n    return 1;\n  }\n};\n\nconst applyAIFix = async (\n  cwd: string,\n  errors: string,\n  quiet: boolean\n): Promise<void> => {\n  const spinner = createSpinner(quiet);\n  spinner.start('Using AI to fix remaining lint issues...');\n\n  try {\n    const fileErrorMap = new Map<string, string[]>();\n    const lines = errors.split('\\n');\n    let currentFile = '';\n\n    for(const line of lines) {\n      if(line.match(/^(\\/|[A-Z]:\\\\).*?\\.(js|jsx|ts|tsx)$/)) {\n        currentFile = line.trim();\n        if(!fileErrorMap.has(currentFile)) {\n          fileErrorMap.set(currentFile, []);\n        }\n      } else if(currentFile && line.trim() && line.match(/\\s+\\d+:\\d+\\s+(error|warning)\\s+/)) {\n        const errorArray = fileErrorMap.get(currentFile);\n        if(errorArray) {\n          errorArray.push(line.trim());\n        }\n      }\n    }\n\n    if(fileErrorMap.size === 0) {\n      log('Using alternative error parsing strategy', 'info', quiet);\n\n      const sections = errors.split('\\n\\n');\n\n      for(const section of sections) {\n        if(section.trim() === '') {\n          continue;\n        }\n\n        const lines = section.split('\\n');\n        const filePath = lines[0].trim();\n\n        if(filePath.match(/\\.(js|jsx|ts|tsx)$/)) {\n          fileErrorMap.set(filePath, []);\n\n          for(let i = 1; i < lines.length; i++) {\n            if(lines[i].trim() !== '') {\n              fileErrorMap.get(filePath)?.push(lines[i].trim());\n            }\n          }\n        }\n      }\n    }\n\n    if(fileErrorMap.size === 0) {\n      log('Using direct file path extraction', 'info', quiet);\n\n      const filePathRegex = /(?:\\/|[A-Z]:\\\\)(?:[^:\\n]+\\/)*[^:\\n]+\\.(js|jsx|ts|tsx)/g;\n      const filePaths = errors.match(filePathRegex) || [];\n\n      for(const filePath of filePaths) {\n        if(!fileErrorMap.has(filePath) && existsSync(filePath)) {\n          fileErrorMap.set(filePath, []);\n        }\n      }\n\n      const knownFiles = [\n        pathResolve(cwd, 'src/create/changelog.ts'),\n        pathResolve(cwd, 'src/utils/aiService.ts'),\n        pathResolve(cwd, 'src/utils/app.ts'),\n        pathResolve(cwd, 'src/utils/reactShim.ts'),\n        pathResolve(cwd, 'src/commands/lint/autofix.js')\n      ];\n\n      for(const file of knownFiles) {\n        if(existsSync(file) && !fileErrorMap.has(file)) {\n          fileErrorMap.set(file, []);\n        }\n      }\n    }\n\n    for(const filePath of fileErrorMap.keys()) {\n      if(!existsSync(filePath)) {\n        log(`File not found: ${filePath}`, 'warn', quiet);\n        continue;\n      }\n\n      log(`Processing file: ${filePath}`, 'info', quiet);\n\n      const isCursorIDE = LexConfig.config.ai?.provider === 'cursor' || process.env.CURSOR_IDE === 'true';\n\n      if(isCursorIDE) {\n        try {\n          const prompt = `Fix all ESLint errors in this file. Focus on:\n1. Fixing naming conventions\n2. Fixing sort-keys issues\n3. Replacing console.log with log utility\n4. Fixing no-plusplus issues\n5. Fixing unnecessary escape characters\n6. Fixing other ESLint errors\n\nCRITICAL REQUIREMENTS:\n- ONLY fix the specific lines with ESLint errors\n- DO NOT modify any other lines of code\n- DO NOT remove line breaks unless they are specifically causing ESLint errors\n- DO NOT condense multi-line structures to single lines\n- PRESERVE all existing line breaks and formatting that is not causing errors\n\nSPECIFIC FORMATTING RULES:\n- Maintain proper indentation (2 spaces)\n- Keep line breaks between class/interface declaration and their members\n- Keep line breaks between methods\n- Ensure there is a line break after opening braces for classes, interfaces, and methods\n- DO NOT place class/interface properties or methods on the same line as the opening brace\n- Preserve empty lines between logical code blocks\n- PRESERVE multi-line imports - do not condense them to single lines\n- PRESERVE multi-line object/array declarations - do not condense them to single lines\n\nSORT-KEYS RULE (HIGHEST PRIORITY):\n- All object literal keys MUST be sorted alphabetically in ascending order\n- This applies to ALL objects in the file, not just those with explicit sort-keys errors\n- Example: {b: 2, a: 1, c: 3} should become {a: 1, b: 2, c: 3}\n- Preserve the original formatting and line breaks when sorting\n\nExample of CORRECT formatting (DO NOT CHANGE):\nexport class UserConstants {\n  static readonly ADD_ITEM_ERROR: string = 'USER_ADD_ITEM_ERROR';\n  static readonly OTHER_CONSTANT: string = 'OTHER_CONSTANT';\n}\n\nconstructor(flux: FluxFramework, CustomAdapter: typeof Event = Event) {\n  this.CustomAdapter = CustomAdapter;\n  this.flux = flux;\n}\n\nimport {\n  app,\n  events,\n  images,\n  locations,\n  messages,\n  posts,\n  tags,\n  users,\n  websocket\n} from './stores';\n\nconst config = {\n  apiKey: 'value',\n  baseUrl: 'https://api.example.com',\n  timeout: 5000\n};\n\nExample of INCORRECT formatting (FIX THIS):\nexport class UserConstants {static readonly ADD_ITEM_ERROR: string = 'USER_ADD_ITEM_ERROR';\n  static readonly OTHER_CONSTANT: string = 'OTHER_CONSTANT';\n}\n\nconstructor(flux: FluxFramework, CustomAdapter: typeof Event = Event) {this.CustomAdapter = CustomAdapter;\n  this.flux = flux;}\n\nimport {app, events, images, locations, messages, posts, tags, users, websocket} from './stores';\n\nconst config = {baseUrl: 'https://api.example.com', apiKey: 'value', timeout: 5000};\n\nFix ONLY the specific ESLint errors. Return the properly formatted code.`;\n\n          try {\n            const promptFile = pathResolve(cwd, '.cursor_prompt_temp.txt');\n            writeFileSync(promptFile, prompt, 'utf8');\n\n            // Use Cursor CLI to fix the file\n            await execa('cursor', ['edit', '--file', filePath, '--prompt-file', promptFile], {\n              reject: false,\n              stdio: 'pipe',\n              cwd\n            });\n\n            try {\n              unlinkSync(promptFile);\n            } catch(_error) {\n            }\n\n            log(`Applied Cursor AI fixes to ${filePath}`, 'info', quiet);\n          } catch(error) {\n            const wasModified = await applyDirectFixes(filePath, quiet);\n            if(wasModified) {\n              log(`Applied direct fixes to ${filePath}`, 'info', quiet);\n            }\n          }\n        } catch(error) {\n          log(`Error using Cursor AI: ${error.message}`, 'error', quiet);\n          await applyDirectFixes(filePath, quiet);\n        }\n      } else {\n        const wasModified = await applyDirectFixes(filePath, quiet);\n        if(wasModified) {\n          log(`Applied direct fixes to ${filePath}`, 'info', quiet);\n        }\n\n        const fileErrors = fileErrorMap.get(filePath) || [];\n        if(fileErrors.length > 0) {\n          try {\n            const {callAIService} = await import('../../utils/aiService.js');\n\n            const fileContent = readFileSync(filePath, 'utf8');\n\n            const prompt = `Fix the following ESLint errors in this code:\n${fileErrors.join('\\n')}\n\nHere's the code:\n\\`\\`\\`\n${fileContent}\n\\`\\`\\`\n\nCRITICAL REQUIREMENTS:\n- ONLY fix the specific lines with ESLint errors\n- DO NOT modify any other lines of code\n- DO NOT remove line breaks unless they are specifically causing ESLint errors\n- DO NOT condense multi-line structures to single lines\n- PRESERVE all existing line breaks and formatting that is not causing errors\n\nSPECIFIC FORMATTING RULES:\n- Maintain proper indentation (2 spaces)\n- Keep line breaks between class/interface declaration and their members\n- Keep line breaks between methods\n- Ensure there is a line break after opening braces for classes, interfaces, and methods\n- DO NOT place class/interface properties or methods on the same line as the opening brace\n- Preserve empty lines between logical code blocks\n- PRESERVE multi-line imports - do not condense them to single lines\n- PRESERVE multi-line object/array declarations - do not condense them to single lines\n\nSORT-KEYS RULE (HIGHEST PRIORITY):\n- All object literal keys MUST be sorted alphabetically in ascending order\n- This applies to ALL objects in the file, not just those with explicit sort-keys errors\n- Example: {b: 2, a: 1, c: 3} should become {a: 1, b: 2, c: 3}\n- Preserve the original formatting and line breaks when sorting\n\nWHAT TO FIX:\n1. Sorting all object keys alphabetically (sort-keys rule) - ALL objects must have sorted keys\n2. Fixing naming conventions - ONLY for variables/functions with naming errors\n3. Replacing console.log with log utility - ONLY for console.log statements\n4. Fixing no-plusplus issues - ONLY for ++/-- operators\n5. Fixing unnecessary escape characters - ONLY for escaped characters that don't need escaping\n6. Proper indentation and spacing - ONLY where specifically required by errors\n7. String quotes consistency (use single quotes) - ONLY for string literals with quote errors\n8. Import order and spacing - ONLY for imports with order/spacing errors\n9. Function parameter formatting - ONLY for functions with parameter errors\n10. Variable naming conventions - ONLY for variables with naming errors\n11. No unused variables or imports - ONLY for unused variables/imports\n12. Avoiding nested ternaries - ONLY for nested ternary expressions\n13. Any other ESLint errors - ONLY for the specific errors listed above\n\nWHAT NOT TO FIX:\n- Do not change properly formatted multi-line structures\n- Do not remove line breaks that are not causing errors\n- Do not change indentation that is already correct\n- Do not modify spacing that is already correct\n- Do not condense readable multi-line code to single lines\n- Do not modify code that is not mentioned in the ESLint errors\n\nExample of CORRECT formatting (DO NOT CHANGE):\nexport class UserConstants {\n  static readonly ADD_ITEM_ERROR: string = 'USER_ADD_ITEM_ERROR';\n  static readonly OTHER_CONSTANT: string = 'OTHER_CONSTANT';\n}\n\nconstructor(flux: FluxFramework, CustomAdapter: typeof Event = Event) {\n  this.CustomAdapter = CustomAdapter;\n  this.flux = flux;\n}\n\nimport {\n  app,\n  events,\n  images,\n  locations,\n  messages,\n  posts,\n  tags,\n  users,\n  websocket\n} from './stores';\n\nconst config = {\n  apiKey: 'value',\n  baseUrl: 'https://api.example.com',\n  timeout: 5000\n};\n\nExample of INCORRECT formatting (FIX THIS):\nexport class UserConstants {static readonly ADD_ITEM_ERROR: string = 'USER_ADD_ITEM_ERROR';\n  static readonly OTHER_CONSTANT: string = 'OTHER_CONSTANT';\n}\n\nconstructor(flux: FluxFramework, CustomAdapter: typeof Event = Event) {this.CustomAdapter = CustomAdapter;\n  this.flux = flux;}\n\nimport {app, events, images, locations, messages, posts, tags, users, websocket} from './stores';\n\nconst config = {baseUrl: 'https://api.example.com', apiKey: 'value', timeout: 5000};\n\nFix ONLY the specific ESLint errors listed above. Review the entire file for compliance with all ESLint rules.\nReturn only the properly formatted fixed code without any explanations.`;\n\n            const fixedContent = await callAIService(prompt, quiet);\n\n            if(fixedContent && fixedContent !== fileContent) {\n              writeFileSync(filePath, fixedContent, 'utf8');\n              log(`Applied AI fixes to ${filePath}`, 'info', quiet);\n            }\n          } catch(error) {\n            log(`Error applying AI fixes to ${filePath}: ${error.message}`, 'error', quiet);\n          }\n        }\n      }\n    }\n\n    spinner.succeed('AI fixes applied successfully!');\n  } catch(error) {\n    spinner.fail('Failed to apply AI fixes');\n    log(`Error: ${error.message}`, 'error', quiet);\n    if(!quiet) {\n      console.error(error);\n    }\n  }\n};\n\nconst applyDirectFixes = async (filePath: string, quiet: boolean): Promise<boolean> => {\n  let wasModified = false;\n\n  try {\n    const fileContent = readFileSync(filePath, 'utf8');\n    let newContent = fileContent;\n\n    if(filePath.includes('aiService.ts')) {\n      log('Fixing issues in aiService.ts', 'info', quiet);\n\n      newContent = newContent.replace(\n        /'Content-Type': 'application\\/json',\\s*'Authorization': `Bearer/g,\n        '\\'Authorization\\': `Bearer\\', \\'Content-Type\\': \\'application/json\\''\n      );\n\n      newContent = newContent.replace(\n        /headers: {([^}]*)},\\s*method: 'POST'/g,\n        'method: \\'POST\\',\\n      headers: {$1}'\n      );\n\n      newContent = newContent.replace(\n        /{role: 'system', content:/g,\n        '{content:, role: \\'system\\','\n      );\n      newContent = newContent.replace(\n        /{role: 'user', content:/g,\n        '{content:, role: \\'user\\','\n      );\n\n      newContent = newContent.replace(\n        /\\(([^)]*?)_([a-zA-Z0-9]+)(\\s*:[^)]*)\\)/g,\n        '($1$2$3)'\n      );\n\n      newContent = newContent.replace(/console\\.log\\(/g, 'log(');\n\n      if(!newContent.includes('import {log}') && newContent.includes('log(')) {\n        newContent = newContent.replace(\n          /import {([^}]*)} from '(.*)';/,\n          'import {$1} from \\'$2\\';\\nimport {log} from \\'./log.js\\';'\n        );\n      }\n    }\n\n    if(filePath.includes('reactShim.ts')) {\n      log('Fixing naming-convention issues in reactShim.ts', 'info', quiet);\n\n      newContent = newContent.replace(\n        'import * as React from',\n        'import * as react from'\n      );\n\n      newContent = newContent.replace(/React\\./g, 'react.');\n    }\n\n    if(filePath.includes('changelog.ts')) {\n      log('Fixing issues in changelog.ts', 'info', quiet);\n\n      newContent = newContent.replace(/(\\w+)\\+\\+/g, '$1 += 1');\n\n      newContent = newContent.replace(/\\\\\\$/g, '$');\n      newContent = newContent.replace(/\\\\\\./g, '.');\n      newContent = newContent.replace(/\\\\\\*/g, '*');\n      newContent = newContent.replace(/\\\\:/g, ':');\n    }\n\n    if(filePath.includes('app.ts')) {\n      log('Fixing issues in app.ts', 'info', quiet);\n\n      newContent = newContent.replace(/console\\.log\\(/g, 'log(');\n\n      if(!newContent.includes('import {log}') && newContent.includes('log(')) {\n        newContent = newContent.replace(\n          /import boxen from 'boxen';/,\n          'import boxen from \\'boxen\\';\\nimport {log} from \\'./log.js\\';'\n        );\n      }\n\n      newContent = newContent.replace(/\\\\\\//g, '/');\n    }\n\n    if(filePath.includes('autofix.js')) {\n      log('Fixing issues in autofix.js', 'info', quiet);\n\n      newContent = newContent.replace(\n        /import {([^}]*)} from 'path';[\\s\\n]*import {([^}]*)} from 'path';/,\n        'import {$1, $2} from \\'path\\';'\n      );\n\n      newContent = newContent.replace(\n        /__filename/g,\n        'currentFilename'\n      );\n      newContent = newContent.replace(\n        /__dirname/g,\n        'currentDirname'\n      );\n\n      newContent = newContent.replace(\n        /const prefix = type === 'error' \\? '\u274C ' : type === 'success' \\? '\u2705 ' : '\u2139\uFE0F ';/,\n        'let prefix = \\'\u2139\uFE0F \\';\\nif(type === \\'error\\') {\\n  prefix = \\'\u274C \\';\\n} else if(type === \\'success\\') {\\n  prefix = \\'\u2705 \\';\\n}'\n      );\n\n      newContent = newContent.replace(\n        /async function runEslintFix\\(\\)/g,\n        'const runEslintFix = async ()'\n      );\n      newContent = newContent.replace(\n        /async function getFilesWithErrors\\(\\)/g,\n        'const getFilesWithErrors = async ()'\n      );\n      newContent = newContent.replace(\n        /async function isCursorAvailable\\(\\)/g,\n        'const isCursorAvailable = async ()'\n      );\n      newContent = newContent.replace(\n        /async function fixFileWithCursorAI\\(filePath\\)/g,\n        'const fixFileWithCursorAI = async (filePath)'\n      );\n      newContent = newContent.replace(\n        /async function main\\(\\)/g,\n        'const main = async ()'\n      );\n\n      newContent = newContent.replace(\n        /import {existsSync, readFileSync, writeFileSync}/g,\n        'import {writeFileSync}'\n      );\n\n      newContent = newContent.replace(\n        /console\\.log\\(`\\${prefix} \\${message}`\\);/g,\n        'process.stdout.write(`${prefix} ${message}\\\\n`);'\n      );\n\n      newContent = newContent.replace(\n        /} catch\\(error\\) {[\\s\\n]*\\/\\/ Ignore cleanup errors/g,\n        '} catch(_) {\\n      // Ignore cleanup errors'\n      );\n      newContent = newContent.replace(\n        /} catch\\(error\\) {[\\s\\n]*log\\(/g,\n        '} catch(err) {\\n    log('\n      );\n      newContent = newContent.replace(\n        /} catch\\(error\\) {[\\s\\n]*return false;/g,\n        '} catch(_) {\\n    return false;'\n      );\n\n      newContent = newContent.replace(\n        /for\\(const filePath of filesWithErrors\\) {[\\s\\n]*const success = await fixFileWithCursorAI\\(filePath\\);/g,\n        'const fixResults = await Promise.all(filesWithErrors.map(filePath => fixFileWithCursorAI(filePath)));\\nfor(const success of fixResults) {'\n      );\n\n      newContent = newContent.replace(\n        /fixedCount\\+\\+;/g,\n        'fixedCount += 1;'\n      );\n    }\n\n    if(newContent !== fileContent) {\n      writeFileSync(filePath, newContent, 'utf8');\n      log(`Fixed issues in ${filePath}`, 'info', quiet);\n      wasModified = true;\n    }\n\n    return wasModified;\n  } catch(error) {\n    log(`Error applying direct fixes to ${filePath}: ${error.message}`, 'error', quiet);\n    return false;\n  }\n};\n\nconst loadAIConfig = async (cwd: string, quiet: boolean): Promise<void> => {\n  const configFormats = ['js', 'mjs', 'cjs', 'ts', 'json'];\n  const configBaseName = 'lex.config';\n  let lexConfigPath = '';\n\n  for(const format of configFormats) {\n    const potentialPath = pathResolve(cwd, `./${configBaseName}.${format}`);\n    if(existsSync(potentialPath)) {\n      lexConfigPath = potentialPath;\n      break;\n    }\n  }\n\n  if(lexConfigPath) {\n    try {\n      const lexConfig = await import(lexConfigPath);\n      if(lexConfig.default && lexConfig.default.ai) {\n        log(`Found AI configuration in ${pathResolve(cwd, lexConfigPath)}, applying settings...`, 'info', quiet);\n        LexConfig.config.ai = {...LexConfig.config.ai, ...lexConfig.default.ai};\n      }\n    } catch(error) {\n      log(`Error loading AI configuration from ${lexConfigPath}: ${error.message}`, 'warn', quiet);\n    }\n  }\n};\n\nexport const lint = async (cmd: LintOptions, callback: LintCallback = process.exit): Promise<number> => {\n  const {\n    cliName = 'Lex',\n    fix = false,\n    debug = false,\n    quiet = false,\n    config = null\n  } = cmd;\n\n  log(`${cliName} linting...`, 'info', quiet);\n\n  const cwd = process.cwd();\n  const spinner = createSpinner(quiet);\n\n  await loadAIConfig(cwd, quiet);\n\n  let originalConfig: string | null = null;\n  let tempConfigPath: string | null = null;\n\n  try {\n    const useTypescript = detectTypeScript(cwd);\n    log(`TypeScript ${useTypescript ? 'detected' : 'not detected'} from tsconfig.json`, 'info', quiet);\n\n    if(useTypescript) {\n      LexConfig.checkLintTypescriptConfig();\n    }\n\n    ensureModuleType(cwd);\n\n    await installDependencies(cwd, useTypescript, quiet);\n\n    const projectConfigPath = pathResolve(cwd, 'eslint.config.js');\n    const projectConfigPathTs = pathResolve(cwd, 'eslint.config.ts');\n    const hasEslintConfig = existsSync(projectConfigPath) ||\n      existsSync(projectConfigPathTs) ||\n      existsSync(pathResolve(cwd, '.eslintrc.js')) ||\n      existsSync(pathResolve(cwd, '.eslintrc.json')) ||\n      existsSync(pathResolve(cwd, '.eslintrc.yml')) ||\n      existsSync(pathResolve(cwd, '.eslintrc.yaml')) ||\n      existsSync(pathResolve(cwd, '.eslintrc'));\n\n    if(existsSync(pathResolve(cwd, '.eslintrc.json'))) {\n      unlinkSync(pathResolve(cwd, '.eslintrc.json'));\n    }\n\n    let lexConfigPath = '';\n    let shouldCreateTempConfig = false;\n\n    if(!hasEslintConfig) {\n      const possiblePaths = [\n        pathResolve(currentDirname, '../../../../eslint.config.ts'),\n        pathResolve(process.env.LEX_HOME || '/usr/local/lib/node_modules/@nlabs/lex', 'eslint.config.ts')\n      ];\n\n      for(const path of possiblePaths) {\n        if(existsSync(path)) {\n          lexConfigPath = path;\n          break;\n        }\n      }\n\n      if(debug) {\n        log(`Current directory: ${currentDirname}`, 'info', quiet);\n        log(`Project config path: ${projectConfigPath}`, 'info', quiet);\n        log(`Project config exists: ${hasEslintConfig}`, 'info', quiet);\n        log(`Found Lex config: ${lexConfigPath}`, 'info', quiet);\n        log(`Lex config exists: ${!!lexConfigPath && existsSync(lexConfigPath)}`, 'info', quiet);\n      }\n\n      if(lexConfigPath && existsSync(lexConfigPath)) {\n        log('No ESLint configuration found in project. Using Lex\\'s default configuration.', 'info', quiet);\n      } else {\n        shouldCreateTempConfig = true;\n      }\n    }\n\n    if(config) {\n      const userConfigPath = pathResolve(cwd, config);\n      if(existsSync(userConfigPath)) {\n        log(`Using specified ESLint configuration: ${config}`, 'info', quiet);\n        shouldCreateTempConfig = false;\n      } else {\n        log(`Specified ESLint configuration not found: ${config}. Using Lex's default configuration.`, 'warn', quiet);\n      }\n    }\n\n    if(shouldCreateTempConfig) {\n      log('No ESLint configuration found. Creating a temporary configuration...', 'info', quiet);\n      const configResult = createDefaultESLintConfig(useTypescript, cwd);\n      tempConfigPath = configResult.configPath;\n      originalConfig = configResult.originalConfig;\n    }\n\n    let eslintOutput = '';\n    const captureOutput = (output: string) => {\n      eslintOutput += `${output}\\n`;\n    };\n\n    const result = await runEslintWithLex(cwd, quiet, cliName, true, debug, useTypescript, captureOutput);\n\n    if(result !== 0 && fix) {\n      const aiConfigured = LexConfig.config.ai?.provider && LexConfig.config.ai.provider !== 'none';\n\n      if(aiConfigured) {\n        log('Applying AI fixes to remaining issues...', 'info', quiet);\n        await applyAIFix(cwd, eslintOutput, quiet);\n\n        const afterFixResult = await runEslintWithLex(cwd, quiet, cliName, false, debug, useTypescript);\n\n        callback(afterFixResult);\n        return afterFixResult;\n      }\n      log('ESLint could not fix all issues automatically.', 'warn', quiet);\n      log('To enable AI-powered fixes, add AI configuration to your lex.config file:', 'info', quiet);\n      log(`\n// In lex.config.js (or lex.config.mjs, lex.config.cjs, etc.)\nexport default {\n  // Your existing config\n  ai: {\n    provider: 'cursor' // or 'openai', 'anthropic', etc.\n    // Additional provider-specific settings\n  }\n};`, 'info', quiet);\n    }\n\n    callback(result);\n    return result;\n  } catch(error) {\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n    if(spinner) {\n      spinner.fail('Linting failed!');\n    }\n    callback(1);\n    return 1;\n  } finally {\n    if(tempConfigPath && originalConfig) {\n      try {\n        writeFileSync(tempConfigPath, originalConfig, 'utf8');\n      } catch(_error) {\n      }\n    } else if(tempConfigPath) {\n      try {\n        unlinkSync(tempConfigPath);\n      } catch(_error) {\n      }\n    }\n  }\n};"],
  "mappings": "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",
  "names": ["lines"]
}
