@nlabs/lex 1.48.6 → 1.49.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.storybook/main.ts +9 -2
- package/.vscode/settings.json +1 -6
- package/README.md +276 -4
- package/eslint.config.mjs +24 -0
- package/examples/lex.config.js +18 -8
- package/examples/serverless-example/README.md +109 -0
- package/examples/serverless-example/dist/handlers/echo.js +15 -0
- package/examples/serverless-example/dist/handlers/graphql.js +137 -0
- package/examples/serverless-example/dist/handlers/hello.js +15 -0
- package/examples/serverless-example/dist/handlers/test.js +17 -0
- package/examples/serverless-example/dist/handlers/websocket.js +14 -0
- package/examples/serverless-example/lex.config.mjs +74 -0
- package/jest.config.mjs +13 -12
- package/{dist → lib}/LexConfig.d.ts +14 -6
- package/lib/LexConfig.js +268 -0
- package/lib/commands/ai/ai.js +303 -0
- package/{dist → lib}/commands/build/build.d.ts +3 -0
- package/lib/commands/build/build.js +494 -0
- package/{dist → lib}/commands/clean/clean.js +1 -1
- package/lib/commands/compile/compile.js +241 -0
- package/lib/commands/copy/copy.js +38 -0
- package/{dist → lib}/commands/create/create.js +1 -1
- package/{dist → lib}/commands/dev/dev.d.ts +2 -0
- package/lib/commands/dev/dev.js +286 -0
- package/{dist → lib}/commands/init/init.js +1 -1
- package/{dist → lib}/commands/lint/lint.d.ts +4 -1
- package/lib/commands/lint/lint.js +993 -0
- package/{dist → lib}/commands/migrate/migrate.js +1 -1
- package/lib/commands/publish/publish.js +104 -0
- package/lib/commands/serverless/serverless.d.ts +17 -0
- package/lib/commands/serverless/serverless.js +662 -0
- package/lib/commands/storybook/storybook.js +249 -0
- package/lib/commands/test/test.js +428 -0
- package/lib/commands/update/update.js +128 -0
- package/lib/commands/versions/versions.js +41 -0
- package/{dist → lib}/create/changelog.js +1 -1
- package/{dist → lib}/index.d.ts +2 -0
- package/{dist → lib}/index.js +3 -1
- package/lib/lex.js +73 -0
- package/lib/storybook/index.d.ts +5 -0
- package/lib/types.js +1 -0
- package/lib/utils/aiService.d.ts +9 -0
- package/lib/utils/aiService.js +299 -0
- package/{dist → lib}/utils/app.d.ts +3 -0
- package/lib/utils/app.js +296 -0
- package/lib/utils/deepMerge.js +26 -0
- package/{dist → lib}/utils/file.d.ts +7 -3
- package/lib/utils/file.js +229 -0
- package/lib/utils/translations.d.ts +1 -0
- package/lib/utils/translations.js +74 -0
- package/package.json +62 -50
- package/postcss.config.js +5 -3
- package/tsconfig.build.json +2 -2
- package/webpack.config.js +229 -39
- package/dist/LexConfig.js +0 -286
- package/dist/commands/ai/ai.js +0 -303
- package/dist/commands/build/build.js +0 -404
- package/dist/commands/compile/compile.js +0 -234
- package/dist/commands/copy/copy.js +0 -38
- package/dist/commands/dev/dev.js +0 -74
- package/dist/commands/lint/lint.js +0 -811
- package/dist/commands/publish/publish.js +0 -104
- package/dist/commands/storybook/storybook.js +0 -249
- package/dist/commands/test/test.js +0 -429
- package/dist/commands/update/update.js +0 -132
- package/dist/commands/versions/versions.js +0 -41
- package/dist/lex.js +0 -70
- package/dist/utils/aiService.d.ts +0 -9
- package/dist/utils/aiService.js +0 -299
- package/dist/utils/app.js +0 -267
- package/dist/utils/deepMerge.js +0 -24
- package/dist/utils/file.js +0 -185
- package/emptyModule.js +0 -0
- package/eslint.config.js +0 -7
- /package/{dist → lib}/Button.stories.d.ts +0 -0
- /package/{dist → lib}/commands/ai/ai.d.ts +0 -0
- /package/{dist → lib}/commands/ai/index.d.ts +0 -0
- /package/{dist → lib}/commands/ai/index.js +0 -0
- /package/{dist → lib}/commands/clean/clean.d.ts +0 -0
- /package/{dist → lib}/commands/compile/compile.d.ts +0 -0
- /package/{dist → lib}/commands/config/config.d.ts +0 -0
- /package/{dist → lib}/commands/config/config.js +0 -0
- /package/{dist → lib}/commands/copy/copy.d.ts +0 -0
- /package/{dist → lib}/commands/create/create.d.ts +0 -0
- /package/{dist → lib}/commands/init/init.d.ts +0 -0
- /package/{dist → lib}/commands/link/link.d.ts +0 -0
- /package/{dist → lib}/commands/link/link.js +0 -0
- /package/{dist → lib}/commands/lint/autofix.d.ts +0 -0
- /package/{dist → lib}/commands/migrate/migrate.d.ts +0 -0
- /package/{dist → lib}/commands/publish/publish.d.ts +0 -0
- /package/{dist → lib}/commands/storybook/storybook.d.ts +0 -0
- /package/{dist → lib}/commands/test/test.d.ts +0 -0
- /package/{dist → lib}/commands/update/update.d.ts +0 -0
- /package/{dist → lib}/commands/upgrade/upgrade.d.ts +0 -0
- /package/{dist → lib}/commands/upgrade/upgrade.js +0 -0
- /package/{dist → lib}/commands/versions/versions.d.ts +0 -0
- /package/{dist → lib}/create/changelog.d.ts +0 -0
- /package/{dist → lib}/lex.d.ts +0 -0
- /package/{dist/types.js → lib/storybook/index.js} +0 -0
- /package/{dist → lib}/test-react/index.d.ts +0 -0
- /package/{dist → lib}/test-react/index.js +0 -0
- /package/{dist → lib}/types.d.ts +0 -0
- /package/{dist → lib}/utils/deepMerge.d.ts +0 -0
- /package/{dist → lib}/utils/log.d.ts +0 -0
- /package/{dist → lib}/utils/log.js +0 -0
- /package/{dist → lib}/utils/reactShim.d.ts +0 -0
- /package/{dist → lib}/utils/reactShim.js +0 -0
package/dist/utils/app.js
DELETED
|
@@ -1,267 +0,0 @@
|
|
|
1
|
-
import boxen from "boxen";
|
|
2
|
-
import { copyFile, existsSync, lstatSync, mkdirSync, readdirSync, readFileSync, writeFileSync } from "fs";
|
|
3
|
-
import { sync as globSync } from "glob";
|
|
4
|
-
import isEmpty from "lodash/isEmpty.js";
|
|
5
|
-
import ora from "ora";
|
|
6
|
-
import { basename as pathBasename, join as pathJoin, relative as pathRelative, resolve as pathResolve } from "path";
|
|
7
|
-
import { rimrafSync } from "rimraf";
|
|
8
|
-
import { log } from "./log.js";
|
|
9
|
-
const cwd = process.cwd();
|
|
10
|
-
const getFilenames = (props) => {
|
|
11
|
-
const { callback, cliName, name, quiet, type, useTypescript } = props;
|
|
12
|
-
let nameCaps;
|
|
13
|
-
const itemTypes = ["stores", "views"];
|
|
14
|
-
if (!name) {
|
|
15
|
-
if (itemTypes.includes(type)) {
|
|
16
|
-
log(`
|
|
17
|
-
${cliName} Error: ${type} name is required. Please use 'lex -h' for options.`, "error", quiet);
|
|
18
|
-
return callback?.(1);
|
|
19
|
-
}
|
|
20
|
-
} else {
|
|
21
|
-
nameCaps = `${name.charAt(0).toUpperCase()}${name.substr(1)}`;
|
|
22
|
-
}
|
|
23
|
-
log(`${cliName} adding ${name} ${type}...`, "info", quiet);
|
|
24
|
-
let templatePath;
|
|
25
|
-
let templateExt;
|
|
26
|
-
let templateReact;
|
|
27
|
-
if (useTypescript) {
|
|
28
|
-
templatePath = "../../templates/typescript";
|
|
29
|
-
templateExt = ".ts";
|
|
30
|
-
templateReact = ".tsx";
|
|
31
|
-
} else {
|
|
32
|
-
templatePath = "../../templates/flow";
|
|
33
|
-
templateExt = ".js";
|
|
34
|
-
templateReact = ".js";
|
|
35
|
-
}
|
|
36
|
-
return {
|
|
37
|
-
nameCaps,
|
|
38
|
-
templateExt,
|
|
39
|
-
templatePath,
|
|
40
|
-
templateReact
|
|
41
|
-
};
|
|
42
|
-
};
|
|
43
|
-
const createSpinner = (quiet = false) => {
|
|
44
|
-
if (quiet) {
|
|
45
|
-
return {
|
|
46
|
-
fail: () => {
|
|
47
|
-
},
|
|
48
|
-
start: () => {
|
|
49
|
-
},
|
|
50
|
-
succeed: () => {
|
|
51
|
-
}
|
|
52
|
-
};
|
|
53
|
-
}
|
|
54
|
-
return ora({ color: "yellow" });
|
|
55
|
-
};
|
|
56
|
-
const copyFiles = async (files, typeName, spinner, config) => {
|
|
57
|
-
const { outputFullPath, sourceFullPath } = config;
|
|
58
|
-
const items = files.map((fileName) => ({
|
|
59
|
-
from: fileName,
|
|
60
|
-
to: pathResolve(outputFullPath, pathRelative(sourceFullPath, fileName))
|
|
61
|
-
}));
|
|
62
|
-
try {
|
|
63
|
-
spinner.start(`Copying ${typeName} files...`);
|
|
64
|
-
await Promise.all(items.map(({ from, to }) => new Promise(
|
|
65
|
-
(resolve, reject) => {
|
|
66
|
-
mkdirSync(pathResolve(to, ".."), { recursive: true });
|
|
67
|
-
return copyFile(from, to, (copyError) => {
|
|
68
|
-
if (copyError) {
|
|
69
|
-
reject();
|
|
70
|
-
} else {
|
|
71
|
-
resolve(true);
|
|
72
|
-
}
|
|
73
|
-
});
|
|
74
|
-
}
|
|
75
|
-
)));
|
|
76
|
-
spinner.succeed(`Successfully copied ${files.length} ${typeName} files!`);
|
|
77
|
-
} catch (error) {
|
|
78
|
-
spinner.fail(`Copying of ${typeName} files failed.`);
|
|
79
|
-
log(`Error: ${error.message}`, "error");
|
|
80
|
-
log(error, "error");
|
|
81
|
-
}
|
|
82
|
-
};
|
|
83
|
-
const copyConfiguredFiles = async (spinner, config, quiet) => {
|
|
84
|
-
const { copyFiles: copyFilesConfig, outputFullPath, sourceFullPath, sourcePath } = config;
|
|
85
|
-
if (!copyFilesConfig || copyFilesConfig.length === 0) {
|
|
86
|
-
return;
|
|
87
|
-
}
|
|
88
|
-
try {
|
|
89
|
-
spinner.start("Copying configured files...");
|
|
90
|
-
let totalCopied = 0;
|
|
91
|
-
const baseDir = sourceFullPath || (sourcePath ? pathResolve(cwd, sourcePath) : cwd);
|
|
92
|
-
for (const pattern of copyFilesConfig) {
|
|
93
|
-
const resolvedPattern = pathResolve(baseDir, pattern);
|
|
94
|
-
const matchingFiles = globSync(resolvedPattern, {
|
|
95
|
-
nodir: true,
|
|
96
|
-
absolute: true
|
|
97
|
-
});
|
|
98
|
-
if (matchingFiles.length === 0) {
|
|
99
|
-
if (!quiet) {
|
|
100
|
-
log(`Warning: No files found matching pattern: ${pattern}`, "warn", quiet);
|
|
101
|
-
}
|
|
102
|
-
continue;
|
|
103
|
-
}
|
|
104
|
-
for (const sourceFile of matchingFiles) {
|
|
105
|
-
const relativePath = pathRelative(baseDir, sourceFile);
|
|
106
|
-
const destPath = pathResolve(outputFullPath, relativePath);
|
|
107
|
-
const destDir = pathResolve(destPath, "..");
|
|
108
|
-
mkdirSync(destDir, { recursive: true });
|
|
109
|
-
await new Promise((resolve, reject) => {
|
|
110
|
-
copyFile(sourceFile, destPath, (copyError) => {
|
|
111
|
-
if (copyError) {
|
|
112
|
-
reject(copyError);
|
|
113
|
-
} else {
|
|
114
|
-
resolve(true);
|
|
115
|
-
}
|
|
116
|
-
});
|
|
117
|
-
});
|
|
118
|
-
totalCopied++;
|
|
119
|
-
}
|
|
120
|
-
}
|
|
121
|
-
if (totalCopied > 0) {
|
|
122
|
-
spinner.succeed(`Successfully copied ${totalCopied} configured files!`);
|
|
123
|
-
} else {
|
|
124
|
-
spinner.succeed("No configured files to copy");
|
|
125
|
-
}
|
|
126
|
-
} catch (error) {
|
|
127
|
-
spinner.fail("Failed to copy configured files");
|
|
128
|
-
log(`Error copying configured files: ${error.message}`, "error", quiet);
|
|
129
|
-
throw error;
|
|
130
|
-
}
|
|
131
|
-
};
|
|
132
|
-
const copyFileSync = (source, target) => {
|
|
133
|
-
let targetFile = target;
|
|
134
|
-
if (existsSync(target)) {
|
|
135
|
-
if (lstatSync(target).isDirectory()) {
|
|
136
|
-
targetFile = pathJoin(target, pathBasename(source));
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
writeFileSync(targetFile, readFileSync(source));
|
|
140
|
-
};
|
|
141
|
-
const copyFolderRecursiveSync = (source, target) => {
|
|
142
|
-
let files = [];
|
|
143
|
-
const targetFolder = pathJoin(target, pathBasename(source));
|
|
144
|
-
if (!existsSync(targetFolder)) {
|
|
145
|
-
mkdirSync(targetFolder);
|
|
146
|
-
}
|
|
147
|
-
if (lstatSync(source).isDirectory()) {
|
|
148
|
-
files = readdirSync(source);
|
|
149
|
-
files.forEach((file) => {
|
|
150
|
-
const curSource = pathJoin(source, file);
|
|
151
|
-
if (lstatSync(curSource).isDirectory()) {
|
|
152
|
-
copyFolderRecursiveSync(curSource, targetFolder);
|
|
153
|
-
} else {
|
|
154
|
-
copyFileSync(curSource, targetFolder);
|
|
155
|
-
}
|
|
156
|
-
});
|
|
157
|
-
}
|
|
158
|
-
};
|
|
159
|
-
const getPackageJson = (packagePath) => {
|
|
160
|
-
const formatPath = packagePath || `${process.cwd()}/package.json`;
|
|
161
|
-
const packageData = readFileSync(formatPath).toString();
|
|
162
|
-
return JSON.parse(packageData);
|
|
163
|
-
};
|
|
164
|
-
const getFilesByExt = (ext, config) => {
|
|
165
|
-
const { sourceFullPath } = config;
|
|
166
|
-
return globSync(`${sourceFullPath}/**/**${ext}`);
|
|
167
|
-
};
|
|
168
|
-
const removeConflictModules = (moduleList) => {
|
|
169
|
-
const updatedList = { ...moduleList };
|
|
170
|
-
Object.keys(updatedList).forEach((moduleName) => {
|
|
171
|
-
const regex = new RegExp("^(?!@types/).*?(jest|webpack).*$", "gi");
|
|
172
|
-
if (regex.test(moduleName)) {
|
|
173
|
-
delete updatedList[moduleName];
|
|
174
|
-
}
|
|
175
|
-
});
|
|
176
|
-
return updatedList;
|
|
177
|
-
};
|
|
178
|
-
const removeFiles = (fileName, isRelative = false) => new Promise((resolve, reject) => {
|
|
179
|
-
const filePath = isRelative ? pathResolve(cwd, fileName) : fileName;
|
|
180
|
-
try {
|
|
181
|
-
rimrafSync(filePath);
|
|
182
|
-
return resolve(null);
|
|
183
|
-
} catch (error) {
|
|
184
|
-
return reject(error);
|
|
185
|
-
}
|
|
186
|
-
});
|
|
187
|
-
const removeModules = () => new Promise(async (resolve, reject) => {
|
|
188
|
-
try {
|
|
189
|
-
await removeFiles("./node_modules", true);
|
|
190
|
-
await removeFiles("./yarn.lock", true);
|
|
191
|
-
await removeFiles("./package-lock.json", true);
|
|
192
|
-
resolve(null);
|
|
193
|
-
} catch (error) {
|
|
194
|
-
reject(error);
|
|
195
|
-
}
|
|
196
|
-
});
|
|
197
|
-
const setPackageJson = (json, packagePath) => {
|
|
198
|
-
if (!json) {
|
|
199
|
-
return;
|
|
200
|
-
}
|
|
201
|
-
const formatPath = packagePath || `${process.cwd()}/package.json`;
|
|
202
|
-
writeFileSync(formatPath, JSON.stringify(json, null, 2));
|
|
203
|
-
};
|
|
204
|
-
const linkedModules = (startPath) => {
|
|
205
|
-
const workingPath = startPath || process.cwd();
|
|
206
|
-
let modulePath;
|
|
207
|
-
let prefix;
|
|
208
|
-
if (workingPath.includes("@")) {
|
|
209
|
-
prefix = `@${workingPath.split("@").pop()}`;
|
|
210
|
-
modulePath = workingPath;
|
|
211
|
-
} else {
|
|
212
|
-
modulePath = pathJoin(workingPath, "node_modules");
|
|
213
|
-
}
|
|
214
|
-
const foundPaths = globSync(`${modulePath}/*`);
|
|
215
|
-
return foundPaths.reduce((list, foundPath) => {
|
|
216
|
-
try {
|
|
217
|
-
const stats = lstatSync(foundPath);
|
|
218
|
-
if (stats.isDirectory()) {
|
|
219
|
-
const deepList = linkedModules(foundPath);
|
|
220
|
-
list.push(...deepList);
|
|
221
|
-
} else if (stats.isSymbolicLink()) {
|
|
222
|
-
const moduleNames = [prefix, pathBasename(foundPath)].filter((item) => !isEmpty(item));
|
|
223
|
-
list.push({ name: `${moduleNames.join("/")}`, path: foundPath });
|
|
224
|
-
}
|
|
225
|
-
return list;
|
|
226
|
-
} catch (fsError) {
|
|
227
|
-
return list;
|
|
228
|
-
}
|
|
229
|
-
}, []);
|
|
230
|
-
};
|
|
231
|
-
const checkLinkedModules = () => {
|
|
232
|
-
const linked = linkedModules();
|
|
233
|
-
if (linked.length) {
|
|
234
|
-
const msgModule = linked.length > 1 ? "Modules" : "Module";
|
|
235
|
-
const linkedMsg = linked.reduce(
|
|
236
|
-
(msg, linkedModule) => `${msg}
|
|
237
|
-
* ${linkedModule.name}`,
|
|
238
|
-
`Linked ${msgModule}:`
|
|
239
|
-
);
|
|
240
|
-
log(boxen(linkedMsg, { dimBorder: true, padding: 1 }), "warn");
|
|
241
|
-
}
|
|
242
|
-
};
|
|
243
|
-
const updateTemplateName = (filePath, replace, replaceCaps) => {
|
|
244
|
-
let data = readFileSync(filePath, "utf8");
|
|
245
|
-
data = data.replace(/sample/g, replace);
|
|
246
|
-
data = data.replace(/Sample/g, replaceCaps);
|
|
247
|
-
writeFileSync(filePath, data, "utf8");
|
|
248
|
-
};
|
|
249
|
-
export {
|
|
250
|
-
checkLinkedModules,
|
|
251
|
-
copyConfiguredFiles,
|
|
252
|
-
copyFileSync,
|
|
253
|
-
copyFiles,
|
|
254
|
-
copyFolderRecursiveSync,
|
|
255
|
-
createSpinner,
|
|
256
|
-
cwd,
|
|
257
|
-
getFilenames,
|
|
258
|
-
getFilesByExt,
|
|
259
|
-
getPackageJson,
|
|
260
|
-
linkedModules,
|
|
261
|
-
removeConflictModules,
|
|
262
|
-
removeFiles,
|
|
263
|
-
removeModules,
|
|
264
|
-
setPackageJson,
|
|
265
|
-
updateTemplateName
|
|
266
|
-
};
|
|
267
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/utils/app.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 */\n\nimport boxen from 'boxen';\nimport {copyFile, existsSync, lstatSync, mkdirSync, readdirSync, readFileSync, writeFileSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport isEmpty from 'lodash/isEmpty.js';\nimport ora from 'ora';\nimport {basename as pathBasename, join as pathJoin, relative as pathRelative, resolve as pathResolve} from 'path';\nimport {rimrafSync} from 'rimraf';\n\n\nimport {log} from './log.js';\n\nimport type {LexConfigType} from '../LexConfig.js';\n\n\nexport const cwd: string = process.cwd();\n\nexport interface GetFilenamesProps {\n  readonly callback?: (status: number) => void;\n  readonly cliName?: string;\n  readonly name?: string;\n  readonly quiet?: boolean;\n  readonly type?: string;\n  readonly useTypescript?: boolean;\n}\n\ninterface FilenamesResult {\n  nameCaps: string;\n  templateExt: string;\n  templatePath: string;\n  templateReact: string;\n}\n\nexport const getFilenames = (props: GetFilenamesProps): FilenamesResult | void => {\n  const {callback, cliName, name, quiet, type, useTypescript} = props;\n\n  let nameCaps: string;\n  const itemTypes: string[] = ['stores', 'views'];\n\n  if(!name) {\n    if(itemTypes.includes(type)) {\n      log(`\\n${cliName} Error: ${type} name is required. Please use 'lex -h' for options.`, 'error', quiet);\n      return callback?.(1);\n    }\n  } else {\n    nameCaps = `${name.charAt(0).toUpperCase()}${name.substr(1)}`;\n  }\n\n  log(`${cliName} adding ${name} ${type}...`, 'info', quiet);\n\n  let templatePath: string;\n  let templateExt: string;\n  let templateReact: string;\n\n  if(useTypescript) {\n    templatePath = '../../templates/typescript';\n    templateExt = '.ts';\n    templateReact = '.tsx';\n  } else {\n    templatePath = '../../templates/flow';\n    templateExt = '.js';\n    templateReact = '.js';\n  }\n\n  return {\n    nameCaps,\n    templateExt,\n    templatePath,\n    templateReact\n  };\n};\n\nexport interface Spinner {\n  fail: (text?: string) => void;\n  start: (text?: string) => void;\n  succeed: (text?: string) => void;\n}\n\nexport const createSpinner = (quiet = false): Spinner => {\n  if(quiet) {\n    return {\n      fail: () => {},\n      start: () => {},\n      succeed: () => {}\n    };\n  }\n\n  return ora({color: 'yellow'});\n};\n\nexport const copyFiles = async (files: string[], typeName: string, spinner, config: LexConfigType) => {\n  const {outputFullPath, sourceFullPath} = config;\n  const items = files.map((fileName: string) => ({\n    from: fileName,\n    to: pathResolve(outputFullPath, pathRelative(sourceFullPath, fileName))\n  }));\n\n  try {\n    spinner.start(`Copying ${typeName} files...`);\n    await Promise.all(items.map(({from, to}) => new Promise(\n      (resolve, reject) => {\n        mkdirSync(pathResolve(to, '..'), {recursive: true});\n        return copyFile(from, to, (copyError) => {\n          if(copyError) {\n            reject();\n          } else {\n            resolve(true);\n          }\n        });\n      }\n    )));\n    spinner.succeed(`Successfully copied ${files.length} ${typeName} files!`);\n  } catch(error) {\n    spinner.fail(`Copying of ${typeName} files failed.`);\n    log(`Error: ${error.message}`, 'error');\n    log(error, 'error');\n  }\n};\n\nexport const copyConfiguredFiles = async (spinner, config: LexConfigType, quiet: boolean) => {\n  const {copyFiles: copyFilesConfig, outputFullPath, sourceFullPath, sourcePath} = config;\n  if(!copyFilesConfig || copyFilesConfig.length === 0) {\n    return;\n  }\n\n  try {\n    spinner.start('Copying configured files...');\n    let totalCopied = 0;\n\n    const baseDir = sourceFullPath || (sourcePath ? pathResolve(cwd, sourcePath) : cwd);\n\n    for(const pattern of copyFilesConfig) {\n      const resolvedPattern = pathResolve(baseDir, pattern);\n      const matchingFiles = globSync(resolvedPattern, {\n        nodir: true,\n        absolute: true\n      });\n      if(matchingFiles.length === 0) {\n        if(!quiet) {\n          log(`Warning: No files found matching pattern: ${pattern}`, 'warn', quiet);\n        }\n        continue;\n      }\n\n      for(const sourceFile of matchingFiles) {\n        // Calculate relative path from source directory\n        const relativePath = pathRelative(baseDir, sourceFile);\n        // Determine destination path in output directory\n        const destPath = pathResolve(outputFullPath, relativePath);\n        // Create destination directory if it doesn't exist\n        const destDir = pathResolve(destPath, '..');\n        mkdirSync(destDir, {recursive: true});\n\n        await new Promise((resolve, reject) => {\n          copyFile(sourceFile, destPath, (copyError) => {\n            if(copyError) {\n              reject(copyError);\n            } else {\n              resolve(true);\n            }\n          });\n        });\n        totalCopied++;\n      }\n    }\n    if(totalCopied > 0) {\n      spinner.succeed(`Successfully copied ${totalCopied} configured files!`);\n    } else {\n      spinner.succeed('No configured files to copy');\n    }\n  } catch(error) {\n    spinner.fail('Failed to copy configured files');\n    log(`Error copying configured files: ${error.message}`, 'error', quiet);\n    throw error;\n  }\n};\n\nexport const copyFileSync = (source: string, target: string) => {\n  let targetFile: string = target;\n\n  if(existsSync(target)) {\n    if(lstatSync(target).isDirectory()) {\n      targetFile = pathJoin(target, pathBasename(source));\n    }\n  }\n\n  writeFileSync(targetFile, readFileSync(source));\n};\n\nexport const copyFolderRecursiveSync = (source: string, target: string): void => {\n  let files: string[] = [];\n\n  const targetFolder: string = pathJoin(target, pathBasename(source));\n\n  if(!existsSync(targetFolder)) {\n    mkdirSync(targetFolder);\n  }\n\n  if(lstatSync(source).isDirectory()) {\n    files = readdirSync(source);\n    files.forEach((file: string) => {\n      const curSource: string = pathJoin(source, file);\n\n      if(lstatSync(curSource).isDirectory()) {\n        copyFolderRecursiveSync(curSource, targetFolder);\n      } else {\n        copyFileSync(curSource, targetFolder);\n      }\n    });\n  }\n};\n\nexport const getPackageJson = (packagePath?: string) => {\n  const formatPath: string = packagePath || `${process.cwd()}/package.json`;\n\n  const packageData: string = readFileSync(formatPath).toString();\n  return JSON.parse(packageData);\n};\n\nexport const getFilesByExt = (ext: string, config: LexConfigType): string[] => {\n  const {sourceFullPath} = config;\n  return globSync(`${sourceFullPath}/**/**${ext}`);\n};\n\nexport const removeConflictModules = (moduleList: object) => {\n  const updatedList: object = {...moduleList};\n\n  Object.keys(updatedList).forEach((moduleName: string) => {\n    const regex: RegExp = new RegExp('^(?!@types/).*?(jest|webpack).*$', 'gi');\n    if(regex.test(moduleName)) {\n      delete updatedList[moduleName];\n    }\n  });\n\n  return updatedList;\n};\n\nexport const removeFiles = (fileName: string, isRelative: boolean = false) => new Promise((resolve, reject) => {\n  const filePath: string = isRelative ? pathResolve(cwd, fileName) : fileName;\n  try {\n    rimrafSync(filePath);\n    return resolve(null);\n  } catch(error) {\n    return reject(error);\n  }\n});\n\nexport const removeModules = () => new Promise(async (resolve, reject) => {\n  try {\n    // Remove node_modules\n    await removeFiles('./node_modules', true);\n\n    // Remove yarn lock\n    await removeFiles('./yarn.lock', true);\n\n    // Remove npm lock\n    await removeFiles('./package-lock.json', true);\n\n    resolve(null);\n  } catch(error) {\n    reject(error);\n  }\n});\n\nexport const setPackageJson = (json, packagePath?: string) => {\n  if(!json) {\n    return;\n  }\n\n  const formatPath: string = packagePath || `${process.cwd()}/package.json`;\n\n  writeFileSync(formatPath, JSON.stringify(json, null, 2));\n};\n\nexport interface LinkedModuleType {\n  readonly name: string;\n  readonly path: string;\n}\n\nexport const linkedModules = (startPath?: string): LinkedModuleType[] => {\n  const workingPath: string = startPath || process.cwd();\n  let modulePath: string;\n  let prefix: string;\n\n  if(workingPath.includes('@')) {\n    prefix = `@${workingPath.split('@').pop()}`;\n    modulePath = workingPath;\n  } else {\n    modulePath = pathJoin(workingPath, 'node_modules');\n  }\n\n  const foundPaths: string[] = globSync(`${modulePath}/*`);\n  return foundPaths.reduce((list: LinkedModuleType[], foundPath: string) => {\n    try {\n      const stats = lstatSync(foundPath);\n\n      if(stats.isDirectory()) {\n        const deepList: LinkedModuleType[] = linkedModules(foundPath);\n        list.push(...deepList);\n      } else if(stats.isSymbolicLink()) {\n        const moduleNames: string[] = ([prefix, pathBasename(foundPath)]).filter((item: string) => !isEmpty(item));\n        list.push({name: `${moduleNames.join('/')}`, path: foundPath});\n      }\n\n      return list;\n    } catch(fsError) {\n      // Skip files that don't exist or can't be accessed\n      return list;\n    }\n  }, []);\n};\n\nexport const checkLinkedModules = () => {\n  const linked = linkedModules();\n\n  if(linked.length) {\n    const msgModule: string = linked.length > 1 ? 'Modules' : 'Module';\n    const linkedMsg: string = linked.reduce(\n      (msg: string, linkedModule: LinkedModuleType) =>\n        `${msg}\\n * ${linkedModule.name}`,\n      `Linked ${msgModule}:`\n    );\n    log(boxen(linkedMsg, {dimBorder: true, padding: 1}), 'warn');\n  }\n};\n\nexport const updateTemplateName = (filePath: string, replace: string, replaceCaps: string) => {\n  let data: string = readFileSync(filePath, 'utf8');\n  data = data.replace(/sample/g, replace);\n  data = data.replace(/Sample/g, replaceCaps);\n  writeFileSync(filePath, data, 'utf8');\n};"],
  "mappings": "AAKA,OAAO,WAAW;AAClB,SAAQ,UAAU,YAAY,WAAW,WAAW,aAAa,cAAc,qBAAoB;AACnG,SAAQ,QAAQ,gBAAe;AAC/B,OAAO,aAAa;AACpB,OAAO,SAAS;AAChB,SAAQ,YAAY,cAAc,QAAQ,UAAU,YAAY,cAAc,WAAW,mBAAkB;AAC3G,SAAQ,kBAAiB;AAGzB,SAAQ,WAAU;AAKX,MAAM,MAAc,QAAQ,IAAI;AAkBhC,MAAM,eAAe,CAAC,UAAqD;AAChF,QAAM,EAAC,UAAU,SAAS,MAAM,OAAO,MAAM,cAAa,IAAI;AAE9D,MAAI;AACJ,QAAM,YAAsB,CAAC,UAAU,OAAO;AAE9C,MAAG,CAAC,MAAM;AACR,QAAG,UAAU,SAAS,IAAI,GAAG;AAC3B,UAAI;AAAA,EAAK,OAAO,WAAW,IAAI,uDAAuD,SAAS,KAAK;AACpG,aAAO,WAAW,CAAC;AAAA,IACrB;AAAA,EACF,OAAO;AACL,eAAW,GAAG,KAAK,OAAO,CAAC,EAAE,YAAY,CAAC,GAAG,KAAK,OAAO,CAAC,CAAC;AAAA,EAC7D;AAEA,MAAI,GAAG,OAAO,WAAW,IAAI,IAAI,IAAI,OAAO,QAAQ,KAAK;AAEzD,MAAI;AACJ,MAAI;AACJ,MAAI;AAEJ,MAAG,eAAe;AAChB,mBAAe;AACf,kBAAc;AACd,oBAAgB;AAAA,EAClB,OAAO;AACL,mBAAe;AACf,kBAAc;AACd,oBAAgB;AAAA,EAClB;AAEA,SAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF;AACF;AAQO,MAAM,gBAAgB,CAAC,QAAQ,UAAmB;AACvD,MAAG,OAAO;AACR,WAAO;AAAA,MACL,MAAM,MAAM;AAAA,MAAC;AAAA,MACb,OAAO,MAAM;AAAA,MAAC;AAAA,MACd,SAAS,MAAM;AAAA,MAAC;AAAA,IAClB;AAAA,EACF;AAEA,SAAO,IAAI,EAAC,OAAO,SAAQ,CAAC;AAC9B;AAEO,MAAM,YAAY,OAAO,OAAiB,UAAkB,SAAS,WAA0B;AACpG,QAAM,EAAC,gBAAgB,eAAc,IAAI;AACzC,QAAM,QAAQ,MAAM,IAAI,CAAC,cAAsB;AAAA,IAC7C,MAAM;AAAA,IACN,IAAI,YAAY,gBAAgB,aAAa,gBAAgB,QAAQ,CAAC;AAAA,EACxE,EAAE;AAEF,MAAI;AACF,YAAQ,MAAM,WAAW,QAAQ,WAAW;AAC5C,UAAM,QAAQ,IAAI,MAAM,IAAI,CAAC,EAAC,MAAM,GAAE,MAAM,IAAI;AAAA,MAC9C,CAAC,SAAS,WAAW;AACnB,kBAAU,YAAY,IAAI,IAAI,GAAG,EAAC,WAAW,KAAI,CAAC;AAClD,eAAO,SAAS,MAAM,IAAI,CAAC,cAAc;AACvC,cAAG,WAAW;AACZ,mBAAO;AAAA,UACT,OAAO;AACL,oBAAQ,IAAI;AAAA,UACd;AAAA,QACF,CAAC;AAAA,MACH;AAAA,IACF,CAAC,CAAC;AACF,YAAQ,QAAQ,uBAAuB,MAAM,MAAM,IAAI,QAAQ,SAAS;AAAA,EAC1E,SAAQ,OAAO;AACb,YAAQ,KAAK,cAAc,QAAQ,gBAAgB;AACnD,QAAI,UAAU,MAAM,OAAO,IAAI,OAAO;AACtC,QAAI,OAAO,OAAO;AAAA,EACpB;AACF;AAEO,MAAM,sBAAsB,OAAO,SAAS,QAAuB,UAAmB;AAC3F,QAAM,EAAC,WAAW,iBAAiB,gBAAgB,gBAAgB,WAAU,IAAI;AACjF,MAAG,CAAC,mBAAmB,gBAAgB,WAAW,GAAG;AACnD;AAAA,EACF;AAEA,MAAI;AACF,YAAQ,MAAM,6BAA6B;AAC3C,QAAI,cAAc;AAElB,UAAM,UAAU,mBAAmB,aAAa,YAAY,KAAK,UAAU,IAAI;AAE/E,eAAU,WAAW,iBAAiB;AACpC,YAAM,kBAAkB,YAAY,SAAS,OAAO;AACpD,YAAM,gBAAgB,SAAS,iBAAiB;AAAA,QAC9C,OAAO;AAAA,QACP,UAAU;AAAA,MACZ,CAAC;AACD,UAAG,cAAc,WAAW,GAAG;AAC7B,YAAG,CAAC,OAAO;AACT,cAAI,6CAA6C,OAAO,IAAI,QAAQ,KAAK;AAAA,QAC3E;AACA;AAAA,MACF;AAEA,iBAAU,cAAc,eAAe;AAErC,cAAM,eAAe,aAAa,SAAS,UAAU;AAErD,cAAM,WAAW,YAAY,gBAAgB,YAAY;AAEzD,cAAM,UAAU,YAAY,UAAU,IAAI;AAC1C,kBAAU,SAAS,EAAC,WAAW,KAAI,CAAC;AAEpC,cAAM,IAAI,QAAQ,CAAC,SAAS,WAAW;AACrC,mBAAS,YAAY,UAAU,CAAC,cAAc;AAC5C,gBAAG,WAAW;AACZ,qBAAO,SAAS;AAAA,YAClB,OAAO;AACL,sBAAQ,IAAI;AAAA,YACd;AAAA,UACF,CAAC;AAAA,QACH,CAAC;AACD;AAAA,MACF;AAAA,IACF;AACA,QAAG,cAAc,GAAG;AAClB,cAAQ,QAAQ,uBAAuB,WAAW,oBAAoB;AAAA,IACxE,OAAO;AACL,cAAQ,QAAQ,6BAA6B;AAAA,IAC/C;AAAA,EACF,SAAQ,OAAO;AACb,YAAQ,KAAK,iCAAiC;AAC9C,QAAI,mCAAmC,MAAM,OAAO,IAAI,SAAS,KAAK;AACtE,UAAM;AAAA,EACR;AACF;AAEO,MAAM,eAAe,CAAC,QAAgB,WAAmB;AAC9D,MAAI,aAAqB;AAEzB,MAAG,WAAW,MAAM,GAAG;AACrB,QAAG,UAAU,MAAM,EAAE,YAAY,GAAG;AAClC,mBAAa,SAAS,QAAQ,aAAa,MAAM,CAAC;AAAA,IACpD;AAAA,EACF;AAEA,gBAAc,YAAY,aAAa,MAAM,CAAC;AAChD;AAEO,MAAM,0BAA0B,CAAC,QAAgB,WAAyB;AAC/E,MAAI,QAAkB,CAAC;AAEvB,QAAM,eAAuB,SAAS,QAAQ,aAAa,MAAM,CAAC;AAElE,MAAG,CAAC,WAAW,YAAY,GAAG;AAC5B,cAAU,YAAY;AAAA,EACxB;AAEA,MAAG,UAAU,MAAM,EAAE,YAAY,GAAG;AAClC,YAAQ,YAAY,MAAM;AAC1B,UAAM,QAAQ,CAAC,SAAiB;AAC9B,YAAM,YAAoB,SAAS,QAAQ,IAAI;AAE/C,UAAG,UAAU,SAAS,EAAE,YAAY,GAAG;AACrC,gCAAwB,WAAW,YAAY;AAAA,MACjD,OAAO;AACL,qBAAa,WAAW,YAAY;AAAA,MACtC;AAAA,IACF,CAAC;AAAA,EACH;AACF;AAEO,MAAM,iBAAiB,CAAC,gBAAyB;AACtD,QAAM,aAAqB,eAAe,GAAG,QAAQ,IAAI,CAAC;AAE1D,QAAM,cAAsB,aAAa,UAAU,EAAE,SAAS;AAC9D,SAAO,KAAK,MAAM,WAAW;AAC/B;AAEO,MAAM,gBAAgB,CAAC,KAAa,WAAoC;AAC7E,QAAM,EAAC,eAAc,IAAI;AACzB,SAAO,SAAS,GAAG,cAAc,SAAS,GAAG,EAAE;AACjD;AAEO,MAAM,wBAAwB,CAAC,eAAuB;AAC3D,QAAM,cAAsB,EAAC,GAAG,WAAU;AAE1C,SAAO,KAAK,WAAW,EAAE,QAAQ,CAAC,eAAuB;AACvD,UAAM,QAAgB,IAAI,OAAO,oCAAoC,IAAI;AACzE,QAAG,MAAM,KAAK,UAAU,GAAG;AACzB,aAAO,YAAY,UAAU;AAAA,IAC/B;AAAA,EACF,CAAC;AAED,SAAO;AACT;AAEO,MAAM,cAAc,CAAC,UAAkB,aAAsB,UAAU,IAAI,QAAQ,CAAC,SAAS,WAAW;AAC7G,QAAM,WAAmB,aAAa,YAAY,KAAK,QAAQ,IAAI;AACnE,MAAI;AACF,eAAW,QAAQ;AACnB,WAAO,QAAQ,IAAI;AAAA,EACrB,SAAQ,OAAO;AACb,WAAO,OAAO,KAAK;AAAA,EACrB;AACF,CAAC;AAEM,MAAM,gBAAgB,MAAM,IAAI,QAAQ,OAAO,SAAS,WAAW;AACxE,MAAI;AAEF,UAAM,YAAY,kBAAkB,IAAI;AAGxC,UAAM,YAAY,eAAe,IAAI;AAGrC,UAAM,YAAY,uBAAuB,IAAI;AAE7C,YAAQ,IAAI;AAAA,EACd,SAAQ,OAAO;AACb,WAAO,KAAK;AAAA,EACd;AACF,CAAC;AAEM,MAAM,iBAAiB,CAAC,MAAM,gBAAyB;AAC5D,MAAG,CAAC,MAAM;AACR;AAAA,EACF;AAEA,QAAM,aAAqB,eAAe,GAAG,QAAQ,IAAI,CAAC;AAE1D,gBAAc,YAAY,KAAK,UAAU,MAAM,MAAM,CAAC,CAAC;AACzD;AAOO,MAAM,gBAAgB,CAAC,cAA2C;AACvE,QAAM,cAAsB,aAAa,QAAQ,IAAI;AACrD,MAAI;AACJ,MAAI;AAEJ,MAAG,YAAY,SAAS,GAAG,GAAG;AAC5B,aAAS,IAAI,YAAY,MAAM,GAAG,EAAE,IAAI,CAAC;AACzC,iBAAa;AAAA,EACf,OAAO;AACL,iBAAa,SAAS,aAAa,cAAc;AAAA,EACnD;AAEA,QAAM,aAAuB,SAAS,GAAG,UAAU,IAAI;AACvD,SAAO,WAAW,OAAO,CAAC,MAA0B,cAAsB;AACxE,QAAI;AACF,YAAM,QAAQ,UAAU,SAAS;AAEjC,UAAG,MAAM,YAAY,GAAG;AACtB,cAAM,WAA+B,cAAc,SAAS;AAC5D,aAAK,KAAK,GAAG,QAAQ;AAAA,MACvB,WAAU,MAAM,eAAe,GAAG;AAChC,cAAM,cAAyB,CAAC,QAAQ,aAAa,SAAS,CAAC,EAAG,OAAO,CAAC,SAAiB,CAAC,QAAQ,IAAI,CAAC;AACzG,aAAK,KAAK,EAAC,MAAM,GAAG,YAAY,KAAK,GAAG,CAAC,IAAI,MAAM,UAAS,CAAC;AAAA,MAC/D;AAEA,aAAO;AAAA,IACT,SAAQ,SAAS;AAEf,aAAO;AAAA,IACT;AAAA,EACF,GAAG,CAAC,CAAC;AACP;AAEO,MAAM,qBAAqB,MAAM;AACtC,QAAM,SAAS,cAAc;AAE7B,MAAG,OAAO,QAAQ;AAChB,UAAM,YAAoB,OAAO,SAAS,IAAI,YAAY;AAC1D,UAAM,YAAoB,OAAO;AAAA,MAC/B,CAAC,KAAa,iBACZ,GAAG,GAAG;AAAA,KAAQ,aAAa,IAAI;AAAA,MACjC,UAAU,SAAS;AAAA,IACrB;AACA,QAAI,MAAM,WAAW,EAAC,WAAW,MAAM,SAAS,EAAC,CAAC,GAAG,MAAM;AAAA,EAC7D;AACF;AAEO,MAAM,qBAAqB,CAAC,UAAkB,SAAiB,gBAAwB;AAC5F,MAAI,OAAe,aAAa,UAAU,MAAM;AAChD,SAAO,KAAK,QAAQ,WAAW,OAAO;AACtC,SAAO,KAAK,QAAQ,WAAW,WAAW;AAC1C,gBAAc,UAAU,MAAM,MAAM;AACtC;",
  "names": []
}

|
package/dist/utils/deepMerge.js
DELETED
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
const deepMerge = (target, source) => {
|
|
2
|
-
if (!source) return target;
|
|
3
|
-
const result = { ...target };
|
|
4
|
-
for (const key in source) {
|
|
5
|
-
if (source.hasOwnProperty(key)) {
|
|
6
|
-
if (source[key] && typeof source[key] === "object" && !Array.isArray(source[key])) {
|
|
7
|
-
result[key] = deepMerge(target[key] || {}, source[key]);
|
|
8
|
-
} else if (Array.isArray(source[key])) {
|
|
9
|
-
if (Array.isArray(target[key])) {
|
|
10
|
-
result[key] = [...target[key], ...source[key]];
|
|
11
|
-
} else {
|
|
12
|
-
result[key] = [...source[key]];
|
|
13
|
-
}
|
|
14
|
-
} else {
|
|
15
|
-
result[key] = source[key];
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
return result;
|
|
20
|
-
};
|
|
21
|
-
export {
|
|
22
|
-
deepMerge
|
|
23
|
-
};
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL3V0aWxzL2RlZXBNZXJnZS50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTgtUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cblxuLyoqXG4gKiBEZWVwIG1lcmdlIGZ1bmN0aW9uIHRoYXQgcmVjdXJzaXZlbHkgbWVyZ2VzIG9iamVjdHMgYW5kIGFycmF5c1xuICogQHBhcmFtIHRhcmdldCAtIFRoZSB0YXJnZXQgb2JqZWN0IHRvIG1lcmdlIGludG9cbiAqIEBwYXJhbSBzb3VyY2UgLSBUaGUgc291cmNlIG9iamVjdCB0byBtZXJnZSBmcm9tXG4gKiBAcmV0dXJucyBUaGUgbWVyZ2VkIG9iamVjdFxuICovXG5leHBvcnQgY29uc3QgZGVlcE1lcmdlID0gKHRhcmdldDogYW55LCBzb3VyY2U6IGFueSk6IGFueSA9PiB7XG4gIGlmKCFzb3VyY2UpIHJldHVybiB0YXJnZXQ7XG5cbiAgY29uc3QgcmVzdWx0ID0gey4uLnRhcmdldH07XG5cbiAgZm9yKGNvbnN0IGtleSBpbiBzb3VyY2UpIHtcbiAgICBpZihzb3VyY2UuaGFzT3duUHJvcGVydHkoa2V5KSkge1xuICAgICAgaWYoc291cmNlW2tleV0gJiYgdHlwZW9mIHNvdXJjZVtrZXldID09PSAnb2JqZWN0JyAmJiAhQXJyYXkuaXNBcnJheShzb3VyY2Vba2V5XSkpIHtcbiAgICAgICAgcmVzdWx0W2tleV0gPSBkZWVwTWVyZ2UodGFyZ2V0W2tleV0gfHwge30sIHNvdXJjZVtrZXldKTtcbiAgICAgIH0gZWxzZSBpZihBcnJheS5pc0FycmF5KHNvdXJjZVtrZXldKSkge1xuICAgICAgICAvLyBGb3IgYXJyYXlzLCBtZXJnZSBpZiBib3RoIGFyZSBhcnJheXMsIG90aGVyd2lzZSByZXBsYWNlXG4gICAgICAgIGlmKEFycmF5LmlzQXJyYXkodGFyZ2V0W2tleV0pKSB7XG4gICAgICAgICAgcmVzdWx0W2tleV0gPSBbLi4udGFyZ2V0W2tleV0sIC4uLnNvdXJjZVtrZXldXTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICByZXN1bHRba2V5XSA9IFsuLi5zb3VyY2Vba2V5XV07XG4gICAgICAgIH1cbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHJlc3VsdFtrZXldID0gc291cmNlW2tleV07XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIHJlc3VsdDtcbn07Il0sCiAgIm1hcHBpbmdzIjogIkFBV08sTUFBTSxZQUFZLENBQUMsUUFBYSxXQUFxQjtBQUMxRCxNQUFHLENBQUMsT0FBUSxRQUFPO0FBRW5CLFFBQU0sU0FBUyxFQUFDLEdBQUcsT0FBTTtBQUV6QixhQUFVLE9BQU8sUUFBUTtBQUN2QixRQUFHLE9BQU8sZUFBZSxHQUFHLEdBQUc7QUFDN0IsVUFBRyxPQUFPLEdBQUcsS0FBSyxPQUFPLE9BQU8sR0FBRyxNQUFNLFlBQVksQ0FBQyxNQUFNLFFBQVEsT0FBTyxHQUFHLENBQUMsR0FBRztBQUNoRixlQUFPLEdBQUcsSUFBSSxVQUFVLE9BQU8sR0FBRyxLQUFLLENBQUMsR0FBRyxPQUFPLEdBQUcsQ0FBQztBQUFBLE1BQ3hELFdBQVUsTUFBTSxRQUFRLE9BQU8sR0FBRyxDQUFDLEdBQUc7QUFFcEMsWUFBRyxNQUFNLFFBQVEsT0FBTyxHQUFHLENBQUMsR0FBRztBQUM3QixpQkFBTyxHQUFHLElBQUksQ0FBQyxHQUFHLE9BQU8sR0FBRyxHQUFHLEdBQUcsT0FBTyxHQUFHLENBQUM7QUFBQSxRQUMvQyxPQUFPO0FBQ0wsaUJBQU8sR0FBRyxJQUFJLENBQUMsR0FBRyxPQUFPLEdBQUcsQ0FBQztBQUFBLFFBQy9CO0FBQUEsTUFDRixPQUFPO0FBQ0wsZUFBTyxHQUFHLElBQUksT0FBTyxHQUFHO0FBQUEsTUFDMUI7QUFBQSxJQUNGO0FBQUEsRUFDRjtBQUVBLFNBQU87QUFDVDsiLAogICJuYW1lcyI6IFtdCn0K
|
package/dist/utils/file.js
DELETED
|
@@ -1,185 +0,0 @@
|
|
|
1
|
-
import findFileUp from "find-file-up";
|
|
2
|
-
import { existsSync, readFileSync } from "fs";
|
|
3
|
-
import { sync as globSync } from "glob";
|
|
4
|
-
import { resolve as pathResolve, dirname } from "path";
|
|
5
|
-
import { LexConfig } from "../LexConfig.js";
|
|
6
|
-
function getDirName() {
|
|
7
|
-
try {
|
|
8
|
-
return eval('new URL(".", import.meta.url).pathname');
|
|
9
|
-
} catch {
|
|
10
|
-
return process.cwd();
|
|
11
|
-
}
|
|
12
|
-
}
|
|
13
|
-
function getFilePath(relativePath) {
|
|
14
|
-
try {
|
|
15
|
-
return eval('require("url").fileURLToPath(new URL(relativePath, import.meta.url))');
|
|
16
|
-
} catch {
|
|
17
|
-
if (relativePath === "../../../package.json") {
|
|
18
|
-
return pathResolve(process.cwd(), "package.json");
|
|
19
|
-
}
|
|
20
|
-
return pathResolve(process.cwd(), relativePath);
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
|
-
function getLexPackageJsonPath() {
|
|
24
|
-
const LEX_PACKAGE_NAME = "@nlabs/lex";
|
|
25
|
-
const lexInNodeModules = pathResolve(process.cwd(), "node_modules/@nlabs/lex/package.json");
|
|
26
|
-
if (existsSync(lexInNodeModules)) {
|
|
27
|
-
return lexInNodeModules;
|
|
28
|
-
}
|
|
29
|
-
let startDir;
|
|
30
|
-
if (process.env.LEX_ROOT) {
|
|
31
|
-
startDir = process.env.LEX_ROOT;
|
|
32
|
-
} else {
|
|
33
|
-
try {
|
|
34
|
-
startDir = eval('new URL(".", import.meta.url).pathname');
|
|
35
|
-
} catch (err1) {
|
|
36
|
-
try {
|
|
37
|
-
startDir = eval('__filename ? require("path").dirname(__filename) : null');
|
|
38
|
-
if (!startDir) {
|
|
39
|
-
throw new Error("__filename not available");
|
|
40
|
-
}
|
|
41
|
-
} catch (err2) {
|
|
42
|
-
try {
|
|
43
|
-
if (process.argv[1] && !process.argv[1].includes("node")) {
|
|
44
|
-
startDir = dirname(process.argv[1]);
|
|
45
|
-
} else {
|
|
46
|
-
throw new Error("process.argv[1] not suitable");
|
|
47
|
-
}
|
|
48
|
-
} catch (err3) {
|
|
49
|
-
startDir = process.cwd();
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
let dir = startDir;
|
|
55
|
-
for (let i = 0; i < 8; i++) {
|
|
56
|
-
const pkgPath = pathResolve(dir, "package.json");
|
|
57
|
-
if (existsSync(pkgPath)) {
|
|
58
|
-
try {
|
|
59
|
-
const pkg = JSON.parse(readFileSync(pkgPath, "utf8"));
|
|
60
|
-
if (pkg.name === LEX_PACKAGE_NAME) {
|
|
61
|
-
return pkgPath;
|
|
62
|
-
}
|
|
63
|
-
} catch (error) {
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
const parent = dirname(dir);
|
|
67
|
-
if (parent === dir) {
|
|
68
|
-
break;
|
|
69
|
-
}
|
|
70
|
-
dir = parent;
|
|
71
|
-
}
|
|
72
|
-
return pathResolve(process.cwd(), "package.json");
|
|
73
|
-
}
|
|
74
|
-
const relativeFilePath = (filename, dirPath = "./", backUp = 0) => {
|
|
75
|
-
const nestDepth = 10;
|
|
76
|
-
if (backUp) {
|
|
77
|
-
const filePath = findFileUp.sync(filename, dirPath, nestDepth);
|
|
78
|
-
const previousPath = Array(backUp).fill(null).map(() => "../").join("");
|
|
79
|
-
return pathResolve(filePath, previousPath);
|
|
80
|
-
}
|
|
81
|
-
return findFileUp.sync(filename, dirPath, nestDepth);
|
|
82
|
-
};
|
|
83
|
-
const relativeNodePath = (filename, dirPath = "./", backUp = 0) => {
|
|
84
|
-
const nestDepth = 10;
|
|
85
|
-
const modulePath = `node_modules/${filename}`;
|
|
86
|
-
if (dirPath !== "./") {
|
|
87
|
-
const lexModulePath = pathResolve(dirPath, modulePath);
|
|
88
|
-
if (existsSync(lexModulePath)) {
|
|
89
|
-
return lexModulePath;
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
const projectPath = pathResolve(process.cwd(), modulePath);
|
|
93
|
-
if (existsSync(projectPath)) {
|
|
94
|
-
return projectPath;
|
|
95
|
-
}
|
|
96
|
-
if (backUp) {
|
|
97
|
-
const filePath = findFileUp.sync(modulePath, dirPath, nestDepth);
|
|
98
|
-
const previousPath = Array(nestDepth).fill(null).map(() => "../").join("");
|
|
99
|
-
return pathResolve(filePath, previousPath);
|
|
100
|
-
}
|
|
101
|
-
return findFileUp.sync(modulePath, dirPath, nestDepth) || `/node_modules/${filename}`;
|
|
102
|
-
};
|
|
103
|
-
const getNodePath = (moduleName) => {
|
|
104
|
-
const dirName = getDirName();
|
|
105
|
-
const modulePath = `node_modules/${moduleName}`;
|
|
106
|
-
const projectPath = pathResolve(process.cwd(), modulePath);
|
|
107
|
-
if (existsSync(projectPath)) {
|
|
108
|
-
return projectPath;
|
|
109
|
-
}
|
|
110
|
-
const repoPath = findFileUp.sync(modulePath, dirName);
|
|
111
|
-
if (repoPath && existsSync(repoPath)) {
|
|
112
|
-
return repoPath;
|
|
113
|
-
}
|
|
114
|
-
const localPath = findFileUp.sync(modulePath, "./", 10) || `./${modulePath}`;
|
|
115
|
-
return localPath;
|
|
116
|
-
};
|
|
117
|
-
const resolveBinaryPath = (binaryName, packageName) => {
|
|
118
|
-
const lexDir = LexConfig.getLexDir();
|
|
119
|
-
const lexBinPath = pathResolve(lexDir, `node_modules/.bin/${binaryName}`);
|
|
120
|
-
if (existsSync(lexBinPath)) {
|
|
121
|
-
return lexBinPath;
|
|
122
|
-
}
|
|
123
|
-
if (packageName) {
|
|
124
|
-
const lexPackageBinPath = pathResolve(lexDir, `node_modules/${packageName}/bin/${binaryName}`);
|
|
125
|
-
if (existsSync(lexPackageBinPath)) {
|
|
126
|
-
return lexPackageBinPath;
|
|
127
|
-
}
|
|
128
|
-
const lexPackageBinJsPath = pathResolve(lexDir, `node_modules/${packageName}/bin/${binaryName}.js`);
|
|
129
|
-
if (existsSync(lexPackageBinJsPath)) {
|
|
130
|
-
return lexPackageBinJsPath;
|
|
131
|
-
}
|
|
132
|
-
const lexPackageBinCjsPath = pathResolve(lexDir, `node_modules/${packageName}/bin/${binaryName}.cjs`);
|
|
133
|
-
if (existsSync(lexPackageBinCjsPath)) {
|
|
134
|
-
return lexPackageBinCjsPath;
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
const checkBinUp = (startDir2) => {
|
|
138
|
-
let checkDir = startDir2;
|
|
139
|
-
for (let i = 0; i < 5; i++) {
|
|
140
|
-
const monorepoBinPath = pathResolve(checkDir, `node_modules/.bin/${binaryName}`);
|
|
141
|
-
if (existsSync(monorepoBinPath)) {
|
|
142
|
-
return monorepoBinPath;
|
|
143
|
-
}
|
|
144
|
-
const parentDir = pathResolve(checkDir, "..");
|
|
145
|
-
if (parentDir === checkDir) {
|
|
146
|
-
break;
|
|
147
|
-
}
|
|
148
|
-
checkDir = parentDir;
|
|
149
|
-
}
|
|
150
|
-
return "";
|
|
151
|
-
};
|
|
152
|
-
const fromCwd = checkBinUp(process.cwd());
|
|
153
|
-
if (fromCwd) {
|
|
154
|
-
return fromCwd;
|
|
155
|
-
}
|
|
156
|
-
const fromLex = checkBinUp(lexDir);
|
|
157
|
-
if (fromLex) {
|
|
158
|
-
return fromLex;
|
|
159
|
-
}
|
|
160
|
-
return "";
|
|
161
|
-
};
|
|
162
|
-
const findTailwindCssPath = () => {
|
|
163
|
-
const tailwindPatterns = ["**/tailwind.css"];
|
|
164
|
-
for (const pattern of tailwindPatterns) {
|
|
165
|
-
const files = globSync(pattern, {
|
|
166
|
-
cwd: process.cwd(),
|
|
167
|
-
ignore: ["**/node_modules/**", "**/dist/**", "**/build/**", "**/.storybook/**"]
|
|
168
|
-
});
|
|
169
|
-
if (files.length > 0) {
|
|
170
|
-
return pathResolve(process.cwd(), files[0]);
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
return "";
|
|
174
|
-
};
|
|
175
|
-
export {
|
|
176
|
-
findTailwindCssPath,
|
|
177
|
-
getDirName,
|
|
178
|
-
getFilePath,
|
|
179
|
-
getLexPackageJsonPath,
|
|
180
|
-
getNodePath,
|
|
181
|
-
relativeFilePath,
|
|
182
|
-
relativeNodePath,
|
|
183
|
-
resolveBinaryPath
|
|
184
|
-
};
|
|
185
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/utils/file.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 findFileUp from 'find-file-up';\nimport {existsSync, readFileSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport {resolve as pathResolve, dirname} from 'path';\n\nimport {LexConfig} from '../LexConfig.js';\n\nexport function getDirName(): string {\n  try {\n    return eval('new URL(\".\", import.meta.url).pathname');\n  } catch{\n    return process.cwd();\n  }\n}\n\nexport function getFilePath(relativePath: string): string {\n  try {\n    return eval('require(\"url\").fileURLToPath(new URL(relativePath, import.meta.url))');\n  } catch{\n    if(relativePath === '../../../package.json') {\n      return pathResolve(process.cwd(), 'package.json');\n    }\n    return pathResolve(process.cwd(), relativePath);\n  }\n}\n\nexport function getLexPackageJsonPath(): string {\n  const LEX_PACKAGE_NAME = '@nlabs/lex';\n\n  const lexInNodeModules = pathResolve(process.cwd(), 'node_modules/@nlabs/lex/package.json');\n\n  if(existsSync(lexInNodeModules)) {\n    return lexInNodeModules;\n  }\n\n  let startDir: string;\n\n  if(process.env.LEX_ROOT) {\n    startDir = process.env.LEX_ROOT;\n  } else {\n    try {\n      startDir = eval('new URL(\".\", import.meta.url).pathname');\n    } catch(err1) {\n      try {\n        startDir = eval('__filename ? require(\"path\").dirname(__filename) : null');\n        if(!startDir) {\n          throw new Error('__filename not available');\n        }\n      } catch(err2) {\n        try {\n          if(process.argv[1] && !process.argv[1].includes('node')) {\n            startDir = dirname(process.argv[1]);\n          } else {\n            throw new Error('process.argv[1] not suitable');\n          }\n        } catch(err3) {\n          startDir = process.cwd();\n        }\n      }\n    }\n  }\n\n  let dir = startDir;\n  for(let i = 0; i < 8; i++) {\n    const pkgPath = pathResolve(dir, 'package.json');\n    if(existsSync(pkgPath)) {\n      try {\n        const pkg = JSON.parse(readFileSync(pkgPath, 'utf8'));\n        if(pkg.name === LEX_PACKAGE_NAME) {\n          return pkgPath;\n        }\n      } catch(error) {\n      }\n    }\n    const parent = dirname(dir);\n    if(parent === dir) {\n      break;\n    }\n    dir = parent;\n  }\n\n  return pathResolve(process.cwd(), 'package.json');\n}\n\nexport const relativeFilePath = (filename: string, dirPath: string = './', backUp: number = 0): string => {\n  const nestDepth: number = 10;\n\n  if(backUp) {\n    const filePath: string = findFileUp.sync(filename, dirPath, nestDepth);\n    const previousPath: string = Array(backUp).fill(null).map(() => '../').join('');\n    return pathResolve(filePath, previousPath);\n  }\n\n  return findFileUp.sync(filename, dirPath, nestDepth);\n};\n\nexport const relativeNodePath = (filename: string, dirPath: string = './', backUp: number = 0): string => {\n  const nestDepth: number = 10;\n  const modulePath = `node_modules/${filename}`;\n\n  if(dirPath !== './') {\n    const lexModulePath = pathResolve(dirPath, modulePath);\n    if(existsSync(lexModulePath)) {\n      return lexModulePath;\n    }\n  }\n\n  const projectPath = pathResolve(process.cwd(), modulePath);\n  if(existsSync(projectPath)) {\n    return projectPath;\n  }\n\n  if(backUp) {\n    const filePath: string = findFileUp.sync(modulePath, dirPath, nestDepth);\n    const previousPath: string = Array(nestDepth).fill(null).map(() => '../').join('');\n    return pathResolve(filePath, previousPath);\n  }\n\n  return findFileUp.sync(modulePath, dirPath, nestDepth) || `/node_modules/${filename}`;\n};\n\nexport const getNodePath = (moduleName: string): string => {\n  const dirName = getDirName();\n  const modulePath: string = `node_modules/${moduleName}`;\n\n  const projectPath = pathResolve(process.cwd(), modulePath);\n  if(existsSync(projectPath)) {\n    return projectPath;\n  }\n\n  const repoPath: string = findFileUp.sync(modulePath, dirName);\n  if(repoPath && existsSync(repoPath)) {\n    return repoPath;\n  }\n\n  const localPath: string = findFileUp.sync(modulePath, './', 10) || `./${modulePath}`;\n  return localPath;\n};\n\nexport const resolveBinaryPath = (binaryName: string, packageName?: string): string => {\n  const lexDir = LexConfig.getLexDir();\n\n  const lexBinPath = pathResolve(lexDir, `node_modules/.bin/${binaryName}`);\n  if(existsSync(lexBinPath)) {\n    return lexBinPath;\n  }\n\n  if(packageName) {\n    const lexPackageBinPath = pathResolve(lexDir, `node_modules/${packageName}/bin/${binaryName}`);\n    if(existsSync(lexPackageBinPath)) {\n      return lexPackageBinPath;\n    }\n\n    const lexPackageBinJsPath = pathResolve(lexDir, `node_modules/${packageName}/bin/${binaryName}.js`);\n    if(existsSync(lexPackageBinJsPath)) {\n      return lexPackageBinJsPath;\n    }\n\n    const lexPackageBinCjsPath = pathResolve(lexDir, `node_modules/${packageName}/bin/${binaryName}.cjs`);\n    if(existsSync(lexPackageBinCjsPath)) {\n      return lexPackageBinCjsPath;\n    }\n  }\n\n  const checkBinUp = (startDir: string) => {\n    let checkDir = startDir;\n    for(let i = 0; i < 5; i++) {\n      const monorepoBinPath = pathResolve(checkDir, `node_modules/.bin/${binaryName}`);\n      if(existsSync(monorepoBinPath)) {\n        return monorepoBinPath;\n      }\n      const parentDir = pathResolve(checkDir, '..');\n      if(parentDir === checkDir) {\n        break;\n      }\n      checkDir = parentDir;\n    }\n    return '';\n  };\n\n  const fromCwd = checkBinUp(process.cwd());\n  if(fromCwd) {\n    return fromCwd;\n  }\n\n  const fromLex = checkBinUp(lexDir);\n  if(fromLex) {\n    return fromLex;\n  }\n\n  return '';\n};\n\nexport const findTailwindCssPath = (): string => {\n  const tailwindPatterns = ['**/tailwind.css'];\n\n  for(const pattern of tailwindPatterns) {\n    const files = globSync(pattern, {\n      cwd: process.cwd(),\n      ignore: ['**/node_modules/**', '**/dist/**', '**/build/**', '**/.storybook/**']\n    });\n\n    if(files.length > 0) {\n      return pathResolve(process.cwd(), files[0]);\n    }\n  }\n\n  return '';\n};"],
  "mappings": "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",
  "names": ["startDir"]
}

|
package/emptyModule.js
DELETED
|
File without changes
|
package/eslint.config.js
DELETED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
/package/{dist → lib}/lex.d.ts
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
/package/{dist → lib}/types.d.ts
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|