@nlabs/lex 1.32.0 → 1.37.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/.postcssrc.js +1 -1
- package/dist/LexConfig.js +22 -43
- package/dist/commands/build.js +24 -42
- package/dist/commands/bulid.test.js +1 -1
- package/dist/commands/clean.js +18 -21
- package/dist/commands/compile.js +53 -57
- package/dist/commands/config.js +17 -23
- package/dist/commands/copy.js +21 -26
- package/dist/commands/create.js +44 -49
- package/dist/commands/dev.js +21 -39
- package/dist/commands/index.js +9 -13
- package/dist/commands/init.js +21 -26
- package/dist/commands/link.js +13 -16
- package/dist/commands/lint.js +17 -23
- package/dist/commands/migrate.js +18 -23
- package/dist/commands/publish.js +23 -45
- package/dist/commands/test.js +17 -21
- package/dist/commands/update.js +15 -21
- package/dist/commands/upgrade.js +17 -22
- package/dist/commands/versions.js +17 -21
- package/dist/create/changelog.js +18 -23
- package/dist/lex.js +1 -0
- package/dist/resolver.js +35 -22
- package/dist/utils/app.js +243 -0
- package/dist/utils/file.js +53 -0
- package/dist/utils/log.js +54 -0
- package/dist/utils/reactShim.js +31 -0
- package/jest.config.js +2 -3
- package/jest.config.lex.js +44 -10
- package/jest.setup.js +3 -1
- package/package.json +41 -40
- package/tsconfig.template.json +1 -1
- package/webpack.config.js +29 -10
- package/dist/utils.js +0 -312
package/dist/commands/create.js
CHANGED
|
@@ -4,40 +4,35 @@ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
|
4
4
|
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
5
|
var __getProtoOf = Object.getPrototypeOf;
|
|
6
6
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
-
var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
|
|
8
7
|
var __export = (target, all) => {
|
|
9
8
|
for (var name in all)
|
|
10
9
|
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
10
|
};
|
|
12
|
-
var
|
|
13
|
-
if (
|
|
14
|
-
for (let key of __getOwnPropNames(
|
|
15
|
-
if (!__hasOwnProp.call(
|
|
16
|
-
__defProp(
|
|
11
|
+
var __copyProps = (to, from, except, desc) => {
|
|
12
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
+
for (let key of __getOwnPropNames(from))
|
|
14
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
15
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
16
|
}
|
|
18
|
-
return
|
|
17
|
+
return to;
|
|
19
18
|
};
|
|
20
|
-
var __toESM = (
|
|
21
|
-
|
|
22
|
-
};
|
|
23
|
-
var __toCommonJS = /* @__PURE__ */ ((cache) => {
|
|
24
|
-
return (module2, temp) => {
|
|
25
|
-
return cache && cache.get(module2) || (temp = __reExport(__markAsModule({}), module2, 1), cache && cache.set(module2, temp), temp);
|
|
26
|
-
};
|
|
27
|
-
})(typeof WeakMap !== "undefined" ? /* @__PURE__ */ new WeakMap() : 0);
|
|
19
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod));
|
|
20
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
28
21
|
var create_exports = {};
|
|
29
22
|
__export(create_exports, {
|
|
30
23
|
create: () => create
|
|
31
24
|
});
|
|
32
|
-
|
|
33
|
-
var
|
|
25
|
+
module.exports = __toCommonJS(create_exports);
|
|
26
|
+
var fs = __toESM(require("fs-extra"));
|
|
27
|
+
var path = __toESM(require("path"));
|
|
34
28
|
var import_changelog = require("../create/changelog");
|
|
35
29
|
var import_LexConfig = require("../LexConfig");
|
|
36
|
-
var
|
|
30
|
+
var import_app = require("../utils/app");
|
|
31
|
+
var import_log = require("../utils/log");
|
|
37
32
|
const create = async (type, cmd, callback = () => ({})) => {
|
|
38
33
|
const { cliName = "Lex", outputFile, outputName, quiet } = cmd;
|
|
39
34
|
const cwd = process.cwd();
|
|
40
|
-
(0,
|
|
35
|
+
(0, import_log.log)(`${cliName} creating ${type}...`, "info", quiet);
|
|
41
36
|
import_LexConfig.LexConfig.parseConfig(cmd, false);
|
|
42
37
|
const { outputPath, sourcePath, useTypescript } = import_LexConfig.LexConfig.config;
|
|
43
38
|
if (useTypescript) {
|
|
@@ -52,7 +47,7 @@ const create = async (type, cmd, callback = () => ({})) => {
|
|
|
52
47
|
}
|
|
53
48
|
case "store": {
|
|
54
49
|
try {
|
|
55
|
-
const { nameCaps, templateExt, templatePath } = (0,
|
|
50
|
+
const { nameCaps, templateExt, templatePath } = (0, import_app.getFilenames)({
|
|
56
51
|
cliName,
|
|
57
52
|
name: outputName,
|
|
58
53
|
quiet,
|
|
@@ -60,23 +55,23 @@ const create = async (type, cmd, callback = () => ({})) => {
|
|
|
60
55
|
useTypescript
|
|
61
56
|
});
|
|
62
57
|
const storePath = `${cwd}/${nameCaps}Store`;
|
|
63
|
-
if (!
|
|
64
|
-
(0,
|
|
65
|
-
|
|
58
|
+
if (!fs.existsSync(storePath)) {
|
|
59
|
+
(0, import_app.copyFolderRecursiveSync)(path.resolve(__dirname, templatePath, "./.SampleStore"), cwd);
|
|
60
|
+
fs.renameSync(`${cwd}/.SampleStore`, storePath);
|
|
66
61
|
const storeTestPath = `${storePath}/${nameCaps}Store.test${templateExt}`;
|
|
67
|
-
|
|
68
|
-
(0,
|
|
62
|
+
fs.renameSync(`${storePath}/SampleStore.test${templateExt}.txt`, storeTestPath);
|
|
63
|
+
(0, import_app.updateTemplateName)(storeTestPath, outputName, nameCaps);
|
|
69
64
|
const storeFilePath = `${storePath}/${nameCaps}Store${templateExt}`;
|
|
70
|
-
|
|
71
|
-
(0,
|
|
65
|
+
fs.renameSync(`${storePath}/SampleStore${templateExt}.txt`, storeFilePath);
|
|
66
|
+
(0, import_app.updateTemplateName)(storeFilePath, outputName, nameCaps);
|
|
72
67
|
} else {
|
|
73
|
-
(0,
|
|
68
|
+
(0, import_log.log)(`
|
|
74
69
|
${cliName} Error: Cannot create new ${type}. Directory, ${storePath} already exists.`, "error", quiet);
|
|
75
70
|
callback(1);
|
|
76
71
|
return 1;
|
|
77
72
|
}
|
|
78
73
|
} catch (error) {
|
|
79
|
-
(0,
|
|
74
|
+
(0, import_log.log)(`
|
|
80
75
|
${cliName} Error: Cannot create new ${type}. ${error.message}`, "error", quiet);
|
|
81
76
|
callback(1);
|
|
82
77
|
return 1;
|
|
@@ -84,17 +79,17 @@ ${cliName} Error: Cannot create new ${type}. ${error.message}`, "error", quiet);
|
|
|
84
79
|
break;
|
|
85
80
|
}
|
|
86
81
|
case "tsconfig": {
|
|
87
|
-
await (0,
|
|
88
|
-
const templatePath =
|
|
89
|
-
let data =
|
|
82
|
+
await (0, import_app.removeFiles)("tsconfig.json", true);
|
|
83
|
+
const templatePath = path.resolve(__dirname, "../../tsconfig.template.json");
|
|
84
|
+
let data = fs.readFileSync(templatePath, "utf8");
|
|
90
85
|
data = data.replace(/.\/src/g, sourcePath);
|
|
91
86
|
data = data.replace(/.\/dist/g, outputPath);
|
|
92
|
-
const destPath =
|
|
93
|
-
|
|
87
|
+
const destPath = path.resolve(cwd, "./tsconfig.json");
|
|
88
|
+
fs.writeFileSync(destPath, data, "utf8");
|
|
94
89
|
break;
|
|
95
90
|
}
|
|
96
91
|
case "view": {
|
|
97
|
-
const { nameCaps, templatePath, templateReact } = (0,
|
|
92
|
+
const { nameCaps, templatePath, templateReact } = (0, import_app.getFilenames)({
|
|
98
93
|
cliName,
|
|
99
94
|
name: outputName,
|
|
100
95
|
quiet,
|
|
@@ -103,26 +98,26 @@ ${cliName} Error: Cannot create new ${type}. ${error.message}`, "error", quiet);
|
|
|
103
98
|
});
|
|
104
99
|
const viewPath = `${cwd}/${nameCaps}View`;
|
|
105
100
|
try {
|
|
106
|
-
if (!
|
|
107
|
-
(0,
|
|
108
|
-
|
|
101
|
+
if (!fs.existsSync(viewPath)) {
|
|
102
|
+
(0, import_app.copyFolderRecursiveSync)(path.resolve(__dirname, templatePath, "./.SampleView"), cwd);
|
|
103
|
+
fs.renameSync(`${cwd}/.SampleView`, viewPath);
|
|
109
104
|
const viewStylePath = `${viewPath}/${outputName}View.css`;
|
|
110
|
-
|
|
111
|
-
(0,
|
|
105
|
+
fs.renameSync(`${viewPath}/sampleView.css`, viewStylePath);
|
|
106
|
+
(0, import_app.updateTemplateName)(viewStylePath, outputName, nameCaps);
|
|
112
107
|
const viewTestPath = `${viewPath}/${nameCaps}View.test${templateReact}`;
|
|
113
|
-
|
|
114
|
-
(0,
|
|
108
|
+
fs.renameSync(`${viewPath}/SampleView.test${templateReact}.txt`, viewTestPath);
|
|
109
|
+
(0, import_app.updateTemplateName)(viewTestPath, outputName, nameCaps);
|
|
115
110
|
const viewFilePath = `${viewPath}/${nameCaps}View${templateReact}`;
|
|
116
|
-
|
|
117
|
-
(0,
|
|
111
|
+
fs.renameSync(`${viewPath}/SampleView${templateReact}.txt`, viewFilePath);
|
|
112
|
+
(0, import_app.updateTemplateName)(viewFilePath, outputName, nameCaps);
|
|
118
113
|
} else {
|
|
119
|
-
(0,
|
|
114
|
+
(0, import_log.log)(`
|
|
120
115
|
${cliName} Error: Cannot create new ${type}. Directory, ${viewPath} already exists.`, "error", quiet);
|
|
121
116
|
callback(1);
|
|
122
117
|
return 1;
|
|
123
118
|
}
|
|
124
119
|
} catch (error) {
|
|
125
|
-
(0,
|
|
120
|
+
(0, import_log.log)(`
|
|
126
121
|
${cliName} Error: Cannot create new ${type}. ${error.message}`, "error", quiet);
|
|
127
122
|
callback(1);
|
|
128
123
|
return 1;
|
|
@@ -130,16 +125,16 @@ ${cliName} Error: Cannot create new ${type}. ${error.message}`, "error", quiet);
|
|
|
130
125
|
break;
|
|
131
126
|
}
|
|
132
127
|
case "vscode": {
|
|
133
|
-
await (0,
|
|
134
|
-
(0,
|
|
128
|
+
await (0, import_app.removeFiles)(".vscode", true);
|
|
129
|
+
(0, import_app.copyFolderRecursiveSync)(path.resolve(__dirname, "../../.vscode"), cwd);
|
|
135
130
|
break;
|
|
136
131
|
}
|
|
137
132
|
}
|
|
138
133
|
callback(0);
|
|
139
134
|
return 0;
|
|
140
135
|
};
|
|
141
|
-
module.exports = __toCommonJS(create_exports);
|
|
142
136
|
// Annotate the CommonJS export names for ESM import in node:
|
|
143
137
|
0 && (module.exports = {
|
|
144
138
|
create
|
|
145
139
|
});
|
|
140
|
+
//# 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 * as fs from 'fs-extra';\nimport * as path from 'path';\n\nimport {createChangelog} from '../create/changelog';\nimport {LexConfig} from '../LexConfig';\nimport {copyFolderRecursiveSync, getFilenames, removeFiles, updateTemplateName} from '../utils/app';\nimport {log} from '../utils/log';\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  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\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(!fs.existsSync(storePath)) {\n          // Copy store files\n          copyFolderRecursiveSync(path.resolve(__dirname, templatePath, './.SampleStore'), cwd);\n\n          // Rename directory\n          fs.renameSync(`${cwd}/.SampleStore`, storePath);\n\n          // Rename test\n          const storeTestPath: string = `${storePath}/${nameCaps}Store.test${templateExt}`;\n          fs.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          fs.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 = path.resolve(__dirname, '../../tsconfig.template.json');\n      let data: string = fs.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 = path.resolve(cwd, './tsconfig.json');\n      fs.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(!fs.existsSync(viewPath)) {\n          // Copy view files\n          copyFolderRecursiveSync(path.resolve(__dirname, templatePath, './.SampleView'), cwd);\n\n          // Rename directory\n          fs.renameSync(`${cwd}/.SampleView`, viewPath);\n\n          // Rename CSS\n          const viewStylePath: string = `${viewPath}/${outputName}View.css`;\n          fs.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          fs.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          fs.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(path.resolve(__dirname, '../../.vscode'), cwd);\n      break;\n    }\n  }\n\n  callback(0);\n  return 0;\n};\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAIA,SAAoB;AACpB,WAAsB;AAEtB,uBAA8B;AAC9B,uBAAwB;AACxB,iBAAqF;AACrF,iBAAkB;AAEX,MAAM,SAAS,OAAO,MAAc,KAAU,WAAgB,MAAO,EAAC,OAAwB;AACnG,QAAM,EAAC,UAAU,OAAO,YAAY,YAAY,UAAS;AACzD,QAAM,MAAc,QAAQ,IAAI;AAChC,sBAAI,GAAG,oBAAoB,WAAW,QAAQ,KAAK;AAGnD,6BAAU,YAAY,KAAK,KAAK;AAChC,QAAM,EAAC,YAAY,YAAY,kBAAiB,2BAAU;AAE1D,MAAG,eAAe;AAEhB,+BAAU,sBAAsB;AAAA,EAClC;AAEA,QAAM,EAAC,WAAU;AAEjB,UAAO;AAAA,SACA,aAAa;AAChB,YAAM,kBAA0B,MAAM,sCAAgB,EAAC,SAAS,QAAQ,YAAY,MAAK,CAAC;AAC1F,eAAS,eAAe;AACxB,aAAO;AAAA,IACT;AAAA,SACK,SAAS;AACZ,UAAI;AACF,cAAM,EAAC,UAAU,aAAa,iBAAgB,6BAAa;AAAA,UACzD;AAAA,UACA,MAAM;AAAA,UACN;AAAA,UACA;AAAA,UACA;AAAA,QACF,CAAC;AACD,cAAM,YAAoB,GAAG,OAAO;AAEpC,YAAG,CAAC,GAAG,WAAW,SAAS,GAAG;AAE5B,kDAAwB,KAAK,QAAQ,WAAW,cAAc,gBAAgB,GAAG,GAAG;AAGpF,aAAG,WAAW,GAAG,oBAAoB,SAAS;AAG9C,gBAAM,gBAAwB,GAAG,aAAa,qBAAqB;AACnE,aAAG,WAAW,GAAG,6BAA6B,mBAAmB,aAAa;AAG9E,6CAAmB,eAAe,YAAY,QAAQ;AAGtD,gBAAM,gBAAwB,GAAG,aAAa,gBAAgB;AAC9D,aAAG,WAAW,GAAG,wBAAwB,mBAAmB,aAAa;AAGzE,6CAAmB,eAAe,YAAY,QAAQ;AAAA,QACxD,OAAO;AACL,8BAAI;AAAA,EAAK,oCAAoC,oBAAoB,6BAA6B,SAAS,KAAK;AAC5G,mBAAS,CAAC;AACV,iBAAO;AAAA,QACT;AAAA,MACF,SAAQ,OAAN;AACA,4BAAI;AAAA,EAAK,oCAAoC,SAAS,MAAM,WAAW,SAAS,KAAK;AACrF,iBAAS,CAAC;AACV,eAAO;AAAA,MACT;AACA;AAAA,IACF;AAAA,SACK,YAAY;AAEf,YAAM,4BAAY,iBAAiB,IAAI;AAGvC,YAAM,eAAuB,KAAK,QAAQ,WAAW,8BAA8B;AACnF,UAAI,OAAe,GAAG,aAAa,cAAc,MAAM;AAGvD,aAAO,KAAK,QAAQ,WAAW,UAAU;AACzC,aAAO,KAAK,QAAQ,YAAY,UAAU;AAG1C,YAAM,WAAmB,KAAK,QAAQ,KAAK,iBAAiB;AAC5D,SAAG,cAAc,UAAU,MAAM,MAAM;AACvC;AAAA,IACF;AAAA,SACK,QAAQ;AACX,YAAM,EAAC,UAAU,cAAc,kBAAiB,6BAAa;AAAA,QAC3D;AAAA,QACA,MAAM;AAAA,QACN;AAAA,QACA;AAAA,QACA;AAAA,MACF,CAAC;AACD,YAAM,WAAmB,GAAG,OAAO;AAEnC,UAAI;AACF,YAAG,CAAC,GAAG,WAAW,QAAQ,GAAG;AAE3B,kDAAwB,KAAK,QAAQ,WAAW,cAAc,eAAe,GAAG,GAAG;AAGnF,aAAG,WAAW,GAAG,mBAAmB,QAAQ;AAG5C,gBAAM,gBAAwB,GAAG,YAAY;AAC7C,aAAG,WAAW,GAAG,2BAA2B,aAAa;AAGzD,6CAAmB,eAAe,YAAY,QAAQ;AAGtD,gBAAM,eAAuB,GAAG,YAAY,oBAAoB;AAChE,aAAG,WAAW,GAAG,2BAA2B,qBAAqB,YAAY;AAG7E,6CAAmB,cAAc,YAAY,QAAQ;AAGrD,gBAAM,eAAuB,GAAG,YAAY,eAAe;AAC3D,aAAG,WAAW,GAAG,sBAAsB,qBAAqB,YAAY;AAGxE,6CAAmB,cAAc,YAAY,QAAQ;AAAA,QACvD,OAAO;AACL,8BAAI;AAAA,EAAK,oCAAoC,oBAAoB,4BAA4B,SAAS,KAAK;AAC3G,mBAAS,CAAC;AACV,iBAAO;AAAA,QACT;AAAA,MACF,SAAQ,OAAN;AACA,4BAAI;AAAA,EAAK,oCAAoC,SAAS,MAAM,WAAW,SAAS,KAAK;AACrF,iBAAS,CAAC;AACV,eAAO;AAAA,MACT;AACA;AAAA,IACF;AAAA,SACK,UAAU;AAEb,YAAM,4BAAY,WAAW,IAAI;AAGjC,8CAAwB,KAAK,QAAQ,WAAW,eAAe,GAAG,GAAG;AACrE;AAAA,IACF;AAAA;AAGF,WAAS,CAAC;AACV,SAAO;AACT;",
  "names": []
}

|
package/dist/commands/dev.js
CHANGED
|
@@ -2,55 +2,37 @@ var __create = Object.create;
|
|
|
2
2
|
var __defProp = Object.defineProperty;
|
|
3
3
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
4
|
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
6
5
|
var __getProtoOf = Object.getPrototypeOf;
|
|
7
6
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
-
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
9
|
-
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
10
|
-
var __spreadValues = (a, b) => {
|
|
11
|
-
for (var prop in b || (b = {}))
|
|
12
|
-
if (__hasOwnProp.call(b, prop))
|
|
13
|
-
__defNormalProp(a, prop, b[prop]);
|
|
14
|
-
if (__getOwnPropSymbols)
|
|
15
|
-
for (var prop of __getOwnPropSymbols(b)) {
|
|
16
|
-
if (__propIsEnum.call(b, prop))
|
|
17
|
-
__defNormalProp(a, prop, b[prop]);
|
|
18
|
-
}
|
|
19
|
-
return a;
|
|
20
|
-
};
|
|
21
|
-
var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
|
|
22
7
|
var __export = (target, all) => {
|
|
23
8
|
for (var name in all)
|
|
24
9
|
__defProp(target, name, { get: all[name], enumerable: true });
|
|
25
10
|
};
|
|
26
|
-
var
|
|
27
|
-
if (
|
|
28
|
-
for (let key of __getOwnPropNames(
|
|
29
|
-
if (!__hasOwnProp.call(
|
|
30
|
-
__defProp(
|
|
11
|
+
var __copyProps = (to, from, except, desc) => {
|
|
12
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
+
for (let key of __getOwnPropNames(from))
|
|
14
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
15
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
31
16
|
}
|
|
32
|
-
return
|
|
33
|
-
};
|
|
34
|
-
var __toESM = (module2, isNodeMode) => {
|
|
35
|
-
return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", !isNodeMode && module2 && module2.__esModule ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
|
|
17
|
+
return to;
|
|
36
18
|
};
|
|
37
|
-
var
|
|
38
|
-
|
|
39
|
-
return cache && cache.get(module2) || (temp = __reExport(__markAsModule({}), module2, 1), cache && cache.set(module2, temp), temp);
|
|
40
|
-
};
|
|
41
|
-
})(typeof WeakMap !== "undefined" ? /* @__PURE__ */ new WeakMap() : 0);
|
|
19
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod));
|
|
20
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
42
21
|
var dev_exports = {};
|
|
43
22
|
__export(dev_exports, {
|
|
44
23
|
dev: () => dev
|
|
45
24
|
});
|
|
25
|
+
module.exports = __toCommonJS(dev_exports);
|
|
46
26
|
var import_execa = __toESM(require("execa"));
|
|
47
27
|
var path = __toESM(require("path"));
|
|
48
28
|
var import_LexConfig = require("../LexConfig");
|
|
49
|
-
var
|
|
29
|
+
var import_app = require("../utils/app");
|
|
30
|
+
var import_file = require("../utils/file");
|
|
31
|
+
var import_log = require("../utils/log");
|
|
50
32
|
const dev = async (cmd, callback = () => ({})) => {
|
|
51
|
-
const { bundleAnalyzer, cliName = "Lex", config, open = false, quiet, remove, variables
|
|
52
|
-
const spinner = (0,
|
|
53
|
-
(0,
|
|
33
|
+
const { bundleAnalyzer, cliName = "Lex", config, open = false, quiet, remove, variables } = cmd;
|
|
34
|
+
const spinner = (0, import_app.createSpinner)(quiet);
|
|
35
|
+
(0, import_log.log)(`${cliName} start development server...`, "info", quiet);
|
|
54
36
|
import_LexConfig.LexConfig.parseConfig(cmd);
|
|
55
37
|
const { outputFullPath, useTypescript } = import_LexConfig.LexConfig.config;
|
|
56
38
|
let variablesObj = { NODE_ENV: "development" };
|
|
@@ -58,19 +40,19 @@ const dev = async (cmd, callback = () => ({})) => {
|
|
|
58
40
|
try {
|
|
59
41
|
variablesObj = JSON.parse(variables);
|
|
60
42
|
} catch (error) {
|
|
61
|
-
(0,
|
|
43
|
+
(0, import_log.log)(`
|
|
62
44
|
${cliName} Error: Environment variables option is not a valid JSON object.`, "error", quiet);
|
|
63
45
|
callback(1);
|
|
64
46
|
return 1;
|
|
65
47
|
}
|
|
66
48
|
}
|
|
67
|
-
process.env =
|
|
49
|
+
process.env = { ...process.env, ...variablesObj };
|
|
68
50
|
if (useTypescript) {
|
|
69
51
|
import_LexConfig.LexConfig.checkTypescriptConfig();
|
|
70
52
|
}
|
|
71
53
|
if (remove) {
|
|
72
54
|
spinner.start("Cleaning output directory...");
|
|
73
|
-
await (0,
|
|
55
|
+
await (0, import_app.removeFiles)(outputFullPath);
|
|
74
56
|
spinner.succeed("Successfully cleaned output directory!");
|
|
75
57
|
}
|
|
76
58
|
const webpackConfig = config || path.resolve(__dirname, "../../webpack.config.js");
|
|
@@ -85,7 +67,7 @@ ${cliName} Error: Environment variables option is not a valid JSON object.`, "er
|
|
|
85
67
|
}
|
|
86
68
|
try {
|
|
87
69
|
const nodePath = path.resolve(__dirname, "../../node_modules");
|
|
88
|
-
const webpackPath = (0,
|
|
70
|
+
const webpackPath = (0, import_file.relativeFilePath)("webpack-cli/bin/cli.js", nodePath);
|
|
89
71
|
await (0, import_execa.default)(webpackPath, webpackOptions, {
|
|
90
72
|
encoding: "utf-8",
|
|
91
73
|
env: {
|
|
@@ -98,15 +80,15 @@ ${cliName} Error: Environment variables option is not a valid JSON object.`, "er
|
|
|
98
80
|
callback(0);
|
|
99
81
|
return 0;
|
|
100
82
|
} catch (error) {
|
|
101
|
-
(0,
|
|
83
|
+
(0, import_log.log)(`
|
|
102
84
|
${cliName} Error: ${error.message}`, "error", quiet);
|
|
103
85
|
spinner.fail("There was an error while running Webpack.");
|
|
104
86
|
callback(error.status);
|
|
105
87
|
return error.status;
|
|
106
88
|
}
|
|
107
89
|
};
|
|
108
|
-
module.exports = __toCommonJS(dev_exports);
|
|
109
90
|
// Annotate the CommonJS export names for ESM import in node:
|
|
110
91
|
0 && (module.exports = {
|
|
111
92
|
dev
|
|
112
93
|
});
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2Rldi50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTgtUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmltcG9ydCB7ZGVmYXVsdCBhcyBleGVjYX0gZnJvbSAnZXhlY2EnO1xuaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcblxuaW1wb3J0IHtMZXhDb25maWd9IGZyb20gJy4uL0xleENvbmZpZyc7XG5pbXBvcnQge2NyZWF0ZVNwaW5uZXIsIHJlbW92ZUZpbGVzfSBmcm9tICcuLi91dGlscy9hcHAnO1xuaW1wb3J0IHtyZWxhdGl2ZUZpbGVQYXRofSBmcm9tICcuLi91dGlscy9maWxlJztcbmltcG9ydCB7bG9nfSBmcm9tICcuLi91dGlscy9sb2cnO1xuXG5leHBvcnQgY29uc3QgZGV2ID0gYXN5bmMgKGNtZDogYW55LCBjYWxsYmFjazogYW55ID0gKCkgPT4gKHt9KSk6IFByb21pc2U8bnVtYmVyPiA9PiB7XG4gIGNvbnN0IHtidW5kbGVBbmFseXplciwgY2xpTmFtZSA9ICdMZXgnLCBjb25maWcsIG9wZW4gPSBmYWxzZSwgcXVpZXQsIHJlbW92ZSwgdmFyaWFibGVzfSA9IGNtZDtcblxuICAvLyBTcGlubmVyXG4gIGNvbnN0IHNwaW5uZXIgPSBjcmVhdGVTcGlubmVyKHF1aWV0KTtcblxuICAvLyBEaXNwbGF5IHN0YXR1c1xuICBsb2coYCR7Y2xpTmFtZX0gc3RhcnQgZGV2ZWxvcG1lbnQgc2VydmVyLi4uYCwgJ2luZm8nLCBxdWlldCk7XG5cbiAgLy8gR2V0IGN1c3RvbSBjb25maWd1cmF0aW9uXG4gIExleENvbmZpZy5wYXJzZUNvbmZpZyhjbWQpO1xuXG4gIGNvbnN0IHtvdXRwdXRGdWxsUGF0aCwgdXNlVHlwZXNjcmlwdH0gPSBMZXhDb25maWcuY29uZmlnO1xuXG4gIC8vIFNldCBub2RlIGVudmlyb25tZW50IHZhcmlhYmxlc1xuICBsZXQgdmFyaWFibGVzT2JqOiBvYmplY3QgPSB7Tk9ERV9FTlY6ICdkZXZlbG9wbWVudCd9O1xuXG4gIGlmKHZhcmlhYmxlcykge1xuICAgIHRyeSB7XG4gICAgICB2YXJpYWJsZXNPYmogPSBKU09OLnBhcnNlKHZhcmlhYmxlcyk7XG4gICAgfSBjYXRjaChlcnJvcikge1xuICAgICAgbG9nKGBcXG4ke2NsaU5hbWV9IEVycm9yOiBFbnZpcm9ubWVudCB2YXJpYWJsZXMgb3B0aW9uIGlzIG5vdCBhIHZhbGlkIEpTT04gb2JqZWN0LmAsICdlcnJvcicsIHF1aWV0KTtcbiAgICAgIGNhbGxiYWNrKDEpO1xuICAgICAgcmV0dXJuIDE7XG4gICAgfVxuICB9XG5cbiAgcHJvY2Vzcy5lbnYgPSB7Li4ucHJvY2Vzcy5lbnYsIC4uLnZhcmlhYmxlc09ian07XG5cbiAgaWYodXNlVHlwZXNjcmlwdCkge1xuICAgIC8vIE1ha2Ugc3VyZSB0c2NvbmZpZy5qc29uIGV4aXN0c1xuICAgIExleENvbmZpZy5jaGVja1R5cGVzY3JpcHRDb25maWcoKTtcbiAgfVxuXG4gIC8vIENsZWFuIG91dHB1dCBkaXJlY3RvcnkgYmVmb3JlIHdlIHN0YXJ0IGFkZGluZyBpbiBuZXcgZmlsZXNcbiAgaWYocmVtb3ZlKSB7XG4gICAgLy8gU3RhcnQgY2xlYW5pbmcgc3Bpbm5lclxuICAgIHNwaW5uZXIuc3RhcnQoJ0NsZWFuaW5nIG91dHB1dCBkaXJlY3RvcnkuLi4nKTtcblxuICAgIC8vIENsZWFuXG4gICAgYXdhaXQgcmVtb3ZlRmlsZXMob3V0cHV0RnVsbFBhdGgpO1xuXG4gICAgLy8gU3RvcCBzcGlubmVyXG4gICAgc3Bpbm5lci5zdWNjZWVkKCdTdWNjZXNzZnVsbHkgY2xlYW5lZCBvdXRwdXQgZGlyZWN0b3J5IScpO1xuICB9XG5cbiAgLy8gR2V0IGN1c3RvbSB3ZWJwYWNrIGNvbmZpZ3VyYXRpb24gZmlsZVxuICBjb25zdCB3ZWJwYWNrQ29uZmlnOiBzdHJpbmcgPSBjb25maWcgfHwgcGF0aC5yZXNvbHZlKF9fZGlybmFtZSwgJy4uLy4uL3dlYnBhY2suY29uZmlnLmpzJyk7XG5cbiAgLy8gQ29tcGlsZSB1c2luZyB3ZWJwYWNrXG4gIGNvbnN0IHdlYnBhY2tPcHRpb25zOiBzdHJpbmdbXSA9IFtcbiAgICAnLS1jb2xvcicsXG4gICAgJy0td2F0Y2gnLFxuICAgICctLWNvbmZpZycsIHdlYnBhY2tDb25maWdcbiAgXTtcblxuICBpZihidW5kbGVBbmFseXplcikge1xuICAgIHdlYnBhY2tPcHRpb25zLnB1c2goJy0tYnVuZGxlQW5hbHl6ZXInKTtcbiAgfVxuXG4gIC8vIFN0YXJ0IGRldmVsb3BtZW50IHNwaW5uZXJcbiAgdHJ5IHtcbiAgICBjb25zdCBub2RlUGF0aDogc3RyaW5nID0gcGF0aC5yZXNvbHZlKF9fZGlybmFtZSwgJy4uLy4uL25vZGVfbW9kdWxlcycpO1xuICAgIGNvbnN0IHdlYnBhY2tQYXRoOiBzdHJpbmcgPSByZWxhdGl2ZUZpbGVQYXRoKCd3ZWJwYWNrLWNsaS9iaW4vY2xpLmpzJywgbm9kZVBhdGgpO1xuICAgIGF3YWl0IGV4ZWNhKHdlYnBhY2tQYXRoLCB3ZWJwYWNrT3B0aW9ucywge1xuICAgICAgZW5jb2Rpbmc6ICd1dGYtOCcsXG4gICAgICBlbnY6IHtcbiAgICAgICAgTEVYX1FVSUVUOiBxdWlldCxcbiAgICAgICAgV0VCUEFDS19ERVZfT1BFTjogb3BlblxuICAgICAgfSxcbiAgICAgIHN0ZGlvOiAnaW5oZXJpdCdcbiAgICB9KTtcblxuICAgIC8vIFN0b3Agc3Bpbm5lclxuICAgIHNwaW5uZXIuc3VjY2VlZCgnRGV2ZWxvcG1lbnQgc2VydmVyIHN0YXJ0ZWQuJyk7XG5cbiAgICBjYWxsYmFjaygwKTtcbiAgICByZXR1cm4gMDtcbiAgfSBjYXRjaChlcnJvcikge1xuICAgIC8vIERpc3BsYXkgZXJyb3IgbWVzc2FnZVxuICAgIGxvZyhgXFxuJHtjbGlOYW1lfSBFcnJvcjogJHtlcnJvci5tZXNzYWdlfWAsICdlcnJvcicsIHF1aWV0KTtcblxuICAgIC8vIFN0b3Agc3Bpbm5lclxuICAgIHNwaW5uZXIuZmFpbCgnVGhlcmUgd2FzIGFuIGVycm9yIHdoaWxlIHJ1bm5pbmcgV2VicGFjay4nKTtcblxuICAgIC8vIEtpbGwgcHJvY2Vzc1xuICAgIGNhbGxiYWNrKGVycm9yLnN0YXR1cyk7XG4gICAgcmV0dXJuIGVycm9yLnN0YXR1cztcbiAgfVxufTtcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUlBLG1CQUErQjtBQUMvQixXQUFzQjtBQUV0Qix1QkFBd0I7QUFDeEIsaUJBQXlDO0FBQ3pDLGtCQUErQjtBQUMvQixpQkFBa0I7QUFFWCxNQUFNLE1BQU0sT0FBTyxLQUFVLFdBQWdCLE1BQU8sRUFBQyxPQUF3QjtBQUNsRixRQUFNLEVBQUMsZ0JBQWdCLFVBQVUsT0FBTyxRQUFRLE9BQU8sT0FBTyxPQUFPLFFBQVEsY0FBYTtBQUcxRixRQUFNLFVBQVUsOEJBQWMsS0FBSztBQUduQyxzQkFBSSxHQUFHLHVDQUF1QyxRQUFRLEtBQUs7QUFHM0QsNkJBQVUsWUFBWSxHQUFHO0FBRXpCLFFBQU0sRUFBQyxnQkFBZ0Isa0JBQWlCLDJCQUFVO0FBR2xELE1BQUksZUFBdUIsRUFBQyxVQUFVLGNBQWE7QUFFbkQsTUFBRyxXQUFXO0FBQ1osUUFBSTtBQUNGLHFCQUFlLEtBQUssTUFBTSxTQUFTO0FBQUEsSUFDckMsU0FBUSxPQUFOO0FBQ0EsMEJBQUk7QUFBQSxFQUFLLDJFQUEyRSxTQUFTLEtBQUs7QUFDbEcsZUFBUyxDQUFDO0FBQ1YsYUFBTztBQUFBLElBQ1Q7QUFBQSxFQUNGO0FBRUEsVUFBUSxNQUFNLEVBQUMsR0FBRyxRQUFRLEtBQUssR0FBRyxhQUFZO0FBRTlDLE1BQUcsZUFBZTtBQUVoQiwrQkFBVSxzQkFBc0I7QUFBQSxFQUNsQztBQUdBLE1BQUcsUUFBUTtBQUVULFlBQVEsTUFBTSw4QkFBOEI7QUFHNUMsVUFBTSw0QkFBWSxjQUFjO0FBR2hDLFlBQVEsUUFBUSx3Q0FBd0M7QUFBQSxFQUMxRDtBQUdBLFFBQU0sZ0JBQXdCLFVBQVUsS0FBSyxRQUFRLFdBQVcseUJBQXlCO0FBR3pGLFFBQU0saUJBQTJCO0FBQUEsSUFDL0I7QUFBQSxJQUNBO0FBQUEsSUFDQTtBQUFBLElBQVk7QUFBQSxFQUNkO0FBRUEsTUFBRyxnQkFBZ0I7QUFDakIsbUJBQWUsS0FBSyxrQkFBa0I7QUFBQSxFQUN4QztBQUdBLE1BQUk7QUFDRixVQUFNLFdBQW1CLEtBQUssUUFBUSxXQUFXLG9CQUFvQjtBQUNyRSxVQUFNLGNBQXNCLGtDQUFpQiwwQkFBMEIsUUFBUTtBQUMvRSxVQUFNLDBCQUFNLGFBQWEsZ0JBQWdCO0FBQUEsTUFDdkMsVUFBVTtBQUFBLE1BQ1YsS0FBSztBQUFBLFFBQ0gsV0FBVztBQUFBLFFBQ1gsa0JBQWtCO0FBQUEsTUFDcEI7QUFBQSxNQUNBLE9BQU87QUFBQSxJQUNULENBQUM7QUFHRCxZQUFRLFFBQVEsNkJBQTZCO0FBRTdDLGFBQVMsQ0FBQztBQUNWLFdBQU87QUFBQSxFQUNULFNBQVEsT0FBTjtBQUVBLHdCQUFJO0FBQUEsRUFBSyxrQkFBa0IsTUFBTSxXQUFXLFNBQVMsS0FBSztBQUcxRCxZQUFRLEtBQUssMkNBQTJDO0FBR3hELGFBQVMsTUFBTSxNQUFNO0FBQ3JCLFdBQU8sTUFBTTtBQUFBLEVBQ2Y7QUFDRjsiLAogICJuYW1lcyI6IFtdCn0K
|
package/dist/commands/index.js
CHANGED
|
@@ -2,24 +2,19 @@ var __defProp = Object.defineProperty;
|
|
|
2
2
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
3
|
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
4
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
-
var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
|
|
6
5
|
var __export = (target, all) => {
|
|
7
6
|
for (var name in all)
|
|
8
7
|
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
8
|
};
|
|
10
|
-
var
|
|
11
|
-
if (
|
|
12
|
-
for (let key of __getOwnPropNames(
|
|
13
|
-
if (!__hasOwnProp.call(
|
|
14
|
-
__defProp(
|
|
9
|
+
var __copyProps = (to, from, except, desc) => {
|
|
10
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
11
|
+
for (let key of __getOwnPropNames(from))
|
|
12
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
13
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
14
|
}
|
|
16
|
-
return
|
|
15
|
+
return to;
|
|
17
16
|
};
|
|
18
|
-
var __toCommonJS =
|
|
19
|
-
return (module2, temp) => {
|
|
20
|
-
return cache && cache.get(module2) || (temp = __reExport(__markAsModule({}), module2, 1), cache && cache.set(module2, temp), temp);
|
|
21
|
-
};
|
|
22
|
-
})(typeof WeakMap !== "undefined" ? /* @__PURE__ */ new WeakMap() : 0);
|
|
17
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
23
18
|
var commands_exports = {};
|
|
24
19
|
__export(commands_exports, {
|
|
25
20
|
build: () => import_build.build,
|
|
@@ -38,6 +33,7 @@ __export(commands_exports, {
|
|
|
38
33
|
upgrade: () => import_upgrade.upgrade,
|
|
39
34
|
versions: () => import_versions.versions
|
|
40
35
|
});
|
|
36
|
+
module.exports = __toCommonJS(commands_exports);
|
|
41
37
|
var import_build = require("./build");
|
|
42
38
|
var import_clean = require("./clean");
|
|
43
39
|
var import_compile = require("./compile");
|
|
@@ -53,7 +49,6 @@ var import_test = require("./test");
|
|
|
53
49
|
var import_update = require("./update");
|
|
54
50
|
var import_upgrade = require("./upgrade");
|
|
55
51
|
var import_versions = require("./versions");
|
|
56
|
-
module.exports = __toCommonJS(commands_exports);
|
|
57
52
|
// Annotate the CommonJS export names for ESM import in node:
|
|
58
53
|
0 && (module.exports = {
|
|
59
54
|
build,
|
|
@@ -72,3 +67,4 @@ module.exports = __toCommonJS(commands_exports);
|
|
|
72
67
|
upgrade,
|
|
73
68
|
versions
|
|
74
69
|
});
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2luZGV4LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuZXhwb3J0IHtidWlsZH0gZnJvbSAnLi9idWlsZCc7XG5leHBvcnQge2NsZWFufSBmcm9tICcuL2NsZWFuJztcbmV4cG9ydCB7Y29tcGlsZX0gZnJvbSAnLi9jb21waWxlJztcbmV4cG9ydCB7Y29uZmlnfSBmcm9tICcuL2NvbmZpZyc7XG5leHBvcnQge2NyZWF0ZX0gZnJvbSAnLi9jcmVhdGUnO1xuZXhwb3J0IHtkZXZ9IGZyb20gJy4vZGV2JztcbmV4cG9ydCB7aW5pdH0gZnJvbSAnLi9pbml0JztcbmV4cG9ydCB7bGlua2VkfSBmcm9tICcuL2xpbmsnO1xuZXhwb3J0IHtsaW50fSBmcm9tICcuL2xpbnQnO1xuZXhwb3J0IHttaWdyYXRlfSBmcm9tICcuL21pZ3JhdGUnO1xuZXhwb3J0IHtwdWJsaXNofSBmcm9tICcuL3B1Ymxpc2gnO1xuZXhwb3J0IHt0ZXN0fSBmcm9tICcuL3Rlc3QnO1xuZXhwb3J0IHt1cGRhdGV9IGZyb20gJy4vdXBkYXRlJztcbmV4cG9ydCB7dXBncmFkZX0gZnJvbSAnLi91cGdyYWRlJztcbmV4cG9ydCB7dmVyc2lvbnN9IGZyb20gJy4vdmVyc2lvbnMnO1xuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUlBLG1CQUFvQjtBQUNwQixtQkFBb0I7QUFDcEIscUJBQXNCO0FBQ3RCLG9CQUFxQjtBQUNyQixvQkFBcUI7QUFDckIsaUJBQWtCO0FBQ2xCLGtCQUFtQjtBQUNuQixrQkFBcUI7QUFDckIsa0JBQW1CO0FBQ25CLHFCQUFzQjtBQUN0QixxQkFBc0I7QUFDdEIsa0JBQW1CO0FBQ25CLG9CQUFxQjtBQUNyQixxQkFBc0I7QUFDdEIsc0JBQXVCOyIsCiAgIm5hbWVzIjogW10KfQo=
|
package/dist/commands/init.js
CHANGED
|
@@ -4,41 +4,36 @@ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
|
4
4
|
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
5
|
var __getProtoOf = Object.getPrototypeOf;
|
|
6
6
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
-
var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
|
|
8
7
|
var __export = (target, all) => {
|
|
9
8
|
for (var name in all)
|
|
10
9
|
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
10
|
};
|
|
12
|
-
var
|
|
13
|
-
if (
|
|
14
|
-
for (let key of __getOwnPropNames(
|
|
15
|
-
if (!__hasOwnProp.call(
|
|
16
|
-
__defProp(
|
|
11
|
+
var __copyProps = (to, from, except, desc) => {
|
|
12
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
+
for (let key of __getOwnPropNames(from))
|
|
14
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
15
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
16
|
}
|
|
18
|
-
return
|
|
17
|
+
return to;
|
|
19
18
|
};
|
|
20
|
-
var __toESM = (
|
|
21
|
-
|
|
22
|
-
};
|
|
23
|
-
var __toCommonJS = /* @__PURE__ */ ((cache) => {
|
|
24
|
-
return (module2, temp) => {
|
|
25
|
-
return cache && cache.get(module2) || (temp = __reExport(__markAsModule({}), module2, 1), cache && cache.set(module2, temp), temp);
|
|
26
|
-
};
|
|
27
|
-
})(typeof WeakMap !== "undefined" ? /* @__PURE__ */ new WeakMap() : 0);
|
|
19
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod));
|
|
20
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
28
21
|
var init_exports = {};
|
|
29
22
|
__export(init_exports, {
|
|
30
23
|
init: () => init
|
|
31
24
|
});
|
|
25
|
+
module.exports = __toCommonJS(init_exports);
|
|
32
26
|
var import_execa = __toESM(require("execa"));
|
|
33
|
-
var fs = __toESM(require("fs"));
|
|
27
|
+
var fs = __toESM(require("fs-extra"));
|
|
34
28
|
var path = __toESM(require("path"));
|
|
35
29
|
var import_LexConfig = require("../LexConfig");
|
|
36
|
-
var
|
|
30
|
+
var import_app = require("../utils/app");
|
|
31
|
+
var import_log = require("../utils/log");
|
|
37
32
|
const init = async (appName, packageName, cmd, callback = () => ({})) => {
|
|
38
33
|
const { cliName = "Lex", install, packageManager: cmdPackageManager, quiet, typescript } = cmd;
|
|
39
34
|
const cwd = process.cwd();
|
|
40
|
-
const spinner = (0,
|
|
41
|
-
(0,
|
|
35
|
+
const spinner = (0, import_app.createSpinner)(quiet);
|
|
36
|
+
(0, import_log.log)(`${cliName} is downloading the app module...`, "info", quiet);
|
|
42
37
|
spinner.start("Downloading app...");
|
|
43
38
|
const tmpPath = path.resolve(cwd, "./.lexTmp");
|
|
44
39
|
const appPath = path.resolve(cwd, `./${appName}`);
|
|
@@ -60,7 +55,7 @@ const init = async (appName, packageName, cmd, callback = () => ({})) => {
|
|
|
60
55
|
spinner.succeed("Successfully downloaded app!");
|
|
61
56
|
} catch (error) {
|
|
62
57
|
console.log("error", error);
|
|
63
|
-
(0,
|
|
58
|
+
(0, import_log.log)(`
|
|
64
59
|
${cliName} Error: There was an error downloading ${appModule}. Make sure the package exists and there is a network connection.`, "error", quiet);
|
|
65
60
|
spinner.fail("Downloaded of app failed.");
|
|
66
61
|
callback(error.status);
|
|
@@ -69,13 +64,13 @@ ${cliName} Error: There was an error downloading ${appModule}. Make sure the pac
|
|
|
69
64
|
try {
|
|
70
65
|
fs.renameSync(`${tmpPath}/${appModule}`, appPath);
|
|
71
66
|
} catch (error) {
|
|
72
|
-
(0,
|
|
67
|
+
(0, import_log.log)(`
|
|
73
68
|
${cliName} Error: There was an error copying ${appModule} to the current working directory.`, "error", quiet);
|
|
74
69
|
callback(error.status);
|
|
75
70
|
return error.status;
|
|
76
71
|
}
|
|
77
72
|
const packagePath = `${appPath}/package.json`;
|
|
78
|
-
const packageJson = (0,
|
|
73
|
+
const packageJson = (0, import_app.getPackageJson)(packagePath);
|
|
79
74
|
packageJson.name = appName;
|
|
80
75
|
packageJson.description = `${cliName} created app`;
|
|
81
76
|
packageJson.version = "0.1.0";
|
|
@@ -86,11 +81,11 @@ ${cliName} Error: There was an error copying ${appModule} to the current working
|
|
|
86
81
|
delete packageJson.homepage;
|
|
87
82
|
delete packageJson.bugs;
|
|
88
83
|
try {
|
|
89
|
-
(0,
|
|
84
|
+
(0, import_app.setPackageJson)(packageJson, packagePath);
|
|
90
85
|
const readmePath = `${appPath}/README.md`;
|
|
91
86
|
fs.writeFileSync(readmePath, `# ${appName}`);
|
|
92
87
|
} catch (error) {
|
|
93
|
-
(0,
|
|
88
|
+
(0, import_log.log)(`
|
|
94
89
|
${cliName} Error: ${error.message}`, "error", quiet);
|
|
95
90
|
callback(error.status);
|
|
96
91
|
return error.status;
|
|
@@ -105,7 +100,7 @@ ${cliName} Error: ${error.message}`, "error", quiet);
|
|
|
105
100
|
});
|
|
106
101
|
spinner.succeed("Successfully installed dependencies!");
|
|
107
102
|
} catch (error) {
|
|
108
|
-
(0,
|
|
103
|
+
(0, import_log.log)(`
|
|
109
104
|
${cliName} Error: ${error.message}`, "error", quiet);
|
|
110
105
|
spinner.fail("Failed to install dependencies.");
|
|
111
106
|
callback(error.status);
|
|
@@ -115,8 +110,8 @@ ${cliName} Error: ${error.message}`, "error", quiet);
|
|
|
115
110
|
callback(0);
|
|
116
111
|
return 0;
|
|
117
112
|
};
|
|
118
|
-
module.exports = __toCommonJS(init_exports);
|
|
119
113
|
// Annotate the CommonJS export names for ESM import in node:
|
|
120
114
|
0 && (module.exports = {
|
|
121
115
|
init
|
|
122
116
|
});
|
|
117
|
+
//# 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 {default as execa} from 'execa';\nimport * as fs from 'fs-extra';\nimport * as path from 'path';\n\nimport {LexConfig} from '../LexConfig';\nimport {createSpinner, getPackageJson, setPackageJson} from '../utils/app';\nimport {log} from '../utils/log';\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 = path.resolve(cwd, './.lexTmp');\n  const appPath: string = path.resolve(cwd, `./${appName}`);\n  const dnpPath: string = path.resolve(__dirname, '../../node_modules/download-npm-package/bin/cli.js');\n\n  // Get custom configuration\n  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(error.status);\n    return error.status;\n  }\n\n  // Move into configured directory\n  try {\n    fs.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(error.status);\n    return error.status;\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    fs.writeFileSync(readmePath, `# ${appName}`);\n  } catch(error) {\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n    callback(error.status);\n    return error.status;\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: 'utf-8',\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(error.status);\n      return error.status;\n    }\n  }\n\n  // Kill process\n  callback(0);\n  return 0;\n};\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAIA,mBAA+B;AAC/B,SAAoB;AACpB,WAAsB;AAEtB,uBAAwB;AACxB,iBAA4D;AAC5D,iBAAkB;AAEX,MAAM,OAAO,OAClB,SACA,aACA,KACA,WAAgB,MAAO,EAAC,OACJ;AACpB,QAAM,EAAC,UAAU,OAAO,SAAS,gBAAgB,mBAAmB,OAAO,eAAc;AACzF,QAAM,MAAc,QAAQ,IAAI;AAGhC,QAAM,UAAU,8BAAc,KAAK;AAGnC,sBAAI,GAAG,4CAA4C,QAAQ,KAAK;AAChE,UAAQ,MAAM,oBAAoB;AAClC,QAAM,UAAkB,KAAK,QAAQ,KAAK,WAAW;AACrD,QAAM,UAAkB,KAAK,QAAQ,KAAK,KAAK,SAAS;AACxD,QAAM,UAAkB,KAAK,QAAQ,WAAW,oDAAoD;AAGpG,6BAAU,YAAY,GAAG;AACzB,QAAM,EAAC,gBAAgB,sBAAsB,eAAe,qBAAoB,2BAAU;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,0BAAM,SAAS,CAAC,WAAW,OAAO,GAAG,CAAC,CAAC;AAG7C,YAAQ,QAAQ,8BAA8B;AAAA,EAChD,SAAQ,OAAN;AACA,YAAQ,IAAI,SAAS,KAAK;AAC1B,wBAAI;AAAA,EAAK,iDAAiD,8EAA8E,SAAS,KAAK;AAGtJ,YAAQ,KAAK,2BAA2B;AAGxC,aAAS,MAAM,MAAM;AACrB,WAAO,MAAM;AAAA,EACf;AAGA,MAAI;AACF,OAAG,WAAW,GAAG,WAAW,aAAa,OAAO;AAAA,EAClD,SAAQ,OAAN;AACA,wBAAI;AAAA,EAAK,6CAA6C,+CAA+C,SAAS,KAAK;AACnH,aAAS,MAAM,MAAM;AACrB,WAAO,MAAM;AAAA,EACf;AAGA,QAAM,cAAsB,GAAG;AAC/B,QAAM,cAAc,+BAAe,WAAW;AAC9C,cAAY,OAAO;AACnB,cAAY,cAAc,GAAG;AAC7B,cAAY,UAAU;AACtB,SAAO,YAAY;AACnB,SAAO,YAAY;AACnB,SAAO,YAAY;AACnB,SAAO,YAAY;AACnB,SAAO,YAAY;AACnB,SAAO,YAAY;AAEnB,MAAI;AAEF,mCAAe,aAAa,WAAW;AAGvC,UAAM,aAAqB,GAAG;AAC9B,OAAG,cAAc,YAAY,KAAK,SAAS;AAAA,EAC7C,SAAQ,OAAN;AACA,wBAAI;AAAA,EAAK,kBAAkB,MAAM,WAAW,SAAS,KAAK;AAC1D,aAAS,MAAM,MAAM;AACrB,WAAO,MAAM;AAAA,EACf;AAEA,MAAG,SAAS;AACV,YAAQ,MAAM,4BAA4B;AAG1C,YAAQ,MAAM,OAAO;AAGrB,QAAI;AACF,YAAM,0BAAM,gBAAgB,CAAC,SAAS,GAAG;AAAA,QACvC,UAAU;AAAA,QACV,OAAO;AAAA,MACT,CAAC;AAGD,cAAQ,QAAQ,sCAAsC;AAAA,IACxD,SAAQ,OAAN;AAEA,0BAAI;AAAA,EAAK,kBAAkB,MAAM,WAAW,SAAS,KAAK;AAG1D,cAAQ,KAAK,iCAAiC;AAG9C,eAAS,MAAM,MAAM;AACrB,aAAO,MAAM;AAAA,IACf;AAAA,EACF;AAGA,WAAS,CAAC;AACV,SAAO;AACT;",
  "names": []
}

|
package/dist/commands/link.js
CHANGED
|
@@ -2,40 +2,37 @@ var __defProp = Object.defineProperty;
|
|
|
2
2
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
3
|
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
4
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
-
var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
|
|
6
5
|
var __export = (target, all) => {
|
|
7
6
|
for (var name in all)
|
|
8
7
|
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
8
|
};
|
|
10
|
-
var
|
|
11
|
-
if (
|
|
12
|
-
for (let key of __getOwnPropNames(
|
|
13
|
-
if (!__hasOwnProp.call(
|
|
14
|
-
__defProp(
|
|
9
|
+
var __copyProps = (to, from, except, desc) => {
|
|
10
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
11
|
+
for (let key of __getOwnPropNames(from))
|
|
12
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
13
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
14
|
}
|
|
16
|
-
return
|
|
15
|
+
return to;
|
|
17
16
|
};
|
|
18
|
-
var __toCommonJS =
|
|
19
|
-
return (module2, temp) => {
|
|
20
|
-
return cache && cache.get(module2) || (temp = __reExport(__markAsModule({}), module2, 1), cache && cache.set(module2, temp), temp);
|
|
21
|
-
};
|
|
22
|
-
})(typeof WeakMap !== "undefined" ? /* @__PURE__ */ new WeakMap() : 0);
|
|
17
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
23
18
|
var link_exports = {};
|
|
24
19
|
__export(link_exports, {
|
|
25
20
|
linked: () => linked
|
|
26
21
|
});
|
|
22
|
+
module.exports = __toCommonJS(link_exports);
|
|
27
23
|
var import_LexConfig = require("../LexConfig");
|
|
28
|
-
var
|
|
24
|
+
var import_app = require("../utils/app");
|
|
25
|
+
var import_log = require("../utils/log");
|
|
29
26
|
const linked = (cmd, callback = () => ({})) => {
|
|
30
27
|
const { cliName = "Lex", quiet } = cmd;
|
|
31
|
-
(0,
|
|
28
|
+
(0, import_log.log)(`${cliName} checking for linked modules...`, "info", quiet);
|
|
32
29
|
import_LexConfig.LexConfig.parseConfig(cmd);
|
|
33
|
-
(0,
|
|
30
|
+
(0, import_app.checkLinkedModules)();
|
|
34
31
|
callback(0);
|
|
35
32
|
return Promise.resolve(0);
|
|
36
33
|
};
|
|
37
|
-
module.exports = __toCommonJS(link_exports);
|
|
38
34
|
// Annotate the CommonJS export names for ESM import in node:
|
|
39
35
|
0 && (module.exports = {
|
|
40
36
|
linked
|
|
41
37
|
});
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2xpbmsudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE4LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQge0xleENvbmZpZ30gZnJvbSAnLi4vTGV4Q29uZmlnJztcbmltcG9ydCB7Y2hlY2tMaW5rZWRNb2R1bGVzfSBmcm9tICcuLi91dGlscy9hcHAnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uL3V0aWxzL2xvZyc7XG5cbmV4cG9ydCBjb25zdCBsaW5rZWQgPSAoY21kOiBhbnksIGNhbGxiYWNrOiBhbnkgPSAoKSA9PiAoe30pKTogUHJvbWlzZTxudW1iZXI+ID0+IHtcbiAgY29uc3Qge2NsaU5hbWUgPSAnTGV4JywgcXVpZXR9ID0gY21kO1xuXG4gIC8vIERpc3BsYXkgc3RhdHVzXG4gIGxvZyhgJHtjbGlOYW1lfSBjaGVja2luZyBmb3IgbGlua2VkIG1vZHVsZXMuLi5gLCAnaW5mbycsIHF1aWV0KTtcblxuICAvLyBHZXQgY3VzdG9tIGNvbmZpZ3VyYXRpb25cbiAgTGV4Q29uZmlnLnBhcnNlQ29uZmlnKGNtZCk7XG5cbiAgLy8gQ2hlY2sgZm9yIGxpbmtlZCBtb2R1bGVzXG4gIGNoZWNrTGlua2VkTW9kdWxlcygpO1xuICBjYWxsYmFjaygwKTtcbiAgcmV0dXJuIFByb21pc2UucmVzb2x2ZSgwKTtcbn07XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFJQSx1QkFBd0I7QUFDeEIsaUJBQWlDO0FBQ2pDLGlCQUFrQjtBQUVYLE1BQU0sU0FBUyxDQUFDLEtBQVUsV0FBZ0IsTUFBTyxFQUFDLE9BQXdCO0FBQy9FLFFBQU0sRUFBQyxVQUFVLE9BQU8sVUFBUztBQUdqQyxzQkFBSSxHQUFHLDBDQUEwQyxRQUFRLEtBQUs7QUFHOUQsNkJBQVUsWUFBWSxHQUFHO0FBR3pCLHFDQUFtQjtBQUNuQixXQUFTLENBQUM7QUFDVixTQUFPLFFBQVEsUUFBUSxDQUFDO0FBQzFCOyIsCiAgIm5hbWVzIjogW10KfQo=
|