@nlabs/lex 1.54.2 → 1.54.3

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.
Files changed (46) hide show
  1. package/.github/copilot-instructions.md +4 -4
  2. package/README.md +25 -25
  3. package/__mocks__/LexConfig.js +9 -9
  4. package/__mocks__/boxen.js +1 -1
  5. package/__mocks__/build.js +6 -6
  6. package/__mocks__/compare-versions.js +1 -1
  7. package/__mocks__/compile.js +2 -2
  8. package/__mocks__/execa.js +2 -2
  9. package/__mocks__/latest-version.js +1 -1
  10. package/__mocks__/ora.js +13 -13
  11. package/__mocks__/versions.js +4 -4
  12. package/config.json +2 -2
  13. package/examples/lex.config.js +4 -4
  14. package/lex.config.js +4 -4
  15. package/lib/LexConfig.d.ts +2 -9
  16. package/lib/LexConfig.js +2 -2
  17. package/lib/commands/ai/ai.js +2 -2
  18. package/lib/commands/config/config.js +14 -8
  19. package/lib/commands/migrate/migrate.js +2 -2
  20. package/lib/commands/test/test.d.ts +2 -0
  21. package/lib/commands/test/test.js +130 -117
  22. package/lib/commands/versions/versions.d.ts +1 -1
  23. package/lib/commands/versions/versions.js +3 -3
  24. package/lib/lex.js +2 -2
  25. package/lib/test-react/index.d.ts +1 -1
  26. package/lib/test-react/index.js +2 -2
  27. package/lib/types.d.ts +1 -1
  28. package/lib/types.js +1 -1
  29. package/lib/utils/app.js +2 -2
  30. package/lib/vitest.d.js +3 -0
  31. package/package.json +42 -42
  32. package/resolver.cjs +11 -9
  33. package/tsconfig/reactNative.json +3 -2
  34. package/tsconfig.build.json +3 -3
  35. package/tsconfig.json +4 -3
  36. package/tsconfig.lint.json +3 -2
  37. package/tsconfig.template.json +3 -2
  38. package/tsconfig.test.json +4 -3
  39. package/vitest.config.d.mts +2 -0
  40. package/vitest.config.mjs +61 -0
  41. package/vitest.config.template.cjs +66 -0
  42. package/vitest.setup.template.js +19 -0
  43. package/jest.config.d.mts +0 -50
  44. package/jest.config.mjs +0 -72
  45. package/jest.config.template.cjs +0 -71
  46. package/jest.setup.template.js +0 -18
package/lib/lex.js CHANGED
@@ -78,7 +78,7 @@ program.command('publish').addOption(new Option('--bump <type>', 'Increments the
78
78
  ]).default('npm')).option('--private', 'Publishes the module as restricted.').option('--quiet', 'No Lex notifications printed in the console.').option('--tag <tag>', 'Registers the published package with the given tag.').action((cmd)=>publish(cmd, process.exit).then(()=>{}));
79
79
  program.command('serverless').option('--config <path>', 'Custom configuration file path (default: lex.config.mjs).').option('--host <host>', 'Host to bind the server to (default: localhost).').option('--httpPort <port>', 'HTTP server port (default: 3000).').option('--httpsPort <port>', 'HTTPS server port (default: 3001).').option('--wsPort <port>', 'WebSocket server port (default: 3002).').option('--quiet', 'No Lex notifications printed in the console.').option('--remove', 'Removes all files from the output directory before starting.').option('--usePublicIp', 'Force refresh the cached public IP address.').option('--variables <json>', 'Environment variables to set in process.env.').option('--debug', 'Enable GraphQL debug logging to see queries, variables, and operations.').option('--printOutput', 'Print GraphQL response output including status, headers, and body.').action((cmd)=>serverless(cmd, process.exit).then(()=>{}));
80
80
  program.command('storybook').option('--config <path>', 'Custom Storybook configuration directory path (ie. .storybook).').option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).').option('--open', 'Automatically open Storybook in a new browser window.').option('--port <number>', 'Port number for the Storybook server.').option('--quiet', 'No Lex notifications printed in the console.').option('--static', 'Build a static Storybook site instead of starting dev server.').option('--variables <n>', 'Environment variables to set in "process.env". (ie. "{STORYBOOK_THEME: \'dark\'}").').option('--verbose', 'Show detailed webpack progress output.').action((cmd)=>storybook(cmd, process.exit).then(()=>{}));
81
- program.command('test [files...]').option('--analyze', 'Use AI to analyze test coverage and suggest improvements.', false).option('--debugTests', 'Use AI to debug test failures and suggest fixes.', false).option('--generate', 'Use AI to generate test cases for untested code.', false).option('--bail', 'Exit the test suite immediately upon the first failing test suite.').option('--changedFilesWithAncestor', 'Runs tests related to the current changes and the changes made in the last commit.').option('--changedSince', 'Runs tests related the changes since the provided branch.').option('--ci', 'When this option is provided, Jest will assume it is running in a CI environment.').option('--clearCache', 'Clear Jest cache.').option('--collectCoverageFrom <glob>', 'A glob pattern relative to matching the files that coverage info needs to be collected from.').option('--colors', 'Forces test results output highlighting even if stdout is not a TTY.').option('--config <path>', 'Custom Jest configuration file path (ie. jest.config.js).').option('--debug', 'Print debugging info about your Jest config.').option('--detectOpenHandles', 'Attempt to collect and print open handles preventing Jest from exiting cleanly').option('--environment <n>', 'Target environment. "node" or "web". Default: "node".').option('--env', 'The test environment used for all tests. This can point to any file or node module. Examples: jsdom, node or path/to/my-environment.js.').option('--errorOnDeprecated', 'Make calling deprecated APIs throw helpful error messages.').option('--expand', 'Use this flag to show full diffs and errors instead of a patch.').option('--forceExit', 'Force Jest to exit after all tests have completed running.').option('--json', 'Prints the test results in JSON.').option('--lastCommit', 'Run all tests affected by file changes in the last commit made.').option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).').option('--listTests', 'Lists all tests as JSON that Jest will run given the arguments, and exits.').option('--logHeapUsage', 'Logs the heap usage after every test.').option('--maxWorkers <num>', 'Specifies the maximum number of workers the worker-pool will spawn for running tests. ').option('--noStackTrace', 'Disables stack trace in test results output.').option('--notify', 'Activates notifications for test results.').option('--onlyChanged', 'un based on which files have changed in the current repository. ').option('--outputFile <filename>', 'Write test results to a file when the --json option is also specified.').option('--passWithNoTests', 'Allows the test suite to pass when no files are found.').option('--quiet', 'No Lex notifications printed in the console.').option('--runInBand', 'Run all tests serially in the current process, rather than creating a worker pool of child processes that run tests.').option('--setup <path>', 'Jest setup file path.').option('--showConfig', 'Print your Jest config and then exits.').option('--silent', 'Prevent tests from printing messages through the console.').option('--testLocationInResults', 'Adds a location field to test results.').option('--testNamePattern <regex>', 'Run only tests with a name that matches the regex. ').option('--testPathPattern <regex>', 'A regexp pattern string that is matched against all tests paths before executing the test.').option('--typescript', 'Transpile as Typescript.').option('--update', 'Update snapshots. Runs "jest --updateSnapshots"').option('--useStderr', 'Divert all output to stderr.').option('--verbose', 'Display individual test results with the test suite hierarchy.').option('--watch <path>', 'Watch files for changes and rerun tests related to changed files.').option('--watchAll', 'Watch files for changes and rerun all tests when something changes.').action((files, options, cmd)=>test(options, cmd.args, files, process.exit).then(()=>{}));
81
+ program.command('test [files...]').option('--analyze', 'Use AI to analyze test coverage and suggest improvements.', false).option('--debugTests', 'Use AI to debug test failures and suggest fixes.', false).option('--generate', 'Use AI to generate test cases for untested code.', false).option('--bail', 'Exit the test suite immediately upon the first failing test suite.').option('--changedFilesWithAncestor', 'Runs tests related to the current changes and the changes made in the last commit.').option('--changedSince', 'Runs tests related the changes since the provided branch.').option('--ci', 'When this option is provided, Vitest will assume it is running in a CI environment.').option('--clearCache', 'Clear Vitest cache.').option('--collectCoverageFrom <glob>', 'A glob pattern relative to matching the files that coverage info needs to be collected from.').option('--colors', 'Forces test results output highlighting even if stdout is not a TTY.').option('--config <path>', 'Custom Vitest configuration file path (ie. vitest.config.mjs).').option('--debug', 'Print debugging info about your Vitest config.').option('--detectOpenHandles', 'Attempt to collect and print open handles preventing Vitest from exiting cleanly').option('--environment <n>', 'Target environment. "node" or "web". Default: "node".').option('--env', 'The test environment used for all tests. This can point to any file or node module. Examples: happy-dom, jsdom, node or path/to/my-environment.js.').option('--errorOnDeprecated', 'Make calling deprecated APIs throw helpful error messages.').option('--expand', 'Use this flag to show full diffs and errors instead of a patch.').option('--forceExit', 'Force Vitest to exit after all tests have completed running.').option('--json', 'Prints the test results in JSON.').option('--lastCommit', 'Run all tests affected by file changes in the last commit made.').option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).').option('--listTests', 'Lists all tests as JSON that Vitest will run given the arguments, and exits.').option('--logHeapUsage', 'Logs the heap usage after every test.').option('--maxWorkers <num>', 'Specifies the maximum number of workers the worker-pool will spawn for running tests. ').option('--noStackTrace', 'Disables stack trace in test results output.').option('--notify', 'Activates notifications for test results.').option('--onlyChanged', 'un based on which files have changed in the current repository. ').option('--outputFile <filename>', 'Write test results to a file when the --json option is also specified.').option('--passWithNoTests', 'Allows the test suite to pass when no files are found.').option('--quiet', 'No Lex notifications printed in the console.').option('--runInBand', 'Run all tests serially in the current process, rather than creating a worker pool of child processes that run tests.').option('--setup <path>', 'Vitest setup file path.').option('--showConfig', 'Print your Vitest config and then exits.').option('--silent', 'Prevent tests from printing messages through the console.').option('--testLocationInResults', 'Adds a location field to test results.').option('--testNamePattern <regex>', 'Run only tests with a name that matches the regex. ').option('--testPathPattern <regex>', 'A regexp pattern string that is matched against all tests paths before executing the test.').option('--typescript', 'Transpile as Typescript.').option('--update', 'Update snapshots. Runs "vitest --update"').option('--useStderr', 'Divert all output to stderr.').option('--verbose', 'Display individual test results with the test suite hierarchy.').option('--watch <path>', 'Watch files for changes and rerun tests related to changed files.').option('--watchAll', 'Watch files for changes and rerun all tests when something changes.').action((files, options, cmd)=>test(options, cmd.args, files, process.exit).then(()=>{}));
82
82
  program.command('update').option('--interactive', 'Choose which packages to update.').addOption(new Option('--package-manager <manager>', 'Which package manager to use. Default: npm').choices([
83
83
  'npm',
84
84
  'yarn'
@@ -97,4 +97,4 @@ program.command('ai').option('--context', 'Include project context in the AI pro
97
97
  program.command('versions').option('--json', 'Print the version as a JSON object.').action((cmd)=>versions(cmd, process.exit).then(()=>{}));
98
98
  program.version(packageJson.version).parse(process.argv);
99
99
 
100
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/lex.ts"],"sourcesContent":["#!/usr/bin/env node\n/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {Option, program} from 'commander';\nimport {readFileSync} from 'fs';\nimport {createRequire} from 'module';\nimport {dirname, resolve} from 'path';\nimport {fileURLToPath} from 'url';\n\nimport {aiFunction} from './commands/ai/ai.js';\nimport {build} from './commands/build/build.js';\nimport {clean} from './commands/clean/clean.js';\nimport {compile} from './commands/compile/compile.js';\nimport {config} from './commands/config/config.js';\nimport {create} from './commands/create/create.js';\nimport {dev} from './commands/dev/dev.js';\nimport {init} from './commands/init/init.js';\nimport {linked} from './commands/link/link.js';\nimport {lint} from './commands/lint/lint.js';\nimport {migrate} from './commands/migrate/migrate.js';\nimport {publish} from './commands/publish/publish.js';\nimport {serverless} from './commands/serverless/serverless.js';\nimport {storybook} from './commands/storybook/storybook.js';\nimport {test} from './commands/test/test.js';\nimport {update} from './commands/update/update.js';\nimport {upgrade} from './commands/upgrade/upgrade.js';\nimport {versions} from './commands/versions/versions.js';\n\nprocess.env.LEX_ROOT = dirname(fileURLToPath(import.meta.url));\n\nconst lexNodeModules = resolve(dirname(fileURLToPath(import.meta.url)), '../node_modules');\nif(!process.env.NODE_PATH) {\n  process.env.NODE_PATH = lexNodeModules;\n} else if(!process.env.NODE_PATH.split(':').includes(lexNodeModules)) {\n  process.env.NODE_PATH += `:${lexNodeModules}`;\n}\n\nconst require = createRequire(import.meta.url);\n// eslint-disable-next-line no-underscore-dangle\nrequire('module').Module._initPaths();\n\nconst packagePath = fileURLToPath(new URL('../package.json', import.meta.url));\nconst packageJson = JSON.parse(readFileSync(packagePath, 'utf8'));\n\nprogram.command('build')\n  .option('--assist', 'Enable AI assistance for fixing build errors.', false)\n  .option('--analyze', 'Enable AI analysis for build optimization suggestions or invoke webpack-bundle-analyzer plugin.', false)\n  .addOption(new Option('--bundler <n>', 'Bundler to use (\"webpack\" or \"swc\"). Default: \"swc\".').choices(['webpack', 'swc']).default('swc'))\n  .option('--config <path>', 'Custom Webpack configuration file path (ie. webpack.config.js).')\n  .option('--configName <value...>', 'Name of the configuration to use.')\n  .option('--defineProcessEnvNodeEnv <value>', 'Sets process.env.NODE_ENV to the specified value. (Currently an alias for `--node-env`)')\n  .option('--devtool <value>', 'A developer tool to enhance debugging (false | eval | [inline-|hidden-|eval-][nosources-][cheap-[module-]]source-map).')\n  .option('--disableInterpret', 'Disable interpret for loading the config file.', false)\n  .option('--entry <value...>', 'A module that is loaded upon startup. Only the last one is exported.')\n  .option('--env <value>', 'Environment passed to the configuration when it is a function.')\n  .option('--failOnWarnings', 'Stop webpack-cli process with non-zero exit code on warnings from webpack', false)\n  .addOption(new Option('--format <value>', 'This sets the output format for the generated JavaScript files. Default: \"esm\".').choices(['cjs', 'esm']).default('esm'))\n  .option('--json <value>', 'Prints result as JSON or store it in a file.')\n  .option('--lexConfig <path>', 'Lex configuration file path (lex.config.js).')\n  .option('--merge', 'Merge two or more configurations using \"webpack-merge\".', false)\n  .addOption(new Option('--mode <type>', 'Webpack mode (\"production\" or \"development\"). Default: \"development\".').choices(['development', 'production']).default('development'))\n  .option('--name <value>', 'Name of the configuration. Used when loading multiple configurations.')\n  .option('--noDevtool', 'Negative \"devtool\" option.', false)\n  .option('--noStats', 'Negative \"stats\" option.', false)\n  .option('--noTarget', 'Negative \"target\" option.', false)\n  .option('--noWatch', 'Negative \"watch\" option.', false)\n  .option('--noWatchOptionsStdin', 'Negative \"watch-options-stdin\" option.', false)\n  .option('--nodeEnv <value>', 'Sets process.env.NODE_ENV to the specified value.')\n  .option('--outputPath <value>', 'The output directory as **absolute path** (required).')\n  .option('--quiet', 'No Lex notifications printed in the console.', false)\n  .option('--remove', 'Removes all files from the output directory before compiling.', false)\n  .option('--sourcePath <path>', 'Source path')\n  .option('--stats <value>', 'Stats options object or preset name.')\n  .option('--static', 'Creates static HTML files when building app.', false)\n  .option('--target <value>', 'Environment to build for. Environment to build for. An array of environments to build for all of them when possible.')\n  .option('--translations', 'Process translation files and output flattened JSON.', false)\n  .option('--typescript', 'Transpile as Typescript.', false)\n  .option('--variables <n>', 'Environment variables to set in \"process.env\". (ie. \"{NODE_ENV: \\'production\\'}\").')\n  .option('--watch', 'Watch for changes.', false)\n  .option('--watchOptionsStdin', 'Stop watching when stdin stream has ended.', false)\n  .action((cmd) => build(cmd, process.exit).then(() => {}));\n\nprogram.command('clean')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--snapshots', 'Remove all \"__snapshots__\" directories.')\n  .action((cmd) => clean(cmd, process.exit).then(() => {}));\n\nprogram.command('config <type>')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--json <path>', 'Save output to json file.')\n  .action((type, cmd) => config(type, cmd, process.exit).then(() => {}));\n\nprogram.command('compile')\n  .option('--config <path>', 'Transpiler configuration file path (ie. tsconfig.json).')\n  .option('--environment <n>', 'Target environment. \"node\" or \"web\". Default: \"node\".')\n  .addOption(new Option('--format <value>', 'This sets the output format for the generated JavaScript files. Default: \"esm\".').choices(['cjs', 'esm']).default('esm'))\n  .option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).')\n  .option('--outputPath <path>', 'Output path')\n  .option('--remove', 'Removes all files from the output directory before compiling.')\n  .option('--sourcePath <path>', 'Source path')\n  .option('--typescript', 'Transpile as Typescript.')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--watch', 'Watches for changes and compiles.')\n  .action((cmd) => compile(cmd, process.exit).then(() => {}));\n\nprogram.command('create <type>')\n  .option('--outputFile <path>', 'Output filename.')\n  .option('--outputName <n>', 'Output name.')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--typescript', 'Create Typescript version.')\n  .action((type, cmd) => create(type, cmd, process.exit).then(() => {}));\n\nprogram.command('dev')\n  .option('--bundleAnalyzer', 'Run bundle analyzer.')\n  .option('--config <path>', 'Custom Webpack configuration file path (ie. webpack.config.js).')\n  .addOption(new Option('--format <value>', 'This sets the output format for the generated JavaScript files. Default: \"esm\".').choices(['cjs', 'esm']).default('esm'))\n  .option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).')\n  .option('--open', 'Automatically open dev server in a new browser window.')\n  .option('--outputPath <path>', 'Output path')\n  .option('--port <number>', 'Port number for the development server (default: 3000).')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--remove', 'Removes all files from the output directory before compiling.')\n  .option('--sourcePath <path>', 'Source path')\n  .option('--translations', 'Process translation files and output flattened JSON.', false)\n  .option('--typescript', 'Transpile as Typescript.')\n  .option('--usePublicIp', 'Force refresh the cached public IP address.')\n  .option('--variables <n>', 'Environment variables to set in \"process.env\". (ie. \"{NODE_ENV: \\'development\\'}\").')\n  .option('--watch', 'Watch for changes.')\n  .action((cmd) => dev(cmd, process.exit).then(() => {}));\n\nprogram.command('init <appName> [packageName]')\n  .option('--install', 'Install dependencies.')\n  .addOption(new Option('--package-manager <manager>', 'Which package manager to use. Default: npm').choices(['npm', 'yarn']).default('npm'))\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--typescript', 'Use a Typescript based app.')\n  .action((appName, packageName, cmd) => init(appName, packageName, cmd, process.exit).then(() => {}));\n\nprogram.command('linked')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .action((cmd) => linked(cmd, process.exit).then(() => {}));\n\nprogram.command('lint')\n  .option('--cache', 'Only check changed files. Default: false.', false)\n  .option('--cacheLocation <path>', 'Path to the cache file or directory.')\n  .option('--color', 'Force enabling of color.', false)\n  .option('--config <path>', 'Use this configuration, overriding .eslintrc.* config options if present. If not specified and no local config exists, Lex will use its default config.')\n  .option('--debug', 'Output debugging information.', false)\n  .option('--envInfo', 'Output execution environment information. Default: false.', false)\n  .option('--env <n>', 'Specify environments.')\n  .option('--fix', 'Apply AI fixes after built-in ESLint fixes (same as --fix).', false)\n  .option('--fixDryRun', 'Automatically fix problems without saving the changes to the file system.', false)\n  .option('--fixType <type>', 'Specify the types of fixes to apply (problem, suggestion, layout).')\n  .option('--format <n>', 'Use a specific output format. Default: stylish.')\n  .option('--global <variables>', 'Define global variables.')\n  .option('--ignorePath <path>', 'Specify path of ignore file.')\n  .option('--ignorePattern <pattern>', 'Pattern of files to ignore (in addition to those in .eslintignore).')\n  .option('--init', 'Run config initialization wizard. Default: false.', false)\n  .option('--maxWarnings <num>', 'Number of warnings to trigger nonzero exit code. Default: -1.')\n  .option('--noColor', 'Force disabling of color.', false)\n  .option('--noEslintrc', 'Disable use of configuration from .eslintrc.*.', false)\n  .option('--noIgnore', 'Disable use of ignore files and patterns.', false)\n  .option('--noInlineConfig', 'Prevent comments from changing config or rules.', false)\n  .option('--outputFile <path>', 'Specify file to write report to.')\n  .option('--parser <n>', 'Specify the parser to be used.')\n  .option('--parserOptions <options>', 'Specify parser options.')\n  .option('--plugin <plugins>', 'Specify plugins.')\n  .option('--printConfig <path>', 'Print the configuration for the given file.')\n  .option('--quiet', 'No Lex notifications printed in the console.', false)\n  .option('--remove-comments', 'Remove all comments except TODOs and copyright notices.', false)\n  .option('--reportUnusedDisableDirectives', 'Adds reported errors for unused eslint-disable directives.', false)\n  .option('--resolvePluginsRelativeTo <path>', 'A folder where plugins should be resolved from.')\n  .option('--rule <path>', 'Specify rules.')\n  .option('--rulesdir <path>', 'Use additional rules from this directory.')\n  .option('--stdin', 'Lint code provided on <STDIN> - Default: false.', false)\n  .option('--stdinFilename <n>', 'Specify filename to process STDIN as.')\n  .action((cmd) => lint(cmd, process.exit).then(() => {}));\n\nprogram.command('migrate')\n  .option('-q, --quiet', 'No Lex notifications printed in the console.')\n  .action((cmd) => migrate(cmd, process.exit).then(() => {}));\n\nprogram.command('publish')\n  .addOption(new Option('--bump <type>', 'Increments the version. Types include: major, minor, patch, beta, alpha, rc. Default: \"patch\".').choices(['major', 'minor', 'patch', 'beta', 'alpha', 'rc']).default('patch'))\n  .option('--newVersion <versionNumber>', 'Publish as a specific version.')\n  .option('--otp <code>', 'Provide a two-factor code.')\n  .addOption(new Option('--package-manager <manager>', 'Which package manager to use. Default: npm').choices(['npm', 'yarn']).default('npm'))\n  .option('--private', 'Publishes the module as restricted.')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--tag <tag>', 'Registers the published package with the given tag.')\n  .action((cmd) => publish(cmd, process.exit).then(() => {}));\n\nprogram.command('serverless')\n  .option('--config <path>', 'Custom configuration file path (default: lex.config.mjs).')\n  .option('--host <host>', 'Host to bind the server to (default: localhost).')\n  .option('--httpPort <port>', 'HTTP server port (default: 3000).')\n  .option('--httpsPort <port>', 'HTTPS server port (default: 3001).')\n  .option('--wsPort <port>', 'WebSocket server port (default: 3002).')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--remove', 'Removes all files from the output directory before starting.')\n  .option('--usePublicIp', 'Force refresh the cached public IP address.')\n  .option('--variables <json>', 'Environment variables to set in process.env.')\n  .option('--debug', 'Enable GraphQL debug logging to see queries, variables, and operations.')\n  .option('--printOutput', 'Print GraphQL response output including status, headers, and body.')\n  .action((cmd) => serverless(cmd, process.exit).then(() => {}));\n\nprogram.command('storybook')\n  .option('--config <path>', 'Custom Storybook configuration directory path (ie. .storybook).')\n  .option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).')\n  .option('--open', 'Automatically open Storybook in a new browser window.')\n  .option('--port <number>', 'Port number for the Storybook server.')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--static', 'Build a static Storybook site instead of starting dev server.')\n  .option('--variables <n>', 'Environment variables to set in \"process.env\". (ie. \"{STORYBOOK_THEME: \\'dark\\'}\").')\n  .option('--verbose', 'Show detailed webpack progress output.')\n  .action((cmd) => storybook(cmd, process.exit).then(() => {}));\n\nprogram.command('test [files...]')\n  .option('--analyze', 'Use AI to analyze test coverage and suggest improvements.', false)\n  .option('--debugTests', 'Use AI to debug test failures and suggest fixes.', false)\n  .option('--generate', 'Use AI to generate test cases for untested code.', false)\n  .option('--bail', 'Exit the test suite immediately upon the first failing test suite.')\n  .option('--changedFilesWithAncestor', 'Runs tests related to the current changes and the changes made in the last commit.')\n  .option('--changedSince', 'Runs tests related the changes since the provided branch.')\n  .option('--ci', 'When this option is provided, Jest will assume it is running in a CI environment.')\n  .option('--clearCache', 'Clear Jest cache.')\n  .option('--collectCoverageFrom <glob>', 'A glob pattern relative to matching the files that coverage info needs to be collected from.')\n  .option('--colors', 'Forces test results output highlighting even if stdout is not a TTY.')\n  .option('--config <path>', 'Custom Jest configuration file path (ie. jest.config.js).')\n  .option('--debug', 'Print debugging info about your Jest config.')\n  .option('--detectOpenHandles', 'Attempt to collect and print open handles preventing Jest from exiting cleanly')\n  .option('--environment <n>', 'Target environment. \"node\" or \"web\". Default: \"node\".')\n  .option('--env', 'The test environment used for all tests. This can point to any file or node module. Examples: jsdom, node or path/to/my-environment.js.')\n  .option('--errorOnDeprecated', 'Make calling deprecated APIs throw helpful error messages.')\n  .option('--expand', 'Use this flag to show full diffs and errors instead of a patch.')\n  .option('--forceExit', 'Force Jest to exit after all tests have completed running.')\n  .option('--json', 'Prints the test results in JSON.')\n  .option('--lastCommit', 'Run all tests affected by file changes in the last commit made.')\n  .option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).')\n  .option('--listTests', 'Lists all tests as JSON that Jest will run given the arguments, and exits.')\n  .option('--logHeapUsage', 'Logs the heap usage after every test.')\n  .option('--maxWorkers <num>', 'Specifies the maximum number of workers the worker-pool will spawn for running tests. ')\n  .option('--noStackTrace', 'Disables stack trace in test results output.')\n  .option('--notify', 'Activates notifications for test results.')\n  .option('--onlyChanged', 'un based on which files have changed in the current repository. ')\n  .option('--outputFile <filename>', 'Write test results to a file when the --json option is also specified.')\n  .option('--passWithNoTests', 'Allows the test suite to pass when no files are found.')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--runInBand', 'Run all tests serially in the current process, rather than creating a worker pool of child processes that run tests.')\n  .option('--setup <path>', 'Jest setup file path.')\n  .option('--showConfig', 'Print your Jest config and then exits.')\n  .option('--silent', 'Prevent tests from printing messages through the console.')\n  .option('--testLocationInResults', 'Adds a location field to test results.')\n  .option('--testNamePattern <regex>', 'Run only tests with a name that matches the regex. ')\n  .option('--testPathPattern <regex>', 'A regexp pattern string that is matched against all tests paths before executing the test.')\n  .option('--typescript', 'Transpile as Typescript.')\n  .option('--update', 'Update snapshots. Runs \"jest --updateSnapshots\"')\n  .option('--useStderr', 'Divert all output to stderr.')\n  .option('--verbose', 'Display individual test results with the test suite hierarchy.')\n  .option('--watch <path>', 'Watch files for changes and rerun tests related to changed files.')\n  .option('--watchAll', 'Watch files for changes and rerun all tests when something changes.')\n  .action((files, options, cmd) => test(options, cmd.args, files, process.exit).then(() => {}));\n\nprogram.command('update')\n  .option('--interactive', 'Choose which packages to update.')\n  .addOption(new Option('--package-manager <manager>', 'Which package manager to use. Default: npm').choices(['npm', 'yarn']).default('npm'))\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--registry', 'Add a custom registry url.')\n  .action((cmd) => update(cmd, process.exit).then(() => {}));\n\nprogram.command('upgrade')\n  .addOption(new Option('--package-manager <manager>', 'Which package manager to use. Default: npm').choices(['npm', 'yarn']).default('npm'))\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .action((cmd) => upgrade(cmd, process.exit).then(() => {}));\n\nprogram.command('ai')\n  .option('--context', 'Include project context in the AI prompt.', true)\n  .option('--file <path>', 'Specific file to operate on.')\n  .option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).')\n  .option('--model <model>', 'AI model to use. Default: gpt-4o.')\n  .option('--prompt <text>', 'The prompt to send to the AI.')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .addOption(new Option('--task <task>', 'Type of AI task to perform.').choices(['generate', 'explain', 'test', 'optimize', 'help']).default('help'))\n  .action((cmd) => aiFunction(cmd).then(() => {}));\n\nprogram.command('versions')\n  .option('--json', 'Print the version as a JSON object.')\n  .action((cmd) => versions(cmd, process.exit).then(() => {}));\n\nprogram\n  .version(packageJson.version)\n  .parse(process.argv);"],"names":["Option","program","readFileSync","createRequire","dirname","resolve","fileURLToPath","aiFunction","build","clean","compile","config","create","dev","init","linked","lint","migrate","publish","serverless","storybook","test","update","upgrade","versions","process","env","LEX_ROOT","url","lexNodeModules","NODE_PATH","split","includes","require","Module","_initPaths","packagePath","URL","packageJson","JSON","parse","command","option","addOption","choices","default","action","cmd","exit","then","type","appName","packageName","files","options","args","version","argv"],"mappings":"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"}
100
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/lex.ts"],"sourcesContent":["#!/usr/bin/env node\n/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {Option, program} from 'commander';\nimport {readFileSync} from 'fs';\nimport {createRequire} from 'module';\nimport {dirname, resolve} from 'path';\nimport {fileURLToPath} from 'url';\n\nimport {aiFunction} from './commands/ai/ai.js';\nimport {build} from './commands/build/build.js';\nimport {clean} from './commands/clean/clean.js';\nimport {compile} from './commands/compile/compile.js';\nimport {config} from './commands/config/config.js';\nimport {create} from './commands/create/create.js';\nimport {dev} from './commands/dev/dev.js';\nimport {init} from './commands/init/init.js';\nimport {linked} from './commands/link/link.js';\nimport {lint} from './commands/lint/lint.js';\nimport {migrate} from './commands/migrate/migrate.js';\nimport {publish} from './commands/publish/publish.js';\nimport {serverless} from './commands/serverless/serverless.js';\nimport {storybook} from './commands/storybook/storybook.js';\nimport {test} from './commands/test/test.js';\nimport {update} from './commands/update/update.js';\nimport {upgrade} from './commands/upgrade/upgrade.js';\nimport {versions} from './commands/versions/versions.js';\n\nprocess.env.LEX_ROOT = dirname(fileURLToPath(import.meta.url));\n\nconst lexNodeModules = resolve(dirname(fileURLToPath(import.meta.url)), '../node_modules');\nif(!process.env.NODE_PATH) {\n  process.env.NODE_PATH = lexNodeModules;\n} else if(!process.env.NODE_PATH.split(':').includes(lexNodeModules)) {\n  process.env.NODE_PATH += `:${lexNodeModules}`;\n}\n\nconst require = createRequire(import.meta.url);\n// eslint-disable-next-line no-underscore-dangle\nrequire('module').Module._initPaths();\n\nconst packagePath = fileURLToPath(new URL('../package.json', import.meta.url));\nconst packageJson = JSON.parse(readFileSync(packagePath, 'utf8'));\n\nprogram.command('build')\n  .option('--assist', 'Enable AI assistance for fixing build errors.', false)\n  .option('--analyze', 'Enable AI analysis for build optimization suggestions or invoke webpack-bundle-analyzer plugin.', false)\n  .addOption(new Option('--bundler <n>', 'Bundler to use (\"webpack\" or \"swc\"). Default: \"swc\".').choices(['webpack', 'swc']).default('swc'))\n  .option('--config <path>', 'Custom Webpack configuration file path (ie. webpack.config.js).')\n  .option('--configName <value...>', 'Name of the configuration to use.')\n  .option('--defineProcessEnvNodeEnv <value>', 'Sets process.env.NODE_ENV to the specified value. (Currently an alias for `--node-env`)')\n  .option('--devtool <value>', 'A developer tool to enhance debugging (false | eval | [inline-|hidden-|eval-][nosources-][cheap-[module-]]source-map).')\n  .option('--disableInterpret', 'Disable interpret for loading the config file.', false)\n  .option('--entry <value...>', 'A module that is loaded upon startup. Only the last one is exported.')\n  .option('--env <value>', 'Environment passed to the configuration when it is a function.')\n  .option('--failOnWarnings', 'Stop webpack-cli process with non-zero exit code on warnings from webpack', false)\n  .addOption(new Option('--format <value>', 'This sets the output format for the generated JavaScript files. Default: \"esm\".').choices(['cjs', 'esm']).default('esm'))\n  .option('--json <value>', 'Prints result as JSON or store it in a file.')\n  .option('--lexConfig <path>', 'Lex configuration file path (lex.config.js).')\n  .option('--merge', 'Merge two or more configurations using \"webpack-merge\".', false)\n  .addOption(new Option('--mode <type>', 'Webpack mode (\"production\" or \"development\"). Default: \"development\".').choices(['development', 'production']).default('development'))\n  .option('--name <value>', 'Name of the configuration. Used when loading multiple configurations.')\n  .option('--noDevtool', 'Negative \"devtool\" option.', false)\n  .option('--noStats', 'Negative \"stats\" option.', false)\n  .option('--noTarget', 'Negative \"target\" option.', false)\n  .option('--noWatch', 'Negative \"watch\" option.', false)\n  .option('--noWatchOptionsStdin', 'Negative \"watch-options-stdin\" option.', false)\n  .option('--nodeEnv <value>', 'Sets process.env.NODE_ENV to the specified value.')\n  .option('--outputPath <value>', 'The output directory as **absolute path** (required).')\n  .option('--quiet', 'No Lex notifications printed in the console.', false)\n  .option('--remove', 'Removes all files from the output directory before compiling.', false)\n  .option('--sourcePath <path>', 'Source path')\n  .option('--stats <value>', 'Stats options object or preset name.')\n  .option('--static', 'Creates static HTML files when building app.', false)\n  .option('--target <value>', 'Environment to build for. Environment to build for. An array of environments to build for all of them when possible.')\n  .option('--translations', 'Process translation files and output flattened JSON.', false)\n  .option('--typescript', 'Transpile as Typescript.', false)\n  .option('--variables <n>', 'Environment variables to set in \"process.env\". (ie. \"{NODE_ENV: \\'production\\'}\").')\n  .option('--watch', 'Watch for changes.', false)\n  .option('--watchOptionsStdin', 'Stop watching when stdin stream has ended.', false)\n  .action((cmd) => build(cmd, process.exit).then(() => {}));\n\nprogram.command('clean')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--snapshots', 'Remove all \"__snapshots__\" directories.')\n  .action((cmd) => clean(cmd, process.exit).then(() => {}));\n\nprogram.command('config <type>')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--json <path>', 'Save output to json file.')\n  .action((type, cmd) => config(type, cmd, process.exit).then(() => {}));\n\nprogram.command('compile')\n  .option('--config <path>', 'Transpiler configuration file path (ie. tsconfig.json).')\n  .option('--environment <n>', 'Target environment. \"node\" or \"web\". Default: \"node\".')\n  .addOption(new Option('--format <value>', 'This sets the output format for the generated JavaScript files. Default: \"esm\".').choices(['cjs', 'esm']).default('esm'))\n  .option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).')\n  .option('--outputPath <path>', 'Output path')\n  .option('--remove', 'Removes all files from the output directory before compiling.')\n  .option('--sourcePath <path>', 'Source path')\n  .option('--typescript', 'Transpile as Typescript.')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--watch', 'Watches for changes and compiles.')\n  .action((cmd) => compile(cmd, process.exit).then(() => {}));\n\nprogram.command('create <type>')\n  .option('--outputFile <path>', 'Output filename.')\n  .option('--outputName <n>', 'Output name.')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--typescript', 'Create Typescript version.')\n  .action((type, cmd) => create(type, cmd, process.exit).then(() => {}));\n\nprogram.command('dev')\n  .option('--bundleAnalyzer', 'Run bundle analyzer.')\n  .option('--config <path>', 'Custom Webpack configuration file path (ie. webpack.config.js).')\n  .addOption(new Option('--format <value>', 'This sets the output format for the generated JavaScript files. Default: \"esm\".').choices(['cjs', 'esm']).default('esm'))\n  .option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).')\n  .option('--open', 'Automatically open dev server in a new browser window.')\n  .option('--outputPath <path>', 'Output path')\n  .option('--port <number>', 'Port number for the development server (default: 3000).')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--remove', 'Removes all files from the output directory before compiling.')\n  .option('--sourcePath <path>', 'Source path')\n  .option('--translations', 'Process translation files and output flattened JSON.', false)\n  .option('--typescript', 'Transpile as Typescript.')\n  .option('--usePublicIp', 'Force refresh the cached public IP address.')\n  .option('--variables <n>', 'Environment variables to set in \"process.env\". (ie. \"{NODE_ENV: \\'development\\'}\").')\n  .option('--watch', 'Watch for changes.')\n  .action((cmd) => dev(cmd, process.exit).then(() => {}));\n\nprogram.command('init <appName> [packageName]')\n  .option('--install', 'Install dependencies.')\n  .addOption(new Option('--package-manager <manager>', 'Which package manager to use. Default: npm').choices(['npm', 'yarn']).default('npm'))\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--typescript', 'Use a Typescript based app.')\n  .action((appName, packageName, cmd) => init(appName, packageName, cmd, process.exit).then(() => {}));\n\nprogram.command('linked')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .action((cmd) => linked(cmd, process.exit).then(() => {}));\n\nprogram.command('lint')\n  .option('--cache', 'Only check changed files. Default: false.', false)\n  .option('--cacheLocation <path>', 'Path to the cache file or directory.')\n  .option('--color', 'Force enabling of color.', false)\n  .option('--config <path>', 'Use this configuration, overriding .eslintrc.* config options if present. If not specified and no local config exists, Lex will use its default config.')\n  .option('--debug', 'Output debugging information.', false)\n  .option('--envInfo', 'Output execution environment information. Default: false.', false)\n  .option('--env <n>', 'Specify environments.')\n  .option('--fix', 'Apply AI fixes after built-in ESLint fixes (same as --fix).', false)\n  .option('--fixDryRun', 'Automatically fix problems without saving the changes to the file system.', false)\n  .option('--fixType <type>', 'Specify the types of fixes to apply (problem, suggestion, layout).')\n  .option('--format <n>', 'Use a specific output format. Default: stylish.')\n  .option('--global <variables>', 'Define global variables.')\n  .option('--ignorePath <path>', 'Specify path of ignore file.')\n  .option('--ignorePattern <pattern>', 'Pattern of files to ignore (in addition to those in .eslintignore).')\n  .option('--init', 'Run config initialization wizard. Default: false.', false)\n  .option('--maxWarnings <num>', 'Number of warnings to trigger nonzero exit code. Default: -1.')\n  .option('--noColor', 'Force disabling of color.', false)\n  .option('--noEslintrc', 'Disable use of configuration from .eslintrc.*.', false)\n  .option('--noIgnore', 'Disable use of ignore files and patterns.', false)\n  .option('--noInlineConfig', 'Prevent comments from changing config or rules.', false)\n  .option('--outputFile <path>', 'Specify file to write report to.')\n  .option('--parser <n>', 'Specify the parser to be used.')\n  .option('--parserOptions <options>', 'Specify parser options.')\n  .option('--plugin <plugins>', 'Specify plugins.')\n  .option('--printConfig <path>', 'Print the configuration for the given file.')\n  .option('--quiet', 'No Lex notifications printed in the console.', false)\n  .option('--remove-comments', 'Remove all comments except TODOs and copyright notices.', false)\n  .option('--reportUnusedDisableDirectives', 'Adds reported errors for unused eslint-disable directives.', false)\n  .option('--resolvePluginsRelativeTo <path>', 'A folder where plugins should be resolved from.')\n  .option('--rule <path>', 'Specify rules.')\n  .option('--rulesdir <path>', 'Use additional rules from this directory.')\n  .option('--stdin', 'Lint code provided on <STDIN> - Default: false.', false)\n  .option('--stdinFilename <n>', 'Specify filename to process STDIN as.')\n  .action((cmd) => lint(cmd, process.exit).then(() => {}));\n\nprogram.command('migrate')\n  .option('-q, --quiet', 'No Lex notifications printed in the console.')\n  .action((cmd) => migrate(cmd, process.exit).then(() => {}));\n\nprogram.command('publish')\n  .addOption(new Option('--bump <type>', 'Increments the version. Types include: major, minor, patch, beta, alpha, rc. Default: \"patch\".').choices(['major', 'minor', 'patch', 'beta', 'alpha', 'rc']).default('patch'))\n  .option('--newVersion <versionNumber>', 'Publish as a specific version.')\n  .option('--otp <code>', 'Provide a two-factor code.')\n  .addOption(new Option('--package-manager <manager>', 'Which package manager to use. Default: npm').choices(['npm', 'yarn']).default('npm'))\n  .option('--private', 'Publishes the module as restricted.')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--tag <tag>', 'Registers the published package with the given tag.')\n  .action((cmd) => publish(cmd, process.exit).then(() => {}));\n\nprogram.command('serverless')\n  .option('--config <path>', 'Custom configuration file path (default: lex.config.mjs).')\n  .option('--host <host>', 'Host to bind the server to (default: localhost).')\n  .option('--httpPort <port>', 'HTTP server port (default: 3000).')\n  .option('--httpsPort <port>', 'HTTPS server port (default: 3001).')\n  .option('--wsPort <port>', 'WebSocket server port (default: 3002).')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--remove', 'Removes all files from the output directory before starting.')\n  .option('--usePublicIp', 'Force refresh the cached public IP address.')\n  .option('--variables <json>', 'Environment variables to set in process.env.')\n  .option('--debug', 'Enable GraphQL debug logging to see queries, variables, and operations.')\n  .option('--printOutput', 'Print GraphQL response output including status, headers, and body.')\n  .action((cmd) => serverless(cmd, process.exit).then(() => {}));\n\nprogram.command('storybook')\n  .option('--config <path>', 'Custom Storybook configuration directory path (ie. .storybook).')\n  .option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).')\n  .option('--open', 'Automatically open Storybook in a new browser window.')\n  .option('--port <number>', 'Port number for the Storybook server.')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--static', 'Build a static Storybook site instead of starting dev server.')\n  .option('--variables <n>', 'Environment variables to set in \"process.env\". (ie. \"{STORYBOOK_THEME: \\'dark\\'}\").')\n  .option('--verbose', 'Show detailed webpack progress output.')\n  .action((cmd) => storybook(cmd, process.exit).then(() => {}));\n\nprogram.command('test [files...]')\n  .option('--analyze', 'Use AI to analyze test coverage and suggest improvements.', false)\n  .option('--debugTests', 'Use AI to debug test failures and suggest fixes.', false)\n  .option('--generate', 'Use AI to generate test cases for untested code.', false)\n  .option('--bail', 'Exit the test suite immediately upon the first failing test suite.')\n  .option('--changedFilesWithAncestor', 'Runs tests related to the current changes and the changes made in the last commit.')\n  .option('--changedSince', 'Runs tests related the changes since the provided branch.')\n  .option('--ci', 'When this option is provided, Vitest will assume it is running in a CI environment.')\n  .option('--clearCache', 'Clear Vitest cache.')\n  .option('--collectCoverageFrom <glob>', 'A glob pattern relative to matching the files that coverage info needs to be collected from.')\n  .option('--colors', 'Forces test results output highlighting even if stdout is not a TTY.')\n  .option('--config <path>', 'Custom Vitest configuration file path (ie. vitest.config.mjs).')\n  .option('--debug', 'Print debugging info about your Vitest config.')\n  .option('--detectOpenHandles', 'Attempt to collect and print open handles preventing Vitest from exiting cleanly')\n  .option('--environment <n>', 'Target environment. \"node\" or \"web\". Default: \"node\".')\n  .option('--env', 'The test environment used for all tests. This can point to any file or node module. Examples: happy-dom, jsdom, node or path/to/my-environment.js.')\n  .option('--errorOnDeprecated', 'Make calling deprecated APIs throw helpful error messages.')\n  .option('--expand', 'Use this flag to show full diffs and errors instead of a patch.')\n  .option('--forceExit', 'Force Vitest to exit after all tests have completed running.')\n  .option('--json', 'Prints the test results in JSON.')\n  .option('--lastCommit', 'Run all tests affected by file changes in the last commit made.')\n  .option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).')\n  .option('--listTests', 'Lists all tests as JSON that Vitest will run given the arguments, and exits.')\n  .option('--logHeapUsage', 'Logs the heap usage after every test.')\n  .option('--maxWorkers <num>', 'Specifies the maximum number of workers the worker-pool will spawn for running tests. ')\n  .option('--noStackTrace', 'Disables stack trace in test results output.')\n  .option('--notify', 'Activates notifications for test results.')\n  .option('--onlyChanged', 'un based on which files have changed in the current repository. ')\n  .option('--outputFile <filename>', 'Write test results to a file when the --json option is also specified.')\n  .option('--passWithNoTests', 'Allows the test suite to pass when no files are found.')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--runInBand', 'Run all tests serially in the current process, rather than creating a worker pool of child processes that run tests.')\n  .option('--setup <path>', 'Vitest setup file path.')\n  .option('--showConfig', 'Print your Vitest config and then exits.')\n  .option('--silent', 'Prevent tests from printing messages through the console.')\n  .option('--testLocationInResults', 'Adds a location field to test results.')\n  .option('--testNamePattern <regex>', 'Run only tests with a name that matches the regex. ')\n  .option('--testPathPattern <regex>', 'A regexp pattern string that is matched against all tests paths before executing the test.')\n  .option('--typescript', 'Transpile as Typescript.')\n  .option('--update', 'Update snapshots. Runs \"vitest --update\"')\n  .option('--useStderr', 'Divert all output to stderr.')\n  .option('--verbose', 'Display individual test results with the test suite hierarchy.')\n  .option('--watch <path>', 'Watch files for changes and rerun tests related to changed files.')\n  .option('--watchAll', 'Watch files for changes and rerun all tests when something changes.')\n  .action((files, options, cmd) => test(options, cmd.args, files, process.exit).then(() => {}));\n\nprogram.command('update')\n  .option('--interactive', 'Choose which packages to update.')\n  .addOption(new Option('--package-manager <manager>', 'Which package manager to use. Default: npm').choices(['npm', 'yarn']).default('npm'))\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .option('--registry', 'Add a custom registry url.')\n  .action((cmd) => update(cmd, process.exit).then(() => {}));\n\nprogram.command('upgrade')\n  .addOption(new Option('--package-manager <manager>', 'Which package manager to use. Default: npm').choices(['npm', 'yarn']).default('npm'))\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .action((cmd) => upgrade(cmd, process.exit).then(() => {}));\n\nprogram.command('ai')\n  .option('--context', 'Include project context in the AI prompt.', true)\n  .option('--file <path>', 'Specific file to operate on.')\n  .option('--lexConfig <path>', 'Custom Lex configuration file path (ie. lex.config.js).')\n  .option('--model <model>', 'AI model to use. Default: gpt-4o.')\n  .option('--prompt <text>', 'The prompt to send to the AI.')\n  .option('--quiet', 'No Lex notifications printed in the console.')\n  .addOption(new Option('--task <task>', 'Type of AI task to perform.').choices(['generate', 'explain', 'test', 'optimize', 'help']).default('help'))\n  .action((cmd) => aiFunction(cmd).then(() => {}));\n\nprogram.command('versions')\n  .option('--json', 'Print the version as a JSON object.')\n  .action((cmd) => versions(cmd, process.exit).then(() => {}));\n\nprogram\n  .version(packageJson.version)\n  .parse(process.argv);\n"],"names":["Option","program","readFileSync","createRequire","dirname","resolve","fileURLToPath","aiFunction","build","clean","compile","config","create","dev","init","linked","lint","migrate","publish","serverless","storybook","test","update","upgrade","versions","process","env","LEX_ROOT","url","lexNodeModules","NODE_PATH","split","includes","require","Module","_initPaths","packagePath","URL","packageJson","JSON","parse","command","option","addOption","choices","default","action","cmd","exit","then","type","appName","packageName","files","options","args","version","argv"],"mappings":"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"}
@@ -2,5 +2,5 @@
2
2
  * Copyright (c) 2025-Present, Nitrogen Labs, Inc.
3
3
  * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
4
4
  */
5
- import '@testing-library/jest-dom';
5
+ import '@testing-library/jest-dom/vitest';
6
6
  export { render, screen, fireEvent, waitFor, waitForElementToBeRemoved, within, getByRole, getByLabelText, getByPlaceholderText, getByText, getByTestId, getAllByRole, getAllByLabelText, getAllByPlaceholderText, getAllByText, getAllByTestId, queryByRole, queryByLabelText, queryByPlaceholderText, queryByText, queryByTestId, queryAllByRole, queryAllByLabelText, queryAllByPlaceholderText, queryAllByText, queryAllByTestId, findByRole, findByLabelText, findByPlaceholderText, findByText, findByTestId, findAllByRole, findAllByLabelText, findAllByPlaceholderText, findAllByText, findAllByTestId, renderHook, act, cleanup } from '@testing-library/react';
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * Copyright (c) 2025-Present, Nitrogen Labs, Inc.
3
3
  * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
4
- */ import '@testing-library/jest-dom';
4
+ */ import '@testing-library/jest-dom/vitest';
5
5
  export { render, screen, fireEvent, waitFor, waitForElementToBeRemoved, within, getByRole, getByLabelText, getByPlaceholderText, getByText, getByTestId, getAllByRole, getAllByLabelText, getAllByPlaceholderText, getAllByText, getAllByTestId, queryByRole, queryByLabelText, queryByPlaceholderText, queryByText, queryByTestId, queryAllByRole, queryAllByLabelText, queryAllByPlaceholderText, queryAllByText, queryAllByTestId, findByRole, findByLabelText, findByPlaceholderText, findByText, findByTestId, findAllByRole, findAllByLabelText, findAllByPlaceholderText, findAllByText, findAllByTestId, renderHook, act, cleanup } from '@testing-library/react';
6
6
 
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90ZXN0LXJlYWN0L2luZGV4LnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDI1LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQgJ0B0ZXN0aW5nLWxpYnJhcnkvamVzdC1kb20nO1xuXG5leHBvcnQge1xuICByZW5kZXIsXG4gIHNjcmVlbixcbiAgZmlyZUV2ZW50LFxuICB3YWl0Rm9yLFxuICB3YWl0Rm9yRWxlbWVudFRvQmVSZW1vdmVkLFxuICB3aXRoaW4sXG4gIGdldEJ5Um9sZSxcbiAgZ2V0QnlMYWJlbFRleHQsXG4gIGdldEJ5UGxhY2Vob2xkZXJUZXh0LFxuICBnZXRCeVRleHQsXG4gIGdldEJ5VGVzdElkLFxuICBnZXRBbGxCeVJvbGUsXG4gIGdldEFsbEJ5TGFiZWxUZXh0LFxuICBnZXRBbGxCeVBsYWNlaG9sZGVyVGV4dCxcbiAgZ2V0QWxsQnlUZXh0LFxuICBnZXRBbGxCeVRlc3RJZCxcbiAgcXVlcnlCeVJvbGUsXG4gIHF1ZXJ5QnlMYWJlbFRleHQsXG4gIHF1ZXJ5QnlQbGFjZWhvbGRlclRleHQsXG4gIHF1ZXJ5QnlUZXh0LFxuICBxdWVyeUJ5VGVzdElkLFxuICBxdWVyeUFsbEJ5Um9sZSxcbiAgcXVlcnlBbGxCeUxhYmVsVGV4dCxcbiAgcXVlcnlBbGxCeVBsYWNlaG9sZGVyVGV4dCxcbiAgcXVlcnlBbGxCeVRleHQsXG4gIHF1ZXJ5QWxsQnlUZXN0SWQsXG4gIGZpbmRCeVJvbGUsXG4gIGZpbmRCeUxhYmVsVGV4dCxcbiAgZmluZEJ5UGxhY2Vob2xkZXJUZXh0LFxuICBmaW5kQnlUZXh0LFxuICBmaW5kQnlUZXN0SWQsXG4gIGZpbmRBbGxCeVJvbGUsXG4gIGZpbmRBbGxCeUxhYmVsVGV4dCxcbiAgZmluZEFsbEJ5UGxhY2Vob2xkZXJUZXh0LFxuICBmaW5kQWxsQnlUZXh0LFxuICBmaW5kQWxsQnlUZXN0SWQsXG4gIHJlbmRlckhvb2ssXG4gIGFjdCxcbiAgY2xlYW51cFxufSBmcm9tICdAdGVzdGluZy1saWJyYXJ5L3JlYWN0JzsiXSwibmFtZXMiOlsicmVuZGVyIiwic2NyZWVuIiwiZmlyZUV2ZW50Iiwid2FpdEZvciIsIndhaXRGb3JFbGVtZW50VG9CZVJlbW92ZWQiLCJ3aXRoaW4iLCJnZXRCeVJvbGUiLCJnZXRCeUxhYmVsVGV4dCIsImdldEJ5UGxhY2Vob2xkZXJUZXh0IiwiZ2V0QnlUZXh0IiwiZ2V0QnlUZXN0SWQiLCJnZXRBbGxCeVJvbGUiLCJnZXRBbGxCeUxhYmVsVGV4dCIsImdldEFsbEJ5UGxhY2Vob2xkZXJUZXh0IiwiZ2V0QWxsQnlUZXh0IiwiZ2V0QWxsQnlUZXN0SWQiLCJxdWVyeUJ5Um9sZSIsInF1ZXJ5QnlMYWJlbFRleHQiLCJxdWVyeUJ5UGxhY2Vob2xkZXJUZXh0IiwicXVlcnlCeVRleHQiLCJxdWVyeUJ5VGVzdElkIiwicXVlcnlBbGxCeVJvbGUiLCJxdWVyeUFsbEJ5TGFiZWxUZXh0IiwicXVlcnlBbGxCeVBsYWNlaG9sZGVyVGV4dCIsInF1ZXJ5QWxsQnlUZXh0IiwicXVlcnlBbGxCeVRlc3RJZCIsImZpbmRCeVJvbGUiLCJmaW5kQnlMYWJlbFRleHQiLCJmaW5kQnlQbGFjZWhvbGRlclRleHQiLCJmaW5kQnlUZXh0IiwiZmluZEJ5VGVzdElkIiwiZmluZEFsbEJ5Um9sZSIsImZpbmRBbGxCeUxhYmVsVGV4dCIsImZpbmRBbGxCeVBsYWNlaG9sZGVyVGV4dCIsImZpbmRBbGxCeVRleHQiLCJmaW5kQWxsQnlUZXN0SWQiLCJyZW5kZXJIb29rIiwiYWN0IiwiY2xlYW51cCJdLCJtYXBwaW5ncyI6IkFBQUE7OztDQUdDLEdBQ0QsT0FBTyw0QkFBNEI7QUFFbkMsU0FDRUEsTUFBTSxFQUNOQyxNQUFNLEVBQ05DLFNBQVMsRUFDVEMsT0FBTyxFQUNQQyx5QkFBeUIsRUFDekJDLE1BQU0sRUFDTkMsU0FBUyxFQUNUQyxjQUFjLEVBQ2RDLG9CQUFvQixFQUNwQkMsU0FBUyxFQUNUQyxXQUFXLEVBQ1hDLFlBQVksRUFDWkMsaUJBQWlCLEVBQ2pCQyx1QkFBdUIsRUFDdkJDLFlBQVksRUFDWkMsY0FBYyxFQUNkQyxXQUFXLEVBQ1hDLGdCQUFnQixFQUNoQkMsc0JBQXNCLEVBQ3RCQyxXQUFXLEVBQ1hDLGFBQWEsRUFDYkMsY0FBYyxFQUNkQyxtQkFBbUIsRUFDbkJDLHlCQUF5QixFQUN6QkMsY0FBYyxFQUNkQyxnQkFBZ0IsRUFDaEJDLFVBQVUsRUFDVkMsZUFBZSxFQUNmQyxxQkFBcUIsRUFDckJDLFVBQVUsRUFDVkMsWUFBWSxFQUNaQyxhQUFhLEVBQ2JDLGtCQUFrQixFQUNsQkMsd0JBQXdCLEVBQ3hCQyxhQUFhLEVBQ2JDLGVBQWUsRUFDZkMsVUFBVSxFQUNWQyxHQUFHLEVBQ0hDLE9BQU8sUUFDRix5QkFBeUIifQ==
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90ZXN0LXJlYWN0L2luZGV4LnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDI1LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQgJ0B0ZXN0aW5nLWxpYnJhcnkvamVzdC1kb20vdml0ZXN0JztcblxuZXhwb3J0IHtcbiAgcmVuZGVyLFxuICBzY3JlZW4sXG4gIGZpcmVFdmVudCxcbiAgd2FpdEZvcixcbiAgd2FpdEZvckVsZW1lbnRUb0JlUmVtb3ZlZCxcbiAgd2l0aGluLFxuICBnZXRCeVJvbGUsXG4gIGdldEJ5TGFiZWxUZXh0LFxuICBnZXRCeVBsYWNlaG9sZGVyVGV4dCxcbiAgZ2V0QnlUZXh0LFxuICBnZXRCeVRlc3RJZCxcbiAgZ2V0QWxsQnlSb2xlLFxuICBnZXRBbGxCeUxhYmVsVGV4dCxcbiAgZ2V0QWxsQnlQbGFjZWhvbGRlclRleHQsXG4gIGdldEFsbEJ5VGV4dCxcbiAgZ2V0QWxsQnlUZXN0SWQsXG4gIHF1ZXJ5QnlSb2xlLFxuICBxdWVyeUJ5TGFiZWxUZXh0LFxuICBxdWVyeUJ5UGxhY2Vob2xkZXJUZXh0LFxuICBxdWVyeUJ5VGV4dCxcbiAgcXVlcnlCeVRlc3RJZCxcbiAgcXVlcnlBbGxCeVJvbGUsXG4gIHF1ZXJ5QWxsQnlMYWJlbFRleHQsXG4gIHF1ZXJ5QWxsQnlQbGFjZWhvbGRlclRleHQsXG4gIHF1ZXJ5QWxsQnlUZXh0LFxuICBxdWVyeUFsbEJ5VGVzdElkLFxuICBmaW5kQnlSb2xlLFxuICBmaW5kQnlMYWJlbFRleHQsXG4gIGZpbmRCeVBsYWNlaG9sZGVyVGV4dCxcbiAgZmluZEJ5VGV4dCxcbiAgZmluZEJ5VGVzdElkLFxuICBmaW5kQWxsQnlSb2xlLFxuICBmaW5kQWxsQnlMYWJlbFRleHQsXG4gIGZpbmRBbGxCeVBsYWNlaG9sZGVyVGV4dCxcbiAgZmluZEFsbEJ5VGV4dCxcbiAgZmluZEFsbEJ5VGVzdElkLFxuICByZW5kZXJIb29rLFxuICBhY3QsXG4gIGNsZWFudXBcbn0gZnJvbSAnQHRlc3RpbmctbGlicmFyeS9yZWFjdCc7XG4iXSwibmFtZXMiOlsicmVuZGVyIiwic2NyZWVuIiwiZmlyZUV2ZW50Iiwid2FpdEZvciIsIndhaXRGb3JFbGVtZW50VG9CZVJlbW92ZWQiLCJ3aXRoaW4iLCJnZXRCeVJvbGUiLCJnZXRCeUxhYmVsVGV4dCIsImdldEJ5UGxhY2Vob2xkZXJUZXh0IiwiZ2V0QnlUZXh0IiwiZ2V0QnlUZXN0SWQiLCJnZXRBbGxCeVJvbGUiLCJnZXRBbGxCeUxhYmVsVGV4dCIsImdldEFsbEJ5UGxhY2Vob2xkZXJUZXh0IiwiZ2V0QWxsQnlUZXh0IiwiZ2V0QWxsQnlUZXN0SWQiLCJxdWVyeUJ5Um9sZSIsInF1ZXJ5QnlMYWJlbFRleHQiLCJxdWVyeUJ5UGxhY2Vob2xkZXJUZXh0IiwicXVlcnlCeVRleHQiLCJxdWVyeUJ5VGVzdElkIiwicXVlcnlBbGxCeVJvbGUiLCJxdWVyeUFsbEJ5TGFiZWxUZXh0IiwicXVlcnlBbGxCeVBsYWNlaG9sZGVyVGV4dCIsInF1ZXJ5QWxsQnlUZXh0IiwicXVlcnlBbGxCeVRlc3RJZCIsImZpbmRCeVJvbGUiLCJmaW5kQnlMYWJlbFRleHQiLCJmaW5kQnlQbGFjZWhvbGRlclRleHQiLCJmaW5kQnlUZXh0IiwiZmluZEJ5VGVzdElkIiwiZmluZEFsbEJ5Um9sZSIsImZpbmRBbGxCeUxhYmVsVGV4dCIsImZpbmRBbGxCeVBsYWNlaG9sZGVyVGV4dCIsImZpbmRBbGxCeVRleHQiLCJmaW5kQWxsQnlUZXN0SWQiLCJyZW5kZXJIb29rIiwiYWN0IiwiY2xlYW51cCJdLCJtYXBwaW5ncyI6IkFBQUE7OztDQUdDLEdBQ0QsT0FBTyxtQ0FBbUM7QUFFMUMsU0FDRUEsTUFBTSxFQUNOQyxNQUFNLEVBQ05DLFNBQVMsRUFDVEMsT0FBTyxFQUNQQyx5QkFBeUIsRUFDekJDLE1BQU0sRUFDTkMsU0FBUyxFQUNUQyxjQUFjLEVBQ2RDLG9CQUFvQixFQUNwQkMsU0FBUyxFQUNUQyxXQUFXLEVBQ1hDLFlBQVksRUFDWkMsaUJBQWlCLEVBQ2pCQyx1QkFBdUIsRUFDdkJDLFlBQVksRUFDWkMsY0FBYyxFQUNkQyxXQUFXLEVBQ1hDLGdCQUFnQixFQUNoQkMsc0JBQXNCLEVBQ3RCQyxXQUFXLEVBQ1hDLGFBQWEsRUFDYkMsY0FBYyxFQUNkQyxtQkFBbUIsRUFDbkJDLHlCQUF5QixFQUN6QkMsY0FBYyxFQUNkQyxnQkFBZ0IsRUFDaEJDLFVBQVUsRUFDVkMsZUFBZSxFQUNmQyxxQkFBcUIsRUFDckJDLFVBQVUsRUFDVkMsWUFBWSxFQUNaQyxhQUFhLEVBQ2JDLGtCQUFrQixFQUNsQkMsd0JBQXdCLEVBQ3hCQyxhQUFhLEVBQ2JDLGVBQWUsRUFDZkMsVUFBVSxFQUNWQyxHQUFHLEVBQ0hDLE9BQU8sUUFDRix5QkFBeUIifQ==
package/lib/types.d.ts CHANGED
@@ -2,4 +2,4 @@
2
2
  * Copyright (c) 2018-Present, Nitrogen Labs, Inc.
3
3
  * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
4
4
  */
5
- export type { AIConfig, Config, JestConfig, LexConfigType, SWCOptions, WebpackConfig } from './LexConfig.js';
5
+ export type { AIConfig, Config, VitestConfig, LexConfigType, SWCOptions, WebpackConfig } from './LexConfig.js';
package/lib/types.js CHANGED
@@ -4,4 +4,4 @@
4
4
  */ // Re-export all types from LexConfig
5
5
  export { };
6
6
 
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy90eXBlcy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuXG4vLyBSZS1leHBvcnQgYWxsIHR5cGVzIGZyb20gTGV4Q29uZmlnXG5leHBvcnQgdHlwZSB7XG4gIEFJQ29uZmlnLFxuICBDb25maWcsXG4gIEplc3RDb25maWcsXG4gIExleENvbmZpZ1R5cGUsXG4gIFNXQ09wdGlvbnMsXG4gIFdlYnBhY2tDb25maWdcbn0gZnJvbSAnLi9MZXhDb25maWcuanMnOyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7O0NBR0MsR0FFRCxxQ0FBcUM7QUFDckMsV0FPd0IifQ==
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy90eXBlcy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuXG4vLyBSZS1leHBvcnQgYWxsIHR5cGVzIGZyb20gTGV4Q29uZmlnXG5leHBvcnQgdHlwZSB7XG4gIEFJQ29uZmlnLFxuICBDb25maWcsXG4gIFZpdGVzdENvbmZpZyxcbiAgTGV4Q29uZmlnVHlwZSxcbiAgU1dDT3B0aW9ucyxcbiAgV2VicGFja0NvbmZpZ1xufSBmcm9tICcuL0xleENvbmZpZy5qcyc7XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7OztDQUdDLEdBRUQscUNBQXFDO0FBQ3JDLFdBT3dCIn0=
package/lib/utils/app.js CHANGED
@@ -210,7 +210,7 @@ export const removeConflictModules = (moduleList)=>{
210
210
  ...moduleList
211
211
  };
212
212
  Object.keys(updatedList).forEach((moduleName)=>{
213
- const regex = new RegExp('^(?!@types/).*?(jest|webpack).*$', 'gi');
213
+ const regex = new RegExp('^(?!@types/).*?(vitest|webpack).*$', 'gi');
214
214
  if (regex.test(moduleName)) {
215
215
  delete updatedList[moduleName];
216
216
  }
@@ -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\n\nimport {log} from './log.js';\n\nimport type {LexConfigType} from '../LexConfig.js';\n\n\nexport interface GetFilenamesProps {\n  readonly callback?: (status: number)=> void;\n  readonly cliName?: string;\n  readonly name?: string;\n  readonly quiet?: boolean;\n  readonly type?: string;\n  readonly useTypescript?: boolean;\n}\n\ninterface FilenamesResult {\n  nameCaps: string;\n  templateExt: string;\n  templatePath: string;\n  templateReact: string;\n}\n\nexport const getFilenames = (props: GetFilenamesProps): FilenamesResult | undefined => {\n  const {callback, cliName, name, quiet, type, useTypescript} = props;\n\n  let nameCaps: string;\n  const itemTypes: string[] = ['stores', 'views'];\n\n  if(!name) {\n    if(itemTypes.includes(type)) {\n      log(`\\n${cliName} Error: ${type} name is required. Please use 'lex -h' for options.`, 'error', quiet);\n      callback?.(1);\n      return undefined;\n    }\n  } else {\n    nameCaps = `${name.charAt(0).toUpperCase()}${name.substr(1)}`;\n  }\n\n  log(`${cliName} adding ${name} ${type}...`, 'info', quiet);\n\n  let templatePath: string;\n  let templateExt: string;\n  let templateReact: string;\n\n  if(useTypescript) {\n    templatePath = '../../templates/typescript';\n    templateExt = '.ts';\n    templateReact = '.tsx';\n  } else {\n    templatePath = '../../templates/flow';\n    templateExt = '.js';\n    templateReact = '.js';\n  }\n\n  return {\n    nameCaps,\n    templateExt,\n    templatePath,\n    templateReact\n  };\n};\n\nexport interface Spinner {\n  fail: (text?: string)=> void;\n  start: (text?: string)=> void;\n  succeed: (text?: string)=> void;\n  text?: string;\n}\n\nexport const createSpinner = (quiet = false): Spinner => {\n  if(quiet) {\n    return {\n      fail: () => {},\n      start: () => {},\n      succeed: () => {}\n    };\n  }\n\n  return ora({color: 'yellow'});\n};\n\nexport const createProgressBar = (percentage: number): string => {\n  const width = 20;\n  const filled = Math.round((percentage / 100) * width);\n  const empty = width - filled;\n\n  const filledBar = chalk.cyan('█').repeat(filled);\n  const emptyBar = chalk.gray('░').repeat(empty);\n\n  return filledBar + emptyBar;\n};\n\nexport const handleWebpackProgress = (\n  output: string,\n  spinner: Spinner,\n  quiet: boolean,\n  emoji: string,\n  action: string\n): void => {\n  if(quiet) {\n    return;\n  }\n\n  const progressMatch = output.match(/\\[webpack\\.Progress\\] (\\d+)%/);\n  if(progressMatch) {\n    const progress = parseInt(progressMatch[1]);\n    const progressBar = createProgressBar(progress);\n    spinner.text = `${emoji} ${action}: ${progressBar} ${progress}%`;\n  } else if(output.includes('[webpack.Progress]')) {\n    const generalProgressMatch = output.match(/(\\d+)%/);\n    if(generalProgressMatch) {\n      const progress = parseInt(generalProgressMatch[1]);\n      const progressBar = createProgressBar(progress);\n      spinner.text = `${emoji} ${action}: ${progressBar} ${progress}%`;\n    }\n  }\n};\n\nexport const copyFiles = async (files: string[], typeName: string, spinner, config: LexConfigType) => {\n  const {outputFullPath, sourceFullPath} = config;\n  const items = files.map((fileName: string) => ({\n    from: fileName,\n    to: pathResolve(outputFullPath, pathRelative(sourceFullPath, fileName))\n  }));\n\n  try {\n    spinner.start(`Copying ${typeName} files...`);\n    await Promise.all(items.map(({from, to}) => new Promise(\n      (resolve, reject) => {\n        mkdirSync(pathResolve(to, '..'), {recursive: true});\n        return copyFile(from, to, (copyError) => {\n          if(copyError) {\n            reject();\n          } else {\n            resolve(true);\n          }\n        });\n      }\n    )));\n    spinner.succeed(`Successfully copied ${files.length} ${typeName} files!`);\n  } catch(error) {\n    spinner.fail(`Copying of ${typeName} files failed.`);\n    log(`Error: ${error.message}`, 'error');\n    log(error, 'error');\n  }\n};\n\nexport const copyConfiguredFiles = async (spinner, config: LexConfigType, quiet: boolean) => {\n  const {copyFiles: copyFilesConfig, outputFullPath, sourceFullPath, sourcePath} = config;\n  if(!copyFilesConfig || copyFilesConfig.length === 0) {\n    return;\n  }\n\n  try {\n    spinner.start('Copying configured files...');\n    let totalCopied = 0;\n\n    const baseDir = sourceFullPath || (sourcePath ? pathResolve(process.cwd(), sourcePath) : process.cwd());\n    const allCopyPromises: Promise<unknown>[] = [];\n\n    for(const pattern of copyFilesConfig) {\n      const resolvedPattern = pathResolve(baseDir, pattern);\n      const matchingFiles = globSync(resolvedPattern, {\n        absolute: true,\n        nodir: true\n      });\n\n      if(matchingFiles.length === 0) {\n        if(!quiet) {\n          log(`Warning: No files found matching pattern: ${pattern}`, 'warn', quiet);\n        }\n        continue;\n      }\n\n      const copyPromises = matchingFiles.map((sourceFile) => {\n        const relativePath = pathRelative(baseDir, sourceFile);\n        const destPath = pathResolve(outputFullPath, relativePath);\n        const destDir = pathResolve(destPath, '..');\n        mkdirSync(destDir, {recursive: true});\n\n        return new Promise((resolve, reject) => {\n          copyFile(sourceFile, destPath, (copyError) => {\n            if(copyError) {\n              reject(copyError);\n            } else {\n              resolve(true);\n            }\n          });\n        });\n      });\n\n      allCopyPromises.push(...copyPromises);\n      totalCopied += matchingFiles.length;\n    }\n\n    await Promise.all(allCopyPromises);\n\n    if(totalCopied > 0) {\n      spinner.succeed(`Successfully copied ${totalCopied} configured files!`);\n    } else {\n      spinner.succeed('No configured files to copy');\n    }\n  } catch(error) {\n    spinner.fail('Failed to copy configured files');\n    log(`Error copying configured files: ${error.message}`, 'error', quiet);\n    throw error;\n  }\n};\n\nexport const copyFileSync = (source: string, target: string) => {\n  let targetFile: string = target;\n\n  if(existsSync(target)) {\n    if(lstatSync(target).isDirectory()) {\n      targetFile = pathJoin(target, pathBasename(source));\n    }\n  }\n\n  writeFileSync(targetFile, readFileSync(source));\n};\n\nexport const copyFolderRecursiveSync = (source: string, target: string): void => {\n  let files: string[] = [];\n\n  const targetFolder: string = pathJoin(target, pathBasename(source));\n\n  if(!existsSync(targetFolder)) {\n    mkdirSync(targetFolder);\n  }\n\n  if(lstatSync(source).isDirectory()) {\n    files = readdirSync(source);\n    files.forEach((file: string) => {\n      const curSource: string = pathJoin(source, file);\n\n      if(lstatSync(curSource).isDirectory()) {\n        copyFolderRecursiveSync(curSource, targetFolder);\n      } else {\n        copyFileSync(curSource, targetFolder);\n      }\n    });\n  }\n};\n\nexport const getPackageJson = (packagePath?: string) => {\n  const formatPath: string = packagePath || `${process.cwd()}/package.json`;\n  const packageData: string = readFileSync(formatPath).toString();\n\n  return JSON.parse(packageData);\n};\n\nexport const getFilesByExt = (ext: string, config: LexConfigType): string[] => {\n  const {sourceFullPath} = config;\n  return globSync(`**/**${ext}`, {\n    absolute: true,\n    cwd: sourceFullPath,\n    nodir: true\n  });\n};\n\nexport const removeConflictModules = (moduleList: object) => {\n  const updatedList: object = {...moduleList};\n\n  Object.keys(updatedList).forEach((moduleName: string) => {\n    const regex: RegExp = new RegExp('^(?!@types/).*?(jest|webpack).*$', 'gi');\n    if(regex.test(moduleName)) {\n      delete updatedList[moduleName];\n    }\n  });\n\n  return updatedList;\n};\n\nexport const removeFiles = (fileName: string, isRelative: boolean = false) => new Promise((resolve, reject) => {\n  const filePath: string = isRelative ? pathResolve(process.cwd(), fileName) : fileName;\n\n  try {\n    rimrafSync(filePath);\n    return resolve(null);\n  } catch(error) {\n    return reject(error);\n  }\n});\n\nexport const removeModules = () => new Promise(async (resolve, reject) => {\n  try {\n    await removeFiles('./node_modules', true);\n    await removeFiles('./yarn.lock', true);\n    await removeFiles('./package-lock.json', true);\n\n    resolve(null);\n  } catch(error) {\n    reject(error);\n  }\n});\n\nexport const setPackageJson = (json, packagePath?: string) => {\n  if(!json) {\n    return;\n  }\n\n  const formatPath: string = packagePath || `${process.cwd()}/package.json`;\n\n  writeFileSync(formatPath, JSON.stringify(json, null, 2));\n};\n\nexport interface LinkedModuleType {\n  readonly name: string;\n  readonly path: string;\n}\n\nexport const linkedModules = (startPath?: string): LinkedModuleType[] => {\n  const workingPath: string = startPath || process.cwd();\n  let modulePath: string;\n  let prefix: string;\n\n  if(workingPath.includes('@')) {\n    prefix = `@${workingPath.split('@').pop()}`;\n    modulePath = workingPath;\n  } else {\n    modulePath = pathJoin(workingPath, 'node_modules');\n  }\n\n  const foundPaths: string[] = globSync('*', {\n    absolute: true,\n    cwd: modulePath,\n    nodir: false\n  });\n\n  return foundPaths.reduce((list: LinkedModuleType[], foundPath: string) => {\n    try {\n      const stats = lstatSync(foundPath);\n\n      if(stats.isDirectory()) {\n        const deepList: LinkedModuleType[] = linkedModules(foundPath);\n        list.push(...deepList);\n      } else if(stats.isSymbolicLink()) {\n        const moduleNames: string[] = ([prefix, pathBasename(foundPath)]).filter((item: string) => !isEmpty(item));\n        list.push({name: `${moduleNames.join('/')}`, path: foundPath});\n      }\n\n      return list;\n    } catch{\n      return list;\n    }\n  }, []);\n};\n\nexport const checkLinkedModules = () => {\n  const linked = linkedModules();\n\n  if(linked.length) {\n    const msgModule: string = linked.length > 1 ? 'Modules' : 'Module';\n    const linkedMsg: string = linked.reduce(\n      (msg: string, linkedModule: LinkedModuleType) =>\n        `${msg}\\n * ${linkedModule.name}`,\n      `Linked ${msgModule}:`\n    );\n\n    log(boxen(linkedMsg, {dimBorder: true, padding: 1}), 'warn');\n  }\n};\n\nexport const updateTemplateName = (filePath: string, replace: string, replaceCaps: string) => {\n  let data: string = readFileSync(filePath, 'utf8');\n  data = data.replace(/sample/g, replace);\n  data = data.replace(/Sample/g, replaceCaps);\n  writeFileSync(filePath, data, 'utf8');\n};"],"names":["boxen","chalk","copyFile","existsSync","lstatSync","mkdirSync","readdirSync","readFileSync","writeFileSync","sync","globSync","isEmpty","ora","basename","pathBasename","join","pathJoin","relative","pathRelative","resolve","pathResolve","rimrafSync","log","getFilenames","props","callback","cliName","name","quiet","type","useTypescript","nameCaps","itemTypes","includes","undefined","charAt","toUpperCase","substr","templatePath","templateExt","templateReact","createSpinner","fail","start","succeed","color","createProgressBar","percentage","width","filled","Math","round","empty","filledBar","cyan","repeat","emptyBar","gray","handleWebpackProgress","output","spinner","emoji","action","progressMatch","match","progress","parseInt","progressBar","text","generalProgressMatch","copyFiles","files","typeName","config","outputFullPath","sourceFullPath","items","map","fileName","from","to","Promise","all","reject","recursive","copyError","length","error","message","copyConfiguredFiles","copyFilesConfig","sourcePath","totalCopied","baseDir","process","cwd","allCopyPromises","pattern","resolvedPattern","matchingFiles","absolute","nodir","copyPromises","sourceFile","relativePath","destPath","destDir","push","copyFileSync","source","target","targetFile","isDirectory","copyFolderRecursiveSync","targetFolder","forEach","file","curSource","getPackageJson","packagePath","formatPath","packageData","toString","JSON","parse","getFilesByExt","ext","removeConflictModules","moduleList","updatedList","Object","keys","moduleName","regex","RegExp","test","removeFiles","isRelative","filePath","removeModules","setPackageJson","json","stringify","linkedModules","startPath","workingPath","modulePath","prefix","split","pop","foundPaths","reduce","list","foundPath","stats","deepList","isSymbolicLink","moduleNames","filter","item","path","checkLinkedModules","linked","msgModule","linkedMsg","msg","linkedModule","dimBorder","padding","updateTemplateName","replace","replaceCaps","data"],"mappings":"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"}
301
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utils/app.ts"],"sourcesContent":["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\n\nimport boxen from 'boxen';\nimport chalk from 'chalk';\nimport {copyFile, existsSync, lstatSync, mkdirSync, readdirSync, readFileSync, writeFileSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport isEmpty from 'lodash/isEmpty.js';\nimport ora from 'ora';\nimport {basename as pathBasename, join as pathJoin, relative as pathRelative, resolve as pathResolve} from 'path';\nimport {rimrafSync} from 'rimraf';\n\n\nimport {log} from './log.js';\n\nimport type {LexConfigType} from '../LexConfig.js';\n\n\nexport interface GetFilenamesProps {\n  readonly callback?: (status: number)=> void;\n  readonly cliName?: string;\n  readonly name?: string;\n  readonly quiet?: boolean;\n  readonly type?: string;\n  readonly useTypescript?: boolean;\n}\n\ninterface FilenamesResult {\n  nameCaps: string;\n  templateExt: string;\n  templatePath: string;\n  templateReact: string;\n}\n\nexport const getFilenames = (props: GetFilenamesProps): FilenamesResult | undefined => {\n  const {callback, cliName, name, quiet, type, useTypescript} = props;\n\n  let nameCaps: string;\n  const itemTypes: string[] = ['stores', 'views'];\n\n  if(!name) {\n    if(itemTypes.includes(type)) {\n      log(`\\n${cliName} Error: ${type} name is required. Please use 'lex -h' for options.`, 'error', quiet);\n      callback?.(1);\n      return undefined;\n    }\n  } else {\n    nameCaps = `${name.charAt(0).toUpperCase()}${name.substr(1)}`;\n  }\n\n  log(`${cliName} adding ${name} ${type}...`, 'info', quiet);\n\n  let templatePath: string;\n  let templateExt: string;\n  let templateReact: string;\n\n  if(useTypescript) {\n    templatePath = '../../templates/typescript';\n    templateExt = '.ts';\n    templateReact = '.tsx';\n  } else {\n    templatePath = '../../templates/flow';\n    templateExt = '.js';\n    templateReact = '.js';\n  }\n\n  return {\n    nameCaps,\n    templateExt,\n    templatePath,\n    templateReact\n  };\n};\n\nexport interface Spinner {\n  fail: (text?: string)=> void;\n  start: (text?: string)=> void;\n  succeed: (text?: string)=> void;\n  text?: string;\n}\n\nexport const createSpinner = (quiet = false): Spinner => {\n  if(quiet) {\n    return {\n      fail: () => {},\n      start: () => {},\n      succeed: () => {}\n    };\n  }\n\n  return ora({color: 'yellow'});\n};\n\nexport const createProgressBar = (percentage: number): string => {\n  const width = 20;\n  const filled = Math.round((percentage / 100) * width);\n  const empty = width - filled;\n\n  const filledBar = chalk.cyan('█').repeat(filled);\n  const emptyBar = chalk.gray('░').repeat(empty);\n\n  return filledBar + emptyBar;\n};\n\nexport const handleWebpackProgress = (\n  output: string,\n  spinner: Spinner,\n  quiet: boolean,\n  emoji: string,\n  action: string\n): void => {\n  if(quiet) {\n    return;\n  }\n\n  const progressMatch = output.match(/\\[webpack\\.Progress\\] (\\d+)%/);\n  if(progressMatch) {\n    const progress = parseInt(progressMatch[1]);\n    const progressBar = createProgressBar(progress);\n    spinner.text = `${emoji} ${action}: ${progressBar} ${progress}%`;\n  } else if(output.includes('[webpack.Progress]')) {\n    const generalProgressMatch = output.match(/(\\d+)%/);\n    if(generalProgressMatch) {\n      const progress = parseInt(generalProgressMatch[1]);\n      const progressBar = createProgressBar(progress);\n      spinner.text = `${emoji} ${action}: ${progressBar} ${progress}%`;\n    }\n  }\n};\n\nexport const copyFiles = async (files: string[], typeName: string, spinner, config: LexConfigType) => {\n  const {outputFullPath, sourceFullPath} = config;\n  const items = files.map((fileName: string) => ({\n    from: fileName,\n    to: pathResolve(outputFullPath, pathRelative(sourceFullPath, fileName))\n  }));\n\n  try {\n    spinner.start(`Copying ${typeName} files...`);\n    await Promise.all(items.map(({from, to}) => new Promise(\n      (resolve, reject) => {\n        mkdirSync(pathResolve(to, '..'), {recursive: true});\n        return copyFile(from, to, (copyError) => {\n          if(copyError) {\n            reject();\n          } else {\n            resolve(true);\n          }\n        });\n      }\n    )));\n    spinner.succeed(`Successfully copied ${files.length} ${typeName} files!`);\n  } catch(error) {\n    spinner.fail(`Copying of ${typeName} files failed.`);\n    log(`Error: ${error.message}`, 'error');\n    log(error, 'error');\n  }\n};\n\nexport const copyConfiguredFiles = async (spinner, config: LexConfigType, quiet: boolean) => {\n  const {copyFiles: copyFilesConfig, outputFullPath, sourceFullPath, sourcePath} = config;\n  if(!copyFilesConfig || copyFilesConfig.length === 0) {\n    return;\n  }\n\n  try {\n    spinner.start('Copying configured files...');\n    let totalCopied = 0;\n\n    const baseDir = sourceFullPath || (sourcePath ? pathResolve(process.cwd(), sourcePath) : process.cwd());\n    const allCopyPromises: Promise<unknown>[] = [];\n\n    for(const pattern of copyFilesConfig) {\n      const resolvedPattern = pathResolve(baseDir, pattern);\n      const matchingFiles = globSync(resolvedPattern, {\n        absolute: true,\n        nodir: true\n      });\n\n      if(matchingFiles.length === 0) {\n        if(!quiet) {\n          log(`Warning: No files found matching pattern: ${pattern}`, 'warn', quiet);\n        }\n        continue;\n      }\n\n      const copyPromises = matchingFiles.map((sourceFile) => {\n        const relativePath = pathRelative(baseDir, sourceFile);\n        const destPath = pathResolve(outputFullPath, relativePath);\n        const destDir = pathResolve(destPath, '..');\n        mkdirSync(destDir, {recursive: true});\n\n        return new Promise((resolve, reject) => {\n          copyFile(sourceFile, destPath, (copyError) => {\n            if(copyError) {\n              reject(copyError);\n            } else {\n              resolve(true);\n            }\n          });\n        });\n      });\n\n      allCopyPromises.push(...copyPromises);\n      totalCopied += matchingFiles.length;\n    }\n\n    await Promise.all(allCopyPromises);\n\n    if(totalCopied > 0) {\n      spinner.succeed(`Successfully copied ${totalCopied} configured files!`);\n    } else {\n      spinner.succeed('No configured files to copy');\n    }\n  } catch(error) {\n    spinner.fail('Failed to copy configured files');\n    log(`Error copying configured files: ${error.message}`, 'error', quiet);\n    throw error;\n  }\n};\n\nexport const copyFileSync = (source: string, target: string) => {\n  let targetFile: string = target;\n\n  if(existsSync(target)) {\n    if(lstatSync(target).isDirectory()) {\n      targetFile = pathJoin(target, pathBasename(source));\n    }\n  }\n\n  writeFileSync(targetFile, readFileSync(source));\n};\n\nexport const copyFolderRecursiveSync = (source: string, target: string): void => {\n  let files: string[] = [];\n\n  const targetFolder: string = pathJoin(target, pathBasename(source));\n\n  if(!existsSync(targetFolder)) {\n    mkdirSync(targetFolder);\n  }\n\n  if(lstatSync(source).isDirectory()) {\n    files = readdirSync(source);\n    files.forEach((file: string) => {\n      const curSource: string = pathJoin(source, file);\n\n      if(lstatSync(curSource).isDirectory()) {\n        copyFolderRecursiveSync(curSource, targetFolder);\n      } else {\n        copyFileSync(curSource, targetFolder);\n      }\n    });\n  }\n};\n\nexport const getPackageJson = (packagePath?: string) => {\n  const formatPath: string = packagePath || `${process.cwd()}/package.json`;\n  const packageData: string = readFileSync(formatPath).toString();\n\n  return JSON.parse(packageData);\n};\n\nexport const getFilesByExt = (ext: string, config: LexConfigType): string[] => {\n  const {sourceFullPath} = config;\n  return globSync(`**/**${ext}`, {\n    absolute: true,\n    cwd: sourceFullPath,\n    nodir: true\n  });\n};\n\nexport const removeConflictModules = (moduleList: object) => {\n  const updatedList: object = {...moduleList};\n\n  Object.keys(updatedList).forEach((moduleName: string) => {\n    const regex: RegExp = new RegExp('^(?!@types/).*?(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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"}
@@ -0,0 +1,3 @@
1
+ export { };
2
+
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy92aXRlc3QuZC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQge307XG5cbmRlY2xhcmUgZ2xvYmFsIHtcbiAgdHlwZSBNb2NrID0gaW1wb3J0KCd2aXRlc3QnKS5Nb2NrO1xuICB0eXBlIE1vY2tlZEZ1bmN0aW9uPFQgZXh0ZW5kcyAoLi4uYXJnczogYW55W10pID0+IGFueT4gPSBpbXBvcnQoJ3ZpdGVzdCcpLk1vY2tlZEZ1bmN0aW9uPFQ+O1xuICB0eXBlIE1vY2tlZENsYXNzPFQgZXh0ZW5kcyBuZXcgKC4uLmFyZ3M6IGFueVtdKSA9PiBhbnk+ID0gaW1wb3J0KCd2aXRlc3QnKS5Nb2NrZWRDbGFzczxUPjtcbiAgdHlwZSBTcHlJbnN0YW5jZSA9IGltcG9ydCgndml0ZXN0JykuU3B5SW5zdGFuY2U7XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsV0FBVSJ9
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nlabs/lex",
3
- "version": "1.54.2",
3
+ "version": "1.54.3",
4
4
  "description": "Lex",
5
5
  "license": "MIT",
6
6
  "type": "module",
@@ -62,11 +62,11 @@
62
62
  "publish:minor": "npm version minor && npm publish",
63
63
  "publish:patch": "npm version patch && npm publish",
64
64
  "test": "NODE_ENV=test && (npm run lint || true) && npm run test:unit",
65
- "test:unit": "NODE_ENV=test && npm run env && npx jest",
66
- "test:integration": "NODE_ENV=test && npx jest --testPathPattern=integration",
67
- "test:cli": "NODE_ENV=test && npx jest --testPathPattern=cli",
65
+ "test:unit": "NODE_ENV=test && npm run env && npx vitest run",
66
+ "test:integration": "NODE_ENV=test && npx vitest run \"src/**/*.integration.*\"",
67
+ "test:cli": "NODE_ENV=test && npx vitest run \"src/**/*.cli.*\"",
68
68
  "test:commands": "NODE_ENV=test && npm run test:cli && npm run test:integration",
69
- "test:coverage": "NODE_ENV=test && npx jest --coverage --coverageDirectory=coverage --coverageReporters=text --coverageReporters=lcov --coverageReporters=html",
69
+ "test:coverage": "NODE_ENV=test && npx vitest run --coverage",
70
70
  "test:coverage:upload": "codecov",
71
71
  "test:webpack": "node scripts/test-webpack.js",
72
72
  "type-check": "tsc --noEmit --project tsconfig.lint.json",
@@ -83,34 +83,35 @@
83
83
  "dependencies": {
84
84
  "@mdx-js/loader": "^3.1.1",
85
85
  "@nlabs/webpack-plugin-static-site": "*",
86
- "@storybook/addon-docs": "^10.2.1",
87
- "@storybook/addon-links": "^10.2.1",
86
+ "@storybook/addon-docs": "^10.2.12",
87
+ "@storybook/addon-links": "^10.2.12",
88
88
  "@storybook/addon-postcss": "^2.0.0",
89
89
  "@storybook/addon-styling-webpack": "^3.0.0",
90
- "@storybook/addon-themes": "^10.2.1",
91
- "@storybook/cli": "^10.2.1",
92
- "@storybook/react": "^10.2.1",
93
- "@storybook/react-webpack5": "^10.2.1",
94
- "@swc/cli": "^0.7.10",
95
- "@swc/core": "^1.15.11",
96
- "@swc/jest": "^0.2.39",
90
+ "@storybook/addon-themes": "^10.2.12",
91
+ "@storybook/cli": "^10.2.12",
92
+ "@storybook/react": "^10.2.12",
93
+ "@storybook/react-webpack5": "^10.2.12",
94
+ "@swc/cli": "^0.8.0",
95
+ "@swc/core": "^1.15.13",
96
+ "@tailwindcss/forms": "^0.5.11",
97
97
  "@tailwindcss/nesting": "^0.0.0-insiders.565cd3e",
98
- "@tailwindcss/postcss": "4.1.18",
98
+ "@tailwindcss/postcss": "4.2.1",
99
99
  "@testing-library/jest-dom": "^6.9.1",
100
100
  "@testing-library/react": "^16.3.2",
101
+ "@vitest/coverage-v8": "^4.0.18",
101
102
  "assert": "^2.1.0",
102
- "autoprefixer": "^10.4.23",
103
+ "autoprefixer": "^10.4.27",
103
104
  "boxen": "8.0.1",
104
105
  "buffer": "^6.0.3",
105
- "caniuse-lite": "1.0.30001766",
106
+ "caniuse-lite": "1.0.30001774",
106
107
  "chalk": "^5.6.2",
107
- "commander": "^14.0.2",
108
+ "commander": "^14.0.3",
108
109
  "compare-versions": "^6.1.1",
109
110
  "compression-webpack-plugin": "^11.1.0",
110
111
  "copy-webpack-plugin": "^13.0.1",
111
112
  "core-js": "^3.48.0",
112
113
  "crypto-js": "^4.2.0",
113
- "css-loader": "^7.1.3",
114
+ "css-loader": "^7.1.4",
114
115
  "css-minimizer-webpack-plugin": "^7.0.4",
115
116
  "cssnano": "^7.1.2",
116
117
  "dotenv-webpack": "^8.1.1",
@@ -122,42 +123,37 @@
122
123
  "express": "^5.2.1",
123
124
  "favicons-webpack-plugin": "^6.0.1",
124
125
  "find-file-up": "^2.0.1",
125
- "glob": "^13.0.0",
126
+ "glob": "^13.0.6",
126
127
  "global": "^4.4.0",
127
- "graphql": "^16.12.0",
128
+ "graphql": "^16.13.0",
128
129
  "graphql-tag": "^2.12.6",
129
130
  "html-loader": "^5.1.0",
130
131
  "html-webpack-plugin": "^5.6.6",
131
132
  "https-browserify": "^1.0.0",
132
133
  "image-webpack-loader": "^8.1.0",
133
- "jest": "^30.2.0",
134
- "jest-circus": "^30.2.0",
135
- "jest-cli": "^30.2.0",
136
- "jest-environment-jsdom": "^30.2.0",
137
- "jest-transform-graphql": "2.1.0",
138
- "jest-util": "^30.2.0",
134
+ "jsdom": "^28.1.0",
139
135
  "latest-version": "9.0.0",
140
136
  "lodash": "^4.17.23",
141
137
  "luxon": "^3.7.2",
142
138
  "math-expression-evaluator": "^2.0.7",
143
139
  "mini-css-extract-plugin": "^2.10.0",
144
- "npm-check-updates": "^19.3.2",
145
- "openai": "^6.16.0",
146
- "ora": "9.1.0",
140
+ "npm-check-updates": "^19.5.0",
141
+ "openai": "^6.25.0",
142
+ "ora": "9.3.0",
147
143
  "os-browserify": "^0.3.0",
148
144
  "path-browserify": "^1.0.1",
149
145
  "postcss": "^8.5.6",
150
146
  "postcss-browser-reporter": "^0.7.0",
151
147
  "postcss-cli": "^11.0.1",
152
- "postcss-custom-properties": "^15.0.0",
148
+ "postcss-custom-properties": "^15.0.1",
153
149
  "postcss-flexbugs-fixes": "^5.0.2",
154
150
  "postcss-for": "^2.1.1",
155
151
  "postcss-hash": "^3.0.0",
156
152
  "postcss-import": "16.1.1",
157
- "postcss-loader": "^8.2.0",
153
+ "postcss-loader": "^8.2.1",
158
154
  "postcss-nesting": "^14.0.0",
159
155
  "postcss-percentage": "^0.0.0",
160
- "postcss-preset-env": "^11.1.2",
156
+ "postcss-preset-env": "^11.2.0",
161
157
  "postcss-simple-vars": "^7.0.1",
162
158
  "postcss-svgo": "7.1.0",
163
159
  "postcss-url": "10.1.3",
@@ -168,23 +164,24 @@
168
164
  "react-dom": "^19.2.4",
169
165
  "regenerator-runtime": "^0.14.1",
170
166
  "resolve": "^1.22.11",
171
- "rimraf": "^6.1.2",
172
- "semver": "^7.7.3",
167
+ "rimraf": "^6.1.3",
168
+ "semver": "^7.7.4",
173
169
  "source-map-loader": "^5.0.0",
174
- "storybook": "^10.2.1",
170
+ "storybook": "^10.2.12",
175
171
  "stream-browserify": "^3.0.0",
176
172
  "stream-http": "^3.2.0",
177
173
  "style-loader": "^4.0.0",
178
174
  "svg-spritemap-webpack-plugin": "^5.1.0",
179
175
  "svgo": "4.0.0",
180
176
  "swc-loader": "^0.2.7",
181
- "tailwindcss": "^4.1.18",
177
+ "tailwindcss": "^4.2.1",
182
178
  "ts-node": "^10.9.2",
183
179
  "tsconfig-paths-webpack-plugin": "^4.2.0",
184
180
  "typescript": "5.9.3",
185
181
  "util": "^0.12.5",
182
+ "vitest": "^4.0.18",
186
183
  "vm-browserify": "^1.1.2",
187
- "webpack": "5.104.1",
184
+ "webpack": "5.105.2",
188
185
  "webpack-bundle-analyzer": "^5.2.0",
189
186
  "webpack-cli": "^6.0.1",
190
187
  "webpack-merge": "^6.0.1",
@@ -193,29 +190,32 @@
193
190
  },
194
191
  "devDependencies": {
195
192
  "@types/express": "^5.0.6",
196
- "@types/jest": "^30.0.0",
197
193
  "@types/luxon": "^3.7.1",
198
- "@types/node": "^25.1.0",
194
+ "@types/node": "^25.3.1",
199
195
  "@types/ora": "^3.2.0",
200
- "@types/react": "^19.2.10",
196
+ "@types/react": "^19.2.14",
201
197
  "@types/webpack": "^5.28.5"
202
198
  },
203
199
  "overrides": {
200
+ "ajv": ">=8.18.0",
204
201
  "cheerio": "^1.1.2",
205
202
  "cross-spawn": "^7.0.6",
206
203
  "css-select": "^6.0.0",
207
204
  "diff": "8.0.3",
205
+ "fast-xml-parser": ">=5.4.1",
208
206
  "got": "^14.6.6",
209
207
  "http-cache-semantics": "^4.2.0",
210
208
  "http-proxy-middleware": "^3.0.5",
211
209
  "lodash.pick": "^4.4.0",
210
+ "minimatch": ">=10.2.4",
212
211
  "querystring": false,
213
212
  "gm": false,
214
213
  "lodash-es": "^4.17.23",
215
214
  "node-domexception": false,
216
215
  "nth-check": "^2.1.1",
217
216
  "postcss": "^8.5.6",
218
- "qs": "^6.14.1",
217
+ "qs": ">=6.15.0",
218
+ "rollup": ">=4.59.0",
219
219
  "semver-regex": "^4.0.5",
220
220
  "tmp": "^0.2.5"
221
221
  },