@nlabs/lex 1.47.1 → 1.47.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 (124) hide show
  1. package/.gitattributes +1 -0
  2. package/.storybook/main.ts +86 -0
  3. package/.storybook/preview.ts +15 -0
  4. package/.vscode/settings.json +83 -0
  5. package/CHANGELOG.md +1 -0
  6. package/TYPESCRIPT_CONFIGS.md +103 -0
  7. package/__mocks__/LexConfig.js +17 -2
  8. package/__mocks__/execa.js +9 -7
  9. package/__mocks__/file.js +50 -0
  10. package/__mocks__/ora.js +10 -1
  11. package/config.json +33 -0
  12. package/dist/LexConfig.js +93 -5
  13. package/dist/commands/ai/ai.js +1 -1
  14. package/dist/commands/build/build.js +15 -11
  15. package/dist/commands/clean/clean.js +10 -4
  16. package/dist/commands/compile/compile.js +29 -34
  17. package/dist/commands/create/create.js +5 -5
  18. package/dist/commands/dev/dev.js +11 -7
  19. package/dist/commands/init/init.js +5 -5
  20. package/dist/commands/lint/lint.js +55 -64
  21. package/dist/commands/migrate/migrate.js +2 -2
  22. package/dist/commands/storybook/storybook.js +174 -0
  23. package/dist/commands/test/test.js +51 -13
  24. package/dist/commands/update/update.js +3 -2
  25. package/dist/commands/upgrade/upgrade.js +3 -3
  26. package/dist/commands/versions/versions.js +3 -3
  27. package/dist/create/changelog.js +1 -1
  28. package/dist/dist/LexConfig.d.ts +119 -0
  29. package/dist/dist/utils/file.d.ts +7 -0
  30. package/dist/dist/utils/log.d.ts +1 -0
  31. package/dist/index.js +4 -3
  32. package/dist/lex.js +14 -1
  33. package/dist/utils/aiService.js +2 -2
  34. package/dist/utils/app.js +3 -3
  35. package/dist/utils/file.js +78 -4
  36. package/eslint.config.js +5 -3
  37. package/examples/lex.config.js +50 -0
  38. package/jest.config.cjs +14 -14
  39. package/jest.setup.js +30 -4
  40. package/package.json +40 -23
  41. package/tsconfig.build.json +38 -5
  42. package/tsconfig.json +28 -1
  43. package/tsconfig.lint.json +44 -0
  44. package/tsconfig.test.json +48 -0
  45. package/webpack.config.js +14 -13
  46. package/dist/LexConfig.d.ts +0 -79
  47. package/dist/commands/ai/ai.d.ts +0 -17
  48. package/dist/commands/ai/index.d.ts +0 -8
  49. package/dist/commands/build/build.cli.test.d.ts +0 -5
  50. package/dist/commands/build/build.d.ts +0 -18
  51. package/dist/commands/build/build.integration.test.d.ts +0 -1
  52. package/dist/commands/build/build.options.test.d.ts +0 -5
  53. package/dist/commands/clean/clean.cli.test.d.ts +0 -1
  54. package/dist/commands/clean/clean.d.ts +0 -7
  55. package/dist/commands/clean/clean.integration.test.d.ts +0 -1
  56. package/dist/commands/clean/clean.options.test.d.ts +0 -1
  57. package/dist/commands/compile/compile.cli.test.d.ts +0 -1
  58. package/dist/commands/compile/compile.d.ts +0 -2
  59. package/dist/commands/compile/compile.integration.test.d.ts +0 -1
  60. package/dist/commands/compile/compile.options.test.d.ts +0 -1
  61. package/dist/commands/config/config.cli.test.d.ts +0 -1
  62. package/dist/commands/config/config.d.ts +0 -7
  63. package/dist/commands/config/config.integration.test.d.ts +0 -1
  64. package/dist/commands/config/config.options.test.d.ts +0 -1
  65. package/dist/commands/copy/copy.cli.test.d.ts +0 -1
  66. package/dist/commands/copy/copy.d.ts +0 -6
  67. package/dist/commands/copy/copy.integration.test.d.ts +0 -1
  68. package/dist/commands/copy/copy.options.test.d.ts +0 -1
  69. package/dist/commands/create/create.cli.test.d.ts +0 -1
  70. package/dist/commands/create/create.d.ts +0 -8
  71. package/dist/commands/create/create.integration.test.d.ts +0 -1
  72. package/dist/commands/create/create.options.test.d.ts +0 -1
  73. package/dist/commands/dev/dev.cli.test.d.ts +0 -1
  74. package/dist/commands/dev/dev.d.ts +0 -11
  75. package/dist/commands/dev/dev.integration.test.d.ts +0 -1
  76. package/dist/commands/dev/dev.options.test.d.ts +0 -1
  77. package/dist/commands/init/init.cli.test.d.ts +0 -1
  78. package/dist/commands/init/init.d.ts +0 -9
  79. package/dist/commands/init/init.integration.test.d.ts +0 -1
  80. package/dist/commands/init/init.options.test.d.ts +0 -1
  81. package/dist/commands/link/link.cli.test.d.ts +0 -1
  82. package/dist/commands/link/link.d.ts +0 -6
  83. package/dist/commands/link/link.integration.test.d.ts +0 -1
  84. package/dist/commands/link/link.options.test.d.ts +0 -1
  85. package/dist/commands/lint/autofix.d.ts +0 -2
  86. package/dist/commands/lint/lint.cli.test.d.ts +0 -1
  87. package/dist/commands/lint/lint.d.ts +0 -39
  88. package/dist/commands/lint/lint.integration.test.d.ts +0 -1
  89. package/dist/commands/lint/lint.options.test.d.ts +0 -1
  90. package/dist/commands/migrate/migrate.cli.test.d.ts +0 -1
  91. package/dist/commands/migrate/migrate.d.ts +0 -7
  92. package/dist/commands/migrate/migrate.integration.test.d.ts +0 -1
  93. package/dist/commands/migrate/migrate.options.test.d.ts +0 -1
  94. package/dist/commands/publish/publish.cli.test.d.ts +0 -1
  95. package/dist/commands/publish/publish.d.ts +0 -12
  96. package/dist/commands/publish/publish.integration.test.d.ts +0 -1
  97. package/dist/commands/publish/publish.options.test.d.ts +0 -1
  98. package/dist/commands/test/test.cli.test.d.ts +0 -1
  99. package/dist/commands/test/test.d.ts +0 -50
  100. package/dist/commands/test/test.integration.test.d.ts +0 -1
  101. package/dist/commands/test/test.options.test.d.ts +0 -1
  102. package/dist/commands/test/test.test.d.ts +0 -1
  103. package/dist/commands/update/update.cli.test.d.ts +0 -1
  104. package/dist/commands/update/update.d.ts +0 -9
  105. package/dist/commands/update/update.integration.test.d.ts +0 -1
  106. package/dist/commands/update/update.options.test.d.ts +0 -1
  107. package/dist/commands/upgrade/upgrade.cli.test.d.ts +0 -1
  108. package/dist/commands/upgrade/upgrade.d.ts +0 -7
  109. package/dist/commands/upgrade/upgrade.integration.test.d.ts +0 -1
  110. package/dist/commands/upgrade/upgrade.options.test.d.ts +0 -1
  111. package/dist/commands/versions/versions.cli.test.d.ts +0 -1
  112. package/dist/commands/versions/versions.d.ts +0 -13
  113. package/dist/commands/versions/versions.integration.test.d.ts +0 -1
  114. package/dist/commands/versions/versions.options.test.d.ts +0 -1
  115. package/dist/create/changelog.d.ts +0 -6
  116. package/dist/index.d.ts +0 -31
  117. package/dist/lex.d.ts +0 -2
  118. package/dist/types.d.ts +0 -5
  119. package/dist/utils/aiService.d.ts +0 -9
  120. package/dist/utils/app.d.ts +0 -41
  121. package/dist/utils/file.d.ts +0 -3
  122. package/dist/utils/log.d.ts +0 -1
  123. package/dist/utils/reactShim.d.ts +0 -2
  124. /package/{jest.config.lex.d.ts → dist/jest.config.lex.d.ts} +0 -0
package/.gitattributes ADDED
@@ -0,0 +1 @@
1
+ /.pnp.* binary linguist-generated
@@ -0,0 +1,86 @@
1
+ import type { StorybookConfig } from '@storybook/react-webpack5';
2
+ import { dirname, resolve } from 'path';
3
+
4
+ const getLexNodeModulesPath = () => {
5
+ const lexPackageRoot = dirname(__dirname); // Go up from .storybook to lex root
6
+ return resolve(lexPackageRoot, 'node_modules');
7
+ };
8
+
9
+ const lexModule = (modulePath: string) => resolve(getLexNodeModulesPath(), modulePath);
10
+
11
+ const config: StorybookConfig = {
12
+ addons: [
13
+ lexModule('@storybook/addon-docs'),
14
+ lexModule('@storybook/addon-links'),
15
+ lexModule('@storybook/addon-themes')
16
+ ],
17
+ framework: {
18
+ name: lexModule('@storybook/react-webpack5'),
19
+ options: {
20
+ builder: {
21
+ useSWC: true
22
+ }
23
+ }
24
+ },
25
+ stories: ['../src/**/*.mdx', '../src/**/*.stories.@(ts|tsx)'],
26
+ webpackFinal: async (config) => ({
27
+ ...config,
28
+ module: {
29
+ ...config.module,
30
+ rules: [
31
+ ...(config.module?.rules || []),
32
+ {
33
+ loader: lexModule('babel-loader/lib/index.js'),
34
+ options: {
35
+ babelrc: false,
36
+ plugins: [
37
+ ['@babel/plugin-transform-nullish-coalescing-operator'],
38
+ ['@babel/plugin-transform-optional-chaining']
39
+ ],
40
+ presets: [
41
+ '@babel/preset-typescript',
42
+ [
43
+ '@babel/preset-react',
44
+ {
45
+ runtime: 'automatic'
46
+ }
47
+ ]
48
+ ]
49
+ },
50
+ test: /\.(ts|tsx)$/
51
+ }
52
+ ]
53
+ },
54
+ resolve: {
55
+ ...config.resolve,
56
+ extensions: ['.js', '.ts', '.tsx'],
57
+ plugins: [
58
+ ...(config.resolve?.plugins || [])
59
+ ],
60
+ fallback: {
61
+ ...config.resolve?.fallback,
62
+ "process": require.resolve("process/browser"),
63
+ "buffer": require.resolve("buffer"),
64
+ "util": require.resolve("util"),
65
+ "stream": require.resolve("stream-browserify"),
66
+ "crypto": require.resolve("crypto-browserify"),
67
+ "path": require.resolve("path-browserify"),
68
+ "os": require.resolve("os-browserify/browser"),
69
+ "vm": require.resolve("vm-browserify"),
70
+ "fs": false,
71
+ "net": false,
72
+ "tls": false
73
+ }
74
+ },
75
+ plugins: [
76
+ ...(config.plugins || []),
77
+ new (require('webpack')).ProvidePlugin({
78
+ process: 'process/browser',
79
+ Buffer: ['buffer', 'Buffer']
80
+ })
81
+ ],
82
+ stats: 'verbose'
83
+ })
84
+ };
85
+
86
+ export default config;
@@ -0,0 +1,15 @@
1
+ import type { Preview } from '@storybook/react';
2
+
3
+ const preview: Preview = {
4
+ parameters: {
5
+ actions: { argTypesRegex: '^on[A-Z].*' },
6
+ controls: {
7
+ matchers: {
8
+ color: /(background|color)$/i,
9
+ date: /Date$/,
10
+ },
11
+ },
12
+ },
13
+ };
14
+
15
+ export default preview;
@@ -0,0 +1,83 @@
1
+ {
2
+ "[javascript]": {
3
+ "editor.defaultFormatter": "dbaeumer.vscode-eslint"
4
+ },
5
+ "[javascriptreact]": {
6
+ "editor.defaultFormatter": "dbaeumer.vscode-eslint"
7
+ },
8
+ "[typescript]": {
9
+ "editor.defaultFormatter": "vscode.typescript-language-features"
10
+ },
11
+ "[typescriptreact]": {
12
+ "editor.defaultFormatter": "dbaeumer.vscode-eslint"
13
+ },
14
+ "cSpell.words": [
15
+ "lex",
16
+ "nitrogenlabs",
17
+ "nlabs",
18
+ "transpiler"
19
+ ],
20
+ "css.validate": false,
21
+ "editor.autoClosingBrackets": "never",
22
+ "editor.codeActionsOnSave": {
23
+ "source.fixAll.eslint": "explicit",
24
+ "source.organizeImports": "explicit"
25
+ },
26
+ "editor.detectIndentation": false,
27
+ "editor.formatOnSave": true,
28
+ "editor.rulers": [
29
+ 120
30
+ ],
31
+ "editor.tabCompletion": "on",
32
+ "editor.tabSize": 2,
33
+ "editor.wordWrap": "off",
34
+ "editor.wordWrapColumn": 120,
35
+ "editor.wrappingIndent": "indent",
36
+ "emmet.includeLanguages": {
37
+ "postcss": "css"
38
+ },
39
+ "emmet.syntaxProfiles": {
40
+ "postcss": "css"
41
+ },
42
+ "eslint.enable": true,
43
+ "eslint.experimental.useFlatConfig": true,
44
+ "eslint.format.enable": true,
45
+ "eslint.lintTask.enable": true,
46
+ "eslint.nodePath": "./node_modules",
47
+ "eslint.options": {
48
+ "overrideConfigFile": "./eslint.config.js"
49
+ },
50
+ "eslint.run": "onType",
51
+ "eslint.runtime": "./node_modules/eslint/bin/eslint.js",
52
+ "eslint.validate": [
53
+ "javascript",
54
+ "javascriptreact",
55
+ "typescript",
56
+ "typescriptreact"
57
+ ],
58
+ "eslint.workingDirectories": [
59
+ "."
60
+ ],
61
+ "explorer.confirmDragAndDrop": false,
62
+ "explorer.decorations.badges": false,
63
+ "files.autoSave": "onFocusChange",
64
+ "files.trimTrailingWhitespace": true,
65
+ "html.autoClosingTags": false,
66
+ "html.format.enable": false,
67
+ "html.format.extraLiners": "",
68
+ "html.format.indentHandlebars": true,
69
+ "html.format.indentInnerHtml": true,
70
+ "html.suggest.html5": false,
71
+ "javascript.format.insertSpaceAfterFunctionKeywordForAnonymousFunctions": false,
72
+ "javascript.format.insertSpaceAfterKeywordsInControlFlowStatements": false,
73
+ "javascript.format.insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces": false,
74
+ "javascript.format.insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets": false,
75
+ "javascript.updateImportsOnFileMove.enabled": "never",
76
+ "prettier.enable": false,
77
+ "typescript.format.insertSpaceAfterFunctionKeywordForAnonymousFunctions": false,
78
+ "typescript.format.insertSpaceAfterKeywordsInControlFlowStatements": false,
79
+ "typescript.format.insertSpaceAfterOpeningAndBeforeClosingNonemptyBraces": false,
80
+ "typescript.format.insertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets": false,
81
+ "typescript.updateImportsOnFileMove.enabled": "never",
82
+ "window.zoomLevel": 0
83
+ }
package/CHANGELOG.md ADDED
@@ -0,0 +1 @@
1
+ # Changes
@@ -0,0 +1,103 @@
1
+ # TypeScript Configurations in Lex
2
+
3
+ Lex now uses specialized TypeScript configurations for different commands to optimize performance and functionality.
4
+
5
+ ## Configuration Files
6
+
7
+ ### 1. `tsconfig.build.json` - For Compilation and Building
8
+
9
+ Used by: `lex compile`, `lex build`
10
+
11
+ **Purpose:** Optimized for compilation and bundling with ESM output.
12
+
13
+ **Key Features:**
14
+
15
+ - ESM module format (`"module": "ESNext"`)
16
+ - Declaration file generation (`"declaration": true`)
17
+ - Source maps for debugging (`"inlineSourceMap": true`)
18
+ - Strict type checking (`"strict": true`)
19
+ - Excludes test files for faster compilation
20
+
21
+ **Use Cases:**
22
+
23
+ - Building production bundles
24
+ - Generating type declarations
25
+ - Compiling source code for distribution
26
+
27
+ ### 2. `tsconfig.lint.json` - For Static Analysis
28
+
29
+ Used by: `lex lint`
30
+
31
+ **Purpose:** Optimized for static analysis and linting.
32
+
33
+ **Key Features:**
34
+
35
+ - No emission (`"noEmit": true`)
36
+ - Strict unused variable checking (`"noUnusedLocals": true`)
37
+ - Disabled pretty printing for faster analysis
38
+ - Excludes test files to focus on source code
39
+ - ESLint-friendly settings
40
+
41
+ **Use Cases:**
42
+
43
+ - Static type checking
44
+ - Code quality analysis
45
+ - Linting with ESLint + TypeScript
46
+
47
+ ### 3. `tsconfig.test.json` - For Testing
48
+
49
+ Used by: `lex test`
50
+
51
+ **Purpose:** Optimized for testing environment.
52
+
53
+ **Key Features:**
54
+
55
+ - Includes test files (`**/*.test.*`, `**/*.spec.*`)
56
+ - Jest types included (`"types": ["jest", "node"]`)
57
+ - Relaxed strict mode for test flexibility (`"strict": false`)
58
+ - Source maps for debugging tests
59
+ - Coverage reporting support
60
+
61
+ **Use Cases:**
62
+
63
+ - Running unit tests
64
+ - Integration testing
65
+ - Test debugging and coverage
66
+
67
+ ## Automatic Configuration
68
+
69
+ Lex automatically creates these configuration files when needed:
70
+
71
+ 1. **First run:** If no specialized config exists, Lex creates it from templates
72
+ 2. **Fallback:** If specialized config doesn't exist, falls back to default `tsconfig.json`
73
+ 3. **Custom configs:** You can override any config by creating your own version
74
+
75
+ ## Migration from Single Config
76
+
77
+ If you're migrating from a single `tsconfig.json`:
78
+
79
+ 1. **Keep your existing config:** It will be used as a fallback
80
+ 2. **Customize specialized configs:** Modify the generated configs for your needs
81
+ 3. **Gradual adoption:** Commands will automatically use the appropriate config
82
+
83
+ ## Customization
84
+
85
+ You can customize any of these configurations:
86
+
87
+ ```json
88
+ // tsconfig.build.json - Customize for your build needs
89
+ {
90
+ "extends": "../../tsconfig.base.json",
91
+ "compilerOptions": {
92
+ "outDir": "./lib", // Custom output directory
93
+ "target": "ES2020" // Custom target
94
+ }
95
+ }
96
+ ```
97
+
98
+ ## Benefits
99
+
100
+ 1. **Performance:** Each config is optimized for its specific use case
101
+ 2. **Clarity:** Clear separation of concerns between compilation, linting, and testing
102
+ 3. **Flexibility:** Easy to customize each workflow independently
103
+ 4. **Compatibility:** Maintains backward compatibility with existing setups
@@ -11,10 +11,25 @@ const defaultConfigValues = {
11
11
  const LexConfig = {
12
12
  config: defaultConfigValues,
13
13
  parseConfig: jest.fn(),
14
- checkTypescriptConfig: jest.fn()
14
+ checkTypescriptConfig: jest.fn(),
15
+ checkCompileTypescriptConfig: jest.fn(),
16
+ checkLintTypescriptConfig: jest.fn(),
17
+ checkTestTypescriptConfig: jest.fn(),
18
+ getLexDir: jest.fn(() => '/mock/lex/dir'),
19
+ updateConfig: jest.fn((config) => ({ ...defaultConfigValues, ...config })),
20
+ addConfigParams: jest.fn(),
21
+ get useTypescript() {
22
+ return this.config.useTypescript;
23
+ },
24
+ set useTypescript(value) {
25
+ this.config.useTypescript = value;
26
+ }
15
27
  };
16
28
 
29
+ const getTypeScriptConfigPath = jest.fn((configName) => `/mock/lex/dir/${configName}`);
30
+
17
31
  module.exports = {
18
32
  LexConfig,
19
- defaultConfigValues
33
+ defaultConfigValues,
34
+ getTypeScriptConfigPath
20
35
  };
@@ -1,11 +1,13 @@
1
1
  // Mock implementation of execa
2
- const mockExeca = jest.fn().mockImplementation(() => ({
3
- stdout: '',
4
- stderr: '',
5
- exitCode: 0,
6
- command: 'mocked-command',
7
- pid: 123
8
- }));
2
+ const mockExeca = jest.fn().mockImplementation(() =>
3
+ Promise.resolve({
4
+ stdout: '',
5
+ stderr: '',
6
+ exitCode: 0,
7
+ command: 'mocked-command',
8
+ pid: 123
9
+ })
10
+ );
9
11
 
10
12
  mockExeca.sync = jest.fn().mockImplementation(() => ({
11
13
  stdout: '',
@@ -0,0 +1,50 @@
1
+ const path = require('path');
2
+ const fs = require('fs');
3
+
4
+ // Mock implementations that don't use import.meta.url
5
+ function getDirName() {
6
+ return process.cwd();
7
+ }
8
+
9
+ function getFilePath(relativePath) {
10
+ // For testing, resolve relative to process.cwd()
11
+ return path.resolve(process.cwd(), relativePath);
12
+ }
13
+
14
+ function getLexPackageJsonPath() {
15
+ // For testing, return a mock path
16
+ return path.resolve(process.cwd(), 'package.json');
17
+ }
18
+
19
+ function relativeFilePath(filename, dirPath = './', backUp = 0) {
20
+ // Mock implementation
21
+ return path.resolve(process.cwd(), filename);
22
+ }
23
+
24
+ function relativeNodePath(filename, dirPath = './', backUp = 0) {
25
+ // Mock implementation
26
+ return path.resolve(process.cwd(), `node_modules/${filename}`);
27
+ }
28
+
29
+ function getNodePath(moduleName) {
30
+ // Mock implementation
31
+ return path.resolve(process.cwd(), `node_modules/${moduleName}`);
32
+ }
33
+
34
+ function resolveBinaryPath(binaryName, packageName) {
35
+ // Mock implementation
36
+ if (packageName) {
37
+ return path.resolve(process.cwd(), `node_modules/${packageName}/bin/${binaryName}`);
38
+ }
39
+ return path.resolve(process.cwd(), `node_modules/.bin/${binaryName}`);
40
+ }
41
+
42
+ module.exports = {
43
+ getDirName,
44
+ getFilePath,
45
+ getLexPackageJsonPath,
46
+ relativeFilePath,
47
+ relativeNodePath,
48
+ getNodePath,
49
+ resolveBinaryPath
50
+ };
package/__mocks__/ora.js CHANGED
@@ -13,5 +13,14 @@ const mockSpinner = {
13
13
 
14
14
  const mockOra = jest.fn().mockImplementation(() => mockSpinner);
15
15
 
16
- module.exports = mockOra;
16
+ module.exports = () => ({
17
+ start: jest.fn().mockReturnThis(),
18
+ succeed: jest.fn().mockReturnThis(),
19
+ fail: jest.fn().mockReturnThis(),
20
+ stop: jest.fn().mockReturnThis(),
21
+ info: jest.fn().mockReturnThis(),
22
+ warn: jest.fn().mockReturnThis(),
23
+ text: ''
24
+ });
25
+
17
26
  module.exports.default = mockOra;
package/config.json ADDED
@@ -0,0 +1,33 @@
1
+ {
2
+ "useTypescript": true,
3
+ "sourcePath": "./src",
4
+ "outputPath": "./dist",
5
+ "targetEnvironment": "web",
6
+ "preset": "web",
7
+ "packageManager": "npm",
8
+ "ai": {
9
+ "provider": "none",
10
+ "model": "gpt-4o",
11
+ "maxTokens": 4000,
12
+ "temperature": 0.1
13
+ },
14
+ "esbuild": {
15
+ "minify": true,
16
+ "treeShaking": true,
17
+ "drop": [],
18
+ "pure": [],
19
+ "legalComments": "none",
20
+ "splitting": true,
21
+ "metafile": false,
22
+ "sourcemap": false
23
+ },
24
+ "webpack": {},
25
+ "jest": {},
26
+ "outputHash": false,
27
+ "useGraphQl": false,
28
+ "configFiles": [],
29
+ "copyFiles": [],
30
+ "entryHTML": "index.html",
31
+ "entryJs": "index.js",
32
+ "env": null
33
+ }
package/dist/LexConfig.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import { existsSync, readFileSync, writeFileSync } from "fs";
2
- import { extname as pathExtname, resolve as pathResolve } from "path";
2
+ import { dirname, extname as pathExtname, resolve as pathResolve } from "path";
3
3
  import { URL } from "url";
4
- import { relativeFilePath } from "./utils/file.js";
4
+ import { getDirName, getLexPackageJsonPath, relativeFilePath } from "./utils/file.js";
5
5
  import { log } from "./utils/log.js";
6
6
  const cwd = process.cwd();
7
7
  const defaultConfigValues = {
@@ -39,10 +39,67 @@ const defaultConfigValues = {
39
39
  useTypescript: false,
40
40
  webpack: {}
41
41
  };
42
+ function findLexRoot(startDir) {
43
+ let dir = startDir;
44
+ console.log("DEBUG: findLexRoot starting with dir:", dir);
45
+ while (dir !== "/" && dir !== ".") {
46
+ const pkgPath = pathResolve(dir, "package.json");
47
+ console.log("DEBUG: findLexRoot checking", pkgPath);
48
+ if (existsSync(pkgPath)) {
49
+ try {
50
+ const pkg = JSON.parse(readFileSync(pkgPath, "utf8"));
51
+ if (pkg.name === "@nlabs/lex") {
52
+ return dir;
53
+ }
54
+ } catch {
55
+ }
56
+ }
57
+ const parent = dirname(dir);
58
+ console.log("DEBUG: findLexRoot parent of", dir, "is", parent);
59
+ if (parent === dir) {
60
+ break;
61
+ }
62
+ dir = parent;
63
+ }
64
+ throw new Error("Could not find @nlabs/lex root");
65
+ }
66
+ function getTypeScriptConfigPath(configName) {
67
+ const cwd2 = process.cwd();
68
+ if (configName === "tsconfig.build.json") {
69
+ const projectBuildConfig = pathResolve(cwd2, "tsconfig.build.json");
70
+ if (existsSync(projectBuildConfig)) {
71
+ return projectBuildConfig;
72
+ }
73
+ }
74
+ if (configName === "tsconfig.lint.json") {
75
+ const projectLintConfig = pathResolve(cwd2, "tsconfig.eslint.json");
76
+ if (existsSync(projectLintConfig)) {
77
+ return projectLintConfig;
78
+ }
79
+ }
80
+ if (configName === "tsconfig.test.json") {
81
+ const projectTestConfig = pathResolve(cwd2, "tsconfig.test.json");
82
+ if (existsSync(projectTestConfig)) {
83
+ return projectTestConfig;
84
+ }
85
+ }
86
+ const projectConfigPath = pathResolve(cwd2, configName);
87
+ if (existsSync(projectConfigPath)) {
88
+ return projectConfigPath;
89
+ }
90
+ const lexDir = LexConfig.getLexDir();
91
+ return pathResolve(lexDir, configName);
92
+ }
42
93
  class LexConfig {
43
94
  static config = {
44
95
  ...defaultConfigValues
45
96
  };
97
+ /**
98
+ * Get the Lex package root directory, handling both development and installed environments
99
+ */
100
+ static getLexDir() {
101
+ return dirname(getLexPackageJsonPath());
102
+ }
46
103
  static set useTypescript(value) {
47
104
  LexConfig.config.useTypescript = value;
48
105
  const { sourceFullPath } = LexConfig.config;
@@ -192,13 +249,44 @@ ${cliName} Error: Config file must be a JS, CJS, MJS, TS, or JSON file.`, "error
192
249
  static checkTypescriptConfig() {
193
250
  const tsconfigPath = pathResolve(cwd, "./tsconfig.json");
194
251
  if (!existsSync(tsconfigPath)) {
195
- const dirName = new URL(".", import.meta.url).pathname;
252
+ const dirName = getDirName();
196
253
  writeFileSync(tsconfigPath, readFileSync(pathResolve(dirName, "../../../tsconfig.base.json")));
197
254
  }
198
255
  }
256
+ static checkCompileTypescriptConfig() {
257
+ const lexDir = LexConfig.getLexDir();
258
+ const tsconfigCompilePath = pathResolve(lexDir, "./tsconfig.build.json");
259
+ if (!existsSync(tsconfigCompilePath)) {
260
+ const templatePath = pathResolve(lexDir, "tsconfig.build.json");
261
+ if (existsSync(templatePath)) {
262
+ writeFileSync(tsconfigCompilePath, readFileSync(templatePath));
263
+ }
264
+ }
265
+ }
266
+ static checkLintTypescriptConfig() {
267
+ const lexDir = LexConfig.getLexDir();
268
+ const tsconfigLintPath = pathResolve(lexDir, "./tsconfig.lint.json");
269
+ if (!existsSync(tsconfigLintPath)) {
270
+ const templatePath = pathResolve(lexDir, "tsconfig.lint.json");
271
+ if (existsSync(templatePath)) {
272
+ writeFileSync(tsconfigLintPath, readFileSync(templatePath));
273
+ }
274
+ }
275
+ }
276
+ static checkTestTypescriptConfig() {
277
+ const lexDir = LexConfig.getLexDir();
278
+ const tsconfigTestPath = pathResolve(lexDir, "./tsconfig.test.json");
279
+ if (!existsSync(tsconfigTestPath)) {
280
+ const templatePath = pathResolve(lexDir, "tsconfig.test.json");
281
+ if (existsSync(templatePath)) {
282
+ writeFileSync(tsconfigTestPath, readFileSync(templatePath));
283
+ }
284
+ }
285
+ }
199
286
  }
200
287
  export {
201
288
  LexConfig,
202
- defaultConfigValues
289
+ defaultConfigValues,
290
+ getTypeScriptConfigPath
203
291
  };
204
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/LexConfig.ts"],
  "sourcesContent": ["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {existsSync, readFileSync, writeFileSync} from 'fs';\nimport {extname as pathExtname, resolve as pathResolve} from 'path';\nimport {URL} from 'url';\n\nimport {relativeFilePath} from './utils/file.js';\nimport {log} from './utils/log.js';\n\nconst cwd: string = process.cwd();\n\nexport interface EsbuildConfig {\n  entryPoints?: string[];\n  outdir?: string;\n  platform?: 'node' | 'browser';\n  target?: string;\n  format?: 'cjs' | 'esm';\n  minify?: boolean;\n  treeShaking?: boolean;\n  drop?: string[];\n  pure?: string[];\n  external?: string[];\n  splitting?: boolean;\n  metafile?: boolean;\n  sourcemap?: boolean | 'inline' | 'external';\n  legalComments?: 'none' | 'inline' | 'eof' | 'linked' | 'separate';\n  banner?: Record<string, string>;\n  footer?: Record<string, string>;\n  define?: Record<string, string>;\n  [key: string]: unknown;\n}\n\nexport interface JestConfig {\n  roots?: string[];\n  testEnvironment?: string;\n  transform?: Record<string, [string, Record<string, unknown>]>;\n  transformIgnorePatterns?: string[];\n  moduleNameMapper?: Record<string, string>;\n  extensionsToTreatAsEsm?: string[];\n  preset?: string;\n  [key: string]: unknown;\n}\n\nexport interface WebpackConfig {\n  entry?: string | string[];\n  output?: Record<string, unknown>;\n  module?: Record<string, unknown>;\n  plugins?: unknown[];\n  [key: string]: unknown;\n}\n\nexport interface AIConfig {\n  provider?: 'cursor' | 'copilot' | 'openai' | 'anthropic' | 'none';\n  apiKey?: string;\n  model?: string;\n  maxTokens?: number;\n  temperature?: number;\n}\nexport interface LexConfigType {\n  ai?: AIConfig;\n  configFiles?: string[];\n  copyFiles?: string[];\n  entryHTML?: string;\n  entryJs?: string;\n  esbuild?: EsbuildConfig;\n  env?: object;\n  gitUrl?: string;\n  jest?: JestConfig;\n  libraryName?: string;\n  libraryTarget?: string;\n  outputFile?: string;\n  outputFullPath?: string;\n  outputHash?: boolean;\n  outputPath?: string;\n  packageManager?: 'npm' | 'yarn';\n  preset?: 'web' | 'node' | 'lambda' | 'mobile';\n  sourceFullPath?: string;\n  sourcePath?: string;\n  targetEnvironment?: 'node' | 'web';\n  useGraphQl?: boolean;\n  useTypescript?: boolean;\n  webpack?: WebpackConfig;\n}\n\nexport type Config = LexConfigType;\n\nexport const defaultConfigValues: LexConfigType = {\n  ai: {\n    provider: 'none',\n    model: 'gpt-4o',\n    maxTokens: 4000,\n    temperature: 0.1\n  },\n  configFiles: [],\n  copyFiles: [],\n  entryHTML: 'index.html',\n  entryJs: 'index.js',\n  esbuild: {\n    minify: true,\n    treeShaking: true,\n    drop: ['console', 'debugger'],\n    pure: ['console.log', 'console.warn', 'console.error'],\n    legalComments: 'none',\n    splitting: true,\n    metafile: false,\n    sourcemap: false\n  },\n  env: null,\n  jest: {},\n  outputFullPath: pathResolve(cwd, './dist'),\n  outputHash: false,\n  outputPath: './dist',\n  packageManager: 'npm',\n  preset: 'web',\n  sourceFullPath: pathResolve(cwd, './src'),\n  sourcePath: './src',\n  targetEnvironment: 'web',\n  useGraphQl: false,\n  useTypescript: false,\n  webpack: {}\n};\n\nexport class LexConfig {\n  static config: LexConfigType = {\n    ...defaultConfigValues\n  };\n\n  static set useTypescript(value: boolean) {\n    LexConfig.config.useTypescript = value;\n    const {sourceFullPath} = LexConfig.config;\n\n    const {entryJs} = LexConfig.config;\n\n    if(entryJs === 'index.js' && value) {\n      const indexPath: string = pathResolve(cwd, sourceFullPath, 'index.tsx');\n      const hasIndexTsx: boolean = existsSync(indexPath);\n\n      if(hasIndexTsx) {\n        LexConfig.config.entryJs = 'index.tsx';\n      } else {\n        LexConfig.config.entryJs = 'index.ts';\n      }\n    }\n  }\n\n  static updateConfig(updatedConfig: LexConfigType): LexConfigType {\n    const {outputFullPath, outputPath, sourcePath, sourceFullPath, useTypescript, ai} = updatedConfig;\n    const cwd: string = process.cwd();\n\n    if(useTypescript !== undefined) {\n      LexConfig.useTypescript = useTypescript;\n    }\n\n    if(outputPath !== undefined && outputFullPath === undefined) {\n      updatedConfig.outputFullPath = pathResolve(cwd, outputPath);\n    }\n\n    if(sourcePath !== undefined && sourceFullPath === undefined) {\n      updatedConfig.sourceFullPath = pathResolve(cwd, sourcePath);\n    }\n\n    if(ai) {\n      LexConfig.config.ai = {...LexConfig.config.ai, ...ai};\n\n      if(process.env.CURSOR_IDE === 'true' && LexConfig.config.ai.provider === 'none') {\n        LexConfig.config.ai.provider = 'cursor';\n      }\n    }\n\n    LexConfig.config = {...LexConfig.config, ...updatedConfig};\n\n    return LexConfig.config;\n  }\n\n  static addConfigParams(cmd, params: LexConfigType) {\n    const nameProperty: string = '_name';\n    const {environment, outputPath, sourcePath, typescript} = cmd;\n\n    if(outputPath !== undefined) {\n      params.outputPath = outputPath;\n      params.outputFullPath = pathResolve(cwd, outputPath);\n    }\n\n    if(sourcePath !== undefined) {\n      params.sourcePath = sourcePath;\n      params.sourceFullPath = pathResolve(cwd, sourcePath);\n    }\n\n    if(typescript !== undefined) {\n      params.useTypescript = true;\n    }\n\n    if(environment !== undefined) {\n      params.targetEnvironment = environment === 'web' ? 'web' : 'node';\n    }\n\n    process.env.LEX_CONFIG = JSON.stringify(\n      {\n        ...LexConfig.updateConfig(params),\n        commandName: cmd[nameProperty],\n        isStatic: cmd.static\n      }, null, 0\n    );\n  }\n\n  static async parseConfig(cmd, isRoot: boolean = true): Promise<void> {\n    const {cliName = 'Lex', lexConfig, lexConfigName, quiet, typescript, debug = false} = cmd;\n    const configFormats = ['js', 'mjs', 'cjs', 'ts', 'json'];\n    const configBaseName: string = lexConfigName || 'lex.config';\n    let configPath: string = lexConfig || '';\n    let configExists: boolean = lexConfig ? existsSync(configPath) : false;\n\n    if(!configPath || !configExists) {\n      if(debug) {\n        log(`Searching for config files with base name: ${configBaseName}`, 'info', quiet);\n      }\n\n      for(const format of configFormats) {\n        const potentialPath = isRoot\n          ? pathResolve(cwd, `./${configBaseName}.${format}`)\n          : relativeFilePath(`${configBaseName}.${format}`, cwd);\n\n        if(debug) {\n          log(`Checking for config file: ${potentialPath}`, 'info', quiet);\n        }\n\n        if(existsSync(potentialPath)) {\n          configPath = potentialPath;\n          configExists = true;\n          break;\n        }\n      }\n    }\n\n    if(configExists) {\n      log(`Using ${cliName} configuration file: ${configPath}`, 'note', quiet);\n      const ext: string = pathExtname(configPath);\n\n      if(ext === '.json') {\n        const configContent: string = readFileSync(configPath, 'utf8');\n\n        if(configContent) {\n          let configJson: LexConfigType;\n\n          try {\n            configJson = JSON.parse(configContent)?.default || {};\n          } catch(error) {\n            log(`\\n${cliName} Error: Failed to parse JSON config: ${error.message}`, 'error', quiet);\n            configJson = {};\n          }\n\n          LexConfig.addConfigParams(cmd, configJson);\n        } else {\n          log(`\\n${cliName} Error: Config file malformed, ${configPath}`, 'error', quiet);\n        }\n      } else if(['.js', '.mjs', '.cjs', '.ts'].includes(ext)) {\n        try {\n          let lexCustomConfig;\n\n          if(ext === '.cjs') {\n            const fileUrl = new URL(`file:///${pathResolve(configPath)}`).href;\n\n            if(debug) {\n              log(`Loading CommonJS config from: ${fileUrl}`, 'info', quiet);\n            }\n            lexCustomConfig = await import(fileUrl);\n          } else {\n            if(debug) {\n              log(`Loading ESM/TS config from: ${configPath}`, 'info', quiet);\n            }\n\n            lexCustomConfig = await import(configPath);\n          }\n\n          const config = lexCustomConfig.default || lexCustomConfig;\n\n          if(debug) {\n            log(`Loaded config: ${JSON.stringify(config, null, 2)}`, 'info', quiet);\n          }\n\n          if(!config) {\n            log(`\\n${cliName} Warning: Config file loaded but no configuration found`, 'warn', quiet);\n          }\n\n          LexConfig.addConfigParams(cmd, config || {});\n        } catch(error) {\n          log(`\\n${cliName} Error: Failed to load config file: ${error.message}`, 'error', quiet);\n          if(debug) {\n            console.error(error);\n          }\n        }\n      } else {\n        log(`\\n${cliName} Error: Config file must be a JS, CJS, MJS, TS, or JSON file.`, 'error', quiet);\n      }\n    } else {\n      if(debug) {\n        log('No config file found. Using default configuration.', 'info', quiet);\n      }\n\n      LexConfig.useTypescript = !!typescript;\n      LexConfig.addConfigParams(cmd, LexConfig.config);\n    }\n  }\n\n  static checkTypescriptConfig() {\n    const tsconfigPath: string = pathResolve(cwd, './tsconfig.json');\n\n    if(!existsSync(tsconfigPath)) {\n      const dirName = new URL('.', import.meta.url).pathname;\n      writeFileSync(tsconfigPath, readFileSync(pathResolve(dirName, '../../../tsconfig.base.json')));\n    }\n  }\n}"],
  "mappings": "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",
  "names": ["cwd"]
}

292
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/LexConfig.ts"],
  "sourcesContent": ["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {existsSync, readFileSync, writeFileSync} from 'fs';\nimport {dirname, extname as pathExtname, resolve as pathResolve} from 'path';\nimport {URL} from 'url';\n\nimport {getDirName, getLexPackageJsonPath, relativeFilePath} from './utils/file.js';\nimport {log} from './utils/log.js';\n\nconst cwd: string = process.cwd();\n\nexport interface EsbuildConfig {\n  entryPoints?: string[];\n  outdir?: string;\n  platform?: 'node' | 'browser';\n  target?: string;\n  format?: 'cjs' | 'esm';\n  minify?: boolean;\n  treeShaking?: boolean;\n  drop?: string[];\n  pure?: string[];\n  external?: string[];\n  splitting?: boolean;\n  metafile?: boolean;\n  sourcemap?: boolean | 'inline' | 'external';\n  legalComments?: 'none' | 'inline' | 'eof' | 'linked' | 'separate';\n  banner?: Record<string, string>;\n  footer?: Record<string, string>;\n  define?: Record<string, string>;\n  [key: string]: unknown;\n}\n\nexport interface JestConfig {\n  roots?: string[];\n  testEnvironment?: string;\n  transform?: Record<string, [string, Record<string, unknown>]>;\n  transformIgnorePatterns?: string[];\n  moduleNameMapper?: Record<string, string>;\n  extensionsToTreatAsEsm?: string[];\n  preset?: string;\n  [key: string]: unknown;\n}\n\nexport interface WebpackConfig {\n  entry?: string | string[];\n  output?: Record<string, unknown>;\n  module?: Record<string, unknown>;\n  plugins?: unknown[];\n  [key: string]: unknown;\n}\n\nexport interface AIConfig {\n  provider?: 'cursor' | 'copilot' | 'openai' | 'anthropic' | 'none';\n  apiKey?: string;\n  model?: string;\n  maxTokens?: number;\n  temperature?: number;\n}\nexport interface LexConfigType {\n  ai?: AIConfig;\n  configFiles?: string[];\n  copyFiles?: string[];\n  entryHTML?: string;\n  entryJs?: string;\n  esbuild?: EsbuildConfig;\n  env?: object;\n  gitUrl?: string;\n  jest?: JestConfig;\n  libraryName?: string;\n  libraryTarget?: string;\n  outputFile?: string;\n  outputFullPath?: string;\n  outputHash?: boolean;\n  outputPath?: string;\n  packageManager?: 'npm' | 'yarn';\n  preset?: 'web' | 'node' | 'lambda' | 'mobile';\n  sourceFullPath?: string;\n  sourcePath?: string;\n  targetEnvironment?: 'node' | 'web';\n  useGraphQl?: boolean;\n  useTypescript?: boolean;\n  webpack?: WebpackConfig;\n}\n\nexport type Config = LexConfigType;\n\nexport const defaultConfigValues: LexConfigType = {\n  ai: {\n    provider: 'none',\n    model: 'gpt-4o',\n    maxTokens: 4000,\n    temperature: 0.1\n  },\n  configFiles: [],\n  copyFiles: [],\n  entryHTML: 'index.html',\n  entryJs: 'index.js',\n  esbuild: {\n    minify: true,\n    treeShaking: true,\n    drop: ['console', 'debugger'],\n    pure: ['console.log', 'console.warn', 'console.error'],\n    legalComments: 'none',\n    splitting: true,\n    metafile: false,\n    sourcemap: false\n  },\n  env: null,\n  jest: {},\n  outputFullPath: pathResolve(cwd, './dist'),\n  outputHash: false,\n  outputPath: './dist',\n  packageManager: 'npm',\n  preset: 'web',\n  sourceFullPath: pathResolve(cwd, './src'),\n  sourcePath: './src',\n  targetEnvironment: 'web',\n  useGraphQl: false,\n  useTypescript: false,\n  webpack: {}\n};\n\nfunction findLexRoot(startDir: string): string {\n  let dir = startDir;\n  console.log('DEBUG: findLexRoot starting with dir:', dir); // TEMP DEBUG\n  while(dir !== '/' && dir !== '.') {\n    const pkgPath = pathResolve(dir, 'package.json');\n    console.log('DEBUG: findLexRoot checking', pkgPath); // TEMP DEBUG\n    if(existsSync(pkgPath)) {\n      try {\n        const pkg = JSON.parse(readFileSync(pkgPath, 'utf8'));\n        if(pkg.name === '@nlabs/lex') {\n          return dir;\n        }\n      } catch{}\n    }\n    const parent = dirname(dir);\n    console.log('DEBUG: findLexRoot parent of', dir, 'is', parent); // TEMP DEBUG\n    if(parent === dir) {\n      break;\n    }\n    dir = parent;\n  }\n  throw new Error('Could not find @nlabs/lex root');\n}\n\n/**\n * Get the appropriate TypeScript config path, prioritizing project configs over Lex configs\n */\nexport function getTypeScriptConfigPath(configName: string): string {\n  const cwd = process.cwd();\n\n  // For compile command, check for project's build config first\n  if(configName === 'tsconfig.build.json') {\n    const projectBuildConfig = pathResolve(cwd, 'tsconfig.build.json');\n    if(existsSync(projectBuildConfig)) {\n      return projectBuildConfig;\n    }\n  }\n\n  // For lint command, check for project's lint config first\n  if(configName === 'tsconfig.lint.json') {\n    const projectLintConfig = pathResolve(cwd, 'tsconfig.eslint.json');\n    if(existsSync(projectLintConfig)) {\n      return projectLintConfig;\n    }\n  }\n\n  // For test command, check for project's test config first\n  if(configName === 'tsconfig.test.json') {\n    const projectTestConfig = pathResolve(cwd, 'tsconfig.test.json');\n    if(existsSync(projectTestConfig)) {\n      return projectTestConfig;\n    }\n  }\n\n  // Check for the exact config name in the project\n  const projectConfigPath = pathResolve(cwd, configName);\n  if(existsSync(projectConfigPath)) {\n    return projectConfigPath;\n  }\n\n  // Otherwise, use Lex's config\n  const lexDir = LexConfig.getLexDir();\n  return pathResolve(lexDir, configName);\n}\n\nexport class LexConfig {\n  static config: LexConfigType = {\n    ...defaultConfigValues\n  };\n\n  /**\n   * Get the Lex package root directory, handling both development and installed environments\n   */\n  static getLexDir(): string {\n    // Always use the directory of Lex's own package.json\n    return dirname(getLexPackageJsonPath());\n  }\n\n  static set useTypescript(value: boolean) {\n    LexConfig.config.useTypescript = value;\n    const {sourceFullPath} = LexConfig.config;\n\n    const {entryJs} = LexConfig.config;\n\n    if(entryJs === 'index.js' && value) {\n      const indexPath: string = pathResolve(cwd, sourceFullPath, 'index.tsx');\n      const hasIndexTsx: boolean = existsSync(indexPath);\n\n      if(hasIndexTsx) {\n        LexConfig.config.entryJs = 'index.tsx';\n      } else {\n        LexConfig.config.entryJs = 'index.ts';\n      }\n    }\n  }\n\n  static updateConfig(updatedConfig: LexConfigType): LexConfigType {\n    const {outputFullPath, outputPath, sourcePath, sourceFullPath, useTypescript, ai} = updatedConfig;\n    const cwd: string = process.cwd();\n\n    if(useTypescript !== undefined) {\n      LexConfig.useTypescript = useTypescript;\n    }\n\n    if(outputPath !== undefined && outputFullPath === undefined) {\n      updatedConfig.outputFullPath = pathResolve(cwd, outputPath);\n    }\n\n    if(sourcePath !== undefined && sourceFullPath === undefined) {\n      updatedConfig.sourceFullPath = pathResolve(cwd, sourcePath);\n    }\n\n    if(ai) {\n      LexConfig.config.ai = {...LexConfig.config.ai, ...ai};\n\n      if(process.env.CURSOR_IDE === 'true' && LexConfig.config.ai.provider === 'none') {\n        LexConfig.config.ai.provider = 'cursor';\n      }\n    }\n\n    LexConfig.config = {...LexConfig.config, ...updatedConfig};\n\n    return LexConfig.config;\n  }\n\n  static addConfigParams(cmd, params: LexConfigType) {\n    const nameProperty: string = '_name';\n    const {environment, outputPath, sourcePath, typescript} = cmd;\n\n    if(outputPath !== undefined) {\n      params.outputPath = outputPath;\n      params.outputFullPath = pathResolve(cwd, outputPath);\n    }\n\n    if(sourcePath !== undefined) {\n      params.sourcePath = sourcePath;\n      params.sourceFullPath = pathResolve(cwd, sourcePath);\n    }\n\n    if(typescript !== undefined) {\n      params.useTypescript = true;\n    }\n\n    if(environment !== undefined) {\n      params.targetEnvironment = environment === 'web' ? 'web' : 'node';\n    }\n\n    process.env.LEX_CONFIG = JSON.stringify(\n      {\n        ...LexConfig.updateConfig(params),\n        commandName: cmd[nameProperty],\n        isStatic: cmd.static\n      }, null, 0\n    );\n  }\n\n  static async parseConfig(cmd, isRoot: boolean = true): Promise<void> {\n    const {cliName = 'Lex', lexConfig, lexConfigName, quiet, typescript, debug = false} = cmd;\n    const configFormats = ['js', 'mjs', 'cjs', 'ts', 'json'];\n    const configBaseName: string = lexConfigName || 'lex.config';\n    let configPath: string = lexConfig || '';\n    let configExists: boolean = lexConfig ? existsSync(configPath) : false;\n\n    if(!configPath || !configExists) {\n      if(debug) {\n        log(`Searching for config files with base name: ${configBaseName}`, 'info', quiet);\n      }\n\n      for(const format of configFormats) {\n        const potentialPath = isRoot\n          ? pathResolve(cwd, `./${configBaseName}.${format}`)\n          : relativeFilePath(`${configBaseName}.${format}`, cwd);\n\n        if(debug) {\n          log(`Checking for config file: ${potentialPath}`, 'info', quiet);\n        }\n\n        if(existsSync(potentialPath)) {\n          configPath = potentialPath;\n          configExists = true;\n          break;\n        }\n      }\n    }\n\n    if(configExists) {\n      log(`Using ${cliName} configuration file: ${configPath}`, 'note', quiet);\n      const ext: string = pathExtname(configPath);\n\n      if(ext === '.json') {\n        const configContent: string = readFileSync(configPath, 'utf8');\n\n        if(configContent) {\n          let configJson: LexConfigType;\n\n          try {\n            configJson = JSON.parse(configContent)?.default || {};\n          } catch(error) {\n            log(`\\n${cliName} Error: Failed to parse JSON config: ${error.message}`, 'error', quiet);\n            configJson = {};\n          }\n\n          LexConfig.addConfigParams(cmd, configJson);\n        } else {\n          log(`\\n${cliName} Error: Config file malformed, ${configPath}`, 'error', quiet);\n        }\n      } else if(['.js', '.mjs', '.cjs', '.ts'].includes(ext)) {\n        try {\n          let lexCustomConfig;\n\n          if(ext === '.cjs') {\n            const fileUrl = new URL(`file:///${pathResolve(configPath)}`).href;\n\n            if(debug) {\n              log(`Loading CommonJS config from: ${fileUrl}`, 'info', quiet);\n            }\n            lexCustomConfig = await import(fileUrl);\n          } else {\n            if(debug) {\n              log(`Loading ESM/TS config from: ${configPath}`, 'info', quiet);\n            }\n\n            lexCustomConfig = await import(configPath);\n          }\n\n          const config = lexCustomConfig.default || lexCustomConfig;\n\n          if(debug) {\n            log(`Loaded config: ${JSON.stringify(config, null, 2)}`, 'info', quiet);\n          }\n\n          if(!config) {\n            log(`\\n${cliName} Warning: Config file loaded but no configuration found`, 'warn', quiet);\n          }\n\n          LexConfig.addConfigParams(cmd, config || {});\n        } catch(error) {\n          log(`\\n${cliName} Error: Failed to load config file: ${error.message}`, 'error', quiet);\n          if(debug) {\n            console.error(error);\n          }\n        }\n      } else {\n        log(`\\n${cliName} Error: Config file must be a JS, CJS, MJS, TS, or JSON file.`, 'error', quiet);\n      }\n    } else {\n      if(debug) {\n        log('No config file found. Using default configuration.', 'info', quiet);\n      }\n\n      LexConfig.useTypescript = !!typescript;\n      LexConfig.addConfigParams(cmd, LexConfig.config);\n    }\n  }\n\n  static checkTypescriptConfig() {\n    const tsconfigPath: string = pathResolve(cwd, './tsconfig.json');\n\n    if(!existsSync(tsconfigPath)) {\n      const dirName = getDirName();\n      writeFileSync(tsconfigPath, readFileSync(pathResolve(dirName, '../../../tsconfig.base.json')));\n    }\n  }\n\n  static checkCompileTypescriptConfig() {\n    const lexDir = LexConfig.getLexDir();\n    const tsconfigCompilePath: string = pathResolve(lexDir, './tsconfig.build.json');\n\n    if(!existsSync(tsconfigCompilePath)) {\n      // Try to copy from the template location\n      const templatePath = pathResolve(lexDir, 'tsconfig.build.json');\n      if(existsSync(templatePath)) {\n        writeFileSync(tsconfigCompilePath, readFileSync(templatePath));\n      }\n    }\n  }\n\n  static checkLintTypescriptConfig() {\n    const lexDir = LexConfig.getLexDir();\n    const tsconfigLintPath: string = pathResolve(lexDir, './tsconfig.lint.json');\n\n    if(!existsSync(tsconfigLintPath)) {\n      // Try to copy from the template location\n      const templatePath = pathResolve(lexDir, 'tsconfig.lint.json');\n      if(existsSync(templatePath)) {\n        writeFileSync(tsconfigLintPath, readFileSync(templatePath));\n      }\n    }\n  }\n\n  static checkTestTypescriptConfig() {\n    const lexDir = LexConfig.getLexDir();\n    const tsconfigTestPath: string = pathResolve(lexDir, './tsconfig.test.json');\n\n    if(!existsSync(tsconfigTestPath)) {\n      // Try to copy from the template location\n      const templatePath = pathResolve(lexDir, 'tsconfig.test.json');\n      if(existsSync(templatePath)) {\n        writeFileSync(tsconfigTestPath, readFileSync(templatePath));\n      }\n    }\n  }\n}"],
  "mappings": "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",
  "names": ["cwd"]
}
