@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
package/dist/commands/create.js
DELETED
|
@@ -1,116 +0,0 @@
|
|
|
1
|
-
import { existsSync, readFileSync, renameSync, writeFileSync } from "fs";
|
|
2
|
-
import { resolve as pathResolve } from "path";
|
|
3
|
-
import { URL } from "url";
|
|
4
|
-
import { createChangelog } from "../create/changelog.js";
|
|
5
|
-
import { LexConfig } from "../LexConfig.js";
|
|
6
|
-
import { copyFolderRecursiveSync, getFilenames, removeFiles, updateTemplateName } from "../utils/app.js";
|
|
7
|
-
import { log } from "../utils/log.js";
|
|
8
|
-
const create = async (type, cmd, callback = () => ({})) => {
|
|
9
|
-
const { cliName = "Lex", outputFile, outputName, quiet } = cmd;
|
|
10
|
-
const cwd = process.cwd();
|
|
11
|
-
log(`${cliName} creating ${type}...`, "info", quiet);
|
|
12
|
-
await LexConfig.parseConfig(cmd, false);
|
|
13
|
-
const { outputPath, sourcePath, useTypescript } = LexConfig.config;
|
|
14
|
-
if (useTypescript) {
|
|
15
|
-
LexConfig.checkTypescriptConfig();
|
|
16
|
-
}
|
|
17
|
-
const { config } = LexConfig;
|
|
18
|
-
const dirName = new URL(".", import.meta.url).pathname;
|
|
19
|
-
switch (type) {
|
|
20
|
-
case "changelog": {
|
|
21
|
-
const statusChangelog = await createChangelog({ cliName, config, outputFile, quiet });
|
|
22
|
-
callback(statusChangelog);
|
|
23
|
-
return statusChangelog;
|
|
24
|
-
}
|
|
25
|
-
case "store": {
|
|
26
|
-
try {
|
|
27
|
-
const { nameCaps, templateExt, templatePath } = getFilenames({
|
|
28
|
-
cliName,
|
|
29
|
-
name: outputName,
|
|
30
|
-
quiet,
|
|
31
|
-
type,
|
|
32
|
-
useTypescript
|
|
33
|
-
});
|
|
34
|
-
const storePath = `${cwd}/${nameCaps}Store`;
|
|
35
|
-
if (!existsSync(storePath)) {
|
|
36
|
-
copyFolderRecursiveSync(pathResolve(dirName, templatePath, "./.SampleStore"), cwd);
|
|
37
|
-
renameSync(`${cwd}/.SampleStore`, storePath);
|
|
38
|
-
const storeTestPath = `${storePath}/${nameCaps}Store.test${templateExt}`;
|
|
39
|
-
renameSync(`${storePath}/SampleStore.test${templateExt}.txt`, storeTestPath);
|
|
40
|
-
updateTemplateName(storeTestPath, outputName, nameCaps);
|
|
41
|
-
const storeFilePath = `${storePath}/${nameCaps}Store${templateExt}`;
|
|
42
|
-
renameSync(`${storePath}/SampleStore${templateExt}.txt`, storeFilePath);
|
|
43
|
-
updateTemplateName(storeFilePath, outputName, nameCaps);
|
|
44
|
-
} else {
|
|
45
|
-
log(`
|
|
46
|
-
${cliName} Error: Cannot create new ${type}. Directory, ${storePath} already exists.`, "error", quiet);
|
|
47
|
-
callback(1);
|
|
48
|
-
return 1;
|
|
49
|
-
}
|
|
50
|
-
} catch (error) {
|
|
51
|
-
log(`
|
|
52
|
-
${cliName} Error: Cannot create new ${type}. ${error.message}`, "error", quiet);
|
|
53
|
-
callback(1);
|
|
54
|
-
return 1;
|
|
55
|
-
}
|
|
56
|
-
break;
|
|
57
|
-
}
|
|
58
|
-
case "tsconfig": {
|
|
59
|
-
await removeFiles("tsconfig.json", true);
|
|
60
|
-
const templatePath = pathResolve(dirName, "../../tsconfig.template.json");
|
|
61
|
-
let data = readFileSync(templatePath, "utf8");
|
|
62
|
-
data = data.replace(/.\/src/g, sourcePath);
|
|
63
|
-
data = data.replace(/.\/dist/g, outputPath);
|
|
64
|
-
const destPath = pathResolve(cwd, "./tsconfig.json");
|
|
65
|
-
writeFileSync(destPath, data, "utf8");
|
|
66
|
-
break;
|
|
67
|
-
}
|
|
68
|
-
case "view": {
|
|
69
|
-
const { nameCaps, templatePath, templateReact } = getFilenames({
|
|
70
|
-
cliName,
|
|
71
|
-
name: outputName,
|
|
72
|
-
quiet,
|
|
73
|
-
type,
|
|
74
|
-
useTypescript
|
|
75
|
-
});
|
|
76
|
-
const viewPath = `${cwd}/${nameCaps}View`;
|
|
77
|
-
try {
|
|
78
|
-
if (!existsSync(viewPath)) {
|
|
79
|
-
copyFolderRecursiveSync(pathResolve(dirName, templatePath, "./.SampleView"), cwd);
|
|
80
|
-
renameSync(`${cwd}/.SampleView`, viewPath);
|
|
81
|
-
const viewStylePath = `${viewPath}/${outputName}View.css`;
|
|
82
|
-
renameSync(`${viewPath}/sampleView.css`, viewStylePath);
|
|
83
|
-
updateTemplateName(viewStylePath, outputName, nameCaps);
|
|
84
|
-
const viewTestPath = `${viewPath}/${nameCaps}View.test${templateReact}`;
|
|
85
|
-
renameSync(`${viewPath}/SampleView.test${templateReact}.txt`, viewTestPath);
|
|
86
|
-
updateTemplateName(viewTestPath, outputName, nameCaps);
|
|
87
|
-
const viewFilePath = `${viewPath}/${nameCaps}View${templateReact}`;
|
|
88
|
-
renameSync(`${viewPath}/SampleView${templateReact}.txt`, viewFilePath);
|
|
89
|
-
updateTemplateName(viewFilePath, outputName, nameCaps);
|
|
90
|
-
} else {
|
|
91
|
-
log(`
|
|
92
|
-
${cliName} Error: Cannot create new ${type}. Directory, ${viewPath} already exists.`, "error", quiet);
|
|
93
|
-
callback(1);
|
|
94
|
-
return 1;
|
|
95
|
-
}
|
|
96
|
-
} catch (error) {
|
|
97
|
-
log(`
|
|
98
|
-
${cliName} Error: Cannot create new ${type}. ${error.message}`, "error", quiet);
|
|
99
|
-
callback(1);
|
|
100
|
-
return 1;
|
|
101
|
-
}
|
|
102
|
-
break;
|
|
103
|
-
}
|
|
104
|
-
case "vscode": {
|
|
105
|
-
await removeFiles(".vscode", true);
|
|
106
|
-
copyFolderRecursiveSync(pathResolve(dirName, "../../.vscode"), cwd);
|
|
107
|
-
break;
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
callback(0);
|
|
111
|
-
return 0;
|
|
112
|
-
};
|
|
113
|
-
export {
|
|
114
|
-
create
|
|
115
|
-
};
|
|
116
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/commands/create.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, renameSync, writeFileSync} from 'fs';\nimport {resolve as pathResolve} from 'path';\nimport {URL} from 'url';\n\nimport {createChangelog} from '../create/changelog.js';\nimport {LexConfig} from '../LexConfig.js';\nimport {copyFolderRecursiveSync, getFilenames, removeFiles, updateTemplateName} from '../utils/app.js';\nimport {log} from '../utils/log.js';\n\nexport const create = async (type: string, cmd: any, callback: any = () => ({})): Promise<number> => {\n  const {cliName = 'Lex', outputFile, outputName, quiet} = cmd;\n  const cwd: string = process.cwd();\n  log(`${cliName} creating ${type}...`, 'info', quiet);\n\n  // Get custom configuration\n  await LexConfig.parseConfig(cmd, false);\n  const {outputPath, sourcePath, useTypescript} = LexConfig.config;\n\n  if(useTypescript) {\n    // Make sure tsconfig.json exists\n    LexConfig.checkTypescriptConfig();\n  }\n\n  const {config} = LexConfig;\n  const dirName = new URL('.', import.meta.url).pathname;\n\n  switch(type) {\n    case 'changelog': {\n      const statusChangelog: number = await createChangelog({cliName, config, outputFile, quiet});\n      callback(statusChangelog);\n      return statusChangelog;\n    }\n    case 'store': {\n      try {\n        const {nameCaps, templateExt, templatePath} = getFilenames({\n          cliName,\n          name: outputName,\n          quiet,\n          type,\n          useTypescript\n        });\n        const storePath: string = `${cwd}/${nameCaps}Store`;\n\n        if(!existsSync(storePath)) {\n          // Copy store files\n          copyFolderRecursiveSync(pathResolve(dirName, templatePath, './.SampleStore'), cwd);\n\n          // Rename directory\n          renameSync(`${cwd}/.SampleStore`, storePath);\n\n          // Rename test\n          const storeTestPath: string = `${storePath}/${nameCaps}Store.test${templateExt}`;\n          renameSync(`${storePath}/SampleStore.test${templateExt}.txt`, storeTestPath);\n\n          // Search and replace store name\n          updateTemplateName(storeTestPath, outputName, nameCaps);\n\n          // Rename source file\n          const storeFilePath: string = `${storePath}/${nameCaps}Store${templateExt}`;\n          renameSync(`${storePath}/SampleStore${templateExt}.txt`, storeFilePath);\n\n          // Search and replace store name\n          updateTemplateName(storeFilePath, outputName, nameCaps);\n        } else {\n          log(`\\n${cliName} Error: Cannot create new ${type}. Directory, ${storePath} already exists.`, 'error', quiet);\n          callback(1);\n          return 1;\n        }\n      } catch(error) {\n        log(`\\n${cliName} Error: Cannot create new ${type}. ${error.message}`, 'error', quiet);\n        callback(1);\n        return 1;\n      }\n      break;\n    }\n    case 'tsconfig': {\n      // Remove existing file\n      await removeFiles('tsconfig.json', true);\n\n      // Get tsconfig template\n      const templatePath: string = pathResolve(dirName, '../../tsconfig.template.json');\n      let data: string = readFileSync(templatePath, 'utf8');\n\n      // Update Lex tsconfig template with source and output directories\n      data = data.replace(/.\\/src/g, sourcePath);\n      data = data.replace(/.\\/dist/g, outputPath);\n\n      // Save new tsconfig to app\n      const destPath: string = pathResolve(cwd, './tsconfig.json');\n      writeFileSync(destPath, data, 'utf8');\n      break;\n    }\n    case 'view': {\n      const {nameCaps, templatePath, templateReact} = getFilenames({\n        cliName,\n        name: outputName,\n        quiet,\n        type,\n        useTypescript\n      });\n      const viewPath: string = `${cwd}/${nameCaps}View`;\n\n      try {\n        if(!existsSync(viewPath)) {\n          // Copy view files\n          copyFolderRecursiveSync(pathResolve(dirName, templatePath, './.SampleView'), cwd);\n\n          // Rename directory\n          renameSync(`${cwd}/.SampleView`, viewPath);\n\n          // Rename CSS\n          const viewStylePath: string = `${viewPath}/${outputName}View.css`;\n          renameSync(`${viewPath}/sampleView.css`, viewStylePath);\n\n          // Search and replace view name\n          updateTemplateName(viewStylePath, outputName, nameCaps);\n\n          // Rename test\n          const viewTestPath: string = `${viewPath}/${nameCaps}View.test${templateReact}`;\n          renameSync(`${viewPath}/SampleView.test${templateReact}.txt`, viewTestPath);\n\n          // Search and replace view name\n          updateTemplateName(viewTestPath, outputName, nameCaps);\n\n          // Rename source file\n          const viewFilePath: string = `${viewPath}/${nameCaps}View${templateReact}`;\n          renameSync(`${viewPath}/SampleView${templateReact}.txt`, viewFilePath);\n\n          // Search and replace view name\n          updateTemplateName(viewFilePath, outputName, nameCaps);\n        } else {\n          log(`\\n${cliName} Error: Cannot create new ${type}. Directory, ${viewPath} already exists.`, 'error', quiet);\n          callback(1);\n          return 1;\n        }\n      } catch(error) {\n        log(`\\n${cliName} Error: Cannot create new ${type}. ${error.message}`, 'error', quiet);\n        callback(1);\n        return 1;\n      }\n      break;\n    }\n    case 'vscode': {\n      // Remove existing directory\n      await removeFiles('.vscode', true);\n\n      // Copy vscode configuration\n      copyFolderRecursiveSync(pathResolve(dirName, '../../.vscode'), cwd);\n      break;\n    }\n  }\n\n  callback(0);\n  return 0;\n};\n"],
  "mappings": "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",
  "names": []
}

|
package/dist/commands/dev.js
DELETED
|
@@ -1,70 +0,0 @@
|
|
|
1
|
-
import { execa } from "execa";
|
|
2
|
-
import { resolve as pathResolve } from "path";
|
|
3
|
-
import { URL } from "url";
|
|
4
|
-
import { LexConfig } from "../LexConfig.js";
|
|
5
|
-
import { createSpinner, removeFiles } from "../utils/app.js";
|
|
6
|
-
import { relativeNodePath } from "../utils/file.js";
|
|
7
|
-
import { log } from "../utils/log.js";
|
|
8
|
-
const dev = async (cmd, callback = () => ({})) => {
|
|
9
|
-
const { bundleAnalyzer, cliName = "Lex", config, open = false, quiet, remove, variables } = cmd;
|
|
10
|
-
const spinner = createSpinner(quiet);
|
|
11
|
-
log(`${cliName} start development server...`, "info", quiet);
|
|
12
|
-
await LexConfig.parseConfig(cmd);
|
|
13
|
-
const { outputFullPath, useTypescript } = LexConfig.config;
|
|
14
|
-
let variablesObj = { NODE_ENV: "development" };
|
|
15
|
-
if (variables) {
|
|
16
|
-
try {
|
|
17
|
-
variablesObj = JSON.parse(variables);
|
|
18
|
-
} catch (error) {
|
|
19
|
-
log(`
|
|
20
|
-
${cliName} Error: Environment variables option is not a valid JSON object.`, "error", quiet);
|
|
21
|
-
callback(1);
|
|
22
|
-
return 1;
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
process.env = { ...process.env, ...variablesObj };
|
|
26
|
-
if (useTypescript) {
|
|
27
|
-
LexConfig.checkTypescriptConfig();
|
|
28
|
-
}
|
|
29
|
-
if (remove) {
|
|
30
|
-
spinner.start("Cleaning output directory...");
|
|
31
|
-
await removeFiles(outputFullPath);
|
|
32
|
-
spinner.succeed("Successfully cleaned output directory!");
|
|
33
|
-
}
|
|
34
|
-
const dirName = new URL(".", import.meta.url).pathname;
|
|
35
|
-
const webpackConfig = config || pathResolve(dirName, "../../webpack.config.js");
|
|
36
|
-
const webpackOptions = [
|
|
37
|
-
"--color",
|
|
38
|
-
"--watch",
|
|
39
|
-
"--config",
|
|
40
|
-
webpackConfig
|
|
41
|
-
];
|
|
42
|
-
if (bundleAnalyzer) {
|
|
43
|
-
webpackOptions.push("--bundleAnalyzer");
|
|
44
|
-
}
|
|
45
|
-
try {
|
|
46
|
-
const dirPath = pathResolve(dirName, "../..");
|
|
47
|
-
const webpackPath = relativeNodePath("webpack-cli/bin/cli.js", dirPath);
|
|
48
|
-
await execa(webpackPath, webpackOptions, {
|
|
49
|
-
encoding: "utf8",
|
|
50
|
-
env: {
|
|
51
|
-
LEX_QUIET: quiet,
|
|
52
|
-
WEBPACK_DEV_OPEN: open
|
|
53
|
-
},
|
|
54
|
-
stdio: "inherit"
|
|
55
|
-
});
|
|
56
|
-
spinner.succeed("Development server started.");
|
|
57
|
-
callback(0);
|
|
58
|
-
return 0;
|
|
59
|
-
} catch (error) {
|
|
60
|
-
log(`
|
|
61
|
-
${cliName} Error: ${error.message}`, "error", quiet);
|
|
62
|
-
spinner.fail("There was an error while running Webpack.");
|
|
63
|
-
callback(1);
|
|
64
|
-
return 1;
|
|
65
|
-
}
|
|
66
|
-
};
|
|
67
|
-
export {
|
|
68
|
-
dev
|
|
69
|
-
};
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2Rldi50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTgtUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmltcG9ydCB7ZXhlY2F9IGZyb20gJ2V4ZWNhJztcbmltcG9ydCB7cmVzb2x2ZSBhcyBwYXRoUmVzb2x2ZX0gZnJvbSAncGF0aCc7XG5pbXBvcnQge1VSTH0gZnJvbSAndXJsJztcblxuaW1wb3J0IHtMZXhDb25maWd9IGZyb20gJy4uL0xleENvbmZpZy5qcyc7XG5pbXBvcnQge2NyZWF0ZVNwaW5uZXIsIHJlbW92ZUZpbGVzfSBmcm9tICcuLi91dGlscy9hcHAuanMnO1xuaW1wb3J0IHtyZWxhdGl2ZU5vZGVQYXRofSBmcm9tICcuLi91dGlscy9maWxlLmpzJztcbmltcG9ydCB7bG9nfSBmcm9tICcuLi91dGlscy9sb2cuanMnO1xuXG5leHBvcnQgY29uc3QgZGV2ID0gYXN5bmMgKGNtZDogYW55LCBjYWxsYmFjazogYW55ID0gKCkgPT4gKHt9KSk6IFByb21pc2U8bnVtYmVyPiA9PiB7XG4gIGNvbnN0IHtidW5kbGVBbmFseXplciwgY2xpTmFtZSA9ICdMZXgnLCBjb25maWcsIG9wZW4gPSBmYWxzZSwgcXVpZXQsIHJlbW92ZSwgdmFyaWFibGVzfSA9IGNtZDtcblxuICAvLyBTcGlubmVyXG4gIGNvbnN0IHNwaW5uZXIgPSBjcmVhdGVTcGlubmVyKHF1aWV0KTtcblxuICAvLyBEaXNwbGF5IHN0YXR1c1xuICBsb2coYCR7Y2xpTmFtZX0gc3RhcnQgZGV2ZWxvcG1lbnQgc2VydmVyLi4uYCwgJ2luZm8nLCBxdWlldCk7XG5cbiAgLy8gR2V0IGN1c3RvbSBjb25maWd1cmF0aW9uXG4gIGF3YWl0IExleENvbmZpZy5wYXJzZUNvbmZpZyhjbWQpO1xuXG4gIGNvbnN0IHtvdXRwdXRGdWxsUGF0aCwgdXNlVHlwZXNjcmlwdH0gPSBMZXhDb25maWcuY29uZmlnO1xuXG4gIC8vIFNldCBub2RlIGVudmlyb25tZW50IHZhcmlhYmxlc1xuICBsZXQgdmFyaWFibGVzT2JqOiBvYmplY3QgPSB7Tk9ERV9FTlY6ICdkZXZlbG9wbWVudCd9O1xuXG4gIGlmKHZhcmlhYmxlcykge1xuICAgIHRyeSB7XG4gICAgICB2YXJpYWJsZXNPYmogPSBKU09OLnBhcnNlKHZhcmlhYmxlcyk7XG4gICAgfSBjYXRjaChlcnJvcikge1xuICAgICAgbG9nKGBcXG4ke2NsaU5hbWV9IEVycm9yOiBFbnZpcm9ubWVudCB2YXJpYWJsZXMgb3B0aW9uIGlzIG5vdCBhIHZhbGlkIEpTT04gb2JqZWN0LmAsICdlcnJvcicsIHF1aWV0KTtcbiAgICAgIGNhbGxiYWNrKDEpO1xuICAgICAgcmV0dXJuIDE7XG4gICAgfVxuICB9XG5cbiAgcHJvY2Vzcy5lbnYgPSB7Li4ucHJvY2Vzcy5lbnYsIC4uLnZhcmlhYmxlc09ian07XG5cbiAgaWYodXNlVHlwZXNjcmlwdCkge1xuICAgIC8vIE1ha2Ugc3VyZSB0c2NvbmZpZy5qc29uIGV4aXN0c1xuICAgIExleENvbmZpZy5jaGVja1R5cGVzY3JpcHRDb25maWcoKTtcbiAgfVxuXG4gIC8vIENsZWFuIG91dHB1dCBkaXJlY3RvcnkgYmVmb3JlIHdlIHN0YXJ0IGFkZGluZyBpbiBuZXcgZmlsZXNcbiAgaWYocmVtb3ZlKSB7XG4gICAgLy8gU3RhcnQgY2xlYW5pbmcgc3Bpbm5lclxuICAgIHNwaW5uZXIuc3RhcnQoJ0NsZWFuaW5nIG91dHB1dCBkaXJlY3RvcnkuLi4nKTtcblxuICAgIC8vIENsZWFuXG4gICAgYXdhaXQgcmVtb3ZlRmlsZXMob3V0cHV0RnVsbFBhdGgpO1xuXG4gICAgLy8gU3RvcCBzcGlubmVyXG4gICAgc3Bpbm5lci5zdWNjZWVkKCdTdWNjZXNzZnVsbHkgY2xlYW5lZCBvdXRwdXQgZGlyZWN0b3J5IScpO1xuICB9XG5cbiAgLy8gR2V0IGN1c3RvbSB3ZWJwYWNrIGNvbmZpZ3VyYXRpb24gZmlsZVxuICBjb25zdCBkaXJOYW1lID0gbmV3IFVSTCgnLicsIGltcG9ydC5tZXRhLnVybCkucGF0aG5hbWU7XG4gIGNvbnN0IHdlYnBhY2tDb25maWc6IHN0cmluZyA9IGNvbmZpZyB8fCBwYXRoUmVzb2x2ZShkaXJOYW1lLCAnLi4vLi4vd2VicGFjay5jb25maWcuanMnKTtcblxuICAvLyBDb21waWxlIHVzaW5nIHdlYnBhY2tcbiAgY29uc3Qgd2VicGFja09wdGlvbnM6IHN0cmluZ1tdID0gW1xuICAgICctLWNvbG9yJyxcbiAgICAnLS13YXRjaCcsXG4gICAgJy0tY29uZmlnJywgd2VicGFja0NvbmZpZ1xuICBdO1xuXG4gIGlmKGJ1bmRsZUFuYWx5emVyKSB7XG4gICAgd2VicGFja09wdGlvbnMucHVzaCgnLS1idW5kbGVBbmFseXplcicpO1xuICB9XG5cbiAgdHJ5IHtcbiAgICBjb25zdCBkaXJQYXRoOiBzdHJpbmcgPSBwYXRoUmVzb2x2ZShkaXJOYW1lLCAnLi4vLi4nKTtcbiAgICBjb25zdCB3ZWJwYWNrUGF0aDogc3RyaW5nID0gcmVsYXRpdmVOb2RlUGF0aCgnd2VicGFjay1jbGkvYmluL2NsaS5qcycsIGRpclBhdGgpO1xuICAgIGF3YWl0IGV4ZWNhKHdlYnBhY2tQYXRoLCB3ZWJwYWNrT3B0aW9ucywge1xuICAgICAgZW5jb2Rpbmc6ICd1dGY4JyxcbiAgICAgIGVudjoge1xuICAgICAgICBMRVhfUVVJRVQ6IHF1aWV0LFxuICAgICAgICBXRUJQQUNLX0RFVl9PUEVOOiBvcGVuXG4gICAgICB9LFxuICAgICAgc3RkaW86ICdpbmhlcml0J1xuICAgIH0pO1xuXG4gICAgLy8gU3RvcCBzcGlubmVyXG4gICAgc3Bpbm5lci5zdWNjZWVkKCdEZXZlbG9wbWVudCBzZXJ2ZXIgc3RhcnRlZC4nKTtcblxuICAgIGNhbGxiYWNrKDApO1xuICAgIHJldHVybiAwO1xuICB9IGNhdGNoKGVycm9yKSB7XG4gICAgLy8gRGlzcGxheSBlcnJvciBtZXNzYWdlXG4gICAgbG9nKGBcXG4ke2NsaU5hbWV9IEVycm9yOiAke2Vycm9yLm1lc3NhZ2V9YCwgJ2Vycm9yJywgcXVpZXQpO1xuXG4gICAgLy8gU3RvcCBzcGlubmVyXG4gICAgc3Bpbm5lci5mYWlsKCdUaGVyZSB3YXMgYW4gZXJyb3Igd2hpbGUgcnVubmluZyBXZWJwYWNrLicpO1xuXG4gICAgLy8gS2lsbCBwcm9jZXNzXG4gICAgY2FsbGJhY2soMSk7XG4gICAgcmV0dXJuIDE7XG4gIH1cbn07XG4iXSwKICAibWFwcGluZ3MiOiAiQUFJQSxTQUFRLGFBQVk7QUFDcEIsU0FBUSxXQUFXLG1CQUFrQjtBQUNyQyxTQUFRLFdBQVU7QUFFbEIsU0FBUSxpQkFBZ0I7QUFDeEIsU0FBUSxlQUFlLG1CQUFrQjtBQUN6QyxTQUFRLHdCQUF1QjtBQUMvQixTQUFRLFdBQVU7QUFFWCxNQUFNLE1BQU0sT0FBTyxLQUFVLFdBQWdCLE9BQU8sQ0FBQyxPQUF3QjtBQUNsRixRQUFNLEVBQUMsZ0JBQWdCLFVBQVUsT0FBTyxRQUFRLE9BQU8sT0FBTyxPQUFPLFFBQVEsVUFBUyxJQUFJO0FBRzFGLFFBQU0sVUFBVSxjQUFjLEtBQUs7QUFHbkMsTUFBSSxHQUFHLE9BQU8sZ0NBQWdDLFFBQVEsS0FBSztBQUczRCxRQUFNLFVBQVUsWUFBWSxHQUFHO0FBRS9CLFFBQU0sRUFBQyxnQkFBZ0IsY0FBYSxJQUFJLFVBQVU7QUFHbEQsTUFBSSxlQUF1QixFQUFDLFVBQVUsY0FBYTtBQUVuRCxNQUFHLFdBQVc7QUFDWixRQUFJO0FBQ0YscUJBQWUsS0FBSyxNQUFNLFNBQVM7QUFBQSxJQUNyQyxTQUFRLE9BQU87QUFDYixVQUFJO0FBQUEsRUFBSyxPQUFPLG9FQUFvRSxTQUFTLEtBQUs7QUFDbEcsZUFBUyxDQUFDO0FBQ1YsYUFBTztBQUFBLElBQ1Q7QUFBQSxFQUNGO0FBRUEsVUFBUSxNQUFNLEVBQUMsR0FBRyxRQUFRLEtBQUssR0FBRyxhQUFZO0FBRTlDLE1BQUcsZUFBZTtBQUVoQixjQUFVLHNCQUFzQjtBQUFBLEVBQ2xDO0FBR0EsTUFBRyxRQUFRO0FBRVQsWUFBUSxNQUFNLDhCQUE4QjtBQUc1QyxVQUFNLFlBQVksY0FBYztBQUdoQyxZQUFRLFFBQVEsd0NBQXdDO0FBQUEsRUFDMUQ7QUFHQSxRQUFNLFVBQVUsSUFBSSxJQUFJLEtBQUssWUFBWSxHQUFHLEVBQUU7QUFDOUMsUUFBTSxnQkFBd0IsVUFBVSxZQUFZLFNBQVMseUJBQXlCO0FBR3RGLFFBQU0saUJBQTJCO0FBQUEsSUFDL0I7QUFBQSxJQUNBO0FBQUEsSUFDQTtBQUFBLElBQVk7QUFBQSxFQUNkO0FBRUEsTUFBRyxnQkFBZ0I7QUFDakIsbUJBQWUsS0FBSyxrQkFBa0I7QUFBQSxFQUN4QztBQUVBLE1BQUk7QUFDRixVQUFNLFVBQWtCLFlBQVksU0FBUyxPQUFPO0FBQ3BELFVBQU0sY0FBc0IsaUJBQWlCLDBCQUEwQixPQUFPO0FBQzlFLFVBQU0sTUFBTSxhQUFhLGdCQUFnQjtBQUFBLE1BQ3ZDLFVBQVU7QUFBQSxNQUNWLEtBQUs7QUFBQSxRQUNILFdBQVc7QUFBQSxRQUNYLGtCQUFrQjtBQUFBLE1BQ3BCO0FBQUEsTUFDQSxPQUFPO0FBQUEsSUFDVCxDQUFDO0FBR0QsWUFBUSxRQUFRLDZCQUE2QjtBQUU3QyxhQUFTLENBQUM7QUFDVixXQUFPO0FBQUEsRUFDVCxTQUFRLE9BQU87QUFFYixRQUFJO0FBQUEsRUFBSyxPQUFPLFdBQVcsTUFBTSxPQUFPLElBQUksU0FBUyxLQUFLO0FBRzFELFlBQVEsS0FBSywyQ0FBMkM7QUFHeEQsYUFBUyxDQUFDO0FBQ1YsV0FBTztBQUFBLEVBQ1Q7QUFDRjsiLAogICJuYW1lcyI6IFtdCn0K
|
package/dist/commands/init.js
DELETED
|
@@ -1,93 +0,0 @@
|
|
|
1
|
-
import { execa } from "execa";
|
|
2
|
-
import { renameSync, writeFileSync } from "fs";
|
|
3
|
-
import { resolve as pathResolve } from "path";
|
|
4
|
-
import { URL } from "url";
|
|
5
|
-
import { LexConfig } from "../LexConfig.js";
|
|
6
|
-
import { createSpinner, getPackageJson, setPackageJson } from "../utils/app.js";
|
|
7
|
-
import { log } from "../utils/log.js";
|
|
8
|
-
const init = async (appName, packageName, cmd, callback = () => ({})) => {
|
|
9
|
-
const { cliName = "Lex", install, packageManager: cmdPackageManager, quiet, typescript } = cmd;
|
|
10
|
-
const cwd = process.cwd();
|
|
11
|
-
const spinner = createSpinner(quiet);
|
|
12
|
-
log(`${cliName} is downloading the app module...`, "info", quiet);
|
|
13
|
-
spinner.start("Downloading app...");
|
|
14
|
-
const tmpPath = pathResolve(cwd, "./.lexTmp");
|
|
15
|
-
const appPath = pathResolve(cwd, `./${appName}`);
|
|
16
|
-
const dirName = new URL(".", import.meta.url).pathname;
|
|
17
|
-
const dnpPath = pathResolve(dirName, "../../node_modules/download-npm-package/bin/cli.js");
|
|
18
|
-
await LexConfig.parseConfig(cmd);
|
|
19
|
-
const { packageManager: configPackageManager, useTypescript: configTypescript } = LexConfig.config;
|
|
20
|
-
const packageManager = cmdPackageManager || configPackageManager;
|
|
21
|
-
const useTypescript = typescript !== void 0 ? typescript : configTypescript;
|
|
22
|
-
let appModule = packageName;
|
|
23
|
-
if (!appModule) {
|
|
24
|
-
if (useTypescript) {
|
|
25
|
-
appModule = "@nlabs/arkhamjs-example-ts-react";
|
|
26
|
-
} else {
|
|
27
|
-
appModule = "@nlabs/arkhamjs-example-flow-react";
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
try {
|
|
31
|
-
await execa(dnpPath, [appModule, tmpPath], {});
|
|
32
|
-
spinner.succeed("Successfully downloaded app!");
|
|
33
|
-
} catch (error) {
|
|
34
|
-
console.log("error", error);
|
|
35
|
-
log(`
|
|
36
|
-
${cliName} Error: There was an error downloading ${appModule}. Make sure the package exists and there is a network connection.`, "error", quiet);
|
|
37
|
-
spinner.fail("Downloaded of app failed.");
|
|
38
|
-
callback(1);
|
|
39
|
-
return 1;
|
|
40
|
-
}
|
|
41
|
-
try {
|
|
42
|
-
renameSync(`${tmpPath}/${appModule}`, appPath);
|
|
43
|
-
} catch (error) {
|
|
44
|
-
log(`
|
|
45
|
-
${cliName} Error: There was an error copying ${appModule} to the current working directory.`, "error", quiet);
|
|
46
|
-
callback(1);
|
|
47
|
-
return 1;
|
|
48
|
-
}
|
|
49
|
-
const packagePath = `${appPath}/package.json`;
|
|
50
|
-
const packageJson = getPackageJson(packagePath);
|
|
51
|
-
packageJson.name = appName;
|
|
52
|
-
packageJson.description = `${cliName} created app`;
|
|
53
|
-
packageJson.version = "0.1.0";
|
|
54
|
-
delete packageJson.keywords;
|
|
55
|
-
delete packageJson.author;
|
|
56
|
-
delete packageJson.contributors;
|
|
57
|
-
delete packageJson.repository;
|
|
58
|
-
delete packageJson.homepage;
|
|
59
|
-
delete packageJson.bugs;
|
|
60
|
-
try {
|
|
61
|
-
setPackageJson(packageJson, packagePath);
|
|
62
|
-
const readmePath = `${appPath}/README.md`;
|
|
63
|
-
writeFileSync(readmePath, `# ${appName}`);
|
|
64
|
-
} catch (error) {
|
|
65
|
-
log(`
|
|
66
|
-
${cliName} Error: ${error.message}`, "error", quiet);
|
|
67
|
-
callback(1);
|
|
68
|
-
return 1;
|
|
69
|
-
}
|
|
70
|
-
if (install) {
|
|
71
|
-
spinner.start("Installing dependencies...");
|
|
72
|
-
process.chdir(appPath);
|
|
73
|
-
try {
|
|
74
|
-
await execa(packageManager, ["install"], {
|
|
75
|
-
encoding: "utf8",
|
|
76
|
-
stdio: "inherit"
|
|
77
|
-
});
|
|
78
|
-
spinner.succeed("Successfully installed dependencies!");
|
|
79
|
-
} catch (error) {
|
|
80
|
-
log(`
|
|
81
|
-
${cliName} Error: ${error.message}`, "error", quiet);
|
|
82
|
-
spinner.fail("Failed to install dependencies.");
|
|
83
|
-
callback(1);
|
|
84
|
-
return 1;
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
callback(0);
|
|
88
|
-
return 0;
|
|
89
|
-
};
|
|
90
|
-
export {
|
|
91
|
-
init
|
|
92
|
-
};
|
|
93
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/commands/init.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 {renameSync, writeFileSync} from 'fs';\nimport {resolve as pathResolve} from 'path';\nimport {URL} from 'url';\n\nimport {LexConfig} from '../LexConfig.js';\nimport {createSpinner, getPackageJson, setPackageJson} from '../utils/app.js';\nimport {log} from '../utils/log.js';\n\nexport const init = async (\n  appName: string,\n  packageName: string,\n  cmd: any,\n  callback: any = () => ({})\n): Promise<number> => {\n  const {cliName = 'Lex', install, packageManager: cmdPackageManager, quiet, typescript} = cmd;\n  const cwd: string = process.cwd();\n\n  // Spinner\n  const spinner = createSpinner(quiet);\n\n  // Download app module into temporary directory\n  log(`${cliName} is downloading the app module...`, 'info', quiet);\n  spinner.start('Downloading app...');\n  const tmpPath: string = pathResolve(cwd, './.lexTmp');\n  const appPath: string = pathResolve(cwd, `./${appName}`);\n  const dirName = new URL('.', import.meta.url).pathname;\n  const dnpPath: string = pathResolve(dirName, '../../node_modules/download-npm-package/bin/cli.js');\n\n  // Get custom configuration\n  await LexConfig.parseConfig(cmd);\n  const {packageManager: configPackageManager, useTypescript: configTypescript} = LexConfig.config;\n  const packageManager: string = cmdPackageManager || configPackageManager;\n  const useTypescript: boolean = typescript !== undefined ? typescript : configTypescript;\n\n  let appModule: string = packageName;\n\n  // Use base app module based on config\n  if(!appModule) {\n    if(useTypescript) {\n      appModule = '@nlabs/arkhamjs-example-ts-react';\n    } else {\n      appModule = '@nlabs/arkhamjs-example-flow-react';\n    }\n  }\n\n  try {\n    await execa(dnpPath, [appModule, tmpPath], {});\n\n    // Stop spinner and update status\n    spinner.succeed('Successfully downloaded app!');\n  } catch(error) {\n    console.log('error', error);\n    log(`\\n${cliName} Error: There was an error downloading ${appModule}. Make sure the package exists and there is a network connection.`, 'error', quiet);\n\n    // Stop spinner and kill process\n    spinner.fail('Downloaded of app failed.');\n\n    // Kill process\n    callback(1);\n    return 1;\n  }\n\n  // Move into configured directory\n  try {\n    renameSync(`${tmpPath}/${appModule}`, appPath);\n  } catch(error) {\n    log(`\\n${cliName} Error: There was an error copying ${appModule} to the current working directory.`, 'error', quiet);\n    callback(1);\n    return 1;\n  }\n\n  // Configure package.json\n  const packagePath: string = `${appPath}/package.json`;\n  const packageJson = getPackageJson(packagePath);\n  packageJson.name = appName;\n  packageJson.description = `${cliName} created app`;\n  packageJson.version = '0.1.0';\n  delete packageJson.keywords;\n  delete packageJson.author;\n  delete packageJson.contributors;\n  delete packageJson.repository;\n  delete packageJson.homepage;\n  delete packageJson.bugs;\n\n  try {\n    // Update package.json\n    setPackageJson(packageJson, packagePath);\n\n    // Update README\n    const readmePath: string = `${appPath}/README.md`;\n    writeFileSync(readmePath, `# ${appName}`);\n  } catch(error) {\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n    callback(1);\n    return 1;\n  }\n\n  if(install) {\n    spinner.start('Installing dependencies...');\n\n    // Change to the app directory\n    process.chdir(appPath);\n\n    // Install dependencies\n    try {\n      await execa(packageManager, ['install'], {\n        encoding: 'utf8',\n        stdio: 'inherit'\n      });\n\n      // Stop spinner\n      spinner.succeed('Successfully installed dependencies!');\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 install dependencies.');\n\n      // Kill process\n      callback(1);\n      return 1;\n    }\n  }\n\n  // Kill process\n  callback(0);\n  return 0;\n};\n"],
  "mappings": "AAIA,SAAQ,aAAY;AACpB,SAAQ,YAAY,qBAAoB;AACxC,SAAQ,WAAW,mBAAkB;AACrC,SAAQ,WAAU;AAElB,SAAQ,iBAAgB;AACxB,SAAQ,eAAe,gBAAgB,sBAAqB;AAC5D,SAAQ,WAAU;AAEX,MAAM,OAAO,OAClB,SACA,aACA,KACA,WAAgB,OAAO,CAAC,OACJ;AACpB,QAAM,EAAC,UAAU,OAAO,SAAS,gBAAgB,mBAAmB,OAAO,WAAU,IAAI;AACzF,QAAM,MAAc,QAAQ,IAAI;AAGhC,QAAM,UAAU,cAAc,KAAK;AAGnC,MAAI,GAAG,OAAO,qCAAqC,QAAQ,KAAK;AAChE,UAAQ,MAAM,oBAAoB;AAClC,QAAM,UAAkB,YAAY,KAAK,WAAW;AACpD,QAAM,UAAkB,YAAY,KAAK,KAAK,OAAO,EAAE;AACvD,QAAM,UAAU,IAAI,IAAI,KAAK,YAAY,GAAG,EAAE;AAC9C,QAAM,UAAkB,YAAY,SAAS,oDAAoD;AAGjG,QAAM,UAAU,YAAY,GAAG;AAC/B,QAAM,EAAC,gBAAgB,sBAAsB,eAAe,iBAAgB,IAAI,UAAU;AAC1F,QAAM,iBAAyB,qBAAqB;AACpD,QAAM,gBAAyB,eAAe,SAAY,aAAa;AAEvE,MAAI,YAAoB;AAGxB,MAAG,CAAC,WAAW;AACb,QAAG,eAAe;AAChB,kBAAY;AAAA,IACd,OAAO;AACL,kBAAY;AAAA,IACd;AAAA,EACF;AAEA,MAAI;AACF,UAAM,MAAM,SAAS,CAAC,WAAW,OAAO,GAAG,CAAC,CAAC;AAG7C,YAAQ,QAAQ,8BAA8B;AAAA,EAChD,SAAQ,OAAO;AACb,YAAQ,IAAI,SAAS,KAAK;AAC1B,QAAI;AAAA,EAAK,OAAO,0CAA0C,SAAS,qEAAqE,SAAS,KAAK;AAGtJ,YAAQ,KAAK,2BAA2B;AAGxC,aAAS,CAAC;AACV,WAAO;AAAA,EACT;AAGA,MAAI;AACF,eAAW,GAAG,OAAO,IAAI,SAAS,IAAI,OAAO;AAAA,EAC/C,SAAQ,OAAO;AACb,QAAI;AAAA,EAAK,OAAO,sCAAsC,SAAS,sCAAsC,SAAS,KAAK;AACnH,aAAS,CAAC;AACV,WAAO;AAAA,EACT;AAGA,QAAM,cAAsB,GAAG,OAAO;AACtC,QAAM,cAAc,eAAe,WAAW;AAC9C,cAAY,OAAO;AACnB,cAAY,cAAc,GAAG,OAAO;AACpC,cAAY,UAAU;AACtB,SAAO,YAAY;AACnB,SAAO,YAAY;AACnB,SAAO,YAAY;AACnB,SAAO,YAAY;AACnB,SAAO,YAAY;AACnB,SAAO,YAAY;AAEnB,MAAI;AAEF,mBAAe,aAAa,WAAW;AAGvC,UAAM,aAAqB,GAAG,OAAO;AACrC,kBAAc,YAAY,KAAK,OAAO,EAAE;AAAA,EAC1C,SAAQ,OAAO;AACb,QAAI;AAAA,EAAK,OAAO,WAAW,MAAM,OAAO,IAAI,SAAS,KAAK;AAC1D,aAAS,CAAC;AACV,WAAO;AAAA,EACT;AAEA,MAAG,SAAS;AACV,YAAQ,MAAM,4BAA4B;AAG1C,YAAQ,MAAM,OAAO;AAGrB,QAAI;AACF,YAAM,MAAM,gBAAgB,CAAC,SAAS,GAAG;AAAA,QACvC,UAAU;AAAA,QACV,OAAO;AAAA,MACT,CAAC;AAGD,cAAQ,QAAQ,sCAAsC;AAAA,IACxD,SAAQ,OAAO;AAEb,UAAI;AAAA,EAAK,OAAO,WAAW,MAAM,OAAO,IAAI,SAAS,KAAK;AAG1D,cAAQ,KAAK,iCAAiC;AAG9C,eAAS,CAAC;AACV,aAAO;AAAA,IACT;AAAA,EACF;AAGA,WAAS,CAAC;AACV,SAAO;AACT;",
  "names": []
}

|
package/dist/commands/link.js
DELETED
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { LexConfig } from "../LexConfig.js";
|
|
2
|
-
import { checkLinkedModules } from "../utils/app.js";
|
|
3
|
-
import { log } from "../utils/log.js";
|
|
4
|
-
const linked = async (cmd, callback = () => ({})) => {
|
|
5
|
-
const { cliName = "Lex", quiet } = cmd;
|
|
6
|
-
log(`${cliName} checking for linked modules...`, "info", quiet);
|
|
7
|
-
await LexConfig.parseConfig(cmd);
|
|
8
|
-
checkLinkedModules();
|
|
9
|
-
callback(0);
|
|
10
|
-
return Promise.resolve(0);
|
|
11
|
-
};
|
|
12
|
-
export {
|
|
13
|
-
linked
|
|
14
|
-
};
|
|
15
|
-
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2xpbmsudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE4LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQge0xleENvbmZpZ30gZnJvbSAnLi4vTGV4Q29uZmlnLmpzJztcbmltcG9ydCB7Y2hlY2tMaW5rZWRNb2R1bGVzfSBmcm9tICcuLi91dGlscy9hcHAuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uL3V0aWxzL2xvZy5qcyc7XG5cbmV4cG9ydCBjb25zdCBsaW5rZWQgPSBhc3luYyAoY21kOiBhbnksIGNhbGxiYWNrOiBhbnkgPSAoKSA9PiAoe30pKTogUHJvbWlzZTxudW1iZXI+ID0+IHtcbiAgY29uc3Qge2NsaU5hbWUgPSAnTGV4JywgcXVpZXR9ID0gY21kO1xuXG4gIC8vIERpc3BsYXkgc3RhdHVzXG4gIGxvZyhgJHtjbGlOYW1lfSBjaGVja2luZyBmb3IgbGlua2VkIG1vZHVsZXMuLi5gLCAnaW5mbycsIHF1aWV0KTtcblxuICAvLyBHZXQgY3VzdG9tIGNvbmZpZ3VyYXRpb25cbiAgYXdhaXQgTGV4Q29uZmlnLnBhcnNlQ29uZmlnKGNtZCk7XG5cbiAgLy8gQ2hlY2sgZm9yIGxpbmtlZCBtb2R1bGVzXG4gIGNoZWNrTGlua2VkTW9kdWxlcygpO1xuICBjYWxsYmFjaygwKTtcbiAgcmV0dXJuIFByb21pc2UucmVzb2x2ZSgwKTtcbn07XG4iXSwKICAibWFwcGluZ3MiOiAiQUFJQSxTQUFRLGlCQUFnQjtBQUN4QixTQUFRLDBCQUF5QjtBQUNqQyxTQUFRLFdBQVU7QUFFWCxNQUFNLFNBQVMsT0FBTyxLQUFVLFdBQWdCLE9BQU8sQ0FBQyxPQUF3QjtBQUNyRixRQUFNLEVBQUMsVUFBVSxPQUFPLE1BQUssSUFBSTtBQUdqQyxNQUFJLEdBQUcsT0FBTyxtQ0FBbUMsUUFBUSxLQUFLO0FBRzlELFFBQU0sVUFBVSxZQUFZLEdBQUc7QUFHL0IscUJBQW1CO0FBQ25CLFdBQVMsQ0FBQztBQUNWLFNBQU8sUUFBUSxRQUFRLENBQUM7QUFDMUI7IiwKICAibmFtZXMiOiBbXQp9Cg==
|
package/dist/commands/lint.js
DELETED
|
@@ -1,179 +0,0 @@
|
|
|
1
|
-
import { execa } from "execa";
|
|
2
|
-
import { resolve as pathResolve } from "path";
|
|
3
|
-
import { URL } from "url";
|
|
4
|
-
import { LexConfig } from "../LexConfig.js";
|
|
5
|
-
import { createSpinner } from "../utils/app.js";
|
|
6
|
-
import { relativeNodePath } from "../utils/file.js";
|
|
7
|
-
import { log } from "../utils/log.js";
|
|
8
|
-
const lint = async (cmd, callback = process.exit) => {
|
|
9
|
-
const {
|
|
10
|
-
cache,
|
|
11
|
-
cacheFile,
|
|
12
|
-
cacheLocation,
|
|
13
|
-
cliName = "Lex",
|
|
14
|
-
color,
|
|
15
|
-
config,
|
|
16
|
-
debug,
|
|
17
|
-
env,
|
|
18
|
-
envInfo,
|
|
19
|
-
ext = ".js",
|
|
20
|
-
fix,
|
|
21
|
-
fixDryRun,
|
|
22
|
-
fixType,
|
|
23
|
-
format,
|
|
24
|
-
global,
|
|
25
|
-
ignorePath,
|
|
26
|
-
ignorePattern,
|
|
27
|
-
init,
|
|
28
|
-
maxWarnings,
|
|
29
|
-
noColor,
|
|
30
|
-
noEslintrc = true,
|
|
31
|
-
noIgnore,
|
|
32
|
-
noInlineConfig,
|
|
33
|
-
outputFile,
|
|
34
|
-
parser,
|
|
35
|
-
parserOptions,
|
|
36
|
-
plugin,
|
|
37
|
-
printConfig,
|
|
38
|
-
quiet,
|
|
39
|
-
reportUnusedDisableDirectives,
|
|
40
|
-
resolvePluginsRelativeTo,
|
|
41
|
-
rule,
|
|
42
|
-
rulesdir,
|
|
43
|
-
stdin,
|
|
44
|
-
stdinFilename
|
|
45
|
-
} = cmd;
|
|
46
|
-
log(`${cliName} linting...`, "info", quiet);
|
|
47
|
-
const spinner = createSpinner(quiet);
|
|
48
|
-
await LexConfig.parseConfig(cmd);
|
|
49
|
-
const { useTypescript } = LexConfig.config;
|
|
50
|
-
let extensions = ext;
|
|
51
|
-
if (useTypescript) {
|
|
52
|
-
LexConfig.checkTypescriptConfig();
|
|
53
|
-
extensions = ".ts,.tsx";
|
|
54
|
-
}
|
|
55
|
-
const dirName = new URL(".", import.meta.url).pathname;
|
|
56
|
-
const dirPath = pathResolve(dirName, "../..");
|
|
57
|
-
const eslintPath = relativeNodePath("eslint/bin/eslint.js", dirPath);
|
|
58
|
-
const eslintOptions = ["./src"];
|
|
59
|
-
if (noEslintrc) {
|
|
60
|
-
eslintOptions.push("--no-eslintrc");
|
|
61
|
-
}
|
|
62
|
-
if (config) {
|
|
63
|
-
eslintOptions.push("--config", config);
|
|
64
|
-
} else {
|
|
65
|
-
let configPath;
|
|
66
|
-
if (useTypescript) {
|
|
67
|
-
configPath = relativeNodePath("eslint-config-styleguidejs/typescript.js", dirPath);
|
|
68
|
-
} else {
|
|
69
|
-
configPath = relativeNodePath("eslint-config-styleguidejs/react.js", dirPath);
|
|
70
|
-
}
|
|
71
|
-
eslintOptions.push("--config", configPath);
|
|
72
|
-
}
|
|
73
|
-
if (env) {
|
|
74
|
-
eslintOptions.push("--env", env);
|
|
75
|
-
}
|
|
76
|
-
if (extensions) {
|
|
77
|
-
eslintOptions.push("--ext", extensions);
|
|
78
|
-
}
|
|
79
|
-
if (global) {
|
|
80
|
-
eslintOptions.push("--global", global);
|
|
81
|
-
}
|
|
82
|
-
if (parser) {
|
|
83
|
-
eslintOptions.push("--parser", parser);
|
|
84
|
-
}
|
|
85
|
-
if (parserOptions) {
|
|
86
|
-
eslintOptions.push("--parserOptions", parserOptions);
|
|
87
|
-
}
|
|
88
|
-
if (resolvePluginsRelativeTo) {
|
|
89
|
-
eslintOptions.push("--resolvePluginsRelativeTo", resolvePluginsRelativeTo);
|
|
90
|
-
}
|
|
91
|
-
if (rulesdir) {
|
|
92
|
-
eslintOptions.push("--rulesdir", rulesdir);
|
|
93
|
-
}
|
|
94
|
-
if (plugin) {
|
|
95
|
-
eslintOptions.push("--plugin", plugin);
|
|
96
|
-
}
|
|
97
|
-
if (rule) {
|
|
98
|
-
eslintOptions.push("--rule", rule);
|
|
99
|
-
}
|
|
100
|
-
if (fix) {
|
|
101
|
-
eslintOptions.push("--fix");
|
|
102
|
-
}
|
|
103
|
-
if (fixDryRun) {
|
|
104
|
-
eslintOptions.push("--fixDryRun");
|
|
105
|
-
}
|
|
106
|
-
if (fixType) {
|
|
107
|
-
eslintOptions.push("--fixType", fixType);
|
|
108
|
-
}
|
|
109
|
-
if (ignorePath) {
|
|
110
|
-
eslintOptions.push("--ignorePath", ignorePath);
|
|
111
|
-
}
|
|
112
|
-
if (noIgnore) {
|
|
113
|
-
eslintOptions.push("--noIgnore");
|
|
114
|
-
}
|
|
115
|
-
if (ignorePattern) {
|
|
116
|
-
eslintOptions.push("--ignorePattern", ignorePattern);
|
|
117
|
-
}
|
|
118
|
-
if (stdin) {
|
|
119
|
-
eslintOptions.push("--stdin");
|
|
120
|
-
}
|
|
121
|
-
if (stdinFilename) {
|
|
122
|
-
eslintOptions.push("--stdinFilename", stdinFilename);
|
|
123
|
-
}
|
|
124
|
-
if (maxWarnings) {
|
|
125
|
-
eslintOptions.push("--maxWarnings", maxWarnings);
|
|
126
|
-
}
|
|
127
|
-
if (outputFile) {
|
|
128
|
-
eslintOptions.push("--outputFile", outputFile);
|
|
129
|
-
}
|
|
130
|
-
if (format) {
|
|
131
|
-
eslintOptions.push("--format", format);
|
|
132
|
-
}
|
|
133
|
-
if (color) {
|
|
134
|
-
eslintOptions.push("--color");
|
|
135
|
-
}
|
|
136
|
-
if (noColor) {
|
|
137
|
-
eslintOptions.push("--noColor");
|
|
138
|
-
}
|
|
139
|
-
if (noInlineConfig) {
|
|
140
|
-
eslintOptions.push("--noInlineConfig", noInlineConfig);
|
|
141
|
-
}
|
|
142
|
-
if (reportUnusedDisableDirectives) {
|
|
143
|
-
eslintOptions.push("--reportUnusedDisableDirectives");
|
|
144
|
-
}
|
|
145
|
-
if (cacheLocation) {
|
|
146
|
-
eslintOptions.push("--cacheLocation", cacheLocation);
|
|
147
|
-
}
|
|
148
|
-
if (init) {
|
|
149
|
-
eslintOptions.push("--init");
|
|
150
|
-
}
|
|
151
|
-
if (envInfo) {
|
|
152
|
-
eslintOptions.push("--env-info");
|
|
153
|
-
}
|
|
154
|
-
if (debug) {
|
|
155
|
-
eslintOptions.push("--debug");
|
|
156
|
-
}
|
|
157
|
-
if (printConfig) {
|
|
158
|
-
eslintOptions.push("--printConfig", printConfig);
|
|
159
|
-
}
|
|
160
|
-
try {
|
|
161
|
-
await execa(eslintPath, eslintOptions, {
|
|
162
|
-
encoding: "utf8",
|
|
163
|
-
stdio: "inherit"
|
|
164
|
-
});
|
|
165
|
-
spinner.succeed("Linting completed!");
|
|
166
|
-
callback(0);
|
|
167
|
-
return 0;
|
|
168
|
-
} catch (error) {
|
|
169
|
-
log(`
|
|
170
|
-
${cliName} Error: Check for unit test errors and/or coverage.`, "error", quiet);
|
|
171
|
-
spinner.fail("Testing failed!");
|
|
172
|
-
callback(1);
|
|
173
|
-
return 1;
|
|
174
|
-
}
|
|
175
|
-
};
|
|
176
|
-
export {
|
|
177
|
-
lint
|
|
178
|
-
};
|
|
179
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/commands/lint.ts"],
  "sourcesContent": ["/**\n * Copyright (c) 2022-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {execa} from 'execa';\nimport {resolve as pathResolve} from 'path';\nimport {URL} from 'url';\n\nimport {LexConfig} from '../LexConfig.js';\nimport {createSpinner} from '../utils/app.js';\nimport {relativeNodePath} from '../utils/file.js';\nimport {log} from '../utils/log.js';\n\nexport const lint = async (cmd: any, callback: any = process.exit): Promise<number> => {\n  const {\n    cache,\n    cacheFile,\n    cacheLocation,\n    cliName = 'Lex',\n    color,\n    config,\n    debug,\n    env,\n    envInfo,\n    ext = '.js',\n    fix,\n    fixDryRun,\n    fixType,\n    format,\n    global,\n    ignorePath,\n    ignorePattern,\n    init,\n    maxWarnings,\n    noColor,\n    noEslintrc = true,\n    noIgnore,\n    noInlineConfig,\n    outputFile,\n    parser,\n    parserOptions,\n    plugin,\n    printConfig,\n    quiet,\n    reportUnusedDisableDirectives,\n    resolvePluginsRelativeTo,\n    rule,\n    rulesdir,\n    stdin,\n    stdinFilename\n  } = cmd;\n\n  log(`${cliName} linting...`, 'info', quiet);\n\n  // Spinner\n  const spinner = createSpinner(quiet);\n\n  // Get custom configuration\n  await LexConfig.parseConfig(cmd);\n\n  const {useTypescript} = LexConfig.config;\n  let extensions = ext;\n\n  if(useTypescript) {\n    LexConfig.checkTypescriptConfig();\n    extensions = '.ts,.tsx';\n  }\n\n  // Configure jest\n  const dirName = new URL('.', import.meta.url).pathname;\n  const dirPath: string = pathResolve(dirName, '../..');\n  const eslintPath: string = relativeNodePath('eslint/bin/eslint.js', dirPath);\n  const eslintOptions: string[] = ['./src'];\n\n  if(noEslintrc) {\n    eslintOptions.push('--no-eslintrc');\n  }\n\n  if(config) {\n    eslintOptions.push('--config', config);\n  } else {\n    let configPath: string;\n\n    if(useTypescript) {\n      configPath = relativeNodePath('eslint-config-styleguidejs/typescript.js', dirPath);\n    } else {\n      configPath = relativeNodePath('eslint-config-styleguidejs/react.js', dirPath);\n    }\n    eslintOptions.push('--config', configPath);\n  }\n\n  if(env) {\n    eslintOptions.push('--env', env);\n  }\n\n  if(extensions) {\n    eslintOptions.push('--ext', extensions);\n  }\n\n  if(global) {\n    eslintOptions.push('--global', global);\n  }\n\n  if(parser) {\n    eslintOptions.push('--parser', parser);\n  }\n\n  if(parserOptions) {\n    eslintOptions.push('--parserOptions', parserOptions);\n  }\n\n  if(resolvePluginsRelativeTo) {\n    eslintOptions.push('--resolvePluginsRelativeTo', resolvePluginsRelativeTo);\n  }\n\n  if(rulesdir) {\n    eslintOptions.push('--rulesdir', rulesdir);\n  }\n\n  if(plugin) {\n    eslintOptions.push('--plugin', plugin);\n  }\n\n  if(rule) {\n    eslintOptions.push('--rule', rule);\n  }\n\n  if(fix) {\n    eslintOptions.push('--fix');\n  }\n\n  if(fixDryRun) {\n    eslintOptions.push('--fixDryRun');\n  }\n\n  if(fixType) {\n    eslintOptions.push('--fixType', fixType);\n  }\n\n  if(ignorePath) {\n    eslintOptions.push('--ignorePath', ignorePath);\n  }\n\n  if(noIgnore) {\n    eslintOptions.push('--noIgnore');\n  }\n\n  if(ignorePattern) {\n    eslintOptions.push('--ignorePattern', ignorePattern);\n  }\n\n  if(stdin) {\n    eslintOptions.push('--stdin');\n  }\n\n  if(stdinFilename) {\n    eslintOptions.push('--stdinFilename', stdinFilename);\n  }\n\n  if(maxWarnings) {\n    eslintOptions.push('--maxWarnings', maxWarnings);\n  }\n\n  if(outputFile) {\n    eslintOptions.push('--outputFile', outputFile);\n  }\n\n  if(format) {\n    eslintOptions.push('--format', format);\n  }\n\n  if(color) {\n    eslintOptions.push('--color');\n  }\n\n  if(noColor) {\n    eslintOptions.push('--noColor');\n  }\n\n  if(noInlineConfig) {\n    eslintOptions.push('--noInlineConfig', noInlineConfig);\n  }\n\n  if(reportUnusedDisableDirectives) {\n    eslintOptions.push('--reportUnusedDisableDirectives');\n  }\n\n  if(cacheLocation) {\n    eslintOptions.push('--cacheLocation', cacheLocation);\n  }\n\n  if(init) {\n    eslintOptions.push('--init');\n  }\n\n  if(envInfo) {\n    eslintOptions.push('--env-info');\n  }\n\n  if(debug) {\n    eslintOptions.push('--debug');\n  }\n\n  if(printConfig) {\n    eslintOptions.push('--printConfig', printConfig);\n  }\n\n  // Test app using jest\n  try {\n    await execa(eslintPath, eslintOptions, {\n      encoding: 'utf8',\n      stdio: 'inherit'\n    });\n\n    spinner.succeed('Linting completed!');\n\n    // Kill process\n    callback(0);\n    return 0;\n  } catch(error) {\n    // Display error message\n    log(`\\n${cliName} Error: Check for unit test errors and/or coverage.`, 'error', quiet);\n\n    // Stop spinner\n    spinner.fail('Testing failed!');\n\n    // Kill process\n    callback(1);\n    return 1;\n  }\n};\n"],
  "mappings": "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",
  "names": []
}

|
package/dist/commands/migrate.js
DELETED
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
import { execa } from "execa";
|
|
2
|
-
import { LexConfig } from "../LexConfig.js";
|
|
3
|
-
import { createSpinner, getPackageJson, removeConflictModules, removeModules } from "../utils/app.js";
|
|
4
|
-
import { log } from "../utils/log.js";
|
|
5
|
-
const migrate = async (cmd, callback = process.exit) => {
|
|
6
|
-
const { cliName = "Lex", packageManager: cmdPackageManager, quiet } = cmd;
|
|
7
|
-
const cwd = process.cwd();
|
|
8
|
-
const spinner = createSpinner(quiet);
|
|
9
|
-
spinner.start("Removing node modules...");
|
|
10
|
-
await removeModules();
|
|
11
|
-
const { packageManager: configPackageManager } = LexConfig.config;
|
|
12
|
-
const packageManager = cmdPackageManager || configPackageManager;
|
|
13
|
-
const packagePath = `${cwd}/package.json`;
|
|
14
|
-
const appPackage = getPackageJson(packagePath);
|
|
15
|
-
const { dependencies = {}, devDependencies = {} } = appPackage;
|
|
16
|
-
appPackage.dependencies = removeConflictModules(dependencies);
|
|
17
|
-
appPackage.devDependencies = removeConflictModules(devDependencies);
|
|
18
|
-
try {
|
|
19
|
-
await execa(packageManager, ["install"], {
|
|
20
|
-
encoding: "utf8",
|
|
21
|
-
stdio: "inherit"
|
|
22
|
-
});
|
|
23
|
-
spinner.succeed("Successfully migrated app!");
|
|
24
|
-
callback(0);
|
|
25
|
-
return 0;
|
|
26
|
-
} catch (error) {
|
|
27
|
-
log(`
|
|
28
|
-
${cliName} Error: ${error.message}`, "error", quiet);
|
|
29
|
-
spinner.fail("Failed to remove modules.");
|
|
30
|
-
callback(1);
|
|
31
|
-
return 1;
|
|
32
|
-
}
|
|
33
|
-
};
|
|
34
|
-
export {
|
|
35
|
-
migrate
|
|
36
|
-
};
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL21pZ3JhdGUudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE4LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQge2V4ZWNhfSBmcm9tICdleGVjYSc7XG5cbmltcG9ydCB7TGV4Q29uZmlnfSBmcm9tICcuLi9MZXhDb25maWcuanMnO1xuaW1wb3J0IHtjcmVhdGVTcGlubmVyLCBnZXRQYWNrYWdlSnNvbiwgcmVtb3ZlQ29uZmxpY3RNb2R1bGVzLCByZW1vdmVNb2R1bGVzfSBmcm9tICcuLi91dGlscy9hcHAuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uL3V0aWxzL2xvZy5qcyc7XG5cbmV4cG9ydCBjb25zdCBtaWdyYXRlID0gYXN5bmMgKGNtZDogYW55LCBjYWxsYmFjazogYW55ID0gcHJvY2Vzcy5leGl0KTogUHJvbWlzZTxudW1iZXI+ID0+IHtcbiAgY29uc3Qge2NsaU5hbWUgPSAnTGV4JywgcGFja2FnZU1hbmFnZXI6IGNtZFBhY2thZ2VNYW5hZ2VyLCBxdWlldH0gPSBjbWQ7XG5cbiAgY29uc3QgY3dkOiBzdHJpbmcgPSBwcm9jZXNzLmN3ZCgpO1xuXG4gIC8vIC8vIERpc3BsYXkgbWVzc2FnZVxuICAvLyBsb2coYCR7Y2xpTmFtZX0gY29weWluZyBcIiR7dG99XCIuLi5gLCAnaW5mbycsIHF1aWV0KTtcblxuICAvLyBTcGlubmVyXG4gIGNvbnN0IHNwaW5uZXIgPSBjcmVhdGVTcGlubmVyKHF1aWV0KTtcbiAgc3Bpbm5lci5zdGFydCgnUmVtb3Zpbmcgbm9kZSBtb2R1bGVzLi4uJyk7XG5cbiAgLy8gUmVtb3ZlIG5vZGVfbW9kdWxlc1xuICBhd2FpdCByZW1vdmVNb2R1bGVzKCk7XG5cbiAgY29uc3Qge3BhY2thZ2VNYW5hZ2VyOiBjb25maWdQYWNrYWdlTWFuYWdlcn0gPSBMZXhDb25maWcuY29uZmlnO1xuICBjb25zdCBwYWNrYWdlTWFuYWdlcjogc3RyaW5nID0gY21kUGFja2FnZU1hbmFnZXIgfHwgY29uZmlnUGFja2FnZU1hbmFnZXI7XG4gIGNvbnN0IHBhY2thZ2VQYXRoOiBzdHJpbmcgPSBgJHtjd2R9L3BhY2thZ2UuanNvbmA7XG4gIGNvbnN0IGFwcFBhY2thZ2UgPSBnZXRQYWNrYWdlSnNvbihwYWNrYWdlUGF0aCk7XG4gIGNvbnN0IHtkZXBlbmRlbmNpZXMgPSB7fSwgZGV2RGVwZW5kZW5jaWVzID0ge319ID0gYXBwUGFja2FnZTtcblxuICAvLyBSZW1vdmUgRVNCdWlsZCwgSmVzdCBhbmQgV2VicGFjayBmcm9tIGFwcCBzaW5jZSBpdCB3aWxsIGNvbmZsaWN0XG4gIGFwcFBhY2thZ2UuZGVwZW5kZW5jaWVzID0gcmVtb3ZlQ29uZmxpY3RNb2R1bGVzKGRlcGVuZGVuY2llcyk7XG4gIGFwcFBhY2thZ2UuZGV2RGVwZW5kZW5jaWVzID0gcmVtb3ZlQ29uZmxpY3RNb2R1bGVzKGRldkRlcGVuZGVuY2llcyk7XG5cbiAgLy8gSW5zdGFsbCBuZXcgbGlzdCBvZiBwYWNrYWdlc1xuICB0cnkge1xuICAgIGF3YWl0IGV4ZWNhKHBhY2thZ2VNYW5hZ2VyLCBbJ2luc3RhbGwnXSwge1xuICAgICAgZW5jb2Rpbmc6ICd1dGY4JyxcbiAgICAgIHN0ZGlvOiAnaW5oZXJpdCdcbiAgICB9KTtcblxuICAgIC8vIFN0b3AgbG9hZGVyXG4gICAgc3Bpbm5lci5zdWNjZWVkKCdTdWNjZXNzZnVsbHkgbWlncmF0ZWQgYXBwIScpO1xuXG4gICAgLy8gS2lsbCBwcm9jZXNzXG4gICAgY2FsbGJhY2soMCk7XG4gICAgcmV0dXJuIDA7XG4gIH0gY2F0Y2goZXJyb3IpIHtcbiAgICAvLyBEaXNwbGF5IGVycm9yIG1lc3NhZ2VcbiAgICBsb2coYFxcbiR7Y2xpTmFtZX0gRXJyb3I6ICR7ZXJyb3IubWVzc2FnZX1gLCAnZXJyb3InLCBxdWlldCk7XG5cbiAgICAvLyBTdG9wIHNwaW5uZXJcbiAgICBzcGlubmVyLmZhaWwoJ0ZhaWxlZCB0byByZW1vdmUgbW9kdWxlcy4nKTtcblxuICAgIC8vIEtpbGwgcHJvY2Vzc1xuICAgIGNhbGxiYWNrKDEpO1xuICAgIHJldHVybiAxO1xuICB9XG59O1xuIl0sCiAgIm1hcHBpbmdzIjogIkFBSUEsU0FBUSxhQUFZO0FBRXBCLFNBQVEsaUJBQWdCO0FBQ3hCLFNBQVEsZUFBZSxnQkFBZ0IsdUJBQXVCLHFCQUFvQjtBQUNsRixTQUFRLFdBQVU7QUFFWCxNQUFNLFVBQVUsT0FBTyxLQUFVLFdBQWdCLFFBQVEsU0FBMEI7QUFDeEYsUUFBTSxFQUFDLFVBQVUsT0FBTyxnQkFBZ0IsbUJBQW1CLE1BQUssSUFBSTtBQUVwRSxRQUFNLE1BQWMsUUFBUSxJQUFJO0FBTWhDLFFBQU0sVUFBVSxjQUFjLEtBQUs7QUFDbkMsVUFBUSxNQUFNLDBCQUEwQjtBQUd4QyxRQUFNLGNBQWM7QUFFcEIsUUFBTSxFQUFDLGdCQUFnQixxQkFBb0IsSUFBSSxVQUFVO0FBQ3pELFFBQU0saUJBQXlCLHFCQUFxQjtBQUNwRCxRQUFNLGNBQXNCLEdBQUcsR0FBRztBQUNsQyxRQUFNLGFBQWEsZUFBZSxXQUFXO0FBQzdDLFFBQU0sRUFBQyxlQUFlLENBQUMsR0FBRyxrQkFBa0IsQ0FBQyxFQUFDLElBQUk7QUFHbEQsYUFBVyxlQUFlLHNCQUFzQixZQUFZO0FBQzVELGFBQVcsa0JBQWtCLHNCQUFzQixlQUFlO0FBR2xFLE1BQUk7QUFDRixVQUFNLE1BQU0sZ0JBQWdCLENBQUMsU0FBUyxHQUFHO0FBQUEsTUFDdkMsVUFBVTtBQUFBLE1BQ1YsT0FBTztBQUFBLElBQ1QsQ0FBQztBQUdELFlBQVEsUUFBUSw0QkFBNEI7QUFHNUMsYUFBUyxDQUFDO0FBQ1YsV0FBTztBQUFBLEVBQ1QsU0FBUSxPQUFPO0FBRWIsUUFBSTtBQUFBLEVBQUssT0FBTyxXQUFXLE1BQU0sT0FBTyxJQUFJLFNBQVMsS0FBSztBQUcxRCxZQUFRLEtBQUssMkJBQTJCO0FBR3hDLGFBQVMsQ0FBQztBQUNWLFdBQU87QUFBQSxFQUNUO0FBQ0Y7IiwKICAibmFtZXMiOiBbXQp9Cg==
|