@nlabs/lex 1.52.23 → 1.53.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -36,32 +36,13 @@ const config = {
36
36
  }
37
37
  },
38
38
  stories: ['../src/**/*.stories.@(js|ts|tsx)', '../src/**/*.mdx'],
39
- webpackFinal: async (config) => {
39
+ webpackFinal: async (config: any) => {
40
40
  return {
41
41
  ...config,
42
42
  module: {
43
43
  ...config.module,
44
44
  rules: [
45
- ...(config.module?.rules || []),
46
- {
47
- test: /\.(ts|tsx)$/,
48
- use: [
49
- {
50
- loader: 'babel-loader',
51
- options: {
52
- presets: [
53
- '@babel/preset-typescript',
54
- [
55
- '@babel/preset-react',
56
- {
57
- runtime: 'automatic'
58
- }
59
- ]
60
- ]
61
- }
62
- }
63
- ]
64
- }
45
+ ...(config.module?.rules || [])
65
46
  ]
66
47
  },
67
48
  resolve: {
package/jest.config.mjs CHANGED
@@ -43,25 +43,7 @@ const baseConfig = {
43
43
  testEnvironment: 'node',
44
44
  testRegex: '(/__tests__/.*|\\.(test|spec|integration))\\.(ts|tsx)?$',
45
45
  transform: {
46
- '^.+\\.js$|^.+\\.jsx$': ['babel-jest', {
47
- plugins: [
48
- 'babel-plugin-transform-import-meta'
49
- ],
50
- presets: [
51
- ['@babel/preset-env', {targets: {node: 'current'}}],
52
- '@babel/preset-typescript'
53
- ]
54
- }],
55
- '^.+\\.ts$|^.+\\.tsx$': ['babel-jest', {
56
- plugins: [
57
- 'babel-plugin-transform-import-meta'
58
- ],
59
- presets: [
60
- ['@babel/preset-env', {targets: {node: 'current'}}],
61
- '@babel/preset-typescript',
62
- ['@babel/preset-react', {runtime: 'automatic'}]
63
- ]
64
- }]
46
+ '^.+\\.(t|j)sx?$': '@swc/jest'
65
47
  },
66
48
  verbose: true
67
49
  };
@@ -26,16 +26,7 @@ const baseConfig = {
26
26
  ],
27
27
  setupFilesAfterEnv: ['<rootDir>/jest.setup.js'],
28
28
  transform: {
29
- '^.+\\.ts$|^.+\\.tsx$': ['ts-jest', {
30
- useESM: false,
31
- tsconfig: 'tsconfig.test.json'
32
- }],
33
- '^.+\\.js$|^.+\\.jsx$': ['babel-jest', {
34
- presets: [
35
- ['@babel/preset-env', {targets: {node: 'current'}}],
36
- '@babel/preset-react'
37
- ]
38
- }]
29
+ '^.+\\.(t|j)sx?$': '@swc/jest'
39
30
  },
40
31
  moduleDirectories: ['node_modules', '<rootDir>'],
41
32
  testRegex: '(/__tests__/.*|\\.(test|spec|integration))\\.(ts|tsx|js|jsx)?$',
@@ -339,10 +339,6 @@ SORT-KEYS RULE (HIGHEST PRIORITY):
339
339
  - Preserve the original formatting and line breaks when sorting
340
340
 
341
341
  Example of CORRECT formatting (DO NOT CHANGE):
342
- export class UserConstants {
343
- static readonly ADD_ITEM_ERROR: string = 'USER_ADD_ITEM_ERROR';
344
- static readonly OTHER_CONSTANT: string = 'OTHER_CONSTANT';
345
- }
346
342
 
347
343
  constructor(flux: FluxFramework, CustomAdapter: typeof Event = Event) {
348
344
  this.CustomAdapter = CustomAdapter;
@@ -368,7 +364,6 @@ const config = {
368
364
  };
369
365
 
370
366
  Example of INCORRECT formatting (FIX THIS):
371
- export class UserConstants {static readonly ADD_ITEM_ERROR: string = 'USER_ADD_ITEM_ERROR';
372
367
  static readonly OTHER_CONSTANT: string = 'OTHER_CONSTANT';
373
368
  }
374
369
 
@@ -474,7 +469,6 @@ WHAT NOT TO FIX:
474
469
  - Do not modify code that is not mentioned in the ESLint errors
475
470
 
476
471
  Example of CORRECT formatting (DO NOT CHANGE):
477
- export class UserConstants {
478
472
  static readonly ADD_ITEM_ERROR: string = 'USER_ADD_ITEM_ERROR';
479
473
  static readonly OTHER_CONSTANT: string = 'OTHER_CONSTANT';
480
474
  }
@@ -503,7 +497,6 @@ const config = {
503
497
  };
504
498
 
505
499
  Example of INCORRECT formatting (FIX THIS):
506
- export class UserConstants {static readonly ADD_ITEM_ERROR: string = 'USER_ADD_ITEM_ERROR';
507
500
  static readonly OTHER_CONSTANT: string = 'OTHER_CONSTANT';
508
501
  }
509
502
 
@@ -952,4 +945,4 @@ export default {
952
945
  }
953
946
  };
954
947
 
955
- //# 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, extname} 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 removeComments?: 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  // Use a temporary file path instead of creating in the project directory\n  const configPath = pathResolve(cwd, '.lex-temp-default-eslint.cjs');\n  const originalConfig = null;\n\n  // Create a temporary CommonJS module that requires Lex's ESLint config\n  const configContent = `// Temporary ESLint config generated by Lex\nconst lexConfig = require('@nlabs/lex/eslint.config.mjs');\n\nmodule.exports = lexConfig;`;\n\n  writeFileSync(configPath, configContent, 'utf8');\n\n  return {\n    configPath,\n    originalConfig\n  };\n};\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.mjs');\n    const projectConfigPathTs = pathResolve(cwd, 'eslint.config.ts');\n    const hasProjectConfig = existsSync(projectConfigPath) || existsSync(projectConfigPathTs);\n    const hasLexConfigEslint = LexConfig.config.eslint && Object.keys(LexConfig.config.eslint).length > 0;\n\n    const possiblePaths = [\n      pathResolve(currentDirname, '../../../../eslint.config.mjs'),\n      pathResolve(currentDirname, '../../../../eslint.config.ts'),\n      pathResolve(process.env.LEX_HOME || '/usr/local/lib/node_modules/@nlabs/lex', 'eslint.config.mjs'),\n      pathResolve(process.env.LEX_HOME || '/usr/local/lib/node_modules/@nlabs/lex', 'eslint.config.ts')\n    ];\n\n    let lexConfigPath = '';\n\n    for(const path of possiblePaths) {\n      if(existsSync(path)) {\n        lexConfigPath = path;\n        break;\n      }\n    }\n\n    let configPath = '';\n    let tempConfigPath = '';\n\n    // Priority:\n    // 1. Project eslint.config files\n    // 2. ESLint config in lex.config.* file\n    // 3. Lex's default eslint.config.mjs\n    // 4. Create a temporary config file\n    if(hasProjectConfig) {\n      configPath = existsSync(projectConfigPathTs) ? projectConfigPathTs : projectConfigPath;\n      if(debug) {\n        log(`Using project ESLint config file: ${configPath}`, 'info', quiet);\n      }\n    } else if(hasLexConfigEslint) {\n      // When using lex.config.eslint, create a temporary JS config file (not JSON)\n      // to avoid ESM JSON import issues\n      tempConfigPath = pathResolve(cwd, '.lex-temp-eslint.cjs');\n\n      // Create a CommonJS module that extends Lex's eslint config\n      const configContent = `// Temporary ESLint config generated by Lex\nconst lexConfig = require('@nlabs/lex/eslint.config.mjs');\nconst userConfig = ${JSON.stringify(LexConfig.config.eslint, null, 2)};\n\n// Merge Lex's config with user config\nmodule.exports = {\n  ...lexConfig\n};`;\n\n      writeFileSync(tempConfigPath, configContent, 'utf8');\n      configPath = tempConfigPath;\n\n      if(debug) {\n        log(`Using ESLint config from lex.config.* file via temp file: ${tempConfigPath}`, 'info', quiet);\n      }\n    } else if(lexConfigPath && existsSync(lexConfigPath)) {\n      configPath = lexConfigPath;\n      if(debug) {\n        log(`Using Lex ESLint config file: ${configPath}`, 'info', quiet);\n      }\n    } else {\n      // Create a temporary default config file if no other config is found\n      tempConfigPath = pathResolve(cwd, '.lex-temp-default-eslint.cjs');\n\n      // Create a basic ESLint config\n      const configContent = `// Temporary default ESLint config generated by Lex\nconst lexConfig = require('@nlabs/lex/eslint.config.mjs');\n\nmodule.exports = lexConfig;`;\n\n      writeFileSync(tempConfigPath, configContent, 'utf8');\n      configPath = tempConfigPath;\n\n      if(debug) {\n        log(`Created temporary default ESLint config at: ${tempConfigPath}`, 'info', quiet);\n      } else {\n        log('No ESLint configuration found. Using Lex default configuration.', 'info', quiet);\n      }\n    }\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    // Base ESLint arguments\n    const baseEslintArgs = [\n      ...(fix ? ['--fix'] : []),\n      ...(debug ? ['--debug'] : []),\n      '--no-error-on-unmatched-pattern',\n      '--no-warn-ignored'\n    ];\n\n    // Add config path\n    const configArgs = configPath ? ['--config', configPath] : [];\n\n    const jsResult = await execa(eslintBinary, [\n      'src/**/*.{js,jsx}',\n      ...configArgs,\n      ...baseEslintArgs\n    ], {\n      cwd,\n      reject: false,\n      shell: true,\n      stdio: 'pipe'\n    });\n\n    if(jsResult.stdout) {\n      // eslint-disable-next-line no-console\n      console.log(jsResult.stdout);\n      if(captureOutput) {\n        captureOutput(jsResult.stdout);\n      }\n    }\n\n    if(jsResult.stderr) {\n      // eslint-disable-next-line no-console\n      console.error(jsResult.stderr);\n      if(captureOutput) {\n        captureOutput(jsResult.stderr);\n      }\n    }\n\n    let tsResult: any = {exitCode: 0, stderr: '', stdout: ''};\n    if(useTypescript) {\n      tsResult = await execa(eslintBinary, [\n        'src/**/*.{ts,tsx}',\n        ...configArgs,\n        ...baseEslintArgs\n      ], {\n        cwd,\n        reject: false,\n        shell: true,\n        stdio: 'pipe'\n      });\n\n      if(tsResult.stdout) {\n        // eslint-disable-next-line no-console\n        console.log(tsResult.stdout);\n      }\n\n      if(tsResult.stderr) {\n        // eslint-disable-next-line no-console\n        console.error(tsResult.stderr);\n      }\n    }\n\n    // Clean up temp file if created\n    if(tempConfigPath && existsSync(tempConfigPath)) {\n      try {\n        unlinkSync(tempConfigPath);\n        if(debug) {\n          log(`Removed temporary ESLint config at ${tempConfigPath}`, 'info', quiet);\n        }\n      } catch(error) {\n        // Ignore errors when cleaning up\n        if(debug) {\n          log(`Failed to remove temporary ESLint config: ${error.message}`, 'warn', quiet);\n        }\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              cwd,\n              reject: false,\n              stdio: 'pipe'\n            });\n\n            try {\n              unlinkSync(promptFile);\n            } catch(_error) {\n            }\n\n            log(`Applied Cursor AI fixes to ${filePath}`, 'info', quiet);\n          } catch{\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' \\? '❌ ' : type === 'success' \\? '✅ ' : 'ℹ️ ';/,\n        'let prefix = \\'ℹ️ \\';\\nif(type === \\'error\\') {\\n  prefix = \\'❌ \\';\\n} else if(type === \\'success\\') {\\n  prefix = \\'✅ \\';\\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, debug: boolean = false): 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      // For MJS files, we need to use dynamic import with URL for compatibility\n      const format = extname(lexConfigPath).slice(1);\n      let importPath = lexConfigPath;\n\n      // Use URL protocol for ESM imports\n      if(format === 'mjs') {\n        try {\n          const url = new URL(`file://${lexConfigPath}`);\n          importPath = url.href;\n          if(debug) {\n            log(`Using URL format for MJS import: ${importPath}`, 'info', quiet);\n          }\n        } catch(urlError) {\n          log(`Error creating URL for MJS import: ${urlError.message}`, 'warn', debug || !quiet);\n          importPath = `file://${lexConfigPath}`;\n        }\n      }\n\n      if(debug) {\n        log(`Trying to import config from ${importPath} (format: ${format})`, 'info', quiet);\n      }\n\n      let lexConfig;\n      try {\n        lexConfig = await import(importPath);\n      } catch(importError) {\n        if(importError.message.includes('not defined in ES module scope')) {\n          log(`ES Module syntax error in ${lexConfigPath}. Make sure you're using 'export' instead of 'module.exports'.`, 'error', quiet);\n          if(debug) {\n            console.error(importError);\n          }\n          return;\n        }\n        throw importError;\n      }\n\n      // Handle both ESM (default export) and CommonJS (module.exports)\n      let configData = null;\n      if(lexConfig.default) {\n        configData = lexConfig.default;\n        if(debug) {\n          log(`Found default export in ${lexConfigPath}`, 'info', quiet);\n        }\n      } else {\n        // For CommonJS or other module systems\n        configData = lexConfig;\n        if(debug) {\n          log(`Using direct export in ${lexConfigPath}`, 'info', quiet);\n        }\n      }\n\n      if(configData && configData.ai) {\n        log(`Found AI configuration in ${pathResolve(cwd, lexConfigPath)}, applying settings...`, 'info', quiet);\n        LexConfig.config.ai = {...LexConfig.config.ai, ...configData.ai};\n      }\n    } catch(error) {\n      log(`Error loading AI configuration from ${lexConfigPath}: ${error.message}`, 'warn', quiet);\n      if(debug) {\n        console.error(error);\n      }\n    }\n  }\n};\n\n/**\n * Load ESLint configuration from lex.config.* files\n */\nconst loadESLintConfig = async (cwd: string, quiet: boolean, debug: boolean): Promise<boolean> => {\n  // Check if LexConfig already has ESLint configuration loaded\n  if(LexConfig.config.eslint && Object.keys(LexConfig.config.eslint).length > 0) {\n    log('Found ESLint configuration in lex.config.* file', 'info', debug || !quiet);\n    return true;\n  }\n\n  // Try to load from lex.config.* files if not already loaded\n  const configFormats = ['js', 'mjs', 'cjs', 'ts', 'json'];\n  const configBaseName = 'lex.config';\n\n  for(const format of configFormats) {\n    const potentialPath = pathResolve(cwd, `./${configBaseName}.${format}`);\n    if(existsSync(potentialPath)) {\n      try {\n        // For MJS files, we need to use dynamic import with URL for compatibility\n        const fileFormat = extname(potentialPath).slice(1);\n        let importPath = potentialPath;\n\n        // Use URL protocol for ESM imports\n        if(fileFormat === 'mjs') {\n          try {\n            const url = new URL(`file://${potentialPath}`);\n            importPath = url.href;\n            if(debug) {\n              log(`Using URL format for MJS import: ${importPath}`, 'info', quiet);\n            }\n          } catch(urlError) {\n            log(`Error creating URL for MJS import: ${urlError.message}`, 'warn', debug || !quiet);\n            importPath = `file://${potentialPath}`;\n          }\n        }\n\n        if(debug) {\n          log(`Trying to import config from ${importPath} (format: ${fileFormat})`, 'info', quiet);\n        }\n\n        let lexConfig;\n        try {\n          lexConfig = await import(importPath);\n        } catch(importError) {\n          if(importError.message.includes('not defined in ES module scope')) {\n            log(`ES Module syntax error in ${potentialPath}. Make sure you're using 'export' instead of 'module.exports'.`, 'error', quiet);\n            if(debug) {\n              console.error(importError);\n            }\n            continue;\n          }\n          throw importError;\n        }\n\n        // Handle both ESM (default export) and CommonJS (module.exports)\n        let configData = null;\n        if(lexConfig.default) {\n          configData = lexConfig.default;\n          if(debug) {\n            log(`Found default export in ${potentialPath}`, 'info', quiet);\n          }\n        } else {\n          // For CommonJS or other module systems\n          configData = lexConfig;\n          if(debug) {\n            log(`Using direct export in ${potentialPath}`, 'info', quiet);\n          }\n        }\n\n        if(configData && configData.eslint && Object.keys(configData.eslint).length > 0) {\n          log(`Found ESLint configuration in ${pathResolve(cwd, potentialPath)}, applying settings...`, 'info', debug || !quiet);\n          LexConfig.config.eslint = {...LexConfig.config.eslint, ...configData.eslint};\n          return true;\n        }\n      } catch(error) {\n        log(`Error loading ESLint configuration from ${potentialPath}: ${error.message}`, 'warn', quiet);\n        if(debug) {\n          console.error(error);\n        }\n      }\n    }\n  }\n\n  return false;\n};\n\nconst removeFileComments = (filePath: string, quiet: boolean): boolean => {\n  try {\n    const fileContent = readFileSync(filePath, 'utf8');\n\n    if(fileContent.length > 1000000) { // 1MB limit\n      log(`Skipping comment removal for large file: ${filePath}`, 'info', quiet);\n      return false;\n    }\n    // Use regex to match different types of comments\n    // Preserves:\n    // 1. Copyright notices (/* Copyright ... */)\n    // 2. TODO comments (// TODO: ...)\n    // 3. License headers (/* ... License ... */)\n\n    // Handle multi-line comments first - preserve copyright/license notices\n    let newContent = fileContent.replace(\n      /\\/\\*[\\s\\S]*?\\*\\//g,\n      (match) => {\n        if(match.includes('Copyright') ||\n          match.includes('LICENSE') ||\n          match.includes('License') ||\n          match.includes('license')) {\n          return match;\n        }\n        return '';\n      }\n    );\n\n    // Handle single-line comments - preserve TODOs\n    newContent = newContent.replace(\n      /\\/\\/.*$/gm,\n      (match) => {\n        if(match.includes('TODO') || match.includes('FIXME')) {\n          return match;\n        }\n        return '';\n      }\n    );\n\n    // Clean up any multiple blank lines created by comment removal\n    newContent = newContent.replace(/\\n\\s*\\n\\s*\\n/g, '\\n\\n');\n\n    // If the file was modified, save it\n    if(newContent !== fileContent) {\n      writeFileSync(filePath, newContent, 'utf8');\n      log(`Removed comments from ${filePath}`, 'info', quiet);\n      return true;\n    }\n\n    return false;\n  } catch(error) {\n    log(`Error removing comments from ${filePath}: ${error.message}`, 'error', quiet);\n    return false;\n  }\n};\n\nexport const lint = async (cmd: LintOptions & {'remove-comments'?: boolean}, callback: LintCallback = process.exit): Promise<number> => {\n  const {\n    cliName = 'Lex',\n    fix = false,\n    debug = false,\n    quiet = false,\n    config = null,\n    removeComments = false,\n    'remove-comments': removeCommentsFlag = false\n  } = cmd;\n\n  const shouldRemoveComments = removeComments || removeCommentsFlag;\n\n  log(`${cliName} linting...`, 'info', quiet);\n\n  const cwd = process.cwd();\n  const spinner = createSpinner(quiet);\n\n  await loadAIConfig(cwd, quiet, debug);\n\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.mjs');\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    const hasLexEslintConfig = await loadESLintConfig(cwd, quiet, debug);\n\n    if(hasLexEslintConfig) {\n      log('Using ESLint configuration from lex.config.* file', 'info', quiet);\n    }\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 && !hasLexEslintConfig) {\n      const possiblePaths = [\n        pathResolve(currentDirname, '../../../../eslint.config.ts'),\n        pathResolve(currentDirname, '../../../../eslint.config.jms'),\n        pathResolve(process.env.LEX_HOME || './node_modules/@nlabs/lex', 'eslint.config.ts'),\n        pathResolve(process.env.LEX_HOME || './node_modules/@nlabs/lex', 'eslint.config.mjs')\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    }\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(shouldRemoveComments) {\n      spinner.start('Removing comments from files...');\n\n      const glob = await import('glob');\n      const files = glob.sync('{src,lib}/**/*.{js,jsx,ts,tsx}', {\n        cwd,\n        ignore: ['**/node_modules/**', '**/lib/**', '**/dist/**', '**/build/**']\n      });\n\n      let processedCount = 0;\n      for(const file of files) {\n        const filePath = pathResolve(cwd, file);\n        if(removeFileComments(filePath, quiet)) {\n          processedCount++;\n        }\n      }\n\n      spinner.succeed(`Removed comments from ${processedCount} files`);\n    }\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    const tempFilePaths = [\n      tempConfigPath,\n      pathResolve(cwd, '.lex-temp-eslint.cjs'),\n      pathResolve(cwd, '.lex-temp-default-eslint.cjs')\n    ];\n\n    for(const filePath of tempFilePaths) {\n      if(filePath && existsSync(filePath)) {\n        try {\n          unlinkSync(filePath);\n          if(debug) {\n            log(`Cleaned up temporary ESLint config at ${filePath}`, 'info', quiet);\n          }\n        } catch{\n        }\n      }\n    }\n  }\n};"],"names":["execa","existsSync","readFileSync","unlinkSync","writeFileSync","dirname","resolve","pathResolve","extname","LexConfig","createSpinner","resolveBinaryPath","log","currentFilename","currentDirname","eval","process","cwd","createDefaultESLintConfig","useTypescript","configPath","originalConfig","configContent","detectTypeScript","ensureModuleType","packageJsonPath","packageJsonContent","packageJson","JSON","parse","type","_error","installDependencies","quiet","runEslintWithLex","cliName","fix","debug","captureOutput","spinner","projectConfigPath","projectConfigPathTs","hasProjectConfig","hasLexConfigEslint","config","eslint","Object","keys","length","possiblePaths","env","LEX_HOME","lexConfigPath","path","tempConfigPath","stringify","eslintBinary","baseEslintArgs","configArgs","jsResult","reject","shell","stdio","stdout","console","stderr","error","tsResult","exitCode","message","eslintNotFound","includes","fail","succeed","noFilesFound","applyAIFix","errors","start","fileErrorMap","Map","lines","split","currentFile","line","match","trim","has","set","errorArray","get","push","size","sections","section","filePath","i","filePathRegex","filePaths","knownFiles","file","isCursorIDE","ai","provider","CURSOR_IDE","prompt","promptFile","wasModified","applyDirectFixes","fileErrors","callAIService","fileContent","join","fixedContent","newContent","replace","loadAIConfig","configFormats","configBaseName","format","potentialPath","slice","importPath","url","URL","href","urlError","lexConfig","importError","configData","default","loadESLintConfig","fileFormat","removeFileComments","lint","cmd","callback","exit","removeComments","removeCommentsFlag","shouldRemoveComments","checkLintTypescriptConfig","hasEslintConfig","hasLexEslintConfig","shouldCreateTempConfig","userConfigPath","configResult","eslintOutput","output","result","glob","files","sync","ignore","processedCount","aiConfigured","afterFixResult","tempFilePaths"],"mappings":"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"}
948
+ //# 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, extname} 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 removeComments?: 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  // Use a temporary file path instead of creating in the project directory\n  const configPath = pathResolve(cwd, '.lex-temp-default-eslint.cjs');\n  const originalConfig = null;\n\n  // Create a temporary CommonJS module that requires Lex's ESLint config\n  const configContent = `// Temporary ESLint config generated by Lex\nconst lexConfig = require('@nlabs/lex/eslint.config.mjs');\n\nmodule.exports = lexConfig;`;\n\n  writeFileSync(configPath, configContent, 'utf8');\n\n  return {\n    configPath,\n    originalConfig\n  };\n};\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.mjs');\n    const projectConfigPathTs = pathResolve(cwd, 'eslint.config.ts');\n    const hasProjectConfig = existsSync(projectConfigPath) || existsSync(projectConfigPathTs);\n    const hasLexConfigEslint = LexConfig.config.eslint && Object.keys(LexConfig.config.eslint).length > 0;\n\n    const possiblePaths = [\n      pathResolve(currentDirname, '../../../../eslint.config.mjs'),\n      pathResolve(currentDirname, '../../../../eslint.config.ts'),\n      pathResolve(process.env.LEX_HOME || '/usr/local/lib/node_modules/@nlabs/lex', 'eslint.config.mjs'),\n      pathResolve(process.env.LEX_HOME || '/usr/local/lib/node_modules/@nlabs/lex', 'eslint.config.ts')\n    ];\n\n    let lexConfigPath = '';\n\n    for(const path of possiblePaths) {\n      if(existsSync(path)) {\n        lexConfigPath = path;\n        break;\n      }\n    }\n\n    let configPath = '';\n    let tempConfigPath = '';\n\n    // Priority:\n    // 1. Project eslint.config files\n    // 2. ESLint config in lex.config.* file\n    // 3. Lex's default eslint.config.mjs\n    // 4. Create a temporary config file\n    if(hasProjectConfig) {\n      configPath = existsSync(projectConfigPathTs) ? projectConfigPathTs : projectConfigPath;\n      if(debug) {\n        log(`Using project ESLint config file: ${configPath}`, 'info', quiet);\n      }\n    } else if(hasLexConfigEslint) {\n      // When using lex.config.eslint, create a temporary JS config file (not JSON)\n      // to avoid ESM JSON import issues\n      tempConfigPath = pathResolve(cwd, '.lex-temp-eslint.cjs');\n\n      // Create a CommonJS module that extends Lex's eslint config\n      const configContent = `// Temporary ESLint config generated by Lex\nconst lexConfig = require('@nlabs/lex/eslint.config.mjs');\nconst userConfig = ${JSON.stringify(LexConfig.config.eslint, null, 2)};\n\n// Merge Lex's config with user config\nmodule.exports = {\n  ...lexConfig\n};`;\n\n      writeFileSync(tempConfigPath, configContent, 'utf8');\n      configPath = tempConfigPath;\n\n      if(debug) {\n        log(`Using ESLint config from lex.config.* file via temp file: ${tempConfigPath}`, 'info', quiet);\n      }\n    } else if(lexConfigPath && existsSync(lexConfigPath)) {\n      configPath = lexConfigPath;\n      if(debug) {\n        log(`Using Lex ESLint config file: ${configPath}`, 'info', quiet);\n      }\n    } else {\n      // Create a temporary default config file if no other config is found\n      tempConfigPath = pathResolve(cwd, '.lex-temp-default-eslint.cjs');\n\n      // Create a basic ESLint config\n      const configContent = `// Temporary default ESLint config generated by Lex\nconst lexConfig = require('@nlabs/lex/eslint.config.mjs');\n\nmodule.exports = lexConfig;`;\n\n      writeFileSync(tempConfigPath, configContent, 'utf8');\n      configPath = tempConfigPath;\n\n      if(debug) {\n        log(`Created temporary default ESLint config at: ${tempConfigPath}`, 'info', quiet);\n      } else {\n        log('No ESLint configuration found. Using Lex default configuration.', 'info', quiet);\n      }\n    }\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    // Base ESLint arguments\n    const baseEslintArgs = [\n      ...(fix ? ['--fix'] : []),\n      ...(debug ? ['--debug'] : []),\n      '--no-error-on-unmatched-pattern',\n      '--no-warn-ignored'\n    ];\n\n    // Add config path\n    const configArgs = configPath ? ['--config', configPath] : [];\n\n    const jsResult = await execa(eslintBinary, [\n      'src/**/*.{js,jsx}',\n      ...configArgs,\n      ...baseEslintArgs\n    ], {\n      cwd,\n      reject: false,\n      shell: true,\n      stdio: 'pipe'\n    });\n\n    if(jsResult.stdout) {\n      // eslint-disable-next-line no-console\n      console.log(jsResult.stdout);\n      if(captureOutput) {\n        captureOutput(jsResult.stdout);\n      }\n    }\n\n    if(jsResult.stderr) {\n      // eslint-disable-next-line no-console\n      console.error(jsResult.stderr);\n      if(captureOutput) {\n        captureOutput(jsResult.stderr);\n      }\n    }\n\n    let tsResult: any = {exitCode: 0, stderr: '', stdout: ''};\n    if(useTypescript) {\n      tsResult = await execa(eslintBinary, [\n        'src/**/*.{ts,tsx}',\n        ...configArgs,\n        ...baseEslintArgs\n      ], {\n        cwd,\n        reject: false,\n        shell: true,\n        stdio: 'pipe'\n      });\n\n      if(tsResult.stdout) {\n        // eslint-disable-next-line no-console\n        console.log(tsResult.stdout);\n      }\n\n      if(tsResult.stderr) {\n        // eslint-disable-next-line no-console\n        console.error(tsResult.stderr);\n      }\n    }\n\n    // Clean up temp file if created\n    if(tempConfigPath && existsSync(tempConfigPath)) {\n      try {\n        unlinkSync(tempConfigPath);\n        if(debug) {\n          log(`Removed temporary ESLint config at ${tempConfigPath}`, 'info', quiet);\n        }\n      } catch(error) {\n        // Ignore errors when cleaning up\n        if(debug) {\n          log(`Failed to remove temporary ESLint config: ${error.message}`, 'warn', quiet);\n        }\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):\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):\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              cwd,\n              reject: false,\n              stdio: 'pipe'\n            });\n\n            try {\n              unlinkSync(promptFile);\n            } catch(_error) {\n            }\n\n            log(`Applied Cursor AI fixes to ${filePath}`, 'info', quiet);\n          } catch{\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):\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):\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' \\? '❌ ' : type === 'success' \\? '✅ ' : 'ℹ️ ';/,\n        'let prefix = \\'ℹ️ \\';\\nif(type === \\'error\\') {\\n  prefix = \\'❌ \\';\\n} else if(type === \\'success\\') {\\n  prefix = \\'✅ \\';\\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, debug: boolean = false): 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      // For MJS files, we need to use dynamic import with URL for compatibility\n      const format = extname(lexConfigPath).slice(1);\n      let importPath = lexConfigPath;\n\n      // Use URL protocol for ESM imports\n      if(format === 'mjs') {\n        try {\n          const url = new URL(`file://${lexConfigPath}`);\n          importPath = url.href;\n          if(debug) {\n            log(`Using URL format for MJS import: ${importPath}`, 'info', quiet);\n          }\n        } catch(urlError) {\n          log(`Error creating URL for MJS import: ${urlError.message}`, 'warn', debug || !quiet);\n          importPath = `file://${lexConfigPath}`;\n        }\n      }\n\n      if(debug) {\n        log(`Trying to import config from ${importPath} (format: ${format})`, 'info', quiet);\n      }\n\n      let lexConfig;\n      try {\n        lexConfig = await import(importPath);\n      } catch(importError) {\n        if(importError.message.includes('not defined in ES module scope')) {\n          log(`ES Module syntax error in ${lexConfigPath}. Make sure you're using 'export' instead of 'module.exports'.`, 'error', quiet);\n          if(debug) {\n            console.error(importError);\n          }\n          return;\n        }\n        throw importError;\n      }\n\n      // Handle both ESM (default export) and CommonJS (module.exports)\n      let configData = null;\n      if(lexConfig.default) {\n        configData = lexConfig.default;\n        if(debug) {\n          log(`Found default export in ${lexConfigPath}`, 'info', quiet);\n        }\n      } else {\n        // For CommonJS or other module systems\n        configData = lexConfig;\n        if(debug) {\n          log(`Using direct export in ${lexConfigPath}`, 'info', quiet);\n        }\n      }\n\n      if(configData && configData.ai) {\n        log(`Found AI configuration in ${pathResolve(cwd, lexConfigPath)}, applying settings...`, 'info', quiet);\n        LexConfig.config.ai = {...LexConfig.config.ai, ...configData.ai};\n      }\n    } catch(error) {\n      log(`Error loading AI configuration from ${lexConfigPath}: ${error.message}`, 'warn', quiet);\n      if(debug) {\n        console.error(error);\n      }\n    }\n  }\n};\n\n/**\n * Load ESLint configuration from lex.config.* files\n */\nconst loadESLintConfig = async (cwd: string, quiet: boolean, debug: boolean): Promise<boolean> => {\n  // Check if LexConfig already has ESLint configuration loaded\n  if(LexConfig.config.eslint && Object.keys(LexConfig.config.eslint).length > 0) {\n    log('Found ESLint configuration in lex.config.* file', 'info', debug || !quiet);\n    return true;\n  }\n\n  // Try to load from lex.config.* files if not already loaded\n  const configFormats = ['js', 'mjs', 'cjs', 'ts', 'json'];\n  const configBaseName = 'lex.config';\n\n  for(const format of configFormats) {\n    const potentialPath = pathResolve(cwd, `./${configBaseName}.${format}`);\n    if(existsSync(potentialPath)) {\n      try {\n        // For MJS files, we need to use dynamic import with URL for compatibility\n        const fileFormat = extname(potentialPath).slice(1);\n        let importPath = potentialPath;\n\n        // Use URL protocol for ESM imports\n        if(fileFormat === 'mjs') {\n          try {\n            const url = new URL(`file://${potentialPath}`);\n            importPath = url.href;\n            if(debug) {\n              log(`Using URL format for MJS import: ${importPath}`, 'info', quiet);\n            }\n          } catch(urlError) {\n            log(`Error creating URL for MJS import: ${urlError.message}`, 'warn', debug || !quiet);\n            importPath = `file://${potentialPath}`;\n          }\n        }\n\n        if(debug) {\n          log(`Trying to import config from ${importPath} (format: ${fileFormat})`, 'info', quiet);\n        }\n\n        let lexConfig;\n        try {\n          lexConfig = await import(importPath);\n        } catch(importError) {\n          if(importError.message.includes('not defined in ES module scope')) {\n            log(`ES Module syntax error in ${potentialPath}. Make sure you're using 'export' instead of 'module.exports'.`, 'error', quiet);\n            if(debug) {\n              console.error(importError);\n            }\n            continue;\n          }\n          throw importError;\n        }\n\n        // Handle both ESM (default export) and CommonJS (module.exports)\n        let configData = null;\n        if(lexConfig.default) {\n          configData = lexConfig.default;\n          if(debug) {\n            log(`Found default export in ${potentialPath}`, 'info', quiet);\n          }\n        } else {\n          // For CommonJS or other module systems\n          configData = lexConfig;\n          if(debug) {\n            log(`Using direct export in ${potentialPath}`, 'info', quiet);\n          }\n        }\n\n        if(configData && configData.eslint && Object.keys(configData.eslint).length > 0) {\n          log(`Found ESLint configuration in ${pathResolve(cwd, potentialPath)}, applying settings...`, 'info', debug || !quiet);\n          LexConfig.config.eslint = {...LexConfig.config.eslint, ...configData.eslint};\n          return true;\n        }\n      } catch(error) {\n        log(`Error loading ESLint configuration from ${potentialPath}: ${error.message}`, 'warn', quiet);\n        if(debug) {\n          console.error(error);\n        }\n      }\n    }\n  }\n\n  return false;\n};\n\nconst removeFileComments = (filePath: string, quiet: boolean): boolean => {\n  try {\n    const fileContent = readFileSync(filePath, 'utf8');\n\n    if(fileContent.length > 1000000) { // 1MB limit\n      log(`Skipping comment removal for large file: ${filePath}`, 'info', quiet);\n      return false;\n    }\n    // Use regex to match different types of comments\n    // Preserves:\n    // 1. Copyright notices (/* Copyright ... */)\n    // 2. TODO comments (// TODO: ...)\n    // 3. License headers (/* ... License ... */)\n\n    // Handle multi-line comments first - preserve copyright/license notices\n    let newContent = fileContent.replace(\n      /\\/\\*[\\s\\S]*?\\*\\//g,\n      (match) => {\n        if(match.includes('Copyright') ||\n          match.includes('LICENSE') ||\n          match.includes('License') ||\n          match.includes('license')) {\n          return match;\n        }\n        return '';\n      }\n    );\n\n    // Handle single-line comments - preserve TODOs\n    newContent = newContent.replace(\n      /\\/\\/.*$/gm,\n      (match) => {\n        if(match.includes('TODO') || match.includes('FIXME')) {\n          return match;\n        }\n        return '';\n      }\n    );\n\n    // Clean up any multiple blank lines created by comment removal\n    newContent = newContent.replace(/\\n\\s*\\n\\s*\\n/g, '\\n\\n');\n\n    // If the file was modified, save it\n    if(newContent !== fileContent) {\n      writeFileSync(filePath, newContent, 'utf8');\n      log(`Removed comments from ${filePath}`, 'info', quiet);\n      return true;\n    }\n\n    return false;\n  } catch(error) {\n    log(`Error removing comments from ${filePath}: ${error.message}`, 'error', quiet);\n    return false;\n  }\n};\n\nexport const lint = async (cmd: LintOptions & {'remove-comments'?: boolean}, callback: LintCallback = process.exit): Promise<number> => {\n  const {\n    cliName = 'Lex',\n    fix = false,\n    debug = false,\n    quiet = false,\n    config = null,\n    removeComments = false,\n    'remove-comments': removeCommentsFlag = false\n  } = cmd;\n\n  const shouldRemoveComments = removeComments || removeCommentsFlag;\n\n  log(`${cliName} linting...`, 'info', quiet);\n\n  const cwd = process.cwd();\n  const spinner = createSpinner(quiet);\n\n  await loadAIConfig(cwd, quiet, debug);\n\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.mjs');\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    const hasLexEslintConfig = await loadESLintConfig(cwd, quiet, debug);\n\n    if(hasLexEslintConfig) {\n      log('Using ESLint configuration from lex.config.* file', 'info', quiet);\n    }\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 && !hasLexEslintConfig) {\n      const possiblePaths = [\n        pathResolve(currentDirname, '../../../../eslint.config.ts'),\n        pathResolve(currentDirname, '../../../../eslint.config.jms'),\n        pathResolve(process.env.LEX_HOME || './node_modules/@nlabs/lex', 'eslint.config.ts'),\n        pathResolve(process.env.LEX_HOME || './node_modules/@nlabs/lex', 'eslint.config.mjs')\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    }\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(shouldRemoveComments) {\n      spinner.start('Removing comments from files...');\n\n      const glob = await import('glob');\n      const files = glob.sync('{src,lib}/**/*.{js,jsx,ts,tsx}', {\n        cwd,\n        ignore: ['**/node_modules/**', '**/lib/**', '**/dist/**', '**/build/**']\n      });\n\n      let processedCount = 0;\n      for(const file of files) {\n        const filePath = pathResolve(cwd, file);\n        if(removeFileComments(filePath, quiet)) {\n          processedCount++;\n        }\n      }\n\n      spinner.succeed(`Removed comments from ${processedCount} files`);\n    }\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    const tempFilePaths = [\n      tempConfigPath,\n      pathResolve(cwd, '.lex-temp-eslint.cjs'),\n      pathResolve(cwd, '.lex-temp-default-eslint.cjs')\n    ];\n\n    for(const filePath of tempFilePaths) {\n      if(filePath && existsSync(filePath)) {\n        try {\n          unlinkSync(filePath);\n          if(debug) {\n            log(`Cleaned up temporary ESLint config at ${filePath}`, 'info', quiet);\n          }\n        } catch{\n        }\n      }\n    }\n  }\n};"],"names":["execa","existsSync","readFileSync","unlinkSync","writeFileSync","dirname","resolve","pathResolve","extname","LexConfig","createSpinner","resolveBinaryPath","log","currentFilename","currentDirname","eval","process","cwd","createDefaultESLintConfig","useTypescript","configPath","originalConfig","configContent","detectTypeScript","ensureModuleType","packageJsonPath","packageJsonContent","packageJson","JSON","parse","type","_error","installDependencies","quiet","runEslintWithLex","cliName","fix","debug","captureOutput","spinner","projectConfigPath","projectConfigPathTs","hasProjectConfig","hasLexConfigEslint","config","eslint","Object","keys","length","possiblePaths","env","LEX_HOME","lexConfigPath","path","tempConfigPath","stringify","eslintBinary","baseEslintArgs","configArgs","jsResult","reject","shell","stdio","stdout","console","stderr","error","tsResult","exitCode","message","eslintNotFound","includes","fail","succeed","noFilesFound","applyAIFix","errors","start","fileErrorMap","Map","lines","split","currentFile","line","match","trim","has","set","errorArray","get","push","size","sections","section","filePath","i","filePathRegex","filePaths","knownFiles","file","isCursorIDE","ai","provider","CURSOR_IDE","prompt","promptFile","wasModified","applyDirectFixes","fileErrors","callAIService","fileContent","join","fixedContent","newContent","replace","loadAIConfig","configFormats","configBaseName","format","potentialPath","slice","importPath","url","URL","href","urlError","lexConfig","importError","configData","default","loadESLintConfig","fileFormat","removeFileComments","lint","cmd","callback","exit","removeComments","removeCommentsFlag","shouldRemoveComments","checkLintTypescriptConfig","hasEslintConfig","hasLexEslintConfig","shouldCreateTempConfig","userConfigPath","configResult","eslintOutput","output","result","glob","files","sync","ignore","processedCount","aiConfigured","afterFixResult","tempFilePaths"],"mappings":"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"}
package/lib/index.d.ts CHANGED
@@ -12,7 +12,6 @@ export * from './utils/aiService.js';
12
12
  export * from './utils/app.js';
13
13
  export * from './utils/file.js';
14
14
  export * from './utils/log.js';
15
- export * from './utils/reactShim.js';
16
15
  export * from './storybook/index.js';
17
16
  export * from './commands/ai/ai.js';
18
17
  export * from './commands/build/build.js';
package/lib/index.js CHANGED
@@ -14,7 +14,6 @@ export * from './utils/aiService.js';
14
14
  export * from './utils/app.js';
15
15
  export * from './utils/file.js';
16
16
  export * from './utils/log.js';
17
- export * from './utils/reactShim.js';
18
17
  // Export Storybook module
19
18
  export * from './storybook/index.js';
20
19
  // Export commands
@@ -38,4 +37,4 @@ export * from './commands/update/update.js';
38
37
  export * from './commands/upgrade/upgrade.js';
39
38
  export * from './commands/versions/versions.js';
40
39
 
41
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuXG5pbXBvcnQgdHlwZSB7TGV4Q29uZmlnVHlwZX0gZnJvbSAnLi9MZXhDb25maWcuanMnO1xuXG4vLyBFeHBvcnQgdHlwZXMgZnJvbSB0eXBlcy50c1xuZXhwb3J0ICogZnJvbSAnLi90eXBlcy5qcyc7XG5cbi8vIEV4cG9ydCBjbGFzc2VzIGFuZCB2YWx1ZXMgZnJvbSBMZXhDb25maWdcbmV4cG9ydCB7XG4gIGRlZmF1bHRDb25maWdWYWx1ZXMsIExleENvbmZpZ1xufSBmcm9tICcuL0xleENvbmZpZy5qcyc7XG5cbi8vIEV4cG9ydCBDb25maWcgYXMgYm90aCBhIHR5cGUgYW5kIGEgbmFtZXNwYWNlIHdpdGggY3JlYXRlIG1ldGhvZCBmb3IgYmFja3dhcmQgY29tcGF0aWJpbGl0eVxuZXhwb3J0IGNvbnN0IENvbmZpZyA9IHtcbiAgY3JlYXRlOiAoY29uZmlnOiBMZXhDb25maWdUeXBlKSA9PiBjb25maWdcbn07XG5cbi8vIEV4cG9ydCB1dGlsaXR5IGZ1bmN0aW9uc1xuZXhwb3J0ICogZnJvbSAnLi91dGlscy9haVNlcnZpY2UuanMnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscy9hcHAuanMnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscy9maWxlLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vdXRpbHMvbG9nLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vdXRpbHMvcmVhY3RTaGltLmpzJztcblxuLy8gRXhwb3J0IFN0b3J5Ym9vayBtb2R1bGVcbmV4cG9ydCAqIGZyb20gJy4vc3Rvcnlib29rL2luZGV4LmpzJztcblxuLy8gRXhwb3J0IGNvbW1hbmRzXG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2FpL2FpLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vY29tbWFuZHMvYnVpbGQvYnVpbGQuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tYW5kcy9jbGVhbi9jbGVhbi5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2NvbXBpbGUvY29tcGlsZS5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2NvbmZpZy9jb25maWcuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tYW5kcy9jb3B5L2NvcHkuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tYW5kcy9jcmVhdGUvY3JlYXRlLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vY29tbWFuZHMvZGV2L2Rldi5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2luaXQvaW5pdC5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2xpbmsvbGluay5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2xpbnQvbGludC5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL21pZ3JhdGUvbWlncmF0ZS5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL3B1Ymxpc2gvcHVibGlzaC5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL3NlcnZlcmxlc3Mvc2VydmVybGVzcy5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL3N0b3J5Ym9vay9zdG9yeWJvb2suanMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tYW5kcy90ZXN0L3Rlc3QuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tYW5kcy91cGRhdGUvdXBkYXRlLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vY29tbWFuZHMvdXBncmFkZS91cGdyYWRlLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vY29tbWFuZHMvdmVyc2lvbnMvdmVyc2lvbnMuanMnO1xuIl0sIm5hbWVzIjpbImRlZmF1bHRDb25maWdWYWx1ZXMiLCJMZXhDb25maWciLCJDb25maWciLCJjcmVhdGUiLCJjb25maWciXSwibWFwcGluZ3MiOiJBQUFBOzs7Q0FHQyxHQUlELDZCQUE2QjtBQUM3QixjQUFjLGFBQWE7QUFFM0IsMkNBQTJDO0FBQzNDLFNBQ0VBLG1CQUFtQixFQUFFQyxTQUFTLFFBQ3pCLGlCQUFpQjtBQUV4Qiw2RkFBNkY7QUFDN0YsT0FBTyxNQUFNQyxTQUFTO0lBQ3BCQyxRQUFRLENBQUNDLFNBQTBCQTtBQUNyQyxFQUFFO0FBRUYsMkJBQTJCO0FBQzNCLGNBQWMsdUJBQXVCO0FBQ3JDLGNBQWMsaUJBQWlCO0FBQy9CLGNBQWMsa0JBQWtCO0FBQ2hDLGNBQWMsaUJBQWlCO0FBQy9CLGNBQWMsdUJBQXVCO0FBRXJDLDBCQUEwQjtBQUMxQixjQUFjLHVCQUF1QjtBQUVyQyxrQkFBa0I7QUFDbEIsY0FBYyxzQkFBc0I7QUFDcEMsY0FBYyw0QkFBNEI7QUFDMUMsY0FBYyw0QkFBNEI7QUFDMUMsY0FBYyxnQ0FBZ0M7QUFDOUMsY0FBYyw4QkFBOEI7QUFDNUMsY0FBYywwQkFBMEI7QUFDeEMsY0FBYyw4QkFBOEI7QUFDNUMsY0FBYyx3QkFBd0I7QUFDdEMsY0FBYywwQkFBMEI7QUFDeEMsY0FBYywwQkFBMEI7QUFDeEMsY0FBYywwQkFBMEI7QUFDeEMsY0FBYyxnQ0FBZ0M7QUFDOUMsY0FBYyxnQ0FBZ0M7QUFDOUMsY0FBYyxzQ0FBc0M7QUFDcEQsY0FBYyxvQ0FBb0M7QUFDbEQsY0FBYywwQkFBMEI7QUFDeEMsY0FBYyw4QkFBOEI7QUFDNUMsY0FBYyxnQ0FBZ0M7QUFDOUMsY0FBYyxrQ0FBa0MifQ==
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuXG5pbXBvcnQgdHlwZSB7TGV4Q29uZmlnVHlwZX0gZnJvbSAnLi9MZXhDb25maWcuanMnO1xuXG4vLyBFeHBvcnQgdHlwZXMgZnJvbSB0eXBlcy50c1xuZXhwb3J0ICogZnJvbSAnLi90eXBlcy5qcyc7XG5cbi8vIEV4cG9ydCBjbGFzc2VzIGFuZCB2YWx1ZXMgZnJvbSBMZXhDb25maWdcbmV4cG9ydCB7XG4gIGRlZmF1bHRDb25maWdWYWx1ZXMsIExleENvbmZpZ1xufSBmcm9tICcuL0xleENvbmZpZy5qcyc7XG5cbi8vIEV4cG9ydCBDb25maWcgYXMgYm90aCBhIHR5cGUgYW5kIGEgbmFtZXNwYWNlIHdpdGggY3JlYXRlIG1ldGhvZCBmb3IgYmFja3dhcmQgY29tcGF0aWJpbGl0eVxuZXhwb3J0IGNvbnN0IENvbmZpZyA9IHtcbiAgY3JlYXRlOiAoY29uZmlnOiBMZXhDb25maWdUeXBlKSA9PiBjb25maWdcbn07XG5cbi8vIEV4cG9ydCB1dGlsaXR5IGZ1bmN0aW9uc1xuZXhwb3J0ICogZnJvbSAnLi91dGlscy9haVNlcnZpY2UuanMnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscy9hcHAuanMnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscy9maWxlLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vdXRpbHMvbG9nLmpzJztcblxuLy8gRXhwb3J0IFN0b3J5Ym9vayBtb2R1bGVcbmV4cG9ydCAqIGZyb20gJy4vc3Rvcnlib29rL2luZGV4LmpzJztcblxuLy8gRXhwb3J0IGNvbW1hbmRzXG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2FpL2FpLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vY29tbWFuZHMvYnVpbGQvYnVpbGQuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tYW5kcy9jbGVhbi9jbGVhbi5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2NvbXBpbGUvY29tcGlsZS5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2NvbmZpZy9jb25maWcuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tYW5kcy9jb3B5L2NvcHkuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tYW5kcy9jcmVhdGUvY3JlYXRlLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vY29tbWFuZHMvZGV2L2Rldi5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2luaXQvaW5pdC5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2xpbmsvbGluay5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2xpbnQvbGludC5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL21pZ3JhdGUvbWlncmF0ZS5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL3B1Ymxpc2gvcHVibGlzaC5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL3NlcnZlcmxlc3Mvc2VydmVybGVzcy5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL3N0b3J5Ym9vay9zdG9yeWJvb2suanMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tYW5kcy90ZXN0L3Rlc3QuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tYW5kcy91cGRhdGUvdXBkYXRlLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vY29tbWFuZHMvdXBncmFkZS91cGdyYWRlLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vY29tbWFuZHMvdmVyc2lvbnMvdmVyc2lvbnMuanMnO1xuIl0sIm5hbWVzIjpbImRlZmF1bHRDb25maWdWYWx1ZXMiLCJMZXhDb25maWciLCJDb25maWciLCJjcmVhdGUiLCJjb25maWciXSwibWFwcGluZ3MiOiJBQUFBOzs7Q0FHQyxHQUlELDZCQUE2QjtBQUM3QixjQUFjLGFBQWE7QUFFM0IsMkNBQTJDO0FBQzNDLFNBQ0VBLG1CQUFtQixFQUFFQyxTQUFTLFFBQ3pCLGlCQUFpQjtBQUV4Qiw2RkFBNkY7QUFDN0YsT0FBTyxNQUFNQyxTQUFTO0lBQ3BCQyxRQUFRLENBQUNDLFNBQTBCQTtBQUNyQyxFQUFFO0FBRUYsMkJBQTJCO0FBQzNCLGNBQWMsdUJBQXVCO0FBQ3JDLGNBQWMsaUJBQWlCO0FBQy9CLGNBQWMsa0JBQWtCO0FBQ2hDLGNBQWMsaUJBQWlCO0FBRS9CLDBCQUEwQjtBQUMxQixjQUFjLHVCQUF1QjtBQUVyQyxrQkFBa0I7QUFDbEIsY0FBYyxzQkFBc0I7QUFDcEMsY0FBYyw0QkFBNEI7QUFDMUMsY0FBYyw0QkFBNEI7QUFDMUMsY0FBYyxnQ0FBZ0M7QUFDOUMsY0FBYyw4QkFBOEI7QUFDNUMsY0FBYywwQkFBMEI7QUFDeEMsY0FBYyw4QkFBOEI7QUFDNUMsY0FBYyx3QkFBd0I7QUFDdEMsY0FBYywwQkFBMEI7QUFDeEMsY0FBYywwQkFBMEI7QUFDeEMsY0FBYywwQkFBMEI7QUFDeEMsY0FBYyxnQ0FBZ0M7QUFDOUMsY0FBYyxnQ0FBZ0M7QUFDOUMsY0FBYyxzQ0FBc0M7QUFDcEQsY0FBYyxvQ0FBb0M7QUFDbEQsY0FBYywwQkFBMEI7QUFDeEMsY0FBYyw4QkFBOEI7QUFDNUMsY0FBYyxnQ0FBZ0M7QUFDOUMsY0FBYyxrQ0FBa0MifQ==
@@ -3,7 +3,6 @@
3
3
  * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
4
4
  */
5
5
  import type { LexConfigType } from '../LexConfig.js';
6
- export declare const cwd: string;
7
6
  export interface GetFilenamesProps {
8
7
  readonly callback?: (status: number) => void;
9
8
  readonly cliName?: string;
package/lib/utils/app.js CHANGED
@@ -10,7 +10,6 @@ import ora from 'ora';
10
10
  import { basename as pathBasename, join as pathJoin, relative as pathRelative, resolve as pathResolve } from 'path';
11
11
  import { rimrafSync } from 'rimraf';
12
12
  import { log } from './log.js';
13
- export const cwd = process.cwd();
14
13
  export const getFilenames = (props)=>{
15
14
  const { callback, cliName, name, quiet, type, useTypescript } = props;
16
15
  let nameCaps;
@@ -120,7 +119,7 @@ export const copyConfiguredFiles = async (spinner, config, quiet)=>{
120
119
  try {
121
120
  spinner.start('Copying configured files...');
122
121
  let totalCopied = 0;
123
- const baseDir = sourceFullPath || (sourcePath ? pathResolve(cwd, sourcePath) : cwd);
122
+ const baseDir = sourceFullPath || (sourcePath ? pathResolve(process.cwd(), sourcePath) : process.cwd());
124
123
  const allCopyPromises = [];
125
124
  for (const pattern of copyFilesConfig){
126
125
  const resolvedPattern = pathResolve(baseDir, pattern);
@@ -219,7 +218,7 @@ export const removeConflictModules = (moduleList)=>{
219
218
  return updatedList;
220
219
  };
221
220
  export const removeFiles = (fileName, isRelative = false)=>new Promise((resolve, reject)=>{
222
- const filePath = isRelative ? pathResolve(cwd, fileName) : fileName;
221
+ const filePath = isRelative ? pathResolve(process.cwd(), fileName) : fileName;
223
222
  try {
224
223
  rimrafSync(filePath);
225
224
  return resolve(null);
@@ -299,4 +298,4 @@ export const updateTemplateName = (filePath, replace, replaceCaps)=>{
299
298
  writeFileSync(filePath, data, 'utf8');
300
299
  };
301
300
 
302
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utils/app.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 */\n\nimport boxen from 'boxen';\nimport chalk from 'chalk';\nimport {copyFile, existsSync, lstatSync, mkdirSync, readdirSync, readFileSync, writeFileSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport isEmpty from 'lodash/isEmpty.js';\nimport ora from 'ora';\nimport {basename as pathBasename, join as pathJoin, relative as pathRelative, resolve as pathResolve} from 'path';\nimport {rimrafSync} from 'rimraf';\n\n\nimport {log} from './log.js';\n\nimport type {LexConfigType} from '../LexConfig.js';\n\n\nexport const cwd: string = process.cwd();\n\nexport interface GetFilenamesProps {\n  readonly callback?: (status: number)=> void;\n  readonly cliName?: string;\n  readonly name?: string;\n  readonly quiet?: boolean;\n  readonly type?: string;\n  readonly useTypescript?: boolean;\n}\n\ninterface FilenamesResult {\n  nameCaps: string;\n  templateExt: string;\n  templatePath: string;\n  templateReact: string;\n}\n\nexport const getFilenames = (props: GetFilenamesProps): FilenamesResult | undefined => {\n  const {callback, cliName, name, quiet, type, useTypescript} = props;\n\n  let nameCaps: string;\n  const itemTypes: string[] = ['stores', 'views'];\n\n  if(!name) {\n    if(itemTypes.includes(type)) {\n      log(`\\n${cliName} Error: ${type} name is required. Please use 'lex -h' for options.`, 'error', quiet);\n      callback?.(1);\n      return undefined;\n    }\n  } else {\n    nameCaps = `${name.charAt(0).toUpperCase()}${name.substr(1)}`;\n  }\n\n  log(`${cliName} adding ${name} ${type}...`, 'info', quiet);\n\n  let templatePath: string;\n  let templateExt: string;\n  let templateReact: string;\n\n  if(useTypescript) {\n    templatePath = '../../templates/typescript';\n    templateExt = '.ts';\n    templateReact = '.tsx';\n  } else {\n    templatePath = '../../templates/flow';\n    templateExt = '.js';\n    templateReact = '.js';\n  }\n\n  return {\n    nameCaps,\n    templateExt,\n    templatePath,\n    templateReact\n  };\n};\n\nexport interface Spinner {\n  fail: (text?: string)=> void;\n  start: (text?: string)=> void;\n  succeed: (text?: string)=> void;\n  text?: string;\n}\n\nexport const createSpinner = (quiet = false): Spinner => {\n  if(quiet) {\n    return {\n      fail: () => {},\n      start: () => {},\n      succeed: () => {}\n    };\n  }\n\n  return ora({color: 'yellow'});\n};\n\nexport const createProgressBar = (percentage: number): string => {\n  const width = 20;\n  const filled = Math.round((percentage / 100) * width);\n  const empty = width - filled;\n\n  const filledBar = chalk.cyan('█').repeat(filled);\n  const emptyBar = chalk.gray('░').repeat(empty);\n\n  return filledBar + emptyBar;\n};\n\nexport const handleWebpackProgress = (\n  output: string,\n  spinner: Spinner,\n  quiet: boolean,\n  emoji: string,\n  action: string\n): void => {\n  if(quiet) {\n    return;\n  }\n\n  const progressMatch = output.match(/\\[webpack\\.Progress\\] (\\d+)%/);\n  if(progressMatch) {\n    const progress = parseInt(progressMatch[1]);\n    const progressBar = createProgressBar(progress);\n    spinner.text = `${emoji} ${action}: ${progressBar} ${progress}%`;\n  } else if(output.includes('[webpack.Progress]')) {\n    const generalProgressMatch = output.match(/(\\d+)%/);\n    if(generalProgressMatch) {\n      const progress = parseInt(generalProgressMatch[1]);\n      const progressBar = createProgressBar(progress);\n      spinner.text = `${emoji} ${action}: ${progressBar} ${progress}%`;\n    }\n  }\n};\n\nexport const copyFiles = async (files: string[], typeName: string, spinner, config: LexConfigType) => {\n  const {outputFullPath, sourceFullPath} = config;\n  const items = files.map((fileName: string) => ({\n    from: fileName,\n    to: pathResolve(outputFullPath, pathRelative(sourceFullPath, fileName))\n  }));\n\n  try {\n    spinner.start(`Copying ${typeName} files...`);\n    await Promise.all(items.map(({from, to}) => new Promise(\n      (resolve, reject) => {\n        mkdirSync(pathResolve(to, '..'), {recursive: true});\n        return copyFile(from, to, (copyError) => {\n          if(copyError) {\n            reject();\n          } else {\n            resolve(true);\n          }\n        });\n      }\n    )));\n    spinner.succeed(`Successfully copied ${files.length} ${typeName} files!`);\n  } catch(error) {\n    spinner.fail(`Copying of ${typeName} files failed.`);\n    log(`Error: ${error.message}`, 'error');\n    log(error, 'error');\n  }\n};\n\nexport const copyConfiguredFiles = async (spinner, config: LexConfigType, quiet: boolean) => {\n  const {copyFiles: copyFilesConfig, outputFullPath, sourceFullPath, sourcePath} = config;\n  if(!copyFilesConfig || copyFilesConfig.length === 0) {\n    return;\n  }\n\n  try {\n    spinner.start('Copying configured files...');\n    let totalCopied = 0;\n\n    const baseDir = sourceFullPath || (sourcePath ? pathResolve(cwd, sourcePath) : cwd);\n    const allCopyPromises: Promise<unknown>[] = [];\n\n    for(const pattern of copyFilesConfig) {\n      const resolvedPattern = pathResolve(baseDir, pattern);\n      const matchingFiles = globSync(resolvedPattern, {\n        absolute: true,\n        nodir: true\n      });\n\n      if(matchingFiles.length === 0) {\n        if(!quiet) {\n          log(`Warning: No files found matching pattern: ${pattern}`, 'warn', quiet);\n        }\n        continue;\n      }\n\n      const copyPromises = matchingFiles.map((sourceFile) => {\n        const relativePath = pathRelative(baseDir, sourceFile);\n        const destPath = pathResolve(outputFullPath, relativePath);\n        const destDir = pathResolve(destPath, '..');\n        mkdirSync(destDir, {recursive: true});\n\n        return new Promise((resolve, reject) => {\n          copyFile(sourceFile, destPath, (copyError) => {\n            if(copyError) {\n              reject(copyError);\n            } else {\n              resolve(true);\n            }\n          });\n        });\n      });\n\n      allCopyPromises.push(...copyPromises);\n      totalCopied += matchingFiles.length;\n    }\n\n    await Promise.all(allCopyPromises);\n\n    if(totalCopied > 0) {\n      spinner.succeed(`Successfully copied ${totalCopied} configured files!`);\n    } else {\n      spinner.succeed('No configured files to copy');\n    }\n  } catch(error) {\n    spinner.fail('Failed to copy configured files');\n    log(`Error copying configured files: ${error.message}`, 'error', quiet);\n    throw error;\n  }\n};\n\nexport const copyFileSync = (source: string, target: string) => {\n  let targetFile: string = target;\n\n  if(existsSync(target)) {\n    if(lstatSync(target).isDirectory()) {\n      targetFile = pathJoin(target, pathBasename(source));\n    }\n  }\n\n  writeFileSync(targetFile, readFileSync(source));\n};\n\nexport const copyFolderRecursiveSync = (source: string, target: string): void => {\n  let files: string[] = [];\n\n  const targetFolder: string = pathJoin(target, pathBasename(source));\n\n  if(!existsSync(targetFolder)) {\n    mkdirSync(targetFolder);\n  }\n\n  if(lstatSync(source).isDirectory()) {\n    files = readdirSync(source);\n    files.forEach((file: string) => {\n      const curSource: string = pathJoin(source, file);\n\n      if(lstatSync(curSource).isDirectory()) {\n        copyFolderRecursiveSync(curSource, targetFolder);\n      } else {\n        copyFileSync(curSource, targetFolder);\n      }\n    });\n  }\n};\n\nexport const getPackageJson = (packagePath?: string) => {\n  const formatPath: string = packagePath || `${process.cwd()}/package.json`;\n  const packageData: string = readFileSync(formatPath).toString();\n\n  return JSON.parse(packageData);\n};\n\nexport const getFilesByExt = (ext: string, config: LexConfigType): string[] => {\n  const {sourceFullPath} = config;\n  return globSync(`**/**${ext}`, {\n    absolute: true,\n    cwd: sourceFullPath,\n    nodir: true\n  });\n};\n\nexport const removeConflictModules = (moduleList: object) => {\n  const updatedList: object = {...moduleList};\n\n  Object.keys(updatedList).forEach((moduleName: string) => {\n    const regex: RegExp = new RegExp('^(?!@types/).*?(jest|webpack).*$', 'gi');\n    if(regex.test(moduleName)) {\n      delete updatedList[moduleName];\n    }\n  });\n\n  return updatedList;\n};\n\nexport const removeFiles = (fileName: string, isRelative: boolean = false) => new Promise((resolve, reject) => {\n  const filePath: string = isRelative ? pathResolve(cwd, fileName) : fileName;\n\n  try {\n    rimrafSync(filePath);\n    return resolve(null);\n  } catch(error) {\n    return reject(error);\n  }\n});\n\nexport const removeModules = () => new Promise(async (resolve, reject) => {\n  try {\n    await removeFiles('./node_modules', true);\n    await removeFiles('./yarn.lock', true);\n    await removeFiles('./package-lock.json', true);\n\n    resolve(null);\n  } catch(error) {\n    reject(error);\n  }\n});\n\nexport const setPackageJson = (json, packagePath?: string) => {\n  if(!json) {\n    return;\n  }\n\n  const formatPath: string = packagePath || `${process.cwd()}/package.json`;\n\n  writeFileSync(formatPath, JSON.stringify(json, null, 2));\n};\n\nexport interface LinkedModuleType {\n  readonly name: string;\n  readonly path: string;\n}\n\nexport const linkedModules = (startPath?: string): LinkedModuleType[] => {\n  const workingPath: string = startPath || process.cwd();\n  let modulePath: string;\n  let prefix: string;\n\n  if(workingPath.includes('@')) {\n    prefix = `@${workingPath.split('@').pop()}`;\n    modulePath = workingPath;\n  } else {\n    modulePath = pathJoin(workingPath, 'node_modules');\n  }\n\n  const foundPaths: string[] = globSync('*', {\n    absolute: true,\n    cwd: modulePath,\n    nodir: false\n  });\n\n  return foundPaths.reduce((list: LinkedModuleType[], foundPath: string) => {\n    try {\n      const stats = lstatSync(foundPath);\n\n      if(stats.isDirectory()) {\n        const deepList: LinkedModuleType[] = linkedModules(foundPath);\n        list.push(...deepList);\n      } else if(stats.isSymbolicLink()) {\n        const moduleNames: string[] = ([prefix, pathBasename(foundPath)]).filter((item: string) => !isEmpty(item));\n        list.push({name: `${moduleNames.join('/')}`, path: foundPath});\n      }\n\n      return list;\n    } catch{\n      return list;\n    }\n  }, []);\n};\n\nexport const checkLinkedModules = () => {\n  const linked = linkedModules();\n\n  if(linked.length) {\n    const msgModule: string = linked.length > 1 ? 'Modules' : 'Module';\n    const linkedMsg: string = linked.reduce(\n      (msg: string, linkedModule: LinkedModuleType) =>\n        `${msg}\\n * ${linkedModule.name}`,\n      `Linked ${msgModule}:`\n    );\n\n    log(boxen(linkedMsg, {dimBorder: true, padding: 1}), 'warn');\n  }\n};\n\nexport const updateTemplateName = (filePath: string, replace: string, replaceCaps: string) => {\n  let data: string = readFileSync(filePath, 'utf8');\n  data = data.replace(/sample/g, replace);\n  data = data.replace(/Sample/g, replaceCaps);\n  writeFileSync(filePath, data, 'utf8');\n};"],"names":["boxen","chalk","copyFile","existsSync","lstatSync","mkdirSync","readdirSync","readFileSync","writeFileSync","sync","globSync","isEmpty","ora","basename","pathBasename","join","pathJoin","relative","pathRelative","resolve","pathResolve","rimrafSync","log","cwd","process","getFilenames","props","callback","cliName","name","quiet","type","useTypescript","nameCaps","itemTypes","includes","undefined","charAt","toUpperCase","substr","templatePath","templateExt","templateReact","createSpinner","fail","start","succeed","color","createProgressBar","percentage","width","filled","Math","round","empty","filledBar","cyan","repeat","emptyBar","gray","handleWebpackProgress","output","spinner","emoji","action","progressMatch","match","progress","parseInt","progressBar","text","generalProgressMatch","copyFiles","files","typeName","config","outputFullPath","sourceFullPath","items","map","fileName","from","to","Promise","all","reject","recursive","copyError","length","error","message","copyConfiguredFiles","copyFilesConfig","sourcePath","totalCopied","baseDir","allCopyPromises","pattern","resolvedPattern","matchingFiles","absolute","nodir","copyPromises","sourceFile","relativePath","destPath","destDir","push","copyFileSync","source","target","targetFile","isDirectory","copyFolderRecursiveSync","targetFolder","forEach","file","curSource","getPackageJson","packagePath","formatPath","packageData","toString","JSON","parse","getFilesByExt","ext","removeConflictModules","moduleList","updatedList","Object","keys","moduleName","regex","RegExp","test","removeFiles","isRelative","filePath","removeModules","setPackageJson","json","stringify","linkedModules","startPath","workingPath","modulePath","prefix","split","pop","foundPaths","reduce","list","foundPath","stats","deepList","isSymbolicLink","moduleNames","filter","item","path","checkLinkedModules","linked","msgModule","linkedMsg","msg","linkedModule","dimBorder","padding","updateTemplateName","replace","replaceCaps","data"],"mappings":"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"}
301
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utils/app.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 */\n\nimport boxen from 'boxen';\nimport chalk from 'chalk';\nimport {copyFile, existsSync, lstatSync, mkdirSync, readdirSync, readFileSync, writeFileSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport isEmpty from 'lodash/isEmpty.js';\nimport ora from 'ora';\nimport {basename as pathBasename, join as pathJoin, relative as pathRelative, resolve as pathResolve} from 'path';\nimport {rimrafSync} from 'rimraf';\n\n\nimport {log} from './log.js';\n\nimport type {LexConfigType} from '../LexConfig.js';\n\n\nexport interface GetFilenamesProps {\n  readonly callback?: (status: number)=> void;\n  readonly cliName?: string;\n  readonly name?: string;\n  readonly quiet?: boolean;\n  readonly type?: string;\n  readonly useTypescript?: boolean;\n}\n\ninterface FilenamesResult {\n  nameCaps: string;\n  templateExt: string;\n  templatePath: string;\n  templateReact: string;\n}\n\nexport const getFilenames = (props: GetFilenamesProps): FilenamesResult | undefined => {\n  const {callback, cliName, name, quiet, type, useTypescript} = props;\n\n  let nameCaps: string;\n  const itemTypes: string[] = ['stores', 'views'];\n\n  if(!name) {\n    if(itemTypes.includes(type)) {\n      log(`\\n${cliName} Error: ${type} name is required. Please use 'lex -h' for options.`, 'error', quiet);\n      callback?.(1);\n      return undefined;\n    }\n  } else {\n    nameCaps = `${name.charAt(0).toUpperCase()}${name.substr(1)}`;\n  }\n\n  log(`${cliName} adding ${name} ${type}...`, 'info', quiet);\n\n  let templatePath: string;\n  let templateExt: string;\n  let templateReact: string;\n\n  if(useTypescript) {\n    templatePath = '../../templates/typescript';\n    templateExt = '.ts';\n    templateReact = '.tsx';\n  } else {\n    templatePath = '../../templates/flow';\n    templateExt = '.js';\n    templateReact = '.js';\n  }\n\n  return {\n    nameCaps,\n    templateExt,\n    templatePath,\n    templateReact\n  };\n};\n\nexport interface Spinner {\n  fail: (text?: string)=> void;\n  start: (text?: string)=> void;\n  succeed: (text?: string)=> void;\n  text?: string;\n}\n\nexport const createSpinner = (quiet = false): Spinner => {\n  if(quiet) {\n    return {\n      fail: () => {},\n      start: () => {},\n      succeed: () => {}\n    };\n  }\n\n  return ora({color: 'yellow'});\n};\n\nexport const createProgressBar = (percentage: number): string => {\n  const width = 20;\n  const filled = Math.round((percentage / 100) * width);\n  const empty = width - filled;\n\n  const filledBar = chalk.cyan('█').repeat(filled);\n  const emptyBar = chalk.gray('░').repeat(empty);\n\n  return filledBar + emptyBar;\n};\n\nexport const handleWebpackProgress = (\n  output: string,\n  spinner: Spinner,\n  quiet: boolean,\n  emoji: string,\n  action: string\n): void => {\n  if(quiet) {\n    return;\n  }\n\n  const progressMatch = output.match(/\\[webpack\\.Progress\\] (\\d+)%/);\n  if(progressMatch) {\n    const progress = parseInt(progressMatch[1]);\n    const progressBar = createProgressBar(progress);\n    spinner.text = `${emoji} ${action}: ${progressBar} ${progress}%`;\n  } else if(output.includes('[webpack.Progress]')) {\n    const generalProgressMatch = output.match(/(\\d+)%/);\n    if(generalProgressMatch) {\n      const progress = parseInt(generalProgressMatch[1]);\n      const progressBar = createProgressBar(progress);\n      spinner.text = `${emoji} ${action}: ${progressBar} ${progress}%`;\n    }\n  }\n};\n\nexport const copyFiles = async (files: string[], typeName: string, spinner, config: LexConfigType) => {\n  const {outputFullPath, sourceFullPath} = config;\n  const items = files.map((fileName: string) => ({\n    from: fileName,\n    to: pathResolve(outputFullPath, pathRelative(sourceFullPath, fileName))\n  }));\n\n  try {\n    spinner.start(`Copying ${typeName} files...`);\n    await Promise.all(items.map(({from, to}) => new Promise(\n      (resolve, reject) => {\n        mkdirSync(pathResolve(to, '..'), {recursive: true});\n        return copyFile(from, to, (copyError) => {\n          if(copyError) {\n            reject();\n          } else {\n            resolve(true);\n          }\n        });\n      }\n    )));\n    spinner.succeed(`Successfully copied ${files.length} ${typeName} files!`);\n  } catch(error) {\n    spinner.fail(`Copying of ${typeName} files failed.`);\n    log(`Error: ${error.message}`, 'error');\n    log(error, 'error');\n  }\n};\n\nexport const copyConfiguredFiles = async (spinner, config: LexConfigType, quiet: boolean) => {\n  const {copyFiles: copyFilesConfig, outputFullPath, sourceFullPath, sourcePath} = config;\n  if(!copyFilesConfig || copyFilesConfig.length === 0) {\n    return;\n  }\n\n  try {\n    spinner.start('Copying configured files...');\n    let totalCopied = 0;\n\n    const baseDir = sourceFullPath || (sourcePath ? pathResolve(process.cwd(), sourcePath) : process.cwd());\n    const allCopyPromises: Promise<unknown>[] = [];\n\n    for(const pattern of copyFilesConfig) {\n      const resolvedPattern = pathResolve(baseDir, pattern);\n      const matchingFiles = globSync(resolvedPattern, {\n        absolute: true,\n        nodir: true\n      });\n\n      if(matchingFiles.length === 0) {\n        if(!quiet) {\n          log(`Warning: No files found matching pattern: ${pattern}`, 'warn', quiet);\n        }\n        continue;\n      }\n\n      const copyPromises = matchingFiles.map((sourceFile) => {\n        const relativePath = pathRelative(baseDir, sourceFile);\n        const destPath = pathResolve(outputFullPath, relativePath);\n        const destDir = pathResolve(destPath, '..');\n        mkdirSync(destDir, {recursive: true});\n\n        return new Promise((resolve, reject) => {\n          copyFile(sourceFile, destPath, (copyError) => {\n            if(copyError) {\n              reject(copyError);\n            } else {\n              resolve(true);\n            }\n          });\n        });\n      });\n\n      allCopyPromises.push(...copyPromises);\n      totalCopied += matchingFiles.length;\n    }\n\n    await Promise.all(allCopyPromises);\n\n    if(totalCopied > 0) {\n      spinner.succeed(`Successfully copied ${totalCopied} configured files!`);\n    } else {\n      spinner.succeed('No configured files to copy');\n    }\n  } catch(error) {\n    spinner.fail('Failed to copy configured files');\n    log(`Error copying configured files: ${error.message}`, 'error', quiet);\n    throw error;\n  }\n};\n\nexport const copyFileSync = (source: string, target: string) => {\n  let targetFile: string = target;\n\n  if(existsSync(target)) {\n    if(lstatSync(target).isDirectory()) {\n      targetFile = pathJoin(target, pathBasename(source));\n    }\n  }\n\n  writeFileSync(targetFile, readFileSync(source));\n};\n\nexport const copyFolderRecursiveSync = (source: string, target: string): void => {\n  let files: string[] = [];\n\n  const targetFolder: string = pathJoin(target, pathBasename(source));\n\n  if(!existsSync(targetFolder)) {\n    mkdirSync(targetFolder);\n  }\n\n  if(lstatSync(source).isDirectory()) {\n    files = readdirSync(source);\n    files.forEach((file: string) => {\n      const curSource: string = pathJoin(source, file);\n\n      if(lstatSync(curSource).isDirectory()) {\n        copyFolderRecursiveSync(curSource, targetFolder);\n      } else {\n        copyFileSync(curSource, targetFolder);\n      }\n    });\n  }\n};\n\nexport const getPackageJson = (packagePath?: string) => {\n  const formatPath: string = packagePath || `${process.cwd()}/package.json`;\n  const packageData: string = readFileSync(formatPath).toString();\n\n  return JSON.parse(packageData);\n};\n\nexport const getFilesByExt = (ext: string, config: LexConfigType): string[] => {\n  const {sourceFullPath} = config;\n  return globSync(`**/**${ext}`, {\n    absolute: true,\n    cwd: sourceFullPath,\n    nodir: true\n  });\n};\n\nexport const removeConflictModules = (moduleList: object) => {\n  const updatedList: object = {...moduleList};\n\n  Object.keys(updatedList).forEach((moduleName: string) => {\n    const regex: RegExp = new RegExp('^(?!@types/).*?(jest|webpack).*$', 'gi');\n    if(regex.test(moduleName)) {\n      delete updatedList[moduleName];\n    }\n  });\n\n  return updatedList;\n};\n\nexport const removeFiles = (fileName: string, isRelative: boolean = false) => new Promise((resolve, reject) => {\n  const filePath: string = isRelative ? pathResolve(process.cwd(), fileName) : fileName;\n\n  try {\n    rimrafSync(filePath);\n    return resolve(null);\n  } catch(error) {\n    return reject(error);\n  }\n});\n\nexport const removeModules = () => new Promise(async (resolve, reject) => {\n  try {\n    await removeFiles('./node_modules', true);\n    await removeFiles('./yarn.lock', true);\n    await removeFiles('./package-lock.json', true);\n\n    resolve(null);\n  } catch(error) {\n    reject(error);\n  }\n});\n\nexport const setPackageJson = (json, packagePath?: string) => {\n  if(!json) {\n    return;\n  }\n\n  const formatPath: string = packagePath || `${process.cwd()}/package.json`;\n\n  writeFileSync(formatPath, JSON.stringify(json, null, 2));\n};\n\nexport interface LinkedModuleType {\n  readonly name: string;\n  readonly path: string;\n}\n\nexport const linkedModules = (startPath?: string): LinkedModuleType[] => {\n  const workingPath: string = startPath || process.cwd();\n  let modulePath: string;\n  let prefix: string;\n\n  if(workingPath.includes('@')) {\n    prefix = `@${workingPath.split('@').pop()}`;\n    modulePath = workingPath;\n  } else {\n    modulePath = pathJoin(workingPath, 'node_modules');\n  }\n\n  const foundPaths: string[] = globSync('*', {\n    absolute: true,\n    cwd: modulePath,\n    nodir: false\n  });\n\n  return foundPaths.reduce((list: LinkedModuleType[], foundPath: string) => {\n    try {\n      const stats = lstatSync(foundPath);\n\n      if(stats.isDirectory()) {\n        const deepList: LinkedModuleType[] = linkedModules(foundPath);\n        list.push(...deepList);\n      } else if(stats.isSymbolicLink()) {\n        const moduleNames: string[] = ([prefix, pathBasename(foundPath)]).filter((item: string) => !isEmpty(item));\n        list.push({name: `${moduleNames.join('/')}`, path: foundPath});\n      }\n\n      return list;\n    } catch{\n      return list;\n    }\n  }, []);\n};\n\nexport const checkLinkedModules = () => {\n  const linked = linkedModules();\n\n  if(linked.length) {\n    const msgModule: string = linked.length > 1 ? 'Modules' : 'Module';\n    const linkedMsg: string = linked.reduce(\n      (msg: string, linkedModule: LinkedModuleType) =>\n        `${msg}\\n * ${linkedModule.name}`,\n      `Linked ${msgModule}:`\n    );\n\n    log(boxen(linkedMsg, {dimBorder: true, padding: 1}), 'warn');\n  }\n};\n\nexport const updateTemplateName = (filePath: string, replace: string, replaceCaps: string) => {\n  let data: string = readFileSync(filePath, 'utf8');\n  data = data.replace(/sample/g, replace);\n  data = data.replace(/Sample/g, replaceCaps);\n  writeFileSync(filePath, data, 'utf8');\n};"],"names":["boxen","chalk","copyFile","existsSync","lstatSync","mkdirSync","readdirSync","readFileSync","writeFileSync","sync","globSync","isEmpty","ora","basename","pathBasename","join","pathJoin","relative","pathRelative","resolve","pathResolve","rimrafSync","log","getFilenames","props","callback","cliName","name","quiet","type","useTypescript","nameCaps","itemTypes","includes","undefined","charAt","toUpperCase","substr","templatePath","templateExt","templateReact","createSpinner","fail","start","succeed","color","createProgressBar","percentage","width","filled","Math","round","empty","filledBar","cyan","repeat","emptyBar","gray","handleWebpackProgress","output","spinner","emoji","action","progressMatch","match","progress","parseInt","progressBar","text","generalProgressMatch","copyFiles","files","typeName","config","outputFullPath","sourceFullPath","items","map","fileName","from","to","Promise","all","reject","recursive","copyError","length","error","message","copyConfiguredFiles","copyFilesConfig","sourcePath","totalCopied","baseDir","process","cwd","allCopyPromises","pattern","resolvedPattern","matchingFiles","absolute","nodir","copyPromises","sourceFile","relativePath","destPath","destDir","push","copyFileSync","source","target","targetFile","isDirectory","copyFolderRecursiveSync","targetFolder","forEach","file","curSource","getPackageJson","packagePath","formatPath","packageData","toString","JSON","parse","getFilesByExt","ext","removeConflictModules","moduleList","updatedList","Object","keys","moduleName","regex","RegExp","test","removeFiles","isRelative","filePath","removeModules","setPackageJson","json","stringify","linkedModules","startPath","workingPath","modulePath","prefix","split","pop","foundPaths","reduce","list","foundPath","stats","deepList","isSymbolicLink","moduleNames","filter","item","path","checkLinkedModules","linked","msgModule","linkedMsg","msg","linkedModule","dimBorder","padding","updateTemplateName","replace","replaceCaps","data"],"mappings":"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"}
@@ -1,9 +1,6 @@
1
1
  export declare const getDirName: () => string;
2
- export declare const getFilePath: (relativePath: string) => string;
3
2
  export declare const getLexPackageJsonPath: () => string;
4
3
  export declare const relativeFilePath: (filename: string, dirPath?: string, backUp?: number) => string;
5
- export declare const relativeNodePath: (filename: string, dirPath?: string, backUp?: number) => string;
6
- export declare const getNodePath: (moduleName: string) => string;
7
4
  export declare const resolveBinaryPath: (binaryName: string, packageName?: string) => string;
8
5
  export declare const findTailwindCssPath: () => string;
9
6
  export declare const resolveWebpackPaths: (currentDirname: string) => {
package/lib/utils/file.js CHANGED
@@ -13,16 +13,6 @@ export const getDirName = ()=>{
13
13
  return process.cwd();
14
14
  }
15
15
  };
16
- export const getFilePath = (relativePath)=>{
17
- try {
18
- return eval('require("url").fileURLToPath(new URL(relativePath, import.meta.url))');
19
- } catch {
20
- if (relativePath === '../../../package.json') {
21
- return pathResolve(process.cwd(), 'package.json');
22
- }
23
- return pathResolve(process.cwd(), relativePath);
24
- }
25
- };
26
16
  export const getLexPackageJsonPath = ()=>{
27
17
  const LEX_PACKAGE_NAME = '@nlabs/lex';
28
18
  const lexInNodeModules = pathResolve(process.cwd(), 'node_modules/@nlabs/lex/package.json');
@@ -82,40 +72,6 @@ export const relativeFilePath = (filename, dirPath = './', backUp = 0)=>{
82
72
  }
83
73
  return findFileUp.sync(filename, dirPath, nestDepth);
84
74
  };
85
- export const relativeNodePath = (filename, dirPath = './', backUp = 0)=>{
86
- const nestDepth = 10;
87
- const modulePath = `node_modules/${filename}`;
88
- if (dirPath !== './') {
89
- const lexModulePath = pathResolve(dirPath, modulePath);
90
- if (existsSync(lexModulePath)) {
91
- return lexModulePath;
92
- }
93
- }
94
- const projectPath = pathResolve(process.cwd(), modulePath);
95
- if (existsSync(projectPath)) {
96
- return projectPath;
97
- }
98
- if (backUp) {
99
- const filePath = findFileUp.sync(modulePath, dirPath, nestDepth);
100
- const previousPath = Array(nestDepth).fill(null).map(()=>'../').join('');
101
- return pathResolve(filePath, previousPath);
102
- }
103
- return findFileUp.sync(modulePath, dirPath, nestDepth) || `/node_modules/${filename}`;
104
- };
105
- export const getNodePath = (moduleName)=>{
106
- const dirName = getDirName();
107
- const modulePath = `node_modules/${moduleName}`;
108
- const projectPath = pathResolve(process.cwd(), modulePath);
109
- if (existsSync(projectPath)) {
110
- return projectPath;
111
- }
112
- const repoPath = findFileUp.sync(modulePath, dirName);
113
- if (repoPath && existsSync(repoPath)) {
114
- return repoPath;
115
- }
116
- const localPath = findFileUp.sync(modulePath, './', 10) || `./${modulePath}`;
117
- return localPath;
118
- };
119
75
  export const resolveBinaryPath = (binaryName, packageName)=>{
120
76
  const lexDir = LexConfig.getLexDir();
121
77
  const lexBinPath = pathResolve(lexDir, `node_modules/.bin/${binaryName}`);
@@ -250,4 +206,4 @@ export const resolveWebpackPaths = (currentDirname)=>{
250
206
  };
251
207
  };
252
208
 
253
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utils/file.ts"],"sourcesContent":["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport findFileUp from 'find-file-up';\nimport {existsSync, readFileSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport {resolve as pathResolve, dirname} from 'path';\n\nimport {LexConfig} from '../LexConfig.js';\n\nexport const getDirName = (): string => {\n  try {\n    return eval('new URL(\".\", import.meta.url).pathname');\n  } catch{\n    return process.cwd();\n  }\n};\n\nexport const getFilePath = (relativePath: string): string => {\n  try {\n    return eval('require(\"url\").fileURLToPath(new URL(relativePath, import.meta.url))');\n  } catch{\n    if(relativePath === '../../../package.json') {\n      return pathResolve(process.cwd(), 'package.json');\n    }\n    return pathResolve(process.cwd(), relativePath);\n  }\n};\n\nexport const getLexPackageJsonPath = (): string => {\n  const LEX_PACKAGE_NAME = '@nlabs/lex';\n\n  const lexInNodeModules = pathResolve(process.cwd(), 'node_modules/@nlabs/lex/package.json');\n\n  if(existsSync(lexInNodeModules)) {\n    return lexInNodeModules;\n  }\n\n  let startDir: string;\n\n  if(process.env.LEX_ROOT) {\n    startDir = process.env.LEX_ROOT;\n  } else {\n    try {\n      startDir = eval('new URL(\".\", import.meta.url).pathname');\n    } catch{\n      try {\n        startDir = eval('__filename ? require(\"path\").dirname(__filename) : null');\n        if(!startDir) {\n          throw new Error('__filename not available');\n        }\n      } catch{\n        try {\n          if(process.argv[1] && !process.argv[1].includes('node')) {\n            startDir = dirname(process.argv[1]);\n          } else {\n            throw new Error('process.argv[1] not suitable');\n          }\n        } catch{\n          startDir = process.cwd();\n        }\n      }\n    }\n  }\n\n  let dir = startDir;\n  for(let i = 0; i < 8; i++) {\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 === LEX_PACKAGE_NAME) {\n          return pkgPath;\n        }\n      } catch{\n      }\n    }\n    const parent = dirname(dir);\n    if(parent === dir) {\n      break;\n    }\n    dir = parent;\n  }\n\n  return pathResolve(process.cwd(), 'package.json');\n};\n\nexport const relativeFilePath = (filename: string, dirPath: string = './', backUp: number = 0): string => {\n  const nestDepth: number = 10;\n\n  if(backUp) {\n    const filePath: string = findFileUp.sync(filename, dirPath, nestDepth);\n    const previousPath: string = Array(backUp).fill(null).map(() => '../').join('');\n    return pathResolve(filePath, previousPath);\n  }\n\n  return findFileUp.sync(filename, dirPath, nestDepth);\n};\n\nexport const relativeNodePath = (filename: string, dirPath: string = './', backUp: number = 0): string => {\n  const nestDepth: number = 10;\n  const modulePath = `node_modules/${filename}`;\n\n  if(dirPath !== './') {\n    const lexModulePath = pathResolve(dirPath, modulePath);\n    if(existsSync(lexModulePath)) {\n      return lexModulePath;\n    }\n  }\n\n  const projectPath = pathResolve(process.cwd(), modulePath);\n  if(existsSync(projectPath)) {\n    return projectPath;\n  }\n\n  if(backUp) {\n    const filePath: string = findFileUp.sync(modulePath, dirPath, nestDepth);\n    const previousPath: string = Array(nestDepth).fill(null).map(() => '../').join('');\n    return pathResolve(filePath, previousPath);\n  }\n\n  return findFileUp.sync(modulePath, dirPath, nestDepth) || `/node_modules/${filename}`;\n};\n\nexport const getNodePath = (moduleName: string): string => {\n  const dirName = getDirName();\n  const modulePath: string = `node_modules/${moduleName}`;\n\n  const projectPath = pathResolve(process.cwd(), modulePath);\n  if(existsSync(projectPath)) {\n    return projectPath;\n  }\n\n  const repoPath: string = findFileUp.sync(modulePath, dirName);\n  if(repoPath && existsSync(repoPath)) {\n    return repoPath;\n  }\n\n  const localPath: string = findFileUp.sync(modulePath, './', 10) || `./${modulePath}`;\n  return localPath;\n};\n\nexport const resolveBinaryPath = (binaryName: string, packageName?: string): string => {\n  const lexDir = LexConfig.getLexDir();\n\n  const lexBinPath = pathResolve(lexDir, `node_modules/.bin/${binaryName}`);\n  if(existsSync(lexBinPath)) {\n    return lexBinPath;\n  }\n\n  if(packageName) {\n    const lexPackageBinPath = pathResolve(lexDir, `node_modules/${packageName}/bin/${binaryName}`);\n    if(existsSync(lexPackageBinPath)) {\n      return lexPackageBinPath;\n    }\n\n    const lexPackageBinJsPath = pathResolve(lexDir, `node_modules/${packageName}/bin/${binaryName}.js`);\n    if(existsSync(lexPackageBinJsPath)) {\n      return lexPackageBinJsPath;\n    }\n\n    const lexPackageBinCjsPath = pathResolve(lexDir, `node_modules/${packageName}/bin/${binaryName}.cjs`);\n    if(existsSync(lexPackageBinCjsPath)) {\n      return lexPackageBinCjsPath;\n    }\n  }\n\n  const checkBinUp = (startDir: string) => {\n    let checkDir = startDir;\n    for(let i = 0; i < 5; i++) {\n      const monorepoBinPath = pathResolve(checkDir, `node_modules/.bin/${binaryName}`);\n      if(existsSync(monorepoBinPath)) {\n        return monorepoBinPath;\n      }\n      const parentDir = pathResolve(checkDir, '..');\n      if(parentDir === checkDir) {\n        break;\n      }\n      checkDir = parentDir;\n    }\n    return '';\n  };\n\n  const fromCwd = checkBinUp(process.cwd());\n  if(fromCwd) {\n    return fromCwd;\n  }\n\n  const fromLex = checkBinUp(lexDir);\n  if(fromLex) {\n    return fromLex;\n  }\n\n  return '';\n};\n\nexport const findTailwindCssPath = (): string => {\n  const tailwindPatterns = ['**/tailwind.css'];\n\n  for(const pattern of tailwindPatterns) {\n    const files = globSync(pattern, {\n      cwd: process.cwd(),\n      ignore: ['**/node_modules/**', '**/dist/**', '**/lib/**', '**/build/**', '**/.storybook/**']\n    });\n\n    if(files.length > 0) {\n      return pathResolve(process.cwd(), files[0]);\n    }\n  }\n\n  return '';\n};\n\nexport const resolveWebpackPaths = (currentDirname: string): {webpackPath: string; webpackConfig: string} => {\n  const possibleWebpackPaths = [\n    pathResolve(process.cwd(), 'node_modules/webpack-cli/bin/cli.js'),\n    pathResolve(process.cwd(), 'node_modules/.bin/webpack'),\n    pathResolve(process.cwd(), 'node_modules/@nlabs/lex', 'node_modules/webpack-cli/bin/cli.js'),\n    pathResolve(process.cwd(), 'node_modules/@nlabs/lex', 'node_modules/.bin/webpack'),\n    pathResolve(currentDirname, 'node_modules/@nlabs/lex/node_modules/webpack-cli/bin/cli.js'),\n    pathResolve(currentDirname, 'node_modules/@nlabs/lex/node_modules/.bin/webpack'),\n    pathResolve(process.env.LEX_HOME || '/node_modules/@nlabs/lex', 'node_modules/webpack-cli/bin/cli.js'),\n    pathResolve(process.env.LEX_HOME || '/node_modules/@nlabs/lex', 'node_modules/.bin/webpack')\n  ];\n\n  let webpackPath = '';\n\n  for(const path of possibleWebpackPaths) {\n    if(existsSync(path)) {\n      webpackPath = path;\n      break;\n    }\n  }\n\n  if(!webpackPath) {\n    try {\n      const lexPackagePath = getLexPackageJsonPath();\n      const lexPackageDir = dirname(lexPackagePath);\n      const lexWebpackCli = pathResolve(lexPackageDir, 'node_modules/webpack-cli/bin/cli.js');\n      const lexWebpackBin = pathResolve(lexPackageDir, 'node_modules/.bin/webpack');\n\n      if(existsSync(lexWebpackCli)) {\n        webpackPath = lexWebpackCli;\n      } else if(existsSync(lexWebpackBin)) {\n        webpackPath = lexWebpackBin;\n      } else {\n        webpackPath = 'npx';\n      }\n    } catch{\n      webpackPath = 'npx';\n    }\n  }\n\n  const possibleWebpackConfigPaths = [\n    pathResolve(process.cwd(), 'webpack.config.js'),\n    pathResolve(process.cwd(), 'webpack.config.ts'),\n    pathResolve(process.cwd(), 'node_modules/@nlabs/lex/webpack.config.js'),\n    pathResolve(process.cwd(), 'node_modules/@nlabs/lex/webpack.config.ts'),\n    pathResolve(currentDirname, 'node_modules/@nlabs/lex/webpack.config.js'),\n    pathResolve(currentDirname, 'node_modules/@nlabs/lex/webpack.config.ts'),\n    pathResolve(process.env.LEX_HOME || '/node_modules/@nlabs/lex', 'webpack.config.js'),\n    pathResolve(process.env.LEX_HOME || '/node_modules/@nlabs/lex', 'webpack.config.ts')\n  ];\n\n  let webpackConfig = '';\n\n  for(const path of possibleWebpackConfigPaths) {\n    if(existsSync(path)) {\n      webpackConfig = path;\n      break;\n    }\n  }\n\n  if(!webpackConfig) {\n    const lexPackagePath = getLexPackageJsonPath();\n    const lexPackageDir = dirname(lexPackagePath);\n    const lexWebpackConfig = pathResolve(lexPackageDir, 'webpack.config.js');\n\n    if(existsSync(lexWebpackConfig)) {\n      webpackConfig = lexWebpackConfig;\n    } else {\n      webpackConfig = pathResolve(currentDirname, '../../webpack.config.js');\n    }\n  }\n\n  return {webpackConfig, webpackPath};\n};"],"names":["findFileUp","existsSync","readFileSync","sync","globSync","resolve","pathResolve","dirname","LexConfig","getDirName","eval","process","cwd","getFilePath","relativePath","getLexPackageJsonPath","LEX_PACKAGE_NAME","lexInNodeModules","startDir","env","LEX_ROOT","Error","argv","includes","dir","i","pkgPath","pkg","JSON","parse","name","parent","relativeFilePath","filename","dirPath","backUp","nestDepth","filePath","previousPath","Array","fill","map","join","relativeNodePath","modulePath","lexModulePath","projectPath","getNodePath","moduleName","dirName","repoPath","localPath","resolveBinaryPath","binaryName","packageName","lexDir","getLexDir","lexBinPath","lexPackageBinPath","lexPackageBinJsPath","lexPackageBinCjsPath","checkBinUp","checkDir","monorepoBinPath","parentDir","fromCwd","fromLex","findTailwindCssPath","tailwindPatterns","pattern","files","ignore","length","resolveWebpackPaths","currentDirname","possibleWebpackPaths","LEX_HOME","webpackPath","path","lexPackagePath","lexPackageDir","lexWebpackCli","lexWebpackBin","possibleWebpackConfigPaths","webpackConfig","lexWebpackConfig"],"mappings":"AAAA;;;CAGC,GACD,OAAOA,gBAAgB,eAAe;AACtC,SAAQC,UAAU,EAAEC,YAAY,QAAO,KAAK;AAC5C,SAAQC,QAAQC,QAAQ,QAAO,OAAO;AACtC,SAAQC,WAAWC,WAAW,EAAEC,OAAO,QAAO,OAAO;AAErD,SAAQC,SAAS,QAAO,kBAAkB;AAE1C,OAAO,MAAMC,aAAa;IACxB,IAAI;QACF,OAAOC,KAAK;IACd,EAAE,OAAK;QACL,OAAOC,QAAQC,GAAG;IACpB;AACF,EAAE;AAEF,OAAO,MAAMC,cAAc,CAACC;IAC1B,IAAI;QACF,OAAOJ,KAAK;IACd,EAAE,OAAK;QACL,IAAGI,iBAAiB,yBAAyB;YAC3C,OAAOR,YAAYK,QAAQC,GAAG,IAAI;QACpC;QACA,OAAON,YAAYK,QAAQC,GAAG,IAAIE;IACpC;AACF,EAAE;AAEF,OAAO,MAAMC,wBAAwB;IACnC,MAAMC,mBAAmB;IAEzB,MAAMC,mBAAmBX,YAAYK,QAAQC,GAAG,IAAI;IAEpD,IAAGX,WAAWgB,mBAAmB;QAC/B,OAAOA;IACT;IAEA,IAAIC;IAEJ,IAAGP,QAAQQ,GAAG,CAACC,QAAQ,EAAE;QACvBF,WAAWP,QAAQQ,GAAG,CAACC,QAAQ;IACjC,OAAO;QACL,IAAI;YACFF,WAAWR,KAAK;QAClB,EAAE,OAAK;YACL,IAAI;gBACFQ,WAAWR,KAAK;gBAChB,IAAG,CAACQ,UAAU;oBACZ,MAAM,IAAIG,MAAM;gBAClB;YACF,EAAE,OAAK;gBACL,IAAI;oBACF,IAAGV,QAAQW,IAAI,CAAC,EAAE,IAAI,CAACX,QAAQW,IAAI,CAAC,EAAE,CAACC,QAAQ,CAAC,SAAS;wBACvDL,WAAWX,QAAQI,QAAQW,IAAI,CAAC,EAAE;oBACpC,OAAO;wBACL,MAAM,IAAID,MAAM;oBAClB;gBACF,EAAE,OAAK;oBACLH,WAAWP,QAAQC,GAAG;gBACxB;YACF;QACF;IACF;IAEA,IAAIY,MAAMN;IACV,IAAI,IAAIO,IAAI,GAAGA,IAAI,GAAGA,IAAK;QACzB,MAAMC,UAAUpB,YAAYkB,KAAK;QACjC,IAAGvB,WAAWyB,UAAU;YACtB,IAAI;gBACF,MAAMC,MAAMC,KAAKC,KAAK,CAAC3B,aAAawB,SAAS;gBAC7C,IAAGC,IAAIG,IAAI,KAAKd,kBAAkB;oBAChC,OAAOU;gBACT;YACF,EAAE,OAAK,CACP;QACF;QACA,MAAMK,SAASxB,QAAQiB;QACvB,IAAGO,WAAWP,KAAK;YACjB;QACF;QACAA,MAAMO;IACR;IAEA,OAAOzB,YAAYK,QAAQC,GAAG,IAAI;AACpC,EAAE;AAEF,OAAO,MAAMoB,mBAAmB,CAACC,UAAkBC,UAAkB,IAAI,EAAEC,SAAiB,CAAC;IAC3F,MAAMC,YAAoB;IAE1B,IAAGD,QAAQ;QACT,MAAME,WAAmBrC,WAAWG,IAAI,CAAC8B,UAAUC,SAASE;QAC5D,MAAME,eAAuBC,MAAMJ,QAAQK,IAAI,CAAC,MAAMC,GAAG,CAAC,IAAM,OAAOC,IAAI,CAAC;QAC5E,OAAOpC,YAAY+B,UAAUC;IAC/B;IAEA,OAAOtC,WAAWG,IAAI,CAAC8B,UAAUC,SAASE;AAC5C,EAAE;AAEF,OAAO,MAAMO,mBAAmB,CAACV,UAAkBC,UAAkB,IAAI,EAAEC,SAAiB,CAAC;IAC3F,MAAMC,YAAoB;IAC1B,MAAMQ,aAAa,CAAC,aAAa,EAAEX,UAAU;IAE7C,IAAGC,YAAY,MAAM;QACnB,MAAMW,gBAAgBvC,YAAY4B,SAASU;QAC3C,IAAG3C,WAAW4C,gBAAgB;YAC5B,OAAOA;QACT;IACF;IAEA,MAAMC,cAAcxC,YAAYK,QAAQC,GAAG,IAAIgC;IAC/C,IAAG3C,WAAW6C,cAAc;QAC1B,OAAOA;IACT;IAEA,IAAGX,QAAQ;QACT,MAAME,WAAmBrC,WAAWG,IAAI,CAACyC,YAAYV,SAASE;QAC9D,MAAME,eAAuBC,MAAMH,WAAWI,IAAI,CAAC,MAAMC,GAAG,CAAC,IAAM,OAAOC,IAAI,CAAC;QAC/E,OAAOpC,YAAY+B,UAAUC;IAC/B;IAEA,OAAOtC,WAAWG,IAAI,CAACyC,YAAYV,SAASE,cAAc,CAAC,cAAc,EAAEH,UAAU;AACvF,EAAE;AAEF,OAAO,MAAMc,cAAc,CAACC;IAC1B,MAAMC,UAAUxC;IAChB,MAAMmC,aAAqB,CAAC,aAAa,EAAEI,YAAY;IAEvD,MAAMF,cAAcxC,YAAYK,QAAQC,GAAG,IAAIgC;IAC/C,IAAG3C,WAAW6C,cAAc;QAC1B,OAAOA;IACT;IAEA,MAAMI,WAAmBlD,WAAWG,IAAI,CAACyC,YAAYK;IACrD,IAAGC,YAAYjD,WAAWiD,WAAW;QACnC,OAAOA;IACT;IAEA,MAAMC,YAAoBnD,WAAWG,IAAI,CAACyC,YAAY,MAAM,OAAO,CAAC,EAAE,EAAEA,YAAY;IACpF,OAAOO;AACT,EAAE;AAEF,OAAO,MAAMC,oBAAoB,CAACC,YAAoBC;IACpD,MAAMC,SAAS/C,UAAUgD,SAAS;IAElC,MAAMC,aAAanD,YAAYiD,QAAQ,CAAC,kBAAkB,EAAEF,YAAY;IACxE,IAAGpD,WAAWwD,aAAa;QACzB,OAAOA;IACT;IAEA,IAAGH,aAAa;QACd,MAAMI,oBAAoBpD,YAAYiD,QAAQ,CAAC,aAAa,EAAED,YAAY,KAAK,EAAED,YAAY;QAC7F,IAAGpD,WAAWyD,oBAAoB;YAChC,OAAOA;QACT;QAEA,MAAMC,sBAAsBrD,YAAYiD,QAAQ,CAAC,aAAa,EAAED,YAAY,KAAK,EAAED,WAAW,GAAG,CAAC;QAClG,IAAGpD,WAAW0D,sBAAsB;YAClC,OAAOA;QACT;QAEA,MAAMC,uBAAuBtD,YAAYiD,QAAQ,CAAC,aAAa,EAAED,YAAY,KAAK,EAAED,WAAW,IAAI,CAAC;QACpG,IAAGpD,WAAW2D,uBAAuB;YACnC,OAAOA;QACT;IACF;IAEA,MAAMC,aAAa,CAAC3C;QAClB,IAAI4C,WAAW5C;QACf,IAAI,IAAIO,IAAI,GAAGA,IAAI,GAAGA,IAAK;YACzB,MAAMsC,kBAAkBzD,YAAYwD,UAAU,CAAC,kBAAkB,EAAET,YAAY;YAC/E,IAAGpD,WAAW8D,kBAAkB;gBAC9B,OAAOA;YACT;YACA,MAAMC,YAAY1D,YAAYwD,UAAU;YACxC,IAAGE,cAAcF,UAAU;gBACzB;YACF;YACAA,WAAWE;QACb;QACA,OAAO;IACT;IAEA,MAAMC,UAAUJ,WAAWlD,QAAQC,GAAG;IACtC,IAAGqD,SAAS;QACV,OAAOA;IACT;IAEA,MAAMC,UAAUL,WAAWN;IAC3B,IAAGW,SAAS;QACV,OAAOA;IACT;IAEA,OAAO;AACT,EAAE;AAEF,OAAO,MAAMC,sBAAsB;IACjC,MAAMC,mBAAmB;QAAC;KAAkB;IAE5C,KAAI,MAAMC,WAAWD,iBAAkB;QACrC,MAAME,QAAQlE,SAASiE,SAAS;YAC9BzD,KAAKD,QAAQC,GAAG;YAChB2D,QAAQ;gBAAC;gBAAsB;gBAAc;gBAAa;gBAAe;aAAmB;QAC9F;QAEA,IAAGD,MAAME,MAAM,GAAG,GAAG;YACnB,OAAOlE,YAAYK,QAAQC,GAAG,IAAI0D,KAAK,CAAC,EAAE;QAC5C;IACF;IAEA,OAAO;AACT,EAAE;AAEF,OAAO,MAAMG,sBAAsB,CAACC;IAClC,MAAMC,uBAAuB;QAC3BrE,YAAYK,QAAQC,GAAG,IAAI;QAC3BN,YAAYK,QAAQC,GAAG,IAAI;QAC3BN,YAAYK,QAAQC,GAAG,IAAI,2BAA2B;QACtDN,YAAYK,QAAQC,GAAG,IAAI,2BAA2B;QACtDN,YAAYoE,gBAAgB;QAC5BpE,YAAYoE,gBAAgB;QAC5BpE,YAAYK,QAAQQ,GAAG,CAACyD,QAAQ,IAAI,4BAA4B;QAChEtE,YAAYK,QAAQQ,GAAG,CAACyD,QAAQ,IAAI,4BAA4B;KACjE;IAED,IAAIC,cAAc;IAElB,KAAI,MAAMC,QAAQH,qBAAsB;QACtC,IAAG1E,WAAW6E,OAAO;YACnBD,cAAcC;YACd;QACF;IACF;IAEA,IAAG,CAACD,aAAa;QACf,IAAI;YACF,MAAME,iBAAiBhE;YACvB,MAAMiE,gBAAgBzE,QAAQwE;YAC9B,MAAME,gBAAgB3E,YAAY0E,eAAe;YACjD,MAAME,gBAAgB5E,YAAY0E,eAAe;YAEjD,IAAG/E,WAAWgF,gBAAgB;gBAC5BJ,cAAcI;YAChB,OAAO,IAAGhF,WAAWiF,gBAAgB;gBACnCL,cAAcK;YAChB,OAAO;gBACLL,cAAc;YAChB;QACF,EAAE,OAAK;YACLA,cAAc;QAChB;IACF;IAEA,MAAMM,6BAA6B;QACjC7E,YAAYK,QAAQC,GAAG,IAAI;QAC3BN,YAAYK,QAAQC,GAAG,IAAI;QAC3BN,YAAYK,QAAQC,GAAG,IAAI;QAC3BN,YAAYK,QAAQC,GAAG,IAAI;QAC3BN,YAAYoE,gBAAgB;QAC5BpE,YAAYoE,gBAAgB;QAC5BpE,YAAYK,QAAQQ,GAAG,CAACyD,QAAQ,IAAI,4BAA4B;QAChEtE,YAAYK,QAAQQ,GAAG,CAACyD,QAAQ,IAAI,4BAA4B;KACjE;IAED,IAAIQ,gBAAgB;IAEpB,KAAI,MAAMN,QAAQK,2BAA4B;QAC5C,IAAGlF,WAAW6E,OAAO;YACnBM,gBAAgBN;YAChB;QACF;IACF;IAEA,IAAG,CAACM,eAAe;QACjB,MAAML,iBAAiBhE;QACvB,MAAMiE,gBAAgBzE,QAAQwE;QAC9B,MAAMM,mBAAmB/E,YAAY0E,eAAe;QAEpD,IAAG/E,WAAWoF,mBAAmB;YAC/BD,gBAAgBC;QAClB,OAAO;YACLD,gBAAgB9E,YAAYoE,gBAAgB;QAC9C;IACF;IAEA,OAAO;QAACU;QAAeP;IAAW;AACpC,EAAE"}
209
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utils/file.ts"],"sourcesContent":["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport findFileUp from 'find-file-up';\nimport {existsSync, readFileSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport {resolve as pathResolve, dirname} from 'path';\n\nimport {LexConfig} from '../LexConfig.js';\n\nexport const getDirName = (): string => {\n  try {\n    return eval('new URL(\".\", import.meta.url).pathname');\n  } catch{\n    return process.cwd();\n  }\n};\n\nexport const getLexPackageJsonPath = (): string => {\n  const LEX_PACKAGE_NAME = '@nlabs/lex';\n\n  const lexInNodeModules = pathResolve(process.cwd(), 'node_modules/@nlabs/lex/package.json');\n\n  if(existsSync(lexInNodeModules)) {\n    return lexInNodeModules;\n  }\n\n  let startDir: string;\n\n  if(process.env.LEX_ROOT) {\n    startDir = process.env.LEX_ROOT;\n  } else {\n    try {\n      startDir = eval('new URL(\".\", import.meta.url).pathname');\n    } catch{\n      try {\n        startDir = eval('__filename ? require(\"path\").dirname(__filename) : null');\n        if(!startDir) {\n          throw new Error('__filename not available');\n        }\n      } catch{\n        try {\n          if(process.argv[1] && !process.argv[1].includes('node')) {\n            startDir = dirname(process.argv[1]);\n          } else {\n            throw new Error('process.argv[1] not suitable');\n          }\n        } catch{\n          startDir = process.cwd();\n        }\n      }\n    }\n  }\n\n  let dir = startDir;\n  for(let i = 0; i < 8; i++) {\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 === LEX_PACKAGE_NAME) {\n          return pkgPath;\n        }\n      } catch{\n      }\n    }\n    const parent = dirname(dir);\n    if(parent === dir) {\n      break;\n    }\n    dir = parent;\n  }\n\n  return pathResolve(process.cwd(), 'package.json');\n};\n\nexport const relativeFilePath = (filename: string, dirPath: string = './', backUp: number = 0): string => {\n  const nestDepth: number = 10;\n\n  if(backUp) {\n    const filePath: string = findFileUp.sync(filename, dirPath, nestDepth);\n    const previousPath: string = Array(backUp).fill(null).map(() => '../').join('');\n    return pathResolve(filePath, previousPath);\n  }\n\n  return findFileUp.sync(filename, dirPath, nestDepth);\n};\n\nexport const resolveBinaryPath = (binaryName: string, packageName?: string): string => {\n  const lexDir = LexConfig.getLexDir();\n\n  const lexBinPath = pathResolve(lexDir, `node_modules/.bin/${binaryName}`);\n  if(existsSync(lexBinPath)) {\n    return lexBinPath;\n  }\n\n  if(packageName) {\n    const lexPackageBinPath = pathResolve(lexDir, `node_modules/${packageName}/bin/${binaryName}`);\n    if(existsSync(lexPackageBinPath)) {\n      return lexPackageBinPath;\n    }\n\n    const lexPackageBinJsPath = pathResolve(lexDir, `node_modules/${packageName}/bin/${binaryName}.js`);\n    if(existsSync(lexPackageBinJsPath)) {\n      return lexPackageBinJsPath;\n    }\n\n    const lexPackageBinCjsPath = pathResolve(lexDir, `node_modules/${packageName}/bin/${binaryName}.cjs`);\n    if(existsSync(lexPackageBinCjsPath)) {\n      return lexPackageBinCjsPath;\n    }\n  }\n\n  const checkBinUp = (startDir: string) => {\n    let checkDir = startDir;\n    for(let i = 0; i < 5; i++) {\n      const monorepoBinPath = pathResolve(checkDir, `node_modules/.bin/${binaryName}`);\n      if(existsSync(monorepoBinPath)) {\n        return monorepoBinPath;\n      }\n      const parentDir = pathResolve(checkDir, '..');\n      if(parentDir === checkDir) {\n        break;\n      }\n      checkDir = parentDir;\n    }\n    return '';\n  };\n\n  const fromCwd = checkBinUp(process.cwd());\n  if(fromCwd) {\n    return fromCwd;\n  }\n\n  const fromLex = checkBinUp(lexDir);\n  if(fromLex) {\n    return fromLex;\n  }\n\n  return '';\n};\n\nexport const findTailwindCssPath = (): string => {\n  const tailwindPatterns = ['**/tailwind.css'];\n\n  for(const pattern of tailwindPatterns) {\n    const files = globSync(pattern, {\n      cwd: process.cwd(),\n      ignore: ['**/node_modules/**', '**/dist/**', '**/lib/**', '**/build/**', '**/.storybook/**']\n    });\n\n    if(files.length > 0) {\n      return pathResolve(process.cwd(), files[0]);\n    }\n  }\n\n  return '';\n};\n\nexport const resolveWebpackPaths = (currentDirname: string): {webpackPath: string; webpackConfig: string} => {\n  const possibleWebpackPaths = [\n    pathResolve(process.cwd(), 'node_modules/webpack-cli/bin/cli.js'),\n    pathResolve(process.cwd(), 'node_modules/.bin/webpack'),\n    pathResolve(process.cwd(), 'node_modules/@nlabs/lex', 'node_modules/webpack-cli/bin/cli.js'),\n    pathResolve(process.cwd(), 'node_modules/@nlabs/lex', 'node_modules/.bin/webpack'),\n    pathResolve(currentDirname, 'node_modules/@nlabs/lex/node_modules/webpack-cli/bin/cli.js'),\n    pathResolve(currentDirname, 'node_modules/@nlabs/lex/node_modules/.bin/webpack'),\n    pathResolve(process.env.LEX_HOME || '/node_modules/@nlabs/lex', 'node_modules/webpack-cli/bin/cli.js'),\n    pathResolve(process.env.LEX_HOME || '/node_modules/@nlabs/lex', 'node_modules/.bin/webpack')\n  ];\n\n  let webpackPath = '';\n\n  for(const path of possibleWebpackPaths) {\n    if(existsSync(path)) {\n      webpackPath = path;\n      break;\n    }\n  }\n\n  if(!webpackPath) {\n    try {\n      const lexPackagePath = getLexPackageJsonPath();\n      const lexPackageDir = dirname(lexPackagePath);\n      const lexWebpackCli = pathResolve(lexPackageDir, 'node_modules/webpack-cli/bin/cli.js');\n      const lexWebpackBin = pathResolve(lexPackageDir, 'node_modules/.bin/webpack');\n\n      if(existsSync(lexWebpackCli)) {\n        webpackPath = lexWebpackCli;\n      } else if(existsSync(lexWebpackBin)) {\n        webpackPath = lexWebpackBin;\n      } else {\n        webpackPath = 'npx';\n      }\n    } catch{\n      webpackPath = 'npx';\n    }\n  }\n\n  const possibleWebpackConfigPaths = [\n    pathResolve(process.cwd(), 'webpack.config.js'),\n    pathResolve(process.cwd(), 'webpack.config.ts'),\n    pathResolve(process.cwd(), 'node_modules/@nlabs/lex/webpack.config.js'),\n    pathResolve(process.cwd(), 'node_modules/@nlabs/lex/webpack.config.ts'),\n    pathResolve(currentDirname, 'node_modules/@nlabs/lex/webpack.config.js'),\n    pathResolve(currentDirname, 'node_modules/@nlabs/lex/webpack.config.ts'),\n    pathResolve(process.env.LEX_HOME || '/node_modules/@nlabs/lex', 'webpack.config.js'),\n    pathResolve(process.env.LEX_HOME || '/node_modules/@nlabs/lex', 'webpack.config.ts')\n  ];\n\n  let webpackConfig = '';\n\n  for(const path of possibleWebpackConfigPaths) {\n    if(existsSync(path)) {\n      webpackConfig = path;\n      break;\n    }\n  }\n\n  if(!webpackConfig) {\n    const lexPackagePath = getLexPackageJsonPath();\n    const lexPackageDir = dirname(lexPackagePath);\n    const lexWebpackConfig = pathResolve(lexPackageDir, 'webpack.config.js');\n\n    if(existsSync(lexWebpackConfig)) {\n      webpackConfig = lexWebpackConfig;\n    } else {\n      webpackConfig = pathResolve(currentDirname, '../../webpack.config.js');\n    }\n  }\n\n  return {webpackConfig, webpackPath};\n};"],"names":["findFileUp","existsSync","readFileSync","sync","globSync","resolve","pathResolve","dirname","LexConfig","getDirName","eval","process","cwd","getLexPackageJsonPath","LEX_PACKAGE_NAME","lexInNodeModules","startDir","env","LEX_ROOT","Error","argv","includes","dir","i","pkgPath","pkg","JSON","parse","name","parent","relativeFilePath","filename","dirPath","backUp","nestDepth","filePath","previousPath","Array","fill","map","join","resolveBinaryPath","binaryName","packageName","lexDir","getLexDir","lexBinPath","lexPackageBinPath","lexPackageBinJsPath","lexPackageBinCjsPath","checkBinUp","checkDir","monorepoBinPath","parentDir","fromCwd","fromLex","findTailwindCssPath","tailwindPatterns","pattern","files","ignore","length","resolveWebpackPaths","currentDirname","possibleWebpackPaths","LEX_HOME","webpackPath","path","lexPackagePath","lexPackageDir","lexWebpackCli","lexWebpackBin","possibleWebpackConfigPaths","webpackConfig","lexWebpackConfig"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nlabs/lex",
3
- "version": "1.52.23",
3
+ "version": "1.53.0",
4
4
  "description": "Lex",
5
5
  "license": "MIT",
6
6
  "type": "module",
@@ -81,16 +81,6 @@
81
81
  "watch": "NODE_ENV=development rm -rf lib && npx swc src --out-dir ./lib --source-maps inline --strip-leading-paths --extensions .ts,.tsx --ignore '**/*.test.ts' --ignore '**/*.spec.ts' --watch"
82
82
  },
83
83
  "dependencies": {
84
- "@babel/core": "^7.28.5",
85
- "@babel/plugin-transform-nullish-coalescing-operator": "^7.27.1",
86
- "@babel/plugin-transform-optional-chaining": "^7.28.5",
87
- "@babel/plugin-transform-react-jsx": "^7.27.1",
88
- "@babel/plugin-transform-runtime": "^7.28.5",
89
- "@babel/preset-env": "^7.28.5",
90
- "@babel/preset-react": "^7.28.5",
91
- "@babel/preset-typescript": "7.28.5",
92
- "@babel/runtime": "^7.28.4",
93
- "@babel/runtime-corejs3": "^7.28.4",
94
84
  "@mdx-js/loader": "^3.1.1",
95
85
  "@nlabs/webpack-plugin-static-site": "*",
96
86
  "@storybook/addon-docs": "^10.1.11",
@@ -98,20 +88,18 @@
98
88
  "@storybook/addon-postcss": "^2.0.0",
99
89
  "@storybook/addon-styling-webpack": "^3.0.0",
100
90
  "@storybook/addon-themes": "^10.1.11",
101
- "@storybook/addon-webpack5-compiler-babel": "^4.0.0",
102
91
  "@storybook/cli": "^10.1.11",
103
92
  "@storybook/react": "^10.1.11",
104
93
  "@storybook/react-webpack5": "^10.1.11",
94
+ "@swc/cli": "^0.7.9",
105
95
  "@swc/core": "^1.15.8",
96
+ "@swc/jest": "^0.2.39",
106
97
  "@tailwindcss/nesting": "^0.0.0-insiders.565cd3e",
107
98
  "@tailwindcss/postcss": "4.1.18",
108
99
  "@testing-library/jest-dom": "^6.9.1",
109
100
  "@testing-library/react": "^16.3.1",
110
101
  "assert": "^2.1.0",
111
102
  "autoprefixer": "^10.4.23",
112
- "babel-jest": "^30.2.0",
113
- "babel-loader": "^10.0.0",
114
- "babel-plugin-transform-import-meta": "^2.3.3",
115
103
  "boxen": "8.0.1",
116
104
  "buffer": "^6.0.3",
117
105
  "caniuse-lite": "1.0.30001763",
@@ -204,7 +192,6 @@
204
192
  "ws": "^8.19.0"
205
193
  },
206
194
  "devDependencies": {
207
- "@swc/cli": "^0.7.9",
208
195
  "@types/express": "^5.0.6",
209
196
  "@types/jest": "^30.0.0",
210
197
  "@types/luxon": "^3.7.1",
package/resolver.cjs CHANGED
@@ -1,3 +1,4 @@
1
+ /* eslint-disable @typescript-eslint/no-require-imports */
1
2
  /**
2
3
  * Copyright (c) 2018-Present, Nitrogen Labs, Inc.
3
4
  * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
@@ -6,93 +7,6 @@ const {existsSync} = require('fs');
6
7
  const {extname: pathExtname, resolve: pathResolve} = require('path');
7
8
  const resolveSync = require('resolve/sync');
8
9
 
9
- // Simple fallback for Jest's internal module resolution
10
- const resolveJestInternal = (moduleName) => {
11
- // For Jest's internal requests, be more permissive
12
- if (moduleName === 'index') {
13
- // Jest might be looking for an index file in the current context
14
- const possibleIndexFiles = [
15
- pathResolve(process.cwd(), 'index.js'),
16
- pathResolve(process.cwd(), 'index.ts'),
17
- pathResolve(process.cwd(), 'index.cjs'),
18
- pathResolve(__dirname, '../index.js'),
19
- pathResolve(__dirname, '../index.ts'),
20
- pathResolve(__dirname, '../index.cjs')
21
- ];
22
-
23
- for (const indexFile of possibleIndexFiles) {
24
- if (existsSync(indexFile)) {
25
- return indexFile;
26
- }
27
- }
28
- }
29
-
30
- // For other bare module names, try Node.js resolution
31
- try {
32
- return require.resolve(moduleName);
33
- } catch (e) {
34
- // If that fails, try to find it in node_modules
35
- const possiblePaths = [
36
- pathResolve(process.cwd(), 'node_modules', moduleName),
37
- pathResolve(__dirname, '../node_modules', moduleName),
38
- pathResolve(__dirname, '../../node_modules', moduleName)
39
- ];
40
-
41
- for (const possiblePath of possiblePaths) {
42
- if (existsSync(possiblePath)) {
43
- // Check for package.json to get the main entry point
44
- const packageJsonPath = pathResolve(possiblePath, 'package.json');
45
- if (existsSync(packageJsonPath)) {
46
- try {
47
- const packageJson = require(packageJsonPath);
48
- const mainFile = packageJson.main || 'index.js';
49
- const mainPath = pathResolve(possiblePath, mainFile);
50
- if (existsSync(mainPath)) {
51
- return mainPath;
52
- }
53
- } catch (e) {
54
- // Continue to next path
55
- }
56
- }
57
- // If no package.json or main file, try index.js
58
- const indexPath = pathResolve(possiblePath, 'index.js');
59
- if (existsSync(indexPath)) {
60
- return indexPath;
61
- }
62
- }
63
- }
64
- }
65
-
66
- return null;
67
- };
68
-
69
- const getFullPath = (basedir, name, extensions) => {
70
- let fileName = name;
71
-
72
- extensions.some((ext) => {
73
- if(fileName !== '..') {
74
- const fullPath = pathResolve(`${basedir}/${fileName}${ext}`);
75
-
76
- if(existsSync(fullPath)) {
77
- fileName = fullPath;
78
- return true;
79
- }
80
- }
81
-
82
- if(fileName !== 'index') {
83
- const indexFile = pathResolve(`${basedir}/${fileName}/index${ext}`);
84
-
85
- if(existsSync(indexFile)) {
86
- fileName = indexFile;
87
- return true;
88
- }
89
- }
90
-
91
- return false;
92
- });
93
-
94
- return fileName;
95
- };
96
10
 
97
11
  module.exports = (value, options) => {
98
12
  let fileName = value;
@@ -112,9 +26,9 @@ module.exports = (value, options) => {
112
26
  const isAbsolute = fileName.indexOf('/') === 0;
113
27
 
114
28
  // For Jest's internal modules and transformers, use lex node_modules
115
- if (fileName.includes('babel-jest') ||
116
- fileName.includes('ts-jest') ||
29
+ if(fileName.includes('ts-jest') ||
117
30
  fileName.includes('jest-transform-graphql') ||
31
+ fileName.includes('@swc/jest') ||
118
32
  fileName.includes('core-js') ||
119
33
  fileName.includes('regenerator-runtime') ||
120
34
  fileName.includes('jest-circus') ||
@@ -123,16 +37,18 @@ module.exports = (value, options) => {
123
37
  try {
124
38
  const result = resolveSync(fileName, {basedir: pathResolve(__dirname, '../'), extensions});
125
39
  return result;
40
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
126
41
  } catch(error) {
127
42
  return null;
128
43
  }
129
44
  }
130
45
 
131
46
  // For internal node_modules imports (like core-js internal imports), use default resolution
132
- if (basedir && basedir.includes('node_modules') && (fileName.startsWith('./') || fileName.startsWith('../'))) {
47
+ if(basedir && basedir.includes('node_modules') && (fileName.startsWith('./') || fileName.startsWith('../'))) {
133
48
  try {
134
49
  const result = resolveSync(fileName, {basedir, extensions});
135
50
  return result;
51
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
136
52
  } catch(error) {
137
53
  return null;
138
54
  }
@@ -163,14 +79,15 @@ module.exports = (value, options) => {
163
79
  try {
164
80
  const result = resolveSync(fileName, {basedir, extensions});
165
81
  return result;
82
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
166
83
  } catch(error) {
167
84
  // If resolveSync fails, try the old method
168
85
  const result = pathResolve(basedir, fileName);
169
86
 
170
87
  // Check if the result is a directory and append index.js if needed
171
- if (existsSync(result) && !existsSync(result + '.js') && !existsSync(result + '.ts') && !existsSync(result + '.cjs')) {
88
+ if(existsSync(result) && !existsSync(`${result}.js`) && !existsSync(`${result}.ts`) && !existsSync(`${result}.cjs`)) {
172
89
  const stats = require('fs').statSync(result);
173
- if (stats.isDirectory()) {
90
+ if(stats.isDirectory()) {
174
91
  const indexResult = pathResolve(result, 'index.js');
175
92
  return indexResult;
176
93
  }
@@ -189,6 +106,7 @@ module.exports = (value, options) => {
189
106
  try {
190
107
  const result = resolveSync(fileName, {basedir: pathResolve(__dirname, '../'), extensions});
191
108
  return result;
109
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
192
110
  } catch(lexError) {
193
111
  // If still not found, throw the original error
194
112
  throw projectError;
package/tsconfig.json CHANGED
@@ -35,6 +35,7 @@
35
35
  ],
36
36
  "include": [
37
37
  "./src",
38
- "./jest.setup.ts"
38
+ "./jest.setup.ts",
39
+ "./.storybook"
39
40
  ]
40
41
  }
package/babel.config.json DELETED
@@ -1,19 +0,0 @@
1
- {
2
- "presets": [
3
- [
4
- "@babel/preset-env",
5
- {
6
- "targets": {
7
- "node": "current"
8
- }
9
- }
10
- ],
11
- "@babel/preset-typescript",
12
- [
13
- "@babel/preset-react",
14
- {
15
- "runtime": "automatic"
16
- }
17
- ]
18
- ]
19
- }
@@ -1,11 +0,0 @@
1
- /**
2
- * Copyright (c) 2018-Present, Nitrogen Labs, Inc.
3
- * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
4
- */
5
- /**
6
- * Deep merge function that recursively merges objects and arrays
7
- * @param target - The target object to merge into
8
- * @param source - The source object to merge from
9
- * @returns The merged object
10
- */
11
- export declare const deepMerge: (target: any, source: any) => any;
@@ -1,40 +0,0 @@
1
- /**
2
- * Copyright (c) 2018-Present, Nitrogen Labs, Inc.
3
- * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
4
- */ /**
5
- * Deep merge function that recursively merges objects and arrays
6
- * @param target - The target object to merge into
7
- * @param source - The source object to merge from
8
- * @returns The merged object
9
- */ export const deepMerge = (target, source)=>{
10
- if (!source) {
11
- return target;
12
- }
13
- const result = {
14
- ...target
15
- };
16
- for(const key in source){
17
- if (source.hasOwnProperty(key)) {
18
- if (source[key] && typeof source[key] === 'object' && !Array.isArray(source[key])) {
19
- result[key] = deepMerge(target[key] || {}, source[key]);
20
- } else if (Array.isArray(source[key])) {
21
- // For arrays, merge if both are arrays, otherwise replace
22
- if (Array.isArray(target[key])) {
23
- result[key] = [
24
- ...target[key],
25
- ...source[key]
26
- ];
27
- } else {
28
- result[key] = [
29
- ...source[key]
30
- ];
31
- }
32
- } else {
33
- result[key] = source[key];
34
- }
35
- }
36
- }
37
- return result;
38
- };
39
-
40
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9kZWVwTWVyZ2UudHMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTgtUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cblxuLyoqXG4gKiBEZWVwIG1lcmdlIGZ1bmN0aW9uIHRoYXQgcmVjdXJzaXZlbHkgbWVyZ2VzIG9iamVjdHMgYW5kIGFycmF5c1xuICogQHBhcmFtIHRhcmdldCAtIFRoZSB0YXJnZXQgb2JqZWN0IHRvIG1lcmdlIGludG9cbiAqIEBwYXJhbSBzb3VyY2UgLSBUaGUgc291cmNlIG9iamVjdCB0byBtZXJnZSBmcm9tXG4gKiBAcmV0dXJucyBUaGUgbWVyZ2VkIG9iamVjdFxuICovXG5leHBvcnQgY29uc3QgZGVlcE1lcmdlID0gKHRhcmdldDogYW55LCBzb3VyY2U6IGFueSk6IGFueSA9PiB7XG4gIGlmKCFzb3VyY2UpIHtcbiAgICByZXR1cm4gdGFyZ2V0O1xuICB9XG5cbiAgY29uc3QgcmVzdWx0ID0gey4uLnRhcmdldH07XG5cbiAgZm9yKGNvbnN0IGtleSBpbiBzb3VyY2UpIHtcbiAgICBpZihzb3VyY2UuaGFzT3duUHJvcGVydHkoa2V5KSkge1xuICAgICAgaWYoc291cmNlW2tleV0gJiYgdHlwZW9mIHNvdXJjZVtrZXldID09PSAnb2JqZWN0JyAmJiAhQXJyYXkuaXNBcnJheShzb3VyY2Vba2V5XSkpIHtcbiAgICAgICAgcmVzdWx0W2tleV0gPSBkZWVwTWVyZ2UodGFyZ2V0W2tleV0gfHwge30sIHNvdXJjZVtrZXldKTtcbiAgICAgIH0gZWxzZSBpZihBcnJheS5pc0FycmF5KHNvdXJjZVtrZXldKSkge1xuICAgICAgICAvLyBGb3IgYXJyYXlzLCBtZXJnZSBpZiBib3RoIGFyZSBhcnJheXMsIG90aGVyd2lzZSByZXBsYWNlXG4gICAgICAgIGlmKEFycmF5LmlzQXJyYXkodGFyZ2V0W2tleV0pKSB7XG4gICAgICAgICAgcmVzdWx0W2tleV0gPSBbLi4udGFyZ2V0W2tleV0sIC4uLnNvdXJjZVtrZXldXTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICByZXN1bHRba2V5XSA9IFsuLi5zb3VyY2Vba2V5XV07XG4gICAgICAgIH1cbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHJlc3VsdFtrZXldID0gc291cmNlW2tleV07XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIHJlc3VsdDtcbn07Il0sIm5hbWVzIjpbImRlZXBNZXJnZSIsInRhcmdldCIsInNvdXJjZSIsInJlc3VsdCIsImtleSIsImhhc093blByb3BlcnR5IiwiQXJyYXkiLCJpc0FycmF5Il0sIm1hcHBpbmdzIjoiQUFBQTs7O0NBR0MsR0FFRDs7Ozs7Q0FLQyxHQUNELE9BQU8sTUFBTUEsWUFBWSxDQUFDQyxRQUFhQztJQUNyQyxJQUFHLENBQUNBLFFBQVE7UUFDVixPQUFPRDtJQUNUO0lBRUEsTUFBTUUsU0FBUztRQUFDLEdBQUdGLE1BQU07SUFBQTtJQUV6QixJQUFJLE1BQU1HLE9BQU9GLE9BQVE7UUFDdkIsSUFBR0EsT0FBT0csY0FBYyxDQUFDRCxNQUFNO1lBQzdCLElBQUdGLE1BQU0sQ0FBQ0UsSUFBSSxJQUFJLE9BQU9GLE1BQU0sQ0FBQ0UsSUFBSSxLQUFLLFlBQVksQ0FBQ0UsTUFBTUMsT0FBTyxDQUFDTCxNQUFNLENBQUNFLElBQUksR0FBRztnQkFDaEZELE1BQU0sQ0FBQ0MsSUFBSSxHQUFHSixVQUFVQyxNQUFNLENBQUNHLElBQUksSUFBSSxDQUFDLEdBQUdGLE1BQU0sQ0FBQ0UsSUFBSTtZQUN4RCxPQUFPLElBQUdFLE1BQU1DLE9BQU8sQ0FBQ0wsTUFBTSxDQUFDRSxJQUFJLEdBQUc7Z0JBQ3BDLDBEQUEwRDtnQkFDMUQsSUFBR0UsTUFBTUMsT0FBTyxDQUFDTixNQUFNLENBQUNHLElBQUksR0FBRztvQkFDN0JELE1BQU0sQ0FBQ0MsSUFBSSxHQUFHOzJCQUFJSCxNQUFNLENBQUNHLElBQUk7MkJBQUtGLE1BQU0sQ0FBQ0UsSUFBSTtxQkFBQztnQkFDaEQsT0FBTztvQkFDTEQsTUFBTSxDQUFDQyxJQUFJLEdBQUc7MkJBQUlGLE1BQU0sQ0FBQ0UsSUFBSTtxQkFBQztnQkFDaEM7WUFDRixPQUFPO2dCQUNMRCxNQUFNLENBQUNDLElBQUksR0FBR0YsTUFBTSxDQUFDRSxJQUFJO1lBQzNCO1FBQ0Y7SUFDRjtJQUVBLE9BQU9EO0FBQ1QsRUFBRSJ9
@@ -1,4 +0,0 @@
1
- import { render, screen, fireEvent, waitFor, waitForElementToBeRemoved, within, getByRole, getByLabelText, getByPlaceholderText, getByText, getByTestId, getAllByRole, getAllByLabelText, getAllByPlaceholderText, getAllByText, getAllByTestId, queryByRole, queryByLabelText, queryByPlaceholderText, queryByText, queryByTestId, queryAllByRole, queryAllByLabelText, queryAllByPlaceholderText, queryAllByText, queryAllByTestId, findByRole, findByLabelText, findByPlaceholderText, findByText, findByTestId, findAllByRole, findAllByLabelText, findAllByPlaceholderText, findAllByText, findAllByTestId, renderHook, act, cleanup } from '@testing-library/react';
2
- import * as react from 'react';
3
- export { react };
4
- export { render, screen, fireEvent, waitFor, waitForElementToBeRemoved, within, getByRole, getByLabelText, getByPlaceholderText, getByText, getByTestId, getAllByRole, getAllByLabelText, getAllByPlaceholderText, getAllByText, getAllByTestId, queryByRole, queryByLabelText, queryByPlaceholderText, queryByText, queryByTestId, queryAllByRole, queryAllByLabelText, queryAllByPlaceholderText, queryAllByText, queryAllByTestId, findByRole, findByLabelText, findByPlaceholderText, findByText, findByTestId, findAllByRole, findAllByLabelText, findAllByPlaceholderText, findAllByText, findAllByTestId, renderHook, act, cleanup };
@@ -1,7 +0,0 @@
1
- import { render, screen, fireEvent, waitFor, waitForElementToBeRemoved, within, getByRole, getByLabelText, getByPlaceholderText, getByText, getByTestId, getAllByRole, getAllByLabelText, getAllByPlaceholderText, getAllByText, getAllByTestId, queryByRole, queryByLabelText, queryByPlaceholderText, queryByText, queryByTestId, queryAllByRole, queryAllByLabelText, queryAllByPlaceholderText, queryAllByText, queryAllByTestId, findByRole, findByLabelText, findByPlaceholderText, findByText, findByTestId, findAllByRole, findAllByLabelText, findAllByPlaceholderText, findAllByText, findAllByTestId, renderHook, act, cleanup } from '@testing-library/react';
2
- import * as react from 'react';
3
- export { react };
4
- // Export specific testing library functions
5
- export { render, screen, fireEvent, waitFor, waitForElementToBeRemoved, within, getByRole, getByLabelText, getByPlaceholderText, getByText, getByTestId, getAllByRole, getAllByLabelText, getAllByPlaceholderText, getAllByText, getAllByTestId, queryByRole, queryByLabelText, queryByPlaceholderText, queryByText, queryByTestId, queryAllByRole, queryAllByLabelText, queryAllByPlaceholderText, queryAllByText, queryAllByTestId, findByRole, findByLabelText, findByPlaceholderText, findByText, findByTestId, findAllByRole, findAllByLabelText, findAllByPlaceholderText, findAllByText, findAllByTestId, renderHook, act, cleanup };
6
-
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9yZWFjdFNoaW0udHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgcmVuZGVyLFxuICBzY3JlZW4sXG4gIGZpcmVFdmVudCxcbiAgd2FpdEZvcixcbiAgd2FpdEZvckVsZW1lbnRUb0JlUmVtb3ZlZCxcbiAgd2l0aGluLFxuICBnZXRCeVJvbGUsXG4gIGdldEJ5TGFiZWxUZXh0LFxuICBnZXRCeVBsYWNlaG9sZGVyVGV4dCxcbiAgZ2V0QnlUZXh0LFxuICBnZXRCeVRlc3RJZCxcbiAgZ2V0QWxsQnlSb2xlLFxuICBnZXRBbGxCeUxhYmVsVGV4dCxcbiAgZ2V0QWxsQnlQbGFjZWhvbGRlclRleHQsXG4gIGdldEFsbEJ5VGV4dCxcbiAgZ2V0QWxsQnlUZXN0SWQsXG4gIHF1ZXJ5QnlSb2xlLFxuICBxdWVyeUJ5TGFiZWxUZXh0LFxuICBxdWVyeUJ5UGxhY2Vob2xkZXJUZXh0LFxuICBxdWVyeUJ5VGV4dCxcbiAgcXVlcnlCeVRlc3RJZCxcbiAgcXVlcnlBbGxCeVJvbGUsXG4gIHF1ZXJ5QWxsQnlMYWJlbFRleHQsXG4gIHF1ZXJ5QWxsQnlQbGFjZWhvbGRlclRleHQsXG4gIHF1ZXJ5QWxsQnlUZXh0LFxuICBxdWVyeUFsbEJ5VGVzdElkLFxuICBmaW5kQnlSb2xlLFxuICBmaW5kQnlMYWJlbFRleHQsXG4gIGZpbmRCeVBsYWNlaG9sZGVyVGV4dCxcbiAgZmluZEJ5VGV4dCxcbiAgZmluZEJ5VGVzdElkLFxuICBmaW5kQWxsQnlSb2xlLFxuICBmaW5kQWxsQnlMYWJlbFRleHQsXG4gIGZpbmRBbGxCeVBsYWNlaG9sZGVyVGV4dCxcbiAgZmluZEFsbEJ5VGV4dCxcbiAgZmluZEFsbEJ5VGVzdElkLFxuICByZW5kZXJIb29rLFxuICBhY3QsXG4gIGNsZWFudXBcbn0gZnJvbSAnQHRlc3RpbmctbGlicmFyeS9yZWFjdCc7XG5pbXBvcnQgKiBhcyByZWFjdCBmcm9tICdyZWFjdCc7XG5cbmV4cG9ydCB7cmVhY3R9O1xuXG4vLyBFeHBvcnQgc3BlY2lmaWMgdGVzdGluZyBsaWJyYXJ5IGZ1bmN0aW9uc1xuZXhwb3J0IHtcbiAgcmVuZGVyLFxuICBzY3JlZW4sXG4gIGZpcmVFdmVudCxcbiAgd2FpdEZvcixcbiAgd2FpdEZvckVsZW1lbnRUb0JlUmVtb3ZlZCxcbiAgd2l0aGluLFxuICBnZXRCeVJvbGUsXG4gIGdldEJ5TGFiZWxUZXh0LFxuICBnZXRCeVBsYWNlaG9sZGVyVGV4dCxcbiAgZ2V0QnlUZXh0LFxuICBnZXRCeVRlc3RJZCxcbiAgZ2V0QWxsQnlSb2xlLFxuICBnZXRBbGxCeUxhYmVsVGV4dCxcbiAgZ2V0QWxsQnlQbGFjZWhvbGRlclRleHQsXG4gIGdldEFsbEJ5VGV4dCxcbiAgZ2V0QWxsQnlUZXN0SWQsXG4gIHF1ZXJ5QnlSb2xlLFxuICBxdWVyeUJ5TGFiZWxUZXh0LFxuICBxdWVyeUJ5UGxhY2Vob2xkZXJUZXh0LFxuICBxdWVyeUJ5VGV4dCxcbiAgcXVlcnlCeVRlc3RJZCxcbiAgcXVlcnlBbGxCeVJvbGUsXG4gIHF1ZXJ5QWxsQnlMYWJlbFRleHQsXG4gIHF1ZXJ5QWxsQnlQbGFjZWhvbGRlclRleHQsXG4gIHF1ZXJ5QWxsQnlUZXh0LFxuICBxdWVyeUFsbEJ5VGVzdElkLFxuICBmaW5kQnlSb2xlLFxuICBmaW5kQnlMYWJlbFRleHQsXG4gIGZpbmRCeVBsYWNlaG9sZGVyVGV4dCxcbiAgZmluZEJ5VGV4dCxcbiAgZmluZEJ5VGVzdElkLFxuICBmaW5kQWxsQnlSb2xlLFxuICBmaW5kQWxsQnlMYWJlbFRleHQsXG4gIGZpbmRBbGxCeVBsYWNlaG9sZGVyVGV4dCxcbiAgZmluZEFsbEJ5VGV4dCxcbiAgZmluZEFsbEJ5VGVzdElkLFxuICByZW5kZXJIb29rLFxuICBhY3QsXG4gIGNsZWFudXBcbn07Il0sIm5hbWVzIjpbInJlbmRlciIsInNjcmVlbiIsImZpcmVFdmVudCIsIndhaXRGb3IiLCJ3YWl0Rm9yRWxlbWVudFRvQmVSZW1vdmVkIiwid2l0aGluIiwiZ2V0QnlSb2xlIiwiZ2V0QnlMYWJlbFRleHQiLCJnZXRCeVBsYWNlaG9sZGVyVGV4dCIsImdldEJ5VGV4dCIsImdldEJ5VGVzdElkIiwiZ2V0QWxsQnlSb2xlIiwiZ2V0QWxsQnlMYWJlbFRleHQiLCJnZXRBbGxCeVBsYWNlaG9sZGVyVGV4dCIsImdldEFsbEJ5VGV4dCIsImdldEFsbEJ5VGVzdElkIiwicXVlcnlCeVJvbGUiLCJxdWVyeUJ5TGFiZWxUZXh0IiwicXVlcnlCeVBsYWNlaG9sZGVyVGV4dCIsInF1ZXJ5QnlUZXh0IiwicXVlcnlCeVRlc3RJZCIsInF1ZXJ5QWxsQnlSb2xlIiwicXVlcnlBbGxCeUxhYmVsVGV4dCIsInF1ZXJ5QWxsQnlQbGFjZWhvbGRlclRleHQiLCJxdWVyeUFsbEJ5VGV4dCIsInF1ZXJ5QWxsQnlUZXN0SWQiLCJmaW5kQnlSb2xlIiwiZmluZEJ5TGFiZWxUZXh0IiwiZmluZEJ5UGxhY2Vob2xkZXJUZXh0IiwiZmluZEJ5VGV4dCIsImZpbmRCeVRlc3RJZCIsImZpbmRBbGxCeVJvbGUiLCJmaW5kQWxsQnlMYWJlbFRleHQiLCJmaW5kQWxsQnlQbGFjZWhvbGRlclRleHQiLCJmaW5kQWxsQnlUZXh0IiwiZmluZEFsbEJ5VGVzdElkIiwicmVuZGVySG9vayIsImFjdCIsImNsZWFudXAiLCJyZWFjdCJdLCJtYXBwaW5ncyI6IkFBQUEsU0FDRUEsTUFBTSxFQUNOQyxNQUFNLEVBQ05DLFNBQVMsRUFDVEMsT0FBTyxFQUNQQyx5QkFBeUIsRUFDekJDLE1BQU0sRUFDTkMsU0FBUyxFQUNUQyxjQUFjLEVBQ2RDLG9CQUFvQixFQUNwQkMsU0FBUyxFQUNUQyxXQUFXLEVBQ1hDLFlBQVksRUFDWkMsaUJBQWlCLEVBQ2pCQyx1QkFBdUIsRUFDdkJDLFlBQVksRUFDWkMsY0FBYyxFQUNkQyxXQUFXLEVBQ1hDLGdCQUFnQixFQUNoQkMsc0JBQXNCLEVBQ3RCQyxXQUFXLEVBQ1hDLGFBQWEsRUFDYkMsY0FBYyxFQUNkQyxtQkFBbUIsRUFDbkJDLHlCQUF5QixFQUN6QkMsY0FBYyxFQUNkQyxnQkFBZ0IsRUFDaEJDLFVBQVUsRUFDVkMsZUFBZSxFQUNmQyxxQkFBcUIsRUFDckJDLFVBQVUsRUFDVkMsWUFBWSxFQUNaQyxhQUFhLEVBQ2JDLGtCQUFrQixFQUNsQkMsd0JBQXdCLEVBQ3hCQyxhQUFhLEVBQ2JDLGVBQWUsRUFDZkMsVUFBVSxFQUNWQyxHQUFHLEVBQ0hDLE9BQU8sUUFDRix5QkFBeUI7QUFDaEMsWUFBWUMsV0FBVyxRQUFRO0FBRS9CLFNBQVFBLEtBQUssR0FBRTtBQUVmLDRDQUE0QztBQUM1QyxTQUNFdkMsTUFBTSxFQUNOQyxNQUFNLEVBQ05DLFNBQVMsRUFDVEMsT0FBTyxFQUNQQyx5QkFBeUIsRUFDekJDLE1BQU0sRUFDTkMsU0FBUyxFQUNUQyxjQUFjLEVBQ2RDLG9CQUFvQixFQUNwQkMsU0FBUyxFQUNUQyxXQUFXLEVBQ1hDLFlBQVksRUFDWkMsaUJBQWlCLEVBQ2pCQyx1QkFBdUIsRUFDdkJDLFlBQVksRUFDWkMsY0FBYyxFQUNkQyxXQUFXLEVBQ1hDLGdCQUFnQixFQUNoQkMsc0JBQXNCLEVBQ3RCQyxXQUFXLEVBQ1hDLGFBQWEsRUFDYkMsY0FBYyxFQUNkQyxtQkFBbUIsRUFDbkJDLHlCQUF5QixFQUN6QkMsY0FBYyxFQUNkQyxnQkFBZ0IsRUFDaEJDLFVBQVUsRUFDVkMsZUFBZSxFQUNmQyxxQkFBcUIsRUFDckJDLFVBQVUsRUFDVkMsWUFBWSxFQUNaQyxhQUFhLEVBQ2JDLGtCQUFrQixFQUNsQkMsd0JBQXdCLEVBQ3hCQyxhQUFhLEVBQ2JDLGVBQWUsRUFDZkMsVUFBVSxFQUNWQyxHQUFHLEVBQ0hDLE9BQU8sR0FDUCJ9