@nlabs/lex 1.32.0 → 1.32.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -4,38 +4,34 @@ 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 __reExport = (target, module2, copyDefault, desc) => {
13
- if (module2 && typeof module2 === "object" || typeof module2 === "function") {
14
- for (let key of __getOwnPropNames(module2))
15
- if (!__hasOwnProp.call(target, key) && (copyDefault || key !== "default"))
16
- __defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
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 target;
17
+ return to;
19
18
  };
20
- var __toESM = (module2, isNodeMode) => {
21
- return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", !isNodeMode && module2 && module2.__esModule ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
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 compile_exports = {};
29
22
  __export(compile_exports, {
30
23
  compile: () => compile,
31
24
  hasFileType: () => hasFileType
32
25
  });
26
+ module.exports = __toCommonJS(compile_exports);
33
27
  var import_execa = __toESM(require("execa"));
34
28
  var import_fs = __toESM(require("fs"));
35
29
  var import_glob = __toESM(require("glob"));
36
30
  var import_path = __toESM(require("path"));
37
31
  var import_LexConfig = require("../LexConfig");
38
- var import_utils = require("../utils");
32
+ var import_app = require("../utils/app");
33
+ var import_file = require("../utils/file");
34
+ var import_log = require("../utils/log");
39
35
  const hasFileType = (startPath, ext) => {
40
36
  if (!import_fs.default.existsSync(startPath)) {
41
37
  return false;
@@ -53,18 +49,18 @@ const hasFileType = (startPath, ext) => {
53
49
  };
54
50
  const compile = async (cmd, callback = () => ({})) => {
55
51
  const { cliName = "Lex", config, quiet, remove, watch } = cmd;
56
- const spinner = (0, import_utils.createSpinner)(quiet);
57
- (0, import_utils.log)(`${cliName} compiling...`, "info", quiet);
52
+ const spinner = (0, import_app.createSpinner)(quiet);
53
+ (0, import_log.log)(`${cliName} compiling...`, "info", quiet);
58
54
  import_LexConfig.LexConfig.parseConfig(cmd);
59
55
  const { outputFullPath, sourceFullPath, useTypescript } = import_LexConfig.LexConfig.config;
60
56
  const nodePath = import_path.default.resolve(__dirname, "../../node_modules");
61
- (0, import_utils.checkLinkedModules)();
57
+ (0, import_app.checkLinkedModules)();
62
58
  if (remove) {
63
- await (0, import_utils.removeFiles)(outputFullPath);
59
+ await (0, import_app.removeFiles)(outputFullPath);
64
60
  }
65
61
  if (useTypescript) {
66
62
  import_LexConfig.LexConfig.checkTypescriptConfig();
67
- const typescriptPath = (0, import_utils.relativeFilePath)("typescript/bin/tsc", nodePath);
63
+ const typescriptPath = (0, import_file.relativeFilePath)("typescript/bin/tsc", nodePath);
68
64
  const typescriptOptions = config ? ["-p", config] : [
69
65
  "--allowSyntheticDefaultImports",
70
66
  "--baseUrl",
@@ -73,7 +69,7 @@ const compile = async (cmd, callback = () => ({})) => {
73
69
  "--emitDeclarationOnly",
74
70
  "--inlineSourceMap",
75
71
  "--jsx",
76
- "react",
72
+ "react-jsx",
77
73
  "--lib",
78
74
  ["ES5", "ES6", "ES2015", "ES7", "ES2016", "ES2017", "ES2018", "ESNext", "DOM"],
79
75
  "--module",
@@ -101,7 +97,7 @@ const compile = async (cmd, callback = () => ({})) => {
101
97
  await (0, import_execa.default)(typescriptPath, typescriptOptions, { encoding: "utf-8" });
102
98
  spinner.succeed("Successfully completed type checking!");
103
99
  } catch (error) {
104
- (0, import_utils.log)(`
100
+ (0, import_log.log)(`
105
101
  ${cliName} Error: ${error.message}`, "error", quiet);
106
102
  if (!quiet) {
107
103
  console.error(error);
@@ -120,7 +116,7 @@ ${cliName} Error: ${error.message}`, "error", quiet);
120
116
  const tsFiles = import_glob.default.sync(`${sourceFullPath}/**/**.ts*`, globOptions);
121
117
  const jsFiles = import_glob.default.sync(`${sourceFullPath}/**/**.js`, globOptions);
122
118
  const sourceFiles = [...tsFiles, ...jsFiles];
123
- const esbuildPath = (0, import_utils.relativeFilePath)("esbuild/bin/esbuild", nodePath);
119
+ const esbuildPath = (0, import_file.relativeFilePath)("esbuild/bin/esbuild", nodePath);
124
120
  const esbuildOptions = [
125
121
  ...sourceFiles,
126
122
  "--color=true",
@@ -137,9 +133,9 @@ ${cliName} Error: ${error.message}`, "error", quiet);
137
133
  if (watch) {
138
134
  esbuildOptions.push("--watch");
139
135
  }
140
- const cssFiles = (0, import_utils.getFilesByExt)(".css");
136
+ const cssFiles = (0, import_app.getFilesByExt)(".css", import_LexConfig.LexConfig.config);
141
137
  if (cssFiles.length) {
142
- const postcssPath = (0, import_utils.relativeFilePath)("postcss-cli/bin/postcss", nodePath);
138
+ const postcssPath = (0, import_file.relativeFilePath)("postcss-cli/index.js", nodePath);
143
139
  const postcssOptions = [
144
140
  `${sourceFullPath}/**/**.css`,
145
141
  "--base",
@@ -153,51 +149,51 @@ ${cliName} Error: ${error.message}`, "error", quiet);
153
149
  await (0, import_execa.default)(postcssPath, postcssOptions, { encoding: "utf-8" });
154
150
  spinner.succeed(`Successfully formatted ${cssFiles.length} css files!`);
155
151
  } catch (error) {
156
- (0, import_utils.log)(`
152
+ (0, import_log.log)(`
157
153
  ${cliName} Error: ${error.message}`, "error", quiet);
158
154
  spinner.fail("Failed formatting css.");
159
155
  callback(error.status);
160
156
  return error.status;
161
157
  }
162
158
  }
163
- const gifFiles = (0, import_utils.getFilesByExt)(".gif");
164
- const jpgFiles = (0, import_utils.getFilesByExt)(".jpg");
165
- const pngFiles = (0, import_utils.getFilesByExt)(".png");
166
- const svgFiles = (0, import_utils.getFilesByExt)(".svg");
159
+ const gifFiles = (0, import_app.getFilesByExt)(".gif", import_LexConfig.LexConfig.config);
160
+ const jpgFiles = (0, import_app.getFilesByExt)(".jpg", import_LexConfig.LexConfig.config);
161
+ const pngFiles = (0, import_app.getFilesByExt)(".png", import_LexConfig.LexConfig.config);
162
+ const svgFiles = (0, import_app.getFilesByExt)(".svg", import_LexConfig.LexConfig.config);
167
163
  const imageFiles = [...gifFiles, ...jpgFiles, ...pngFiles, ...svgFiles];
168
164
  if (imageFiles.length) {
169
165
  try {
170
- await (0, import_utils.copyFiles)(imageFiles, "image", spinner);
166
+ await (0, import_app.copyFiles)(imageFiles, "image", spinner, import_LexConfig.LexConfig.config);
171
167
  } catch (error) {
172
- (0, import_utils.log)(`
168
+ (0, import_log.log)(`
173
169
  ${cliName} Error: ${error.message}`, "error", quiet);
174
170
  spinner.fail("Failed to move images to output directory.");
175
171
  callback(error.status);
176
172
  return error.status;
177
173
  }
178
174
  }
179
- const ttfFiles = (0, import_utils.getFilesByExt)(".ttf");
180
- const otfFiles = (0, import_utils.getFilesByExt)(".otf");
181
- const woffFiles = (0, import_utils.getFilesByExt)(".woff");
182
- const woff2Files = (0, import_utils.getFilesByExt)(".woff2");
175
+ const ttfFiles = (0, import_app.getFilesByExt)(".ttf", import_LexConfig.LexConfig.config);
176
+ const otfFiles = (0, import_app.getFilesByExt)(".otf", import_LexConfig.LexConfig.config);
177
+ const woffFiles = (0, import_app.getFilesByExt)(".woff", import_LexConfig.LexConfig.config);
178
+ const woff2Files = (0, import_app.getFilesByExt)(".woff2", import_LexConfig.LexConfig.config);
183
179
  const fontFiles = [...ttfFiles, ...otfFiles, ...woffFiles, ...woff2Files];
184
180
  if (fontFiles.length) {
185
181
  try {
186
- await (0, import_utils.copyFiles)(fontFiles, "font", spinner);
182
+ await (0, import_app.copyFiles)(fontFiles, "font", spinner, import_LexConfig.LexConfig.config);
187
183
  } catch (error) {
188
- (0, import_utils.log)(`
184
+ (0, import_log.log)(`
189
185
  ${cliName} Error: ${error.message}`, "error", quiet);
190
186
  spinner.fail("Failed to move fonts to output directory.");
191
187
  callback(error.status);
192
188
  return error.status;
193
189
  }
194
190
  }
195
- const mdFiles = (0, import_utils.getFilesByExt)(".md");
191
+ const mdFiles = (0, import_app.getFilesByExt)(".md", import_LexConfig.LexConfig.config);
196
192
  if (mdFiles.length) {
197
193
  try {
198
- await (0, import_utils.copyFiles)(mdFiles, "documents", spinner);
194
+ await (0, import_app.copyFiles)(mdFiles, "documents", spinner, import_LexConfig.LexConfig.config);
199
195
  } catch (error) {
200
- (0, import_utils.log)(`
196
+ (0, import_log.log)(`
201
197
  ${cliName} Error: ${error.message}`, "error", quiet);
202
198
  spinner.fail("Failed to move docs to output directory.");
203
199
  callback(error.status);
@@ -209,7 +205,7 @@ ${cliName} Error: ${error.message}`, "error", quiet);
209
205
  await (0, import_execa.default)(esbuildPath, esbuildOptions, { encoding: "utf-8" });
210
206
  spinner.succeed("Compile completed successfully!");
211
207
  } catch (error) {
212
- (0, import_utils.log)(`
208
+ (0, import_log.log)(`
213
209
  ${cliName} Error: ${error.message}`, "error", quiet);
214
210
  if (!quiet) {
215
211
  console.error(error);
@@ -221,9 +217,9 @@ ${cliName} Error: ${error.message}`, "error", quiet);
221
217
  callback(0);
222
218
  return 0;
223
219
  };
224
- module.exports = __toCommonJS(compile_exports);
225
220
  // Annotate the CommonJS export names for ESM import in node:
226
221
  0 && (module.exports = {
227
222
  compile,
228
223
  hasFileType
229
224
  });
225
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/commands/compile.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 fs from 'fs';\nimport glob from 'glob';\nimport path from 'path';\n\nimport {LexConfig} from '../LexConfig';\nimport {\n  checkLinkedModules,\n  copyFiles,\n  createSpinner,\n  getFilesByExt,\n  removeFiles\n} from '../utils/app';\nimport {relativeFilePath} from '../utils/file';\nimport {log} from '../utils/log';\n\nexport const hasFileType = (startPath: string, ext: string[]): boolean => {\n  if(!fs.existsSync(startPath)) {\n    return false;\n  }\n\n  const files: string[] = fs.readdirSync(startPath);\n\n  return files.some((file: string) => {\n    const filename: string = path.join(startPath, file);\n    const fileExt: string = path.extname(filename);\n    const stat = fs.lstatSync(filename);\n\n    if(stat.isDirectory()) {\n      // Recursive search\n      return hasFileType(filename, ext);\n    }\n\n    return ext.includes(fileExt);\n  });\n};\n\nexport const compile = async (cmd: any, callback: any = () => ({})): Promise<number> => {\n  const {cliName = 'Lex', config, quiet, remove, watch} = cmd;\n\n  // Spinner\n  const spinner = createSpinner(quiet);\n\n  // Display status\n  log(`${cliName} compiling...`, 'info', quiet);\n\n  // Get custom configuration\n  LexConfig.parseConfig(cmd);\n\n  // Compile type\n  const {outputFullPath, sourceFullPath, useTypescript} = LexConfig.config;\n  const nodePath: string = path.resolve(__dirname, '../../node_modules');\n\n  // Check for linked modules\n  checkLinkedModules();\n\n  // Clean output directory before we start adding in new files\n  if(remove) {\n    await removeFiles(outputFullPath);\n  }\n\n  // Add tsconfig file if none exists\n  if(useTypescript) {\n    // Make sure tsconfig.json exists\n    LexConfig.checkTypescriptConfig();\n\n    // Check static types with typescript\n    const typescriptPath: string = relativeFilePath('typescript/bin/tsc', nodePath);\n    const typescriptOptions: string[] = config ?\n      ['-p', config] :\n      [\n        '--allowSyntheticDefaultImports',\n        '--baseUrl', sourceFullPath,\n        '--declaration',\n        '--emitDeclarationOnly',\n        '--inlineSourceMap',\n        '--jsx', 'react-jsx',\n        '--lib', ['ES5', 'ES6', 'ES2015', 'ES7', 'ES2016', 'ES2017', 'ES2018', 'ESNext', 'DOM'],\n        '--module', 'commonjs',\n        '--moduleResolution', 'node',\n        '--noImplicitReturns',\n        '--noImplicitThis',\n        '--noStrictGenericChecks',\n        '--outDir', outputFullPath,\n        '--removeComments',\n        '--resolveJsonModule',\n        '--rootDir', sourceFullPath,\n        '--sourceRoot', sourceFullPath,\n        '--target', 'ES5',\n        '--typeRoots', ['node_modules/@types', 'node_modules/json-d-ts']\n      ];\n\n    // Start type checking spinner\n    spinner.start('Static type checking with Typescript...');\n\n    // Type checking\n    try {\n      await execa(typescriptPath, typescriptOptions, {encoding: 'utf-8'});\n\n      // Stop spinner\n      spinner.succeed('Successfully completed type checking!');\n    } catch(error) {\n      // Display error message\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      if(!quiet) {\n        console.error(error);\n      }\n\n      // Stop spinner\n      spinner.fail('Type checking failed.');\n\n      // Kill Process\n      callback(error.status);\n      return error.status;\n    }\n  }\n\n  // Source files\n  const globOptions = {\n    cwd: sourceFullPath,\n    dot: false,\n    nodir: true,\n    nosort: true\n  };\n  const tsFiles: string[] = glob.sync(`${sourceFullPath}/**/**.ts*`, globOptions);\n  const jsFiles: string[] = glob.sync(`${sourceFullPath}/**/**.js`, globOptions);\n  const sourceFiles: string[] = [...tsFiles, ...jsFiles];\n\n  // ESBuild options\n  const esbuildPath: string = relativeFilePath('esbuild/bin/esbuild', nodePath);\n  const esbuildOptions: string[] = [\n    ...sourceFiles,\n    '--color=true',\n    '--format=cjs',\n    '--loader:.js=js',\n    '--outdir=lib',\n    '--platform=node',\n    '--sourcemap=inline',\n    '--target=node14'\n  ];\n\n  if(useTypescript) {\n    esbuildOptions.push('--loader:.ts=ts', '--loader:.tsx=tsx');\n  }\n\n  if(watch) {\n    esbuildOptions.push('--watch');\n  }\n\n  // Use PostCSS for CSS files\n  const cssFiles: string[] = getFilesByExt('.css', LexConfig.config);\n\n  if(cssFiles.length) {\n    const postcssPath: string = relativeFilePath('postcss-cli/index.js', nodePath);\n    const postcssOptions: string[] = [\n      `${sourceFullPath}/**/**.css`,\n      '--base',\n      sourceFullPath,\n      '--dir',\n      outputFullPath,\n      '--config',\n      path.resolve(__dirname, '../../.postcssrc.js')\n    ];\n\n    try {\n      await execa(postcssPath, postcssOptions, {encoding: 'utf-8'});\n      spinner.succeed(`Successfully formatted ${cssFiles.length} css files!`);\n    } catch(error) {\n      // Display error message\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      // Stop spinner\n      spinner.fail('Failed formatting css.');\n\n      // Kill Process\n      callback(error.status);\n      return error.status;\n    }\n  }\n\n  // Copy image files\n  const gifFiles: string[] = getFilesByExt('.gif', LexConfig.config);\n  const jpgFiles: string[] = getFilesByExt('.jpg', LexConfig.config);\n  const pngFiles: string[] = getFilesByExt('.png', LexConfig.config);\n  const svgFiles: string[] = getFilesByExt('.svg', LexConfig.config);\n  const imageFiles: string[] = [...gifFiles, ...jpgFiles, ...pngFiles, ...svgFiles];\n\n  if(imageFiles.length) {\n    try {\n      await copyFiles(imageFiles, 'image', spinner, LexConfig.config);\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 move images to output directory.');\n\n      // Kill Process\n      callback(error.status);\n      return error.status;\n    }\n  }\n\n  // Copy font files\n  const ttfFiles: string[] = getFilesByExt('.ttf', LexConfig.config);\n  const otfFiles: string[] = getFilesByExt('.otf', LexConfig.config);\n  const woffFiles: string[] = getFilesByExt('.woff', LexConfig.config);\n  const woff2Files: string[] = getFilesByExt('.woff2', LexConfig.config);\n  const fontFiles: string[] = [...ttfFiles, ...otfFiles, ...woffFiles, ...woff2Files];\n\n  if(fontFiles.length) {\n    try {\n      await copyFiles(fontFiles, 'font', spinner, LexConfig.config);\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 move fonts to output directory.');\n\n      // Kill Process\n      callback(error.status);\n      return error.status;\n    }\n  }\n\n  // Copy markdown files\n  const mdFiles: string[] = getFilesByExt('.md', LexConfig.config);\n\n  if(mdFiles.length) {\n    try {\n      await copyFiles(mdFiles, 'documents', spinner, LexConfig.config);\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 move docs to output directory.');\n\n      // Kill Process\n      callback(error.status);\n      return error.status;\n    }\n  }\n\n  // Start compile spinner\n  spinner.start(watch ? 'Watching for changes...' : 'Compiling with ESBuild...');\n\n  try {\n    await execa(esbuildPath, esbuildOptions, {encoding: 'utf-8'});\n\n    // Stop spinner\n    spinner.succeed('Compile completed successfully!');\n  } catch(error) {\n    // Display error message\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n    if(!quiet) {\n      console.error(error);\n    }\n\n    // Stop spinner\n    spinner.fail('Code compiling failed.');\n\n    // Kill Process\n    callback(error.status);\n    return error.status;\n  }\n\n  // Stop process\n  callback(0);\n  return 0;\n};\n"],
  "mappings": "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",
  "names": []
}

@@ -4,46 +4,41 @@ 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 __reExport = (target, module2, copyDefault, desc) => {
13
- if (module2 && typeof module2 === "object" || typeof module2 === "function") {
14
- for (let key of __getOwnPropNames(module2))
15
- if (!__hasOwnProp.call(target, key) && (copyDefault || key !== "default"))
16
- __defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
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 target;
17
+ return to;
19
18
  };
20
- var __toESM = (module2, isNodeMode) => {
21
- return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", !isNodeMode && module2 && module2.__esModule ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
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 config_exports = {};
29
22
  __export(config_exports, {
30
23
  config: () => config
31
24
  });
25
+ module.exports = __toCommonJS(config_exports);
32
26
  var import_fs = __toESM(require("fs"));
33
27
  var import_startCase = __toESM(require("lodash/startCase"));
34
28
  var path = __toESM(require("path"));
35
29
  var import_LexConfig = require("../LexConfig");
36
- var import_utils = require("../utils");
30
+ var import_app = require("../utils/app");
31
+ var import_log = require("../utils/log");
37
32
  const config = (type, cmd, callback = () => ({})) => {
38
33
  const { cliName = "Lex", json, quiet } = cmd;
39
34
  const validTypes = ["app", "jest", "webpack"];
40
35
  if (!validTypes.includes(type)) {
41
- (0, import_utils.log)(`
36
+ (0, import_log.log)(`
42
37
  ${cliName} Error: Option for ${type} not found. Configurations only available for app, jest, and webpack.`, "error", quiet);
43
38
  callback(1);
44
39
  return Promise.resolve(1);
45
40
  }
46
- (0, import_utils.log)(`${cliName} generating configuration for ${(0, import_startCase.default)(type)}...`, "info", quiet);
41
+ (0, import_log.log)(`${cliName} generating configuration for ${(0, import_startCase.default)(type)}...`, "info", quiet);
47
42
  import_LexConfig.LexConfig.parseConfig(cmd);
48
43
  let configOptions;
49
44
  switch (type) {
@@ -61,9 +56,8 @@ ${cliName} Error: Option for ${type} not found. Configurations only available fo
61
56
  break;
62
57
  }
63
58
  const jsonOutput = JSON.stringify(configOptions, null, 2);
64
- console.log(jsonOutput);
65
59
  if (json) {
66
- const spinner = (0, import_utils.createSpinner)(quiet);
60
+ const spinner = (0, import_app.createSpinner)(quiet);
67
61
  spinner.start("Creating JSON output...");
68
62
  import_fs.default.writeFileSync(json, jsonOutput);
69
63
  spinner.succeed(`Successfully saved JSON output to ${path.relative(process.cwd(), json)}`);
@@ -71,8 +65,8 @@ ${cliName} Error: Option for ${type} not found. Configurations only available fo
71
65
  callback(0);
72
66
  return Promise.resolve(0);
73
67
  };
74
- module.exports = __toCommonJS(config_exports);
75
68
  // Annotate the CommonJS export names for ESM import in node:
76
69
  0 && (module.exports = {
77
70
  config
78
71
  });
72
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2NvbmZpZy50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTgtUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmltcG9ydCBmcyBmcm9tICdmcyc7XG5pbXBvcnQgc3RhcnRDYXNlIGZyb20gJ2xvZGFzaC9zdGFydENhc2UnO1xuaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcblxuaW1wb3J0IHtMZXhDb25maWd9IGZyb20gJy4uL0xleENvbmZpZyc7XG5pbXBvcnQge2NyZWF0ZVNwaW5uZXJ9IGZyb20gJy4uL3V0aWxzL2FwcCc7XG5pbXBvcnQge2xvZ30gZnJvbSAnLi4vdXRpbHMvbG9nJztcblxuZXhwb3J0IGNvbnN0IGNvbmZpZyA9ICh0eXBlOiBzdHJpbmcsIGNtZDogYW55LCBjYWxsYmFjazogYW55ID0gKCkgPT4gKHt9KSk6IFByb21pc2U8bnVtYmVyPiA9PiB7XG4gIGNvbnN0IHtjbGlOYW1lID0gJ0xleCcsIGpzb24sIHF1aWV0fSA9IGNtZDtcbiAgY29uc3QgdmFsaWRUeXBlczogc3RyaW5nW10gPSBbJ2FwcCcsICdqZXN0JywgJ3dlYnBhY2snXTtcblxuICBpZighdmFsaWRUeXBlcy5pbmNsdWRlcyh0eXBlKSkge1xuICAgIGxvZyhgXFxuJHtjbGlOYW1lfSBFcnJvcjogT3B0aW9uIGZvciAke3R5cGV9IG5vdCBmb3VuZC4gQ29uZmlndXJhdGlvbnMgb25seSBhdmFpbGFibGUgZm9yIGFwcCwgamVzdCwgYW5kIHdlYnBhY2suYCwgJ2Vycm9yJywgcXVpZXQpO1xuICAgIGNhbGxiYWNrKDEpO1xuICAgIHJldHVybiBQcm9taXNlLnJlc29sdmUoMSk7XG4gIH1cblxuICAvLyBEaXNwbGF5IHN0YXR1c1xuICBsb2coYCR7Y2xpTmFtZX0gZ2VuZXJhdGluZyBjb25maWd1cmF0aW9uIGZvciAke3N0YXJ0Q2FzZSh0eXBlKX0uLi5gLCAnaW5mbycsIHF1aWV0KTtcblxuICAvLyBHZXQgY3VzdG9tIGNvbmZpZ3VyYXRpb25cbiAgTGV4Q29uZmlnLnBhcnNlQ29uZmlnKGNtZCk7XG5cbiAgbGV0IGNvbmZpZ09wdGlvbnM7XG5cbiAgc3dpdGNoKHR5cGUpIHtcbiAgICBjYXNlICdhcHAnOlxuICAgICAgY29uZmlnT3B0aW9ucyA9IExleENvbmZpZy5jb25maWc7XG4gICAgICBicmVhaztcbiAgICBjYXNlICdlc2J1aWxkJzpcbiAgICAgIGNvbmZpZ09wdGlvbnMgPSByZXF1aXJlKCcuLi8uLi9lc2J1aWxkT3B0aW9ucycpO1xuICAgICAgYnJlYWs7XG4gICAgY2FzZSAnamVzdCc6XG4gICAgICBjb25maWdPcHRpb25zID0gcmVxdWlyZSgnLi4vLi4vamVzdC5jb25maWcubGV4Jyk7XG4gICAgICBicmVhaztcbiAgICBjYXNlICd3ZWJwYWNrJzpcbiAgICAgIGNvbmZpZ09wdGlvbnMgPSByZXF1aXJlKCcuLi8uLi93ZWJwYWNrLmNvbmZpZycpO1xuICAgICAgYnJlYWs7XG4gIH1cblxuICAvLyBPdXRwdXQgY29uZmlnIHRvIGNvbnNvbGVcbiAgY29uc3QganNvbk91dHB1dDogc3RyaW5nID0gSlNPTi5zdHJpbmdpZnkoY29uZmlnT3B0aW9ucywgbnVsbCwgMik7XG5cbiAgaWYoanNvbikge1xuICAgIC8vIFNwaW5uZXJcbiAgICBjb25zdCBzcGlubmVyID0gY3JlYXRlU3Bpbm5lcihxdWlldCk7XG5cbiAgICAvLyBTdGFydCBzcGlubmVyXG4gICAgc3Bpbm5lci5zdGFydCgnQ3JlYXRpbmcgSlNPTiBvdXRwdXQuLi4nKTtcblxuICAgIC8vIFNhdmUganNvbiBsb2NhbGx5XG4gICAgZnMud3JpdGVGaWxlU3luYyhqc29uLCBqc29uT3V0cHV0KTtcblxuICAgIC8vIFN1Y2Nlc3Mgc3Bpbm5lclxuICAgIHNwaW5uZXIuc3VjY2VlZChgU3VjY2Vzc2Z1bGx5IHNhdmVkIEpTT04gb3V0cHV0IHRvICR7cGF0aC5yZWxhdGl2ZShwcm9jZXNzLmN3ZCgpLCBqc29uKX1gKTtcbiAgfVxuXG4gIGNhbGxiYWNrKDApO1xuICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKDApO1xufTtcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUlBLGdCQUFlO0FBQ2YsdUJBQXNCO0FBQ3RCLFdBQXNCO0FBRXRCLHVCQUF3QjtBQUN4QixpQkFBNEI7QUFDNUIsaUJBQWtCO0FBRVgsTUFBTSxTQUFTLENBQUMsTUFBYyxLQUFVLFdBQWdCLE1BQU8sRUFBQyxPQUF3QjtBQUM3RixRQUFNLEVBQUMsVUFBVSxPQUFPLE1BQU0sVUFBUztBQUN2QyxRQUFNLGFBQXVCLENBQUMsT0FBTyxRQUFRLFNBQVM7QUFFdEQsTUFBRyxDQUFDLFdBQVcsU0FBUyxJQUFJLEdBQUc7QUFDN0Isd0JBQUk7QUFBQSxFQUFLLDZCQUE2Qiw2RUFBNkUsU0FBUyxLQUFLO0FBQ2pJLGFBQVMsQ0FBQztBQUNWLFdBQU8sUUFBUSxRQUFRLENBQUM7QUFBQSxFQUMxQjtBQUdBLHNCQUFJLEdBQUcsd0NBQXdDLDhCQUFVLElBQUksUUFBUSxRQUFRLEtBQUs7QUFHbEYsNkJBQVUsWUFBWSxHQUFHO0FBRXpCLE1BQUk7QUFFSixVQUFPO0FBQUEsU0FDQTtBQUNILHNCQUFnQiwyQkFBVTtBQUMxQjtBQUFBLFNBQ0c7QUFDSCxzQkFBZ0IsUUFBUSxzQkFBc0I7QUFDOUM7QUFBQSxTQUNHO0FBQ0gsc0JBQWdCLFFBQVEsdUJBQXVCO0FBQy9DO0FBQUEsU0FDRztBQUNILHNCQUFnQixRQUFRLHNCQUFzQjtBQUM5QztBQUFBO0FBSUosUUFBTSxhQUFxQixLQUFLLFVBQVUsZUFBZSxNQUFNLENBQUM7QUFFaEUsTUFBRyxNQUFNO0FBRVAsVUFBTSxVQUFVLDhCQUFjLEtBQUs7QUFHbkMsWUFBUSxNQUFNLHlCQUF5QjtBQUd2QyxzQkFBRyxjQUFjLE1BQU0sVUFBVTtBQUdqQyxZQUFRLFFBQVEscUNBQXFDLEtBQUssU0FBUyxRQUFRLElBQUksR0FBRyxJQUFJLEdBQUc7QUFBQSxFQUMzRjtBQUVBLFdBQVMsQ0FBQztBQUNWLFNBQU8sUUFBUSxRQUFRLENBQUM7QUFDMUI7IiwKICAibmFtZXMiOiBbXQp9Cg==
@@ -4,56 +4,51 @@ 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 __reExport = (target, module2, copyDefault, desc) => {
13
- if (module2 && typeof module2 === "object" || typeof module2 === "function") {
14
- for (let key of __getOwnPropNames(module2))
15
- if (!__hasOwnProp.call(target, key) && (copyDefault || key !== "default"))
16
- __defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
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 target;
17
+ return to;
19
18
  };
20
- var __toESM = (module2, isNodeMode) => {
21
- return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", !isNodeMode && module2 && module2.__esModule ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
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 copy_exports = {};
29
22
  __export(copy_exports, {
30
23
  copy: () => copy
31
24
  });
25
+ module.exports = __toCommonJS(copy_exports);
32
26
  var import_fs = __toESM(require("fs"));
33
- var import_utils = require("../utils");
27
+ var import_app = require("../utils/app");
28
+ var import_log = require("../utils/log");
34
29
  const copy = (from, to, cmd, callback = () => ({})) => {
35
30
  const { cliName = "Lex", quiet } = cmd;
36
- (0, import_utils.log)(`${cliName} copying "${to}"...`, "info", quiet);
31
+ (0, import_log.log)(`${cliName} copying "${to}"...`, "info", quiet);
37
32
  if (!import_fs.default.existsSync(from)) {
38
- (0, import_utils.log)(`
33
+ (0, import_log.log)(`
39
34
  ${cliName} Error: Path not found, "${from}"...`, "error", quiet);
40
35
  callback(1);
41
36
  return Promise.resolve(1);
42
37
  }
43
38
  if (import_fs.default.lstatSync(from).isDirectory()) {
44
39
  try {
45
- (0, import_utils.copyFolderRecursiveSync)(from, to);
40
+ (0, import_app.copyFolderRecursiveSync)(from, to);
46
41
  } catch (error) {
47
- (0, import_utils.log)(`
42
+ (0, import_log.log)(`
48
43
  ${cliName} Error: Cannot copy "${from}". ${error.message}`, "error", quiet);
49
44
  callback(1);
50
45
  return Promise.resolve(1);
51
46
  }
52
47
  } else {
53
48
  try {
54
- (0, import_utils.copyFileSync)(from, to);
49
+ (0, import_app.copyFileSync)(from, to);
55
50
  } catch (error) {
56
- (0, import_utils.log)(`
51
+ (0, import_log.log)(`
57
52
  ${cliName} Error: Cannot copy "${from}" ${error.message}`, "error", quiet);
58
53
  callback(1);
59
54
  return Promise.resolve(1);
@@ -62,8 +57,8 @@ ${cliName} Error: Cannot copy "${from}" ${error.message}`, "error", quiet);
62
57
  callback(0);
63
58
  return Promise.resolve(0);
64
59
  };
65
- module.exports = __toCommonJS(copy_exports);
66
60
  // Annotate the CommonJS export names for ESM import in node:
67
61
  0 && (module.exports = {
68
62
  copy
69
63
  });
64
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2NvcHkudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE4LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQgZnMgZnJvbSAnZnMnO1xuXG5pbXBvcnQge2NvcHlGaWxlU3luYywgY29weUZvbGRlclJlY3Vyc2l2ZVN5bmN9IGZyb20gJy4uL3V0aWxzL2FwcCc7XG5pbXBvcnQge2xvZ30gZnJvbSAnLi4vdXRpbHMvbG9nJztcblxuZXhwb3J0IGNvbnN0IGNvcHkgPSAoZnJvbTogc3RyaW5nLCB0bzogc3RyaW5nLCBjbWQ6IGFueSwgY2FsbGJhY2s6IGFueSA9ICgpID0+ICh7fSkpOiBQcm9taXNlPG51bWJlcj4gPT4ge1xuICBjb25zdCB7Y2xpTmFtZSA9ICdMZXgnLCBxdWlldH0gPSBjbWQ7XG5cbiAgLy8gRGlzcGxheSBtZXNzYWdlXG4gIGxvZyhgJHtjbGlOYW1lfSBjb3B5aW5nIFwiJHt0b31cIi4uLmAsICdpbmZvJywgcXVpZXQpO1xuXG4gIGlmKCFmcy5leGlzdHNTeW5jKGZyb20pKSB7XG4gICAgbG9nKGBcXG4ke2NsaU5hbWV9IEVycm9yOiBQYXRoIG5vdCBmb3VuZCwgXCIke2Zyb219XCIuLi5gLCAnZXJyb3InLCBxdWlldCk7XG4gICAgY2FsbGJhY2soMSk7XG4gICAgcmV0dXJuIFByb21pc2UucmVzb2x2ZSgxKTtcbiAgfVxuXG4gIGlmKGZzLmxzdGF0U3luYyhmcm9tKS5pc0RpcmVjdG9yeSgpKSB7XG4gICAgdHJ5IHtcbiAgICAgIC8vIENvcHkgZGlyZWN0b3J5XG4gICAgICBjb3B5Rm9sZGVyUmVjdXJzaXZlU3luYyhmcm9tLCB0byk7XG4gICAgfSBjYXRjaChlcnJvcikge1xuICAgICAgbG9nKGBcXG4ke2NsaU5hbWV9IEVycm9yOiBDYW5ub3QgY29weSBcIiR7ZnJvbX1cIi4gJHtlcnJvci5tZXNzYWdlfWAsICdlcnJvcicsIHF1aWV0KTtcbiAgICAgIGNhbGxiYWNrKDEpO1xuICAgICAgcmV0dXJuIFByb21pc2UucmVzb2x2ZSgxKTtcbiAgICB9XG4gIH0gZWxzZSB7XG4gICAgdHJ5IHtcbiAgICAgIC8vIENvcHkgZmlsZVxuICAgICAgY29weUZpbGVTeW5jKGZyb20sIHRvKTtcbiAgICB9IGNhdGNoKGVycm9yKSB7XG4gICAgICBsb2coYFxcbiR7Y2xpTmFtZX0gRXJyb3I6IENhbm5vdCBjb3B5IFwiJHtmcm9tfVwiICR7ZXJyb3IubWVzc2FnZX1gLCAnZXJyb3InLCBxdWlldCk7XG4gICAgICBjYWxsYmFjaygxKTtcbiAgICAgIHJldHVybiBQcm9taXNlLnJlc29sdmUoMSk7XG4gICAgfVxuICB9XG5cbiAgY2FsbGJhY2soMCk7XG4gIHJldHVybiBQcm9taXNlLnJlc29sdmUoMCk7XG59O1xuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBSUEsZ0JBQWU7QUFFZixpQkFBb0Q7QUFDcEQsaUJBQWtCO0FBRVgsTUFBTSxPQUFPLENBQUMsTUFBYyxJQUFZLEtBQVUsV0FBZ0IsTUFBTyxFQUFDLE9BQXdCO0FBQ3ZHLFFBQU0sRUFBQyxVQUFVLE9BQU8sVUFBUztBQUdqQyxzQkFBSSxHQUFHLG9CQUFvQixVQUFVLFFBQVEsS0FBSztBQUVsRCxNQUFHLENBQUMsa0JBQUcsV0FBVyxJQUFJLEdBQUc7QUFDdkIsd0JBQUk7QUFBQSxFQUFLLG1DQUFtQyxZQUFZLFNBQVMsS0FBSztBQUN0RSxhQUFTLENBQUM7QUFDVixXQUFPLFFBQVEsUUFBUSxDQUFDO0FBQUEsRUFDMUI7QUFFQSxNQUFHLGtCQUFHLFVBQVUsSUFBSSxFQUFFLFlBQVksR0FBRztBQUNuQyxRQUFJO0FBRUYsOENBQXdCLE1BQU0sRUFBRTtBQUFBLElBQ2xDLFNBQVEsT0FBTjtBQUNBLDBCQUFJO0FBQUEsRUFBSywrQkFBK0IsVUFBVSxNQUFNLFdBQVcsU0FBUyxLQUFLO0FBQ2pGLGVBQVMsQ0FBQztBQUNWLGFBQU8sUUFBUSxRQUFRLENBQUM7QUFBQSxJQUMxQjtBQUFBLEVBQ0YsT0FBTztBQUNMLFFBQUk7QUFFRixtQ0FBYSxNQUFNLEVBQUU7QUFBQSxJQUN2QixTQUFRLE9BQU47QUFDQSwwQkFBSTtBQUFBLEVBQUssK0JBQStCLFNBQVMsTUFBTSxXQUFXLFNBQVMsS0FBSztBQUNoRixlQUFTLENBQUM7QUFDVixhQUFPLFFBQVEsUUFBUSxDQUFDO0FBQUEsSUFDMUI7QUFBQSxFQUNGO0FBRUEsV0FBUyxDQUFDO0FBQ1YsU0FBTyxRQUFRLFFBQVEsQ0FBQztBQUMxQjsiLAogICJuYW1lcyI6IFtdCn0K
@@ -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 __reExport = (target, module2, copyDefault, desc) => {
13
- if (module2 && typeof module2 === "object" || typeof module2 === "function") {
14
- for (let key of __getOwnPropNames(module2))
15
- if (!__hasOwnProp.call(target, key) && (copyDefault || key !== "default"))
16
- __defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
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 target;
17
+ return to;
19
18
  };
20
- var __toESM = (module2, isNodeMode) => {
21
- return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", !isNodeMode && module2 && module2.__esModule ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
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
  });
25
+ module.exports = __toCommonJS(create_exports);
32
26
  var import_fs = __toESM(require("fs"));
33
27
  var import_path = __toESM(require("path"));
34
28
  var import_changelog = require("../create/changelog");
35
29
  var import_LexConfig = require("../LexConfig");
36
- var import_utils = require("../utils");
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, import_utils.log)(`${cliName} creating ${type}...`, "info", quiet);
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, import_utils.getFilenames)({
50
+ const { nameCaps, templateExt, templatePath } = (0, import_app.getFilenames)({
56
51
  cliName,
57
52
  name: outputName,
58
53
  quiet,
@@ -61,22 +56,22 @@ const create = async (type, cmd, callback = () => ({})) => {
61
56
  });
62
57
  const storePath = `${cwd}/${nameCaps}Store`;
63
58
  if (!import_fs.default.existsSync(storePath)) {
64
- (0, import_utils.copyFolderRecursiveSync)(import_path.default.resolve(__dirname, templatePath, "./.SampleStore"), cwd);
59
+ (0, import_app.copyFolderRecursiveSync)(import_path.default.resolve(__dirname, templatePath, "./.SampleStore"), cwd);
65
60
  import_fs.default.renameSync(`${cwd}/.SampleStore`, storePath);
66
61
  const storeTestPath = `${storePath}/${nameCaps}Store.test${templateExt}`;
67
62
  import_fs.default.renameSync(`${storePath}/SampleStore.test${templateExt}.txt`, storeTestPath);
68
- (0, import_utils.updateTemplateName)(storeTestPath, outputName, nameCaps);
63
+ (0, import_app.updateTemplateName)(storeTestPath, outputName, nameCaps);
69
64
  const storeFilePath = `${storePath}/${nameCaps}Store${templateExt}`;
70
65
  import_fs.default.renameSync(`${storePath}/SampleStore${templateExt}.txt`, storeFilePath);
71
- (0, import_utils.updateTemplateName)(storeFilePath, outputName, nameCaps);
66
+ (0, import_app.updateTemplateName)(storeFilePath, outputName, nameCaps);
72
67
  } else {
73
- (0, import_utils.log)(`
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, import_utils.log)(`
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,7 +79,7 @@ ${cliName} Error: Cannot create new ${type}. ${error.message}`, "error", quiet);
84
79
  break;
85
80
  }
86
81
  case "tsconfig": {
87
- await (0, import_utils.removeFiles)("tsconfig.json", true);
82
+ await (0, import_app.removeFiles)("tsconfig.json", true);
88
83
  const templatePath = import_path.default.resolve(__dirname, "../../tsconfig.template.json");
89
84
  let data = import_fs.default.readFileSync(templatePath, "utf8");
90
85
  data = data.replace(/.\/src/g, sourcePath);
@@ -94,7 +89,7 @@ ${cliName} Error: Cannot create new ${type}. ${error.message}`, "error", quiet);
94
89
  break;
95
90
  }
96
91
  case "view": {
97
- const { nameCaps, templatePath, templateReact } = (0, import_utils.getFilenames)({
92
+ const { nameCaps, templatePath, templateReact } = (0, import_app.getFilenames)({
98
93
  cliName,
99
94
  name: outputName,
100
95
  quiet,
@@ -104,25 +99,25 @@ ${cliName} Error: Cannot create new ${type}. ${error.message}`, "error", quiet);
104
99
  const viewPath = `${cwd}/${nameCaps}View`;
105
100
  try {
106
101
  if (!import_fs.default.existsSync(viewPath)) {
107
- (0, import_utils.copyFolderRecursiveSync)(import_path.default.resolve(__dirname, templatePath, "./.SampleView"), cwd);
102
+ (0, import_app.copyFolderRecursiveSync)(import_path.default.resolve(__dirname, templatePath, "./.SampleView"), cwd);
108
103
  import_fs.default.renameSync(`${cwd}/.SampleView`, viewPath);
109
104
  const viewStylePath = `${viewPath}/${outputName}View.css`;
110
105
  import_fs.default.renameSync(`${viewPath}/sampleView.css`, viewStylePath);
111
- (0, import_utils.updateTemplateName)(viewStylePath, outputName, nameCaps);
106
+ (0, import_app.updateTemplateName)(viewStylePath, outputName, nameCaps);
112
107
  const viewTestPath = `${viewPath}/${nameCaps}View.test${templateReact}`;
113
108
  import_fs.default.renameSync(`${viewPath}/SampleView.test${templateReact}.txt`, viewTestPath);
114
- (0, import_utils.updateTemplateName)(viewTestPath, outputName, nameCaps);
109
+ (0, import_app.updateTemplateName)(viewTestPath, outputName, nameCaps);
115
110
  const viewFilePath = `${viewPath}/${nameCaps}View${templateReact}`;
116
111
  import_fs.default.renameSync(`${viewPath}/SampleView${templateReact}.txt`, viewFilePath);
117
- (0, import_utils.updateTemplateName)(viewFilePath, outputName, nameCaps);
112
+ (0, import_app.updateTemplateName)(viewFilePath, outputName, nameCaps);
118
113
  } else {
119
- (0, import_utils.log)(`
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, import_utils.log)(`
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, import_utils.removeFiles)(".vscode", true);
134
- (0, import_utils.copyFolderRecursiveSync)(import_path.default.resolve(__dirname, "../../.vscode"), cwd);
128
+ await (0, import_app.removeFiles)(".vscode", true);
129
+ (0, import_app.copyFolderRecursiveSync)(import_path.default.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 fs from 'fs';\nimport 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": []
}
