@nlabs/lex 1.37.7 → 1.39.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/.eslintrc +1 -0
- package/.postcssrc.js +39 -29
- package/dist/LexConfig.js +31 -48
- package/dist/commands/build.js +35 -60
- package/dist/commands/bulid.test.js +3 -3
- package/dist/commands/clean.js +14 -37
- package/dist/commands/compile.js +60 -78
- package/dist/commands/config.js +18 -47
- package/dist/commands/copy.js +14 -40
- package/dist/commands/create.js +45 -69
- package/dist/commands/dev.js +23 -47
- package/dist/commands/init.js +26 -50
- package/dist/commands/link.js +9 -32
- package/dist/commands/lint.js +20 -44
- package/dist/commands/migrate.js +15 -41
- package/dist/commands/publish.js +27 -53
- package/dist/commands/test.js +21 -45
- package/dist/commands/update.js +15 -41
- package/dist/commands/upgrade.js +21 -47
- package/dist/commands/versions.js +17 -43
- package/dist/create/changelog.js +26 -50
- package/dist/lex.js +34 -20
- package/dist/resolver.js +12 -6
- package/dist/utils/app.js +60 -86
- package/dist/utils/file.js +14 -39
- package/dist/utils/log.js +9 -35
- package/dist/utils/reactShim.js +4 -30
- package/jest.config.lex.js +5 -0
- package/jest.setup.js +1 -1
- package/package.json +62 -60
- package/tsconfig/reactNative.json +30 -0
- package/tsconfig/web.json +0 -0
- package/tsconfig.template.json +0 -1
- package/webpack.config.js +3 -2
- package/dist/commands/index.js +0 -70
package/dist/commands/create.js
CHANGED
|
@@ -1,53 +1,30 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
for (var name in all)
|
|
9
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
-
};
|
|
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 });
|
|
16
|
-
}
|
|
17
|
-
return to;
|
|
18
|
-
};
|
|
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);
|
|
21
|
-
var create_exports = {};
|
|
22
|
-
__export(create_exports, {
|
|
23
|
-
create: () => create
|
|
24
|
-
});
|
|
25
|
-
module.exports = __toCommonJS(create_exports);
|
|
26
|
-
var fs = __toESM(require("fs-extra"));
|
|
27
|
-
var path = __toESM(require("path"));
|
|
28
|
-
var import_changelog = require("../create/changelog");
|
|
29
|
-
var import_LexConfig = require("../LexConfig");
|
|
30
|
-
var import_app = require("../utils/app");
|
|
31
|
-
var import_log = require("../utils/log");
|
|
1
|
+
import { existsSync, readFileSync, renameSync, writeFileSync } from "fs";
|
|
2
|
+
import * as path from "path";
|
|
3
|
+
import { fileURLToPath } 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";
|
|
32
8
|
const create = async (type, cmd, callback = () => ({})) => {
|
|
33
9
|
const { cliName = "Lex", outputFile, outputName, quiet } = cmd;
|
|
34
10
|
const cwd = process.cwd();
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
const { outputPath, sourcePath, useTypescript } =
|
|
11
|
+
log(`${cliName} creating ${type}...`, "info", quiet);
|
|
12
|
+
LexConfig.parseConfig(cmd, false);
|
|
13
|
+
const { outputPath, sourcePath, useTypescript } = LexConfig.config;
|
|
38
14
|
if (useTypescript) {
|
|
39
|
-
|
|
15
|
+
LexConfig.checkTypescriptConfig();
|
|
40
16
|
}
|
|
41
|
-
const { config } =
|
|
17
|
+
const { config } = LexConfig;
|
|
18
|
+
const dirName = fileURLToPath(new URL(".", import.meta.url));
|
|
42
19
|
switch (type) {
|
|
43
20
|
case "changelog": {
|
|
44
|
-
const statusChangelog = await
|
|
21
|
+
const statusChangelog = await createChangelog({ cliName, config, outputFile, quiet });
|
|
45
22
|
callback(statusChangelog);
|
|
46
23
|
return statusChangelog;
|
|
47
24
|
}
|
|
48
25
|
case "store": {
|
|
49
26
|
try {
|
|
50
|
-
const { nameCaps, templateExt, templatePath } =
|
|
27
|
+
const { nameCaps, templateExt, templatePath } = getFilenames({
|
|
51
28
|
cliName,
|
|
52
29
|
name: outputName,
|
|
53
30
|
quiet,
|
|
@@ -55,23 +32,23 @@ const create = async (type, cmd, callback = () => ({})) => {
|
|
|
55
32
|
useTypescript
|
|
56
33
|
});
|
|
57
34
|
const storePath = `${cwd}/${nameCaps}Store`;
|
|
58
|
-
if (!
|
|
59
|
-
|
|
60
|
-
|
|
35
|
+
if (!existsSync(storePath)) {
|
|
36
|
+
copyFolderRecursiveSync(path.resolve(dirName, templatePath, "./.SampleStore"), cwd);
|
|
37
|
+
renameSync(`${cwd}/.SampleStore`, storePath);
|
|
61
38
|
const storeTestPath = `${storePath}/${nameCaps}Store.test${templateExt}`;
|
|
62
|
-
|
|
63
|
-
|
|
39
|
+
renameSync(`${storePath}/SampleStore.test${templateExt}.txt`, storeTestPath);
|
|
40
|
+
updateTemplateName(storeTestPath, outputName, nameCaps);
|
|
64
41
|
const storeFilePath = `${storePath}/${nameCaps}Store${templateExt}`;
|
|
65
|
-
|
|
66
|
-
|
|
42
|
+
renameSync(`${storePath}/SampleStore${templateExt}.txt`, storeFilePath);
|
|
43
|
+
updateTemplateName(storeFilePath, outputName, nameCaps);
|
|
67
44
|
} else {
|
|
68
|
-
|
|
45
|
+
log(`
|
|
69
46
|
${cliName} Error: Cannot create new ${type}. Directory, ${storePath} already exists.`, "error", quiet);
|
|
70
47
|
callback(1);
|
|
71
48
|
return 1;
|
|
72
49
|
}
|
|
73
50
|
} catch (error) {
|
|
74
|
-
|
|
51
|
+
log(`
|
|
75
52
|
${cliName} Error: Cannot create new ${type}. ${error.message}`, "error", quiet);
|
|
76
53
|
callback(1);
|
|
77
54
|
return 1;
|
|
@@ -79,17 +56,17 @@ ${cliName} Error: Cannot create new ${type}. ${error.message}`, "error", quiet);
|
|
|
79
56
|
break;
|
|
80
57
|
}
|
|
81
58
|
case "tsconfig": {
|
|
82
|
-
await
|
|
83
|
-
const templatePath = path.resolve(
|
|
84
|
-
let data =
|
|
59
|
+
await removeFiles("tsconfig.json", true);
|
|
60
|
+
const templatePath = path.resolve(dirName, "../../tsconfig.template.json");
|
|
61
|
+
let data = readFileSync(templatePath, "utf8");
|
|
85
62
|
data = data.replace(/.\/src/g, sourcePath);
|
|
86
63
|
data = data.replace(/.\/dist/g, outputPath);
|
|
87
64
|
const destPath = path.resolve(cwd, "./tsconfig.json");
|
|
88
|
-
|
|
65
|
+
writeFileSync(destPath, data, "utf8");
|
|
89
66
|
break;
|
|
90
67
|
}
|
|
91
68
|
case "view": {
|
|
92
|
-
const { nameCaps, templatePath, templateReact } =
|
|
69
|
+
const { nameCaps, templatePath, templateReact } = getFilenames({
|
|
93
70
|
cliName,
|
|
94
71
|
name: outputName,
|
|
95
72
|
quiet,
|
|
@@ -98,26 +75,26 @@ ${cliName} Error: Cannot create new ${type}. ${error.message}`, "error", quiet);
|
|
|
98
75
|
});
|
|
99
76
|
const viewPath = `${cwd}/${nameCaps}View`;
|
|
100
77
|
try {
|
|
101
|
-
if (!
|
|
102
|
-
|
|
103
|
-
|
|
78
|
+
if (!existsSync(viewPath)) {
|
|
79
|
+
copyFolderRecursiveSync(path.resolve(dirName, templatePath, "./.SampleView"), cwd);
|
|
80
|
+
renameSync(`${cwd}/.SampleView`, viewPath);
|
|
104
81
|
const viewStylePath = `${viewPath}/${outputName}View.css`;
|
|
105
|
-
|
|
106
|
-
|
|
82
|
+
renameSync(`${viewPath}/sampleView.css`, viewStylePath);
|
|
83
|
+
updateTemplateName(viewStylePath, outputName, nameCaps);
|
|
107
84
|
const viewTestPath = `${viewPath}/${nameCaps}View.test${templateReact}`;
|
|
108
|
-
|
|
109
|
-
|
|
85
|
+
renameSync(`${viewPath}/SampleView.test${templateReact}.txt`, viewTestPath);
|
|
86
|
+
updateTemplateName(viewTestPath, outputName, nameCaps);
|
|
110
87
|
const viewFilePath = `${viewPath}/${nameCaps}View${templateReact}`;
|
|
111
|
-
|
|
112
|
-
|
|
88
|
+
renameSync(`${viewPath}/SampleView${templateReact}.txt`, viewFilePath);
|
|
89
|
+
updateTemplateName(viewFilePath, outputName, nameCaps);
|
|
113
90
|
} else {
|
|
114
|
-
|
|
91
|
+
log(`
|
|
115
92
|
${cliName} Error: Cannot create new ${type}. Directory, ${viewPath} already exists.`, "error", quiet);
|
|
116
93
|
callback(1);
|
|
117
94
|
return 1;
|
|
118
95
|
}
|
|
119
96
|
} catch (error) {
|
|
120
|
-
|
|
97
|
+
log(`
|
|
121
98
|
${cliName} Error: Cannot create new ${type}. ${error.message}`, "error", quiet);
|
|
122
99
|
callback(1);
|
|
123
100
|
return 1;
|
|
@@ -125,16 +102,15 @@ ${cliName} Error: Cannot create new ${type}. ${error.message}`, "error", quiet);
|
|
|
125
102
|
break;
|
|
126
103
|
}
|
|
127
104
|
case "vscode": {
|
|
128
|
-
await
|
|
129
|
-
|
|
105
|
+
await removeFiles(".vscode", true);
|
|
106
|
+
copyFolderRecursiveSync(path.resolve(dirName, "../../.vscode"), cwd);
|
|
130
107
|
break;
|
|
131
108
|
}
|
|
132
109
|
}
|
|
133
110
|
callback(0);
|
|
134
111
|
return 0;
|
|
135
112
|
};
|
|
136
|
-
|
|
137
|
-
0 && (module.exports = {
|
|
113
|
+
export {
|
|
138
114
|
create
|
|
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": "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",
  "names": []
}

|
|
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 * as path from 'path';\nimport {fileURLToPath} 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  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 = fileURLToPath(new URL('.', import.meta.url));\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(path.resolve(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 = path.resolve(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 = path.resolve(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(path.resolve(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(path.resolve(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
CHANGED
|
@@ -1,46 +1,22 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
for (var name in all)
|
|
9
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
-
};
|
|
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 });
|
|
16
|
-
}
|
|
17
|
-
return to;
|
|
18
|
-
};
|
|
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);
|
|
21
|
-
var dev_exports = {};
|
|
22
|
-
__export(dev_exports, {
|
|
23
|
-
dev: () => dev
|
|
24
|
-
});
|
|
25
|
-
module.exports = __toCommonJS(dev_exports);
|
|
26
|
-
var import_execa = __toESM(require("execa"));
|
|
27
|
-
var path = __toESM(require("path"));
|
|
28
|
-
var import_LexConfig = require("../LexConfig");
|
|
29
|
-
var import_app = require("../utils/app");
|
|
30
|
-
var import_file = require("../utils/file");
|
|
31
|
-
var import_log = require("../utils/log");
|
|
1
|
+
import { execa } from "execa";
|
|
2
|
+
import * as path from "path";
|
|
3
|
+
import { fileURLToPath } from "url";
|
|
4
|
+
import { LexConfig } from "../LexConfig.js";
|
|
5
|
+
import { createSpinner, removeFiles } from "../utils/app.js";
|
|
6
|
+
import { relativeFilePath } from "../utils/file.js";
|
|
7
|
+
import { log } from "../utils/log.js";
|
|
32
8
|
const dev = async (cmd, callback = () => ({})) => {
|
|
33
9
|
const { bundleAnalyzer, cliName = "Lex", config, open = false, quiet, remove, variables } = cmd;
|
|
34
|
-
const spinner =
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
const { outputFullPath, useTypescript } =
|
|
10
|
+
const spinner = createSpinner(quiet);
|
|
11
|
+
log(`${cliName} start development server...`, "info", quiet);
|
|
12
|
+
LexConfig.parseConfig(cmd);
|
|
13
|
+
const { outputFullPath, useTypescript } = LexConfig.config;
|
|
38
14
|
let variablesObj = { NODE_ENV: "development" };
|
|
39
15
|
if (variables) {
|
|
40
16
|
try {
|
|
41
17
|
variablesObj = JSON.parse(variables);
|
|
42
18
|
} catch (error) {
|
|
43
|
-
|
|
19
|
+
log(`
|
|
44
20
|
${cliName} Error: Environment variables option is not a valid JSON object.`, "error", quiet);
|
|
45
21
|
callback(1);
|
|
46
22
|
return 1;
|
|
@@ -48,14 +24,15 @@ ${cliName} Error: Environment variables option is not a valid JSON object.`, "er
|
|
|
48
24
|
}
|
|
49
25
|
process.env = { ...process.env, ...variablesObj };
|
|
50
26
|
if (useTypescript) {
|
|
51
|
-
|
|
27
|
+
LexConfig.checkTypescriptConfig();
|
|
52
28
|
}
|
|
53
29
|
if (remove) {
|
|
54
30
|
spinner.start("Cleaning output directory...");
|
|
55
|
-
await
|
|
31
|
+
await removeFiles(outputFullPath);
|
|
56
32
|
spinner.succeed("Successfully cleaned output directory!");
|
|
57
33
|
}
|
|
58
|
-
const
|
|
34
|
+
const dirName = fileURLToPath(new URL(".", import.meta.url));
|
|
35
|
+
const webpackConfig = config || path.resolve(dirName, "../../webpack.config.js");
|
|
59
36
|
const webpackOptions = [
|
|
60
37
|
"--color",
|
|
61
38
|
"--watch",
|
|
@@ -66,9 +43,9 @@ ${cliName} Error: Environment variables option is not a valid JSON object.`, "er
|
|
|
66
43
|
webpackOptions.push("--bundleAnalyzer");
|
|
67
44
|
}
|
|
68
45
|
try {
|
|
69
|
-
const nodePath = path.resolve(
|
|
70
|
-
const webpackPath =
|
|
71
|
-
await (
|
|
46
|
+
const nodePath = path.resolve(dirName, "../../node_modules");
|
|
47
|
+
const webpackPath = relativeFilePath("webpack-cli/bin/cli.js", nodePath);
|
|
48
|
+
await execa(webpackPath, webpackOptions, {
|
|
72
49
|
encoding: "utf-8",
|
|
73
50
|
env: {
|
|
74
51
|
LEX_QUIET: quiet,
|
|
@@ -80,15 +57,14 @@ ${cliName} Error: Environment variables option is not a valid JSON object.`, "er
|
|
|
80
57
|
callback(0);
|
|
81
58
|
return 0;
|
|
82
59
|
} catch (error) {
|
|
83
|
-
|
|
60
|
+
log(`
|
|
84
61
|
${cliName} Error: ${error.message}`, "error", quiet);
|
|
85
62
|
spinner.fail("There was an error while running Webpack.");
|
|
86
63
|
callback(error.status);
|
|
87
64
|
return error.status;
|
|
88
65
|
}
|
|
89
66
|
};
|
|
90
|
-
|
|
91
|
-
0 && (module.exports = {
|
|
67
|
+
export {
|
|
92
68
|
dev
|
|
93
|
-
}
|
|
94
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
69
|
+
};
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2Rldi50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTgtUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmltcG9ydCB7ZXhlY2F9IGZyb20gJ2V4ZWNhJztcbmltcG9ydCAqIGFzIHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQge2ZpbGVVUkxUb1BhdGh9IGZyb20gJ3VybCc7XG5cbmltcG9ydCB7TGV4Q29uZmlnfSBmcm9tICcuLi9MZXhDb25maWcuanMnO1xuaW1wb3J0IHtjcmVhdGVTcGlubmVyLCByZW1vdmVGaWxlc30gZnJvbSAnLi4vdXRpbHMvYXBwLmpzJztcbmltcG9ydCB7cmVsYXRpdmVGaWxlUGF0aH0gZnJvbSAnLi4vdXRpbHMvZmlsZS5qcyc7XG5pbXBvcnQge2xvZ30gZnJvbSAnLi4vdXRpbHMvbG9nLmpzJztcblxuZXhwb3J0IGNvbnN0IGRldiA9IGFzeW5jIChjbWQ6IGFueSwgY2FsbGJhY2s6IGFueSA9ICgpID0+ICh7fSkpOiBQcm9taXNlPG51bWJlcj4gPT4ge1xuICBjb25zdCB7YnVuZGxlQW5hbHl6ZXIsIGNsaU5hbWUgPSAnTGV4JywgY29uZmlnLCBvcGVuID0gZmFsc2UsIHF1aWV0LCByZW1vdmUsIHZhcmlhYmxlc30gPSBjbWQ7XG5cbiAgLy8gU3Bpbm5lclxuICBjb25zdCBzcGlubmVyID0gY3JlYXRlU3Bpbm5lcihxdWlldCk7XG5cbiAgLy8gRGlzcGxheSBzdGF0dXNcbiAgbG9nKGAke2NsaU5hbWV9IHN0YXJ0IGRldmVsb3BtZW50IHNlcnZlci4uLmAsICdpbmZvJywgcXVpZXQpO1xuXG4gIC8vIEdldCBjdXN0b20gY29uZmlndXJhdGlvblxuICBMZXhDb25maWcucGFyc2VDb25maWcoY21kKTtcblxuICBjb25zdCB7b3V0cHV0RnVsbFBhdGgsIHVzZVR5cGVzY3JpcHR9ID0gTGV4Q29uZmlnLmNvbmZpZztcblxuICAvLyBTZXQgbm9kZSBlbnZpcm9ubWVudCB2YXJpYWJsZXNcbiAgbGV0IHZhcmlhYmxlc09iajogb2JqZWN0ID0ge05PREVfRU5WOiAnZGV2ZWxvcG1lbnQnfTtcblxuICBpZih2YXJpYWJsZXMpIHtcbiAgICB0cnkge1xuICAgICAgdmFyaWFibGVzT2JqID0gSlNPTi5wYXJzZSh2YXJpYWJsZXMpO1xuICAgIH0gY2F0Y2goZXJyb3IpIHtcbiAgICAgIGxvZyhgXFxuJHtjbGlOYW1lfSBFcnJvcjogRW52aXJvbm1lbnQgdmFyaWFibGVzIG9wdGlvbiBpcyBub3QgYSB2YWxpZCBKU09OIG9iamVjdC5gLCAnZXJyb3InLCBxdWlldCk7XG4gICAgICBjYWxsYmFjaygxKTtcbiAgICAgIHJldHVybiAxO1xuICAgIH1cbiAgfVxuXG4gIHByb2Nlc3MuZW52ID0gey4uLnByb2Nlc3MuZW52LCAuLi52YXJpYWJsZXNPYmp9O1xuXG4gIGlmKHVzZVR5cGVzY3JpcHQpIHtcbiAgICAvLyBNYWtlIHN1cmUgdHNjb25maWcuanNvbiBleGlzdHNcbiAgICBMZXhDb25maWcuY2hlY2tUeXBlc2NyaXB0Q29uZmlnKCk7XG4gIH1cblxuICAvLyBDbGVhbiBvdXRwdXQgZGlyZWN0b3J5IGJlZm9yZSB3ZSBzdGFydCBhZGRpbmcgaW4gbmV3IGZpbGVzXG4gIGlmKHJlbW92ZSkge1xuICAgIC8vIFN0YXJ0IGNsZWFuaW5nIHNwaW5uZXJcbiAgICBzcGlubmVyLnN0YXJ0KCdDbGVhbmluZyBvdXRwdXQgZGlyZWN0b3J5Li4uJyk7XG5cbiAgICAvLyBDbGVhblxuICAgIGF3YWl0IHJlbW92ZUZpbGVzKG91dHB1dEZ1bGxQYXRoKTtcblxuICAgIC8vIFN0b3Agc3Bpbm5lclxuICAgIHNwaW5uZXIuc3VjY2VlZCgnU3VjY2Vzc2Z1bGx5IGNsZWFuZWQgb3V0cHV0IGRpcmVjdG9yeSEnKTtcbiAgfVxuXG4gIC8vIEdldCBjdXN0b20gd2VicGFjayBjb25maWd1cmF0aW9uIGZpbGVcbiAgY29uc3QgZGlyTmFtZSA9IGZpbGVVUkxUb1BhdGgobmV3IFVSTCgnLicsIGltcG9ydC5tZXRhLnVybCkpO1xuICBjb25zdCB3ZWJwYWNrQ29uZmlnOiBzdHJpbmcgPSBjb25maWcgfHwgcGF0aC5yZXNvbHZlKGRpck5hbWUsICcuLi8uLi93ZWJwYWNrLmNvbmZpZy5qcycpO1xuXG4gIC8vIENvbXBpbGUgdXNpbmcgd2VicGFja1xuICBjb25zdCB3ZWJwYWNrT3B0aW9uczogc3RyaW5nW10gPSBbXG4gICAgJy0tY29sb3InLFxuICAgICctLXdhdGNoJyxcbiAgICAnLS1jb25maWcnLCB3ZWJwYWNrQ29uZmlnXG4gIF07XG5cbiAgaWYoYnVuZGxlQW5hbHl6ZXIpIHtcbiAgICB3ZWJwYWNrT3B0aW9ucy5wdXNoKCctLWJ1bmRsZUFuYWx5emVyJyk7XG4gIH1cblxuICB0cnkge1xuICAgIGNvbnN0IG5vZGVQYXRoOiBzdHJpbmcgPSBwYXRoLnJlc29sdmUoZGlyTmFtZSwgJy4uLy4uL25vZGVfbW9kdWxlcycpO1xuICAgIGNvbnN0IHdlYnBhY2tQYXRoOiBzdHJpbmcgPSByZWxhdGl2ZUZpbGVQYXRoKCd3ZWJwYWNrLWNsaS9iaW4vY2xpLmpzJywgbm9kZVBhdGgpO1xuICAgIGF3YWl0IGV4ZWNhKHdlYnBhY2tQYXRoLCB3ZWJwYWNrT3B0aW9ucywge1xuICAgICAgZW5jb2Rpbmc6ICd1dGYtOCcsXG4gICAgICBlbnY6IHtcbiAgICAgICAgTEVYX1FVSUVUOiBxdWlldCxcbiAgICAgICAgV0VCUEFDS19ERVZfT1BFTjogb3BlblxuICAgICAgfSxcbiAgICAgIHN0ZGlvOiAnaW5oZXJpdCdcbiAgICB9KTtcblxuICAgIC8vIFN0b3Agc3Bpbm5lclxuICAgIHNwaW5uZXIuc3VjY2VlZCgnRGV2ZWxvcG1lbnQgc2VydmVyIHN0YXJ0ZWQuJyk7XG5cbiAgICBjYWxsYmFjaygwKTtcbiAgICByZXR1cm4gMDtcbiAgfSBjYXRjaChlcnJvcikge1xuICAgIC8vIERpc3BsYXkgZXJyb3IgbWVzc2FnZVxuICAgIGxvZyhgXFxuJHtjbGlOYW1lfSBFcnJvcjogJHtlcnJvci5tZXNzYWdlfWAsICdlcnJvcicsIHF1aWV0KTtcblxuICAgIC8vIFN0b3Agc3Bpbm5lclxuICAgIHNwaW5uZXIuZmFpbCgnVGhlcmUgd2FzIGFuIGVycm9yIHdoaWxlIHJ1bm5pbmcgV2VicGFjay4nKTtcblxuICAgIC8vIEtpbGwgcHJvY2Vzc1xuICAgIGNhbGxiYWNrKGVycm9yLnN0YXR1cyk7XG4gICAgcmV0dXJuIGVycm9yLnN0YXR1cztcbiAgfVxufTtcbiJdLAogICJtYXBwaW5ncyI6ICJBQUlBLFNBQVEsYUFBWTtBQUNwQixZQUFZLFVBQVU7QUFDdEIsU0FBUSxxQkFBb0I7QUFFNUIsU0FBUSxpQkFBZ0I7QUFDeEIsU0FBUSxlQUFlLG1CQUFrQjtBQUN6QyxTQUFRLHdCQUF1QjtBQUMvQixTQUFRLFdBQVU7QUFFWCxNQUFNLE1BQU0sT0FBTyxLQUFVLFdBQWdCLE9BQU8sQ0FBQyxPQUF3QjtBQUNsRixRQUFNLEVBQUMsZ0JBQWdCLFVBQVUsT0FBTyxRQUFRLE9BQU8sT0FBTyxPQUFPLFFBQVEsVUFBUyxJQUFJO0FBRzFGLFFBQU0sVUFBVSxjQUFjLEtBQUs7QUFHbkMsTUFBSSxHQUFHLHVDQUF1QyxRQUFRLEtBQUs7QUFHM0QsWUFBVSxZQUFZLEdBQUc7QUFFekIsUUFBTSxFQUFDLGdCQUFnQixjQUFhLElBQUksVUFBVTtBQUdsRCxNQUFJLGVBQXVCLEVBQUMsVUFBVSxjQUFhO0FBRW5ELE1BQUcsV0FBVztBQUNaLFFBQUk7QUFDRixxQkFBZSxLQUFLLE1BQU0sU0FBUztBQUFBLElBQ3JDLFNBQVEsT0FBTjtBQUNBLFVBQUk7QUFBQSxFQUFLLDJFQUEyRSxTQUFTLEtBQUs7QUFDbEcsZUFBUyxDQUFDO0FBQ1YsYUFBTztBQUFBLElBQ1Q7QUFBQSxFQUNGO0FBRUEsVUFBUSxNQUFNLEVBQUMsR0FBRyxRQUFRLEtBQUssR0FBRyxhQUFZO0FBRTlDLE1BQUcsZUFBZTtBQUVoQixjQUFVLHNCQUFzQjtBQUFBLEVBQ2xDO0FBR0EsTUFBRyxRQUFRO0FBRVQsWUFBUSxNQUFNLDhCQUE4QjtBQUc1QyxVQUFNLFlBQVksY0FBYztBQUdoQyxZQUFRLFFBQVEsd0NBQXdDO0FBQUEsRUFDMUQ7QUFHQSxRQUFNLFVBQVUsY0FBYyxJQUFJLElBQUksS0FBSyxZQUFZLEdBQUcsQ0FBQztBQUMzRCxRQUFNLGdCQUF3QixVQUFVLEtBQUssUUFBUSxTQUFTLHlCQUF5QjtBQUd2RixRQUFNLGlCQUEyQjtBQUFBLElBQy9CO0FBQUEsSUFDQTtBQUFBLElBQ0E7QUFBQSxJQUFZO0FBQUEsRUFDZDtBQUVBLE1BQUcsZ0JBQWdCO0FBQ2pCLG1CQUFlLEtBQUssa0JBQWtCO0FBQUEsRUFDeEM7QUFFQSxNQUFJO0FBQ0YsVUFBTSxXQUFtQixLQUFLLFFBQVEsU0FBUyxvQkFBb0I7QUFDbkUsVUFBTSxjQUFzQixpQkFBaUIsMEJBQTBCLFFBQVE7QUFDL0UsVUFBTSxNQUFNLGFBQWEsZ0JBQWdCO0FBQUEsTUFDdkMsVUFBVTtBQUFBLE1BQ1YsS0FBSztBQUFBLFFBQ0gsV0FBVztBQUFBLFFBQ1gsa0JBQWtCO0FBQUEsTUFDcEI7QUFBQSxNQUNBLE9BQU87QUFBQSxJQUNULENBQUM7QUFHRCxZQUFRLFFBQVEsNkJBQTZCO0FBRTdDLGFBQVMsQ0FBQztBQUNWLFdBQU87QUFBQSxFQUNULFNBQVEsT0FBTjtBQUVBLFFBQUk7QUFBQSxFQUFLLGtCQUFrQixNQUFNLFdBQVcsU0FBUyxLQUFLO0FBRzFELFlBQVEsS0FBSywyQ0FBMkM7QUFHeEQsYUFBUyxNQUFNLE1BQU07QUFDckIsV0FBTyxNQUFNO0FBQUEsRUFDZjtBQUNGOyIsCiAgIm5hbWVzIjogW10KfQo=
|
package/dist/commands/init.js
CHANGED
|
@@ -1,45 +1,22 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
for (var name in all)
|
|
9
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
-
};
|
|
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 });
|
|
16
|
-
}
|
|
17
|
-
return to;
|
|
18
|
-
};
|
|
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);
|
|
21
|
-
var init_exports = {};
|
|
22
|
-
__export(init_exports, {
|
|
23
|
-
init: () => init
|
|
24
|
-
});
|
|
25
|
-
module.exports = __toCommonJS(init_exports);
|
|
26
|
-
var import_execa = __toESM(require("execa"));
|
|
27
|
-
var fs = __toESM(require("fs-extra"));
|
|
28
|
-
var path = __toESM(require("path"));
|
|
29
|
-
var import_LexConfig = require("../LexConfig");
|
|
30
|
-
var import_app = require("../utils/app");
|
|
31
|
-
var import_log = require("../utils/log");
|
|
1
|
+
import { execa } from "execa";
|
|
2
|
+
import { renameSync, writeFileSync } from "fs";
|
|
3
|
+
import * as path from "path";
|
|
4
|
+
import { fileURLToPath } from "url";
|
|
5
|
+
import { LexConfig } from "../LexConfig.js";
|
|
6
|
+
import { createSpinner, getPackageJson, setPackageJson } from "../utils/app.js";
|
|
7
|
+
import { log } from "../utils/log.js";
|
|
32
8
|
const init = async (appName, packageName, cmd, callback = () => ({})) => {
|
|
33
9
|
const { cliName = "Lex", install, packageManager: cmdPackageManager, quiet, typescript } = cmd;
|
|
34
10
|
const cwd = process.cwd();
|
|
35
|
-
const spinner =
|
|
36
|
-
|
|
11
|
+
const spinner = createSpinner(quiet);
|
|
12
|
+
log(`${cliName} is downloading the app module...`, "info", quiet);
|
|
37
13
|
spinner.start("Downloading app...");
|
|
38
14
|
const tmpPath = path.resolve(cwd, "./.lexTmp");
|
|
39
15
|
const appPath = path.resolve(cwd, `./${appName}`);
|
|
40
|
-
const
|
|
41
|
-
|
|
42
|
-
|
|
16
|
+
const dirName = fileURLToPath(new URL(".", import.meta.url));
|
|
17
|
+
const dnpPath = path.resolve(dirName, "../../node_modules/download-npm-package/bin/cli.js");
|
|
18
|
+
LexConfig.parseConfig(cmd);
|
|
19
|
+
const { packageManager: configPackageManager, useTypescript: configTypescript } = LexConfig.config;
|
|
43
20
|
const packageManager = cmdPackageManager || configPackageManager;
|
|
44
21
|
const useTypescript = typescript !== void 0 ? typescript : configTypescript;
|
|
45
22
|
let appModule = packageName;
|
|
@@ -51,26 +28,26 @@ const init = async (appName, packageName, cmd, callback = () => ({})) => {
|
|
|
51
28
|
}
|
|
52
29
|
}
|
|
53
30
|
try {
|
|
54
|
-
await (
|
|
31
|
+
await execa(dnpPath, [appModule, tmpPath], {});
|
|
55
32
|
spinner.succeed("Successfully downloaded app!");
|
|
56
33
|
} catch (error) {
|
|
57
34
|
console.log("error", error);
|
|
58
|
-
|
|
35
|
+
log(`
|
|
59
36
|
${cliName} Error: There was an error downloading ${appModule}. Make sure the package exists and there is a network connection.`, "error", quiet);
|
|
60
37
|
spinner.fail("Downloaded of app failed.");
|
|
61
38
|
callback(error.status);
|
|
62
39
|
return error.status;
|
|
63
40
|
}
|
|
64
41
|
try {
|
|
65
|
-
|
|
42
|
+
renameSync(`${tmpPath}/${appModule}`, appPath);
|
|
66
43
|
} catch (error) {
|
|
67
|
-
|
|
44
|
+
log(`
|
|
68
45
|
${cliName} Error: There was an error copying ${appModule} to the current working directory.`, "error", quiet);
|
|
69
46
|
callback(error.status);
|
|
70
47
|
return error.status;
|
|
71
48
|
}
|
|
72
49
|
const packagePath = `${appPath}/package.json`;
|
|
73
|
-
const packageJson =
|
|
50
|
+
const packageJson = getPackageJson(packagePath);
|
|
74
51
|
packageJson.name = appName;
|
|
75
52
|
packageJson.description = `${cliName} created app`;
|
|
76
53
|
packageJson.version = "0.1.0";
|
|
@@ -81,11 +58,11 @@ ${cliName} Error: There was an error copying ${appModule} to the current working
|
|
|
81
58
|
delete packageJson.homepage;
|
|
82
59
|
delete packageJson.bugs;
|
|
83
60
|
try {
|
|
84
|
-
|
|
61
|
+
setPackageJson(packageJson, packagePath);
|
|
85
62
|
const readmePath = `${appPath}/README.md`;
|
|
86
|
-
|
|
63
|
+
writeFileSync(readmePath, `# ${appName}`);
|
|
87
64
|
} catch (error) {
|
|
88
|
-
|
|
65
|
+
log(`
|
|
89
66
|
${cliName} Error: ${error.message}`, "error", quiet);
|
|
90
67
|
callback(error.status);
|
|
91
68
|
return error.status;
|
|
@@ -94,13 +71,13 @@ ${cliName} Error: ${error.message}`, "error", quiet);
|
|
|
94
71
|
spinner.start("Installing dependencies...");
|
|
95
72
|
process.chdir(appPath);
|
|
96
73
|
try {
|
|
97
|
-
await (
|
|
74
|
+
await execa(packageManager, ["install"], {
|
|
98
75
|
encoding: "utf-8",
|
|
99
76
|
stdio: "inherit"
|
|
100
77
|
});
|
|
101
78
|
spinner.succeed("Successfully installed dependencies!");
|
|
102
79
|
} catch (error) {
|
|
103
|
-
|
|
80
|
+
log(`
|
|
104
81
|
${cliName} Error: ${error.message}`, "error", quiet);
|
|
105
82
|
spinner.fail("Failed to install dependencies.");
|
|
106
83
|
callback(error.status);
|
|
@@ -110,8 +87,7 @@ ${cliName} Error: ${error.message}`, "error", quiet);
|
|
|
110
87
|
callback(0);
|
|
111
88
|
return 0;
|
|
112
89
|
};
|
|
113
|
-
|
|
114
|
-
0 && (module.exports = {
|
|
90
|
+
export {
|
|
115
91
|
init
|
|
116
|
-
}
|
|
117
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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 * as path from 'path';\nimport {fileURLToPath} 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 = path.resolve(cwd, './.lexTmp');\n  const appPath: string = path.resolve(cwd, `./${appName}`);\n  const dirName = fileURLToPath(new URL('.', import.meta.url));\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    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    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": "AAIA,SAAQ,aAAY;AACpB,SAAQ,YAAY,qBAAoB;AACxC,YAAY,UAAU;AACtB,SAAQ,qBAAoB;AAE5B,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,4CAA4C,QAAQ,KAAK;AAChE,UAAQ,MAAM,oBAAoB;AAClC,QAAM,UAAkB,KAAK,QAAQ,KAAK,WAAW;AACrD,QAAM,UAAkB,KAAK,QAAQ,KAAK,KAAK,SAAS;AACxD,QAAM,UAAU,cAAc,IAAI,IAAI,KAAK,YAAY,GAAG,CAAC;AAC3D,QAAM,UAAkB,KAAK,QAAQ,SAAS,oDAAoD;AAGlG,YAAU,YAAY,GAAG;AACzB,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,OAAN;AACA,YAAQ,IAAI,SAAS,KAAK;AAC1B,QAAI;AAAA,EAAK,iDAAiD,8EAA8E,SAAS,KAAK;AAGtJ,YAAQ,KAAK,2BAA2B;AAGxC,aAAS,MAAM,MAAM;AACrB,WAAO,MAAM;AAAA,EACf;AAGA,MAAI;AACF,eAAW,GAAG,WAAW,aAAa,OAAO;AAAA,EAC/C,SAAQ,OAAN;AACA,QAAI;AAAA,EAAK,6CAA6C,+CAA+C,SAAS,KAAK;AACnH,aAAS,MAAM,MAAM;AACrB,WAAO,MAAM;AAAA,EACf;AAGA,QAAM,cAAsB,GAAG;AAC/B,QAAM,cAAc,eAAe,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,mBAAe,aAAa,WAAW;AAGvC,UAAM,aAAqB,GAAG;AAC9B,kBAAc,YAAY,KAAK,SAAS;AAAA,EAC1C,SAAQ,OAAN;AACA,QAAI;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,MAAM,gBAAgB,CAAC,SAAS,GAAG;AAAA,QACvC,UAAU;AAAA,QACV,OAAO;AAAA,MACT,CAAC;AAGD,cAAQ,QAAQ,sCAAsC;AAAA,IACxD,SAAQ,OAAN;AAEA,UAAI;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
|
@@ -1,38 +1,15 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
-
var __export = (target, all) => {
|
|
6
|
-
for (var name in all)
|
|
7
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
8
|
-
};
|
|
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 });
|
|
14
|
-
}
|
|
15
|
-
return to;
|
|
16
|
-
};
|
|
17
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
18
|
-
var link_exports = {};
|
|
19
|
-
__export(link_exports, {
|
|
20
|
-
linked: () => linked
|
|
21
|
-
});
|
|
22
|
-
module.exports = __toCommonJS(link_exports);
|
|
23
|
-
var import_LexConfig = require("../LexConfig");
|
|
24
|
-
var import_app = require("../utils/app");
|
|
25
|
-
var import_log = require("../utils/log");
|
|
1
|
+
import { LexConfig } from "../LexConfig.js";
|
|
2
|
+
import { checkLinkedModules } from "../utils/app.js";
|
|
3
|
+
import { log } from "../utils/log.js";
|
|
26
4
|
const linked = (cmd, callback = () => ({})) => {
|
|
27
5
|
const { cliName = "Lex", quiet } = cmd;
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
6
|
+
log(`${cliName} checking for linked modules...`, "info", quiet);
|
|
7
|
+
LexConfig.parseConfig(cmd);
|
|
8
|
+
checkLinkedModules();
|
|
31
9
|
callback(0);
|
|
32
10
|
return Promise.resolve(0);
|
|
33
11
|
};
|
|
34
|
-
|
|
35
|
-
0 && (module.exports = {
|
|
12
|
+
export {
|
|
36
13
|
linked
|
|
37
|
-
}
|
|
38
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
14
|
+
};
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2xpbmsudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE4LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQge0xleENvbmZpZ30gZnJvbSAnLi4vTGV4Q29uZmlnLmpzJztcbmltcG9ydCB7Y2hlY2tMaW5rZWRNb2R1bGVzfSBmcm9tICcuLi91dGlscy9hcHAuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uL3V0aWxzL2xvZy5qcyc7XG5cbmV4cG9ydCBjb25zdCBsaW5rZWQgPSAoY21kOiBhbnksIGNhbGxiYWNrOiBhbnkgPSAoKSA9PiAoe30pKTogUHJvbWlzZTxudW1iZXI+ID0+IHtcbiAgY29uc3Qge2NsaU5hbWUgPSAnTGV4JywgcXVpZXR9ID0gY21kO1xuXG4gIC8vIERpc3BsYXkgc3RhdHVzXG4gIGxvZyhgJHtjbGlOYW1lfSBjaGVja2luZyBmb3IgbGlua2VkIG1vZHVsZXMuLi5gLCAnaW5mbycsIHF1aWV0KTtcblxuICAvLyBHZXQgY3VzdG9tIGNvbmZpZ3VyYXRpb25cbiAgTGV4Q29uZmlnLnBhcnNlQ29uZmlnKGNtZCk7XG5cbiAgLy8gQ2hlY2sgZm9yIGxpbmtlZCBtb2R1bGVzXG4gIGNoZWNrTGlua2VkTW9kdWxlcygpO1xuICBjYWxsYmFjaygwKTtcbiAgcmV0dXJuIFByb21pc2UucmVzb2x2ZSgwKTtcbn07XG4iXSwKICAibWFwcGluZ3MiOiAiQUFJQSxTQUFRLGlCQUFnQjtBQUN4QixTQUFRLDBCQUF5QjtBQUNqQyxTQUFRLFdBQVU7QUFFWCxNQUFNLFNBQVMsQ0FBQyxLQUFVLFdBQWdCLE9BQU8sQ0FBQyxPQUF3QjtBQUMvRSxRQUFNLEVBQUMsVUFBVSxPQUFPLE1BQUssSUFBSTtBQUdqQyxNQUFJLEdBQUcsMENBQTBDLFFBQVEsS0FBSztBQUc5RCxZQUFVLFlBQVksR0FBRztBQUd6QixxQkFBbUI7QUFDbkIsV0FBUyxDQUFDO0FBQ1YsU0FBTyxRQUFRLFFBQVEsQ0FBQztBQUMxQjsiLAogICJuYW1lcyI6IFtdCn0K
|