@nlabs/lex 1.47.2 → 1.48.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.gitattributes +1 -0
- package/.storybook/main.ts +86 -0
- package/.storybook/preview.ts +15 -0
- package/.vscode/settings.json +83 -0
- package/CHANGELOG.md +1 -0
- package/TYPESCRIPT_CONFIGS.md +103 -0
- package/__mocks__/LexConfig.js +17 -2
- package/__mocks__/execa.js +9 -7
- package/__mocks__/file.js +50 -0
- package/__mocks__/ora.js +10 -1
- package/config.json +33 -0
- package/dist/LexConfig.js +93 -5
- package/dist/commands/ai/ai.js +1 -1
- package/dist/commands/build/build.js +15 -11
- package/dist/commands/clean/clean.js +10 -4
- package/dist/commands/compile/compile.js +29 -34
- package/dist/commands/create/create.js +5 -5
- package/dist/commands/dev/dev.js +11 -7
- package/dist/commands/init/init.js +5 -5
- package/dist/commands/lint/lint.js +55 -64
- package/dist/commands/migrate/migrate.js +2 -2
- package/dist/commands/storybook/storybook.js +174 -0
- package/dist/commands/test/test.js +51 -13
- package/dist/commands/update/update.js +3 -2
- package/dist/commands/upgrade/upgrade.js +3 -3
- package/dist/commands/versions/versions.js +3 -3
- package/dist/create/changelog.js +1 -1
- package/dist/dist/LexConfig.d.ts +119 -0
- package/dist/dist/utils/file.d.ts +7 -0
- package/dist/dist/utils/log.d.ts +1 -0
- package/dist/index.js +4 -3
- package/dist/lex.js +14 -1
- package/dist/utils/aiService.js +2 -2
- package/dist/utils/app.js +3 -3
- package/dist/utils/file.js +78 -4
- package/eslint.config.js +5 -3
- package/examples/lex.config.js +50 -0
- package/jest.config.cjs +14 -14
- package/jest.setup.js +30 -4
- package/package.json +40 -23
- package/tsconfig.build.json +38 -5
- package/tsconfig.json +28 -1
- package/tsconfig.lint.json +44 -0
- package/tsconfig.test.json +48 -0
- package/webpack.config.js +14 -13
- package/dist/LexConfig.d.ts +0 -79
- package/dist/commands/ai/ai.d.ts +0 -17
- package/dist/commands/ai/index.d.ts +0 -8
- package/dist/commands/build/build.cli.test.d.ts +0 -5
- package/dist/commands/build/build.d.ts +0 -18
- package/dist/commands/build/build.integration.test.d.ts +0 -1
- package/dist/commands/build/build.options.test.d.ts +0 -5
- package/dist/commands/clean/clean.cli.test.d.ts +0 -1
- package/dist/commands/clean/clean.d.ts +0 -7
- package/dist/commands/clean/clean.integration.test.d.ts +0 -1
- package/dist/commands/clean/clean.options.test.d.ts +0 -1
- package/dist/commands/compile/compile.cli.test.d.ts +0 -1
- package/dist/commands/compile/compile.d.ts +0 -2
- package/dist/commands/compile/compile.integration.test.d.ts +0 -1
- package/dist/commands/compile/compile.options.test.d.ts +0 -1
- package/dist/commands/config/config.cli.test.d.ts +0 -1
- package/dist/commands/config/config.d.ts +0 -7
- package/dist/commands/config/config.integration.test.d.ts +0 -1
- package/dist/commands/config/config.options.test.d.ts +0 -1
- package/dist/commands/copy/copy.cli.test.d.ts +0 -1
- package/dist/commands/copy/copy.d.ts +0 -6
- package/dist/commands/copy/copy.integration.test.d.ts +0 -1
- package/dist/commands/copy/copy.options.test.d.ts +0 -1
- package/dist/commands/create/create.cli.test.d.ts +0 -1
- package/dist/commands/create/create.d.ts +0 -8
- package/dist/commands/create/create.integration.test.d.ts +0 -1
- package/dist/commands/create/create.options.test.d.ts +0 -1
- package/dist/commands/dev/dev.cli.test.d.ts +0 -1
- package/dist/commands/dev/dev.d.ts +0 -11
- package/dist/commands/dev/dev.integration.test.d.ts +0 -1
- package/dist/commands/dev/dev.options.test.d.ts +0 -1
- package/dist/commands/init/init.cli.test.d.ts +0 -1
- package/dist/commands/init/init.d.ts +0 -9
- package/dist/commands/init/init.integration.test.d.ts +0 -1
- package/dist/commands/init/init.options.test.d.ts +0 -1
- package/dist/commands/link/link.cli.test.d.ts +0 -1
- package/dist/commands/link/link.d.ts +0 -6
- package/dist/commands/link/link.integration.test.d.ts +0 -1
- package/dist/commands/link/link.options.test.d.ts +0 -1
- package/dist/commands/lint/autofix.d.ts +0 -2
- package/dist/commands/lint/lint.cli.test.d.ts +0 -1
- package/dist/commands/lint/lint.d.ts +0 -39
- package/dist/commands/lint/lint.integration.test.d.ts +0 -1
- package/dist/commands/lint/lint.options.test.d.ts +0 -1
- package/dist/commands/migrate/migrate.cli.test.d.ts +0 -1
- package/dist/commands/migrate/migrate.d.ts +0 -7
- package/dist/commands/migrate/migrate.integration.test.d.ts +0 -1
- package/dist/commands/migrate/migrate.options.test.d.ts +0 -1
- package/dist/commands/publish/publish.cli.test.d.ts +0 -1
- package/dist/commands/publish/publish.d.ts +0 -12
- package/dist/commands/publish/publish.integration.test.d.ts +0 -1
- package/dist/commands/publish/publish.options.test.d.ts +0 -1
- package/dist/commands/test/test.cli.test.d.ts +0 -1
- package/dist/commands/test/test.d.ts +0 -50
- package/dist/commands/test/test.integration.test.d.ts +0 -1
- package/dist/commands/test/test.options.test.d.ts +0 -1
- package/dist/commands/test/test.test.d.ts +0 -1
- package/dist/commands/update/update.cli.test.d.ts +0 -1
- package/dist/commands/update/update.d.ts +0 -9
- package/dist/commands/update/update.integration.test.d.ts +0 -1
- package/dist/commands/update/update.options.test.d.ts +0 -1
- package/dist/commands/upgrade/upgrade.cli.test.d.ts +0 -1
- package/dist/commands/upgrade/upgrade.d.ts +0 -7
- package/dist/commands/upgrade/upgrade.integration.test.d.ts +0 -1
- package/dist/commands/upgrade/upgrade.options.test.d.ts +0 -1
- package/dist/commands/versions/versions.cli.test.d.ts +0 -1
- package/dist/commands/versions/versions.d.ts +0 -13
- package/dist/commands/versions/versions.integration.test.d.ts +0 -1
- package/dist/commands/versions/versions.options.test.d.ts +0 -1
- package/dist/create/changelog.d.ts +0 -6
- package/dist/index.d.ts +0 -31
- package/dist/lex.d.ts +0 -2
- package/dist/types.d.ts +0 -5
- package/dist/utils/aiService.d.ts +0 -9
- package/dist/utils/app.d.ts +0 -41
- package/dist/utils/file.d.ts +0 -3
- package/dist/utils/log.d.ts +0 -1
- package/dist/utils/reactShim.d.ts +0 -2
- /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
|
package/__mocks__/LexConfig.js
CHANGED
|
@@ -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
|
};
|
package/__mocks__/execa.js
CHANGED
|
@@ -1,11 +1,13 @@
|
|
|
1
1
|
// Mock implementation of execa
|
|
2
|
-
const mockExeca = jest.fn().mockImplementation(() =>
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
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 =
|
|
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 =
|
|
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"]
}

|