@nlabs/lex 1.46.2 → 1.47.1

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 (149) hide show
  1. package/__mocks__/LexConfig.js +20 -0
  2. package/__mocks__/boxen.js +7 -0
  3. package/__mocks__/build.js +16 -0
  4. package/__mocks__/chalk.js +23 -0
  5. package/__mocks__/compile.js +8 -0
  6. package/__mocks__/execa.js +21 -0
  7. package/__mocks__/ora.js +17 -0
  8. package/__mocks__/versions.js +12 -0
  9. package/dist/LexConfig.d.ts +79 -0
  10. package/dist/LexConfig.js +83 -15
  11. package/dist/commands/ai/ai.d.ts +17 -0
  12. package/dist/commands/ai/ai.js +303 -0
  13. package/dist/commands/ai/index.d.ts +8 -0
  14. package/dist/commands/ai/index.js +7 -0
  15. package/dist/commands/build/build.cli.test.d.ts +5 -0
  16. package/dist/commands/build/build.d.ts +18 -0
  17. package/dist/commands/build/build.integration.test.d.ts +1 -0
  18. package/dist/commands/build/build.js +400 -0
  19. package/dist/commands/build/build.options.test.d.ts +5 -0
  20. package/dist/commands/clean/clean.cli.test.d.ts +1 -0
  21. package/dist/commands/clean/clean.d.ts +7 -0
  22. package/dist/commands/clean/clean.integration.test.d.ts +1 -0
  23. package/dist/commands/clean/clean.js +31 -0
  24. package/dist/commands/clean/clean.options.test.d.ts +1 -0
  25. package/dist/commands/compile/compile.cli.test.d.ts +1 -0
  26. package/dist/commands/compile/compile.d.ts +2 -0
  27. package/dist/commands/compile/compile.integration.test.d.ts +1 -0
  28. package/dist/commands/compile/compile.js +239 -0
  29. package/dist/commands/compile/compile.options.test.d.ts +1 -0
  30. package/dist/commands/config/config.cli.test.d.ts +1 -0
  31. package/dist/commands/config/config.d.ts +7 -0
  32. package/dist/commands/config/config.integration.test.d.ts +1 -0
  33. package/dist/commands/config/config.js +43 -0
  34. package/dist/commands/config/config.options.test.d.ts +1 -0
  35. package/dist/commands/copy/copy.cli.test.d.ts +1 -0
  36. package/dist/commands/copy/copy.d.ts +6 -0
  37. package/dist/commands/copy/copy.integration.test.d.ts +1 -0
  38. package/dist/commands/copy/copy.js +38 -0
  39. package/dist/commands/copy/copy.options.test.d.ts +1 -0
  40. package/dist/commands/create/create.cli.test.d.ts +1 -0
  41. package/dist/commands/create/create.d.ts +8 -0
  42. package/dist/commands/create/create.integration.test.d.ts +1 -0
  43. package/dist/commands/create/create.js +124 -0
  44. package/dist/commands/create/create.options.test.d.ts +1 -0
  45. package/dist/commands/dev/dev.cli.test.d.ts +1 -0
  46. package/dist/commands/dev/dev.d.ts +11 -0
  47. package/dist/commands/dev/dev.integration.test.d.ts +1 -0
  48. package/dist/commands/dev/dev.js +70 -0
  49. package/dist/commands/dev/dev.options.test.d.ts +1 -0
  50. package/dist/commands/init/init.cli.test.d.ts +1 -0
  51. package/dist/commands/init/init.d.ts +9 -0
  52. package/dist/commands/init/init.integration.test.d.ts +1 -0
  53. package/dist/commands/init/init.js +93 -0
  54. package/dist/commands/init/init.options.test.d.ts +1 -0
  55. package/dist/commands/link/link.cli.test.d.ts +1 -0
  56. package/dist/commands/link/link.d.ts +6 -0
  57. package/dist/commands/link/link.integration.test.d.ts +1 -0
  58. package/dist/commands/link/link.js +15 -0
  59. package/dist/commands/link/link.options.test.d.ts +1 -0
  60. package/dist/commands/lint/autofix.d.ts +2 -0
  61. package/dist/commands/lint/lint.cli.test.d.ts +1 -0
  62. package/dist/commands/lint/lint.d.ts +39 -0
  63. package/dist/commands/lint/lint.integration.test.d.ts +1 -0
  64. package/dist/commands/lint/lint.js +820 -0
  65. package/dist/commands/lint/lint.options.test.d.ts +1 -0
  66. package/dist/commands/migrate/migrate.cli.test.d.ts +1 -0
  67. package/dist/commands/migrate/migrate.d.ts +7 -0
  68. package/dist/commands/migrate/migrate.integration.test.d.ts +1 -0
  69. package/dist/commands/migrate/migrate.js +37 -0
  70. package/dist/commands/migrate/migrate.options.test.d.ts +1 -0
  71. package/dist/commands/publish/publish.cli.test.d.ts +1 -0
  72. package/dist/commands/publish/publish.d.ts +12 -0
  73. package/dist/commands/publish/publish.integration.test.d.ts +1 -0
  74. package/dist/commands/publish/publish.js +104 -0
  75. package/dist/commands/publish/publish.options.test.d.ts +1 -0
  76. package/dist/commands/test/test.cli.test.d.ts +1 -0
  77. package/dist/commands/test/test.d.ts +50 -0
  78. package/dist/commands/test/test.integration.test.d.ts +1 -0
  79. package/dist/commands/test/test.js +327 -0
  80. package/dist/commands/test/test.options.test.d.ts +1 -0
  81. package/dist/commands/test/test.test.d.ts +1 -0
  82. package/dist/commands/update/update.cli.test.d.ts +1 -0
  83. package/dist/commands/update/update.d.ts +9 -0
  84. package/dist/commands/update/update.integration.test.d.ts +1 -0
  85. package/dist/commands/update/update.js +131 -0
  86. package/dist/commands/update/update.options.test.d.ts +1 -0
  87. package/dist/commands/upgrade/upgrade.cli.test.d.ts +1 -0
  88. package/dist/commands/upgrade/upgrade.d.ts +7 -0
  89. package/dist/commands/upgrade/upgrade.integration.test.d.ts +1 -0
  90. package/dist/commands/upgrade/upgrade.js +47 -0
  91. package/dist/commands/upgrade/upgrade.options.test.d.ts +1 -0
  92. package/dist/commands/versions/versions.cli.test.d.ts +1 -0
  93. package/dist/commands/versions/versions.d.ts +13 -0
  94. package/dist/commands/versions/versions.integration.test.d.ts +1 -0
  95. package/dist/commands/versions/versions.js +41 -0
  96. package/dist/commands/versions/versions.options.test.d.ts +1 -0
  97. package/dist/create/changelog.d.ts +6 -0
  98. package/dist/create/changelog.js +3 -3
  99. package/dist/index.d.ts +31 -0
  100. package/dist/index.js +35 -0
  101. package/dist/lex.d.ts +2 -0
  102. package/dist/lex.js +25 -22
  103. package/dist/types.d.ts +5 -0
  104. package/dist/types.js +1 -0
  105. package/dist/utils/aiService.d.ts +9 -0
  106. package/dist/utils/aiService.js +299 -0
  107. package/dist/utils/app.d.ts +41 -0
  108. package/dist/utils/app.js +53 -3
  109. package/dist/utils/file.d.ts +3 -0
  110. package/dist/utils/file.js +18 -3
  111. package/dist/utils/log.d.ts +1 -0
  112. package/dist/utils/log.js +2 -1
  113. package/dist/utils/reactShim.d.ts +2 -0
  114. package/dist/utils/reactShim.js +3 -3
  115. package/eslint.config.js +5 -0
  116. package/index.cjs +20 -0
  117. package/jest.config.cjs +31 -27
  118. package/jest.config.lex.d.ts +2 -0
  119. package/jest.config.lex.js +86 -38
  120. package/jest.setup.js +5 -0
  121. package/lex.config.js +50 -0
  122. package/package.json +73 -53
  123. package/{.postcssrc.js → postcss.config.js} +21 -9
  124. package/resolver.cjs +125 -14
  125. package/tsconfig.json +2 -1
  126. package/webpack.config.d.ts +2 -0
  127. package/webpack.config.js +27 -11
  128. package/dist/commands/build.js +0 -265
  129. package/dist/commands/bulid.test.js +0 -317
  130. package/dist/commands/clean.js +0 -31
  131. package/dist/commands/clean.test.js +0 -63
  132. package/dist/commands/compile.js +0 -195
  133. package/dist/commands/compile.test.js +0 -93
  134. package/dist/commands/config.js +0 -43
  135. package/dist/commands/copy.js +0 -38
  136. package/dist/commands/create.js +0 -120
  137. package/dist/commands/dev.js +0 -70
  138. package/dist/commands/init.js +0 -93
  139. package/dist/commands/link.js +0 -15
  140. package/dist/commands/lint.js +0 -179
  141. package/dist/commands/migrate.js +0 -37
  142. package/dist/commands/publish.js +0 -104
  143. package/dist/commands/test.js +0 -190
  144. package/dist/commands/update.js +0 -64
  145. package/dist/commands/upgrade.js +0 -47
  146. package/dist/commands/versions.js +0 -41
  147. package/dist/commands/versions.test.js +0 -49
  148. package/dist/lint.js +0 -11
  149. package/jest.setup.ts +0 -3
@@ -0,0 +1,400 @@
1
+ import GraphqlLoaderPlugin from "@luckycatfactory/esbuild-graphql-loader";
2
+ import { execa } from "execa";
3
+ import { readFileSync } from "fs";
4
+ import { sync as globSync } from "glob";
5
+ import { resolve as pathResolve } from "path";
6
+ import { URL } from "url";
7
+ import { LexConfig } from "../../LexConfig.js";
8
+ import { checkLinkedModules, copyConfiguredFiles, createSpinner, removeFiles } from "../../utils/app.js";
9
+ import { relativeNodePath } from "../../utils/file.js";
10
+ import { log } from "../../utils/log.js";
11
+ import { aiFunction } from "../ai/ai.js";
12
+ const buildWithEsBuild = async (spinner, commandOptions, callback) => {
13
+ const {
14
+ cliName = "Lex",
15
+ format = "cjs",
16
+ outputPath,
17
+ quiet,
18
+ sourcePath,
19
+ watch
20
+ } = commandOptions;
21
+ const {
22
+ outputFullPath,
23
+ sourceFullPath,
24
+ targetEnvironment,
25
+ useGraphQl,
26
+ useTypescript
27
+ } = LexConfig.config;
28
+ const sourceDir = sourcePath ? pathResolve(process.cwd(), `./${sourcePath}`) : sourceFullPath;
29
+ const loader = {
30
+ ".js": "js"
31
+ };
32
+ if (useTypescript) {
33
+ loader[".ts"] = "ts";
34
+ loader[".tsx"] = "tsx";
35
+ }
36
+ const plugins = [];
37
+ if (useGraphQl) {
38
+ plugins.push(GraphqlLoaderPlugin());
39
+ }
40
+ const globOptions = {
41
+ cwd: sourceDir,
42
+ dot: false,
43
+ nodir: true,
44
+ nosort: true
45
+ };
46
+ const tsFiles = globSync(`${sourceDir}/**/!(*.spec|*.test).ts*`, globOptions);
47
+ const jsFiles = globSync(`${sourceDir}/**/!(*.spec|*.test).js`, globOptions);
48
+ const sourceFiles = [...tsFiles, ...jsFiles];
49
+ const packageJsonData = readFileSync(pathResolve(process.cwd(), "./package.json"));
50
+ const packageJson = JSON.parse(packageJsonData.toString());
51
+ const external = [
52
+ ...Object.keys(packageJson.dependencies || {}),
53
+ ...Object.keys(packageJson.peerDependencies || {})
54
+ ];
55
+ const dirName = new URL(".", import.meta.url).pathname;
56
+ const dirPath = pathResolve(dirName, "../..");
57
+ const outputDir = outputPath || outputFullPath;
58
+ const esbuildPath = relativeNodePath("esbuild/bin/esbuild", dirPath);
59
+ const esbuildConfig = LexConfig.config.esbuild || {};
60
+ const esbuildOptions = [
61
+ ...sourceFiles,
62
+ "--bundle",
63
+ "--color=true",
64
+ `--format=${format}`,
65
+ `--outdir=${outputDir}`,
66
+ `--platform=${esbuildConfig.platform || "node"}`,
67
+ `--target=${esbuildConfig.target || (targetEnvironment === "node" ? "node20" : "es2020")}`,
68
+ `--sourcemap=${esbuildConfig.sourcemap || "inline"}`
69
+ ];
70
+ if (esbuildConfig.minify !== false) {
71
+ esbuildOptions.push("--minify");
72
+ }
73
+ if (esbuildConfig.treeShaking !== false) {
74
+ esbuildOptions.push("--tree-shaking=true");
75
+ }
76
+ if (esbuildConfig.drop && esbuildConfig.drop.length > 0) {
77
+ esbuildConfig.drop.forEach((item) => {
78
+ esbuildOptions.push(`--drop:${item}`);
79
+ });
80
+ }
81
+ if (esbuildConfig.pure && esbuildConfig.pure.length > 0) {
82
+ esbuildConfig.pure.forEach((item) => {
83
+ esbuildOptions.push(`--pure:${item}`);
84
+ });
85
+ }
86
+ if (esbuildConfig.legalComments) {
87
+ esbuildOptions.push(`--legal-comments=${esbuildConfig.legalComments}`);
88
+ }
89
+ if (esbuildConfig.splitting !== false) {
90
+ esbuildOptions.push("--splitting");
91
+ }
92
+ if (esbuildConfig.metafile) {
93
+ esbuildOptions.push("--metafile");
94
+ }
95
+ if (esbuildConfig.banner) {
96
+ Object.entries(esbuildConfig.banner).forEach(([type, content]) => {
97
+ esbuildOptions.push(`--banner:${type}=${content}`);
98
+ });
99
+ }
100
+ if (esbuildConfig.footer) {
101
+ Object.entries(esbuildConfig.footer).forEach(([type, content]) => {
102
+ esbuildOptions.push(`--footer:${type}=${content}`);
103
+ });
104
+ }
105
+ if (esbuildConfig.define) {
106
+ Object.entries(esbuildConfig.define).forEach(([key, value]) => {
107
+ esbuildOptions.push(`--define:${key}=${value}`);
108
+ });
109
+ }
110
+ if (external.length) {
111
+ esbuildOptions.push(`--external:${external.join(",")}`);
112
+ }
113
+ if (plugins.length) {
114
+ esbuildOptions.push(`--plugins=${plugins.join(",")}`);
115
+ }
116
+ if (watch) {
117
+ esbuildOptions.push("--watch");
118
+ }
119
+ try {
120
+ await execa(esbuildPath, esbuildOptions, { encoding: "utf8" });
121
+ spinner.succeed("Build completed successfully!");
122
+ } catch (error) {
123
+ log(`
124
+ ${cliName} Error: ${error.message}`, "error", quiet);
125
+ if (!quiet) {
126
+ console.error(error);
127
+ }
128
+ spinner.fail("Code build failed.");
129
+ if (commandOptions.assist) {
130
+ spinner.start("AI is analyzing the error...");
131
+ try {
132
+ await aiFunction({
133
+ prompt: `Fix this esbuild error: ${error.message}
134
+
135
+ Error details:
136
+ ${error.toString()}`,
137
+ task: "help",
138
+ context: true,
139
+ quiet
140
+ });
141
+ spinner.succeed("AI analysis complete");
142
+ } catch (aiError) {
143
+ spinner.fail("Could not generate AI assistance");
144
+ if (!quiet) {
145
+ console.error("AI assistance error:", aiError);
146
+ }
147
+ }
148
+ }
149
+ callback(1);
150
+ return 1;
151
+ }
152
+ callback(0);
153
+ return 0;
154
+ };
155
+ const buildWithWebpack = async (spinner, cmd, callback) => {
156
+ const {
157
+ analyze,
158
+ cliName = "Lex",
159
+ config,
160
+ configName,
161
+ defineProcessEnvNodeEnv,
162
+ devtool,
163
+ disableInterpret,
164
+ entry,
165
+ env,
166
+ failOnWarnings,
167
+ json,
168
+ merge,
169
+ mode,
170
+ name,
171
+ nodeEnv,
172
+ noDevtool,
173
+ noStats,
174
+ noTarget,
175
+ noWatch,
176
+ noWatchOptionsStdin,
177
+ outputPath,
178
+ quiet = false,
179
+ stats,
180
+ target,
181
+ watch,
182
+ watchOptionsStdin
183
+ } = cmd;
184
+ let webpackConfig;
185
+ const dirName = new URL(".", import.meta.url).pathname;
186
+ if (config) {
187
+ const isRelativeConfig = config.substr(0, 2) === "./";
188
+ webpackConfig = isRelativeConfig ? pathResolve(process.cwd(), config) : config;
189
+ } else {
190
+ webpackConfig = pathResolve(dirName, "../../webpack.config.js");
191
+ }
192
+ const webpackOptions = [
193
+ "--color",
194
+ "--progress",
195
+ "--config",
196
+ webpackConfig
197
+ ];
198
+ if (analyze) {
199
+ webpackOptions.push("--analyze");
200
+ }
201
+ if (configName) {
202
+ webpackOptions.push("--configName", configName);
203
+ }
204
+ if (defineProcessEnvNodeEnv) {
205
+ webpackOptions.push("--defineProcessEnvNodeEnv", defineProcessEnvNodeEnv);
206
+ }
207
+ if (devtool) {
208
+ webpackOptions.push("--devtool", devtool);
209
+ }
210
+ if (disableInterpret) {
211
+ webpackOptions.push("--disableInterpret");
212
+ }
213
+ if (entry) {
214
+ webpackOptions.push("--entry", entry);
215
+ }
216
+ if (env) {
217
+ webpackOptions.push("--env", env);
218
+ }
219
+ if (failOnWarnings) {
220
+ webpackOptions.push("--failOnWarnings");
221
+ }
222
+ if (json) {
223
+ webpackOptions.push("--json", json);
224
+ }
225
+ if (mode) {
226
+ webpackOptions.push("--mode", mode);
227
+ }
228
+ if (merge) {
229
+ webpackOptions.push("--merge");
230
+ }
231
+ if (name) {
232
+ webpackOptions.push("--name", name);
233
+ }
234
+ if (noDevtool) {
235
+ webpackOptions.push("--noDevtool");
236
+ }
237
+ if (noStats) {
238
+ webpackOptions.push("--noStats");
239
+ }
240
+ if (noTarget) {
241
+ webpackOptions.push("--noTarget");
242
+ }
243
+ if (noWatch) {
244
+ webpackOptions.push("--noWatch");
245
+ }
246
+ if (noWatchOptionsStdin) {
247
+ webpackOptions.push("--noWatchOptionsStdin");
248
+ }
249
+ if (nodeEnv) {
250
+ webpackOptions.push("--nodeEnv", nodeEnv);
251
+ }
252
+ if (outputPath) {
253
+ webpackOptions.push("--outputPath", outputPath);
254
+ }
255
+ if (stats) {
256
+ webpackOptions.push("--stats", stats);
257
+ }
258
+ if (target) {
259
+ webpackOptions.push("--target", target);
260
+ }
261
+ if (watch) {
262
+ webpackOptions.push("--watch");
263
+ }
264
+ if (watchOptionsStdin) {
265
+ webpackOptions.push("--watchOptionsStdin");
266
+ }
267
+ const dirPath = pathResolve(dirName, "../..");
268
+ try {
269
+ const webpackPath = relativeNodePath("webpack-cli/bin/cli.js", dirPath);
270
+ await execa(webpackPath, webpackOptions, { encoding: "utf8", stdio: "inherit" });
271
+ spinner.succeed("Build completed successfully!");
272
+ callback(0);
273
+ return 0;
274
+ } catch (error) {
275
+ log(`
276
+ ${cliName} Error: ${error.message}`, "error", quiet);
277
+ spinner.fail("Build failed.");
278
+ if (cmd.assist) {
279
+ spinner.start("AI is analyzing the webpack error...");
280
+ try {
281
+ await aiFunction({
282
+ prompt: `Fix this webpack build error: ${error.message}
283
+
284
+ Error details:
285
+ ${error.toString()}
286
+
287
+ Configuration used:
288
+ ${JSON.stringify(webpackOptions, null, 2)}`,
289
+ task: "help",
290
+ context: true,
291
+ quiet
292
+ });
293
+ spinner.succeed("AI analysis complete");
294
+ } catch (aiError) {
295
+ spinner.fail("Could not generate AI assistance");
296
+ if (!quiet) {
297
+ console.error("AI assistance error:", aiError);
298
+ }
299
+ }
300
+ }
301
+ callback(1);
302
+ return 1;
303
+ }
304
+ };
305
+ const build = async (cmd, callback = () => ({})) => {
306
+ const {
307
+ bundler = "webpack",
308
+ cliName = "Lex",
309
+ quiet = false,
310
+ remove = false,
311
+ variables = "{}"
312
+ } = cmd;
313
+ const spinner = createSpinner(quiet);
314
+ log(`${cliName} building...`, "info", quiet);
315
+ await LexConfig.parseConfig(cmd);
316
+ const { outputFullPath, useTypescript } = LexConfig.config;
317
+ checkLinkedModules();
318
+ let variablesObj = { NODE_ENV: "production" };
319
+ if (variables) {
320
+ try {
321
+ variablesObj = JSON.parse(variables);
322
+ } catch (error) {
323
+ log(`
324
+ ${cliName} Error: Environment variables option is not a valid JSON object.`, "error", quiet);
325
+ callback(1);
326
+ return 1;
327
+ }
328
+ }
329
+ process.env = { ...process.env, ...variablesObj };
330
+ spinner.start("Building code...");
331
+ if (remove) {
332
+ await removeFiles(outputFullPath);
333
+ }
334
+ if (useTypescript) {
335
+ LexConfig.checkTypescriptConfig();
336
+ }
337
+ let buildResult = 0;
338
+ if (bundler === "esbuild") {
339
+ buildResult = await buildWithEsBuild(spinner, cmd, (status) => {
340
+ buildResult = status;
341
+ });
342
+ } else {
343
+ buildResult = await buildWithWebpack(spinner, cmd, (status) => {
344
+ buildResult = status;
345
+ });
346
+ }
347
+ if (buildResult === 0 && cmd.analyze) {
348
+ spinner.start("AI is analyzing the build output for optimization opportunities...");
349
+ try {
350
+ const stats = {
351
+ outputPath: LexConfig.config.outputFullPath,
352
+ entryPoints: bundler === "esbuild" ? `Source files: ${LexConfig.config.sourceFullPath}/**/*.{ts,js}` : LexConfig.config.webpack?.entry || "Unknown entry points"
353
+ };
354
+ await aiFunction({
355
+ prompt: `Analyze this build for optimization opportunities:
356
+
357
+ Build Type: ${bundler}
358
+ Format: ${cmd.format || "default"}
359
+ Environment: ${LexConfig.config.targetEnvironment}
360
+ ${JSON.stringify(stats, null, 2)}
361
+
362
+ What are the key optimization opportunities for this build configuration? Consider:
363
+ 1. Bundle size optimization strategies
364
+ 2. Code splitting recommendations
365
+ 3. Tree-shaking improvements
366
+ 4. Performance enhancements
367
+ 5. Dependency optimizations`,
368
+ task: "optimize",
369
+ context: true,
370
+ quiet
371
+ });
372
+ spinner.succeed("AI build analysis complete");
373
+ } catch (aiError) {
374
+ spinner.fail("Could not generate AI optimization analysis");
375
+ if (!quiet) {
376
+ console.error("AI analysis error:", aiError);
377
+ }
378
+ }
379
+ }
380
+ if (buildResult === 0) {
381
+ try {
382
+ await copyConfiguredFiles(spinner, LexConfig.config, quiet);
383
+ } catch (copyError) {
384
+ log(`
385
+ ${cliName} Error: Failed to copy configured files: ${copyError.message}`, "error", quiet);
386
+ callback(1);
387
+ return 1;
388
+ }
389
+ }
390
+ callback(buildResult);
391
+ return buildResult;
392
+ };
393
+ var build_default = build;
394
+ export {
395
+ build,
396
+ buildWithEsBuild,
397
+ buildWithWebpack,
398
+ build_default as default
399
+ };
400
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/commands/build/build.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 GraphqlLoaderPlugin from '@luckycatfactory/esbuild-graphql-loader';\nimport {execa} from 'execa';\nimport {readFileSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport {resolve as pathResolve} from 'path';\nimport {URL} from 'url';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {checkLinkedModules, copyConfiguredFiles, createSpinner, removeFiles} from '../../utils/app.js';\nimport {relativeNodePath} from '../../utils/file.js';\nimport {log} from '../../utils/log.js';\nimport {aiFunction} from '../ai/ai.js';\n\nexport interface BuildOptions {\n  readonly assist?: boolean;\n  readonly analyze?: boolean;\n  readonly bundler?: 'webpack' | 'esbuild';\n  readonly cliName?: string;\n  readonly format?: string;\n  readonly outputPath?: string;\n  readonly quiet?: boolean;\n  readonly remove?: boolean;\n  readonly sourcePath?: string;\n  readonly variables?: string;\n  readonly watch?: boolean;\n}\n\nexport type BuildCallback = (status: number) => void;\n\nexport const buildWithEsBuild = async (spinner, commandOptions: BuildOptions, callback: BuildCallback) => {\n  const {\n    cliName = 'Lex',\n    format = 'cjs',\n    outputPath,\n    quiet,\n    sourcePath,\n    watch\n  } = commandOptions;\n  const {\n    outputFullPath,\n    sourceFullPath,\n    targetEnvironment,\n    useGraphQl,\n    useTypescript\n  } = LexConfig.config;\n  const sourceDir: string = sourcePath ? pathResolve(process.cwd(), `./${sourcePath}`) : sourceFullPath;\n  const loader = {\n    '.js': 'js'\n  };\n\n  if(useTypescript) {\n    loader['.ts'] = 'ts';\n    loader['.tsx'] = 'tsx';\n  }\n\n  const plugins = [];\n\n  if(useGraphQl) {\n    plugins.push((GraphqlLoaderPlugin as unknown as () => void)());\n  }\n\n  const globOptions = {\n    cwd: sourceDir,\n    dot: false,\n    nodir: true,\n    nosort: true\n  };\n  const tsFiles: string[] = globSync(`${sourceDir}/**/!(*.spec|*.test).ts*`, globOptions);\n  const jsFiles: string[] = globSync(`${sourceDir}/**/!(*.spec|*.test).js`, globOptions);\n  const sourceFiles: string[] = [...tsFiles, ...jsFiles];\n\n  const packageJsonData = readFileSync(pathResolve(process.cwd(), './package.json'));\n  const packageJson = JSON.parse(packageJsonData.toString());\n  const external = [\n    ...Object.keys(packageJson.dependencies || {}),\n    ...Object.keys(packageJson.peerDependencies || {})\n  ];\n\n  const dirName = new URL('.', import.meta.url).pathname;\n  const dirPath: string = pathResolve(dirName, '../..');\n  const outputDir: string = outputPath || outputFullPath;\n  const esbuildPath: string = relativeNodePath('esbuild/bin/esbuild', dirPath);\n  // Get esbuild configuration with defaults\n  const esbuildConfig = LexConfig.config.esbuild || {};\n\n  const esbuildOptions: string[] = [\n    ...sourceFiles,\n    '--bundle',\n    '--color=true',\n    `--format=${format}`,\n    `--outdir=${outputDir}`,\n    `--platform=${esbuildConfig.platform || 'node'}`,\n    `--target=${esbuildConfig.target || (targetEnvironment === 'node' ? 'node20' : 'es2020')}`,\n    `--sourcemap=${esbuildConfig.sourcemap || 'inline'}`\n  ];\n\n  // Apply optimization options\n  if (esbuildConfig.minify !== false) {\n    esbuildOptions.push('--minify');\n  }\n\n  if (esbuildConfig.treeShaking !== false) {\n    esbuildOptions.push('--tree-shaking=true');\n  }\n\n    if (esbuildConfig.drop && esbuildConfig.drop.length > 0) {\n    esbuildConfig.drop.forEach(item => {\n      esbuildOptions.push(`--drop:${item}`);\n    });\n  }\n\n  if (esbuildConfig.pure && esbuildConfig.pure.length > 0) {\n    esbuildConfig.pure.forEach(item => {\n      esbuildOptions.push(`--pure:${item}`);\n    });\n  }\n\n  if (esbuildConfig.legalComments) {\n    esbuildOptions.push(`--legal-comments=${esbuildConfig.legalComments}`);\n  }\n\n  if (esbuildConfig.splitting !== false) {\n    esbuildOptions.push('--splitting');\n  }\n\n  if (esbuildConfig.metafile) {\n    esbuildOptions.push('--metafile');\n  }\n\n  if (esbuildConfig.banner) {\n    Object.entries(esbuildConfig.banner).forEach(([type, content]) => {\n      esbuildOptions.push(`--banner:${type}=${content}`);\n    });\n  }\n\n  if (esbuildConfig.footer) {\n    Object.entries(esbuildConfig.footer).forEach(([type, content]) => {\n      esbuildOptions.push(`--footer:${type}=${content}`);\n    });\n  }\n\n  if (esbuildConfig.define) {\n    Object.entries(esbuildConfig.define).forEach(([key, value]) => {\n      esbuildOptions.push(`--define:${key}=${value}`);\n    });\n  }\n\n  if(external.length) {\n    esbuildOptions.push(`--external:${external.join(',')}`);\n  }\n\n  if(plugins.length) {\n    esbuildOptions.push(`--plugins=${plugins.join(',')}`);\n  }\n  if(watch) {\n    esbuildOptions.push('--watch');\n  }\n\n  try {\n    await execa(esbuildPath, esbuildOptions, {encoding: 'utf8'});\n\n    spinner.succeed('Build completed successfully!');\n  } catch(error) {\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n    if(!quiet) {\n      console.error(error);\n    }\n\n    spinner.fail('Code build failed.');\n\n    if(commandOptions.assist) {\n      spinner.start('AI is analyzing the error...');\n\n      try {\n        await aiFunction({\n          prompt: `Fix this esbuild error: ${error.message}\\n\\nError details:\\n${error.toString()}`,\n          task: 'help',\n          context: true,\n          quiet\n        });\n\n        spinner.succeed('AI analysis complete');\n      } catch(aiError) {\n        spinner.fail('Could not generate AI assistance');\n        if(!quiet) {\n          console.error('AI assistance error:', aiError);\n        }\n      }\n    }\n\n    callback(1);\n    return 1;\n  }\n\n  callback(0);\n  return 0;\n};\n\nexport const buildWithWebpack = async (spinner, cmd, callback) => {\n  const {\n    analyze,\n    cliName = 'Lex',\n    config,\n    configName,\n    defineProcessEnvNodeEnv,\n    devtool,\n    disableInterpret,\n    entry,\n    env,\n    failOnWarnings,\n    json,\n    merge,\n    mode,\n    name,\n    nodeEnv,\n    noDevtool,\n    noStats,\n    noTarget,\n    noWatch,\n    noWatchOptionsStdin,\n    outputPath,\n    quiet = false,\n    stats,\n    target,\n    watch,\n    watchOptionsStdin\n  } = cmd;\n\n  let webpackConfig: string;\n  const dirName = new URL('.', import.meta.url).pathname;\n\n  if(config) {\n    const isRelativeConfig: boolean = config.substr(0, 2) === './';\n    webpackConfig = isRelativeConfig ? pathResolve(process.cwd(), config) : config;\n  } else {\n    webpackConfig = pathResolve(dirName, '../../webpack.config.js');\n  }\n\n  const webpackOptions: string[] = [\n    '--color',\n    '--progress',\n    '--config', webpackConfig\n  ];\n\n  if(analyze) {\n    webpackOptions.push('--analyze');\n  }\n\n  if(configName) {\n    webpackOptions.push('--configName', configName);\n  }\n\n  if(defineProcessEnvNodeEnv) {\n    webpackOptions.push('--defineProcessEnvNodeEnv', defineProcessEnvNodeEnv);\n  }\n\n  if(devtool) {\n    webpackOptions.push('--devtool', devtool);\n  }\n\n  if(disableInterpret) {\n    webpackOptions.push('--disableInterpret');\n  }\n\n  if(entry) {\n    webpackOptions.push('--entry', entry);\n  }\n\n  if(env) {\n    webpackOptions.push('--env', env);\n  }\n\n  if(failOnWarnings) {\n    webpackOptions.push('--failOnWarnings');\n  }\n\n  if(json) {\n    webpackOptions.push('--json', json);\n  }\n\n  if(mode) {\n    webpackOptions.push('--mode', mode);\n  }\n\n  if(merge) {\n    webpackOptions.push('--merge');\n  }\n\n  if(name) {\n    webpackOptions.push('--name', name);\n  }\n\n  if(noDevtool) {\n    webpackOptions.push('--noDevtool');\n  }\n\n  if(noStats) {\n    webpackOptions.push('--noStats');\n  }\n\n  if(noTarget) {\n    webpackOptions.push('--noTarget');\n  }\n\n  if(noWatch) {\n    webpackOptions.push('--noWatch');\n  }\n\n  if(noWatchOptionsStdin) {\n    webpackOptions.push('--noWatchOptionsStdin');\n  }\n\n  if(nodeEnv) {\n    webpackOptions.push('--nodeEnv', nodeEnv);\n  }\n\n  if(outputPath) {\n    webpackOptions.push('--outputPath', outputPath);\n  }\n\n  if(stats) {\n    webpackOptions.push('--stats', stats);\n  }\n\n  if(target) {\n    webpackOptions.push('--target', target);\n  }\n\n  if(watch) {\n    webpackOptions.push('--watch');\n  }\n\n  if(watchOptionsStdin) {\n    webpackOptions.push('--watchOptionsStdin');\n  }\n\n  const dirPath: string = pathResolve(dirName, '../..');\n\n  try {\n    const webpackPath: string = relativeNodePath('webpack-cli/bin/cli.js', dirPath);\n    await execa(webpackPath, webpackOptions, {encoding: 'utf8', stdio: 'inherit'});\n\n    spinner.succeed('Build completed successfully!');\n\n    callback(0);\n    return 0;\n  } catch(error) {\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n    spinner.fail('Build failed.');\n\n    if(cmd.assist) {\n      spinner.start('AI is analyzing the webpack error...');\n\n      try {\n        await aiFunction({\n          prompt: `Fix this webpack build error: ${error.message}\\n\\nError details:\\n${error.toString()}\\n\\nConfiguration used:\\n${JSON.stringify(webpackOptions, null, 2)}`,\n          task: 'help',\n          context: true,\n          quiet\n        });\n\n        spinner.succeed('AI analysis complete');\n      } catch(aiError) {\n        spinner.fail('Could not generate AI assistance');\n        if(!quiet) {\n          console.error('AI assistance error:', aiError);\n        }\n      }\n    }\n\n    callback(1);\n    return 1;\n  }\n};\n\nexport const build = async (cmd: BuildOptions, callback: BuildCallback = () => ({})): Promise<number> => {\n  const {\n    bundler = 'webpack',\n    cliName = 'Lex',\n    quiet = false,\n    remove = false,\n    variables = '{}'\n  } = cmd;\n\n  const spinner = createSpinner(quiet);\n\n  log(`${cliName} building...`, 'info', quiet);\n\n  await LexConfig.parseConfig(cmd);\n\n  const {outputFullPath, useTypescript} = LexConfig.config;\n\n  checkLinkedModules();\n\n  let variablesObj: object = {NODE_ENV: 'production'};\n\n  if(variables) {\n    try {\n      variablesObj = JSON.parse(variables);\n    } catch(error) {\n      log(`\\n${cliName} Error: Environment variables option is not a valid JSON object.`, 'error', quiet);\n\n      callback(1);\n      return 1;\n    }\n  }\n\n  process.env = {...process.env, ...variablesObj};\n\n  spinner.start('Building code...');\n\n  if(remove) {\n    await removeFiles(outputFullPath);\n  }\n\n  if(useTypescript) {\n    LexConfig.checkTypescriptConfig();\n  }\n\n  let buildResult = 0;\n\n  if(bundler === 'esbuild') {\n    buildResult = await buildWithEsBuild(spinner, cmd, (status) => {\n      buildResult = status;\n    });\n  } else {\n    buildResult = await buildWithWebpack(spinner, cmd, (status) => {\n      buildResult = status;\n    });\n  }\n\n  if(buildResult === 0 && cmd.analyze) {\n    spinner.start('AI is analyzing the build output for optimization opportunities...');\n\n    try {\n      const stats = {\n        outputPath: LexConfig.config.outputFullPath,\n        entryPoints: bundler === 'esbuild' ?\n          `Source files: ${LexConfig.config.sourceFullPath}/**/*.{ts,js}` :\n          LexConfig.config.webpack?.entry || 'Unknown entry points'\n      };\n\n      await aiFunction({\n        prompt: `Analyze this build for optimization opportunities:\n\nBuild Type: ${bundler}\nFormat: ${cmd.format || 'default'}\nEnvironment: ${LexConfig.config.targetEnvironment}\n${JSON.stringify(stats, null, 2)}\n\nWhat are the key optimization opportunities for this build configuration? Consider:\n1. Bundle size optimization strategies\n2. Code splitting recommendations\n3. Tree-shaking improvements\n4. Performance enhancements\n5. Dependency optimizations`,\n        task: 'optimize',\n        context: true,\n        quiet\n      });\n\n      spinner.succeed('AI build analysis complete');\n    } catch(aiError) {\n      spinner.fail('Could not generate AI optimization analysis');\n      if(!quiet) {\n        console.error('AI analysis error:', aiError);\n      }\n    }\n  }\n\n  // Copy configured files after successful build\n  if(buildResult === 0) {\n    try {\n      await copyConfiguredFiles(spinner, LexConfig.config, quiet);\n    } catch(copyError) {\n      log(`\\n${cliName} Error: Failed to copy configured files: ${copyError.message}`, 'error', quiet);\n      callback(1);\n      return 1;\n    }\n  }\n\n  callback(buildResult);\n  return buildResult;\n};\n\nexport default build;\n"],
  "mappings": "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",
  "names": []
}

@@ -0,0 +1,5 @@
1
+ /**
2
+ * Test file for build CLI options coverage
3
+ * This test ensures all CLI options from lex.ts are properly handled
4
+ */
5
+ export {};
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,7 @@
1
+ export interface CleanOptions {
2
+ readonly cliName?: string;
3
+ readonly quiet?: boolean;
4
+ readonly snapshots?: boolean;
5
+ }
6
+ export type CleanCallback = (status: number) => void;
7
+ export declare const clean: (cmd: CleanOptions, callback?: CleanCallback) => Promise<number>;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,31 @@
1
+ import { LexConfig } from "../../LexConfig.js";
2
+ import { createSpinner, removeFiles, removeModules } from "../../utils/app.js";
3
+ import { log } from "../../utils/log.js";
4
+ const clean = async (cmd, callback = (_status) => ({})) => {
5
+ const { cliName = "Lex", quiet, snapshots } = cmd;
6
+ const spinner = createSpinner(quiet);
7
+ log(`${cliName} cleaning directory...`, "info", quiet);
8
+ await LexConfig.parseConfig(cmd);
9
+ spinner.start("Cleaning files...");
10
+ try {
11
+ await removeModules();
12
+ await removeFiles("./coverage", true);
13
+ await removeFiles("./npm-debug.log", true);
14
+ if (snapshots) {
15
+ await removeFiles("./**/__snapshots__", true);
16
+ }
17
+ spinner.succeed("Successfully cleaned!");
18
+ callback(0);
19
+ return 0;
20
+ } catch (error) {
21
+ log(`
22
+ ${cliName} Error: ${error.message}`, "error", quiet);
23
+ spinner.fail("Failed to clean project.");
24
+ callback(1);
25
+ return 1;
26
+ }
27
+ };
28
+ export {
29
+ clean
30
+ };
31
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL2NvbW1hbmRzL2NsZWFuL2NsZWFuLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtMZXhDb25maWd9IGZyb20gJy4uLy4uL0xleENvbmZpZy5qcyc7XG5pbXBvcnQge2NyZWF0ZVNwaW5uZXIsIHJlbW92ZUZpbGVzLCByZW1vdmVNb2R1bGVzfSBmcm9tICcuLi8uLi91dGlscy9hcHAuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uLy4uL3V0aWxzL2xvZy5qcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2xlYW5PcHRpb25zIHtcbiAgcmVhZG9ubHkgY2xpTmFtZT86IHN0cmluZztcbiAgcmVhZG9ubHkgcXVpZXQ/OiBib29sZWFuO1xuICByZWFkb25seSBzbmFwc2hvdHM/OiBib29sZWFuO1xufVxuXG5leHBvcnQgdHlwZSBDbGVhbkNhbGxiYWNrID0gKHN0YXR1czogbnVtYmVyKSA9PiB2b2lkO1xuXG5leHBvcnQgY29uc3QgY2xlYW4gPSBhc3luYyAoY21kOiBDbGVhbk9wdGlvbnMsIGNhbGxiYWNrOiBDbGVhbkNhbGxiYWNrID0gKF9zdGF0dXM6IG51bWJlcikgPT4gKHt9KSk6IFByb21pc2U8bnVtYmVyPiA9PiB7XG4gIGNvbnN0IHtjbGlOYW1lID0gJ0xleCcsIHF1aWV0LCBzbmFwc2hvdHN9ID0gY21kO1xuXG4gIC8vIFNwaW5uZXJcbiAgY29uc3Qgc3Bpbm5lciA9IGNyZWF0ZVNwaW5uZXIocXVpZXQpO1xuXG4gIC8vIERpc3BsYXkgc3RhdHVzXG4gIGxvZyhgJHtjbGlOYW1lfSBjbGVhbmluZyBkaXJlY3RvcnkuLi5gLCAnaW5mbycsIHF1aWV0KTtcblxuICAvLyBHZXQgY3VzdG9tIGNvbmZpZ3VyYXRpb25cbiAgYXdhaXQgTGV4Q29uZmlnLnBhcnNlQ29uZmlnKGNtZCk7XG5cbiAgLy8gU3RhcnQgY2xlYW5pbmcgc3Bpbm5lclxuICBzcGlubmVyLnN0YXJ0KCdDbGVhbmluZyBmaWxlcy4uLicpO1xuXG4gIHRyeSB7XG4gICAgLy8gUmVtb3ZlIG5vZGVfbW9kdWxlc1xuICAgIGF3YWl0IHJlbW92ZU1vZHVsZXMoKTtcblxuICAgIC8vIFJlbW92ZSB0ZXN0IGNvdmVyYWdlIHJlcG9ydHNcbiAgICBhd2FpdCByZW1vdmVGaWxlcygnLi9jb3ZlcmFnZScsIHRydWUpO1xuXG4gICAgLy8gUmVtb3ZlIG5wbSBsb2dzXG4gICAgYXdhaXQgcmVtb3ZlRmlsZXMoJy4vbnBtLWRlYnVnLmxvZycsIHRydWUpO1xuXG4gICAgaWYoc25hcHNob3RzKSB7XG4gICAgICBhd2FpdCByZW1vdmVGaWxlcygnLi8qKi9fX3NuYXBzaG90c19fJywgdHJ1ZSk7XG4gICAgfVxuXG4gICAgLy8gU3RvcCBzcGlubmVyXG4gICAgc3Bpbm5lci5zdWNjZWVkKCdTdWNjZXNzZnVsbHkgY2xlYW5lZCEnKTtcblxuICAgIC8vIFN0b3AgcHJvY2Vzc1xuICAgIGNhbGxiYWNrKDApO1xuICAgIHJldHVybiAwO1xuICB9IGNhdGNoKGVycm9yKSB7XG4gICAgLy8gRGlzcGxheSBlcnJvciBtZXNzYWdlXG4gICAgbG9nKGBcXG4ke2NsaU5hbWV9IEVycm9yOiAke2Vycm9yLm1lc3NhZ2V9YCwgJ2Vycm9yJywgcXVpZXQpO1xuXG4gICAgLy8gU3RvcCBzcGlubmVyXG4gICAgc3Bpbm5lci5mYWlsKCdGYWlsZWQgdG8gY2xlYW4gcHJvamVjdC4nKTtcblxuICAgIC8vIEtpbGwgcHJvY2Vzc1xuICAgIGNhbGxiYWNrKDEpO1xuICAgIHJldHVybiAxO1xuICB9XG59OyJdLAogICJtYXBwaW5ncyI6ICJBQUlBLFNBQVEsaUJBQWdCO0FBQ3hCLFNBQVEsZUFBZSxhQUFhLHFCQUFvQjtBQUN4RCxTQUFRLFdBQVU7QUFVWCxNQUFNLFFBQVEsT0FBTyxLQUFtQixXQUEwQixDQUFDLGFBQXFCLENBQUMsT0FBd0I7QUFDdEgsUUFBTSxFQUFDLFVBQVUsT0FBTyxPQUFPLFVBQVMsSUFBSTtBQUc1QyxRQUFNLFVBQVUsY0FBYyxLQUFLO0FBR25DLE1BQUksR0FBRyxPQUFPLDBCQUEwQixRQUFRLEtBQUs7QUFHckQsUUFBTSxVQUFVLFlBQVksR0FBRztBQUcvQixVQUFRLE1BQU0sbUJBQW1CO0FBRWpDLE1BQUk7QUFFRixVQUFNLGNBQWM7QUFHcEIsVUFBTSxZQUFZLGNBQWMsSUFBSTtBQUdwQyxVQUFNLFlBQVksbUJBQW1CLElBQUk7QUFFekMsUUFBRyxXQUFXO0FBQ1osWUFBTSxZQUFZLHNCQUFzQixJQUFJO0FBQUEsSUFDOUM7QUFHQSxZQUFRLFFBQVEsdUJBQXVCO0FBR3ZDLGFBQVMsQ0FBQztBQUNWLFdBQU87QUFBQSxFQUNULFNBQVEsT0FBTztBQUViLFFBQUk7QUFBQSxFQUFLLE9BQU8sV0FBVyxNQUFNLE9BQU8sSUFBSSxTQUFTLEtBQUs7QUFHMUQsWUFBUSxLQUFLLDBCQUEwQjtBQUd2QyxhQUFTLENBQUM7QUFDVixXQUFPO0FBQUEsRUFDVDtBQUNGOyIsCiAgIm5hbWVzIjogW10KfQo=
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,2 @@
1
+ export declare const hasFileType: (startPath: string, ext: string[]) => boolean;
2
+ export declare const compile: (cmd: any, callback?: any) => Promise<number>;