@nlabs/lex 1.46.1 → 1.47.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/__mocks__/LexConfig.js +20 -0
- package/__mocks__/boxen.js +7 -0
- package/__mocks__/build.js +16 -0
- package/__mocks__/chalk.js +23 -0
- package/__mocks__/compile.js +8 -0
- package/__mocks__/execa.js +21 -0
- package/__mocks__/ora.js +17 -0
- package/__mocks__/versions.js +12 -0
- package/dist/LexConfig.js +72 -14
- package/dist/commands/ai/ai.js +303 -0
- package/dist/commands/ai/index.js +7 -0
- package/dist/commands/build/build.js +350 -0
- package/dist/commands/clean/clean.js +31 -0
- package/dist/commands/compile/compile.js +195 -0
- package/dist/commands/config/config.js +43 -0
- package/dist/commands/copy/copy.js +38 -0
- package/dist/commands/create/create.js +124 -0
- package/dist/commands/dev/dev.js +70 -0
- package/dist/commands/init/init.js +93 -0
- package/dist/commands/link/link.js +15 -0
- package/dist/commands/lint/lint.js +656 -0
- package/dist/commands/migrate/migrate.js +37 -0
- package/dist/commands/publish/publish.js +104 -0
- package/dist/commands/test/test.js +327 -0
- package/dist/commands/update/update.js +62 -0
- package/dist/commands/upgrade/upgrade.js +47 -0
- package/dist/commands/versions/versions.js +41 -0
- package/dist/create/changelog.js +3 -3
- package/dist/index.js +35 -0
- package/dist/jest.config.lex.d.ts +2 -0
- package/dist/lex.js +25 -22
- package/dist/types.js +1 -0
- package/dist/utils/aiService.js +290 -0
- package/dist/utils/app.js +4 -4
- package/dist/utils/file.js +1 -1
- package/dist/utils/log.js +2 -1
- package/dist/utils/reactShim.js +3 -3
- package/dist/webpack.config.d.ts +2 -0
- package/eslint.config.js +10 -0
- package/index.cjs +20 -0
- package/jest.config.cjs +31 -27
- package/jest.config.lex.js +90 -38
- package/jest.setup.js +5 -0
- package/lex.config.js +50 -0
- package/package.json +70 -50
- package/{.postcssrc.js → postcss.config.js} +21 -9
- package/tsconfig.build.json +7 -16
- package/tsconfig.json +2 -1
- package/webpack.config.js +136 -77
- package/.eslintrc +0 -45
- package/dist/commands/build.js +0 -265
- package/dist/commands/bulid.test.js +0 -317
- package/dist/commands/clean.js +0 -31
- package/dist/commands/clean.test.js +0 -63
- package/dist/commands/compile.js +0 -195
- package/dist/commands/compile.test.js +0 -93
- package/dist/commands/config.js +0 -43
- package/dist/commands/copy.js +0 -38
- package/dist/commands/create.js +0 -116
- package/dist/commands/dev.js +0 -70
- package/dist/commands/init.js +0 -93
- package/dist/commands/link.js +0 -15
- package/dist/commands/lint.js +0 -179
- package/dist/commands/migrate.js +0 -37
- package/dist/commands/publish.js +0 -104
- package/dist/commands/test.js +0 -190
- package/dist/commands/update.js +0 -64
- package/dist/commands/upgrade.js +0 -47
- package/dist/commands/versions.js +0 -41
- package/dist/commands/versions.test.js +0 -49
- package/dist/lint.js +0 -11
- package/jest.setup.ts +0 -3
|
@@ -0,0 +1,350 @@
|
|
|
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, 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 esbuildOptions = [
|
|
60
|
+
...sourceFiles,
|
|
61
|
+
"--bundle",
|
|
62
|
+
"--color=true",
|
|
63
|
+
`--format=${format}`,
|
|
64
|
+
`--outdir=${outputDir}`,
|
|
65
|
+
"--platform=node",
|
|
66
|
+
"--format=cjs",
|
|
67
|
+
"--sourcemap=inline",
|
|
68
|
+
`--target=${targetEnvironment === "node" ? "node20" : "es2018"}`
|
|
69
|
+
];
|
|
70
|
+
if (external.length) {
|
|
71
|
+
esbuildOptions.push(`--external:${external.join(",")}`);
|
|
72
|
+
}
|
|
73
|
+
if (plugins.length) {
|
|
74
|
+
esbuildOptions.push(`--plugins=${plugins.join(",")}`);
|
|
75
|
+
}
|
|
76
|
+
if (watch) {
|
|
77
|
+
esbuildOptions.push("--watch");
|
|
78
|
+
}
|
|
79
|
+
try {
|
|
80
|
+
await execa(esbuildPath, esbuildOptions, { encoding: "utf8" });
|
|
81
|
+
spinner.succeed("Build completed successfully!");
|
|
82
|
+
} catch (error) {
|
|
83
|
+
log(`
|
|
84
|
+
${cliName} Error: ${error.message}`, "error", quiet);
|
|
85
|
+
if (!quiet) {
|
|
86
|
+
console.error(error);
|
|
87
|
+
}
|
|
88
|
+
spinner.fail("Code build failed.");
|
|
89
|
+
if (commandOptions.assist) {
|
|
90
|
+
spinner.start("AI is analyzing the error...");
|
|
91
|
+
try {
|
|
92
|
+
await aiFunction({
|
|
93
|
+
prompt: `Fix this esbuild error: ${error.message}
|
|
94
|
+
|
|
95
|
+
Error details:
|
|
96
|
+
${error.toString()}`,
|
|
97
|
+
task: "help",
|
|
98
|
+
context: true,
|
|
99
|
+
quiet
|
|
100
|
+
});
|
|
101
|
+
spinner.succeed("AI analysis complete");
|
|
102
|
+
} catch (aiError) {
|
|
103
|
+
spinner.fail("Could not generate AI assistance");
|
|
104
|
+
if (!quiet) {
|
|
105
|
+
console.error("AI assistance error:", aiError);
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
callback(1);
|
|
110
|
+
return 1;
|
|
111
|
+
}
|
|
112
|
+
callback(0);
|
|
113
|
+
return 0;
|
|
114
|
+
};
|
|
115
|
+
const buildWithWebpack = async (spinner, cmd, callback) => {
|
|
116
|
+
const {
|
|
117
|
+
analyze,
|
|
118
|
+
cliName = "Lex",
|
|
119
|
+
config,
|
|
120
|
+
configName,
|
|
121
|
+
defineProcessEnvNodeEnv,
|
|
122
|
+
devtool,
|
|
123
|
+
disableInterpret,
|
|
124
|
+
entry,
|
|
125
|
+
env,
|
|
126
|
+
failOnWarnings,
|
|
127
|
+
json,
|
|
128
|
+
merge,
|
|
129
|
+
mode,
|
|
130
|
+
name,
|
|
131
|
+
nodeEnv,
|
|
132
|
+
noDevtool,
|
|
133
|
+
noStats,
|
|
134
|
+
noTarget,
|
|
135
|
+
noWatch,
|
|
136
|
+
noWatchOptionsStdin,
|
|
137
|
+
outputPath,
|
|
138
|
+
quiet = false,
|
|
139
|
+
stats,
|
|
140
|
+
target,
|
|
141
|
+
watch,
|
|
142
|
+
watchOptionsStdin
|
|
143
|
+
} = cmd;
|
|
144
|
+
let webpackConfig;
|
|
145
|
+
const dirName = new URL(".", import.meta.url).pathname;
|
|
146
|
+
if (config) {
|
|
147
|
+
const isRelativeConfig = config.substr(0, 2) === "./";
|
|
148
|
+
webpackConfig = isRelativeConfig ? pathResolve(process.cwd(), config) : config;
|
|
149
|
+
} else {
|
|
150
|
+
webpackConfig = pathResolve(dirName, "../../webpack.config.js");
|
|
151
|
+
}
|
|
152
|
+
const webpackOptions = [
|
|
153
|
+
"--color",
|
|
154
|
+
"--progress",
|
|
155
|
+
"--config",
|
|
156
|
+
webpackConfig
|
|
157
|
+
];
|
|
158
|
+
if (analyze) {
|
|
159
|
+
webpackOptions.push("--analyze");
|
|
160
|
+
}
|
|
161
|
+
if (configName) {
|
|
162
|
+
webpackOptions.push("--configName", configName);
|
|
163
|
+
}
|
|
164
|
+
if (defineProcessEnvNodeEnv) {
|
|
165
|
+
webpackOptions.push("--defineProcessEnvNodeEnv", defineProcessEnvNodeEnv);
|
|
166
|
+
}
|
|
167
|
+
if (devtool) {
|
|
168
|
+
webpackOptions.push("--devtool", devtool);
|
|
169
|
+
}
|
|
170
|
+
if (disableInterpret) {
|
|
171
|
+
webpackOptions.push("--disableInterpret");
|
|
172
|
+
}
|
|
173
|
+
if (entry) {
|
|
174
|
+
webpackOptions.push("--entry", entry);
|
|
175
|
+
}
|
|
176
|
+
if (env) {
|
|
177
|
+
webpackOptions.push("--env", env);
|
|
178
|
+
}
|
|
179
|
+
if (failOnWarnings) {
|
|
180
|
+
webpackOptions.push("--failOnWarnings");
|
|
181
|
+
}
|
|
182
|
+
if (json) {
|
|
183
|
+
webpackOptions.push("--json", json);
|
|
184
|
+
}
|
|
185
|
+
if (mode) {
|
|
186
|
+
webpackOptions.push("--mode", mode);
|
|
187
|
+
}
|
|
188
|
+
if (merge) {
|
|
189
|
+
webpackOptions.push("--merge");
|
|
190
|
+
}
|
|
191
|
+
if (name) {
|
|
192
|
+
webpackOptions.push("--name", name);
|
|
193
|
+
}
|
|
194
|
+
if (noDevtool) {
|
|
195
|
+
webpackOptions.push("--noDevtool");
|
|
196
|
+
}
|
|
197
|
+
if (noStats) {
|
|
198
|
+
webpackOptions.push("--noStats");
|
|
199
|
+
}
|
|
200
|
+
if (noTarget) {
|
|
201
|
+
webpackOptions.push("--noTarget");
|
|
202
|
+
}
|
|
203
|
+
if (noWatch) {
|
|
204
|
+
webpackOptions.push("--noWatch");
|
|
205
|
+
}
|
|
206
|
+
if (noWatchOptionsStdin) {
|
|
207
|
+
webpackOptions.push("--noWatchOptionsStdin");
|
|
208
|
+
}
|
|
209
|
+
if (nodeEnv) {
|
|
210
|
+
webpackOptions.push("--nodeEnv", nodeEnv);
|
|
211
|
+
}
|
|
212
|
+
if (outputPath) {
|
|
213
|
+
webpackOptions.push("--outputPath", outputPath);
|
|
214
|
+
}
|
|
215
|
+
if (stats) {
|
|
216
|
+
webpackOptions.push("--stats", stats);
|
|
217
|
+
}
|
|
218
|
+
if (target) {
|
|
219
|
+
webpackOptions.push("--target", target);
|
|
220
|
+
}
|
|
221
|
+
if (watch) {
|
|
222
|
+
webpackOptions.push("--watch");
|
|
223
|
+
}
|
|
224
|
+
if (watchOptionsStdin) {
|
|
225
|
+
webpackOptions.push("--watchOptionsStdin");
|
|
226
|
+
}
|
|
227
|
+
const dirPath = pathResolve(dirName, "../..");
|
|
228
|
+
try {
|
|
229
|
+
const webpackPath = relativeNodePath("webpack-cli/bin/cli.js", dirPath);
|
|
230
|
+
await execa(webpackPath, webpackOptions, { encoding: "utf8", stdio: "inherit" });
|
|
231
|
+
spinner.succeed("Build completed successfully!");
|
|
232
|
+
callback(0);
|
|
233
|
+
return 0;
|
|
234
|
+
} catch (error) {
|
|
235
|
+
log(`
|
|
236
|
+
${cliName} Error: ${error.message}`, "error", quiet);
|
|
237
|
+
spinner.fail("Build failed.");
|
|
238
|
+
if (cmd.assist) {
|
|
239
|
+
spinner.start("AI is analyzing the webpack error...");
|
|
240
|
+
try {
|
|
241
|
+
await aiFunction({
|
|
242
|
+
prompt: `Fix this webpack build error: ${error.message}
|
|
243
|
+
|
|
244
|
+
Error details:
|
|
245
|
+
${error.toString()}
|
|
246
|
+
|
|
247
|
+
Configuration used:
|
|
248
|
+
${JSON.stringify(webpackOptions, null, 2)}`,
|
|
249
|
+
task: "help",
|
|
250
|
+
context: true,
|
|
251
|
+
quiet
|
|
252
|
+
});
|
|
253
|
+
spinner.succeed("AI analysis complete");
|
|
254
|
+
} catch (aiError) {
|
|
255
|
+
spinner.fail("Could not generate AI assistance");
|
|
256
|
+
if (!quiet) {
|
|
257
|
+
console.error("AI assistance error:", aiError);
|
|
258
|
+
}
|
|
259
|
+
}
|
|
260
|
+
}
|
|
261
|
+
callback(1);
|
|
262
|
+
return 1;
|
|
263
|
+
}
|
|
264
|
+
};
|
|
265
|
+
const build = async (cmd, callback = () => ({})) => {
|
|
266
|
+
const {
|
|
267
|
+
bundler = "webpack",
|
|
268
|
+
cliName = "Lex",
|
|
269
|
+
quiet = false,
|
|
270
|
+
remove = false,
|
|
271
|
+
variables = "{}"
|
|
272
|
+
} = cmd;
|
|
273
|
+
const spinner = createSpinner(quiet);
|
|
274
|
+
log(`${cliName} building...`, "info", quiet);
|
|
275
|
+
await LexConfig.parseConfig(cmd);
|
|
276
|
+
const { outputFullPath, useTypescript } = LexConfig.config;
|
|
277
|
+
checkLinkedModules();
|
|
278
|
+
let variablesObj = { NODE_ENV: "production" };
|
|
279
|
+
if (variables) {
|
|
280
|
+
try {
|
|
281
|
+
variablesObj = JSON.parse(variables);
|
|
282
|
+
} catch (error) {
|
|
283
|
+
log(`
|
|
284
|
+
${cliName} Error: Environment variables option is not a valid JSON object.`, "error", quiet);
|
|
285
|
+
callback(1);
|
|
286
|
+
return 1;
|
|
287
|
+
}
|
|
288
|
+
}
|
|
289
|
+
process.env = { ...process.env, ...variablesObj };
|
|
290
|
+
spinner.start("Building code...");
|
|
291
|
+
if (remove) {
|
|
292
|
+
await removeFiles(outputFullPath);
|
|
293
|
+
}
|
|
294
|
+
if (useTypescript) {
|
|
295
|
+
LexConfig.checkTypescriptConfig();
|
|
296
|
+
}
|
|
297
|
+
let buildResult = 0;
|
|
298
|
+
if (bundler === "esbuild") {
|
|
299
|
+
buildResult = await buildWithEsBuild(spinner, cmd, (status) => {
|
|
300
|
+
buildResult = status;
|
|
301
|
+
});
|
|
302
|
+
} else {
|
|
303
|
+
buildResult = await buildWithWebpack(spinner, cmd, (status) => {
|
|
304
|
+
buildResult = status;
|
|
305
|
+
});
|
|
306
|
+
}
|
|
307
|
+
if (buildResult === 0 && cmd.analyze) {
|
|
308
|
+
spinner.start("AI is analyzing the build output for optimization opportunities...");
|
|
309
|
+
try {
|
|
310
|
+
const stats = {
|
|
311
|
+
outputPath: LexConfig.config.outputFullPath,
|
|
312
|
+
entryPoints: bundler === "esbuild" ? `Source files: ${LexConfig.config.sourceFullPath}/**/*.{ts,js}` : LexConfig.config.webpack?.entry || "Unknown entry points"
|
|
313
|
+
};
|
|
314
|
+
await aiFunction({
|
|
315
|
+
prompt: `Analyze this build for optimization opportunities:
|
|
316
|
+
|
|
317
|
+
Build Type: ${bundler}
|
|
318
|
+
Format: ${cmd.format || "default"}
|
|
319
|
+
Environment: ${LexConfig.config.targetEnvironment}
|
|
320
|
+
${JSON.stringify(stats, null, 2)}
|
|
321
|
+
|
|
322
|
+
What are the key optimization opportunities for this build configuration? Consider:
|
|
323
|
+
1. Bundle size optimization strategies
|
|
324
|
+
2. Code splitting recommendations
|
|
325
|
+
3. Tree-shaking improvements
|
|
326
|
+
4. Performance enhancements
|
|
327
|
+
5. Dependency optimizations`,
|
|
328
|
+
task: "optimize",
|
|
329
|
+
context: true,
|
|
330
|
+
quiet
|
|
331
|
+
});
|
|
332
|
+
spinner.succeed("AI build analysis complete");
|
|
333
|
+
} catch (aiError) {
|
|
334
|
+
spinner.fail("Could not generate AI optimization analysis");
|
|
335
|
+
if (!quiet) {
|
|
336
|
+
console.error("AI analysis error:", aiError);
|
|
337
|
+
}
|
|
338
|
+
}
|
|
339
|
+
}
|
|
340
|
+
callback(buildResult);
|
|
341
|
+
return buildResult;
|
|
342
|
+
};
|
|
343
|
+
var build_default = build;
|
|
344
|
+
export {
|
|
345
|
+
build,
|
|
346
|
+
buildWithEsBuild,
|
|
347
|
+
buildWithWebpack,
|
|
348
|
+
build_default as default
|
|
349
|
+
};
|
|
350
|
+
//# 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, 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  const esbuildOptions: string[] = [\n    ...sourceFiles,\n    '--bundle',\n    '--color=true',\n    `--format=${format}`,\n    `--outdir=${outputDir}`,\n    '--platform=node',\n    '--format=cjs',\n    '--sourcemap=inline',\n    `--target=${targetEnvironment === 'node' ? 'node20' : 'es2018'}`\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  callback(buildResult);\n  return buildResult;\n};\n\nexport default build;\n"],
  "mappings": "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",
  "names": []
}

|
|
@@ -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,195 @@
|
|
|
1
|
+
import { execa } from "execa";
|
|
2
|
+
import { existsSync, lstatSync, readdirSync } from "fs";
|
|
3
|
+
import { sync as globSync } from "glob";
|
|
4
|
+
import { extname as pathExtname, join as pathJoin, resolve as pathResolve } from "path";
|
|
5
|
+
import { URL } from "url";
|
|
6
|
+
import { LexConfig } from "../../LexConfig.js";
|
|
7
|
+
import { checkLinkedModules, copyFiles, createSpinner, getFilesByExt, removeFiles } from "../../utils/app.js";
|
|
8
|
+
import { relativeNodePath } from "../../utils/file.js";
|
|
9
|
+
import { log } from "../../utils/log.js";
|
|
10
|
+
const hasFileType = (startPath, ext) => {
|
|
11
|
+
if (!existsSync(startPath)) {
|
|
12
|
+
return false;
|
|
13
|
+
}
|
|
14
|
+
const files = readdirSync(startPath);
|
|
15
|
+
return files.some((file) => {
|
|
16
|
+
const filename = pathJoin(startPath, file);
|
|
17
|
+
const fileExt = pathExtname(filename);
|
|
18
|
+
const stat = lstatSync(filename);
|
|
19
|
+
if (stat.isDirectory()) {
|
|
20
|
+
return hasFileType(filename, ext);
|
|
21
|
+
}
|
|
22
|
+
return ext.includes(fileExt);
|
|
23
|
+
});
|
|
24
|
+
};
|
|
25
|
+
const compile = async (cmd, callback = () => ({})) => {
|
|
26
|
+
const {
|
|
27
|
+
cliName = "Lex",
|
|
28
|
+
config,
|
|
29
|
+
outputPath,
|
|
30
|
+
quiet,
|
|
31
|
+
remove,
|
|
32
|
+
sourcePath,
|
|
33
|
+
watch
|
|
34
|
+
} = cmd;
|
|
35
|
+
const spinner = createSpinner(quiet);
|
|
36
|
+
log(`${cliName} compiling...`, "info", quiet);
|
|
37
|
+
await LexConfig.parseConfig(cmd);
|
|
38
|
+
const { outputFullPath, sourceFullPath, useTypescript } = LexConfig.config;
|
|
39
|
+
const outputDir = outputPath || outputFullPath;
|
|
40
|
+
const sourceDir = sourcePath ? pathResolve(process.cwd(), `./${sourcePath}`) : sourceFullPath;
|
|
41
|
+
const dirName = new URL(".", import.meta.url).pathname;
|
|
42
|
+
const dirPath = pathResolve(dirName, "../..");
|
|
43
|
+
checkLinkedModules();
|
|
44
|
+
if (remove) {
|
|
45
|
+
await removeFiles(outputDir);
|
|
46
|
+
}
|
|
47
|
+
if (useTypescript) {
|
|
48
|
+
LexConfig.checkTypescriptConfig();
|
|
49
|
+
const typescriptPath = relativeNodePath("typescript/bin/tsc", dirPath);
|
|
50
|
+
const typescriptOptions = config ? ["-p", config] : [
|
|
51
|
+
"--allowSyntheticDefaultImports",
|
|
52
|
+
"--baseUrl",
|
|
53
|
+
sourceDir,
|
|
54
|
+
"--declaration",
|
|
55
|
+
"--emitDeclarationOnly",
|
|
56
|
+
"--lib",
|
|
57
|
+
"ESNext,DOM",
|
|
58
|
+
"--module",
|
|
59
|
+
"esnext",
|
|
60
|
+
"--moduleResolution",
|
|
61
|
+
"node",
|
|
62
|
+
"--noImplicitReturns",
|
|
63
|
+
"--noImplicitThis",
|
|
64
|
+
"--outDir",
|
|
65
|
+
outputDir,
|
|
66
|
+
"--removeComments",
|
|
67
|
+
"--resolveJsonModule",
|
|
68
|
+
"--target",
|
|
69
|
+
"ESNext",
|
|
70
|
+
"--typeRoots",
|
|
71
|
+
"node_modules/@types,node_modules/json-d-ts"
|
|
72
|
+
];
|
|
73
|
+
spinner.start("Static type checking with Typescript...");
|
|
74
|
+
try {
|
|
75
|
+
await execa(typescriptPath, typescriptOptions, { encoding: "utf8" });
|
|
76
|
+
spinner.succeed("Successfully completed type checking!");
|
|
77
|
+
} catch (error) {
|
|
78
|
+
log(`
|
|
79
|
+
${cliName} Error: ${error.message}`, "error", quiet);
|
|
80
|
+
spinner.fail("Type checking failed.");
|
|
81
|
+
callback(1);
|
|
82
|
+
return 1;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
const globOptions = {
|
|
86
|
+
cwd: sourceDir,
|
|
87
|
+
dot: false,
|
|
88
|
+
nodir: true,
|
|
89
|
+
nosort: true
|
|
90
|
+
};
|
|
91
|
+
const tsFiles = globSync(`${sourceDir}/**/!(*.spec|*.test).ts*`, globOptions);
|
|
92
|
+
const jsFiles = globSync(`${sourceDir}/**/!(*.spec|*.test).js`, globOptions);
|
|
93
|
+
const sourceFiles = [...tsFiles, ...jsFiles];
|
|
94
|
+
const esbuildPath = relativeNodePath("esbuild/bin/esbuild", dirPath);
|
|
95
|
+
const esbuildOptions = [
|
|
96
|
+
...sourceFiles,
|
|
97
|
+
"--color=true",
|
|
98
|
+
"--format=cjs",
|
|
99
|
+
`--outdir=${outputDir}`,
|
|
100
|
+
"--platform=node",
|
|
101
|
+
"--sourcemap=inline",
|
|
102
|
+
"--target=node20"
|
|
103
|
+
];
|
|
104
|
+
if (watch) {
|
|
105
|
+
esbuildOptions.push("--watch");
|
|
106
|
+
}
|
|
107
|
+
const cssFiles = getFilesByExt(".css", LexConfig.config);
|
|
108
|
+
if (cssFiles.length) {
|
|
109
|
+
const postcssPath = relativeNodePath("postcss-cli/index.js", dirPath);
|
|
110
|
+
const postcssOptions = [
|
|
111
|
+
`${sourceDir}/**/**.css`,
|
|
112
|
+
"--base",
|
|
113
|
+
sourceDir,
|
|
114
|
+
"--dir",
|
|
115
|
+
outputDir,
|
|
116
|
+
"--config",
|
|
117
|
+
pathResolve(dirName, "../../postcss.config.js")
|
|
118
|
+
];
|
|
119
|
+
try {
|
|
120
|
+
await execa(postcssPath, postcssOptions, { encoding: "utf8" });
|
|
121
|
+
spinner.succeed(`Successfully formatted ${cssFiles.length} css files!`);
|
|
122
|
+
} catch (error) {
|
|
123
|
+
log(`
|
|
124
|
+
${cliName} Error: ${error.message}`, "error", quiet);
|
|
125
|
+
spinner.fail("Failed formatting css.");
|
|
126
|
+
callback(1);
|
|
127
|
+
return 1;
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
const gifFiles = getFilesByExt(".gif", LexConfig.config);
|
|
131
|
+
const jpgFiles = getFilesByExt(".jpg", LexConfig.config);
|
|
132
|
+
const pngFiles = getFilesByExt(".png", LexConfig.config);
|
|
133
|
+
const svgFiles = getFilesByExt(".svg", LexConfig.config);
|
|
134
|
+
const imageFiles = [...gifFiles, ...jpgFiles, ...pngFiles, ...svgFiles];
|
|
135
|
+
if (imageFiles.length) {
|
|
136
|
+
try {
|
|
137
|
+
await copyFiles(imageFiles, "image", spinner, LexConfig.config);
|
|
138
|
+
} catch (error) {
|
|
139
|
+
log(`
|
|
140
|
+
${cliName} Error: ${error.message}`, "error", quiet);
|
|
141
|
+
spinner.fail("Failed to move images to output directory.");
|
|
142
|
+
callback(1);
|
|
143
|
+
return 1;
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
const ttfFiles = getFilesByExt(".ttf", LexConfig.config);
|
|
147
|
+
const otfFiles = getFilesByExt(".otf", LexConfig.config);
|
|
148
|
+
const woffFiles = getFilesByExt(".woff", LexConfig.config);
|
|
149
|
+
const woff2Files = getFilesByExt(".woff2", LexConfig.config);
|
|
150
|
+
const fontFiles = [...ttfFiles, ...otfFiles, ...woffFiles, ...woff2Files];
|
|
151
|
+
if (fontFiles.length) {
|
|
152
|
+
try {
|
|
153
|
+
await copyFiles(fontFiles, "font", spinner, LexConfig.config);
|
|
154
|
+
} catch (error) {
|
|
155
|
+
log(`
|
|
156
|
+
${cliName} Error: ${error.message}`, "error", quiet);
|
|
157
|
+
spinner.fail("Failed to move fonts to output directory.");
|
|
158
|
+
callback(1);
|
|
159
|
+
return 1;
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
const mdFiles = getFilesByExt(".md", LexConfig.config);
|
|
163
|
+
if (mdFiles.length) {
|
|
164
|
+
try {
|
|
165
|
+
await copyFiles(mdFiles, "documents", spinner, LexConfig.config);
|
|
166
|
+
} catch (error) {
|
|
167
|
+
log(`
|
|
168
|
+
${cliName} Error: ${error.message}`, "error", quiet);
|
|
169
|
+
spinner.fail("Failed to move docs to output directory.");
|
|
170
|
+
callback(1);
|
|
171
|
+
return 1;
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
spinner.start(watch ? "Watching for changes..." : "Compiling with ESBuild...");
|
|
175
|
+
try {
|
|
176
|
+
await execa(esbuildPath, esbuildOptions, { encoding: "utf8" });
|
|
177
|
+
spinner.succeed("Compile completed successfully!");
|
|
178
|
+
} catch (error) {
|
|
179
|
+
log(`
|
|
180
|
+
${cliName} Error: ${error.message}`, "error", quiet);
|
|
181
|
+
if (!quiet) {
|
|
182
|
+
console.error(error);
|
|
183
|
+
}
|
|
184
|
+
spinner.fail("Code compiling failed.");
|
|
185
|
+
callback(1);
|
|
186
|
+
return 1;
|
|
187
|
+
}
|
|
188
|
+
callback(0);
|
|
189
|
+
return 0;
|
|
190
|
+
};
|
|
191
|
+
export {
|
|
192
|
+
compile,
|
|
193
|
+
hasFileType
|
|
194
|
+
};
|
|
195
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/commands/compile/compile.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 {execa} from 'execa';\nimport {existsSync, lstatSync, readdirSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport {extname as pathExtname, join as pathJoin, resolve as pathResolve} from 'path';\nimport {URL} from 'url';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {checkLinkedModules, copyFiles, createSpinner, getFilesByExt, removeFiles} from '../../utils/app.js';\nimport {relativeNodePath} from '../../utils/file.js';\nimport {log} from '../../utils/log.js';\n\nexport const hasFileType = (startPath: string, ext: string[]): boolean => {\n  if(!existsSync(startPath)) {\n    return false;\n  }\n\n  const files: string[] = readdirSync(startPath);\n\n  return files.some((file: string) => {\n    const filename: string = pathJoin(startPath, file);\n    const fileExt: string = pathExtname(filename);\n    const stat = lstatSync(filename);\n\n    if(stat.isDirectory()) {\n      // Recursive search\n      return hasFileType(filename, ext);\n    }\n\n    return ext.includes(fileExt);\n  });\n};\n\nexport const compile = async (cmd: any, callback: any = () => ({})): Promise<number> => {\n  const {\n    cliName = 'Lex',\n    config,\n    outputPath,\n    quiet,\n    remove,\n    sourcePath,\n    watch\n  } = cmd;\n\n  // Spinner\n  const spinner = createSpinner(quiet);\n\n  // Display status\n  log(`${cliName} compiling...`, 'info', quiet);\n\n  // Get custom configuration\n  await LexConfig.parseConfig(cmd);\n\n  // Compile type\n  const {outputFullPath, sourceFullPath, useTypescript} = LexConfig.config;\n  const outputDir: string = outputPath || outputFullPath;\n  const sourceDir: string = sourcePath ? pathResolve(process.cwd(), `./${sourcePath}`) : sourceFullPath;\n  const dirName = new URL('.', import.meta.url).pathname;\n  const dirPath: string = pathResolve(dirName, '../..');\n\n  // Check for linked modules\n  checkLinkedModules();\n\n  // Clean output directory before we start adding in new files\n  if(remove) {\n    await removeFiles(outputDir);\n  }\n\n  // Add tsconfig file if none exists\n  if(useTypescript) {\n    // Make sure tsconfig.json exists\n    LexConfig.checkTypescriptConfig();\n\n    // Check static types with typescript\n    const typescriptPath: string = relativeNodePath('typescript/bin/tsc', dirPath);\n    const typescriptOptions: string[] = config ?\n      ['-p', config] :\n      [\n        '--allowSyntheticDefaultImports',\n        '--baseUrl', sourceDir,\n        '--declaration',\n        '--emitDeclarationOnly',\n        '--lib', 'ESNext,DOM',\n        '--module', 'esnext',\n        '--moduleResolution', 'node',\n        '--noImplicitReturns',\n        '--noImplicitThis',\n        '--outDir', outputDir,\n        '--removeComments',\n        '--resolveJsonModule',\n        '--target', 'ESNext',\n        '--typeRoots', 'node_modules/@types,node_modules/json-d-ts'\n      ];\n\n    // Start type checking spinner\n    spinner.start('Static type checking with Typescript...');\n\n    // Type checking\n    try {\n      await execa(typescriptPath, typescriptOptions, {encoding: 'utf8'});\n\n      // Stop spinner\n      spinner.succeed('Successfully completed type checking!');\n    } catch(error) {\n      // Display error message\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      // Stop spinner\n      spinner.fail('Type checking failed.');\n\n      // Kill Process\n      callback(1);\n      return 1;\n    }\n  }\n\n  // Source files\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  // ESBuild options\n  const esbuildPath: string = relativeNodePath('esbuild/bin/esbuild', dirPath);\n  const esbuildOptions: string[] = [\n    ...sourceFiles,\n    '--color=true',\n    '--format=cjs',\n    `--outdir=${outputDir}`,\n    '--platform=node',\n    '--sourcemap=inline',\n    '--target=node20'\n  ];\n\n  if(watch) {\n    esbuildOptions.push('--watch');\n  }\n\n  // Use PostCSS for CSS files\n  const cssFiles: string[] = getFilesByExt('.css', LexConfig.config);\n\n  if(cssFiles.length) {\n    const postcssPath: string = relativeNodePath('postcss-cli/index.js', dirPath);\n    const postcssOptions: string[] = [\n      `${sourceDir}/**/**.css`,\n      '--base',\n      sourceDir,\n      '--dir',\n      outputDir,\n      '--config',\n      pathResolve(dirName, '../../postcss.config.js')\n    ];\n\n    try {\n      await execa(postcssPath, postcssOptions, {encoding: 'utf8'});\n      spinner.succeed(`Successfully formatted ${cssFiles.length} css files!`);\n    } catch(error) {\n      // Display error message\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      // Stop spinner\n      spinner.fail('Failed formatting css.');\n\n      // Kill Process\n      callback(1);\n      return 1;\n    }\n  }\n\n  // Copy image files\n  const gifFiles: string[] = getFilesByExt('.gif', LexConfig.config);\n  const jpgFiles: string[] = getFilesByExt('.jpg', LexConfig.config);\n  const pngFiles: string[] = getFilesByExt('.png', LexConfig.config);\n  const svgFiles: string[] = getFilesByExt('.svg', LexConfig.config);\n  const imageFiles: string[] = [...gifFiles, ...jpgFiles, ...pngFiles, ...svgFiles];\n\n  if(imageFiles.length) {\n    try {\n      await copyFiles(imageFiles, 'image', spinner, LexConfig.config);\n    } catch(error) {\n      // Display error message\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      // Stop spinner\n      spinner.fail('Failed to move images to output directory.');\n\n      // Kill Process\n      callback(1);\n      return 1;\n    }\n  }\n\n  // Copy font files\n  const ttfFiles: string[] = getFilesByExt('.ttf', LexConfig.config);\n  const otfFiles: string[] = getFilesByExt('.otf', LexConfig.config);\n  const woffFiles: string[] = getFilesByExt('.woff', LexConfig.config);\n  const woff2Files: string[] = getFilesByExt('.woff2', LexConfig.config);\n  const fontFiles: string[] = [...ttfFiles, ...otfFiles, ...woffFiles, ...woff2Files];\n\n  if(fontFiles.length) {\n    try {\n      await copyFiles(fontFiles, 'font', spinner, LexConfig.config);\n    } catch(error) {\n      // Display error message\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      // Stop spinner\n      spinner.fail('Failed to move fonts to output directory.');\n\n      // Kill Process\n      callback(1);\n      return 1;\n    }\n  }\n\n  // Copy markdown files\n  const mdFiles: string[] = getFilesByExt('.md', LexConfig.config);\n\n  if(mdFiles.length) {\n    try {\n      await copyFiles(mdFiles, 'documents', spinner, LexConfig.config);\n    } catch(error) {\n      // Display error message\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      // Stop spinner\n      spinner.fail('Failed to move docs to output directory.');\n\n      // Kill Process\n      callback(1);\n      return 1;\n    }\n  }\n\n  // Start compile spinner\n  spinner.start(watch ? 'Watching for changes...' : 'Compiling with ESBuild...');\n\n  try {\n    await execa(esbuildPath, esbuildOptions, {encoding: 'utf8'});\n\n    // Stop spinner\n    spinner.succeed('Compile completed successfully!');\n  } catch(error) {\n    // Display error message\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n    if(!quiet) {\n      console.error(error);\n    }\n\n    // Stop spinner\n    spinner.fail('Code compiling failed.');\n\n    // Kill Process\n    callback(1);\n    return 1;\n  }\n\n  // Stop process\n  callback(0);\n  return 0;\n};"],
  "mappings": "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",
  "names": []
}

|