@nlabs/lex 1.54.1 → 1.54.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.github/copilot-instructions.md +4 -4
- package/README.md +25 -25
- package/__mocks__/LexConfig.js +9 -9
- package/__mocks__/boxen.js +1 -1
- package/__mocks__/build.js +6 -6
- package/__mocks__/compare-versions.js +1 -1
- package/__mocks__/compile.js +2 -2
- package/__mocks__/execa.js +2 -2
- package/__mocks__/latest-version.js +1 -1
- package/__mocks__/ora.js +13 -13
- package/__mocks__/versions.js +4 -4
- package/config.json +2 -2
- package/examples/lex.config.js +4 -4
- package/lex.config.js +4 -4
- package/lib/LexConfig.d.ts +2 -9
- package/lib/LexConfig.js +2 -2
- package/lib/commands/ai/ai.js +2 -2
- package/lib/commands/config/config.js +14 -8
- package/lib/commands/migrate/migrate.js +2 -2
- package/lib/commands/test/test.d.ts +2 -0
- package/lib/commands/test/test.js +130 -117
- package/lib/commands/versions/versions.d.ts +1 -1
- package/lib/commands/versions/versions.js +3 -3
- package/lib/lex.js +2 -2
- package/lib/test-react/index.d.ts +1 -1
- package/lib/test-react/index.js +2 -2
- package/lib/types.d.ts +1 -1
- package/lib/types.js +1 -1
- package/lib/utils/app.js +2 -2
- package/lib/vitest.d.js +3 -0
- package/package.json +42 -42
- package/resolver.cjs +11 -9
- package/tsconfig/reactNative.json +3 -2
- package/tsconfig.build.json +3 -3
- package/tsconfig.json +4 -3
- package/tsconfig.lint.json +3 -2
- package/tsconfig.template.json +3 -2
- package/tsconfig.test.json +4 -3
- package/vitest.config.d.mts +2 -0
- package/vitest.config.mjs +61 -0
- package/vitest.config.template.cjs +66 -0
- package/vitest.setup.template.js +19 -0
- package/webpack.config.js +1 -1
- package/jest.config.d.mts +0 -50
- package/jest.config.mjs +0 -72
- package/jest.config.template.cjs +0 -71
- package/jest.setup.template.js +0 -18
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
# Lex: AI Coding Agent Instructions
|
|
2
2
|
|
|
3
3
|
## Project Overview
|
|
4
|
-
Lex is a zero-configuration React development CLI that provides a complete development environment with AI-powered features. It uses SWC for lightning-fast compilation and includes
|
|
4
|
+
Lex is a zero-configuration React development CLI that provides a complete development environment with AI-powered features. It uses SWC for lightning-fast compilation and includes Vitest testing, Storybook integration, and intelligent code assistance.
|
|
5
5
|
|
|
6
6
|
## Architecture & Key Components
|
|
7
7
|
|
|
@@ -15,7 +15,7 @@ Lex is a zero-configuration React development CLI that provides a complete devel
|
|
|
15
15
|
### Build System
|
|
16
16
|
- **Compiler**: SWC (10-100x faster than Babel)
|
|
17
17
|
- **Bundler**: Webpack (configurable, defaults to SWC for speed)
|
|
18
|
-
- **Testing**:
|
|
18
|
+
- **Testing**: Vitest with jsdom environment
|
|
19
19
|
- **Linting**: ESLint with AI-powered auto-fixes
|
|
20
20
|
|
|
21
21
|
## Critical Workflows
|
|
@@ -115,7 +115,7 @@ log('Error message', 'error');
|
|
|
115
115
|
|
|
116
116
|
### Unit Tests
|
|
117
117
|
```typescript
|
|
118
|
-
// Use
|
|
118
|
+
// Use Vitest with jsdom for DOM testing
|
|
119
119
|
import {render, screen} from '@testing-library/react';
|
|
120
120
|
import {Button} from './Button.js';
|
|
121
121
|
|
|
@@ -191,4 +191,4 @@ import {readFile, writeFile} from '../utils/file.js';
|
|
|
191
191
|
- Commands should be stateless and configurable
|
|
192
192
|
- Prefer functional programming patterns
|
|
193
193
|
- Document complex logic with comments
|
|
194
|
-
- Follow existing naming conventions (camelCase for variables, PascalCase for types)
|
|
194
|
+
- Follow existing naming conventions (camelCase for variables, PascalCase for types)
|
package/README.md
CHANGED
|
@@ -37,7 +37,7 @@ Lex is the all-in-one development CLI that eliminates the complexity of modern R
|
|
|
37
37
|
### **Enterprise Ready**
|
|
38
38
|
|
|
39
39
|
- TypeScript support out of the box
|
|
40
|
-
-
|
|
40
|
+
- Vitest testing framework included
|
|
41
41
|
- Storybook integration
|
|
42
42
|
- Production-optimized builds
|
|
43
43
|
|
|
@@ -70,7 +70,7 @@ Lex comes with everything you need for modern React development:
|
|
|
70
70
|
| Tool | Purpose | Version |
|
|
71
71
|
|------|---------|---------|
|
|
72
72
|
| **SWC** | Lightning-fast TypeScript/JavaScript compiler | Latest |
|
|
73
|
-
| **
|
|
73
|
+
| **Vitest** | Testing framework | Latest |
|
|
74
74
|
| **TypeScript** | Type safety | Latest |
|
|
75
75
|
| **Webpack** | Advanced bundling | Latest |
|
|
76
76
|
| **Storybook** | Component development | Latest |
|
|
@@ -100,7 +100,7 @@ Lex comes with everything you need for modern React development:
|
|
|
100
100
|
|
|
101
101
|
| Command | Description | Quick Example |
|
|
102
102
|
|---------|-------------|---------------|
|
|
103
|
-
| [`lex test`](#test) | Run
|
|
103
|
+
| [`lex test`](#test) | Run Vitest tests | `lex test --watch` |
|
|
104
104
|
| [`lex lint`](#lint) | Lint code with ESLint | `lex lint --fix` |
|
|
105
105
|
| [`lex storybook`](#storybook) | Start Storybook | `lex storybook --open` |
|
|
106
106
|
|
|
@@ -204,15 +204,15 @@ lex test --generate
|
|
|
204
204
|
# Debug failing tests
|
|
205
205
|
lex test --debugTests
|
|
206
206
|
|
|
207
|
-
# Use project-specific
|
|
208
|
-
lex test --config ./
|
|
207
|
+
# Use project-specific Vitest config
|
|
208
|
+
lex test --config ./vitest.config.mjs
|
|
209
209
|
```
|
|
210
210
|
|
|
211
211
|
#### Advanced Testing Features
|
|
212
212
|
|
|
213
|
-
- **Smart Configuration Merging**: Automatically merges your project's
|
|
213
|
+
- **Smart Configuration Merging**: Automatically merges your project's Vitest config with Lex's optimized defaults
|
|
214
214
|
- **ESM Support**: Automatic detection and configuration for ES modules projects
|
|
215
|
-
- **Automatic Setup**: Creates
|
|
215
|
+
- **Automatic Setup**: Creates vitest.setup.js file if one doesn't exist
|
|
216
216
|
- **React JSX Automatic Runtime**: No need to import React in your test files
|
|
217
217
|
- **TypeScript-First**: Optimized for TypeScript projects with specialized configs
|
|
218
218
|
|
|
@@ -288,12 +288,13 @@ export default {
|
|
|
288
288
|
// SWC configuration (defaults to ESM format)
|
|
289
289
|
// SWC is now the default transpiler for all compilation tasks
|
|
290
290
|
|
|
291
|
-
//
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
291
|
+
// Vitest configuration (merged with Lex defaults)
|
|
292
|
+
vitest: {
|
|
293
|
+
environment: 'jsdom',
|
|
294
|
+
setupFiles: ['./src/setupTests.js'],
|
|
295
|
+
include: ['src/**/*.{test,spec}.ts'],
|
|
296
|
+
coverage: {
|
|
297
|
+
reporter: ['html', 'text']
|
|
297
298
|
}
|
|
298
299
|
}
|
|
299
300
|
};
|
|
@@ -352,17 +353,16 @@ SWC is automatically configured and doesn't require additional configuration in
|
|
|
352
353
|
| **Decorators** | TypeScript decorators support | `enabled` |
|
|
353
354
|
| **Source Maps** | Debug information | `inline` |
|
|
354
355
|
|
|
355
|
-
### **
|
|
356
|
+
### **Vitest Configuration**
|
|
356
357
|
|
|
357
358
|
| Option | Type | Default | Description | Example |
|
|
358
359
|
|--------|------|---------|-------------|---------|
|
|
359
|
-
| `
|
|
360
|
-
| `
|
|
361
|
-
| `
|
|
362
|
-
| `
|
|
363
|
-
| `
|
|
364
|
-
| `
|
|
365
|
-
| `jest.transformIgnorePatterns` | `string[]` | `undefined` | Patterns to ignore in transforms | `jest: { transformIgnorePatterns: ['node_modules'] }` |
|
|
360
|
+
| `vitest.environment` | `string` | `undefined` | Test environment | `vitest: { environment: 'jsdom' }` |
|
|
361
|
+
| `vitest.setupFiles` | `string[]` | `undefined` | Setup files executed before tests | `vitest: { setupFiles: ['./src/setupTests.ts'] }` |
|
|
362
|
+
| `vitest.include` | `string[]` | `undefined` | Test file glob patterns | `vitest: { include: ['src/**/*.{test,spec}.ts'] }` |
|
|
363
|
+
| `vitest.exclude` | `string[]` | `undefined` | Exclude patterns for tests | `vitest: { exclude: ['dist'] }` |
|
|
364
|
+
| `vitest.coverage.reporter` | `string[]` | `undefined` | Coverage reporters | `vitest: { coverage: { reporter: ['text', 'html'] } }` |
|
|
365
|
+
| `vitest.coverage.reportsDirectory` | `string` | `undefined` | Coverage output directory | `vitest: { coverage: { reportsDirectory: 'coverage' } }` |
|
|
366
366
|
|
|
367
367
|
### **ESLint Configuration**
|
|
368
368
|
|
|
@@ -467,9 +467,9 @@ export default {
|
|
|
467
467
|
maxTokens: 8000,
|
|
468
468
|
temperature: 0.3
|
|
469
469
|
},
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
470
|
+
vitest: {
|
|
471
|
+
environment: 'jsdom',
|
|
472
|
+
setupFiles: ['./src/setupTests.ts']
|
|
473
473
|
}
|
|
474
474
|
};
|
|
475
475
|
```
|
|
@@ -634,7 +634,7 @@ This project is licensed under the MIT License - see the [LICENSE](LICENSE) file
|
|
|
634
634
|
## 🙏 Acknowledgments
|
|
635
635
|
|
|
636
636
|
- **SWC** - For lightning-fast TypeScript/JavaScript compilation
|
|
637
|
-
- **
|
|
637
|
+
- **Vitest** - For comprehensive testing
|
|
638
638
|
- **TypeScript** - For type safety
|
|
639
639
|
- **Webpack** - For advanced bundling features
|
|
640
640
|
- **Storybook** - For component development
|
package/__mocks__/LexConfig.js
CHANGED
|
@@ -10,14 +10,14 @@ const defaultConfigValues = {
|
|
|
10
10
|
|
|
11
11
|
const LexConfig = {
|
|
12
12
|
config: defaultConfigValues,
|
|
13
|
-
parseConfig:
|
|
14
|
-
checkTypescriptConfig:
|
|
15
|
-
checkCompileTypescriptConfig:
|
|
16
|
-
checkLintTypescriptConfig:
|
|
17
|
-
checkTestTypescriptConfig:
|
|
18
|
-
getLexDir:
|
|
19
|
-
updateConfig:
|
|
20
|
-
addConfigParams:
|
|
13
|
+
parseConfig: vi.fn(),
|
|
14
|
+
checkTypescriptConfig: vi.fn(),
|
|
15
|
+
checkCompileTypescriptConfig: vi.fn(),
|
|
16
|
+
checkLintTypescriptConfig: vi.fn(),
|
|
17
|
+
checkTestTypescriptConfig: vi.fn(),
|
|
18
|
+
getLexDir: vi.fn(() => '/mock/lex/dir'),
|
|
19
|
+
updateConfig: vi.fn((config) => ({...defaultConfigValues, ...config})),
|
|
20
|
+
addConfigParams: vi.fn(),
|
|
21
21
|
get useTypescript() {
|
|
22
22
|
return this.config.useTypescript;
|
|
23
23
|
},
|
|
@@ -26,7 +26,7 @@ const LexConfig = {
|
|
|
26
26
|
}
|
|
27
27
|
};
|
|
28
28
|
|
|
29
|
-
const getTypeScriptConfigPath =
|
|
29
|
+
const getTypeScriptConfigPath = vi.fn((configName) => `/mock/lex/dir/${configName}`);
|
|
30
30
|
|
|
31
31
|
module.exports = {
|
|
32
32
|
LexConfig,
|
package/__mocks__/boxen.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
// Mock implementation of boxen
|
|
2
|
-
const mockBoxen =
|
|
2
|
+
const mockBoxen = vi.fn().mockImplementation((text, options) => `[BOXED] ${text}`);
|
|
3
3
|
|
|
4
4
|
module.exports = mockBoxen;
|
|
5
5
|
module.exports.default = mockBoxen;
|
package/__mocks__/build.js
CHANGED
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
// Mock implementation of build module
|
|
2
2
|
const mockSpinner = {
|
|
3
|
-
start:
|
|
4
|
-
succeed:
|
|
5
|
-
fail:
|
|
3
|
+
start: vi.fn(),
|
|
4
|
+
succeed: vi.fn(),
|
|
5
|
+
fail: vi.fn()
|
|
6
6
|
};
|
|
7
7
|
|
|
8
|
-
const build =
|
|
9
|
-
const buildWithEsBuild =
|
|
10
|
-
const buildWithWebpack =
|
|
8
|
+
const build = vi.fn().mockResolvedValue(0);
|
|
9
|
+
const buildWithEsBuild = vi.fn().mockResolvedValue(0);
|
|
10
|
+
const buildWithWebpack = vi.fn().mockResolvedValue(0);
|
|
11
11
|
|
|
12
12
|
module.exports = {
|
|
13
13
|
build,
|
package/__mocks__/compile.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
// Mock implementation of compile module
|
|
2
|
-
const compile =
|
|
3
|
-
const hasFileType =
|
|
2
|
+
const compile = vi.fn().mockResolvedValue(0);
|
|
3
|
+
const hasFileType = vi.fn().mockReturnValue(false);
|
|
4
4
|
|
|
5
5
|
module.exports = {
|
|
6
6
|
compile,
|
package/__mocks__/execa.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
// Mock implementation of execa
|
|
2
|
-
const mockExeca =
|
|
2
|
+
const mockExeca = vi.fn().mockImplementation(() =>
|
|
3
3
|
Promise.resolve({
|
|
4
4
|
stdout: '',
|
|
5
5
|
stderr: '',
|
|
@@ -9,7 +9,7 @@ const mockExeca = jest.fn().mockImplementation(() =>
|
|
|
9
9
|
})
|
|
10
10
|
);
|
|
11
11
|
|
|
12
|
-
mockExeca.sync =
|
|
12
|
+
mockExeca.sync = vi.fn().mockImplementation(() => ({
|
|
13
13
|
stdout: '',
|
|
14
14
|
stderr: '',
|
|
15
15
|
exitCode: 0,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
module.exports =
|
|
1
|
+
module.exports = vi.fn().mockResolvedValue('1.0.0');
|
package/__mocks__/ora.js
CHANGED
|
@@ -1,25 +1,25 @@
|
|
|
1
1
|
// Mock implementation of ora
|
|
2
2
|
const mockSpinner = {
|
|
3
|
-
start:
|
|
4
|
-
stop:
|
|
5
|
-
succeed:
|
|
6
|
-
fail:
|
|
7
|
-
warn:
|
|
8
|
-
info:
|
|
3
|
+
start: vi.fn().mockReturnThis(),
|
|
4
|
+
stop: vi.fn().mockReturnThis(),
|
|
5
|
+
succeed: vi.fn().mockReturnThis(),
|
|
6
|
+
fail: vi.fn().mockReturnThis(),
|
|
7
|
+
warn: vi.fn().mockReturnThis(),
|
|
8
|
+
info: vi.fn().mockReturnThis(),
|
|
9
9
|
text: '',
|
|
10
10
|
color: 'cyan',
|
|
11
11
|
isSpinning: false
|
|
12
12
|
};
|
|
13
13
|
|
|
14
|
-
const mockOra =
|
|
14
|
+
const mockOra = vi.fn().mockImplementation(() => mockSpinner);
|
|
15
15
|
|
|
16
16
|
module.exports = () => ({
|
|
17
|
-
start:
|
|
18
|
-
succeed:
|
|
19
|
-
fail:
|
|
20
|
-
stop:
|
|
21
|
-
info:
|
|
22
|
-
warn:
|
|
17
|
+
start: vi.fn().mockReturnThis(),
|
|
18
|
+
succeed: vi.fn().mockReturnThis(),
|
|
19
|
+
fail: vi.fn().mockReturnThis(),
|
|
20
|
+
stop: vi.fn().mockReturnThis(),
|
|
21
|
+
info: vi.fn().mockReturnThis(),
|
|
22
|
+
warn: vi.fn().mockReturnThis(),
|
|
23
23
|
text: ''
|
|
24
24
|
});
|
|
25
25
|
|
package/__mocks__/versions.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
// Mock implementation of versions module
|
|
2
|
-
const jsonVersions =
|
|
3
|
-
const packages =
|
|
4
|
-
const parseVersion =
|
|
5
|
-
const versions =
|
|
2
|
+
const jsonVersions = vi.fn().mockResolvedValue({});
|
|
3
|
+
const packages = vi.fn().mockResolvedValue([]);
|
|
4
|
+
const parseVersion = vi.fn().mockReturnValue('1.0.0');
|
|
5
|
+
const versions = vi.fn().mockResolvedValue(undefined);
|
|
6
6
|
|
|
7
7
|
module.exports = {
|
|
8
8
|
jsonVersions,
|
package/config.json
CHANGED
package/examples/lex.config.js
CHANGED
|
@@ -114,9 +114,9 @@ export default {
|
|
|
114
114
|
},
|
|
115
115
|
|
|
116
116
|
// Test configuration
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
117
|
+
vitest: {
|
|
118
|
+
dir: './src',
|
|
119
|
+
environment: 'node'
|
|
120
120
|
}
|
|
121
121
|
};
|
|
122
122
|
|
|
@@ -157,4 +157,4 @@ export default {
|
|
|
157
157
|
// minify: true,
|
|
158
158
|
// sourceMaps: true
|
|
159
159
|
// }
|
|
160
|
-
// };
|
|
160
|
+
// };
|
package/lex.config.js
CHANGED
package/lib/LexConfig.d.ts
CHANGED
|
@@ -1,14 +1,7 @@
|
|
|
1
1
|
import type { Options } from '@swc/core';
|
|
2
2
|
import type { Linter } from 'eslint';
|
|
3
|
-
export interface
|
|
3
|
+
export interface VitestConfig {
|
|
4
4
|
[key: string]: unknown;
|
|
5
|
-
roots?: string[];
|
|
6
|
-
testEnvironment?: string;
|
|
7
|
-
transform?: Record<string, [string, Record<string, unknown>]>;
|
|
8
|
-
transformIgnorePatterns?: string[];
|
|
9
|
-
moduleNameMapper?: Record<string, string>;
|
|
10
|
-
extensionsToTreatAsEsm?: string[];
|
|
11
|
-
preset?: string;
|
|
12
5
|
}
|
|
13
6
|
export interface WebpackConfig {
|
|
14
7
|
[key: string]: unknown;
|
|
@@ -39,7 +32,7 @@ export interface LexConfigType {
|
|
|
39
32
|
env?: object;
|
|
40
33
|
eslint?: ESLintConfig;
|
|
41
34
|
gitUrl?: string;
|
|
42
|
-
|
|
35
|
+
vitest?: VitestConfig;
|
|
43
36
|
libraryName?: string;
|
|
44
37
|
libraryTarget?: string;
|
|
45
38
|
outputFile?: string;
|
package/lib/LexConfig.js
CHANGED
|
@@ -34,7 +34,7 @@ export const defaultConfigValues = {
|
|
|
34
34
|
entryJs: 'index.js',
|
|
35
35
|
env: null,
|
|
36
36
|
eslint: {},
|
|
37
|
-
|
|
37
|
+
vitest: {},
|
|
38
38
|
outputFullPath: pathResolve(cwd, './lib'),
|
|
39
39
|
outputHash: false,
|
|
40
40
|
outputPath: './lib',
|
|
@@ -414,4 +414,4 @@ _define_property(LexConfig, "config", {
|
|
|
414
414
|
...defaultConfigValues
|
|
415
415
|
});
|
|
416
416
|
|
|
417
|
-
//# 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 findFileUp from 'find-file-up';\nimport {existsSync, readFileSync, writeFileSync} from 'fs';\nimport {\n  dirname,\n  extname as pathExtname,\n  relative as pathRelative,\n  resolve as pathResolve\n} from 'path';\nimport {URL} from 'url';\n\nimport {getLexPackageJsonPath, relativeFilePath} from './utils/file.js';\nimport {log} from './utils/log.js';\n\nimport type {Options} from '@swc/core';\nimport type {Linter} from 'eslint';\n\nconst cwd: string = process.cwd();\n\n\nexport interface JestConfig {\n  [key: string]: unknown;\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}\n\nexport interface WebpackConfig {\n  [key: string]: unknown;\n  entry?: string | string[];\n  output?: Record<string, unknown>;\n  module?: Record<string, unknown>;\n  plugins?: unknown[];\n  staticPath?: string;\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}\n\nexport interface ESLintConfig {\n  [key: string]: unknown;\n  extends?: string[];\n  rules?: Linter.RulesRecord;\n}\n\nexport interface LexConfigType {\n  ai?: AIConfig;\n  configFiles?: string[];\n  copyFiles?: string[];\n  entryHTML?: string;\n  entryJs?: string;\n  env?: object;\n  eslint?: ESLintConfig;\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  swc?: SWCOptions;\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    maxTokens: 4000,\n    model: 'gpt-4o',\n    provider: 'none',\n    temperature: 0.1\n  },\n  configFiles: [],\n  copyFiles: [],\n  entryHTML: 'index.html',\n  entryJs: 'index.js',\n  env: null,\n  eslint: {},\n  jest: {},\n  outputFullPath: pathResolve(cwd, './lib'),\n  outputHash: false,\n  outputPath: './lib',\n  packageManager: 'npm',\n  preset: 'web',\n  sourceFullPath: pathResolve(cwd, './src'),\n  sourcePath: './src',\n  swc: {\n    inlineSourcesContent: true,\n    isModule: true,\n    jsc: {\n      externalHelpers: false,\n      keepClassNames: false,\n      loose: false,\n      parser: {\n        decorators: true,\n        dynamicImport: true,\n        syntax: 'typescript',\n        tsx: true\n      },\n      target: 'es2023',\n      transform: {\n        react: {\n          runtime: 'automatic'\n        }\n      }\n    },\n    minify: false,\n    module: {\n      lazy: false,\n      noInterop: false,\n      strict: false,\n      strictMode: true,\n      type: 'es6'\n    },\n    sourceMaps: 'inline'\n  },\n  targetEnvironment: 'web',\n  useGraphQl: false,\n  useTypescript: false,\n  webpack: {\n    staticPath: './src/static'\n  }\n};\n\nexport const getPackageDir = (): string => {\n  const cwd = process.cwd();\n  const currentPkgPath = pathResolve(cwd, 'package.json');\n\n  if(existsSync(currentPkgPath)) {\n    try {\n      const pkg = JSON.parse(readFileSync(currentPkgPath, 'utf8'));\n      if(!pkg.workspaces) {\n        return cwd;\n      }\n    } catch{\n      return cwd;\n    }\n  }\n\n  let searchDir = cwd;\n\n  for(let i = 0; i < 10; i++) {\n    const pkgPath = pathResolve(searchDir, 'package.json');\n    if(existsSync(pkgPath)) {\n      try {\n        const pkg = JSON.parse(readFileSync(pkgPath, 'utf8'));\n\n        if(!pkg.workspaces) {\n          return searchDir;\n        }\n      } catch{\n        // Continue searching\n      }\n    }\n\n    const parent = dirname(searchDir);\n\n    if(parent === searchDir) {\n      break;\n    }\n    searchDir = parent;\n  }\n\n  const configFormats = ['js', 'mjs', 'cjs', 'ts', 'json'];\n\n  for(const format of configFormats) {\n    const configPath = findFileUp.sync(`lex.config.${format}`, cwd, 5);\n\n    if(configPath) {\n      return dirname(configPath);\n    }\n  }\n\n  return cwd;\n};\n\nexport const getTypeScriptConfigPath = (configName: string): string => {\n  const packageDir = getPackageDir();\n  const cwd = process.cwd();\n\n  if(configName === 'tsconfig.build.json') {\n    const projectBuildConfig = pathResolve(packageDir, 'tsconfig.build.json');\n\n    if(existsSync(projectBuildConfig)) {\n      return projectBuildConfig;\n    }\n\n    const rootBuildConfig = pathResolve(cwd, 'tsconfig.build.json');\n    if(existsSync(rootBuildConfig)) {\n      return rootBuildConfig;\n    }\n  }\n\n  if(configName === 'tsconfig.lint.json') {\n    const projectLintConfig = pathResolve(packageDir, 'tsconfig.eslint.json');\n    if(existsSync(projectLintConfig)) {\n      return projectLintConfig;\n    }\n\n    const rootLintConfig = pathResolve(cwd, 'tsconfig.eslint.json');\n\n    if(existsSync(rootLintConfig)) {\n      return rootLintConfig;\n    }\n  }\n\n  if(configName === 'tsconfig.test.json') {\n    const projectTestConfig = pathResolve(packageDir, 'tsconfig.test.json');\n    if(existsSync(projectTestConfig)) {\n      return projectTestConfig;\n    }\n\n    const rootTestConfig = pathResolve(cwd, 'tsconfig.test.json');\n\n    if(existsSync(rootTestConfig)) {\n      return rootTestConfig;\n    }\n  }\n\n  const projectConfigPath = pathResolve(packageDir, configName);\n\n  if(existsSync(projectConfigPath)) {\n    return projectConfigPath;\n  }\n\n  const rootConfigPath = pathResolve(cwd, configName);\n\n  if(existsSync(rootConfigPath)) {\n    return rootConfigPath;\n  }\n\n  const lexDir = LexConfig.getLexDir();\n\n  return pathResolve(lexDir, configName);\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 {entryJs, sourceFullPath, targetEnvironment} = 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    LexConfig.config.swc.jsc.parser = {\n      syntax: 'typescript',\n      tsx: true\n    };\n\n    if(targetEnvironment === 'web') {\n      LexConfig.config.swc.jsc.transform = {\n        react: {\n          runtime: 'automatic'\n        }\n      };\n    }\n  }\n\n  static getLexDir(): string {\n    return dirname(getLexPackageJsonPath());\n  }\n\n  static updateConfig(updatedConfig: LexConfigType): LexConfigType {\n    const {outputFullPath, outputPath, sourcePath, sourceFullPath, useTypescript, ai} = updatedConfig;\n    const packageDir = getPackageDir();\n\n    if(useTypescript !== undefined) {\n      LexConfig.useTypescript = useTypescript;\n    }\n\n    if(outputPath !== undefined && outputFullPath === undefined) {\n      updatedConfig.outputFullPath = pathResolve(packageDir, outputPath);\n    }\n\n    if(sourcePath !== undefined && sourceFullPath === undefined) {\n      updatedConfig.sourceFullPath = pathResolve(packageDir, 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    const packageDir = getPackageDir();\n\n    if(outputPath !== undefined) {\n      params.outputPath = outputPath;\n      params.outputFullPath = pathResolve(packageDir, outputPath);\n    } else if(params.outputPath && !params.outputFullPath) {\n      params.outputFullPath = pathResolve(packageDir, params.outputPath);\n    }\n\n    if(sourcePath !== undefined) {\n      params.sourcePath = sourcePath;\n      params.sourceFullPath = pathResolve(packageDir, sourcePath);\n    } else if(params.sourcePath && !params.sourceFullPath) {\n      params.sourceFullPath = pathResolve(packageDir, params.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            // eslint-disable-next-line no-console\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 packageDir = getPackageDir();\n    const tsconfigPath: string = pathResolve(packageDir, './tsconfig.json');\n\n    if(!existsSync(tsconfigPath)) {\n      const lexDir = LexConfig.getLexDir();\n      const baseConfigPath = pathResolve(lexDir, 'tsconfig.base.json');\n      const templateConfigPath = pathResolve(lexDir, 'tsconfig.template.json');\n      const sourcePath = existsSync(baseConfigPath) ? baseConfigPath : templateConfigPath;\n\n      if(existsSync(sourcePath)) {\n        writeFileSync(tsconfigPath, readFileSync(sourcePath));\n      }\n    }\n  }\n\n  static getTypeScriptDeclarationFlags(): string[] {\n    const cwd = process.cwd();\n    const outputPath = LexConfig.config.outputPath || './lib';\n    const outputFullPath = LexConfig.config.outputFullPath || pathResolve(cwd, outputPath);\n    const sourcePath = LexConfig.config.sourcePath || './src';\n    const sourceFullPath = LexConfig.config.sourceFullPath || pathResolve(cwd, sourcePath);\n    const relativeOutDir = pathRelative(cwd, outputFullPath) || './lib';\n    const relativeRootDir = pathRelative(cwd, sourceFullPath) || './src';\n\n    return [\n      '--emitDeclarationOnly', // CRITICAL: Only emit .d.ts files, no JS files\n      '--declaration', // Generate declaration files\n      '--declarationMap', // Generate source maps for declarations\n      '--outDir', relativeOutDir,\n      '--rootDir', relativeRootDir,\n      '--skipLibCheck', // Skip type checking of declaration files (faster, more lenient)\n      '--esModuleInterop',\n      '--allowSyntheticDefaultImports',\n      '--module', 'NodeNext',\n      '--moduleResolution', 'NodeNext',\n      '--target', 'ESNext',\n      '--jsx', 'react-jsx',\n      '--isolatedModules',\n      '--resolveJsonModule',\n      '--allowJs'\n      // Note: --noUnusedLocals and --noUnusedParameters are not needed for declaration generation\n      // and would actually enable strict checking, which we want to avoid for faster declaration generation\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      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      const templatePath = pathResolve(lexDir, 'tsconfig.test.json');\n      if(existsSync(templatePath)) {\n        writeFileSync(tsconfigTestPath, readFileSync(templatePath));\n      }\n    }\n  }\n}\n\nexport type SWCOptions = Options;"],"names":["findFileUp","existsSync","readFileSync","writeFileSync","dirname","extname","pathExtname","relative","pathRelative","resolve","pathResolve","URL","getLexPackageJsonPath","relativeFilePath","log","cwd","process","defaultConfigValues","ai","maxTokens","model","provider","temperature","configFiles","copyFiles","entryHTML","entryJs","env","eslint","jest","outputFullPath","outputHash","outputPath","packageManager","preset","sourceFullPath","sourcePath","swc","inlineSourcesContent","isModule","jsc","externalHelpers","keepClassNames","loose","parser","decorators","dynamicImport","syntax","tsx","target","transform","react","runtime","minify","module","lazy","noInterop","strict","strictMode","type","sourceMaps","targetEnvironment","useGraphQl","useTypescript","webpack","staticPath","getPackageDir","currentPkgPath","pkg","JSON","parse","workspaces","searchDir","i","pkgPath","parent","configFormats","format","configPath","sync","getTypeScriptConfigPath","configName","packageDir","projectBuildConfig","rootBuildConfig","projectLintConfig","rootLintConfig","projectTestConfig","rootTestConfig","projectConfigPath","rootConfigPath","lexDir","LexConfig","getLexDir","value","config","indexPath","hasIndexTsx","updateConfig","updatedConfig","undefined","CURSOR_IDE","addConfigParams","cmd","params","nameProperty","environment","typescript","LEX_CONFIG","stringify","commandName","isStatic","static","parseConfig","isRoot","cliName","lexConfig","lexConfigName","quiet","debug","configBaseName","configExists","potentialPath","ext","configContent","configJson","default","error","message","includes","lexCustomConfig","fileUrl","href","console","checkTypescriptConfig","tsconfigPath","baseConfigPath","templateConfigPath","getTypeScriptDeclarationFlags","relativeOutDir","relativeRootDir","checkLintTypescriptConfig","tsconfigLintPath","templatePath","checkTestTypescriptConfig","tsconfigTestPath"],"mappings":"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"}
|
|
417
|
+
//# 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 findFileUp from 'find-file-up';\nimport {existsSync, readFileSync, writeFileSync} from 'fs';\nimport {\n  dirname,\n  extname as pathExtname,\n  relative as pathRelative,\n  resolve as pathResolve\n} from 'path';\nimport {URL} from 'url';\n\nimport {getLexPackageJsonPath, relativeFilePath} from './utils/file.js';\nimport {log} from './utils/log.js';\n\nimport type {Options} from '@swc/core';\nimport type {Linter} from 'eslint';\n\nconst cwd: string = process.cwd();\n\n\nexport interface VitestConfig {\n  [key: string]: unknown;\n}\n\nexport interface WebpackConfig {\n  [key: string]: unknown;\n  entry?: string | string[];\n  output?: Record<string, unknown>;\n  module?: Record<string, unknown>;\n  plugins?: unknown[];\n  staticPath?: string;\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}\n\nexport interface ESLintConfig {\n  [key: string]: unknown;\n  extends?: string[];\n  rules?: Linter.RulesRecord;\n}\n\nexport interface LexConfigType {\n  ai?: AIConfig;\n  configFiles?: string[];\n  copyFiles?: string[];\n  entryHTML?: string;\n  entryJs?: string;\n  env?: object;\n  eslint?: ESLintConfig;\n  gitUrl?: string;\n  vitest?: VitestConfig;\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  swc?: SWCOptions;\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    maxTokens: 4000,\n    model: 'gpt-4o',\n    provider: 'none',\n    temperature: 0.1\n  },\n  configFiles: [],\n  copyFiles: [],\n  entryHTML: 'index.html',\n  entryJs: 'index.js',\n  env: null,\n  eslint: {},\n  vitest: {},\n  outputFullPath: pathResolve(cwd, './lib'),\n  outputHash: false,\n  outputPath: './lib',\n  packageManager: 'npm',\n  preset: 'web',\n  sourceFullPath: pathResolve(cwd, './src'),\n  sourcePath: './src',\n  swc: {\n    inlineSourcesContent: true,\n    isModule: true,\n    jsc: {\n      externalHelpers: false,\n      keepClassNames: false,\n      loose: false,\n      parser: {\n        decorators: true,\n        dynamicImport: true,\n        syntax: 'typescript',\n        tsx: true\n      },\n      target: 'es2023',\n      transform: {\n        react: {\n          runtime: 'automatic'\n        }\n      }\n    },\n    minify: false,\n    module: {\n      lazy: false,\n      noInterop: false,\n      strict: false,\n      strictMode: true,\n      type: 'es6'\n    },\n    sourceMaps: 'inline'\n  },\n  targetEnvironment: 'web',\n  useGraphQl: false,\n  useTypescript: false,\n  webpack: {\n    staticPath: './src/static'\n  }\n};\n\nexport const getPackageDir = (): string => {\n  const cwd = process.cwd();\n  const currentPkgPath = pathResolve(cwd, 'package.json');\n\n  if(existsSync(currentPkgPath)) {\n    try {\n      const pkg = JSON.parse(readFileSync(currentPkgPath, 'utf8'));\n      if(!pkg.workspaces) {\n        return cwd;\n      }\n    } catch{\n      return cwd;\n    }\n  }\n\n  let searchDir = cwd;\n\n  for(let i = 0; i < 10; i++) {\n    const pkgPath = pathResolve(searchDir, 'package.json');\n    if(existsSync(pkgPath)) {\n      try {\n        const pkg = JSON.parse(readFileSync(pkgPath, 'utf8'));\n\n        if(!pkg.workspaces) {\n          return searchDir;\n        }\n      } catch{\n        // Continue searching\n      }\n    }\n\n    const parent = dirname(searchDir);\n\n    if(parent === searchDir) {\n      break;\n    }\n    searchDir = parent;\n  }\n\n  const configFormats = ['js', 'mjs', 'cjs', 'ts', 'json'];\n\n  for(const format of configFormats) {\n    const configPath = findFileUp.sync(`lex.config.${format}`, cwd, 5);\n\n    if(configPath) {\n      return dirname(configPath);\n    }\n  }\n\n  return cwd;\n};\n\nexport const getTypeScriptConfigPath = (configName: string): string => {\n  const packageDir = getPackageDir();\n  const cwd = process.cwd();\n\n  if(configName === 'tsconfig.build.json') {\n    const projectBuildConfig = pathResolve(packageDir, 'tsconfig.build.json');\n\n    if(existsSync(projectBuildConfig)) {\n      return projectBuildConfig;\n    }\n\n    const rootBuildConfig = pathResolve(cwd, 'tsconfig.build.json');\n    if(existsSync(rootBuildConfig)) {\n      return rootBuildConfig;\n    }\n  }\n\n  if(configName === 'tsconfig.lint.json') {\n    const projectLintConfig = pathResolve(packageDir, 'tsconfig.eslint.json');\n    if(existsSync(projectLintConfig)) {\n      return projectLintConfig;\n    }\n\n    const rootLintConfig = pathResolve(cwd, 'tsconfig.eslint.json');\n\n    if(existsSync(rootLintConfig)) {\n      return rootLintConfig;\n    }\n  }\n\n  if(configName === 'tsconfig.test.json') {\n    const projectTestConfig = pathResolve(packageDir, 'tsconfig.test.json');\n    if(existsSync(projectTestConfig)) {\n      return projectTestConfig;\n    }\n\n    const rootTestConfig = pathResolve(cwd, 'tsconfig.test.json');\n\n    if(existsSync(rootTestConfig)) {\n      return rootTestConfig;\n    }\n  }\n\n  const projectConfigPath = pathResolve(packageDir, configName);\n\n  if(existsSync(projectConfigPath)) {\n    return projectConfigPath;\n  }\n\n  const rootConfigPath = pathResolve(cwd, configName);\n\n  if(existsSync(rootConfigPath)) {\n    return rootConfigPath;\n  }\n\n  const lexDir = LexConfig.getLexDir();\n\n  return pathResolve(lexDir, configName);\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 {entryJs, sourceFullPath, targetEnvironment} = 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    LexConfig.config.swc.jsc.parser = {\n      syntax: 'typescript',\n      tsx: true\n    };\n\n    if(targetEnvironment === 'web') {\n      LexConfig.config.swc.jsc.transform = {\n        react: {\n          runtime: 'automatic'\n        }\n      };\n    }\n  }\n\n  static getLexDir(): string {\n    return dirname(getLexPackageJsonPath());\n  }\n\n  static updateConfig(updatedConfig: LexConfigType): LexConfigType {\n    const {outputFullPath, outputPath, sourcePath, sourceFullPath, useTypescript, ai} = updatedConfig;\n    const packageDir = getPackageDir();\n\n    if(useTypescript !== undefined) {\n      LexConfig.useTypescript = useTypescript;\n    }\n\n    if(outputPath !== undefined && outputFullPath === undefined) {\n      updatedConfig.outputFullPath = pathResolve(packageDir, outputPath);\n    }\n\n    if(sourcePath !== undefined && sourceFullPath === undefined) {\n      updatedConfig.sourceFullPath = pathResolve(packageDir, 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    const packageDir = getPackageDir();\n\n    if(outputPath !== undefined) {\n      params.outputPath = outputPath;\n      params.outputFullPath = pathResolve(packageDir, outputPath);\n    } else if(params.outputPath && !params.outputFullPath) {\n      params.outputFullPath = pathResolve(packageDir, params.outputPath);\n    }\n\n    if(sourcePath !== undefined) {\n      params.sourcePath = sourcePath;\n      params.sourceFullPath = pathResolve(packageDir, sourcePath);\n    } else if(params.sourcePath && !params.sourceFullPath) {\n      params.sourceFullPath = pathResolve(packageDir, params.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            // eslint-disable-next-line no-console\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 packageDir = getPackageDir();\n    const tsconfigPath: string = pathResolve(packageDir, './tsconfig.json');\n\n    if(!existsSync(tsconfigPath)) {\n      const lexDir = LexConfig.getLexDir();\n      const baseConfigPath = pathResolve(lexDir, 'tsconfig.base.json');\n      const templateConfigPath = pathResolve(lexDir, 'tsconfig.template.json');\n      const sourcePath = existsSync(baseConfigPath) ? baseConfigPath : templateConfigPath;\n\n      if(existsSync(sourcePath)) {\n        writeFileSync(tsconfigPath, readFileSync(sourcePath));\n      }\n    }\n  }\n\n  static getTypeScriptDeclarationFlags(): string[] {\n    const cwd = process.cwd();\n    const outputPath = LexConfig.config.outputPath || './lib';\n    const outputFullPath = LexConfig.config.outputFullPath || pathResolve(cwd, outputPath);\n    const sourcePath = LexConfig.config.sourcePath || './src';\n    const sourceFullPath = LexConfig.config.sourceFullPath || pathResolve(cwd, sourcePath);\n    const relativeOutDir = pathRelative(cwd, outputFullPath) || './lib';\n    const relativeRootDir = pathRelative(cwd, sourceFullPath) || './src';\n\n    return [\n      '--emitDeclarationOnly', // CRITICAL: Only emit .d.ts files, no JS files\n      '--declaration', // Generate declaration files\n      '--declarationMap', // Generate source maps for declarations\n      '--outDir', relativeOutDir,\n      '--rootDir', relativeRootDir,\n      '--skipLibCheck', // Skip type checking of declaration files (faster, more lenient)\n      '--esModuleInterop',\n      '--allowSyntheticDefaultImports',\n      '--module', 'NodeNext',\n      '--moduleResolution', 'NodeNext',\n      '--target', 'ESNext',\n      '--jsx', 'react-jsx',\n      '--isolatedModules',\n      '--resolveJsonModule',\n      '--allowJs'\n      // Note: --noUnusedLocals and --noUnusedParameters are not needed for declaration generation\n      // and would actually enable strict checking, which we want to avoid for faster declaration generation\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      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      const templatePath = pathResolve(lexDir, 'tsconfig.test.json');\n      if(existsSync(templatePath)) {\n        writeFileSync(tsconfigTestPath, readFileSync(templatePath));\n      }\n    }\n  }\n}\n\nexport type SWCOptions = Options;\n"],"names":["findFileUp","existsSync","readFileSync","writeFileSync","dirname","extname","pathExtname","relative","pathRelative","resolve","pathResolve","URL","getLexPackageJsonPath","relativeFilePath","log","cwd","process","defaultConfigValues","ai","maxTokens","model","provider","temperature","configFiles","copyFiles","entryHTML","entryJs","env","eslint","vitest","outputFullPath","outputHash","outputPath","packageManager","preset","sourceFullPath","sourcePath","swc","inlineSourcesContent","isModule","jsc","externalHelpers","keepClassNames","loose","parser","decorators","dynamicImport","syntax","tsx","target","transform","react","runtime","minify","module","lazy","noInterop","strict","strictMode","type","sourceMaps","targetEnvironment","useGraphQl","useTypescript","webpack","staticPath","getPackageDir","currentPkgPath","pkg","JSON","parse","workspaces","searchDir","i","pkgPath","parent","configFormats","format","configPath","sync","getTypeScriptConfigPath","configName","packageDir","projectBuildConfig","rootBuildConfig","projectLintConfig","rootLintConfig","projectTestConfig","rootTestConfig","projectConfigPath","rootConfigPath","lexDir","LexConfig","getLexDir","value","config","indexPath","hasIndexTsx","updateConfig","updatedConfig","undefined","CURSOR_IDE","addConfigParams","cmd","params","nameProperty","environment","typescript","LEX_CONFIG","stringify","commandName","isStatic","static","parseConfig","isRoot","cliName","lexConfig","lexConfigName","quiet","debug","configBaseName","configExists","potentialPath","ext","configContent","configJson","default","error","message","includes","lexCustomConfig","fileUrl","href","console","checkTypescriptConfig","tsconfigPath","baseConfigPath","templateConfigPath","getTypeScriptDeclarationFlags","relativeOutDir","relativeRootDir","checkLintTypescriptConfig","tsconfigLintPath","templatePath","checkTestTypescriptConfig","tsconfigTestPath"],"mappings":"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"}
|