@nlabs/lex 1.48.7 → 1.49.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.
Files changed (105) hide show
  1. package/.storybook/main.ts +9 -2
  2. package/.vscode/settings.json +1 -6
  3. package/README.md +249 -0
  4. package/eslint.config.mjs +24 -0
  5. package/examples/lex.config.js +18 -8
  6. package/examples/serverless-example/README.md +109 -0
  7. package/examples/serverless-example/dist/handlers/echo.js +15 -0
  8. package/examples/serverless-example/dist/handlers/graphql.js +137 -0
  9. package/examples/serverless-example/dist/handlers/hello.js +15 -0
  10. package/examples/serverless-example/dist/handlers/test.js +17 -0
  11. package/examples/serverless-example/dist/handlers/websocket.js +14 -0
  12. package/examples/serverless-example/lex.config.mjs +74 -0
  13. package/jest.config.mjs +13 -12
  14. package/{dist → lib}/LexConfig.d.ts +7 -6
  15. package/lib/LexConfig.js +268 -0
  16. package/lib/commands/ai/ai.js +303 -0
  17. package/{dist → lib}/commands/build/build.d.ts +3 -0
  18. package/lib/commands/build/build.js +494 -0
  19. package/{dist → lib}/commands/clean/clean.js +1 -1
  20. package/lib/commands/compile/compile.js +241 -0
  21. package/lib/commands/copy/copy.js +38 -0
  22. package/{dist → lib}/commands/create/create.js +1 -1
  23. package/{dist → lib}/commands/dev/dev.d.ts +2 -0
  24. package/lib/commands/dev/dev.js +286 -0
  25. package/{dist → lib}/commands/init/init.js +1 -1
  26. package/lib/commands/lint/lint.js +993 -0
  27. package/{dist → lib}/commands/migrate/migrate.js +1 -1
  28. package/lib/commands/publish/publish.js +104 -0
  29. package/lib/commands/serverless/serverless.d.ts +17 -0
  30. package/lib/commands/serverless/serverless.js +662 -0
  31. package/lib/commands/storybook/storybook.js +249 -0
  32. package/lib/commands/test/test.js +428 -0
  33. package/lib/commands/update/update.js +128 -0
  34. package/{dist → lib}/create/changelog.js +1 -1
  35. package/{dist → lib}/index.d.ts +1 -0
  36. package/{dist → lib}/index.js +2 -1
  37. package/lib/lex.js +73 -0
  38. package/lib/utils/aiService.d.ts +9 -0
  39. package/lib/utils/aiService.js +299 -0
  40. package/{dist → lib}/utils/app.d.ts +3 -0
  41. package/lib/utils/app.js +296 -0
  42. package/{dist → lib}/utils/file.d.ts +7 -3
  43. package/lib/utils/file.js +229 -0
  44. package/lib/utils/translations.d.ts +1 -0
  45. package/lib/utils/translations.js +74 -0
  46. package/package.json +59 -53
  47. package/postcss.config.js +5 -3
  48. package/tsconfig.build.json +2 -2
  49. package/webpack.config.js +229 -39
  50. package/dist/LexConfig.js +0 -287
  51. package/dist/commands/ai/ai.js +0 -303
  52. package/dist/commands/build/build.js +0 -404
  53. package/dist/commands/compile/compile.js +0 -234
  54. package/dist/commands/copy/copy.js +0 -38
  55. package/dist/commands/dev/dev.js +0 -74
  56. package/dist/commands/lint/lint.js +0 -993
  57. package/dist/commands/publish/publish.js +0 -104
  58. package/dist/commands/storybook/storybook.js +0 -249
  59. package/dist/commands/test/test.js +0 -429
  60. package/dist/commands/update/update.js +0 -132
  61. package/dist/lex.js +0 -70
  62. package/dist/utils/aiService.d.ts +0 -9
  63. package/dist/utils/aiService.js +0 -299
  64. package/dist/utils/app.js +0 -267
  65. package/dist/utils/file.js +0 -185
  66. package/emptyModule.js +0 -0
  67. package/eslint.config.js +0 -3
  68. /package/{dist → lib}/Button.stories.d.ts +0 -0
  69. /package/{dist → lib}/commands/ai/ai.d.ts +0 -0
  70. /package/{dist → lib}/commands/ai/index.d.ts +0 -0
  71. /package/{dist → lib}/commands/ai/index.js +0 -0
  72. /package/{dist → lib}/commands/clean/clean.d.ts +0 -0
  73. /package/{dist → lib}/commands/compile/compile.d.ts +0 -0
  74. /package/{dist → lib}/commands/config/config.d.ts +0 -0
  75. /package/{dist → lib}/commands/config/config.js +0 -0
  76. /package/{dist → lib}/commands/copy/copy.d.ts +0 -0
  77. /package/{dist → lib}/commands/create/create.d.ts +0 -0
  78. /package/{dist → lib}/commands/init/init.d.ts +0 -0
  79. /package/{dist → lib}/commands/link/link.d.ts +0 -0
  80. /package/{dist → lib}/commands/link/link.js +0 -0
  81. /package/{dist → lib}/commands/lint/autofix.d.ts +0 -0
  82. /package/{dist → lib}/commands/lint/lint.d.ts +0 -0
  83. /package/{dist → lib}/commands/migrate/migrate.d.ts +0 -0
  84. /package/{dist → lib}/commands/publish/publish.d.ts +0 -0
  85. /package/{dist → lib}/commands/storybook/storybook.d.ts +0 -0
  86. /package/{dist → lib}/commands/test/test.d.ts +0 -0
  87. /package/{dist → lib}/commands/update/update.d.ts +0 -0
  88. /package/{dist → lib}/commands/upgrade/upgrade.d.ts +0 -0
  89. /package/{dist → lib}/commands/upgrade/upgrade.js +0 -0
  90. /package/{dist → lib}/commands/versions/versions.d.ts +0 -0
  91. /package/{dist → lib}/commands/versions/versions.js +0 -0
  92. /package/{dist → lib}/create/changelog.d.ts +0 -0
  93. /package/{dist → lib}/lex.d.ts +0 -0
  94. /package/{dist → lib}/storybook/index.d.ts +0 -0
  95. /package/{dist → lib}/storybook/index.js +0 -0
  96. /package/{dist → lib}/test-react/index.d.ts +0 -0
  97. /package/{dist → lib}/test-react/index.js +0 -0
  98. /package/{dist → lib}/types.d.ts +0 -0
  99. /package/{dist → lib}/types.js +0 -0
  100. /package/{dist → lib}/utils/deepMerge.d.ts +0 -0
  101. /package/{dist → lib}/utils/deepMerge.js +0 -0
  102. /package/{dist → lib}/utils/log.d.ts +0 -0
  103. /package/{dist → lib}/utils/log.js +0 -0
  104. /package/{dist → lib}/utils/reactShim.d.ts +0 -0
  105. /package/{dist → lib}/utils/reactShim.js +0 -0
@@ -0,0 +1,17 @@
1
+ export const handler = async (event, context) => {
2
+ console.log('Test handler called');
3
+ console.log('Event:', event);
4
+
5
+ return {
6
+ statusCode: 200,
7
+ headers: {
8
+ 'Content-Type': 'application/json'
9
+ },
10
+ body: JSON.stringify({
11
+ message: 'Hello from test handler!',
12
+ data: {
13
+ test: true
14
+ }
15
+ })
16
+ };
17
+ };
@@ -0,0 +1,14 @@
1
+ export const handler = async (event, context) => {
2
+ const {routeKey, connectionId} = event.requestContext;
3
+
4
+ return {
5
+ statusCode: 200,
6
+ body: JSON.stringify({
7
+ message: 'WebSocket message received',
8
+ route: routeKey,
9
+ connectionId,
10
+ receivedData: event.body,
11
+ timestamp: new Date().toISOString()
12
+ })
13
+ };
14
+ };
@@ -0,0 +1,74 @@
1
+ export default {
2
+ outputFullPath: './dist',
3
+ serverless: {
4
+ custom: {
5
+ 'serverless-offline': {
6
+ cors: true,
7
+ host: 'localhost',
8
+ httpPort: 3000,
9
+ httpsPort: 3001,
10
+ wsPort: 3002
11
+ }
12
+ },
13
+ functions: {
14
+ echo: {
15
+ events: [
16
+ {
17
+ http: {
18
+ cors: true,
19
+ method: 'POST',
20
+ path: '/echo'
21
+ }
22
+ }
23
+ ],
24
+ handler: 'handlers/echo.js'
25
+ },
26
+ graphql: {
27
+ events: [
28
+ {
29
+ http: {
30
+ cors: true,
31
+ method: 'POST',
32
+ path: '/public'
33
+ }
34
+ }
35
+ ],
36
+ handler: 'handlers/graphql.js'
37
+ },
38
+ hello: {
39
+ events: [
40
+ {
41
+ http: {
42
+ cors: true,
43
+ method: 'GET',
44
+ path: '/hello'
45
+ }
46
+ }
47
+ ],
48
+ handler: 'handlers/hello.js'
49
+ },
50
+ test: {
51
+ events: [
52
+ {
53
+ http: {
54
+ cors: true,
55
+ method: 'GET',
56
+ path: '/test'
57
+ }
58
+ }
59
+ ],
60
+ handler: 'handlers/test.js'
61
+ },
62
+ websocket: {
63
+ events: [
64
+ {
65
+ websocket: {
66
+ route: '$default'
67
+ }
68
+ }
69
+ ],
70
+ handler: 'handlers/websocket.js'
71
+ }
72
+ }
73
+ }
74
+ };
package/jest.config.mjs CHANGED
@@ -2,22 +2,23 @@
2
2
  * Copyright (c) 2018-Present, Nitrogen Labs, Inc.
3
3
  * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
4
4
  */
5
- import {fileURLToPath} from 'url';
6
- import {dirname, resolve} from 'path';
7
- import {deepMerge} from './dist/utils/deepMerge.js';
8
-
9
5
  import {readFileSync} from 'fs';
6
+ import merge from 'lodash/merge.js';
7
+ import {dirname, resolve} from 'path';
8
+ import {fileURLToPath} from 'url';
10
9
 
11
- const __filename = fileURLToPath(import.meta.url);
12
- const __dirname = dirname(__filename);
13
- const pack = JSON.parse(readFileSync(resolve(__dirname, 'package.json'), 'utf8'));
10
+ const filename = fileURLToPath(import.meta.url);
11
+ const dirnamePath = dirname(filename);
12
+ const pack = JSON.parse(readFileSync(resolve(dirnamePath, 'package.json'), 'utf8'));
14
13
 
15
14
  let projectJestConfig = null;
15
+
16
16
  if(process.env.LEX_CONFIG) {
17
17
  try {
18
18
  const lexConfig = JSON.parse(process.env.LEX_CONFIG);
19
19
  projectJestConfig = lexConfig.jest;
20
- } catch(error) {
20
+ } catch (error) {
21
+ // eslint-disable-next-line no-console
21
22
  console.warn('Failed to parse LEX_CONFIG:', error.message);
22
23
  }
23
24
  }
@@ -36,19 +37,19 @@ const baseConfig = {
36
37
  displayName: pack.name,
37
38
  moduleFileExtensions: ['ts', 'tsx', 'js', 'json', 'node'],
38
39
  moduleNameMapper: {
39
- '^(\\.{1,2}/.*)\\.js$': '$1',
40
+ '^(\\.{1,2}/.*)\\.js$': '$1'
40
41
  },
41
42
  rootDir: process.cwd(),
42
43
  testEnvironment: 'node',
43
44
  testRegex: '(/__tests__/.*|\\.(test|spec|integration))\\.(ts|tsx)?$',
44
45
  transform: {
45
- '^.+\.js$|^.+\.jsx$': ['babel-jest', {
46
+ '^.+\\.js$|^.+\\.jsx$': ['babel-jest', {
46
47
  presets: [
47
48
  ['@babel/preset-env', {targets: {node: 'current'}}],
48
49
  '@babel/preset-typescript'
49
50
  ]
50
51
  }],
51
- '^.+\.ts$|^.+\.tsx$': ['babel-jest', {
52
+ '^.+\\.ts$|^.+\\.tsx$': ['babel-jest', {
52
53
  presets: [
53
54
  ['@babel/preset-env', {targets: {node: 'current'}}],
54
55
  '@babel/preset-typescript',
@@ -60,7 +61,7 @@ const baseConfig = {
60
61
  };
61
62
 
62
63
  const finalConfig = projectJestConfig && Object.keys(projectJestConfig).length > 0
63
- ? deepMerge(baseConfig, projectJestConfig)
64
+ ? merge(baseConfig, projectJestConfig)
64
65
  : baseConfig;
65
66
 
66
67
  export default finalConfig;
@@ -1,5 +1,6 @@
1
1
  import type { Linter } from 'eslint';
2
2
  export interface EsbuildConfig {
3
+ [key: string]: unknown;
3
4
  entryPoints?: string[];
4
5
  outdir?: string;
5
6
  platform?: 'node' | 'browser';
@@ -17,9 +18,9 @@ export interface EsbuildConfig {
17
18
  banner?: Record<string, string>;
18
19
  footer?: Record<string, string>;
19
20
  define?: Record<string, string>;
20
- [key: string]: unknown;
21
21
  }
22
22
  export interface JestConfig {
23
+ [key: string]: unknown;
23
24
  roots?: string[];
24
25
  testEnvironment?: string;
25
26
  transform?: Record<string, [string, Record<string, unknown>]>;
@@ -27,14 +28,14 @@ export interface JestConfig {
27
28
  moduleNameMapper?: Record<string, string>;
28
29
  extensionsToTreatAsEsm?: string[];
29
30
  preset?: string;
30
- [key: string]: unknown;
31
31
  }
32
32
  export interface WebpackConfig {
33
+ [key: string]: unknown;
33
34
  entry?: string | string[];
34
35
  output?: Record<string, unknown>;
35
36
  module?: Record<string, unknown>;
36
37
  plugins?: unknown[];
37
- [key: string]: unknown;
38
+ publicPath?: string;
38
39
  }
39
40
  export interface AIConfig {
40
41
  provider?: 'cursor' | 'copilot' | 'openai' | 'anthropic' | 'none';
@@ -44,9 +45,9 @@ export interface AIConfig {
44
45
  temperature?: number;
45
46
  }
46
47
  export interface ESLintConfig {
48
+ [key: string]: unknown;
47
49
  extends?: string[];
48
50
  rules?: Linter.RulesRecord;
49
- [key: string]: unknown;
50
51
  }
51
52
  export interface LexConfigType {
52
53
  ai?: AIConfig;
@@ -76,11 +77,11 @@ export interface LexConfigType {
76
77
  }
77
78
  export type Config = LexConfigType;
78
79
  export declare const defaultConfigValues: LexConfigType;
79
- export declare function getTypeScriptConfigPath(configName: string): string;
80
+ export declare const getTypeScriptConfigPath: (configName: string) => string;
80
81
  export declare class LexConfig {
81
82
  static config: LexConfigType;
82
- static getLexDir(): string;
83
83
  static set useTypescript(value: boolean);
84
+ static getLexDir(): string;
84
85
  static updateConfig(updatedConfig: LexConfigType): LexConfigType;
85
86
  static addConfigParams(cmd: any, params: LexConfigType): void;
86
87
  static parseConfig(cmd: any, isRoot?: boolean): Promise<void>;
@@ -0,0 +1,268 @@
1
+ import { existsSync, readFileSync, writeFileSync } from "fs";
2
+ import { dirname, extname as pathExtname, resolve as pathResolve } from "path";
3
+ import { URL } from "url";
4
+ import { getDirName, getLexPackageJsonPath, relativeFilePath } from "./utils/file.js";
5
+ import { log } from "./utils/log.js";
6
+ const cwd = process.cwd();
7
+ const defaultConfigValues = {
8
+ ai: {
9
+ maxTokens: 4e3,
10
+ model: "gpt-4o",
11
+ provider: "none",
12
+ temperature: 0.1
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, "./dist"),
32
+ outputHash: false,
33
+ outputPath: "./dist",
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;
57
+ }
58
+ }
59
+ if (configName === "tsconfig.test.json") {
60
+ const projectTestConfig = pathResolve(cwd2, "tsconfig.test.json");
61
+ if (existsSync(projectTestConfig)) {
62
+ return projectTestConfig;
63
+ }
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
+ };
72
+ class LexConfig {
73
+ static config = {
74
+ ...defaultConfigValues
75
+ };
76
+ static set useTypescript(value) {
77
+ LexConfig.config.useTypescript = value;
78
+ const { sourceFullPath } = LexConfig.config;
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);
104
+ }
105
+ if (ai) {
106
+ LexConfig.config.ai = { ...LexConfig.config.ai, ...ai };
107
+ if (process.env.CURSOR_IDE === "true" && LexConfig.config.ai.provider === "none") {
108
+ LexConfig.config.ai.provider = "cursor";
109
+ }
110
+ }
111
+ LexConfig.config = { ...LexConfig.config, ...updatedConfig };
112
+ return LexConfig.config;
113
+ }
114
+ static addConfigParams(cmd, params) {
115
+ const nameProperty = "_name";
116
+ const { environment, outputPath, sourcePath, typescript } = cmd;
117
+ if (outputPath !== void 0) {
118
+ params.outputPath = outputPath;
119
+ params.outputFullPath = pathResolve(cwd, outputPath);
120
+ }
121
+ if (sourcePath !== void 0) {
122
+ params.sourcePath = sourcePath;
123
+ params.sourceFullPath = pathResolve(cwd, sourcePath);
124
+ }
125
+ if (typescript !== void 0) {
126
+ params.useTypescript = true;
127
+ }
128
+ if (environment !== void 0) {
129
+ params.targetEnvironment = environment === "web" ? "web" : "node";
130
+ }
131
+ process.env.LEX_CONFIG = JSON.stringify(
132
+ {
133
+ ...LexConfig.updateConfig(params),
134
+ commandName: cmd[nameProperty],
135
+ isStatic: cmd.static
136
+ },
137
+ null,
138
+ 0
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);
155
+ }
156
+ if (existsSync(potentialPath)) {
157
+ configPath = potentialPath;
158
+ configExists = true;
159
+ break;
160
+ }
161
+ }
162
+ }
163
+ if (configExists) {
164
+ log(`Using ${cliName} configuration file: ${configPath}`, "note", quiet);
165
+ const ext = pathExtname(configPath);
166
+ if (ext === ".json") {
167
+ const configContent = readFileSync(configPath, "utf8");
168
+ if (configContent) {
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);
181
+ }
182
+ } else if ([".js", ".mjs", ".cjs", ".ts"].includes(ext)) {
183
+ try {
184
+ let lexCustomConfig;
185
+ if (ext === ".cjs") {
186
+ const fileUrl = new URL(`file:///${pathResolve(configPath)}`).href;
187
+ if (debug) {
188
+ log(`Loading CommonJS config from: ${fileUrl}`, "info", quiet);
189
+ }
190
+ lexCustomConfig = await import(fileUrl);
191
+ } else {
192
+ if (debug) {
193
+ log(`Loading ESM/TS config from: ${configPath}`, "info", quiet);
194
+ }
195
+ lexCustomConfig = await import(configPath);
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
+ }
212
+ }
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
+ }
224
+ }
225
+ static checkTypescriptConfig() {
226
+ const tsconfigPath = pathResolve(cwd, "./tsconfig.json");
227
+ if (!existsSync(tsconfigPath)) {
228
+ const dirName = getDirName();
229
+ writeFileSync(tsconfigPath, readFileSync(pathResolve(dirName, "../../../tsconfig.base.json")));
230
+ }
231
+ }
232
+ static checkCompileTypescriptConfig() {
233
+ const lexDir = LexConfig.getLexDir();
234
+ const tsconfigCompilePath = pathResolve(lexDir, "./tsconfig.build.json");
235
+ if (!existsSync(tsconfigCompilePath)) {
236
+ const templatePath = pathResolve(lexDir, "tsconfig.build.json");
237
+ if (existsSync(templatePath)) {
238
+ writeFileSync(tsconfigCompilePath, readFileSync(templatePath));
239
+ }
240
+ }
241
+ }
242
+ static checkLintTypescriptConfig() {
243
+ const lexDir = LexConfig.getLexDir();
244
+ const tsconfigLintPath = pathResolve(lexDir, "./tsconfig.lint.json");
245
+ if (!existsSync(tsconfigLintPath)) {
246
+ const templatePath = pathResolve(lexDir, "tsconfig.lint.json");
247
+ if (existsSync(templatePath)) {
248
+ writeFileSync(tsconfigLintPath, readFileSync(templatePath));
249
+ }
250
+ }
251
+ }
252
+ static checkTestTypescriptConfig() {
253
+ const lexDir = LexConfig.getLexDir();
254
+ const tsconfigTestPath = pathResolve(lexDir, "./tsconfig.test.json");
255
+ if (!existsSync(tsconfigTestPath)) {
256
+ const templatePath = pathResolve(lexDir, "tsconfig.test.json");
257
+ if (existsSync(templatePath)) {
258
+ writeFileSync(tsconfigTestPath, readFileSync(templatePath));
259
+ }
260
+ }
261
+ }
262
+ }
263
+ export {
264
+ LexConfig,
265
+ defaultConfigValues,
266
+ getTypeScriptConfigPath
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, './dist'),\n  outputHash: false,\n  outputPath: './dist',\n  packageManager: 'npm',\n  preset: 'web',\n  sourceFullPath: pathResolve(cwd, './src'),\n  sourcePath: './src',\n  targetEnvironment: 'web',\n  useGraphQl: false,\n  useTypescript: false,\n  webpack: {\n    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"]
}
