@nlabs/lex 1.55.2 → 1.56.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.
@@ -161,7 +161,7 @@ export const test = async (options, args, filesOrCallback, callbackParam)=>{
161
161
  } else {
162
162
  // No Vitest config file exists in the project
163
163
  // Check if there's a Vitest config in lex.config.cjs
164
- projectVitestConfig = LexConfig.config.vitest;
164
+ projectVitestConfig = LexConfig.config.vitest || null;
165
165
  const lexDir = LexConfig.getLexDir();
166
166
  const lexVitestConfig = pathResolve(lexDir, 'vitest.config.mjs');
167
167
  if (debug) {
@@ -426,4 +426,4 @@ Please provide:
426
426
  };
427
427
  export default test;
428
428
 
429
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/commands/test/test.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 {execa} from 'execa';\nimport {existsSync, readFileSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport {resolve as pathResolve} from 'path';\n\nimport {LexConfig, getTypeScriptConfigPath} from '../../LexConfig.js';\nimport {createSpinner} from '../../utils/app.js';\nimport {resolveBinaryPath} from '../../utils/file.js';\nimport {log} from '../../utils/log.js';\nimport {aiFunction} from '../ai/ai.js';\n\nconst detectESM = (cwd: string): boolean => {\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      return packageJson.type === 'module';\n    } catch(_error) {\n      return false;\n    }\n  }\n\n  return false;\n};\n\nexport interface TestOptions {\n  readonly analyze?: boolean;\n  readonly aiDebug?: boolean;\n  readonly aiGenerate?: boolean;\n  readonly aiAnalyze?: boolean;\n  readonly bail?: boolean;\n  readonly changedFilesWithAncestor?: boolean;\n  readonly changedSince?: string;\n  readonly ci?: boolean;\n  readonly clearCache?: boolean;\n  readonly cliName?: string;\n  readonly collectCoverageFrom?: string;\n  readonly colors?: boolean;\n  readonly config?: string;\n  readonly debug?: boolean;\n  readonly debugTests?: boolean;\n  readonly detectOpenHandles?: boolean;\n  readonly environment?: string;\n  readonly env?: string;\n  readonly errorOnDeprecated?: boolean;\n  readonly expand?: boolean;\n  readonly forceExit?: boolean;\n  readonly generate?: boolean;\n  readonly json?: boolean;\n  readonly lastCommit?: boolean;\n  readonly listTests?: boolean;\n  readonly logHeapUsage?: boolean;\n  readonly maxWorkers?: string;\n  readonly noStackTrace?: boolean;\n  readonly notify?: boolean;\n  readonly onlyChanged?: boolean;\n  readonly outputFile?: string;\n  readonly passWithNoTests?: boolean;\n  readonly quiet?: boolean;\n  readonly removeCache?: boolean;\n  readonly runInBand?: boolean;\n  readonly setup?: string;\n  readonly showConfig?: boolean;\n  readonly silent?: boolean;\n  readonly testLocationInResults?: boolean;\n  readonly testNamePattern?: string;\n  readonly testPathPattern?: string;\n  readonly update?: boolean;\n  readonly useStderr?: boolean;\n  readonly verbose?: boolean;\n  readonly watch?: string;\n  readonly watchAll?: boolean;\n}\n\nexport type TestCallback = typeof process.exit;\n\nconst defaultExit = ((code?: number) => {\n  if(process.env.VITEST || process.env.VITEST_WORKER_ID || process.env.NODE_ENV === 'test') {\n    return undefined as never;\n  }\n\n  process.exit(code);\n}) as typeof process.exit;\n\nexport const getTestFilePatterns = (testPathPattern?: string): string[] => {\n  const defaultPatterns = ['**/*.test.*', '**/*.spec.*', '**/*.integration.*'];\n\n  if(!testPathPattern) {\n    return defaultPatterns;\n  }\n\n  return [testPathPattern];\n};\n\nconst findUncoveredSourceFiles = (): string[] => {\n  const sourceFiles = globSync('src/**/*.{ts,tsx,js,jsx}', {\n    cwd: process.cwd(),\n    ignore: ['**/node_modules/**', '**/dist/**', '**/lib/**', '**/*.test.*', '**/*.spec.*']\n  });\n\n  const testFiles = globSync('**/*.{test,spec}.{ts,tsx,js,jsx}', {\n    cwd: process.cwd(),\n    ignore: ['**/node_modules/**', '**/dist/**', '**/lib/**']\n  });\n\n  return sourceFiles.filter((sourceFile) => {\n    const baseName = sourceFile.replace(/\\.[^/.]+$/, '');\n    return !testFiles.some((testFile) => testFile.includes(baseName));\n  });\n};\n\nconst processTestResults = (outputFile?: string): any => {\n  if(!outputFile) {\n    return null;\n  }\n\n  try {\n    const content = readFileSync(outputFile, 'utf-8');\n    return JSON.parse(content);\n  } catch(_error) {\n    return null;\n  }\n};\n\nexport const test = async (\n  options: TestOptions,\n  args?: string[],\n  filesOrCallback?: string[] | TestCallback,\n  callbackParam?: TestCallback\n): Promise<number> => {\n  // Backward-compat argument normalization: allow callback as third param\n  let files: string[] | undefined;\n  let callback: TestCallback = defaultExit;\n\n  if(typeof filesOrCallback === 'function') {\n    callback = filesOrCallback as TestCallback;\n  } else {\n    files = filesOrCallback as string[] | undefined;\n    callback = callbackParam || defaultExit;\n  }\n  const {\n    analyze = false,\n    aiAnalyze = false,\n    aiDebug = false,\n    aiGenerate = false,\n    bail,\n    changedFilesWithAncestor,\n    changedSince,\n    ci,\n    clearCache,\n    cliName = 'Lex',\n    collectCoverageFrom,\n    colors,\n    config,\n    debug = false,\n    debugTests = false,\n    detectOpenHandles,\n    environment,\n    env,\n    errorOnDeprecated,\n    expand,\n    forceExit,\n    generate = false,\n    json,\n    lastCommit,\n    listTests,\n    logHeapUsage,\n    maxWorkers,\n    noStackTrace,\n    notify,\n    onlyChanged,\n    outputFile,\n    passWithNoTests,\n    quiet,\n    removeCache,\n    runInBand,\n    setup,\n    showConfig,\n    silent,\n    testLocationInResults,\n    testNamePattern,\n    testPathPattern,\n    update,\n    useStderr,\n    verbose,\n    watch,\n    watchAll\n  } = options;\n\n  const useGenerate = generate || aiGenerate;\n  const useAnalyze = analyze || aiAnalyze;\n  const useDebug = debugTests || aiDebug;\n\n  log(`${cliName} testing...`, 'info', quiet);\n\n  const spinner = createSpinner(quiet);\n\n  await LexConfig.parseConfig(options);\n\n  const {useTypescript} = LexConfig.config;\n\n  if(useTypescript) {\n    const testConfigPath = getTypeScriptConfigPath('tsconfig.test.json');\n    if(existsSync(testConfigPath)) {\n      log('Using tsconfig.test.json for testing...', 'info', quiet);\n    } else {\n      LexConfig.checkTestTypescriptConfig();\n    }\n  }\n\n  if(useGenerate) {\n    spinner.start('AI is analyzing code to generate test cases...');\n\n    try {\n      const uncoveredFiles = findUncoveredSourceFiles();\n\n      if(uncoveredFiles.length > 0) {\n        const targetFile = uncoveredFiles[0];\n\n        await aiFunction({\n          context: true,\n          file: targetFile,\n          prompt: `Generate Vitest unit tests for this file: ${targetFile}\\n\\n${readFileSync(targetFile, 'utf-8')}\\n\\nPlease create comprehensive tests that cover the main functionality. Include test fixtures and mocks where necessary.`,\n          quiet,\n          task: 'test'\n        });\n\n        spinner.succeed(`AI test generation suggestions provided for ${targetFile}`);\n      } else {\n        spinner.succeed('All source files appear to have corresponding test files');\n      }\n    } catch(aiError) {\n      spinner.fail('Could not generate AI test suggestions');\n      if(!quiet) {\n        // eslint-disable-next-line no-console\n        console.error('AI test generation error:', aiError);\n      }\n    }\n  }\n\n  const projectVitestBin = pathResolve(process.cwd(), 'node_modules/.bin/vitest');\n  let vitestPath: string;\n\n  if(existsSync(projectVitestBin)) {\n    vitestPath = projectVitestBin;\n  } else {\n    vitestPath = resolveBinaryPath('vitest');\n  }\n\n  if(!vitestPath) {\n    log(`\\n${cliName} Error: Vitest binary not found in Lex's node_modules or monorepo root`, 'error', quiet);\n    log('Please reinstall Lex or check your installation.', 'info', quiet);\n    return 1;\n  }\n\n  let vitestConfigFile: string | undefined;\n  let projectVitestConfig: Record<string, unknown> | null = null;\n\n  if(config) {\n    vitestConfigFile = config;\n  } else {\n    const projectVitestConfigPaths = [\n      pathResolve(process.cwd(), 'vitest.config.ts'),\n      pathResolve(process.cwd(), 'vitest.config.mts'),\n      pathResolve(process.cwd(), 'vitest.config.js'),\n      pathResolve(process.cwd(), 'vitest.config.mjs'),\n      pathResolve(process.cwd(), 'vitest.config.cjs')\n    ];\n    const existingConfigPath = projectVitestConfigPaths.find((configPath) => existsSync(configPath));\n\n    if(existingConfigPath) {\n      vitestConfigFile = existingConfigPath;\n      if(debug) {\n        log(`Using project Vitest config file: ${vitestConfigFile}`, 'info', quiet);\n      }\n    } else {\n      // No Vitest config file exists in the project\n      // Check if there's a Vitest config in lex.config.cjs\n      projectVitestConfig = LexConfig.config.vitest;\n\n      const lexDir = LexConfig.getLexDir();\n      const lexVitestConfig = pathResolve(lexDir, 'vitest.config.mjs');\n\n      if(debug) {\n        log(`Looking for Vitest config at: ${lexVitestConfig}`, 'info', quiet);\n        log(`File exists: ${existsSync(lexVitestConfig)}`, 'info', quiet);\n      }\n\n      if(existsSync(lexVitestConfig)) {\n        vitestConfigFile = lexVitestConfig;\n        if(projectVitestConfig && Object.keys(projectVitestConfig).length > 0) {\n          if(debug) {\n            log(`Using Lex Vitest config with project Vitest config from lex.config.cjs: ${vitestConfigFile}`, 'info', quiet);\n          }\n        } else if(debug) {\n          log(`Using Lex Vitest config (no project Vitest config found): ${vitestConfigFile}`, 'info', quiet);\n        }\n      } else {\n        if(debug) {\n          log('No Vitest config found in project or Lex', 'warn', quiet);\n        }\n      }\n    }\n  }\n\n  if(showConfig) {\n    if(vitestConfigFile) {\n      const resolvedConfig = await import(vitestConfigFile);\n      log(JSON.stringify(resolvedConfig.default ?? resolvedConfig, null, 2), 'info', quiet);\n    } else {\n      log(JSON.stringify({test: projectVitestConfig ?? {}}, null, 2), 'info', quiet);\n    }\n    callback(0);\n    return 0;\n  }\n\n  const vitestSetupFile: string = setup || pathResolve(process.cwd(), 'vitest.setup.js');\n  const vitestArgs: string[] = [];\n  const vitestOptions: string[] = [];\n  const reporters = new Set<string>();\n  const filters: string[] = [];\n  const watchMode = Boolean(watch || watchAll);\n  const listMode = Boolean(listTests);\n\n  if(listMode) {\n    vitestArgs.push('list');\n  } else if(watchMode) {\n    vitestArgs.push('watch');\n  } else {\n    vitestArgs.push('run');\n  }\n\n  const isESM = detectESM(process.cwd());\n  let nodeOptions = process.env.NODE_OPTIONS || '';\n  if(isESM) {\n    if(!nodeOptions.includes('--experimental-vm-modules')) {\n      nodeOptions = `${nodeOptions} --experimental-vm-modules`.trim();\n    }\n    log('ESM project detected, using --experimental-vm-modules in NODE_OPTIONS', 'info', quiet);\n  }\n\n  if(vitestConfigFile) {\n    vitestOptions.push('--config', vitestConfigFile);\n  }\n\n  if(bail) {\n    vitestOptions.push('--bail', '1');\n  }\n\n  if(changedFilesWithAncestor) {\n    vitestOptions.push('--changed');\n  }\n\n  if(changedSince) {\n    vitestOptions.push('--changed', changedSince);\n  }\n\n  if(ci) {\n    vitestOptions.push('--run');\n  }\n\n  if(collectCoverageFrom) {\n    vitestOptions.push('--coverage', '--coverage.include', collectCoverageFrom);\n  }\n\n  if(debug) {\n    vitestOptions.push('--inspect');\n  }\n\n  if(detectOpenHandles) {\n    reporters.add('hanging-process');\n  }\n\n  const environmentName = environment || env;\n  if(environmentName) {\n    vitestOptions.push('--environment', environmentName);\n  }\n\n  if(errorOnDeprecated) {\n    log('Vitest does not support --errorOnDeprecated; option ignored.', 'warn', quiet);\n  }\n\n  if(expand) {\n    vitestOptions.push('--expandSnapshotDiff');\n  }\n\n  if(forceExit) {\n    log('Vitest does not support --forceExit; option ignored.', 'warn', quiet);\n  }\n\n  if(lastCommit) {\n    vitestOptions.push('--changed');\n  }\n\n  if(logHeapUsage) {\n    vitestOptions.push('--logHeapUsage');\n  }\n\n  if(maxWorkers) {\n    vitestOptions.push('--maxWorkers', maxWorkers);\n  }\n\n  if(noStackTrace) {\n    log('Vitest does not support --noStackTrace; option ignored.', 'warn', quiet);\n  }\n\n  if(notify) {\n    log('Vitest does not support --notify; option ignored.', 'warn', quiet);\n  }\n\n  if(onlyChanged) {\n    vitestOptions.push('--changed');\n  }\n\n  let tempOutputFile = outputFile;\n  const shouldWriteJson = json || useAnalyze || useDebug || Boolean(outputFile);\n\n  if(shouldWriteJson) {\n    tempOutputFile = outputFile || '.lex-test-results.json';\n    vitestOptions.push('--outputFile', tempOutputFile);\n    reporters.add('json');\n  }\n\n  if(passWithNoTests) {\n    vitestOptions.push('--passWithNoTests');\n  }\n\n  if(runInBand) {\n    vitestOptions.push('--no-file-parallelism', '--maxWorkers', '1');\n  }\n\n  if(silent) {\n    vitestOptions.push('--silent');\n  }\n\n  if(testLocationInResults) {\n    vitestOptions.push('--includeTaskLocation');\n  }\n\n  if(testNamePattern) {\n    vitestOptions.push('--testNamePattern', testNamePattern);\n  }\n\n  if(testPathPattern) {\n    filters.push(testPathPattern);\n  }\n\n  if(useStderr) {\n    log('Vitest does not support --useStderr; option ignored.', 'warn', quiet);\n  }\n\n  if(verbose) {\n    reporters.add('verbose');\n  }\n\n  if(removeCache || clearCache) {\n    vitestOptions.push('--clearCache');\n  }\n\n  if(update) {\n    vitestOptions.push('--update');\n  }\n\n  if(watch) {\n    filters.push(watch);\n  }\n\n  if(args) {\n    vitestOptions.push(...args);\n  }\n\n  if(files && files.length > 0) {\n    filters.push(...files);\n  }\n\n  if(reporters.size > 0) {\n    const reporterList = Array.from(reporters);\n    if(reporterList.includes('json') && !reporterList.includes('verbose')) {\n      // Keep console output while writing JSON results.\n      reporterList.unshift('default');\n    }\n    reporterList.forEach((reporter) => vitestOptions.push('--reporter', reporter));\n  }\n\n  const finalArgs = [...vitestArgs, ...vitestOptions, ...filters];\n\n  if(debug) {\n    log(`Vitest options: ${finalArgs.join(' ')}`, 'info', quiet);\n    log(`NODE_OPTIONS: ${nodeOptions}`, 'info', quiet);\n  }\n\n  try {\n    const env: Record<string, string> = {\n      ...process.env,\n      NODE_OPTIONS: nodeOptions\n    };\n\n    if(colors) {\n      env.FORCE_COLOR = '1';\n    }\n\n    if(ci) {\n      env.CI = 'true';\n    }\n\n    if(vitestSetupFile && existsSync(vitestSetupFile)) {\n      env.LEX_VITEST_SETUP = vitestSetupFile;\n    }\n\n    await execa(vitestPath, finalArgs, {\n      encoding: 'utf8',\n      env,\n      stdio: 'inherit'\n    });\n\n    spinner.succeed('Testing completed!');\n\n    if(useAnalyze) {\n      spinner.start('AI is analyzing test coverage and suggesting improvements...');\n\n      try {\n        const testResults = processTestResults(tempOutputFile);\n        const filePatterns = getTestFilePatterns(testPathPattern);\n\n        await aiFunction({\n          context: true,\n          prompt: `Analyze these Vitest test results and suggest test coverage improvements:\n\n${JSON.stringify(testResults, null, 2)}\n\nTest patterns: ${filePatterns.join(', ')}\n\nPlease provide:\n1. Analysis of current coverage gaps\n2. Suggestions for improving test cases\n3. Recommendations for additional integration test scenarios\n4. Best practices for increasing test effectiveness`,\n          quiet,\n          task: 'optimize'\n        });\n\n        spinner.succeed('AI test analysis complete');\n      } catch(aiError) {\n        spinner.fail('Could not generate AI test analysis');\n        if(!quiet) {\n          // eslint-disable-next-line no-console\n          console.error('AI analysis error:', aiError);\n        }\n      }\n    }\n\n    callback(0);\n    return 0;\n  } catch(error) {\n    log(`\\n${cliName} Error: Check for unit test errors and/or coverage.`, 'error', quiet);\n\n    spinner.fail('Testing failed!');\n\n    if(useDebug) {\n      spinner.start('AI is analyzing test failures...');\n\n      try {\n        const testResults = processTestResults(tempOutputFile);\n\n        await aiFunction({\n          context: true,\n          prompt: `Debug these failed Vitest tests and suggest fixes:\n\n${JSON.stringify(error.message, null, 2)}\n\nTest results: ${JSON.stringify(testResults, null, 2)}\n\nPlease provide:\n1. Analysis of why the tests are failing\n2. Specific suggestions to fix each failing test\n3. Any potential issues with test fixtures or mocks\n4. Code examples for solutions`,\n          quiet,\n          task: 'help'\n        });\n\n        spinner.succeed('AI debugging assistance complete');\n      } catch(aiError) {\n        spinner.fail('Could not generate AI debugging assistance');\n        if(!quiet) {\n          // eslint-disable-next-line no-console\n          console.error('AI debugging error:', aiError);\n        }\n      }\n    }\n\n    callback(1);\n    return 1;\n  }\n};\n\nexport default test;\n"],"names":["execa","existsSync","readFileSync","sync","globSync","resolve","pathResolve","LexConfig","getTypeScriptConfigPath","createSpinner","resolveBinaryPath","log","aiFunction","detectESM","cwd","packageJsonPath","packageJsonContent","packageJson","JSON","parse","type","_error","defaultExit","code","process","env","VITEST","VITEST_WORKER_ID","NODE_ENV","undefined","exit","getTestFilePatterns","testPathPattern","defaultPatterns","findUncoveredSourceFiles","sourceFiles","ignore","testFiles","filter","sourceFile","baseName","replace","some","testFile","includes","processTestResults","outputFile","content","test","options","args","filesOrCallback","callbackParam","files","callback","analyze","aiAnalyze","aiDebug","aiGenerate","bail","changedFilesWithAncestor","changedSince","ci","clearCache","cliName","collectCoverageFrom","colors","config","debug","debugTests","detectOpenHandles","environment","errorOnDeprecated","expand","forceExit","generate","json","lastCommit","listTests","logHeapUsage","maxWorkers","noStackTrace","notify","onlyChanged","passWithNoTests","quiet","removeCache","runInBand","setup","showConfig","silent","testLocationInResults","testNamePattern","update","useStderr","verbose","watch","watchAll","useGenerate","useAnalyze","useDebug","spinner","parseConfig","useTypescript","testConfigPath","checkTestTypescriptConfig","start","uncoveredFiles","length","targetFile","context","file","prompt","task","succeed","aiError","fail","console","error","projectVitestBin","vitestPath","vitestConfigFile","projectVitestConfig","projectVitestConfigPaths","existingConfigPath","find","configPath","vitest","lexDir","getLexDir","lexVitestConfig","Object","keys","resolvedConfig","stringify","default","vitestSetupFile","vitestArgs","vitestOptions","reporters","Set","filters","watchMode","Boolean","listMode","push","isESM","nodeOptions","NODE_OPTIONS","trim","add","environmentName","tempOutputFile","shouldWriteJson","size","reporterList","Array","from","unshift","forEach","reporter","finalArgs","join","FORCE_COLOR","CI","LEX_VITEST_SETUP","encoding","stdio","testResults","filePatterns","message"],"mappings":"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"}
429
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/commands/test/test.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 {execa} from 'execa';\nimport {existsSync, readFileSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport {resolve as pathResolve} from 'path';\n\nimport {LexConfig, getTypeScriptConfigPath} from '../../LexConfig.js';\nimport {createSpinner} from '../../utils/app.js';\nimport {resolveBinaryPath} from '../../utils/file.js';\nimport {log} from '../../utils/log.js';\nimport {aiFunction} from '../ai/ai.js';\n\nconst detectESM = (cwd: string): boolean => {\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      return packageJson.type === 'module';\n    } catch(_error) {\n      return false;\n    }\n  }\n\n  return false;\n};\n\nexport interface TestOptions {\n  readonly analyze?: boolean;\n  readonly aiDebug?: boolean;\n  readonly aiGenerate?: boolean;\n  readonly aiAnalyze?: boolean;\n  readonly bail?: boolean;\n  readonly changedFilesWithAncestor?: boolean;\n  readonly changedSince?: string;\n  readonly ci?: boolean;\n  readonly clearCache?: boolean;\n  readonly cliName?: string;\n  readonly collectCoverageFrom?: string;\n  readonly colors?: boolean;\n  readonly config?: string;\n  readonly debug?: boolean;\n  readonly debugTests?: boolean;\n  readonly detectOpenHandles?: boolean;\n  readonly environment?: string;\n  readonly env?: string;\n  readonly errorOnDeprecated?: boolean;\n  readonly expand?: boolean;\n  readonly forceExit?: boolean;\n  readonly generate?: boolean;\n  readonly json?: boolean;\n  readonly lastCommit?: boolean;\n  readonly listTests?: boolean;\n  readonly logHeapUsage?: boolean;\n  readonly maxWorkers?: string;\n  readonly noStackTrace?: boolean;\n  readonly notify?: boolean;\n  readonly onlyChanged?: boolean;\n  readonly outputFile?: string;\n  readonly passWithNoTests?: boolean;\n  readonly quiet?: boolean;\n  readonly removeCache?: boolean;\n  readonly runInBand?: boolean;\n  readonly setup?: string;\n  readonly showConfig?: boolean;\n  readonly silent?: boolean;\n  readonly testLocationInResults?: boolean;\n  readonly testNamePattern?: string;\n  readonly testPathPattern?: string;\n  readonly update?: boolean;\n  readonly useStderr?: boolean;\n  readonly verbose?: boolean;\n  readonly watch?: string;\n  readonly watchAll?: boolean;\n}\n\nexport type TestCallback = typeof process.exit;\n\nconst defaultExit = ((code?: number) => {\n  if(process.env.VITEST || process.env.VITEST_WORKER_ID || process.env.NODE_ENV === 'test') {\n    return undefined as never;\n  }\n\n  process.exit(code);\n}) as typeof process.exit;\n\nexport const getTestFilePatterns = (testPathPattern?: string): string[] => {\n  const defaultPatterns = ['**/*.test.*', '**/*.spec.*', '**/*.integration.*'];\n\n  if(!testPathPattern) {\n    return defaultPatterns;\n  }\n\n  return [testPathPattern];\n};\n\nconst findUncoveredSourceFiles = (): string[] => {\n  const sourceFiles = globSync('src/**/*.{ts,tsx,js,jsx}', {\n    cwd: process.cwd(),\n    ignore: ['**/node_modules/**', '**/dist/**', '**/lib/**', '**/*.test.*', '**/*.spec.*']\n  });\n\n  const testFiles = globSync('**/*.{test,spec}.{ts,tsx,js,jsx}', {\n    cwd: process.cwd(),\n    ignore: ['**/node_modules/**', '**/dist/**', '**/lib/**']\n  });\n\n  return sourceFiles.filter((sourceFile) => {\n    const baseName = sourceFile.replace(/\\.[^/.]+$/, '');\n    return !testFiles.some((testFile) => testFile.includes(baseName));\n  });\n};\n\nconst processTestResults = (outputFile?: string): any => {\n  if(!outputFile) {\n    return null;\n  }\n\n  try {\n    const content = readFileSync(outputFile, 'utf-8');\n    return JSON.parse(content);\n  } catch(_error) {\n    return null;\n  }\n};\n\nexport const test = async (\n  options: TestOptions,\n  args?: string[],\n  filesOrCallback?: string[] | TestCallback,\n  callbackParam?: TestCallback\n): Promise<number> => {\n  // Backward-compat argument normalization: allow callback as third param\n  let files: string[] | undefined;\n  let callback: TestCallback = defaultExit;\n\n  if(typeof filesOrCallback === 'function') {\n    callback = filesOrCallback as TestCallback;\n  } else {\n    files = filesOrCallback as string[] | undefined;\n    callback = callbackParam || defaultExit;\n  }\n  const {\n    analyze = false,\n    aiAnalyze = false,\n    aiDebug = false,\n    aiGenerate = false,\n    bail,\n    changedFilesWithAncestor,\n    changedSince,\n    ci,\n    clearCache,\n    cliName = 'Lex',\n    collectCoverageFrom,\n    colors,\n    config,\n    debug = false,\n    debugTests = false,\n    detectOpenHandles,\n    environment,\n    env,\n    errorOnDeprecated,\n    expand,\n    forceExit,\n    generate = false,\n    json,\n    lastCommit,\n    listTests,\n    logHeapUsage,\n    maxWorkers,\n    noStackTrace,\n    notify,\n    onlyChanged,\n    outputFile,\n    passWithNoTests,\n    quiet,\n    removeCache,\n    runInBand,\n    setup,\n    showConfig,\n    silent,\n    testLocationInResults,\n    testNamePattern,\n    testPathPattern,\n    update,\n    useStderr,\n    verbose,\n    watch,\n    watchAll\n  } = options;\n\n  const useGenerate = generate || aiGenerate;\n  const useAnalyze = analyze || aiAnalyze;\n  const useDebug = debugTests || aiDebug;\n\n  log(`${cliName} testing...`, 'info', quiet);\n\n  const spinner = createSpinner(quiet);\n\n  await LexConfig.parseConfig(options);\n\n  const {useTypescript} = LexConfig.config;\n\n  if(useTypescript) {\n    const testConfigPath = getTypeScriptConfigPath('tsconfig.test.json');\n    if(existsSync(testConfigPath)) {\n      log('Using tsconfig.test.json for testing...', 'info', quiet);\n    } else {\n      LexConfig.checkTestTypescriptConfig();\n    }\n  }\n\n  if(useGenerate) {\n    spinner.start('AI is analyzing code to generate test cases...');\n\n    try {\n      const uncoveredFiles = findUncoveredSourceFiles();\n\n      if(uncoveredFiles.length > 0) {\n        const targetFile = uncoveredFiles[0];\n\n        await aiFunction({\n          context: true,\n          file: targetFile,\n          prompt: `Generate Vitest unit tests for this file: ${targetFile}\\n\\n${readFileSync(targetFile, 'utf-8')}\\n\\nPlease create comprehensive tests that cover the main functionality. Include test fixtures and mocks where necessary.`,\n          quiet,\n          task: 'test'\n        });\n\n        spinner.succeed(`AI test generation suggestions provided for ${targetFile}`);\n      } else {\n        spinner.succeed('All source files appear to have corresponding test files');\n      }\n    } catch(aiError) {\n      spinner.fail('Could not generate AI test suggestions');\n      if(!quiet) {\n        // eslint-disable-next-line no-console\n        console.error('AI test generation error:', aiError);\n      }\n    }\n  }\n\n  const projectVitestBin = pathResolve(process.cwd(), 'node_modules/.bin/vitest');\n  let vitestPath: string;\n\n  if(existsSync(projectVitestBin)) {\n    vitestPath = projectVitestBin;\n  } else {\n    vitestPath = resolveBinaryPath('vitest');\n  }\n\n  if(!vitestPath) {\n    log(`\\n${cliName} Error: Vitest binary not found in Lex's node_modules or monorepo root`, 'error', quiet);\n    log('Please reinstall Lex or check your installation.', 'info', quiet);\n    return 1;\n  }\n\n  let vitestConfigFile: string | undefined;\n  let projectVitestConfig: Record<string, unknown> | null = null;\n\n  if(config) {\n    vitestConfigFile = config;\n  } else {\n    const projectVitestConfigPaths = [\n      pathResolve(process.cwd(), 'vitest.config.ts'),\n      pathResolve(process.cwd(), 'vitest.config.mts'),\n      pathResolve(process.cwd(), 'vitest.config.js'),\n      pathResolve(process.cwd(), 'vitest.config.mjs'),\n      pathResolve(process.cwd(), 'vitest.config.cjs')\n    ];\n    const existingConfigPath = projectVitestConfigPaths.find((configPath) => existsSync(configPath));\n\n    if(existingConfigPath) {\n      vitestConfigFile = existingConfigPath;\n      if(debug) {\n        log(`Using project Vitest config file: ${vitestConfigFile}`, 'info', quiet);\n      }\n    } else {\n      // No Vitest config file exists in the project\n      // Check if there's a Vitest config in lex.config.cjs\n      projectVitestConfig = LexConfig.config.vitest || null;\n\n      const lexDir = LexConfig.getLexDir();\n      const lexVitestConfig = pathResolve(lexDir, 'vitest.config.mjs');\n\n      if(debug) {\n        log(`Looking for Vitest config at: ${lexVitestConfig}`, 'info', quiet);\n        log(`File exists: ${existsSync(lexVitestConfig)}`, 'info', quiet);\n      }\n\n      if(existsSync(lexVitestConfig)) {\n        vitestConfigFile = lexVitestConfig;\n        if(projectVitestConfig && Object.keys(projectVitestConfig).length > 0) {\n          if(debug) {\n            log(`Using Lex Vitest config with project Vitest config from lex.config.cjs: ${vitestConfigFile}`, 'info', quiet);\n          }\n        } else if(debug) {\n          log(`Using Lex Vitest config (no project Vitest config found): ${vitestConfigFile}`, 'info', quiet);\n        }\n      } else {\n        if(debug) {\n          log('No Vitest config found in project or Lex', 'warn', quiet);\n        }\n      }\n    }\n  }\n\n  if(showConfig) {\n    if(vitestConfigFile) {\n      const resolvedConfig = await import(vitestConfigFile);\n      log(JSON.stringify(resolvedConfig.default ?? resolvedConfig, null, 2), 'info', quiet);\n    } else {\n      log(JSON.stringify({test: projectVitestConfig ?? {}}, null, 2), 'info', quiet);\n    }\n    callback(0);\n    return 0;\n  }\n\n  const vitestSetupFile: string = setup || pathResolve(process.cwd(), 'vitest.setup.js');\n  const vitestArgs: string[] = [];\n  const vitestOptions: string[] = [];\n  const reporters = new Set<string>();\n  const filters: string[] = [];\n  const watchMode = Boolean(watch || watchAll);\n  const listMode = Boolean(listTests);\n\n  if(listMode) {\n    vitestArgs.push('list');\n  } else if(watchMode) {\n    vitestArgs.push('watch');\n  } else {\n    vitestArgs.push('run');\n  }\n\n  const isESM = detectESM(process.cwd());\n  let nodeOptions = process.env.NODE_OPTIONS || '';\n  if(isESM) {\n    if(!nodeOptions.includes('--experimental-vm-modules')) {\n      nodeOptions = `${nodeOptions} --experimental-vm-modules`.trim();\n    }\n    log('ESM project detected, using --experimental-vm-modules in NODE_OPTIONS', 'info', quiet);\n  }\n\n  if(vitestConfigFile) {\n    vitestOptions.push('--config', vitestConfigFile);\n  }\n\n  if(bail) {\n    vitestOptions.push('--bail', '1');\n  }\n\n  if(changedFilesWithAncestor) {\n    vitestOptions.push('--changed');\n  }\n\n  if(changedSince) {\n    vitestOptions.push('--changed', changedSince);\n  }\n\n  if(ci) {\n    vitestOptions.push('--run');\n  }\n\n  if(collectCoverageFrom) {\n    vitestOptions.push('--coverage', '--coverage.include', collectCoverageFrom);\n  }\n\n  if(debug) {\n    vitestOptions.push('--inspect');\n  }\n\n  if(detectOpenHandles) {\n    reporters.add('hanging-process');\n  }\n\n  const environmentName = environment || env;\n  if(environmentName) {\n    vitestOptions.push('--environment', environmentName);\n  }\n\n  if(errorOnDeprecated) {\n    log('Vitest does not support --errorOnDeprecated; option ignored.', 'warn', quiet);\n  }\n\n  if(expand) {\n    vitestOptions.push('--expandSnapshotDiff');\n  }\n\n  if(forceExit) {\n    log('Vitest does not support --forceExit; option ignored.', 'warn', quiet);\n  }\n\n  if(lastCommit) {\n    vitestOptions.push('--changed');\n  }\n\n  if(logHeapUsage) {\n    vitestOptions.push('--logHeapUsage');\n  }\n\n  if(maxWorkers) {\n    vitestOptions.push('--maxWorkers', maxWorkers);\n  }\n\n  if(noStackTrace) {\n    log('Vitest does not support --noStackTrace; option ignored.', 'warn', quiet);\n  }\n\n  if(notify) {\n    log('Vitest does not support --notify; option ignored.', 'warn', quiet);\n  }\n\n  if(onlyChanged) {\n    vitestOptions.push('--changed');\n  }\n\n  let tempOutputFile = outputFile;\n  const shouldWriteJson = json || useAnalyze || useDebug || Boolean(outputFile);\n\n  if(shouldWriteJson) {\n    tempOutputFile = outputFile || '.lex-test-results.json';\n    vitestOptions.push('--outputFile', tempOutputFile);\n    reporters.add('json');\n  }\n\n  if(passWithNoTests) {\n    vitestOptions.push('--passWithNoTests');\n  }\n\n  if(runInBand) {\n    vitestOptions.push('--no-file-parallelism', '--maxWorkers', '1');\n  }\n\n  if(silent) {\n    vitestOptions.push('--silent');\n  }\n\n  if(testLocationInResults) {\n    vitestOptions.push('--includeTaskLocation');\n  }\n\n  if(testNamePattern) {\n    vitestOptions.push('--testNamePattern', testNamePattern);\n  }\n\n  if(testPathPattern) {\n    filters.push(testPathPattern);\n  }\n\n  if(useStderr) {\n    log('Vitest does not support --useStderr; option ignored.', 'warn', quiet);\n  }\n\n  if(verbose) {\n    reporters.add('verbose');\n  }\n\n  if(removeCache || clearCache) {\n    vitestOptions.push('--clearCache');\n  }\n\n  if(update) {\n    vitestOptions.push('--update');\n  }\n\n  if(watch) {\n    filters.push(watch);\n  }\n\n  if(args) {\n    vitestOptions.push(...args);\n  }\n\n  if(files && files.length > 0) {\n    filters.push(...files);\n  }\n\n  if(reporters.size > 0) {\n    const reporterList = Array.from(reporters);\n    if(reporterList.includes('json') && !reporterList.includes('verbose')) {\n      // Keep console output while writing JSON results.\n      reporterList.unshift('default');\n    }\n    reporterList.forEach((reporter) => vitestOptions.push('--reporter', reporter));\n  }\n\n  const finalArgs = [...vitestArgs, ...vitestOptions, ...filters];\n\n  if(debug) {\n    log(`Vitest options: ${finalArgs.join(' ')}`, 'info', quiet);\n    log(`NODE_OPTIONS: ${nodeOptions}`, 'info', quiet);\n  }\n\n  try {\n    const env: Record<string, string> = {\n      ...process.env,\n      NODE_OPTIONS: nodeOptions\n    };\n\n    if(colors) {\n      env.FORCE_COLOR = '1';\n    }\n\n    if(ci) {\n      env.CI = 'true';\n    }\n\n    if(vitestSetupFile && existsSync(vitestSetupFile)) {\n      env.LEX_VITEST_SETUP = vitestSetupFile;\n    }\n\n    await execa(vitestPath, finalArgs, {\n      encoding: 'utf8',\n      env,\n      stdio: 'inherit'\n    });\n\n    spinner.succeed('Testing completed!');\n\n    if(useAnalyze) {\n      spinner.start('AI is analyzing test coverage and suggesting improvements...');\n\n      try {\n        const testResults = processTestResults(tempOutputFile);\n        const filePatterns = getTestFilePatterns(testPathPattern);\n\n        await aiFunction({\n          context: true,\n          prompt: `Analyze these Vitest test results and suggest test coverage improvements:\n\n${JSON.stringify(testResults, null, 2)}\n\nTest patterns: ${filePatterns.join(', ')}\n\nPlease provide:\n1. Analysis of current coverage gaps\n2. Suggestions for improving test cases\n3. Recommendations for additional integration test scenarios\n4. Best practices for increasing test effectiveness`,\n          quiet,\n          task: 'optimize'\n        });\n\n        spinner.succeed('AI test analysis complete');\n      } catch(aiError) {\n        spinner.fail('Could not generate AI test analysis');\n        if(!quiet) {\n          // eslint-disable-next-line no-console\n          console.error('AI analysis error:', aiError);\n        }\n      }\n    }\n\n    callback(0);\n    return 0;\n  } catch(error) {\n    log(`\\n${cliName} Error: Check for unit test errors and/or coverage.`, 'error', quiet);\n\n    spinner.fail('Testing failed!');\n\n    if(useDebug) {\n      spinner.start('AI is analyzing test failures...');\n\n      try {\n        const testResults = processTestResults(tempOutputFile);\n\n        await aiFunction({\n          context: true,\n          prompt: `Debug these failed Vitest tests and suggest fixes:\n\n${JSON.stringify(error.message, null, 2)}\n\nTest results: ${JSON.stringify(testResults, null, 2)}\n\nPlease provide:\n1. Analysis of why the tests are failing\n2. Specific suggestions to fix each failing test\n3. Any potential issues with test fixtures or mocks\n4. Code examples for solutions`,\n          quiet,\n          task: 'help'\n        });\n\n        spinner.succeed('AI debugging assistance complete');\n      } catch(aiError) {\n        spinner.fail('Could not generate AI debugging assistance');\n        if(!quiet) {\n          // eslint-disable-next-line no-console\n          console.error('AI debugging error:', aiError);\n        }\n      }\n    }\n\n    callback(1);\n    return 1;\n  }\n};\n\nexport default test;\n"],"names":["execa","existsSync","readFileSync","sync","globSync","resolve","pathResolve","LexConfig","getTypeScriptConfigPath","createSpinner","resolveBinaryPath","log","aiFunction","detectESM","cwd","packageJsonPath","packageJsonContent","packageJson","JSON","parse","type","_error","defaultExit","code","process","env","VITEST","VITEST_WORKER_ID","NODE_ENV","undefined","exit","getTestFilePatterns","testPathPattern","defaultPatterns","findUncoveredSourceFiles","sourceFiles","ignore","testFiles","filter","sourceFile","baseName","replace","some","testFile","includes","processTestResults","outputFile","content","test","options","args","filesOrCallback","callbackParam","files","callback","analyze","aiAnalyze","aiDebug","aiGenerate","bail","changedFilesWithAncestor","changedSince","ci","clearCache","cliName","collectCoverageFrom","colors","config","debug","debugTests","detectOpenHandles","environment","errorOnDeprecated","expand","forceExit","generate","json","lastCommit","listTests","logHeapUsage","maxWorkers","noStackTrace","notify","onlyChanged","passWithNoTests","quiet","removeCache","runInBand","setup","showConfig","silent","testLocationInResults","testNamePattern","update","useStderr","verbose","watch","watchAll","useGenerate","useAnalyze","useDebug","spinner","parseConfig","useTypescript","testConfigPath","checkTestTypescriptConfig","start","uncoveredFiles","length","targetFile","context","file","prompt","task","succeed","aiError","fail","console","error","projectVitestBin","vitestPath","vitestConfigFile","projectVitestConfig","projectVitestConfigPaths","existingConfigPath","find","configPath","vitest","lexDir","getLexDir","lexVitestConfig","Object","keys","resolvedConfig","stringify","default","vitestSetupFile","vitestArgs","vitestOptions","reporters","Set","filters","watchMode","Boolean","listMode","push","isESM","nodeOptions","NODE_OPTIONS","trim","add","environmentName","tempOutputFile","shouldWriteJson","size","reporterList","Array","from","unshift","forEach","reporter","finalArgs","join","FORCE_COLOR","CI","LEX_VITEST_SETUP","encoding","stdio","testResults","filePatterns","message"],"mappings":"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"}
@@ -6,7 +6,7 @@ export declare const packages: {
6
6
  vitest: string;
7
7
  webpack: string;
8
8
  };
9
- export declare const jsonVersions: (lexPackages: any) => {};
9
+ export declare const jsonVersions: (lexPackages: Record<string, string>) => Record<string, string>;
10
10
  export interface VersionsCmd {
11
11
  readonly json?: boolean;
12
12
  }
@@ -15,7 +15,7 @@ export const packages = {
15
15
  webpack: parseVersion(packageJson?.dependencies?.webpack)
16
16
  };
17
17
  export const jsonVersions = (lexPackages)=>Object.keys(lexPackages).reduce((list, key)=>{
18
- list[key] = packages[key];
18
+ list[key] = lexPackages[key] || 'N/A';
19
19
  return list;
20
20
  }, {});
21
21
  export const versions = (cmd, callback)=>{
@@ -36,4 +36,4 @@ export const versions = (cmd, callback)=>{
36
36
  return Promise.resolve(0);
37
37
  };
38
38
 
39
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21tYW5kcy92ZXJzaW9ucy92ZXJzaW9ucy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtyZWFkRmlsZVN5bmN9IGZyb20gJ2ZzJztcblxuaW1wb3J0IHtnZXRMZXhQYWNrYWdlSnNvblBhdGh9IGZyb20gJy4uLy4uL3V0aWxzL2ZpbGUuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uLy4uL3V0aWxzL2xvZy5qcyc7XG5cbmNvbnN0IHBhY2thZ2VQYXRoID0gZ2V0TGV4UGFja2FnZUpzb25QYXRoKCk7XG5jb25zdCBwYWNrYWdlSnNvbiA9IEpTT04ucGFyc2UocmVhZEZpbGVTeW5jKHBhY2thZ2VQYXRoLCAndXRmOCcpKTtcblxuZXhwb3J0IGNvbnN0IHBhcnNlVmVyc2lvbiA9IChwYWNrYWdlVmVyc2lvbjogc3RyaW5nKTogc3RyaW5nID0+IHBhY2thZ2VWZXJzaW9uPy5yZXBsYWNlKC9cXF4vZywgJycpIHx8ICdOL0EnO1xuXG5leHBvcnQgY29uc3QgcGFja2FnZXMgPSB7XG4gIGxleDogcGFja2FnZUpzb24udmVyc2lvbixcbiAgc3djOiBwYXJzZVZlcnNpb24ocGFja2FnZUpzb24/LmRlcGVuZGVuY2llcz8uWydAc3djL2NvcmUnXSksXG4gIHR5cGVzY3JpcHQ6IHBhcnNlVmVyc2lvbihwYWNrYWdlSnNvbj8uZGVwZW5kZW5jaWVzPy50eXBlc2NyaXB0KSxcbiAgdml0ZXN0OiBwYXJzZVZlcnNpb24ocGFja2FnZUpzb24/LmRlcGVuZGVuY2llcz8udml0ZXN0KSxcbiAgd2VicGFjazogcGFyc2VWZXJzaW9uKHBhY2thZ2VKc29uPy5kZXBlbmRlbmNpZXM/LndlYnBhY2spXG59O1xuXG5leHBvcnQgY29uc3QganNvblZlcnNpb25zID0gKGxleFBhY2thZ2VzKSA9PiBPYmplY3Qua2V5cyhsZXhQYWNrYWdlcykucmVkdWNlKChsaXN0LCBrZXkpID0+IHtcbiAgbGlzdFtrZXldID0gcGFja2FnZXNba2V5XTtcbiAgcmV0dXJuIGxpc3Q7XG59LCB7fSk7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVmVyc2lvbnNDbWQge1xuICByZWFkb25seSBqc29uPzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGNvbnN0IHZlcnNpb25zID0gKGNtZDogVmVyc2lvbnNDbWQsIGNhbGxiYWNrOiAoc3RhdHVzOiBudW1iZXIpID0+IHZvaWQpOiBQcm9taXNlPG51bWJlcj4gPT4ge1xuICBpZihjbWQuanNvbikge1xuICAgIGNvbnNvbGUubG9nKEpTT04uc3RyaW5naWZ5KGpzb25WZXJzaW9ucyhwYWNrYWdlcykpKTtcbiAgfSBlbHNlIHtcbiAgICBsb2coJ1ZlcnNpb25zOicsICdpbmZvJywgZmFsc2UpO1xuICAgIGxvZyhgICBMZXg6ICR7cGFja2FnZXMubGV4fWAsICdpbmZvJywgZmFsc2UpO1xuICAgIGxvZygnICAtLS0tLS0tLS0tJywgJ25vdGUnLCBmYWxzZSk7XG4gICAgbG9nKGAgIFNXQzogJHtwYWNrYWdlcy5zd2N9YCwgJ2luZm8nLCBmYWxzZSk7XG4gICAgbG9nKGAgIFZpdGVzdDogJHtwYWNrYWdlcy52aXRlc3R9YCwgJ2luZm8nLCBmYWxzZSk7XG4gICAgbG9nKGAgIFR5cGVzY3JpcHQ6ICR7cGFja2FnZXMudHlwZXNjcmlwdH1gLCAnaW5mbycsIGZhbHNlKTtcbiAgICBsb2coYCAgV2VicGFjazogJHtwYWNrYWdlcy53ZWJwYWNrfWAsICdpbmZvJywgZmFsc2UpO1xuICB9XG5cbiAgaWYoY2FsbGJhY2spIHtcbiAgICBjYWxsYmFjaygwKTtcbiAgfVxuXG4gIHJldHVybiBQcm9taXNlLnJlc29sdmUoMCk7XG59O1xuIl0sIm5hbWVzIjpbInJlYWRGaWxlU3luYyIsImdldExleFBhY2thZ2VKc29uUGF0aCIsImxvZyIsInBhY2thZ2VQYXRoIiwicGFja2FnZUpzb24iLCJKU09OIiwicGFyc2UiLCJwYXJzZVZlcnNpb24iLCJwYWNrYWdlVmVyc2lvbiIsInJlcGxhY2UiLCJwYWNrYWdlcyIsImxleCIsInZlcnNpb24iLCJzd2MiLCJkZXBlbmRlbmNpZXMiLCJ0eXBlc2NyaXB0Iiwidml0ZXN0Iiwid2VicGFjayIsImpzb25WZXJzaW9ucyIsImxleFBhY2thZ2VzIiwiT2JqZWN0Iiwia2V5cyIsInJlZHVjZSIsImxpc3QiLCJrZXkiLCJ2ZXJzaW9ucyIsImNtZCIsImNhbGxiYWNrIiwianNvbiIsImNvbnNvbGUiLCJzdHJpbmdpZnkiLCJQcm9taXNlIiwicmVzb2x2ZSJdLCJtYXBwaW5ncyI6IkFBQUE7OztDQUdDLEdBQ0QsU0FBUUEsWUFBWSxRQUFPLEtBQUs7QUFFaEMsU0FBUUMscUJBQXFCLFFBQU8sc0JBQXNCO0FBQzFELFNBQVFDLEdBQUcsUUFBTyxxQkFBcUI7QUFFdkMsTUFBTUMsY0FBY0Y7QUFDcEIsTUFBTUcsY0FBY0MsS0FBS0MsS0FBSyxDQUFDTixhQUFhRyxhQUFhO0FBRXpELE9BQU8sTUFBTUksZUFBZSxDQUFDQyxpQkFBbUNBLGdCQUFnQkMsUUFBUSxPQUFPLE9BQU8sTUFBTTtBQUU1RyxPQUFPLE1BQU1DLFdBQVc7SUFDdEJDLEtBQUtQLFlBQVlRLE9BQU87SUFDeEJDLEtBQUtOLGFBQWFILGFBQWFVLGNBQWMsQ0FBQyxZQUFZO0lBQzFEQyxZQUFZUixhQUFhSCxhQUFhVSxjQUFjQztJQUNwREMsUUFBUVQsYUFBYUgsYUFBYVUsY0FBY0U7SUFDaERDLFNBQVNWLGFBQWFILGFBQWFVLGNBQWNHO0FBQ25ELEVBQUU7QUFFRixPQUFPLE1BQU1DLGVBQWUsQ0FBQ0MsY0FBZ0JDLE9BQU9DLElBQUksQ0FBQ0YsYUFBYUcsTUFBTSxDQUFDLENBQUNDLE1BQU1DO1FBQ2xGRCxJQUFJLENBQUNDLElBQUksR0FBR2QsUUFBUSxDQUFDYyxJQUFJO1FBQ3pCLE9BQU9EO0lBQ1QsR0FBRyxDQUFDLEdBQUc7QUFNUCxPQUFPLE1BQU1FLFdBQVcsQ0FBQ0MsS0FBa0JDO0lBQ3pDLElBQUdELElBQUlFLElBQUksRUFBRTtRQUNYQyxRQUFRM0IsR0FBRyxDQUFDRyxLQUFLeUIsU0FBUyxDQUFDWixhQUFhUjtJQUMxQyxPQUFPO1FBQ0xSLElBQUksYUFBYSxRQUFRO1FBQ3pCQSxJQUFJLENBQUMsT0FBTyxFQUFFUSxTQUFTQyxHQUFHLEVBQUUsRUFBRSxRQUFRO1FBQ3RDVCxJQUFJLGdCQUFnQixRQUFRO1FBQzVCQSxJQUFJLENBQUMsT0FBTyxFQUFFUSxTQUFTRyxHQUFHLEVBQUUsRUFBRSxRQUFRO1FBQ3RDWCxJQUFJLENBQUMsVUFBVSxFQUFFUSxTQUFTTSxNQUFNLEVBQUUsRUFBRSxRQUFRO1FBQzVDZCxJQUFJLENBQUMsY0FBYyxFQUFFUSxTQUFTSyxVQUFVLEVBQUUsRUFBRSxRQUFRO1FBQ3BEYixJQUFJLENBQUMsV0FBVyxFQUFFUSxTQUFTTyxPQUFPLEVBQUUsRUFBRSxRQUFRO0lBQ2hEO0lBRUEsSUFBR1UsVUFBVTtRQUNYQSxTQUFTO0lBQ1g7SUFFQSxPQUFPSSxRQUFRQyxPQUFPLENBQUM7QUFDekIsRUFBRSJ9
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21tYW5kcy92ZXJzaW9ucy92ZXJzaW9ucy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtyZWFkRmlsZVN5bmN9IGZyb20gJ2ZzJztcblxuaW1wb3J0IHtnZXRMZXhQYWNrYWdlSnNvblBhdGh9IGZyb20gJy4uLy4uL3V0aWxzL2ZpbGUuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uLy4uL3V0aWxzL2xvZy5qcyc7XG5cbmNvbnN0IHBhY2thZ2VQYXRoID0gZ2V0TGV4UGFja2FnZUpzb25QYXRoKCk7XG5jb25zdCBwYWNrYWdlSnNvbiA9IEpTT04ucGFyc2UocmVhZEZpbGVTeW5jKHBhY2thZ2VQYXRoLCAndXRmOCcpKTtcblxuZXhwb3J0IGNvbnN0IHBhcnNlVmVyc2lvbiA9IChwYWNrYWdlVmVyc2lvbjogc3RyaW5nKTogc3RyaW5nID0+IHBhY2thZ2VWZXJzaW9uPy5yZXBsYWNlKC9cXF4vZywgJycpIHx8ICdOL0EnO1xuXG5leHBvcnQgY29uc3QgcGFja2FnZXMgPSB7XG4gIGxleDogcGFja2FnZUpzb24udmVyc2lvbixcbiAgc3djOiBwYXJzZVZlcnNpb24ocGFja2FnZUpzb24/LmRlcGVuZGVuY2llcz8uWydAc3djL2NvcmUnXSksXG4gIHR5cGVzY3JpcHQ6IHBhcnNlVmVyc2lvbihwYWNrYWdlSnNvbj8uZGVwZW5kZW5jaWVzPy50eXBlc2NyaXB0KSxcbiAgdml0ZXN0OiBwYXJzZVZlcnNpb24ocGFja2FnZUpzb24/LmRlcGVuZGVuY2llcz8udml0ZXN0KSxcbiAgd2VicGFjazogcGFyc2VWZXJzaW9uKHBhY2thZ2VKc29uPy5kZXBlbmRlbmNpZXM/LndlYnBhY2spXG59O1xuXG5leHBvcnQgY29uc3QganNvblZlcnNpb25zID0gKGxleFBhY2thZ2VzOiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+KSA9PiBPYmplY3Qua2V5cyhsZXhQYWNrYWdlcykucmVkdWNlKChsaXN0LCBrZXkpID0+IHtcbiAgbGlzdFtrZXldID0gbGV4UGFja2FnZXNba2V5XSB8fCAnTi9BJztcbiAgcmV0dXJuIGxpc3Q7XG59LCB7fSBhcyBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+KTtcblxuZXhwb3J0IGludGVyZmFjZSBWZXJzaW9uc0NtZCB7XG4gIHJlYWRvbmx5IGpzb24/OiBib29sZWFuO1xufVxuXG5leHBvcnQgY29uc3QgdmVyc2lvbnMgPSAoY21kOiBWZXJzaW9uc0NtZCwgY2FsbGJhY2s6IChzdGF0dXM6IG51bWJlcikgPT4gdm9pZCk6IFByb21pc2U8bnVtYmVyPiA9PiB7XG4gIGlmKGNtZC5qc29uKSB7XG4gICAgY29uc29sZS5sb2coSlNPTi5zdHJpbmdpZnkoanNvblZlcnNpb25zKHBhY2thZ2VzKSkpO1xuICB9IGVsc2Uge1xuICAgIGxvZygnVmVyc2lvbnM6JywgJ2luZm8nLCBmYWxzZSk7XG4gICAgbG9nKGAgIExleDogJHtwYWNrYWdlcy5sZXh9YCwgJ2luZm8nLCBmYWxzZSk7XG4gICAgbG9nKCcgIC0tLS0tLS0tLS0nLCAnbm90ZScsIGZhbHNlKTtcbiAgICBsb2coYCAgU1dDOiAke3BhY2thZ2VzLnN3Y31gLCAnaW5mbycsIGZhbHNlKTtcbiAgICBsb2coYCAgVml0ZXN0OiAke3BhY2thZ2VzLnZpdGVzdH1gLCAnaW5mbycsIGZhbHNlKTtcbiAgICBsb2coYCAgVHlwZXNjcmlwdDogJHtwYWNrYWdlcy50eXBlc2NyaXB0fWAsICdpbmZvJywgZmFsc2UpO1xuICAgIGxvZyhgICBXZWJwYWNrOiAke3BhY2thZ2VzLndlYnBhY2t9YCwgJ2luZm8nLCBmYWxzZSk7XG4gIH1cblxuICBpZihjYWxsYmFjaykge1xuICAgIGNhbGxiYWNrKDApO1xuICB9XG5cbiAgcmV0dXJuIFByb21pc2UucmVzb2x2ZSgwKTtcbn07XG4iXSwibmFtZXMiOlsicmVhZEZpbGVTeW5jIiwiZ2V0TGV4UGFja2FnZUpzb25QYXRoIiwibG9nIiwicGFja2FnZVBhdGgiLCJwYWNrYWdlSnNvbiIsIkpTT04iLCJwYXJzZSIsInBhcnNlVmVyc2lvbiIsInBhY2thZ2VWZXJzaW9uIiwicmVwbGFjZSIsInBhY2thZ2VzIiwibGV4IiwidmVyc2lvbiIsInN3YyIsImRlcGVuZGVuY2llcyIsInR5cGVzY3JpcHQiLCJ2aXRlc3QiLCJ3ZWJwYWNrIiwianNvblZlcnNpb25zIiwibGV4UGFja2FnZXMiLCJPYmplY3QiLCJrZXlzIiwicmVkdWNlIiwibGlzdCIsImtleSIsInZlcnNpb25zIiwiY21kIiwiY2FsbGJhY2siLCJqc29uIiwiY29uc29sZSIsInN0cmluZ2lmeSIsIlByb21pc2UiLCJyZXNvbHZlIl0sIm1hcHBpbmdzIjoiQUFBQTs7O0NBR0MsR0FDRCxTQUFRQSxZQUFZLFFBQU8sS0FBSztBQUVoQyxTQUFRQyxxQkFBcUIsUUFBTyxzQkFBc0I7QUFDMUQsU0FBUUMsR0FBRyxRQUFPLHFCQUFxQjtBQUV2QyxNQUFNQyxjQUFjRjtBQUNwQixNQUFNRyxjQUFjQyxLQUFLQyxLQUFLLENBQUNOLGFBQWFHLGFBQWE7QUFFekQsT0FBTyxNQUFNSSxlQUFlLENBQUNDLGlCQUFtQ0EsZ0JBQWdCQyxRQUFRLE9BQU8sT0FBTyxNQUFNO0FBRTVHLE9BQU8sTUFBTUMsV0FBVztJQUN0QkMsS0FBS1AsWUFBWVEsT0FBTztJQUN4QkMsS0FBS04sYUFBYUgsYUFBYVUsY0FBYyxDQUFDLFlBQVk7SUFDMURDLFlBQVlSLGFBQWFILGFBQWFVLGNBQWNDO0lBQ3BEQyxRQUFRVCxhQUFhSCxhQUFhVSxjQUFjRTtJQUNoREMsU0FBU1YsYUFBYUgsYUFBYVUsY0FBY0c7QUFDbkQsRUFBRTtBQUVGLE9BQU8sTUFBTUMsZUFBZSxDQUFDQyxjQUF3Q0MsT0FBT0MsSUFBSSxDQUFDRixhQUFhRyxNQUFNLENBQUMsQ0FBQ0MsTUFBTUM7UUFDMUdELElBQUksQ0FBQ0MsSUFBSSxHQUFHTCxXQUFXLENBQUNLLElBQUksSUFBSTtRQUNoQyxPQUFPRDtJQUNULEdBQUcsQ0FBQyxHQUE2QjtBQU1qQyxPQUFPLE1BQU1FLFdBQVcsQ0FBQ0MsS0FBa0JDO0lBQ3pDLElBQUdELElBQUlFLElBQUksRUFBRTtRQUNYQyxRQUFRM0IsR0FBRyxDQUFDRyxLQUFLeUIsU0FBUyxDQUFDWixhQUFhUjtJQUMxQyxPQUFPO1FBQ0xSLElBQUksYUFBYSxRQUFRO1FBQ3pCQSxJQUFJLENBQUMsT0FBTyxFQUFFUSxTQUFTQyxHQUFHLEVBQUUsRUFBRSxRQUFRO1FBQ3RDVCxJQUFJLGdCQUFnQixRQUFRO1FBQzVCQSxJQUFJLENBQUMsT0FBTyxFQUFFUSxTQUFTRyxHQUFHLEVBQUUsRUFBRSxRQUFRO1FBQ3RDWCxJQUFJLENBQUMsVUFBVSxFQUFFUSxTQUFTTSxNQUFNLEVBQUUsRUFBRSxRQUFRO1FBQzVDZCxJQUFJLENBQUMsY0FBYyxFQUFFUSxTQUFTSyxVQUFVLEVBQUUsRUFBRSxRQUFRO1FBQ3BEYixJQUFJLENBQUMsV0FBVyxFQUFFUSxTQUFTTyxPQUFPLEVBQUUsRUFBRSxRQUFRO0lBQ2hEO0lBRUEsSUFBR1UsVUFBVTtRQUNYQSxTQUFTO0lBQ1g7SUFFQSxPQUFPSSxRQUFRQyxPQUFPLENBQUM7QUFDekIsRUFBRSJ9
@@ -1,6 +1,11 @@
1
- export declare const createChangelog: ({ cliName, config, outputFile, quiet }: {
2
- cliName: any;
3
- config: any;
4
- outputFile?: string;
5
- quiet: any;
6
- }) => Promise<number>;
1
+ interface ChangelogConfig {
2
+ readonly gitUrl?: string;
3
+ }
4
+ interface ChangelogOptions {
5
+ readonly cliName?: string;
6
+ readonly config?: ChangelogConfig;
7
+ readonly outputFile?: string;
8
+ readonly quiet?: boolean;
9
+ }
10
+ export declare const createChangelog: ({ cliName, config, outputFile, quiet }: ChangelogOptions) => Promise<number>;
11
+ export {};
@@ -10,7 +10,7 @@ import { DateTime } from 'luxon';
10
10
  import { join as pathJoin } from 'path';
11
11
  import { createSpinner } from '../utils/app.js';
12
12
  import { log } from '../utils/log.js';
13
- export const createChangelog = async ({ cliName, config, outputFile = 'changelog.tmp.md', quiet })=>{
13
+ export const createChangelog = async ({ cliName, config = {}, outputFile = 'changelog.tmp.md', quiet })=>{
14
14
  const spinner = createSpinner(quiet);
15
15
  const gitOptions = [
16
16
  'log',
@@ -60,7 +60,7 @@ export const createChangelog = async ({ cliName, config, outputFile = 'changelog
60
60
  const matches = formatLine.match(headerPattern);
61
61
  if (matches) {
62
62
  const itemType = capitalize(matches[1]);
63
- const itemScope = matches[2];
63
+ const itemScope = matches[2] || 'General';
64
64
  const itemDetails = matches[3];
65
65
  const details = {
66
66
  authorEmail,
@@ -110,7 +110,7 @@ export const createChangelog = async ({ cliName, config, outputFile = 'changelog
110
110
  let hash = `#${hashShort}`;
111
111
  if (!isEmpty(gitUrl)) {
112
112
  let commitPath = 'commits';
113
- if (gitUrl.includes('github.com')) {
113
+ if (gitUrl && gitUrl.includes('github.com')) {
114
114
  commitPath = 'commit';
115
115
  }
116
116
  hash = `[#${hashShort}](${gitUrl}/${commitPath}/${hashFull})`;
@@ -132,8 +132,8 @@ export const createChangelog = async ({ cliName, config, outputFile = 'changelog
132
132
  // Stop spinner
133
133
  spinner.fail('Failed generating change log!');
134
134
  // Kill process
135
- return error.status;
135
+ return 1;
136
136
  }
137
137
  };
138
138
 
139
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/create/changelog.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 {execa} from 'execa';\nimport {writeFileSync} from 'fs';\nimport capitalize from 'lodash/capitalize.js';\nimport isEmpty from 'lodash/isEmpty.js';\nimport merge from 'lodash/merge.js';\nimport {DateTime} from 'luxon';\nimport {join as pathJoin} from 'path';\n\nimport {createSpinner} from '../utils/app.js';\nimport {log} from '../utils/log.js';\n\nexport const createChangelog = async ({cliName, config, outputFile = 'changelog.tmp.md', quiet}): Promise<number> => {\n  const spinner = createSpinner(quiet);\n\n  const gitOptions: string[] = [\n    'log',\n    '-3',\n    '--pretty=format:{\"authorName\": \"%an\", \"authorEmail\": \"%ae\", \"hashShort\": \"%h\", \"hashFull\": \"%H\", \"tag\": \"%D\", \"date\": %ct, \"subject\": \"%s\",\"comments\": \"%b\"}[lex_break]'\n  ];\n\n  try {\n    const git = await execa('git', gitOptions, {encoding: 'utf8'});\n\n    const {stdout} = git;\n    const entries: string[] = stdout.split('[lex_break]').filter((item) => !!item);\n    const gitJson = JSON.parse(\n      (`[${entries.join(',')}]`).replace(/\"[^\"]*(?:\"\"[^\"]*)*\"/g, (match) => match.replace(/\\n/g, '[lex_break]'))\n    );\n    const commitContent = {};\n    let version: string = 'Unreleased';\n\n    gitJson.forEach((item) => {\n      const {comments, authorEmail, authorName, date, hashFull, hashShort, tag} = item;\n      const formatDate: string = DateTime.fromMillis(date).toFormat('DDD');\n\n      if(!isEmpty(tag)) {\n        const refs = tag.split(', ');\n        const updatedVersion: string = refs.reduce((ref: string, tagItem: string) => {\n          let updatedRef: string = ref;\n\n          if(updatedRef === '' && tagItem.includes('tag: v')) {\n            updatedRef = tagItem.replace('tag: v', '').trim();\n          }\n\n          return updatedRef;\n        }, '');\n\n        if(!isEmpty(updatedVersion)) {\n          version = updatedVersion;\n          commitContent[version] = {date: formatDate, version: updatedVersion};\n        }\n      }\n\n      if(!commitContent[version]) {\n        commitContent[version] = {list: {}};\n      }\n\n      const subjectLines: string[] = comments.split('[lex_break]');\n      const topics = {};\n\n\n      for(let idx: number = 0, len: number = subjectLines.length; idx < len; idx++) {\n        const nextLine: string = subjectLines[idx];\n        const formatLine: string = nextLine.trim();\n        const headerPattern: RegExp = /^(\\w*)(?:\\(([\\w$.\\- *]*)\\))?: (.*)$/;\n        const matches = formatLine.match(headerPattern);\n\n        if(matches) {\n          const itemType: string = capitalize(matches[1]);\n          const itemScope: string = matches[2];\n          const itemDetails: string = matches[3];\n          const details = {\n            authorEmail,\n            authorName,\n            details: itemDetails,\n            hashFull,\n            hashShort,\n            type: itemType\n          };\n\n          if(!topics[itemScope]) {\n            topics[itemScope] = {[itemType]: [details]};\n          } else {\n            topics[itemScope][itemType].push(details);\n          }\n        }\n      }\n\n      commitContent[version] = merge(commitContent[version], {list: topics});\n    });\n\n    const formatLog: string = Object.keys(commitContent).reduce((content: string, versionKey: string) => {\n      const {date, list = {}, version} = commitContent[versionKey];\n      const formatScopes: string[] = Object.keys(list);\n      let updatedContent: string = content;\n\n      const versionLabel: string = version ? version : 'Unreleased';\n      const headerLabels: string[] = [versionLabel];\n      if(date) {\n        headerLabels.push(`(${date})`);\n      }\n\n      updatedContent += `\\n## ${headerLabels.join(' ')}\\n`;\n\n      formatScopes.forEach((scopeName: string) => {\n        updatedContent += `\\n### ${scopeName}\\n\\n`;\n\n        // Get the topic name\n        const itemList = list[scopeName];\n        const itemNames: string[] = Object.keys(itemList);\n\n        itemNames.forEach((itemName: string) => {\n          updatedContent += `* ${itemName}\\n`;\n\n          itemList[itemName].forEach((changes) => {\n            const {authorEmail, authorName, details, hashFull, hashShort} = changes;\n            const {gitUrl} = config;\n            let hash: string = `#${hashShort}`;\n\n            if(!isEmpty(gitUrl)) {\n              let commitPath: string = 'commits';\n\n              if(gitUrl.includes('github.com')) {\n                commitPath = 'commit';\n              }\n\n              hash = `[#${hashShort}](${gitUrl}/${commitPath}/${hashFull})`;\n            }\n\n            updatedContent += `  * ${details} ([${authorName}](mailto:${authorEmail}) in ${hash})\\n`;\n          });\n        });\n      });\n\n      return updatedContent;\n    }, '# Changes\\n');\n\n    const logFile: string = pathJoin(process.cwd(), outputFile);\n    writeFileSync(logFile, formatLog);\n    spinner.succeed('Git change log complete!');\n\n    // Kill process\n    return 0;\n  } catch(error) {\n    // Display error message\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n    // Stop spinner\n    spinner.fail('Failed generating change log!');\n\n    // Kill process\n    return error.status;\n  }\n};"],"names":["execa","writeFileSync","capitalize","isEmpty","merge","DateTime","join","pathJoin","createSpinner","log","createChangelog","cliName","config","outputFile","quiet","spinner","gitOptions","git","encoding","stdout","entries","split","filter","item","gitJson","JSON","parse","replace","match","commitContent","version","forEach","comments","authorEmail","authorName","date","hashFull","hashShort","tag","formatDate","fromMillis","toFormat","refs","updatedVersion","reduce","ref","tagItem","updatedRef","includes","trim","list","subjectLines","topics","idx","len","length","nextLine","formatLine","headerPattern","matches","itemType","itemScope","itemDetails","details","type","push","formatLog","Object","keys","content","versionKey","formatScopes","updatedContent","versionLabel","headerLabels","scopeName","itemList","itemNames","itemName","changes","gitUrl","hash","commitPath","logFile","process","cwd","succeed","error","message","fail","status"],"mappings":"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"}
139
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/create/changelog.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 {execa} from 'execa';\nimport {writeFileSync} from 'fs';\nimport capitalize from 'lodash/capitalize.js';\nimport isEmpty from 'lodash/isEmpty.js';\nimport merge from 'lodash/merge.js';\nimport {DateTime} from 'luxon';\nimport {join as pathJoin} from 'path';\n\nimport {createSpinner} from '../utils/app.js';\nimport {log} from '../utils/log.js';\n\ninterface ChangelogConfig {\n  readonly gitUrl?: string;\n}\n\ninterface ChangelogOptions {\n  readonly cliName?: string;\n  readonly config?: ChangelogConfig;\n  readonly outputFile?: string;\n  readonly quiet?: boolean;\n}\n\ninterface ChangelogEntry {\n  readonly authorEmail: string;\n  readonly authorName: string;\n  readonly comments: string;\n  readonly date: number;\n  readonly hashFull: string;\n  readonly hashShort: string;\n  readonly tag: string;\n}\n\ninterface ChangelogItemDetails {\n  readonly authorEmail: string;\n  readonly authorName: string;\n  readonly details: string;\n  readonly hashFull: string;\n  readonly hashShort: string;\n  readonly type: string;\n}\n\ninterface ChangelogVersionEntry {\n  readonly date?: string;\n  readonly version?: string;\n  readonly list?: Record<string, Record<string, ChangelogItemDetails[]>>;\n}\n\nexport const createChangelog = async ({cliName, config = {}, outputFile = 'changelog.tmp.md', quiet}: ChangelogOptions): Promise<number> => {\n  const spinner = createSpinner(quiet);\n\n  const gitOptions: string[] = [\n    'log',\n    '-3',\n    '--pretty=format:{\"authorName\": \"%an\", \"authorEmail\": \"%ae\", \"hashShort\": \"%h\", \"hashFull\": \"%H\", \"tag\": \"%D\", \"date\": %ct, \"subject\": \"%s\",\"comments\": \"%b\"}[lex_break]'\n  ];\n\n  try {\n    const git = await execa('git', gitOptions, {encoding: 'utf8'});\n\n    const {stdout} = git;\n    const entries: string[] = stdout.split('[lex_break]').filter((item) => !!item);\n    const gitJson = JSON.parse(\n      (`[${entries.join(',')}]`).replace(/\"[^\"]*(?:\"\"[^\"]*)*\"/g, (match) => match.replace(/\\n/g, '[lex_break]'))\n    ) as ChangelogEntry[];\n    const commitContent: Record<string, ChangelogVersionEntry> = {};\n    let version: string = 'Unreleased';\n\n    gitJson.forEach((item: ChangelogEntry) => {\n      const {comments, authorEmail, authorName, date, hashFull, hashShort, tag} = item;\n      const formatDate: string = DateTime.fromMillis(date).toFormat('DDD');\n\n      if(!isEmpty(tag)) {\n        const refs = tag.split(', ');\n        const updatedVersion: string = refs.reduce((ref: string, tagItem: string) => {\n          let updatedRef: string = ref;\n\n          if(updatedRef === '' && tagItem.includes('tag: v')) {\n            updatedRef = tagItem.replace('tag: v', '').trim();\n          }\n\n          return updatedRef;\n        }, '');\n\n        if(!isEmpty(updatedVersion)) {\n          version = updatedVersion;\n          commitContent[version] = {date: formatDate, version: updatedVersion};\n        }\n      }\n\n      if(!commitContent[version]) {\n        commitContent[version] = {list: {}};\n      }\n\n      const subjectLines: string[] = comments.split('[lex_break]');\n      const topics: Record<string, Record<string, ChangelogItemDetails[]>> = {};\n\n\n      for(let idx: number = 0, len: number = subjectLines.length; idx < len; idx++) {\n        const nextLine: string = subjectLines[idx];\n        const formatLine: string = nextLine.trim();\n        const headerPattern: RegExp = /^(\\w*)(?:\\(([\\w$.\\- *]*)\\))?: (.*)$/;\n        const matches = formatLine.match(headerPattern);\n\n        if(matches) {\n          const itemType: string = capitalize(matches[1]);\n          const itemScope: string = matches[2] || 'General';\n          const itemDetails: string = matches[3];\n          const details = {\n            authorEmail,\n            authorName,\n            details: itemDetails,\n            hashFull,\n            hashShort,\n            type: itemType\n          };\n\n          if(!topics[itemScope]) {\n            topics[itemScope] = {[itemType]: [details]};\n          } else {\n            topics[itemScope][itemType].push(details);\n          }\n        }\n      }\n\n      commitContent[version] = merge(commitContent[version], {list: topics});\n    });\n\n    const formatLog: string = Object.keys(commitContent).reduce((content: string, versionKey: string) => {\n      const {date, list = {}, version} = commitContent[versionKey];\n      const formatScopes: string[] = Object.keys(list);\n      let updatedContent: string = content;\n\n      const versionLabel: string = version ? version : 'Unreleased';\n      const headerLabels: string[] = [versionLabel];\n      if(date) {\n        headerLabels.push(`(${date})`);\n      }\n\n      updatedContent += `\\n## ${headerLabels.join(' ')}\\n`;\n\n      formatScopes.forEach((scopeName: string) => {\n        updatedContent += `\\n### ${scopeName}\\n\\n`;\n\n        // Get the topic name\n        const itemList = list[scopeName];\n        const itemNames: string[] = Object.keys(itemList);\n\n        itemNames.forEach((itemName: string) => {\n          updatedContent += `* ${itemName}\\n`;\n\n          itemList[itemName].forEach((changes: ChangelogItemDetails) => {\n            const {authorEmail, authorName, details, hashFull, hashShort} = changes;\n            const {gitUrl} = config;\n            let hash: string = `#${hashShort}`;\n\n            if(!isEmpty(gitUrl)) {\n              let commitPath: string = 'commits';\n\n              if(gitUrl && gitUrl.includes('github.com')) {\n                commitPath = 'commit';\n              }\n\n              hash = `[#${hashShort}](${gitUrl}/${commitPath}/${hashFull})`;\n            }\n\n            updatedContent += `  * ${details} ([${authorName}](mailto:${authorEmail}) in ${hash})\\n`;\n          });\n        });\n      });\n\n      return updatedContent;\n    }, '# Changes\\n');\n\n    const logFile: string = pathJoin(process.cwd(), outputFile);\n    writeFileSync(logFile, formatLog);\n    spinner.succeed('Git change log complete!');\n\n    // Kill process\n    return 0;\n  } catch(error) {\n    // Display error message\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n    // Stop spinner\n    spinner.fail('Failed generating change log!');\n\n    // Kill process\n    return 1;\n  }\n};\n"],"names":["execa","writeFileSync","capitalize","isEmpty","merge","DateTime","join","pathJoin","createSpinner","log","createChangelog","cliName","config","outputFile","quiet","spinner","gitOptions","git","encoding","stdout","entries","split","filter","item","gitJson","JSON","parse","replace","match","commitContent","version","forEach","comments","authorEmail","authorName","date","hashFull","hashShort","tag","formatDate","fromMillis","toFormat","refs","updatedVersion","reduce","ref","tagItem","updatedRef","includes","trim","list","subjectLines","topics","idx","len","length","nextLine","formatLine","headerPattern","matches","itemType","itemScope","itemDetails","details","type","push","formatLog","Object","keys","content","versionKey","formatScopes","updatedContent","versionLabel","headerLabels","scopeName","itemList","itemNames","itemName","changes","gitUrl","hash","commitPath","logFile","process","cwd","succeed","error","message","fail"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiJ9
@@ -27,16 +27,16 @@ export interface Spinner {
27
27
  export declare const createSpinner: (quiet?: boolean) => Spinner;
28
28
  export declare const createProgressBar: (percentage: number) => string;
29
29
  export declare const handleWebpackProgress: (output: string, spinner: Spinner, quiet: boolean, emoji: string, action: string) => void;
30
- export declare const copyFiles: (files: string[], typeName: string, spinner: any, config: LexConfigType) => Promise<void>;
31
- export declare const copyConfiguredFiles: (spinner: any, config: LexConfigType, quiet: boolean) => Promise<void>;
30
+ export declare const copyFiles: (files: string[], typeName: string, spinner: Spinner, config: LexConfigType) => Promise<void>;
31
+ export declare const copyConfiguredFiles: (spinner: Spinner, config: LexConfigType, quiet: boolean) => Promise<void>;
32
32
  export declare const copyFileSync: (source: string, target: string) => void;
33
33
  export declare const copyFolderRecursiveSync: (source: string, target: string) => void;
34
34
  export declare const getPackageJson: (packagePath?: string) => any;
35
35
  export declare const getFilesByExt: (ext: string, config: LexConfigType) => string[];
36
- export declare const removeConflictModules: (moduleList: object) => object;
36
+ export declare const removeConflictModules: (moduleList: Record<string, unknown>) => Record<string, unknown>;
37
37
  export declare const removeFiles: (fileName: string, isRelative?: boolean) => Promise<unknown>;
38
38
  export declare const removeModules: () => Promise<unknown>;
39
- export declare const setPackageJson: (json: any, packagePath?: string) => void;
39
+ export declare const setPackageJson: (json: unknown, packagePath?: string) => void;
40
40
  export interface LinkedModuleType {
41
41
  readonly name: string;
42
42
  readonly path: string;
package/lib/utils/app.js CHANGED
@@ -12,13 +12,13 @@ import { rimrafSync } from 'rimraf';
12
12
  import { log } from './log.js';
13
13
  export const getFilenames = (props)=>{
14
14
  const { callback, cliName, name, quiet, type, useTypescript } = props;
15
- let nameCaps;
15
+ let nameCaps = '';
16
16
  const itemTypes = [
17
17
  'stores',
18
18
  'views'
19
19
  ];
20
20
  if (!name) {
21
- if (itemTypes.includes(type)) {
21
+ if (type && itemTypes.includes(type)) {
22
22
  log(`\n${cliName} Error: ${type} name is required. Please use 'lex -h' for options.`, 'error', quiet);
23
23
  callback?.(1);
24
24
  return undefined;
@@ -88,7 +88,7 @@ export const copyFiles = async (files, typeName, spinner, config)=>{
88
88
  const { outputFullPath, sourceFullPath } = config;
89
89
  const items = files.map((fileName)=>({
90
90
  from: fileName,
91
- to: pathResolve(outputFullPath, pathRelative(sourceFullPath, fileName))
91
+ to: pathResolve(outputFullPath || process.cwd(), pathRelative(sourceFullPath || process.cwd(), fileName))
92
92
  }));
93
93
  try {
94
94
  spinner.start(`Copying ${typeName} files...`);
@@ -108,7 +108,7 @@ export const copyFiles = async (files, typeName, spinner, config)=>{
108
108
  } catch (error) {
109
109
  spinner.fail(`Copying of ${typeName} files failed.`);
110
110
  log(`Error: ${error.message}`, 'error');
111
- log(error, 'error');
111
+ log(String(error), 'error');
112
112
  }
113
113
  };
114
114
  export const copyConfiguredFiles = async (spinner, config, quiet)=>{
@@ -135,7 +135,7 @@ export const copyConfiguredFiles = async (spinner, config, quiet)=>{
135
135
  }
136
136
  const copyPromises = matchingFiles.map((sourceFile)=>{
137
137
  const relativePath = pathRelative(baseDir, sourceFile);
138
- const destPath = pathResolve(outputFullPath, relativePath);
138
+ const destPath = pathResolve(outputFullPath || process.cwd(), relativePath);
139
139
  const destDir = pathResolve(destPath, '..');
140
140
  mkdirSync(destDir, {
141
141
  recursive: true
@@ -298,4 +298,4 @@ export const updateTemplateName = (filePath, replace, replaceCaps)=>{
298
298
  writeFileSync(filePath, data, 'utf8');
299
299
  };
300
300
 
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\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/).*?(vitest|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};\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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"}
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\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 = '';\n  const itemTypes: string[] = ['stores', 'views'];\n\n  if(!name) {\n    if(type && 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: Spinner, config: LexConfigType) => {\n  const {outputFullPath, sourceFullPath} = config;\n  const items = files.map((fileName: string) => ({\n    from: fileName,\n    to: pathResolve(outputFullPath || process.cwd(), pathRelative(sourceFullPath || process.cwd(), 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(String(error), 'error');\n  }\n};\n\nexport const copyConfiguredFiles = async (spinner: 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 || process.cwd(), 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: Record<string, unknown>) => {\n  const updatedList: Record<string, unknown> = {...moduleList};\n\n  Object.keys(updatedList).forEach((moduleName: string) => {\n    const regex: RegExp = new RegExp('^(?!@types/).*?(vitest|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: unknown, 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};\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","process","cwd","Promise","all","reject","recursive","copyError","length","error","message","String","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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"}
@@ -1,9 +1,17 @@
1
+ /**
2
+ * Copyright (c) 2025-Present, Nitrogen Labs, Inc.
3
+ * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
4
+ *
5
+ * PostCSS 8-compatible version of postcss-for plugin
6
+ * Original: https://github.com/antyakushev/postcss-for
7
+ */
8
+ import postcss from 'postcss';
1
9
  interface PostcssForOptions {
2
10
  nested?: boolean;
3
11
  }
4
12
  declare const postcssFor: {
5
13
  (opts?: PostcssForOptions): {
6
- Once(root: any): void;
14
+ Once(root: postcss.Root): void;
7
15
  postcssPlugin: string;
8
16
  };
9
17
  postcss: boolean;