@nlabs/lex 1.37.8 → 1.39.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.
package/.eslintrc CHANGED
@@ -3,6 +3,7 @@
3
3
  "styleguidejs/typescript"
4
4
  ],
5
5
  "rules": {
6
+ "import/extensions": 0,
6
7
  "no-useless-escape": 0
7
8
  }
8
9
  }
package/.postcssrc.js CHANGED
@@ -2,34 +2,44 @@
2
2
  * Copyright (c) 2018-Present, Nitrogen Labs, Inc.
3
3
  * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
4
4
  */
5
- const path = require('path');
6
- const {relativeFilePath} = require('./dist/utils/file');
7
- const pluginPath = relativeFilePath('postcss-cli', path.resolve(__dirname, './node_modules'));
8
- const nodePath = path.resolve(pluginPath, '../');
5
+ import autoprefixer from 'autoprefixer';
6
+ import cssnano from 'cssnano';
7
+ import postcssBrowserReporter from 'postcss-browser-reporter';
8
+ import postcssCustomProperties from 'postcss-custom-properties';
9
+ import postcssFlexbugsFixes from 'postcss-flexbugs-fixes';
10
+ import postcssFor from 'postcss-for';
11
+ import postcssImport from 'postcss-import';
12
+ import postcssNesting from 'postcss-nesting';
13
+ import postcssPercentage from 'postcss-percentage';
14
+ import postcssPresetEnv from 'postcss-preset-env';
15
+ import postcssUrl from 'postcss-url';
16
+ import {fileURLToPath} from 'url';
9
17
 
10
- module.exports = {
18
+ const config = {
11
19
  plugins: [
12
- require(`${nodePath}/postcss-import`),
13
- require(`${nodePath}/postcss-url`),
14
- require(`${nodePath}/postcss-for`),
15
- require(`${nodePath}/postcss-percentage`)({
16
- floor: true,
17
- precision: 9,
18
- trimTrailingZero: true
19
- }),
20
- require(`${nodePath}/postcss-custom-properties`)({
21
- preserve: false,
22
- strict: false,
23
- warnings: false
24
- }),
25
- require(`${nodePath}/autoprefixer`),
26
- require(`${nodePath}/postcss-nesting`),
27
- require(`${nodePath}/postcss-flexbugs-fixes`),
28
- require(`${nodePath}/postcss-preset-env`)({
29
- browsers: ['last 5 versions'],
30
- stage: 0
31
- }),
32
- require(`${nodePath}/cssnano`)({autoprefixer: false}),
33
- require(`${nodePath}/postcss-browser-reporter`)
34
- ]
35
- }
20
+ postcssImport,
21
+ postcssUrl,
22
+ postcssFor,
23
+ postcssPercentage({
24
+ floor: true,
25
+ precision: 9,
26
+ trimTrailingZero: true
27
+ }),
28
+ postcssCustomProperties({
29
+ preserve: false,
30
+ strict: false,
31
+ warnings: false
32
+ }),
33
+ autoprefixer,
34
+ postcssNesting,
35
+ postcssFlexbugsFixes,
36
+ postcssPresetEnv({
37
+ browsers: ['last 5 versions'],
38
+ stage: 0
39
+ }),
40
+ cssnano({autoprefixer: false}),
41
+ postcssBrowserReporter
42
+ ]
43
+ }
44
+
45
+ export default config;
package/dist/LexConfig.js CHANGED
@@ -1,35 +1,8 @@
1
- var __create = Object.create;
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __getProtoOf = Object.getPrototypeOf;
6
- var __hasOwnProp = Object.prototype.hasOwnProperty;
7
- var __export = (target, all) => {
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(
20
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
21
- mod
22
- ));
23
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
24
- var LexConfig_exports = {};
25
- __export(LexConfig_exports, {
26
- LexConfig: () => LexConfig
27
- });
28
- module.exports = __toCommonJS(LexConfig_exports);
29
- var fs = __toESM(require("fs-extra"));
30
- var path = __toESM(require("path"));
31
- var import_file = require("./utils/file");
32
- var import_log = require("./utils/log");
1
+ import { existsSync, readFileSync, writeFileSync } from "fs";
2
+ import { extname as pathExtname, resolve as pathResolve } from "path";
3
+ import { fileURLToPath } from "url";
4
+ import { relativeFilePath } from "./utils/file.js";
5
+ import { log } from "./utils/log.js";
33
6
  const cwd = process.cwd();
34
7
  class LexConfig {
35
8
  static config = {
@@ -39,12 +12,12 @@ class LexConfig {
39
12
  esbuild: {},
40
13
  env: null,
41
14
  jest: {},
42
- outputFullPath: path.resolve(cwd, "./dist"),
15
+ outputFullPath: pathResolve(cwd, "./dist"),
43
16
  outputHash: false,
44
17
  outputPath: "./dist",
45
18
  packageManager: "npm",
46
19
  preset: "web",
47
- sourceFullPath: path.resolve(cwd, "./src"),
20
+ sourceFullPath: pathResolve(cwd, "./src"),
48
21
  sourcePath: "./src",
49
22
  targetEnvironment: "web",
50
23
  useGraphQl: false,
@@ -56,8 +29,8 @@ class LexConfig {
56
29
  const { sourceFullPath } = LexConfig.config;
57
30
  const { entryJs } = LexConfig.config;
58
31
  if (entryJs === "index.js" && value) {
59
- const indexPath = path.resolve(cwd, sourceFullPath, "index.tsx");
60
- const hasIndexTsx = fs.existsSync(indexPath);
32
+ const indexPath = pathResolve(cwd, sourceFullPath, "index.tsx");
33
+ const hasIndexTsx = existsSync(indexPath);
61
34
  if (hasIndexTsx) {
62
35
  LexConfig.config.entryJs = "index.tsx";
63
36
  } else {
@@ -65,6 +38,7 @@ class LexConfig {
65
38
  }
66
39
  }
67
40
  }
41
+ // Set options from a custom configuration file
68
42
  static updateConfig(updatedConfig) {
69
43
  const { outputFullPath, outputPath, sourcePath, sourceFullPath, useTypescript } = updatedConfig;
70
44
  const cwd2 = process.cwd();
@@ -72,24 +46,25 @@ class LexConfig {
72
46
  LexConfig.useTypescript = useTypescript;
73
47
  }
74
48
  if (outputPath !== void 0 && outputFullPath === void 0) {
75
- updatedConfig.outputFullPath = path.resolve(cwd2, outputPath);
49
+ updatedConfig.outputFullPath = pathResolve(cwd2, outputPath);
76
50
  }
77
51
  if (sourcePath !== void 0 && sourceFullPath === void 0) {
78
- updatedConfig.sourceFullPath = path.resolve(cwd2, sourcePath);
52
+ updatedConfig.sourceFullPath = pathResolve(cwd2, sourcePath);
79
53
  }
80
54
  LexConfig.config = { ...LexConfig.config, ...updatedConfig };
81
55
  return LexConfig.config;
82
56
  }
57
+ // Set option updates from the command line
83
58
  static addConfigParams(cmd, params) {
84
59
  const nameProperty = "_name";
85
60
  const { environment, outputPath, sourcePath, typescript } = cmd;
86
61
  if (outputPath !== void 0) {
87
62
  params.outputPath = outputPath;
88
- params.outputFullPath = path.resolve(cwd, outputPath);
63
+ params.outputFullPath = pathResolve(cwd, outputPath);
89
64
  }
90
65
  if (sourcePath !== void 0) {
91
66
  params.sourcePath = sourcePath;
92
- params.sourceFullPath = path.resolve(cwd, sourcePath);
67
+ params.sourceFullPath = pathResolve(cwd, sourcePath);
93
68
  }
94
69
  if (typescript !== void 0) {
95
70
  params.useTypescript = typescript;
@@ -107,17 +82,18 @@ class LexConfig {
107
82
  0
108
83
  );
109
84
  }
85
+ // Get configuration
110
86
  static parseConfig(cmd, isRoot = true) {
111
87
  const { cliName = "Lex", lexConfig, lexConfigName, quiet, typescript } = cmd;
112
88
  const configName = lexConfigName || "lex.config.js";
113
- const defaultConfigPath = isRoot ? path.resolve(cwd, `./${configName}`) : (0, import_file.relativeFilePath)(configName, cwd);
89
+ const defaultConfigPath = isRoot ? pathResolve(cwd, `./${configName}`) : relativeFilePath(configName, cwd);
114
90
  const configPath = lexConfig || defaultConfigPath;
115
- const configExists = fs.existsSync(configPath);
91
+ const configExists = existsSync(configPath);
116
92
  if (configExists) {
117
- (0, import_log.log)(`Using ${cliName} configuration file: ${configPath}`, "note", quiet);
118
- const ext = path.extname(configPath);
93
+ log(`Using ${cliName} configuration file: ${configPath}`, "note", quiet);
94
+ const ext = pathExtname(configPath);
119
95
  if (ext === ".json") {
120
- const configContent = fs.readFileSync(configPath, "utf8");
96
+ const configContent = readFileSync(configPath, "utf8");
121
97
  if (configContent) {
122
98
  let configJson;
123
99
  try {
@@ -127,14 +103,14 @@ class LexConfig {
127
103
  }
128
104
  LexConfig.addConfigParams(cmd, configJson);
129
105
  } else {
130
- (0, import_log.log)(`
106
+ log(`
131
107
  ${cliName} Error: Config file malformed, ${configPath}`, "error", quiet);
132
108
  }
133
109
  } else if (ext === ".js") {
134
- const lexCustomConfig = require(configPath);
110
+ const lexCustomConfig = readFileSync(configPath).toJSON();
135
111
  LexConfig.addConfigParams(cmd, lexCustomConfig);
136
112
  } else {
137
- (0, import_log.log)(`
113
+ log(`
138
114
  ${cliName} Error: Config file must be a JS or JSON file.`, "error", quiet);
139
115
  }
140
116
  } else {
@@ -143,14 +119,14 @@ ${cliName} Error: Config file must be a JS or JSON file.`, "error", quiet);
143
119
  }
144
120
  }
145
121
  static checkTypescriptConfig() {
146
- const tsconfigPath = path.resolve(cwd, "./tsconfig.json");
147
- if (!fs.existsSync(tsconfigPath)) {
148
- fs.writeFileSync(tsconfigPath, fs.readFileSync(path.resolve(__dirname, "../../../tsconfig.base.json")));
122
+ const tsconfigPath = pathResolve(cwd, "./tsconfig.json");
123
+ if (!existsSync(tsconfigPath)) {
124
+ const dirName = fileURLToPath(new URL(".", import.meta.url));
125
+ writeFileSync(tsconfigPath, readFileSync(pathResolve(dirName, "../../../tsconfig.base.json")));
149
126
  }
150
127
  }
151
128
  }
152
- // Annotate the CommonJS export names for ESM import in node:
153
- 0 && (module.exports = {
129
+ export {
154
130
  LexConfig
155
- });
156
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/LexConfig.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 {relativeFilePath} from './utils/file';\nimport {log} from './utils/log';\n\nconst cwd: string = process.cwd();\n\nexport interface LexConfigType {\n  configFiles?: string[];\n  entryHTML?: string;\n  entryJs?: string;\n  esbuild?: any;\n  env?: object;\n  gitUrl?: string;\n  jest?: any;\n  libraryName?: string;\n  libraryTarget?: string;\n  outputFile?: string;\n  outputFullPath?: string;\n  outputHash?: boolean;\n  outputPath?: string;\n  packageManager?: 'npm' | 'yarn';\n  preset?: 'web' | 'node' | 'lambda';\n  sourceFullPath?: string;\n  sourcePath?: string;\n  targetEnvironment?: 'node' | 'web';\n  useGraphQl?: boolean;\n  useTypescript?: boolean;\n  webpack?: any;\n}\n\nexport class LexConfig {\n  static config: LexConfigType = {\n    configFiles: [],\n    entryHTML: 'index.html',\n    entryJs: 'index.js',\n    esbuild: {},\n    env: null,\n    jest: {},\n    outputFullPath: path.resolve(cwd, './dist'),\n    outputHash: false,\n    outputPath: './dist',\n    packageManager: 'npm',\n    preset: 'web',\n    sourceFullPath: path.resolve(cwd, './src'),\n    sourcePath: './src',\n    targetEnvironment: 'web',\n    useGraphQl: false,\n    useTypescript: false,\n    webpack: {}\n  };\n\n  static set useTypescript(value: boolean) {\n    LexConfig.config.useTypescript = value;\n    const {sourceFullPath} = LexConfig.config;\n\n    // Make sure we change the default entry file if Typescript is being used.\n    const {entryJs} = LexConfig.config;\n\n    if(entryJs === 'index.js' && value) {\n      const indexPath: string = path.resolve(cwd, sourceFullPath, 'index.tsx');\n      const hasIndexTsx: boolean = fs.existsSync(indexPath);\n\n      if(hasIndexTsx) {\n        LexConfig.config.entryJs = 'index.tsx';\n      } else {\n        LexConfig.config.entryJs = 'index.ts';\n      }\n    }\n  }\n\n  // Set options from a custom configuration file\n  static updateConfig(updatedConfig: LexConfigType): LexConfigType {\n    const {outputFullPath, outputPath, sourcePath, sourceFullPath, useTypescript} = updatedConfig;\n    const cwd: string = process.cwd();\n\n    // Use Typescript\n    if(useTypescript !== undefined) {\n      LexConfig.useTypescript = useTypescript;\n    }\n\n    // Destination Path\n    if(outputPath !== undefined && outputFullPath === undefined) {\n      updatedConfig.outputFullPath = path.resolve(cwd, outputPath);\n    }\n\n    // Source code path\n    if(sourcePath !== undefined && sourceFullPath === undefined) {\n      updatedConfig.sourceFullPath = path.resolve(cwd, sourcePath);\n    }\n\n    LexConfig.config = {...LexConfig.config, ...updatedConfig};\n    return LexConfig.config;\n  }\n\n  // Set option updates from the command line\n  static addConfigParams(cmd, params: LexConfigType) {\n    const nameProperty: string = '_name';\n    const {environment, outputPath, sourcePath, typescript} = cmd;\n\n    // Custom output dir\n    if(outputPath !== undefined) {\n      params.outputPath = outputPath;\n      params.outputFullPath = path.resolve(cwd, outputPath);\n    }\n\n    // Custom source dir\n    if(sourcePath !== undefined) {\n      params.sourcePath = sourcePath;\n      params.sourceFullPath = path.resolve(cwd, sourcePath);\n    }\n\n    // Determine if we're using Typescript or Flow\n    if(typescript !== undefined) {\n      params.useTypescript = typescript;\n    }\n\n    // Set the target environment\n    if(environment !== undefined) {\n      params.targetEnvironment = environment === 'web' ? 'web' : 'node';\n    }\n\n    process.env.LEX_CONFIG = JSON.stringify(\n      {\n        ...LexConfig.updateConfig(params),\n        commandName: cmd[nameProperty],\n        isStatic: cmd.static\n      }, null, 0\n    );\n  }\n\n  // Get configuration\n  static parseConfig(cmd, isRoot: boolean = true): void {\n    const {cliName = 'Lex', lexConfig, lexConfigName, quiet, typescript} = cmd;\n    const configName: string = lexConfigName || 'lex.config.js';\n    const defaultConfigPath: string = isRoot\n      ? path.resolve(cwd, `./${configName}`)\n      : relativeFilePath(configName, cwd);\n    const configPath: string = lexConfig || defaultConfigPath;\n    const configExists: boolean = fs.existsSync(configPath);\n\n    // If user has a Lex config file, lets use it.\n    if(configExists) {\n      log(`Using ${cliName} configuration file: ${configPath}`, 'note', quiet);\n      const ext: string = path.extname(configPath);\n\n      if(ext === '.json') {\n        const configContent: string = fs.readFileSync(configPath, 'utf8');\n\n        if(configContent) {\n          let configJson: LexConfigType;\n\n          try {\n            configJson = JSON.parse(configContent);\n          } catch(error) {\n            configJson = {};\n          }\n\n          LexConfig.addConfigParams(cmd, configJson);\n        } else {\n          log(`\\n${cliName} Error: Config file malformed, ${configPath}`, 'error', quiet);\n        }\n      } else if(ext === '.js') {\n        const lexCustomConfig = require(configPath);\n        LexConfig.addConfigParams(cmd, lexCustomConfig);\n      } else {\n        log(`\\n${cliName} Error: Config file must be a JS or JSON file.`, 'error', quiet);\n      }\n    } else {\n      // Determine if we're using Typescript or Flow\n      LexConfig.useTypescript = !!typescript;\n\n      // Save config as environment variable for other commands to include\n      LexConfig.addConfigParams(cmd, LexConfig.config);\n    }\n  }\n\n  static checkTypescriptConfig() {\n    // Make sure tsconfig.json exists\n    const tsconfigPath: string = path.resolve(cwd, './tsconfig.json');\n\n    if(!fs.existsSync(tsconfigPath)) {\n      fs.writeFileSync(tsconfigPath, fs.readFileSync(path.resolve(__dirname, '../../../tsconfig.base.json')));\n    }\n  }\n}\n"],
  "mappings": "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",
  "names": ["cwd"]
}

131
+ };
132
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/LexConfig.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, writeFileSync} from 'fs';\nimport {extname as pathExtname, resolve as pathResolve} from 'path';\nimport {fileURLToPath} from 'url';\n\nimport {relativeFilePath} from './utils/file.js';\nimport {log} from './utils/log.js';\n\nconst cwd: string = process.cwd();\n\nexport interface LexConfigType {\n  configFiles?: string[];\n  entryHTML?: string;\n  entryJs?: string;\n  esbuild?: any;\n  env?: object;\n  gitUrl?: string;\n  jest?: any;\n  libraryName?: string;\n  libraryTarget?: string;\n  outputFile?: string;\n  outputFullPath?: string;\n  outputHash?: boolean;\n  outputPath?: string;\n  packageManager?: 'npm' | 'yarn';\n  preset?: 'web' | 'node' | 'lambda' | 'mobile';\n  sourceFullPath?: string;\n  sourcePath?: string;\n  targetEnvironment?: 'node' | 'web';\n  useGraphQl?: boolean;\n  useTypescript?: boolean;\n  webpack?: any;\n}\n\nexport class LexConfig {\n  static config: LexConfigType = {\n    configFiles: [],\n    entryHTML: 'index.html',\n    entryJs: 'index.js',\n    esbuild: {},\n    env: null,\n    jest: {},\n    outputFullPath: pathResolve(cwd, './dist'),\n    outputHash: false,\n    outputPath: './dist',\n    packageManager: 'npm',\n    preset: 'web',\n    sourceFullPath: pathResolve(cwd, './src'),\n    sourcePath: './src',\n    targetEnvironment: 'web',\n    useGraphQl: false,\n    useTypescript: false,\n    webpack: {}\n  };\n\n  static set useTypescript(value: boolean) {\n    LexConfig.config.useTypescript = value;\n    const {sourceFullPath} = LexConfig.config;\n\n    // Make sure we change the default entry file if Typescript is being used.\n    const {entryJs} = LexConfig.config;\n\n    if(entryJs === 'index.js' && value) {\n      const indexPath: string = pathResolve(cwd, sourceFullPath, 'index.tsx');\n      const hasIndexTsx: boolean = existsSync(indexPath);\n\n      if(hasIndexTsx) {\n        LexConfig.config.entryJs = 'index.tsx';\n      } else {\n        LexConfig.config.entryJs = 'index.ts';\n      }\n    }\n  }\n\n  // Set options from a custom configuration file\n  static updateConfig(updatedConfig: LexConfigType): LexConfigType {\n    const {outputFullPath, outputPath, sourcePath, sourceFullPath, useTypescript} = updatedConfig;\n    const cwd: string = process.cwd();\n\n    // Use Typescript\n    if(useTypescript !== undefined) {\n      LexConfig.useTypescript = useTypescript;\n    }\n\n    // Destination Path\n    if(outputPath !== undefined && outputFullPath === undefined) {\n      updatedConfig.outputFullPath = pathResolve(cwd, outputPath);\n    }\n\n    // Source code path\n    if(sourcePath !== undefined && sourceFullPath === undefined) {\n      updatedConfig.sourceFullPath = pathResolve(cwd, sourcePath);\n    }\n\n    LexConfig.config = {...LexConfig.config, ...updatedConfig};\n    return LexConfig.config;\n  }\n\n  // Set option updates from the command line\n  static addConfigParams(cmd, params: LexConfigType) {\n    const nameProperty: string = '_name';\n    const {environment, outputPath, sourcePath, typescript} = cmd;\n\n    // Custom output dir\n    if(outputPath !== undefined) {\n      params.outputPath = outputPath;\n      params.outputFullPath = pathResolve(cwd, outputPath);\n    }\n\n    // Custom source dir\n    if(sourcePath !== undefined) {\n      params.sourcePath = sourcePath;\n      params.sourceFullPath = pathResolve(cwd, sourcePath);\n    }\n\n    // Determine if we're using Typescript or Flow\n    if(typescript !== undefined) {\n      params.useTypescript = typescript;\n    }\n\n    // Set the target environment\n    if(environment !== undefined) {\n      params.targetEnvironment = environment === 'web' ? 'web' : 'node';\n    }\n\n    process.env.LEX_CONFIG = JSON.stringify(\n      {\n        ...LexConfig.updateConfig(params),\n        commandName: cmd[nameProperty],\n        isStatic: cmd.static\n      }, null, 0\n    );\n  }\n\n  // Get configuration\n  static parseConfig(cmd, isRoot: boolean = true): void {\n    const {cliName = 'Lex', lexConfig, lexConfigName, quiet, typescript} = cmd;\n    const configName: string = lexConfigName || 'lex.config.js';\n    const defaultConfigPath: string = isRoot\n      ? pathResolve(cwd, `./${configName}`)\n      : relativeFilePath(configName, cwd);\n    const configPath: string = lexConfig || defaultConfigPath;\n    const configExists: boolean = existsSync(configPath);\n\n    // If user has a Lex config file, lets use it.\n    if(configExists) {\n      log(`Using ${cliName} configuration file: ${configPath}`, 'note', quiet);\n      const ext: string = pathExtname(configPath);\n\n      if(ext === '.json') {\n        const configContent: string = readFileSync(configPath, 'utf8');\n\n        if(configContent) {\n          let configJson: LexConfigType;\n\n          try {\n            configJson = JSON.parse(configContent);\n          } catch(error) {\n            configJson = {};\n          }\n\n          LexConfig.addConfigParams(cmd, configJson);\n        } else {\n          log(`\\n${cliName} Error: Config file malformed, ${configPath}`, 'error', quiet);\n        }\n      } else if(ext === '.js') {\n        const lexCustomConfig = readFileSync(configPath).toJSON() as LexConfigType;\n        LexConfig.addConfigParams(cmd, lexCustomConfig);\n      } else {\n        log(`\\n${cliName} Error: Config file must be a JS or JSON file.`, 'error', quiet);\n      }\n    } else {\n      // Determine if we're using Typescript or Flow\n      LexConfig.useTypescript = !!typescript;\n\n      // Save config as environment variable for other commands to include\n      LexConfig.addConfigParams(cmd, LexConfig.config);\n    }\n  }\n\n  static checkTypescriptConfig() {\n    // Make sure tsconfig.json exists\n    const tsconfigPath: string = pathResolve(cwd, './tsconfig.json');\n\n    if(!existsSync(tsconfigPath)) {\n      const dirName = fileURLToPath(new URL('.', import.meta.url));\n      writeFileSync(tsconfigPath, readFileSync(pathResolve(dirName, '../../../tsconfig.base.json')));\n    }\n  }\n}\n"],
  "mappings": "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",
  "names": ["cwd"]
}

@@ -1,41 +1,12 @@
1
- var __create = Object.create;
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __getProtoOf = Object.getPrototypeOf;
6
- var __hasOwnProp = Object.prototype.hasOwnProperty;
7
- var __export = (target, all) => {
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(
20
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
21
- mod
22
- ));
23
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
24
- var build_exports = {};
25
- __export(build_exports, {
26
- build: () => build,
27
- buildWithEsBuild: () => buildWithEsBuild,
28
- buildWithWebpack: () => buildWithWebpack
29
- });
30
- module.exports = __toCommonJS(build_exports);
31
- var import_esbuild_graphql_loader = __toESM(require("@luckycatfactory/esbuild-graphql-loader"));
32
- var import_esbuild = require("esbuild");
33
- var import_execa = __toESM(require("execa"));
34
- var path = __toESM(require("path"));
35
- var import_LexConfig = require("../LexConfig");
36
- var import_app = require("../utils/app");
37
- var import_log = require("../utils/log");
38
- var import_file = require("../utils/file");
1
+ import graphqlLoaderPlugin from "@luckycatfactory/esbuild-graphql-loader";
2
+ import { build as esBuild } from "esbuild";
3
+ import { execa } from "execa";
4
+ import { resolve as pathResolve } from "path";
5
+ import { fileURLToPath } from "url";
6
+ import { LexConfig } from "../LexConfig.js";
7
+ import { checkLinkedModules, createSpinner, removeFiles } from "../utils/app.js";
8
+ import { relativeNodePath } from "../utils/file.js";
9
+ import { log } from "../utils/log.js";
39
10
  const buildWithEsBuild = async (spinner, cmd, callback) => {
40
11
  const {
41
12
  cliName = "Lex",
@@ -48,7 +19,7 @@ const buildWithEsBuild = async (spinner, cmd, callback) => {
48
19
  targetEnvironment,
49
20
  useGraphQl,
50
21
  useTypescript
51
- } = import_LexConfig.LexConfig.config;
22
+ } = LexConfig.config;
52
23
  const loader = {
53
24
  ".js": "js"
54
25
  };
@@ -58,10 +29,10 @@ const buildWithEsBuild = async (spinner, cmd, callback) => {
58
29
  }
59
30
  const plugins = [];
60
31
  if (useGraphQl) {
61
- plugins.push((0, import_esbuild_graphql_loader.default)());
32
+ plugins.push(graphqlLoaderPlugin());
62
33
  }
63
34
  try {
64
- await (0, import_esbuild.build)({
35
+ await esBuild({
65
36
  bundle: true,
66
37
  color: true,
67
38
  entryPoints: [sourcePath],
@@ -70,12 +41,12 @@ const buildWithEsBuild = async (spinner, cmd, callback) => {
70
41
  platform: "node",
71
42
  plugins,
72
43
  sourcemap: "inline",
73
- target: targetEnvironment === "node" ? "node16" : "es2016",
44
+ target: targetEnvironment === "node" ? "node18" : "es2016",
74
45
  watch
75
46
  });
76
47
  spinner.succeed("Build completed successfully!");
77
48
  } catch (error) {
78
- (0, import_log.log)(`
49
+ log(`
79
50
  ${cliName} Error: ${error.message}`, "error", quiet);
80
51
  if (!quiet) {
81
52
  console.error(error);
@@ -98,7 +69,7 @@ const buildWithWebpack = async (spinner, cmd, callback) => {
98
69
  outputJsonpFunction,
99
70
  outputLibrary,
100
71
  outputLibraryTarget,
101
- outputPathinfo,
72
+ outputPathInfo,
102
73
  outputPublicPath,
103
74
  outputSourceMapFilename,
104
75
  quiet = false,
@@ -107,10 +78,11 @@ const buildWithWebpack = async (spinner, cmd, callback) => {
107
78
  let webpackConfig;
108
79
  if (config) {
109
80
  const isRelativeConfig = config.substr(0, 2) === "./";
110
- const fullConfigPath = isRelativeConfig ? path.resolve(process.cwd(), config) : config;
81
+ const fullConfigPath = isRelativeConfig ? pathResolve(process.cwd(), config) : config;
111
82
  webpackConfig = fullConfigPath;
112
83
  } else {
113
- webpackConfig = path.resolve(__dirname, "../../webpack.config.js");
84
+ const dirName = fileURLToPath(new URL(".", import.meta.url));
85
+ webpackConfig = pathResolve(dirName, "../../webpack.config.js");
114
86
  }
115
87
  const webpackOptions = [
116
88
  "--color",
@@ -137,8 +109,8 @@ const buildWithWebpack = async (spinner, cmd, callback) => {
137
109
  if (outputLibraryTarget) {
138
110
  webpackOptions.push("--output-library-target", outputLibraryTarget);
139
111
  }
140
- if (outputPathinfo) {
141
- webpackOptions.push("--output-path-info", outputPathinfo);
112
+ if (outputPathInfo) {
113
+ webpackOptions.push("--output-path-info", outputPathInfo);
142
114
  }
143
115
  if (outputPublicPath) {
144
116
  webpackOptions.push("--output-public-path", outputPublicPath);
@@ -153,14 +125,15 @@ const buildWithWebpack = async (spinner, cmd, callback) => {
153
125
  webpackOptions.push("--watch");
154
126
  }
155
127
  try {
156
- const nodePath = path.resolve(__dirname, "../../node_modules");
157
- const webpackPath = (0, import_file.relativeFilePath)("webpack-cli/bin/cli.js", nodePath);
158
- await (0, import_execa.default)(webpackPath, webpackOptions, { encoding: "utf-8", stdio: "inherit" });
128
+ const dirName = fileURLToPath(new URL(".", import.meta.url));
129
+ const nodePath = pathResolve(dirName, "../../node_modules");
130
+ const webpackPath = relativeNodePath("webpack-cli/bin/cli.js", nodePath);
131
+ await execa(webpackPath, webpackOptions, { encoding: "utf-8", stdio: "inherit" });
159
132
  spinner.succeed("Build completed successfully!");
160
133
  callback(0);
161
134
  return 0;
162
135
  } catch (error) {
163
- (0, import_log.log)(`
136
+ log(`
164
137
  ${cliName} Error: ${error.message}`, "error", quiet);
165
138
  spinner.fail("Build failed.");
166
139
  callback(error.status);
@@ -175,17 +148,17 @@ const build = async (cmd, callback = () => ({})) => {
175
148
  remove,
176
149
  variables
177
150
  } = cmd;
178
- const spinner = (0, import_app.createSpinner)(quiet);
179
- (0, import_log.log)(`${cliName} building...`, "info", quiet);
180
- import_LexConfig.LexConfig.parseConfig(cmd);
181
- const { outputFullPath, useTypescript } = import_LexConfig.LexConfig.config;
182
- (0, import_app.checkLinkedModules)();
151
+ const spinner = createSpinner(quiet);
152
+ log(`${cliName} building...`, "info", quiet);
153
+ LexConfig.parseConfig(cmd);
154
+ const { outputFullPath, useTypescript } = LexConfig.config;
155
+ checkLinkedModules();
183
156
  let variablesObj = { NODE_ENV: "production" };
184
157
  if (variables) {
185
158
  try {
186
159
  variablesObj = JSON.parse(variables);
187
160
  } catch (error) {
188
- (0, import_log.log)(`
161
+ log(`
189
162
  ${cliName} Error: Environment variables option is not a valid JSON object.`, "error", quiet);
190
163
  callback(1);
191
164
  return 1;
@@ -194,20 +167,19 @@ ${cliName} Error: Environment variables option is not a valid JSON object.`, "er
194
167
  process.env = { ...process.env, ...variablesObj };
195
168
  spinner.start("Building code...");
196
169
  if (remove) {
197
- await (0, import_app.removeFiles)(outputFullPath);
170
+ await removeFiles(outputFullPath);
198
171
  }
199
172
  if (useTypescript) {
200
- import_LexConfig.LexConfig.checkTypescriptConfig();
173
+ LexConfig.checkTypescriptConfig();
201
174
  }
202
175
  if (bundler === "esbuild") {
203
176
  return buildWithEsBuild(spinner, cmd, callback);
204
177
  }
205
178
  return buildWithWebpack(spinner, cmd, callback);
206
179
  };
207
- // Annotate the CommonJS export names for ESM import in node:
208
- 0 && (module.exports = {
180
+ export {
209
181
  build,
210
182
  buildWithEsBuild,
211
183
  buildWithWebpack
212
- });
213
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/commands/build.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 graphqlLoaderPlugin from '@luckycatfactory/esbuild-graphql-loader';\nimport {build as esBuild} from 'esbuild';\nimport {default as execa} from 'execa';\nimport * as path from 'path';\n\nimport {LexConfig} from '../LexConfig';\nimport {checkLinkedModules, createSpinner, removeFiles} from '../utils/app';\nimport {log} from '../utils/log';\nimport {relativeFilePath} from '../utils/file';\n\nexport const buildWithEsBuild = async (spinner, cmd, callback) => {\n  const {\n    cliName = 'Lex',\n    outputPath,\n    quiet,\n    sourcePath,\n    watch\n  } = cmd;\n  const {\n    targetEnvironment,\n    useGraphQl,\n    useTypescript\n  } = LexConfig.config;\n\n  const loader: any = {\n    '.js': 'js'\n  };\n\n  if(useTypescript) {\n    loader['.ts'] = 'ts';\n    loader['.tsx'] = 'tsx';\n  }\n\n  // Plugins\n  const plugins = [];\n\n  if(useGraphQl) {\n    plugins.push(graphqlLoaderPlugin());\n  }\n\n  try {\n    await esBuild({\n      bundle: true,\n      color: true,\n      entryPoints: [sourcePath],\n      loader,\n      outdir: outputPath,\n      platform: 'node',\n      plugins,\n      sourcemap: 'inline',\n      target: targetEnvironment === 'node' ? 'node16' : 'es2016',\n      watch\n    });\n\n    // Stop spinner\n    spinner.succeed('Build 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 build 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\nexport const buildWithWebpack = async (spinner, cmd, callback) => {\n  const {\n    buildDelimiter,\n    cliName = 'Lex',\n    config,\n    mode,\n    outputChunkFilename,\n    outputFilename,\n    outputJsonpFunction,\n    outputLibrary,\n    outputLibraryTarget,\n    outputPathinfo,\n    outputPublicPath,\n    outputSourceMapFilename,\n    quiet = false,\n    watch\n  } = cmd;\n\n  // Get custom webpack configuration\n  let webpackConfig: string;\n\n  if(config) {\n    const isRelativeConfig: boolean = config.substr(0, 2) === './';\n    const fullConfigPath: string = isRelativeConfig ? path.resolve(process.cwd(), config) : config;\n    webpackConfig = fullConfigPath;\n  } else {\n    webpackConfig = path.resolve(__dirname, '../../webpack.config.js');\n  }\n\n  const webpackOptions: string[] = [\n    '--color',\n    '--progress',\n    '--stats-error-details',\n    '--config', webpackConfig\n  ];\n\n  if(mode) {\n    webpackOptions.push('--mode', mode);\n  }\n\n  if(outputChunkFilename) {\n    webpackOptions.push('--output-chunk-filename', outputChunkFilename);\n  }\n\n  if(outputFilename) {\n    webpackOptions.push('--output-filename', outputFilename);\n  }\n\n  if(outputJsonpFunction) {\n    webpackOptions.push('--output-jsonp-function', outputJsonpFunction);\n  }\n\n  if(outputLibrary) {\n    webpackOptions.push('--output-library', outputLibrary);\n  }\n\n  if(outputLibraryTarget) {\n    webpackOptions.push('--output-library-target', outputLibraryTarget);\n  }\n\n  if(outputPathinfo) {\n    webpackOptions.push('--output-path-info', outputPathinfo);\n  }\n\n  if(outputPublicPath) {\n    webpackOptions.push('--output-public-path', outputPublicPath);\n  }\n\n  if(outputSourceMapFilename) {\n    webpackOptions.push('--output-source-map-filename', outputSourceMapFilename);\n  }\n\n  if(buildDelimiter) {\n    webpackOptions.push('--build-delimiter', buildDelimiter);\n  }\n\n  if(watch) {\n    webpackOptions.push('--watch');\n  }\n\n  // Compile using webpack\n  try {\n    const nodePath: string = path.resolve(__dirname, '../../node_modules');\n    const webpackPath: string = relativeFilePath('webpack-cli/bin/cli.js', nodePath);\n    await execa(webpackPath, webpackOptions, {encoding: 'utf-8', stdio: 'inherit'});\n\n    // Stop spinner\n    spinner.succeed('Build completed successfully!');\n\n    // Stop process\n    callback(0);\n    return 0;\n  } catch(error) {\n    // Display error message\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n    // Stop spinner\n    spinner.fail('Build failed.');\n\n    // Kill process\n    callback(error.status);\n    return error.status;\n  }\n};\n\nexport const build = async (cmd: any, callback: any = () => ({})): Promise<number> => {\n  const {\n    bundler = 'webpack',\n    cliName = 'Lex',\n    quiet = false,\n    remove,\n    variables\n  } = cmd;\n\n  // Spinner\n  const spinner = createSpinner(quiet);\n\n  // Display status\n  log(`${cliName} building...`, 'info', quiet);\n\n  // Get custom configuration\n  LexConfig.parseConfig(cmd);\n\n  const {outputFullPath, useTypescript} = LexConfig.config;\n\n  // Check for linked modules\n  checkLinkedModules();\n\n  // Set node environment variables\n  let variablesObj: object = {NODE_ENV: 'production'};\n\n  if(variables) {\n    try {\n      variablesObj = JSON.parse(variables);\n    } catch(error) {\n      log(`\\n${cliName} Error: Environment variables option is not a valid JSON object.`, 'error', quiet);\n\n      // Kill process\n      callback(1);\n      return 1;\n    }\n  }\n\n  process.env = {...process.env, ...variablesObj};\n\n  // Start build spinner\n  spinner.start('Building code...');\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\n  if(bundler === 'esbuild') {\n    return buildWithEsBuild(spinner, cmd, callback);\n  }\n\n  return buildWithWebpack(spinner, cmd, callback);\n};\n\n"],
  "mappings": "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",
  "names": ["graphqlLoaderPlugin", "esBuild", "execa"]
}

184
+ };
185
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/commands/build.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 graphqlLoaderPlugin from '@luckycatfactory/esbuild-graphql-loader';\nimport {build as esBuild} from 'esbuild';\nimport {execa} from 'execa';\nimport {resolve as pathResolve} from 'path';\nimport {fileURLToPath} from 'url';\n\nimport {LexConfig} from '../LexConfig.js';\nimport {checkLinkedModules, createSpinner, removeFiles} from '../utils/app.js';\nimport {relativeNodePath} from '../utils/file.js';\nimport {log} from '../utils/log.js';\n\nexport const buildWithEsBuild = async (spinner, cmd, callback) => {\n  const {\n    cliName = 'Lex',\n    outputPath,\n    quiet,\n    sourcePath,\n    watch\n  } = cmd;\n  const {\n    targetEnvironment,\n    useGraphQl,\n    useTypescript\n  } = LexConfig.config;\n\n  const loader: any = {\n    '.js': 'js'\n  };\n\n  if(useTypescript) {\n    loader['.ts'] = 'ts';\n    loader['.tsx'] = 'tsx';\n  }\n\n  // Plugins\n  const plugins = [];\n\n  if(useGraphQl) {\n    plugins.push(graphqlLoaderPlugin());\n  }\n\n  try {\n    await esBuild({\n      bundle: true,\n      color: true,\n      entryPoints: [sourcePath],\n      loader,\n      outdir: outputPath,\n      platform: 'node',\n      plugins,\n      sourcemap: 'inline',\n      target: targetEnvironment === 'node' ? 'node18' : 'es2016',\n      watch\n    });\n\n    // Stop spinner\n    spinner.succeed('Build 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 build 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\nexport const buildWithWebpack = async (spinner, cmd, callback) => {\n  const {\n    buildDelimiter,\n    cliName = 'Lex',\n    config,\n    mode,\n    outputChunkFilename,\n    outputFilename,\n    outputJsonpFunction,\n    outputLibrary,\n    outputLibraryTarget,\n    outputPathInfo,\n    outputPublicPath,\n    outputSourceMapFilename,\n    quiet = false,\n    watch\n  } = cmd;\n\n  // Get custom webpack configuration\n  let webpackConfig: string;\n\n  if(config) {\n    const isRelativeConfig: boolean = config.substr(0, 2) === './';\n    const fullConfigPath: string = isRelativeConfig ? pathResolve(process.cwd(), config) : config;\n    webpackConfig = fullConfigPath;\n  } else {\n    const dirName = fileURLToPath(new URL('.', import.meta.url));\n    webpackConfig = pathResolve(dirName, '../../webpack.config.js');\n  }\n\n  const webpackOptions: string[] = [\n    '--color',\n    '--progress',\n    '--stats-error-details',\n    '--config', webpackConfig\n  ];\n\n  if(mode) {\n    webpackOptions.push('--mode', mode);\n  }\n\n  if(outputChunkFilename) {\n    webpackOptions.push('--output-chunk-filename', outputChunkFilename);\n  }\n\n  if(outputFilename) {\n    webpackOptions.push('--output-filename', outputFilename);\n  }\n\n  if(outputJsonpFunction) {\n    webpackOptions.push('--output-jsonp-function', outputJsonpFunction);\n  }\n\n  if(outputLibrary) {\n    webpackOptions.push('--output-library', outputLibrary);\n  }\n\n  if(outputLibraryTarget) {\n    webpackOptions.push('--output-library-target', outputLibraryTarget);\n  }\n\n  if(outputPathInfo) {\n    webpackOptions.push('--output-path-info', outputPathInfo);\n  }\n\n  if(outputPublicPath) {\n    webpackOptions.push('--output-public-path', outputPublicPath);\n  }\n\n  if(outputSourceMapFilename) {\n    webpackOptions.push('--output-source-map-filename', outputSourceMapFilename);\n  }\n\n  if(buildDelimiter) {\n    webpackOptions.push('--build-delimiter', buildDelimiter);\n  }\n\n  if(watch) {\n    webpackOptions.push('--watch');\n  }\n\n  // Compile using webpack\n  try {\n    const dirName = fileURLToPath(new URL('.', import.meta.url));\n    const nodePath: string = pathResolve(dirName, '../../node_modules');\n    const webpackPath: string = relativeNodePath('webpack-cli/bin/cli.js', nodePath);\n    await execa(webpackPath, webpackOptions, {encoding: 'utf-8', stdio: 'inherit'});\n\n    // Stop spinner\n    spinner.succeed('Build completed successfully!');\n\n    // Stop process\n    callback(0);\n    return 0;\n  } catch(error) {\n    // Display error message\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n    // Stop spinner\n    spinner.fail('Build failed.');\n\n    // Kill process\n    callback(error.status);\n    return error.status;\n  }\n};\n\nexport const build = async (cmd: any, callback: any = () => ({})): Promise<number> => {\n  const {\n    bundler = 'webpack',\n    cliName = 'Lex',\n    quiet = false,\n    remove,\n    variables\n  } = cmd;\n\n  // Spinner\n  const spinner = createSpinner(quiet);\n\n  // Display status\n  log(`${cliName} building...`, 'info', quiet);\n\n  // Get custom configuration\n  LexConfig.parseConfig(cmd);\n\n  const {outputFullPath, useTypescript} = LexConfig.config;\n\n  // Check for linked modules\n  checkLinkedModules();\n\n  // Set node environment variables\n  let variablesObj: object = {NODE_ENV: 'production'};\n\n  if(variables) {\n    try {\n      variablesObj = JSON.parse(variables);\n    } catch(error) {\n      log(`\\n${cliName} Error: Environment variables option is not a valid JSON object.`, 'error', quiet);\n\n      // Kill process\n      callback(1);\n      return 1;\n    }\n  }\n\n  process.env = {...process.env, ...variablesObj};\n\n  // Start build spinner\n  spinner.start('Building code...');\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\n  if(bundler === 'esbuild') {\n    return buildWithEsBuild(spinner, cmd, callback);\n  }\n\n  return buildWithWebpack(spinner, cmd, callback);\n};\n\n"],
  "mappings": "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",
  "names": []
}

@@ -1,8 +1,8 @@
1
- var import_build = require("./build");
1
+ import { build } from "./build.js";
2
2
  describe("build", () => {
3
3
  it("should", async () => {
4
- const status = await (0, import_build.build)({ cliName: "Test" }, Promise.resolve);
4
+ const status = await build({ cliName: "Test" }, Promise.resolve);
5
5
  expect(status).toBe(1);
6
6
  });
7
7
  });
8
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2J1bGlkLnRlc3QudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImltcG9ydCB7YnVpbGR9IGZyb20gJy4vYnVpbGQnO1xuXG5kZXNjcmliZSgnYnVpbGQnLCAoKSA9PiB7XG4gIGl0KCdzaG91bGQnLCBhc3luYyAoKSA9PiB7XG4gICAgY29uc3Qgc3RhdHVzOiBudW1iZXIgPSBhd2FpdCBidWlsZCh7Y2xpTmFtZTogJ1Rlc3QnfSwgUHJvbWlzZS5yZXNvbHZlKTtcbiAgICBleHBlY3Qoc3RhdHVzKS50b0JlKDEpO1xuICB9KTtcbn0pO1xuIl0sCiAgIm1hcHBpbmdzIjogIkFBQUEsbUJBQW9CO0FBRXBCLFNBQVMsU0FBUyxNQUFNO0FBQ3RCLEtBQUcsVUFBVSxZQUFZO0FBQ3ZCLFVBQU0sU0FBaUIsVUFBTSxvQkFBTSxFQUFDLFNBQVMsT0FBTSxHQUFHLFFBQVEsT0FBTztBQUNyRSxXQUFPLE1BQU0sRUFBRSxLQUFLLENBQUM7QUFBQSxFQUN2QixDQUFDO0FBQ0gsQ0FBQzsiLAogICJuYW1lcyI6IFtdCn0K
8
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2J1bGlkLnRlc3QudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImltcG9ydCB7YnVpbGR9IGZyb20gJy4vYnVpbGQuanMnO1xuXG5kZXNjcmliZSgnYnVpbGQnLCAoKSA9PiB7XG4gIGl0KCdzaG91bGQnLCBhc3luYyAoKSA9PiB7XG4gICAgY29uc3Qgc3RhdHVzOiBudW1iZXIgPSBhd2FpdCBidWlsZCh7Y2xpTmFtZTogJ1Rlc3QnfSwgUHJvbWlzZS5yZXNvbHZlKTtcbiAgICBleHBlY3Qoc3RhdHVzKS50b0JlKDEpO1xuICB9KTtcbn0pO1xuIl0sCiAgIm1hcHBpbmdzIjogIkFBQUEsU0FBUSxhQUFZO0FBRXBCLFNBQVMsU0FBUyxNQUFNO0FBQ3RCLEtBQUcsVUFBVSxZQUFZO0FBQ3ZCLFVBQU0sU0FBaUIsTUFBTSxNQUFNLEVBQUMsU0FBUyxPQUFNLEdBQUcsUUFBUSxPQUFPO0FBQ3JFLFdBQU8sTUFBTSxFQUFFLEtBQUssQ0FBQztBQUFBLEVBQ3ZCLENBQUM7QUFDSCxDQUFDOyIsCiAgIm5hbWVzIjogW10KfQo=