@nlabs/lex 1.49.5 → 1.50.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/.swcrc +35 -0
- package/README.md +43 -59
- package/config.json +32 -8
- package/examples/lex.config.js +110 -10
- package/lex.config.js +34 -7
- package/lib/Button.stories.js +99 -0
- package/lib/LexConfig.d.ts +60 -22
- package/lib/LexConfig.js +285 -244
- package/lib/commands/ai/ai.js +287 -288
- package/lib/commands/ai/index.js +8 -7
- package/lib/commands/build/build.d.ts +2 -2
- package/lib/commands/build/build.js +349 -458
- package/lib/commands/clean/clean.js +45 -33
- package/lib/commands/compile/compile.js +214 -228
- package/lib/commands/config/config.js +46 -42
- package/lib/commands/copy/copy.js +36 -35
- package/lib/commands/create/create.js +200 -121
- package/lib/commands/dev/dev.d.ts +1 -0
- package/lib/commands/dev/dev.js +261 -259
- package/lib/commands/init/init.js +108 -88
- package/lib/commands/link/link.js +18 -14
- package/lib/commands/lint/lint.js +735 -742
- package/lib/commands/migrate/migrate.js +49 -36
- package/lib/commands/publish/publish.js +116 -96
- package/lib/commands/serverless/serverless.js +611 -585
- package/lib/commands/storybook/storybook.js +242 -238
- package/lib/commands/test/test.js +381 -409
- package/lib/commands/update/update.js +141 -120
- package/lib/commands/upgrade/upgrade.js +51 -44
- package/lib/commands/versions/versions.d.ts +1 -1
- package/lib/commands/versions/versions.js +36 -38
- package/lib/create/changelog.js +136 -125
- package/lib/index.js +40 -38
- package/lib/lex.js +95 -68
- package/lib/storybook/index.js +6 -1
- package/lib/test-react/index.js +7 -84
- package/lib/types.d.ts +1 -1
- package/lib/types.js +7 -1
- package/lib/utils/aiService.js +240 -227
- package/lib/utils/app.js +274 -273
- package/lib/utils/deepMerge.js +37 -23
- package/lib/utils/file.js +218 -215
- package/lib/utils/log.js +29 -27
- package/lib/utils/reactShim.js +7 -85
- package/lib/utils/translations.js +92 -82
- package/package.json +63 -64
- package/templates/typescript/DataLayer.js.txt +218 -0
- package/templates/typescript/DataLayer.test.js.txt +268 -0
- package/templates/typescript/DataLayer.test.ts.txt +269 -0
- package/templates/typescript/DataLayer.ts.txt +227 -0
- package/webpack.config.js +38 -28
- package/lib/commands/lint/autofix.d.ts +0 -2
package/lib/LexConfig.js
CHANGED
|
@@ -1,268 +1,309 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
configFiles: [],
|
|
15
|
-
copyFiles: [],
|
|
16
|
-
entryHTML: "index.html",
|
|
17
|
-
entryJs: "index.js",
|
|
18
|
-
env: null,
|
|
19
|
-
esbuild: {
|
|
20
|
-
drop: ["console", "debugger"],
|
|
21
|
-
legalComments: "none",
|
|
22
|
-
metafile: false,
|
|
23
|
-
minify: true,
|
|
24
|
-
pure: ["console.log", "console.warn", "console.error"],
|
|
25
|
-
sourcemap: false,
|
|
26
|
-
splitting: true,
|
|
27
|
-
treeShaking: true
|
|
28
|
-
},
|
|
29
|
-
eslint: {},
|
|
30
|
-
jest: {},
|
|
31
|
-
outputFullPath: pathResolve(cwd, "./lib"),
|
|
32
|
-
outputHash: false,
|
|
33
|
-
outputPath: "./lib",
|
|
34
|
-
packageManager: "npm",
|
|
35
|
-
preset: "web",
|
|
36
|
-
sourceFullPath: pathResolve(cwd, "./src"),
|
|
37
|
-
sourcePath: "./src",
|
|
38
|
-
targetEnvironment: "web",
|
|
39
|
-
useGraphQl: false,
|
|
40
|
-
useTypescript: false,
|
|
41
|
-
webpack: {
|
|
42
|
-
publicPath: "./src/static"
|
|
43
|
-
}
|
|
44
|
-
};
|
|
45
|
-
const getTypeScriptConfigPath = (configName) => {
|
|
46
|
-
const cwd2 = process.cwd();
|
|
47
|
-
if (configName === "tsconfig.build.json") {
|
|
48
|
-
const projectBuildConfig = pathResolve(cwd2, "tsconfig.build.json");
|
|
49
|
-
if (existsSync(projectBuildConfig)) {
|
|
50
|
-
return projectBuildConfig;
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
if (configName === "tsconfig.lint.json") {
|
|
54
|
-
const projectLintConfig = pathResolve(cwd2, "tsconfig.eslint.json");
|
|
55
|
-
if (existsSync(projectLintConfig)) {
|
|
56
|
-
return projectLintConfig;
|
|
1
|
+
/**
|
|
2
|
+
* Copyright (c) 2018-Present, Nitrogen Labs, Inc.
|
|
3
|
+
* Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
|
|
4
|
+
*/ function _define_property(obj, key, value) {
|
|
5
|
+
if (key in obj) {
|
|
6
|
+
Object.defineProperty(obj, key, {
|
|
7
|
+
value: value,
|
|
8
|
+
enumerable: true,
|
|
9
|
+
configurable: true,
|
|
10
|
+
writable: true
|
|
11
|
+
});
|
|
12
|
+
} else {
|
|
13
|
+
obj[key] = value;
|
|
57
14
|
}
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
15
|
+
return obj;
|
|
16
|
+
}
|
|
17
|
+
import { existsSync, readFileSync, writeFileSync } from 'fs';
|
|
18
|
+
import { dirname, extname as pathExtname, resolve as pathResolve } from 'path';
|
|
19
|
+
import { URL } from 'url';
|
|
20
|
+
import { getDirName, getLexPackageJsonPath, relativeFilePath } from './utils/file.js';
|
|
21
|
+
import { log } from './utils/log.js';
|
|
22
|
+
const cwd = process.cwd();
|
|
23
|
+
export const defaultConfigValues = {
|
|
24
|
+
ai: {
|
|
25
|
+
maxTokens: 4000,
|
|
26
|
+
model: 'gpt-4o',
|
|
27
|
+
provider: 'none',
|
|
28
|
+
temperature: 0.1
|
|
29
|
+
},
|
|
30
|
+
configFiles: [],
|
|
31
|
+
copyFiles: [],
|
|
32
|
+
entryHTML: 'index.html',
|
|
33
|
+
entryJs: 'index.js',
|
|
34
|
+
env: null,
|
|
35
|
+
eslint: {},
|
|
36
|
+
jest: {},
|
|
37
|
+
outputFullPath: pathResolve(cwd, './lib'),
|
|
38
|
+
outputHash: false,
|
|
39
|
+
outputPath: './lib',
|
|
40
|
+
packageManager: 'npm',
|
|
41
|
+
preset: 'web',
|
|
42
|
+
sourceFullPath: pathResolve(cwd, './src'),
|
|
43
|
+
sourcePath: './src',
|
|
44
|
+
swc: {
|
|
45
|
+
jsc: {
|
|
46
|
+
externalHelpers: false,
|
|
47
|
+
keepClassNames: false,
|
|
48
|
+
loose: false,
|
|
49
|
+
parser: {
|
|
50
|
+
decorators: true,
|
|
51
|
+
dynamicImport: true,
|
|
52
|
+
syntax: 'typescript',
|
|
53
|
+
tsx: true
|
|
54
|
+
},
|
|
55
|
+
target: 'es2020',
|
|
56
|
+
transform: {
|
|
57
|
+
react: {
|
|
58
|
+
runtime: 'automatic'
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
},
|
|
62
|
+
module: {
|
|
63
|
+
lazy: false,
|
|
64
|
+
noInterop: false,
|
|
65
|
+
strict: false,
|
|
66
|
+
strictMode: true,
|
|
67
|
+
type: 'es6'
|
|
68
|
+
},
|
|
69
|
+
inlineSourcesContent: true,
|
|
70
|
+
isModule: true,
|
|
71
|
+
minify: false,
|
|
72
|
+
sourceMaps: 'inline'
|
|
73
|
+
},
|
|
74
|
+
targetEnvironment: 'web',
|
|
75
|
+
useGraphQl: false,
|
|
76
|
+
useTypescript: false,
|
|
77
|
+
webpack: {
|
|
78
|
+
staticPath: './src/static'
|
|
63
79
|
}
|
|
64
|
-
}
|
|
65
|
-
const projectConfigPath = pathResolve(cwd2, configName);
|
|
66
|
-
if (existsSync(projectConfigPath)) {
|
|
67
|
-
return projectConfigPath;
|
|
68
|
-
}
|
|
69
|
-
const lexDir = LexConfig.getLexDir();
|
|
70
|
-
return pathResolve(lexDir, configName);
|
|
71
80
|
};
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
const { entryJs } = LexConfig.config;
|
|
80
|
-
if (entryJs === "index.js" && value) {
|
|
81
|
-
const indexPath = pathResolve(cwd, sourceFullPath, "index.tsx");
|
|
82
|
-
const hasIndexTsx = existsSync(indexPath);
|
|
83
|
-
if (hasIndexTsx) {
|
|
84
|
-
LexConfig.config.entryJs = "index.tsx";
|
|
85
|
-
} else {
|
|
86
|
-
LexConfig.config.entryJs = "index.ts";
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
static getLexDir() {
|
|
91
|
-
return dirname(getLexPackageJsonPath());
|
|
92
|
-
}
|
|
93
|
-
static updateConfig(updatedConfig) {
|
|
94
|
-
const { outputFullPath, outputPath, sourcePath, sourceFullPath, useTypescript, ai } = updatedConfig;
|
|
95
|
-
const cwd2 = process.cwd();
|
|
96
|
-
if (useTypescript !== void 0) {
|
|
97
|
-
LexConfig.useTypescript = useTypescript;
|
|
98
|
-
}
|
|
99
|
-
if (outputPath !== void 0 && outputFullPath === void 0) {
|
|
100
|
-
updatedConfig.outputFullPath = pathResolve(cwd2, outputPath);
|
|
101
|
-
}
|
|
102
|
-
if (sourcePath !== void 0 && sourceFullPath === void 0) {
|
|
103
|
-
updatedConfig.sourceFullPath = pathResolve(cwd2, sourcePath);
|
|
81
|
+
export const getTypeScriptConfigPath = (configName)=>{
|
|
82
|
+
const cwd = process.cwd();
|
|
83
|
+
if (configName === 'tsconfig.build.json') {
|
|
84
|
+
const projectBuildConfig = pathResolve(cwd, 'tsconfig.build.json');
|
|
85
|
+
if (existsSync(projectBuildConfig)) {
|
|
86
|
+
return projectBuildConfig;
|
|
87
|
+
}
|
|
104
88
|
}
|
|
105
|
-
if (
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
89
|
+
if (configName === 'tsconfig.lint.json') {
|
|
90
|
+
const projectLintConfig = pathResolve(cwd, 'tsconfig.eslint.json');
|
|
91
|
+
if (existsSync(projectLintConfig)) {
|
|
92
|
+
return projectLintConfig;
|
|
93
|
+
}
|
|
110
94
|
}
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
const { environment, outputPath, sourcePath, typescript } = cmd;
|
|
117
|
-
if (outputPath !== void 0) {
|
|
118
|
-
params.outputPath = outputPath;
|
|
119
|
-
params.outputFullPath = pathResolve(cwd, outputPath);
|
|
95
|
+
if (configName === 'tsconfig.test.json') {
|
|
96
|
+
const projectTestConfig = pathResolve(cwd, 'tsconfig.test.json');
|
|
97
|
+
if (existsSync(projectTestConfig)) {
|
|
98
|
+
return projectTestConfig;
|
|
99
|
+
}
|
|
120
100
|
}
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
101
|
+
const projectConfigPath = pathResolve(cwd, configName);
|
|
102
|
+
if (existsSync(projectConfigPath)) {
|
|
103
|
+
return projectConfigPath;
|
|
124
104
|
}
|
|
125
|
-
|
|
126
|
-
|
|
105
|
+
const lexDir = LexConfig.getLexDir();
|
|
106
|
+
return pathResolve(lexDir, configName);
|
|
107
|
+
};
|
|
108
|
+
export class LexConfig {
|
|
109
|
+
static set useTypescript(value) {
|
|
110
|
+
LexConfig.config.useTypescript = value;
|
|
111
|
+
const { sourceFullPath } = LexConfig.config;
|
|
112
|
+
const { entryJs } = LexConfig.config;
|
|
113
|
+
if (entryJs === 'index.js' && value) {
|
|
114
|
+
const indexPath = pathResolve(cwd, sourceFullPath, 'index.tsx');
|
|
115
|
+
const hasIndexTsx = existsSync(indexPath);
|
|
116
|
+
if (hasIndexTsx) {
|
|
117
|
+
LexConfig.config.entryJs = 'index.tsx';
|
|
118
|
+
} else {
|
|
119
|
+
LexConfig.config.entryJs = 'index.ts';
|
|
120
|
+
}
|
|
121
|
+
}
|
|
127
122
|
}
|
|
128
|
-
|
|
129
|
-
|
|
123
|
+
static getLexDir() {
|
|
124
|
+
return dirname(getLexPackageJsonPath());
|
|
130
125
|
}
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
);
|
|
140
|
-
}
|
|
141
|
-
static async parseConfig(cmd, isRoot = true) {
|
|
142
|
-
const { cliName = "Lex", lexConfig, lexConfigName, quiet, typescript, debug = false } = cmd;
|
|
143
|
-
const configFormats = ["js", "mjs", "cjs", "ts", "json"];
|
|
144
|
-
const configBaseName = lexConfigName || "lex.config";
|
|
145
|
-
let configPath = lexConfig || "";
|
|
146
|
-
let configExists = lexConfig ? existsSync(configPath) : false;
|
|
147
|
-
if (!configPath || !configExists) {
|
|
148
|
-
if (debug) {
|
|
149
|
-
log(`Searching for config files with base name: ${configBaseName}`, "info", quiet);
|
|
150
|
-
}
|
|
151
|
-
for (const format of configFormats) {
|
|
152
|
-
const potentialPath = isRoot ? pathResolve(cwd, `./${configBaseName}.${format}`) : relativeFilePath(`${configBaseName}.${format}`, cwd);
|
|
153
|
-
if (debug) {
|
|
154
|
-
log(`Checking for config file: ${potentialPath}`, "info", quiet);
|
|
126
|
+
static updateConfig(updatedConfig) {
|
|
127
|
+
const { outputFullPath, outputPath, sourcePath, sourceFullPath, useTypescript, ai } = updatedConfig;
|
|
128
|
+
const cwd = process.cwd();
|
|
129
|
+
if (useTypescript !== undefined) {
|
|
130
|
+
LexConfig.useTypescript = useTypescript;
|
|
131
|
+
}
|
|
132
|
+
if (outputPath !== undefined && outputFullPath === undefined) {
|
|
133
|
+
updatedConfig.outputFullPath = pathResolve(cwd, outputPath);
|
|
155
134
|
}
|
|
156
|
-
if (
|
|
157
|
-
|
|
158
|
-
configExists = true;
|
|
159
|
-
break;
|
|
135
|
+
if (sourcePath !== undefined && sourceFullPath === undefined) {
|
|
136
|
+
updatedConfig.sourceFullPath = pathResolve(cwd, sourcePath);
|
|
160
137
|
}
|
|
161
|
-
|
|
138
|
+
if (ai) {
|
|
139
|
+
LexConfig.config.ai = {
|
|
140
|
+
...LexConfig.config.ai,
|
|
141
|
+
...ai
|
|
142
|
+
};
|
|
143
|
+
if (process.env.CURSOR_IDE === 'true' && LexConfig.config.ai.provider === 'none') {
|
|
144
|
+
LexConfig.config.ai.provider = 'cursor';
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
LexConfig.config = {
|
|
148
|
+
...LexConfig.config,
|
|
149
|
+
...updatedConfig
|
|
150
|
+
};
|
|
151
|
+
return LexConfig.config;
|
|
162
152
|
}
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
let configJson;
|
|
170
|
-
try {
|
|
171
|
-
configJson = JSON.parse(configContent)?.default || {};
|
|
172
|
-
} catch (error) {
|
|
173
|
-
log(`
|
|
174
|
-
${cliName} Error: Failed to parse JSON config: ${error.message}`, "error", quiet);
|
|
175
|
-
configJson = {};
|
|
176
|
-
}
|
|
177
|
-
LexConfig.addConfigParams(cmd, configJson);
|
|
178
|
-
} else {
|
|
179
|
-
log(`
|
|
180
|
-
${cliName} Error: Config file malformed, ${configPath}`, "error", quiet);
|
|
153
|
+
static addConfigParams(cmd, params) {
|
|
154
|
+
const nameProperty = '_name';
|
|
155
|
+
const { environment, outputPath, sourcePath, typescript } = cmd;
|
|
156
|
+
if (outputPath !== undefined) {
|
|
157
|
+
params.outputPath = outputPath;
|
|
158
|
+
params.outputFullPath = pathResolve(cwd, outputPath);
|
|
181
159
|
}
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
160
|
+
if (sourcePath !== undefined) {
|
|
161
|
+
params.sourcePath = sourcePath;
|
|
162
|
+
params.sourceFullPath = pathResolve(cwd, sourcePath);
|
|
163
|
+
}
|
|
164
|
+
if (typescript !== undefined) {
|
|
165
|
+
params.useTypescript = true;
|
|
166
|
+
}
|
|
167
|
+
if (environment !== undefined) {
|
|
168
|
+
params.targetEnvironment = environment === 'web' ? 'web' : 'node';
|
|
169
|
+
}
|
|
170
|
+
process.env.LEX_CONFIG = JSON.stringify({
|
|
171
|
+
...LexConfig.updateConfig(params),
|
|
172
|
+
commandName: cmd[nameProperty],
|
|
173
|
+
isStatic: cmd.static
|
|
174
|
+
}, null, 0);
|
|
175
|
+
}
|
|
176
|
+
static async parseConfig(cmd, isRoot = true) {
|
|
177
|
+
const { cliName = 'Lex', lexConfig, lexConfigName, quiet, typescript, debug = false } = cmd;
|
|
178
|
+
const configFormats = [
|
|
179
|
+
'js',
|
|
180
|
+
'mjs',
|
|
181
|
+
'cjs',
|
|
182
|
+
'ts',
|
|
183
|
+
'json'
|
|
184
|
+
];
|
|
185
|
+
const configBaseName = lexConfigName || 'lex.config';
|
|
186
|
+
let configPath = lexConfig || '';
|
|
187
|
+
let configExists = lexConfig ? existsSync(configPath) : false;
|
|
188
|
+
if (!configPath || !configExists) {
|
|
187
189
|
if (debug) {
|
|
188
|
-
|
|
190
|
+
log(`Searching for config files with base name: ${configBaseName}`, 'info', quiet);
|
|
191
|
+
}
|
|
192
|
+
for (const format of configFormats){
|
|
193
|
+
const potentialPath = isRoot ? pathResolve(cwd, `./${configBaseName}.${format}`) : relativeFilePath(`${configBaseName}.${format}`, cwd);
|
|
194
|
+
if (debug) {
|
|
195
|
+
log(`Checking for config file: ${potentialPath}`, 'info', quiet);
|
|
196
|
+
}
|
|
197
|
+
if (existsSync(potentialPath)) {
|
|
198
|
+
configPath = potentialPath;
|
|
199
|
+
configExists = true;
|
|
200
|
+
break;
|
|
201
|
+
}
|
|
189
202
|
}
|
|
190
|
-
|
|
191
|
-
|
|
203
|
+
}
|
|
204
|
+
if (configExists) {
|
|
205
|
+
log(`Using ${cliName} configuration file: ${configPath}`, 'note', quiet);
|
|
206
|
+
const ext = pathExtname(configPath);
|
|
207
|
+
if (ext === '.json') {
|
|
208
|
+
const configContent = readFileSync(configPath, 'utf8');
|
|
209
|
+
if (configContent) {
|
|
210
|
+
let configJson;
|
|
211
|
+
try {
|
|
212
|
+
configJson = JSON.parse(configContent)?.default || {};
|
|
213
|
+
} catch (error) {
|
|
214
|
+
log(`\n${cliName} Error: Failed to parse JSON config: ${error.message}`, 'error', quiet);
|
|
215
|
+
configJson = {};
|
|
216
|
+
}
|
|
217
|
+
LexConfig.addConfigParams(cmd, configJson);
|
|
218
|
+
} else {
|
|
219
|
+
log(`\n${cliName} Error: Config file malformed, ${configPath}`, 'error', quiet);
|
|
220
|
+
}
|
|
221
|
+
} else if ([
|
|
222
|
+
'.js',
|
|
223
|
+
'.mjs',
|
|
224
|
+
'.cjs',
|
|
225
|
+
'.ts'
|
|
226
|
+
].includes(ext)) {
|
|
227
|
+
try {
|
|
228
|
+
let lexCustomConfig;
|
|
229
|
+
if (ext === '.cjs') {
|
|
230
|
+
const fileUrl = new URL(`file:///${pathResolve(configPath)}`).href;
|
|
231
|
+
if (debug) {
|
|
232
|
+
log(`Loading CommonJS config from: ${fileUrl}`, 'info', quiet);
|
|
233
|
+
}
|
|
234
|
+
lexCustomConfig = await import(fileUrl);
|
|
235
|
+
} else {
|
|
236
|
+
if (debug) {
|
|
237
|
+
log(`Loading ESM/TS config from: ${configPath}`, 'info', quiet);
|
|
238
|
+
}
|
|
239
|
+
lexCustomConfig = await import(configPath);
|
|
240
|
+
}
|
|
241
|
+
const config = lexCustomConfig.default || lexCustomConfig;
|
|
242
|
+
if (debug) {
|
|
243
|
+
log(`Loaded config: ${JSON.stringify(config, null, 2)}`, 'info', quiet);
|
|
244
|
+
}
|
|
245
|
+
if (!config) {
|
|
246
|
+
log(`\n${cliName} Warning: Config file loaded but no configuration found`, 'warn', quiet);
|
|
247
|
+
}
|
|
248
|
+
LexConfig.addConfigParams(cmd, config || {});
|
|
249
|
+
} catch (error) {
|
|
250
|
+
log(`\n${cliName} Error: Failed to load config file: ${error.message}`, 'error', quiet);
|
|
251
|
+
if (debug) {
|
|
252
|
+
// eslint-disable-next-line no-console
|
|
253
|
+
console.error(error);
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
} else {
|
|
257
|
+
log(`\n${cliName} Error: Config file must be a JS, CJS, MJS, TS, or JSON file.`, 'error', quiet);
|
|
258
|
+
}
|
|
259
|
+
} else {
|
|
192
260
|
if (debug) {
|
|
193
|
-
|
|
261
|
+
log('No config file found. Using default configuration.', 'info', quiet);
|
|
194
262
|
}
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
const config = lexCustomConfig.default || lexCustomConfig;
|
|
198
|
-
if (debug) {
|
|
199
|
-
log(`Loaded config: ${JSON.stringify(config, null, 2)}`, "info", quiet);
|
|
200
|
-
}
|
|
201
|
-
if (!config) {
|
|
202
|
-
log(`
|
|
203
|
-
${cliName} Warning: Config file loaded but no configuration found`, "warn", quiet);
|
|
204
|
-
}
|
|
205
|
-
LexConfig.addConfigParams(cmd, config || {});
|
|
206
|
-
} catch (error) {
|
|
207
|
-
log(`
|
|
208
|
-
${cliName} Error: Failed to load config file: ${error.message}`, "error", quiet);
|
|
209
|
-
if (debug) {
|
|
210
|
-
console.error(error);
|
|
211
|
-
}
|
|
263
|
+
LexConfig.useTypescript = !!typescript;
|
|
264
|
+
LexConfig.addConfigParams(cmd, LexConfig.config);
|
|
212
265
|
}
|
|
213
|
-
} else {
|
|
214
|
-
log(`
|
|
215
|
-
${cliName} Error: Config file must be a JS, CJS, MJS, TS, or JSON file.`, "error", quiet);
|
|
216
|
-
}
|
|
217
|
-
} else {
|
|
218
|
-
if (debug) {
|
|
219
|
-
log("No config file found. Using default configuration.", "info", quiet);
|
|
220
|
-
}
|
|
221
|
-
LexConfig.useTypescript = !!typescript;
|
|
222
|
-
LexConfig.addConfigParams(cmd, LexConfig.config);
|
|
223
266
|
}
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
267
|
+
static checkTypescriptConfig() {
|
|
268
|
+
const tsconfigPath = pathResolve(cwd, './tsconfig.json');
|
|
269
|
+
if (!existsSync(tsconfigPath)) {
|
|
270
|
+
const dirName = getDirName();
|
|
271
|
+
writeFileSync(tsconfigPath, readFileSync(pathResolve(dirName, '../../../tsconfig.base.json')));
|
|
272
|
+
}
|
|
230
273
|
}
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
274
|
+
static checkCompileTypescriptConfig() {
|
|
275
|
+
const lexDir = LexConfig.getLexDir();
|
|
276
|
+
const tsconfigCompilePath = pathResolve(lexDir, './tsconfig.build.json');
|
|
277
|
+
if (!existsSync(tsconfigCompilePath)) {
|
|
278
|
+
const templatePath = pathResolve(lexDir, 'tsconfig.build.json');
|
|
279
|
+
if (existsSync(templatePath)) {
|
|
280
|
+
writeFileSync(tsconfigCompilePath, readFileSync(templatePath));
|
|
281
|
+
}
|
|
282
|
+
}
|
|
240
283
|
}
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
284
|
+
static checkLintTypescriptConfig() {
|
|
285
|
+
const lexDir = LexConfig.getLexDir();
|
|
286
|
+
const tsconfigLintPath = pathResolve(lexDir, './tsconfig.lint.json');
|
|
287
|
+
if (!existsSync(tsconfigLintPath)) {
|
|
288
|
+
const templatePath = pathResolve(lexDir, 'tsconfig.lint.json');
|
|
289
|
+
if (existsSync(templatePath)) {
|
|
290
|
+
writeFileSync(tsconfigLintPath, readFileSync(templatePath));
|
|
291
|
+
}
|
|
292
|
+
}
|
|
250
293
|
}
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
294
|
+
static checkTestTypescriptConfig() {
|
|
295
|
+
const lexDir = LexConfig.getLexDir();
|
|
296
|
+
const tsconfigTestPath = pathResolve(lexDir, './tsconfig.test.json');
|
|
297
|
+
if (!existsSync(tsconfigTestPath)) {
|
|
298
|
+
const templatePath = pathResolve(lexDir, 'tsconfig.test.json');
|
|
299
|
+
if (existsSync(templatePath)) {
|
|
300
|
+
writeFileSync(tsconfigTestPath, readFileSync(templatePath));
|
|
301
|
+
}
|
|
302
|
+
}
|
|
260
303
|
}
|
|
261
|
-
}
|
|
262
304
|
}
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
};
|
|
268
|
-
//# 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\nimport type {Linter} from 'eslint';\n\nconst cwd: string = process.cwd();\n\nexport interface EsbuildConfig {\n  [key: string]: unknown;\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}\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  publicPath?: 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  esbuild?: EsbuildConfig;\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  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  esbuild: {\n    drop: ['console', 'debugger'],\n    legalComments: 'none',\n    metafile: false,\n    minify: true,\n    pure: ['console.log', 'console.warn', 'console.error'],\n    sourcemap: false,\n    splitting: true,\n    treeShaking: true\n  },\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  targetEnvironment: 'web',\n  useGraphQl: false,\n  useTypescript: false,\n  webpack: {\n    publicPath: './src/static'\n  }\n};\n\nexport const getTypeScriptConfigPath = (configName: string): string => {\n  const cwd = process.cwd();\n\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  if(configName === 'tsconfig.lint.json') {\n    const projectLintConfig = pathResolve(cwd, 'tsconfig.eslint.json');\n    if(existsSync(projectLintConfig)) {\n      return projectLintConfig;\n    }\n  }\n\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  const projectConfigPath = pathResolve(cwd, configName);\n  if(existsSync(projectConfigPath)) {\n    return projectConfigPath;\n  }\n\n  const lexDir = LexConfig.getLexDir();\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 {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 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 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            // 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 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      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      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}"],
  "mappings": "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",
  "names": ["cwd"]
}

|
|
305
|
+
_define_property(LexConfig, "config", {
|
|
306
|
+
...defaultConfigValues
|
|
307
|
+
});
|
|
308
|
+
|
|
309
|
+
//# 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\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 SWCConfig {\n  jsc?: {\n    parser?: {\n      syntax?: 'typescript' | 'ecmascript';\n      tsx?: boolean;\n      decorators?: boolean;\n      dynamicImport?: boolean;\n    };\n    target?: 'es3' | 'es5' | 'es2015' | 'es2016' | 'es2017' | 'es2018' | 'es2019' | 'es2020' | 'es2021' | 'es2022' | 'es2023';\n    transform?: {\n      react?: {\n        runtime?: 'automatic' | 'classic';\n        pragma?: string;\n        pragmaFrag?: string;\n        throwIfNamespace?: boolean;\n        development?: boolean;\n        useBuiltins?: boolean;\n        refresh?: boolean;\n      };\n    };\n    externalHelpers?: boolean;\n    keepClassNames?: boolean;\n    loose?: boolean;\n    minify?: {\n      compress?: boolean;\n      mangle?: boolean;\n    };\n  };\n  module?: {\n    type?: 'es6' | 'commonjs' | 'amd' | 'umd' | 'systemjs';\n    strict?: boolean;\n    strictMode?: boolean;\n    lazy?: boolean;\n    noInterop?: boolean;\n  };\n  minify?: boolean;\n  sourceMaps?: boolean | 'inline';\n  inlineSourcesContent?: boolean;\n  isModule?: boolean;\n  filename?: string;\n  configFile?: string;\n  swcrc?: boolean;\n  env?: {\n    targets?: string | string[] | Record<string, string>;\n    mode?: 'usage' | 'entry';\n    coreJs?: string;\n    path?: string;\n    debug?: boolean;\n    dynamicImport?: boolean;\n    loose?: boolean;\n    bugfixes?: boolean;\n    include?: string[];\n    exclude?: string[];\n    forceAllTransforms?: boolean;\n    modules?: 'amd' | 'umd' | 'systemjs' | 'auto' | false;\n    shippedProposals?: boolean;\n  };\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?: SWCConfig;\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    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: 'es2020',\n      transform: {\n        react: {\n          runtime: 'automatic'\n        }\n      }\n    },\n    module: {\n      lazy: false,\n      noInterop: false,\n      strict: false,\n      strictMode: true,\n      type: 'es6'\n    },\n    inlineSourcesContent: true,\n    isModule: true,\n    minify: false,\n    sourceMaps: 'inline'\n  },\n  targetEnvironment: 'web',\n  useGraphQl: false,\n  useTypescript: false,\n  webpack: {\n    staticPath: './src/static'\n  }\n};\n\nexport const getTypeScriptConfigPath = (configName: string): string => {\n  const cwd = process.cwd();\n\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  if(configName === 'tsconfig.lint.json') {\n    const projectLintConfig = pathResolve(cwd, 'tsconfig.eslint.json');\n    if(existsSync(projectLintConfig)) {\n      return projectLintConfig;\n    }\n  }\n\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  const projectConfigPath = pathResolve(cwd, configName);\n  if(existsSync(projectConfigPath)) {\n    return projectConfigPath;\n  }\n\n  const lexDir = LexConfig.getLexDir();\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 {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 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 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            // 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 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      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      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}"],"names":["existsSync","readFileSync","writeFileSync","dirname","extname","pathExtname","resolve","pathResolve","URL","getDirName","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","jsc","externalHelpers","keepClassNames","loose","parser","decorators","dynamicImport","syntax","tsx","target","transform","react","runtime","module","lazy","noInterop","strict","strictMode","type","inlineSourcesContent","isModule","minify","sourceMaps","targetEnvironment","useGraphQl","useTypescript","webpack","staticPath","getTypeScriptConfigPath","configName","projectBuildConfig","projectLintConfig","projectTestConfig","projectConfigPath","lexDir","LexConfig","getLexDir","value","config","indexPath","hasIndexTsx","updateConfig","updatedConfig","undefined","CURSOR_IDE","addConfigParams","cmd","params","nameProperty","environment","typescript","LEX_CONFIG","JSON","stringify","commandName","isStatic","static","parseConfig","isRoot","cliName","lexConfig","lexConfigName","quiet","debug","configFormats","configBaseName","configPath","configExists","format","potentialPath","ext","configContent","configJson","parse","default","error","message","includes","lexCustomConfig","fileUrl","href","console","checkTypescriptConfig","tsconfigPath","dirName","checkCompileTypescriptConfig","tsconfigCompilePath","templatePath","checkLintTypescriptConfig","tsconfigLintPath","checkTestTypescriptConfig","tsconfigTestPath"],"mappings":"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"}
|