@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.
- 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.d.ts +79 -0
- package/dist/LexConfig.js +83 -15
- package/dist/commands/ai/ai.d.ts +17 -0
- package/dist/commands/ai/ai.js +303 -0
- package/dist/commands/ai/index.d.ts +8 -0
- package/dist/commands/ai/index.js +7 -0
- package/dist/commands/build/build.cli.test.d.ts +5 -0
- package/dist/commands/build/build.d.ts +18 -0
- package/dist/commands/build/build.integration.test.d.ts +1 -0
- package/dist/commands/build/build.js +400 -0
- package/dist/commands/build/build.options.test.d.ts +5 -0
- package/dist/commands/clean/clean.cli.test.d.ts +1 -0
- package/dist/commands/clean/clean.d.ts +7 -0
- package/dist/commands/clean/clean.integration.test.d.ts +1 -0
- package/dist/commands/clean/clean.js +31 -0
- package/dist/commands/clean/clean.options.test.d.ts +1 -0
- package/dist/commands/compile/compile.cli.test.d.ts +1 -0
- package/dist/commands/compile/compile.d.ts +2 -0
- package/dist/commands/compile/compile.integration.test.d.ts +1 -0
- package/dist/commands/compile/compile.js +239 -0
- package/dist/commands/compile/compile.options.test.d.ts +1 -0
- package/dist/commands/config/config.cli.test.d.ts +1 -0
- package/dist/commands/config/config.d.ts +7 -0
- package/dist/commands/config/config.integration.test.d.ts +1 -0
- package/dist/commands/config/config.js +43 -0
- package/dist/commands/config/config.options.test.d.ts +1 -0
- package/dist/commands/copy/copy.cli.test.d.ts +1 -0
- package/dist/commands/copy/copy.d.ts +6 -0
- package/dist/commands/copy/copy.integration.test.d.ts +1 -0
- package/dist/commands/copy/copy.js +38 -0
- package/dist/commands/copy/copy.options.test.d.ts +1 -0
- package/dist/commands/create/create.cli.test.d.ts +1 -0
- package/dist/commands/create/create.d.ts +8 -0
- package/dist/commands/create/create.integration.test.d.ts +1 -0
- package/dist/commands/create/create.js +124 -0
- package/dist/commands/create/create.options.test.d.ts +1 -0
- package/dist/commands/dev/dev.cli.test.d.ts +1 -0
- package/dist/commands/dev/dev.d.ts +11 -0
- package/dist/commands/dev/dev.integration.test.d.ts +1 -0
- package/dist/commands/dev/dev.js +70 -0
- package/dist/commands/dev/dev.options.test.d.ts +1 -0
- package/dist/commands/init/init.cli.test.d.ts +1 -0
- package/dist/commands/init/init.d.ts +9 -0
- package/dist/commands/init/init.integration.test.d.ts +1 -0
- package/dist/commands/init/init.js +93 -0
- package/dist/commands/init/init.options.test.d.ts +1 -0
- package/dist/commands/link/link.cli.test.d.ts +1 -0
- package/dist/commands/link/link.d.ts +6 -0
- package/dist/commands/link/link.integration.test.d.ts +1 -0
- package/dist/commands/link/link.js +15 -0
- package/dist/commands/link/link.options.test.d.ts +1 -0
- package/dist/commands/lint/autofix.d.ts +2 -0
- package/dist/commands/lint/lint.cli.test.d.ts +1 -0
- package/dist/commands/lint/lint.d.ts +39 -0
- package/dist/commands/lint/lint.integration.test.d.ts +1 -0
- package/dist/commands/lint/lint.js +820 -0
- package/dist/commands/lint/lint.options.test.d.ts +1 -0
- package/dist/commands/migrate/migrate.cli.test.d.ts +1 -0
- package/dist/commands/migrate/migrate.d.ts +7 -0
- package/dist/commands/migrate/migrate.integration.test.d.ts +1 -0
- package/dist/commands/migrate/migrate.js +37 -0
- package/dist/commands/migrate/migrate.options.test.d.ts +1 -0
- package/dist/commands/publish/publish.cli.test.d.ts +1 -0
- package/dist/commands/publish/publish.d.ts +12 -0
- package/dist/commands/publish/publish.integration.test.d.ts +1 -0
- package/dist/commands/publish/publish.js +104 -0
- package/dist/commands/publish/publish.options.test.d.ts +1 -0
- package/dist/commands/test/test.cli.test.d.ts +1 -0
- package/dist/commands/test/test.d.ts +50 -0
- package/dist/commands/test/test.integration.test.d.ts +1 -0
- package/dist/commands/test/test.js +327 -0
- package/dist/commands/test/test.options.test.d.ts +1 -0
- package/dist/commands/test/test.test.d.ts +1 -0
- package/dist/commands/update/update.cli.test.d.ts +1 -0
- package/dist/commands/update/update.d.ts +9 -0
- package/dist/commands/update/update.integration.test.d.ts +1 -0
- package/dist/commands/update/update.js +131 -0
- package/dist/commands/update/update.options.test.d.ts +1 -0
- package/dist/commands/upgrade/upgrade.cli.test.d.ts +1 -0
- package/dist/commands/upgrade/upgrade.d.ts +7 -0
- package/dist/commands/upgrade/upgrade.integration.test.d.ts +1 -0
- package/dist/commands/upgrade/upgrade.js +47 -0
- package/dist/commands/upgrade/upgrade.options.test.d.ts +1 -0
- package/dist/commands/versions/versions.cli.test.d.ts +1 -0
- package/dist/commands/versions/versions.d.ts +13 -0
- package/dist/commands/versions/versions.integration.test.d.ts +1 -0
- package/dist/commands/versions/versions.js +41 -0
- package/dist/commands/versions/versions.options.test.d.ts +1 -0
- package/dist/create/changelog.d.ts +6 -0
- package/dist/create/changelog.js +3 -3
- package/dist/index.d.ts +31 -0
- package/dist/index.js +35 -0
- package/dist/lex.d.ts +2 -0
- package/dist/lex.js +25 -22
- package/dist/types.d.ts +5 -0
- package/dist/types.js +1 -0
- package/dist/utils/aiService.d.ts +9 -0
- package/dist/utils/aiService.js +299 -0
- package/dist/utils/app.d.ts +41 -0
- package/dist/utils/app.js +53 -3
- package/dist/utils/file.d.ts +3 -0
- package/dist/utils/file.js +18 -3
- package/dist/utils/log.d.ts +1 -0
- package/dist/utils/log.js +2 -1
- package/dist/utils/reactShim.d.ts +2 -0
- package/dist/utils/reactShim.js +3 -3
- package/eslint.config.js +5 -0
- package/index.cjs +20 -0
- package/jest.config.cjs +31 -27
- package/jest.config.lex.d.ts +2 -0
- package/jest.config.lex.js +86 -38
- package/jest.setup.js +5 -0
- package/lex.config.js +50 -0
- package/package.json +73 -53
- package/{.postcssrc.js → postcss.config.js} +21 -9
- package/resolver.cjs +125 -14
- package/tsconfig.json +2 -1
- package/webpack.config.d.ts +2 -0
- package/webpack.config.js +27 -11
- 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 -120
- 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,20 @@
|
|
|
1
|
+
// Mock implementation of LexConfig
|
|
2
|
+
const defaultConfigValues = {
|
|
3
|
+
bundler: 'webpack',
|
|
4
|
+
useTypescript: false,
|
|
5
|
+
useGraphQl: false,
|
|
6
|
+
targetEnvironment: 'web',
|
|
7
|
+
sourcePath: './src',
|
|
8
|
+
outputPath: './dist'
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
const LexConfig = {
|
|
12
|
+
config: defaultConfigValues,
|
|
13
|
+
parseConfig: jest.fn(),
|
|
14
|
+
checkTypescriptConfig: jest.fn()
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
module.exports = {
|
|
18
|
+
LexConfig,
|
|
19
|
+
defaultConfigValues
|
|
20
|
+
};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
// Mock implementation of build module
|
|
2
|
+
const mockSpinner = {
|
|
3
|
+
start: jest.fn(),
|
|
4
|
+
succeed: jest.fn(),
|
|
5
|
+
fail: jest.fn()
|
|
6
|
+
};
|
|
7
|
+
|
|
8
|
+
const build = jest.fn().mockResolvedValue(0);
|
|
9
|
+
const buildWithEsBuild = jest.fn().mockResolvedValue(0);
|
|
10
|
+
const buildWithWebpack = jest.fn().mockResolvedValue(0);
|
|
11
|
+
|
|
12
|
+
module.exports = {
|
|
13
|
+
build,
|
|
14
|
+
buildWithEsBuild,
|
|
15
|
+
buildWithWebpack
|
|
16
|
+
};
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
// Mock implementation of chalk
|
|
2
|
+
const createChalkMock = (text) => text;
|
|
3
|
+
|
|
4
|
+
const chalkMock = {
|
|
5
|
+
red: createChalkMock,
|
|
6
|
+
green: createChalkMock,
|
|
7
|
+
blue: createChalkMock,
|
|
8
|
+
yellow: createChalkMock,
|
|
9
|
+
cyan: createChalkMock,
|
|
10
|
+
magenta: createChalkMock,
|
|
11
|
+
white: createChalkMock,
|
|
12
|
+
gray: createChalkMock,
|
|
13
|
+
grey: createChalkMock,
|
|
14
|
+
black: createChalkMock,
|
|
15
|
+
bold: createChalkMock,
|
|
16
|
+
dim: createChalkMock,
|
|
17
|
+
italic: createChalkMock,
|
|
18
|
+
underline: createChalkMock,
|
|
19
|
+
strikethrough: createChalkMock
|
|
20
|
+
};
|
|
21
|
+
|
|
22
|
+
module.exports = chalkMock;
|
|
23
|
+
module.exports.default = chalkMock;
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
// Mock implementation of execa
|
|
2
|
+
const mockExeca = jest.fn().mockImplementation(() => ({
|
|
3
|
+
stdout: '',
|
|
4
|
+
stderr: '',
|
|
5
|
+
exitCode: 0,
|
|
6
|
+
command: 'mocked-command',
|
|
7
|
+
pid: 123
|
|
8
|
+
}));
|
|
9
|
+
|
|
10
|
+
mockExeca.sync = jest.fn().mockImplementation(() => ({
|
|
11
|
+
stdout: '',
|
|
12
|
+
stderr: '',
|
|
13
|
+
exitCode: 0,
|
|
14
|
+
command: 'mocked-command',
|
|
15
|
+
pid: 123
|
|
16
|
+
}));
|
|
17
|
+
|
|
18
|
+
module.exports = {
|
|
19
|
+
execa: mockExeca,
|
|
20
|
+
default: mockExeca
|
|
21
|
+
};
|
package/__mocks__/ora.js
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
// Mock implementation of ora
|
|
2
|
+
const mockSpinner = {
|
|
3
|
+
start: jest.fn().mockReturnThis(),
|
|
4
|
+
stop: jest.fn().mockReturnThis(),
|
|
5
|
+
succeed: jest.fn().mockReturnThis(),
|
|
6
|
+
fail: jest.fn().mockReturnThis(),
|
|
7
|
+
warn: jest.fn().mockReturnThis(),
|
|
8
|
+
info: jest.fn().mockReturnThis(),
|
|
9
|
+
text: '',
|
|
10
|
+
color: 'cyan',
|
|
11
|
+
isSpinning: false
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
const mockOra = jest.fn().mockImplementation(() => mockSpinner);
|
|
15
|
+
|
|
16
|
+
module.exports = mockOra;
|
|
17
|
+
module.exports.default = mockOra;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
// Mock implementation of versions module
|
|
2
|
+
const jsonVersions = jest.fn().mockResolvedValue({});
|
|
3
|
+
const packages = jest.fn().mockResolvedValue([]);
|
|
4
|
+
const parseVersion = jest.fn().mockReturnValue('1.0.0');
|
|
5
|
+
const versions = jest.fn().mockResolvedValue(undefined);
|
|
6
|
+
|
|
7
|
+
module.exports = {
|
|
8
|
+
jsonVersions,
|
|
9
|
+
packages,
|
|
10
|
+
parseVersion,
|
|
11
|
+
versions
|
|
12
|
+
};
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
export interface EsbuildConfig {
|
|
2
|
+
entryPoints?: string[];
|
|
3
|
+
outdir?: string;
|
|
4
|
+
platform?: 'node' | 'browser';
|
|
5
|
+
target?: string;
|
|
6
|
+
format?: 'cjs' | 'esm';
|
|
7
|
+
minify?: boolean;
|
|
8
|
+
treeShaking?: boolean;
|
|
9
|
+
drop?: string[];
|
|
10
|
+
pure?: string[];
|
|
11
|
+
external?: string[];
|
|
12
|
+
splitting?: boolean;
|
|
13
|
+
metafile?: boolean;
|
|
14
|
+
sourcemap?: boolean | 'inline' | 'external';
|
|
15
|
+
legalComments?: 'none' | 'inline' | 'eof' | 'linked' | 'separate';
|
|
16
|
+
banner?: Record<string, string>;
|
|
17
|
+
footer?: Record<string, string>;
|
|
18
|
+
define?: Record<string, string>;
|
|
19
|
+
[key: string]: unknown;
|
|
20
|
+
}
|
|
21
|
+
export interface JestConfig {
|
|
22
|
+
roots?: string[];
|
|
23
|
+
testEnvironment?: string;
|
|
24
|
+
transform?: Record<string, [string, Record<string, unknown>]>;
|
|
25
|
+
transformIgnorePatterns?: string[];
|
|
26
|
+
moduleNameMapper?: Record<string, string>;
|
|
27
|
+
extensionsToTreatAsEsm?: string[];
|
|
28
|
+
preset?: string;
|
|
29
|
+
[key: string]: unknown;
|
|
30
|
+
}
|
|
31
|
+
export interface WebpackConfig {
|
|
32
|
+
entry?: string | string[];
|
|
33
|
+
output?: Record<string, unknown>;
|
|
34
|
+
module?: Record<string, unknown>;
|
|
35
|
+
plugins?: unknown[];
|
|
36
|
+
[key: string]: unknown;
|
|
37
|
+
}
|
|
38
|
+
export interface AIConfig {
|
|
39
|
+
provider?: 'cursor' | 'copilot' | 'openai' | 'anthropic' | 'none';
|
|
40
|
+
apiKey?: string;
|
|
41
|
+
model?: string;
|
|
42
|
+
maxTokens?: number;
|
|
43
|
+
temperature?: number;
|
|
44
|
+
}
|
|
45
|
+
export interface LexConfigType {
|
|
46
|
+
ai?: AIConfig;
|
|
47
|
+
configFiles?: string[];
|
|
48
|
+
copyFiles?: string[];
|
|
49
|
+
entryHTML?: string;
|
|
50
|
+
entryJs?: string;
|
|
51
|
+
esbuild?: EsbuildConfig;
|
|
52
|
+
env?: object;
|
|
53
|
+
gitUrl?: string;
|
|
54
|
+
jest?: JestConfig;
|
|
55
|
+
libraryName?: string;
|
|
56
|
+
libraryTarget?: string;
|
|
57
|
+
outputFile?: string;
|
|
58
|
+
outputFullPath?: string;
|
|
59
|
+
outputHash?: boolean;
|
|
60
|
+
outputPath?: string;
|
|
61
|
+
packageManager?: 'npm' | 'yarn';
|
|
62
|
+
preset?: 'web' | 'node' | 'lambda' | 'mobile';
|
|
63
|
+
sourceFullPath?: string;
|
|
64
|
+
sourcePath?: string;
|
|
65
|
+
targetEnvironment?: 'node' | 'web';
|
|
66
|
+
useGraphQl?: boolean;
|
|
67
|
+
useTypescript?: boolean;
|
|
68
|
+
webpack?: WebpackConfig;
|
|
69
|
+
}
|
|
70
|
+
export type Config = LexConfigType;
|
|
71
|
+
export declare const defaultConfigValues: LexConfigType;
|
|
72
|
+
export declare class LexConfig {
|
|
73
|
+
static config: LexConfigType;
|
|
74
|
+
static set useTypescript(value: boolean);
|
|
75
|
+
static updateConfig(updatedConfig: LexConfigType): LexConfigType;
|
|
76
|
+
static addConfigParams(cmd: any, params: LexConfigType): void;
|
|
77
|
+
static parseConfig(cmd: any, isRoot?: boolean): Promise<void>;
|
|
78
|
+
static checkTypescriptConfig(): void;
|
|
79
|
+
}
|
package/dist/LexConfig.js
CHANGED
|
@@ -5,10 +5,26 @@ import { relativeFilePath } from "./utils/file.js";
|
|
|
5
5
|
import { log } from "./utils/log.js";
|
|
6
6
|
const cwd = process.cwd();
|
|
7
7
|
const defaultConfigValues = {
|
|
8
|
+
ai: {
|
|
9
|
+
provider: "none",
|
|
10
|
+
model: "gpt-4o",
|
|
11
|
+
maxTokens: 4e3,
|
|
12
|
+
temperature: 0.1
|
|
13
|
+
},
|
|
8
14
|
configFiles: [],
|
|
15
|
+
copyFiles: [],
|
|
9
16
|
entryHTML: "index.html",
|
|
10
17
|
entryJs: "index.js",
|
|
11
|
-
esbuild: {
|
|
18
|
+
esbuild: {
|
|
19
|
+
minify: true,
|
|
20
|
+
treeShaking: true,
|
|
21
|
+
drop: ["console", "debugger"],
|
|
22
|
+
pure: ["console.log", "console.warn", "console.error"],
|
|
23
|
+
legalComments: "none",
|
|
24
|
+
splitting: true,
|
|
25
|
+
metafile: false,
|
|
26
|
+
sourcemap: false
|
|
27
|
+
},
|
|
12
28
|
env: null,
|
|
13
29
|
jest: {},
|
|
14
30
|
outputFullPath: pathResolve(cwd, "./dist"),
|
|
@@ -41,9 +57,8 @@ class LexConfig {
|
|
|
41
57
|
}
|
|
42
58
|
}
|
|
43
59
|
}
|
|
44
|
-
// Set options from a custom configuration file
|
|
45
60
|
static updateConfig(updatedConfig) {
|
|
46
|
-
const { outputFullPath, outputPath, sourcePath, sourceFullPath, useTypescript } = updatedConfig;
|
|
61
|
+
const { outputFullPath, outputPath, sourcePath, sourceFullPath, useTypescript, ai } = updatedConfig;
|
|
47
62
|
const cwd2 = process.cwd();
|
|
48
63
|
if (useTypescript !== void 0) {
|
|
49
64
|
LexConfig.useTypescript = useTypescript;
|
|
@@ -54,10 +69,15 @@ class LexConfig {
|
|
|
54
69
|
if (sourcePath !== void 0 && sourceFullPath === void 0) {
|
|
55
70
|
updatedConfig.sourceFullPath = pathResolve(cwd2, sourcePath);
|
|
56
71
|
}
|
|
72
|
+
if (ai) {
|
|
73
|
+
LexConfig.config.ai = { ...LexConfig.config.ai, ...ai };
|
|
74
|
+
if (process.env.CURSOR_IDE === "true" && LexConfig.config.ai.provider === "none") {
|
|
75
|
+
LexConfig.config.ai.provider = "cursor";
|
|
76
|
+
}
|
|
77
|
+
}
|
|
57
78
|
LexConfig.config = { ...LexConfig.config, ...updatedConfig };
|
|
58
79
|
return LexConfig.config;
|
|
59
80
|
}
|
|
60
|
-
// Set option updates from the command line
|
|
61
81
|
static addConfigParams(cmd, params) {
|
|
62
82
|
const nameProperty = "_name";
|
|
63
83
|
const { environment, outputPath, sourcePath, typescript } = cmd;
|
|
@@ -85,13 +105,28 @@ class LexConfig {
|
|
|
85
105
|
0
|
|
86
106
|
);
|
|
87
107
|
}
|
|
88
|
-
// Get configuration
|
|
89
108
|
static async parseConfig(cmd, isRoot = true) {
|
|
90
|
-
const { cliName = "Lex", lexConfig, lexConfigName, quiet, typescript } = cmd;
|
|
91
|
-
const
|
|
92
|
-
const
|
|
93
|
-
|
|
94
|
-
|
|
109
|
+
const { cliName = "Lex", lexConfig, lexConfigName, quiet, typescript, debug = false } = cmd;
|
|
110
|
+
const configFormats = ["js", "mjs", "cjs", "ts", "json"];
|
|
111
|
+
const configBaseName = lexConfigName || "lex.config";
|
|
112
|
+
let configPath = lexConfig || "";
|
|
113
|
+
let configExists = lexConfig ? existsSync(configPath) : false;
|
|
114
|
+
if (!configPath || !configExists) {
|
|
115
|
+
if (debug) {
|
|
116
|
+
log(`Searching for config files with base name: ${configBaseName}`, "info", quiet);
|
|
117
|
+
}
|
|
118
|
+
for (const format of configFormats) {
|
|
119
|
+
const potentialPath = isRoot ? pathResolve(cwd, `./${configBaseName}.${format}`) : relativeFilePath(`${configBaseName}.${format}`, cwd);
|
|
120
|
+
if (debug) {
|
|
121
|
+
log(`Checking for config file: ${potentialPath}`, "info", quiet);
|
|
122
|
+
}
|
|
123
|
+
if (existsSync(potentialPath)) {
|
|
124
|
+
configPath = potentialPath;
|
|
125
|
+
configExists = true;
|
|
126
|
+
break;
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
}
|
|
95
130
|
if (configExists) {
|
|
96
131
|
log(`Using ${cliName} configuration file: ${configPath}`, "note", quiet);
|
|
97
132
|
const ext = pathExtname(configPath);
|
|
@@ -102,6 +137,8 @@ class LexConfig {
|
|
|
102
137
|
try {
|
|
103
138
|
configJson = JSON.parse(configContent)?.default || {};
|
|
104
139
|
} catch (error) {
|
|
140
|
+
log(`
|
|
141
|
+
${cliName} Error: Failed to parse JSON config: ${error.message}`, "error", quiet);
|
|
105
142
|
configJson = {};
|
|
106
143
|
}
|
|
107
144
|
LexConfig.addConfigParams(cmd, configJson);
|
|
@@ -109,14 +146,45 @@ class LexConfig {
|
|
|
109
146
|
log(`
|
|
110
147
|
${cliName} Error: Config file malformed, ${configPath}`, "error", quiet);
|
|
111
148
|
}
|
|
112
|
-
} else if (
|
|
113
|
-
|
|
114
|
-
|
|
149
|
+
} else if ([".js", ".mjs", ".cjs", ".ts"].includes(ext)) {
|
|
150
|
+
try {
|
|
151
|
+
let lexCustomConfig;
|
|
152
|
+
if (ext === ".cjs") {
|
|
153
|
+
const fileUrl = new URL(`file:///${pathResolve(configPath)}`).href;
|
|
154
|
+
if (debug) {
|
|
155
|
+
log(`Loading CommonJS config from: ${fileUrl}`, "info", quiet);
|
|
156
|
+
}
|
|
157
|
+
lexCustomConfig = await import(fileUrl);
|
|
158
|
+
} else {
|
|
159
|
+
if (debug) {
|
|
160
|
+
log(`Loading ESM/TS config from: ${configPath}`, "info", quiet);
|
|
161
|
+
}
|
|
162
|
+
lexCustomConfig = await import(configPath);
|
|
163
|
+
}
|
|
164
|
+
const config = lexCustomConfig.default || lexCustomConfig;
|
|
165
|
+
if (debug) {
|
|
166
|
+
log(`Loaded config: ${JSON.stringify(config, null, 2)}`, "info", quiet);
|
|
167
|
+
}
|
|
168
|
+
if (!config) {
|
|
169
|
+
log(`
|
|
170
|
+
${cliName} Warning: Config file loaded but no configuration found`, "warn", quiet);
|
|
171
|
+
}
|
|
172
|
+
LexConfig.addConfigParams(cmd, config || {});
|
|
173
|
+
} catch (error) {
|
|
174
|
+
log(`
|
|
175
|
+
${cliName} Error: Failed to load config file: ${error.message}`, "error", quiet);
|
|
176
|
+
if (debug) {
|
|
177
|
+
console.error(error);
|
|
178
|
+
}
|
|
179
|
+
}
|
|
115
180
|
} else {
|
|
116
181
|
log(`
|
|
117
|
-
${cliName} Error: Config file must be a JS or JSON file.`, "error", quiet);
|
|
182
|
+
${cliName} Error: Config file must be a JS, CJS, MJS, TS, or JSON file.`, "error", quiet);
|
|
118
183
|
}
|
|
119
184
|
} else {
|
|
185
|
+
if (debug) {
|
|
186
|
+
log("No config file found. Using default configuration.", "info", quiet);
|
|
187
|
+
}
|
|
120
188
|
LexConfig.useTypescript = !!typescript;
|
|
121
189
|
LexConfig.addConfigParams(cmd, LexConfig.config);
|
|
122
190
|
}
|
|
@@ -133,4 +201,4 @@ export {
|
|
|
133
201
|
LexConfig,
|
|
134
202
|
defaultConfigValues
|
|
135
203
|
};
|
|
136
|
-
//# 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 {extname as pathExtname, resolve as pathResolve} from 'path';\nimport {URL} from 'url';\n\nimport {relativeFilePath} from './utils/file.js';\nimport {log} from './utils/log.js';\n\nconst cwd: string = process.cwd();\n\nexport interface EsbuildConfig {\n  entryPoints?: string[];\n  outdir?: string;\n  platform?: 'node' | 'browser';\n  target?: string;\n  format?: 'cjs' | 'esm';\n  [key: string]: unknown;\n}\n\nexport interface JestConfig {\n  roots?: string[];\n  testEnvironment?: string;\n  transform?: Record<string, [string, Record<string, unknown>]>;\n  [key: string]: unknown;\n}\n\nexport interface WebpackConfig {\n  entry?: string | string[];\n  output?: Record<string, unknown>;\n  module?: Record<string, unknown>;\n  plugins?: unknown[];\n  [key: string]: unknown;\n}\n\nexport interface LexConfigType {\n  configFiles?: string[];\n  entryHTML?: string;\n  entryJs?: string;\n  esbuild?: EsbuildConfig;\n  env?: object;\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 const defaultConfigValues: LexConfigType = {\n  configFiles: [],\n  entryHTML: 'index.html',\n  entryJs: 'index.js',\n  esbuild: {},\n  env: null,\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};\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    // Make sure we change the default entry file if Typescript is being used.\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  // Set options from a custom configuration file\n  static updateConfig(updatedConfig: LexConfigType): LexConfigType {\n    const {outputFullPath, outputPath, sourcePath, sourceFullPath, useTypescript} = updatedConfig;\n    const cwd: string = process.cwd();\n\n    // Use Typescript\n    if(useTypescript !== undefined) {\n      LexConfig.useTypescript = useTypescript;\n    }\n\n    // Destination Path\n    if(outputPath !== undefined && outputFullPath === undefined) {\n      updatedConfig.outputFullPath = pathResolve(cwd, outputPath);\n    }\n\n    // Source code path\n    if(sourcePath !== undefined && sourceFullPath === undefined) {\n      updatedConfig.sourceFullPath = pathResolve(cwd, sourcePath);\n    }\n\n    LexConfig.config = {...LexConfig.config, ...updatedConfig};\n    return LexConfig.config;\n  }\n\n  // Set option updates from the command line\n  static addConfigParams(cmd, params: LexConfigType) {\n    const nameProperty: string = '_name';\n    const {environment, outputPath, sourcePath, typescript} = cmd;\n\n    // Custom output dir\n    if(outputPath !== undefined) {\n      params.outputPath = outputPath;\n      params.outputFullPath = pathResolve(cwd, outputPath);\n    }\n\n    // Custom source dir\n    if(sourcePath !== undefined) {\n      params.sourcePath = sourcePath;\n      params.sourceFullPath = pathResolve(cwd, sourcePath);\n    }\n\n    // Determine if we're using Typescript or Flow\n    if(typescript !== undefined) {\n      params.useTypescript = true;\n    }\n\n    // Set the target environment\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  // Get configuration\n  static async parseConfig(cmd, isRoot: boolean = true): Promise<void> {\n    const {cliName = 'Lex', lexConfig, lexConfigName, quiet, typescript} = cmd;\n    const configName: string = lexConfigName || 'lex.config.js';\n    const defaultConfigPath: string = isRoot\n      ? pathResolve(cwd, `./${configName}`)\n      : relativeFilePath(configName, cwd);\n    const configPath: string = lexConfig || defaultConfigPath;\n    const configExists: boolean = existsSync(configPath);\n\n    // If user has a Lex config file, lets use it.\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            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(ext === '.js') {\n        const lexCustomConfig = await import(configPath);\n        LexConfig.addConfigParams(cmd, lexCustomConfig.default || {});\n      } else {\n        log(`\\n${cliName} Error: Config file must be a JS or JSON file.`, 'error', quiet);\n      }\n    } else {\n      // Determine if we're using Typescript or Flow\n      LexConfig.useTypescript = !!typescript;\n\n      // Save config as environment variable for other commands to include\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 = new URL('.', import.meta.url).pathname;\n      writeFileSync(tsconfigPath, readFileSync(pathResolve(dirName, '../../../tsconfig.base.json')));\n    }\n  }\n}\n"],
  "mappings": "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",
  "names": ["cwd"]
}

|
|
204
|
+
//# 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 {extname as pathExtname, resolve as pathResolve} from 'path';\nimport {URL} from 'url';\n\nimport {relativeFilePath} from './utils/file.js';\nimport {log} from './utils/log.js';\n\nconst cwd: string = process.cwd();\n\nexport interface EsbuildConfig {\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  [key: string]: unknown;\n}\n\nexport interface JestConfig {\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  [key: string]: unknown;\n}\n\nexport interface WebpackConfig {\n  entry?: string | string[];\n  output?: Record<string, unknown>;\n  module?: Record<string, unknown>;\n  plugins?: unknown[];\n  [key: string]: unknown;\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}\nexport interface LexConfigType {\n  ai?: AIConfig;\n  configFiles?: string[];\n  copyFiles?: string[];\n  entryHTML?: string;\n  entryJs?: string;\n  esbuild?: EsbuildConfig;\n  env?: object;\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    provider: 'none',\n    model: 'gpt-4o',\n    maxTokens: 4000,\n    temperature: 0.1\n  },\n  configFiles: [],\n  copyFiles: [],\n  entryHTML: 'index.html',\n  entryJs: 'index.js',\n  esbuild: {\n    minify: true,\n    treeShaking: true,\n    drop: ['console', 'debugger'],\n    pure: ['console.log', 'console.warn', 'console.error'],\n    legalComments: 'none',\n    splitting: true,\n    metafile: false,\n    sourcemap: false\n  },\n  env: null,\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};\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 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            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 = new URL('.', import.meta.url).pathname;\n      writeFileSync(tsconfigPath, readFileSync(pathResolve(dirName, '../../../tsconfig.base.json')));\n    }\n  }\n}"],
  "mappings": "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",
  "names": ["cwd"]
}

|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Command } from 'commander';
|
|
2
|
+
export interface AIOptions {
|
|
3
|
+
readonly cliName?: string;
|
|
4
|
+
readonly context?: boolean;
|
|
5
|
+
readonly file?: string;
|
|
6
|
+
readonly lexConfig?: string;
|
|
7
|
+
readonly model?: string;
|
|
8
|
+
readonly prompt?: string;
|
|
9
|
+
readonly quiet?: boolean;
|
|
10
|
+
readonly task?: 'generate' | 'explain' | 'test' | 'optimize' | 'help' | 'ask' | 'analyze';
|
|
11
|
+
readonly debug?: boolean;
|
|
12
|
+
readonly provider?: string;
|
|
13
|
+
readonly dir?: string;
|
|
14
|
+
}
|
|
15
|
+
export declare const aiFunction: (options: AIOptions) => Promise<any>;
|
|
16
|
+
export declare const ai: Command;
|
|
17
|
+
export default ai;
|