@nlabs/lex 1.37.7 → 1.39.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/.eslintrc 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,32 +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(isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod));
20
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
21
- var LexConfig_exports = {};
22
- __export(LexConfig_exports, {
23
- LexConfig: () => LexConfig
24
- });
25
- module.exports = __toCommonJS(LexConfig_exports);
26
- var fs = __toESM(require("fs-extra"));
27
- var path = __toESM(require("path"));
28
- var import_file = require("./utils/file");
29
- var import_log = require("./utils/log");
1
+ import { existsSync, readFileSync, writeFileSync } from "fs";
2
+ import * as path from "path";
3
+ import { fileURLToPath } from "url";
4
+ import { relativeFilePath } from "./utils/file.js";
5
+ import { log } from "./utils/log.js";
30
6
  const cwd = process.cwd();
31
7
  class LexConfig {
32
8
  static config = {
@@ -54,7 +30,7 @@ class LexConfig {
54
30
  const { entryJs } = LexConfig.config;
55
31
  if (entryJs === "index.js" && value) {
56
32
  const indexPath = path.resolve(cwd, sourceFullPath, "index.tsx");
57
- const hasIndexTsx = fs.existsSync(indexPath);
33
+ const hasIndexTsx = existsSync(indexPath);
58
34
  if (hasIndexTsx) {
59
35
  LexConfig.config.entryJs = "index.tsx";
60
36
  } else {
@@ -62,6 +38,7 @@ class LexConfig {
62
38
  }
63
39
  }
64
40
  }
41
+ // Set options from a custom configuration file
65
42
  static updateConfig(updatedConfig) {
66
43
  const { outputFullPath, outputPath, sourcePath, sourceFullPath, useTypescript } = updatedConfig;
67
44
  const cwd2 = process.cwd();
@@ -77,6 +54,7 @@ class LexConfig {
77
54
  LexConfig.config = { ...LexConfig.config, ...updatedConfig };
78
55
  return LexConfig.config;
79
56
  }
57
+ // Set option updates from the command line
80
58
  static addConfigParams(cmd, params) {
81
59
  const nameProperty = "_name";
82
60
  const { environment, outputPath, sourcePath, typescript } = cmd;
@@ -94,23 +72,28 @@ class LexConfig {
94
72
  if (environment !== void 0) {
95
73
  params.targetEnvironment = environment === "web" ? "web" : "node";
96
74
  }
97
- process.env.LEX_CONFIG = JSON.stringify({
98
- ...LexConfig.updateConfig(params),
99
- commandName: cmd[nameProperty],
100
- isStatic: cmd.static
101
- }, null, 0);
75
+ process.env.LEX_CONFIG = JSON.stringify(
76
+ {
77
+ ...LexConfig.updateConfig(params),
78
+ commandName: cmd[nameProperty],
79
+ isStatic: cmd.static
80
+ },
81
+ null,
82
+ 0
83
+ );
102
84
  }
85
+ // Get configuration
103
86
  static parseConfig(cmd, isRoot = true) {
104
87
  const { cliName = "Lex", lexConfig, lexConfigName, quiet, typescript } = cmd;
105
88
  const configName = lexConfigName || "lex.config.js";
106
- const defaultConfigPath = isRoot ? path.resolve(cwd, `./${configName}`) : (0, import_file.relativeFilePath)(configName, cwd);
89
+ const defaultConfigPath = isRoot ? path.resolve(cwd, `./${configName}`) : relativeFilePath(configName, cwd);
107
90
  const configPath = lexConfig || defaultConfigPath;
108
- const configExists = fs.existsSync(configPath);
91
+ const configExists = existsSync(configPath);
109
92
  if (configExists) {
110
- (0, import_log.log)(`Using ${cliName} configuration file: ${configPath}`, "note", quiet);
93
+ log(`Using ${cliName} configuration file: ${configPath}`, "note", quiet);
111
94
  const ext = path.extname(configPath);
112
95
  if (ext === ".json") {
113
- const configContent = fs.readFileSync(configPath, "utf8");
96
+ const configContent = readFileSync(configPath, "utf8");
114
97
  if (configContent) {
115
98
  let configJson;
116
99
  try {
@@ -120,14 +103,14 @@ class LexConfig {
120
103
  }
121
104
  LexConfig.addConfigParams(cmd, configJson);
122
105
  } else {
123
- (0, import_log.log)(`
106
+ log(`
124
107
  ${cliName} Error: Config file malformed, ${configPath}`, "error", quiet);
125
108
  }
126
109
  } else if (ext === ".js") {
127
- const lexCustomConfig = require(configPath);
110
+ const lexCustomConfig = readFileSync(configPath).toJSON();
128
111
  LexConfig.addConfigParams(cmd, lexCustomConfig);
129
112
  } else {
130
- (0, import_log.log)(`
113
+ log(`
131
114
  ${cliName} Error: Config file must be a JS or JSON file.`, "error", quiet);
132
115
  }
133
116
  } else {
@@ -137,13 +120,13 @@ ${cliName} Error: Config file must be a JS or JSON file.`, "error", quiet);
137
120
  }
138
121
  static checkTypescriptConfig() {
139
122
  const tsconfigPath = path.resolve(cwd, "./tsconfig.json");
140
- if (!fs.existsSync(tsconfigPath)) {
141
- fs.writeFileSync(tsconfigPath, fs.readFileSync(path.resolve(__dirname, "../../../tsconfig.base.json")));
123
+ if (!existsSync(tsconfigPath)) {
124
+ const dirName = fileURLToPath(new URL(".", import.meta.url));
125
+ writeFileSync(tsconfigPath, readFileSync(path.resolve(dirName, "../../../tsconfig.base.json")));
142
126
  }
143
127
  }
144
128
  }
145
- // Annotate the CommonJS export names for ESM import in node:
146
- 0 && (module.exports = {
129
+ export {
147
130
  LexConfig
148
- });
149
- //# 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": ";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAIA,SAAoB;AACpB,WAAsB;AAEtB,kBAA+B;AAC/B,iBAAkB;AAElB,MAAM,MAAc,QAAQ,IAAI;AA0BzB,MAAM,UAAU;AAAA,EACrB,OAAO,SAAwB;AAAA,IAC7B,aAAa,CAAC;AAAA,IACd,WAAW;AAAA,IACX,SAAS;AAAA,IACT,SAAS,CAAC;AAAA,IACV,KAAK;AAAA,IACL,MAAM,CAAC;AAAA,IACP,gBAAgB,KAAK,QAAQ,KAAK,QAAQ;AAAA,IAC1C,YAAY;AAAA,IACZ,YAAY;AAAA,IACZ,gBAAgB;AAAA,IAChB,QAAQ;AAAA,IACR,gBAAgB,KAAK,QAAQ,KAAK,OAAO;AAAA,IACzC,YAAY;AAAA,IACZ,mBAAmB;AAAA,IACnB,YAAY;AAAA,IACZ,eAAe;AAAA,IACf,SAAS,CAAC;AAAA,EACZ;AAAA,EAEA,WAAW,cAAc,OAAgB;AACvC,cAAU,OAAO,gBAAgB;AACjC,UAAM,EAAC,mBAAkB,UAAU;AAGnC,UAAM,EAAC,YAAW,UAAU;AAE5B,QAAG,YAAY,cAAc,OAAO;AAClC,YAAM,YAAoB,KAAK,QAAQ,KAAK,gBAAgB,WAAW;AACvE,YAAM,cAAuB,GAAG,WAAW,SAAS;AAEpD,UAAG,aAAa;AACd,kBAAU,OAAO,UAAU;AAAA,MAC7B,OAAO;AACL,kBAAU,OAAO,UAAU;AAAA,MAC7B;AAAA,IACF;AAAA,EACF;AAAA,EAGA,OAAO,aAAa,eAA6C;AAC/D,UAAM,EAAC,gBAAgB,YAAY,YAAY,gBAAgB,kBAAiB;AAChF,UAAM,OAAc,QAAQ,IAAI;AAGhC,QAAG,kBAAkB,QAAW;AAC9B,gBAAU,gBAAgB;AAAA,IAC5B;AAGA,QAAG,eAAe,UAAa,mBAAmB,QAAW;AAC3D,oBAAc,iBAAiB,KAAK,QAAQ,MAAK,UAAU;AAAA,IAC7D;AAGA,QAAG,eAAe,UAAa,mBAAmB,QAAW;AAC3D,oBAAc,iBAAiB,KAAK,QAAQ,MAAK,UAAU;AAAA,IAC7D;AAEA,cAAU,SAAS,EAAC,GAAG,UAAU,QAAQ,GAAG,cAAa;AACzD,WAAO,UAAU;AAAA,EACnB;AAAA,EAGA,OAAO,gBAAgB,KAAK,QAAuB;AACjD,UAAM,eAAuB;AAC7B,UAAM,EAAC,aAAa,YAAY,YAAY,eAAc;AAG1D,QAAG,eAAe,QAAW;AAC3B,aAAO,aAAa;AACpB,aAAO,iBAAiB,KAAK,QAAQ,KAAK,UAAU;AAAA,IACtD;AAGA,QAAG,eAAe,QAAW;AAC3B,aAAO,aAAa;AACpB,aAAO,iBAAiB,KAAK,QAAQ,KAAK,UAAU;AAAA,IACtD;AAGA,QAAG,eAAe,QAAW;AAC3B,aAAO,gBAAgB;AAAA,IACzB;AAGA,QAAG,gBAAgB,QAAW;AAC5B,aAAO,oBAAoB,gBAAgB,QAAQ,QAAQ;AAAA,IAC7D;AAEA,YAAQ,IAAI,aAAa,KAAK,UAC5B;AAAA,MACE,GAAG,UAAU,aAAa,MAAM;AAAA,MAChC,aAAa,IAAI;AAAA,MACjB,UAAU,IAAI;AAAA,IAChB,GAAG,MAAM,CACX;AAAA,EACF;AAAA,EAGA,OAAO,YAAY,KAAK,SAAkB,MAAY;AACpD,UAAM,EAAC,UAAU,OAAO,WAAW,eAAe,OAAO,eAAc;AACvE,UAAM,aAAqB,iBAAiB;AAC5C,UAAM,oBAA4B,SAC9B,KAAK,QAAQ,KAAK,KAAK,YAAY,IACnC,kCAAiB,YAAY,GAAG;AACpC,UAAM,aAAqB,aAAa;AACxC,UAAM,eAAwB,GAAG,WAAW,UAAU;AAGtD,QAAG,cAAc;AACf,0BAAI,SAAS,+BAA+B,cAAc,QAAQ,KAAK;AACvE,YAAM,MAAc,KAAK,QAAQ,UAAU;AAE3C,UAAG,QAAQ,SAAS;AAClB,cAAM,gBAAwB,GAAG,aAAa,YAAY,MAAM;AAEhE,YAAG,eAAe;AAChB,cAAI;AAEJ,cAAI;AACF,yBAAa,KAAK,MAAM,aAAa;AAAA,UACvC,SAAQ,OAAN;AACA,yBAAa,CAAC;AAAA,UAChB;AAEA,oBAAU,gBAAgB,KAAK,UAAU;AAAA,QAC3C,OAAO;AACL,8BAAI;AAAA,EAAK,yCAAyC,cAAc,SAAS,KAAK;AAAA,QAChF;AAAA,MACF,WAAU,QAAQ,OAAO;AACvB,cAAM,kBAAkB,QAAQ,UAAU;AAC1C,kBAAU,gBAAgB,KAAK,eAAe;AAAA,MAChD,OAAO;AACL,4BAAI;AAAA,EAAK,yDAAyD,SAAS,KAAK;AAAA,MAClF;AAAA,IACF,OAAO;AAEL,gBAAU,gBAAgB,CAAC,CAAC;AAG5B,gBAAU,gBAAgB,KAAK,UAAU,MAAM;AAAA,IACjD;AAAA,EACF;AAAA,EAEA,OAAO,wBAAwB;AAE7B,UAAM,eAAuB,KAAK,QAAQ,KAAK,iBAAiB;AAEhE,QAAG,CAAC,GAAG,WAAW,YAAY,GAAG;AAC/B,SAAG,cAAc,cAAc,GAAG,aAAa,KAAK,QAAQ,WAAW,6BAA6B,CAAC,CAAC;AAAA,IACxG;AAAA,EACF;AACF;",
  "names": []
}

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 * as path 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: 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 = 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 = 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 = 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 = path.resolve(cwd, './tsconfig.json');\n\n    if(!existsSync(tsconfigPath)) {\n      const dirName = fileURLToPath(new URL('.', import.meta.url));\n      writeFileSync(tsconfigPath, readFileSync(path.resolve(dirName, '../../../tsconfig.base.json')));\n    }\n  }\n}\n"],
  "mappings": "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",
  "names": ["cwd"]
}

@@ -1,38 +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(isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod));
20
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
21
- var build_exports = {};
22
- __export(build_exports, {
23
- build: () => build,
24
- buildWithEsBuild: () => buildWithEsBuild,
25
- buildWithWebpack: () => buildWithWebpack
26
- });
27
- module.exports = __toCommonJS(build_exports);
28
- var import_esbuild_graphql_loader = __toESM(require("@luckycatfactory/esbuild-graphql-loader"));
29
- var import_esbuild = require("esbuild");
30
- var import_execa = __toESM(require("execa"));
31
- var path = __toESM(require("path"));
32
- var import_LexConfig = require("../LexConfig");
33
- var import_app = require("../utils/app");
34
- var import_log = require("../utils/log");
35
- 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 * as path from "path";
5
+ import { fileURLToPath } from "url";
6
+ import { LexConfig } from "../LexConfig.js";
7
+ import { checkLinkedModules, createSpinner, removeFiles } from "../utils/app.js";
8
+ import { relativeFilePath } from "../utils/file.js";
9
+ import { log } from "../utils/log.js";
36
10
  const buildWithEsBuild = async (spinner, cmd, callback) => {
37
11
  const {
38
12
  cliName = "Lex",
@@ -45,7 +19,7 @@ const buildWithEsBuild = async (spinner, cmd, callback) => {
45
19
  targetEnvironment,
46
20
  useGraphQl,
47
21
  useTypescript
48
- } = import_LexConfig.LexConfig.config;
22
+ } = LexConfig.config;
49
23
  const loader = {
50
24
  ".js": "js"
51
25
  };
@@ -55,10 +29,10 @@ const buildWithEsBuild = async (spinner, cmd, callback) => {
55
29
  }
56
30
  const plugins = [];
57
31
  if (useGraphQl) {
58
- plugins.push((0, import_esbuild_graphql_loader.default)());
32
+ plugins.push(graphqlLoaderPlugin());
59
33
  }
60
34
  try {
61
- await (0, import_esbuild.build)({
35
+ await esBuild({
62
36
  bundle: true,
63
37
  color: true,
64
38
  entryPoints: [sourcePath],
@@ -67,12 +41,12 @@ const buildWithEsBuild = async (spinner, cmd, callback) => {
67
41
  platform: "node",
68
42
  plugins,
69
43
  sourcemap: "inline",
70
- target: targetEnvironment === "node" ? "node14" : "es2016",
44
+ target: targetEnvironment === "node" ? "node18" : "es2016",
71
45
  watch
72
46
  });
73
47
  spinner.succeed("Build completed successfully!");
74
48
  } catch (error) {
75
- (0, import_log.log)(`
49
+ log(`
76
50
  ${cliName} Error: ${error.message}`, "error", quiet);
77
51
  if (!quiet) {
78
52
  console.error(error);
@@ -95,7 +69,7 @@ const buildWithWebpack = async (spinner, cmd, callback) => {
95
69
  outputJsonpFunction,
96
70
  outputLibrary,
97
71
  outputLibraryTarget,
98
- outputPathinfo,
72
+ outputPathInfo,
99
73
  outputPublicPath,
100
74
  outputSourceMapFilename,
101
75
  quiet = false,
@@ -107,7 +81,8 @@ const buildWithWebpack = async (spinner, cmd, callback) => {
107
81
  const fullConfigPath = isRelativeConfig ? path.resolve(process.cwd(), config) : config;
108
82
  webpackConfig = fullConfigPath;
109
83
  } else {
110
- webpackConfig = path.resolve(__dirname, "../../webpack.config.js");
84
+ const dirName = fileURLToPath(new URL(".", import.meta.url));
85
+ webpackConfig = path.resolve(dirName, "../../webpack.config.js");
111
86
  }
112
87
  const webpackOptions = [
113
88
  "--color",
@@ -134,8 +109,8 @@ const buildWithWebpack = async (spinner, cmd, callback) => {
134
109
  if (outputLibraryTarget) {
135
110
  webpackOptions.push("--output-library-target", outputLibraryTarget);
136
111
  }
137
- if (outputPathinfo) {
138
- webpackOptions.push("--output-path-info", outputPathinfo);
112
+ if (outputPathInfo) {
113
+ webpackOptions.push("--output-path-info", outputPathInfo);
139
114
  }
140
115
  if (outputPublicPath) {
141
116
  webpackOptions.push("--output-public-path", outputPublicPath);
@@ -150,14 +125,15 @@ const buildWithWebpack = async (spinner, cmd, callback) => {
150
125
  webpackOptions.push("--watch");
151
126
  }
152
127
  try {
153
- const nodePath = path.resolve(__dirname, "../../node_modules");
154
- const webpackPath = (0, import_file.relativeFilePath)("webpack-cli/bin/cli.js", nodePath);
155
- await (0, import_execa.default)(webpackPath, webpackOptions, { encoding: "utf-8", stdio: "inherit" });
128
+ const dirName = fileURLToPath(new URL(".", import.meta.url));
129
+ const nodePath = path.resolve(dirName, "../../node_modules");
130
+ const webpackPath = relativeFilePath("webpack-cli/bin/cli.js", nodePath);
131
+ await execa(webpackPath, webpackOptions, { encoding: "utf-8", stdio: "inherit" });
156
132
  spinner.succeed("Build completed successfully!");
157
133
  callback(0);
158
134
  return 0;
159
135
  } catch (error) {
160
- (0, import_log.log)(`
136
+ log(`
161
137
  ${cliName} Error: ${error.message}`, "error", quiet);
162
138
  spinner.fail("Build failed.");
163
139
  callback(error.status);
@@ -172,17 +148,17 @@ const build = async (cmd, callback = () => ({})) => {
172
148
  remove,
173
149
  variables
174
150
  } = cmd;
175
- const spinner = (0, import_app.createSpinner)(quiet);
176
- (0, import_log.log)(`${cliName} building...`, "info", quiet);
177
- import_LexConfig.LexConfig.parseConfig(cmd);
178
- const { outputFullPath, useTypescript } = import_LexConfig.LexConfig.config;
179
- (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();
180
156
  let variablesObj = { NODE_ENV: "production" };
181
157
  if (variables) {
182
158
  try {
183
159
  variablesObj = JSON.parse(variables);
184
160
  } catch (error) {
185
- (0, import_log.log)(`
161
+ log(`
186
162
  ${cliName} Error: Environment variables option is not a valid JSON object.`, "error", quiet);
187
163
  callback(1);
188
164
  return 1;
@@ -191,20 +167,19 @@ ${cliName} Error: Environment variables option is not a valid JSON object.`, "er
191
167
  process.env = { ...process.env, ...variablesObj };
192
168
  spinner.start("Building code...");
193
169
  if (remove) {
194
- await (0, import_app.removeFiles)(outputFullPath);
170
+ await removeFiles(outputFullPath);
195
171
  }
196
172
  if (useTypescript) {
197
- import_LexConfig.LexConfig.checkTypescriptConfig();
173
+ LexConfig.checkTypescriptConfig();
198
174
  }
199
175
  if (bundler === "esbuild") {
200
176
  return buildWithEsBuild(spinner, cmd, callback);
201
177
  }
202
178
  return buildWithWebpack(spinner, cmd, callback);
203
179
  };
204
- // Annotate the CommonJS export names for ESM import in node:
205
- 0 && (module.exports = {
180
+ export {
206
181
  build,
207
182
  buildWithEsBuild,
208
183
  buildWithWebpack
209
- });
210
- //# 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' ? 'node14' : '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": []
}

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 * as path from 'path';\nimport {fileURLToPath} from 'url';\n\nimport {LexConfig} from '../LexConfig.js';\nimport {checkLinkedModules, createSpinner, removeFiles} from '../utils/app.js';\nimport {relativeFilePath} 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 ? path.resolve(process.cwd(), config) : config;\n    webpackConfig = fullConfigPath;\n  } else {\n    const dirName = fileURLToPath(new URL('.', import.meta.url));\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 dirName = fileURLToPath(new URL('.', import.meta.url));\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": []
}

@@ -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,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2J1bGlkLnRlc3QudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImltcG9ydCB7YnVpbGR9IGZyb20gJy4vYnVpbGQnO1xuXG5kZXNjcmliZSgnYnVpbGQnLCAoKSA9PiB7XG4gIGl0KCdzaG91bGQnLCBhc3luYyAoKSA9PiB7XG4gICAgY29uc3Qgc3RhdHVzOiBudW1iZXIgPSBhd2FpdCBidWlsZCh7Y2xpTmFtZTogJ1Rlc3QnfSwgUHJvbWlzZS5yZXNvbHZlKTtcbiAgICBleHBlY3Qoc3RhdHVzKS50b0JlKDEpO1xuICB9KTtcbn0pO1xuIl0sCiAgIm1hcHBpbmdzIjogIkFBQUEsbUJBQW9CO0FBRXBCLFNBQVMsU0FBUyxNQUFNO0FBQ3RCLEtBQUcsVUFBVSxZQUFZO0FBQ3ZCLFVBQU0sU0FBaUIsTUFBTSx3QkFBTSxFQUFDLFNBQVMsT0FBTSxHQUFHLFFBQVEsT0FBTztBQUNyRSxXQUFPLE1BQU0sRUFBRSxLQUFLLENBQUM7QUFBQSxFQUN2QixDQUFDO0FBQ0gsQ0FBQzsiLAogICJuYW1lcyI6IFtdCn0K
8
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2J1bGlkLnRlc3QudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImltcG9ydCB7YnVpbGR9IGZyb20gJy4vYnVpbGQuanMnO1xuXG5kZXNjcmliZSgnYnVpbGQnLCAoKSA9PiB7XG4gIGl0KCdzaG91bGQnLCBhc3luYyAoKSA9PiB7XG4gICAgY29uc3Qgc3RhdHVzOiBudW1iZXIgPSBhd2FpdCBidWlsZCh7Y2xpTmFtZTogJ1Rlc3QnfSwgUHJvbWlzZS5yZXNvbHZlKTtcbiAgICBleHBlY3Qoc3RhdHVzKS50b0JlKDEpO1xuICB9KTtcbn0pO1xuIl0sCiAgIm1hcHBpbmdzIjogIkFBQUEsU0FBUSxhQUFZO0FBRXBCLFNBQVMsU0FBUyxNQUFNO0FBQ3RCLEtBQUcsVUFBVSxZQUFZO0FBQ3ZCLFVBQU0sU0FBaUIsTUFBTSxNQUFNLEVBQUMsU0FBUyxPQUFNLEdBQUcsUUFBUSxPQUFPO0FBQ3JFLFdBQU8sTUFBTSxFQUFFLEtBQUssQ0FBQztBQUFBLEVBQ3ZCLENBQUM7QUFDSCxDQUFDOyIsCiAgIm5hbWVzIjogW10KfQo=
@@ -1,54 +1,31 @@
1
- var __defProp = Object.defineProperty;
2
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
- var __getOwnPropNames = Object.getOwnPropertyNames;
4
- var __hasOwnProp = Object.prototype.hasOwnProperty;
5
- var __export = (target, all) => {
6
- for (var name in all)
7
- __defProp(target, name, { get: all[name], enumerable: true });
8
- };
9
- var __copyProps = (to, from, except, desc) => {
10
- if (from && typeof from === "object" || typeof from === "function") {
11
- for (let key of __getOwnPropNames(from))
12
- if (!__hasOwnProp.call(to, key) && key !== except)
13
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
14
- }
15
- return to;
16
- };
17
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
- var clean_exports = {};
19
- __export(clean_exports, {
20
- clean: () => clean
21
- });
22
- module.exports = __toCommonJS(clean_exports);
23
- var import_LexConfig = require("../LexConfig");
24
- var import_app = require("../utils/app");
25
- var import_log = require("../utils/log");
1
+ import { LexConfig } from "../LexConfig.js";
2
+ import { createSpinner, removeFiles, removeModules } from "../utils/app.js";
3
+ import { log } from "../utils/log.js";
26
4
  const clean = async (cmd, callback = () => ({})) => {
27
5
  const { cliName = "Lex", quiet, snapshots } = cmd;
28
- const spinner = (0, import_app.createSpinner)(quiet);
29
- (0, import_log.log)(`${cliName} cleaning directory...`, "info", quiet);
30
- import_LexConfig.LexConfig.parseConfig(cmd);
6
+ const spinner = createSpinner(quiet);
7
+ log(`${cliName} cleaning directory...`, "info", quiet);
8
+ LexConfig.parseConfig(cmd);
31
9
  spinner.start("Cleaning files...");
32
10
  try {
33
- await (0, import_app.removeModules)();
34
- await (0, import_app.removeFiles)("./coverage", true);
35
- await (0, import_app.removeFiles)("./npm-debug.log", true);
11
+ await removeModules();
12
+ await removeFiles("./coverage", true);
13
+ await removeFiles("./npm-debug.log", true);
36
14
  if (snapshots) {
37
- await (0, import_app.removeFiles)("./**/__snapshots__", true);
15
+ await removeFiles("./**/__snapshots__", true);
38
16
  }
39
17
  spinner.succeed("Successfully cleaned!");
40
18
  callback(0);
41
19
  return 0;
42
20
  } catch (error) {
43
- (0, import_log.log)(`
21
+ log(`
44
22
  ${cliName} Error: ${error.message}`, "error", quiet);
45
23
  spinner.fail("Failed to clean project.");
46
24
  callback(error.status);
47
25
  return error.status;
48
26
  }
49
27
  };
50
- // Annotate the CommonJS export names for ESM import in node:
51
- 0 && (module.exports = {
28
+ export {
52
29
  clean
53
- });
54
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2NsZWFuLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtMZXhDb25maWd9IGZyb20gJy4uL0xleENvbmZpZyc7XG5pbXBvcnQge2NyZWF0ZVNwaW5uZXIsIHJlbW92ZUZpbGVzLCByZW1vdmVNb2R1bGVzfSBmcm9tICcuLi91dGlscy9hcHAnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uL3V0aWxzL2xvZyc7XG5cbmV4cG9ydCBjb25zdCBjbGVhbiA9IGFzeW5jIChjbWQ6IGFueSwgY2FsbGJhY2s6IGFueSA9ICgpID0+ICh7fSkpOiBQcm9taXNlPG51bWJlcj4gPT4ge1xuICBjb25zdCB7Y2xpTmFtZSA9ICdMZXgnLCBxdWlldCwgc25hcHNob3RzfSA9IGNtZDtcblxuICAvLyBTcGlubmVyXG4gIGNvbnN0IHNwaW5uZXIgPSBjcmVhdGVTcGlubmVyKHF1aWV0KTtcblxuICAvLyBEaXNwbGF5IHN0YXR1c1xuICBsb2coYCR7Y2xpTmFtZX0gY2xlYW5pbmcgZGlyZWN0b3J5Li4uYCwgJ2luZm8nLCBxdWlldCk7XG5cbiAgLy8gR2V0IGN1c3RvbSBjb25maWd1cmF0aW9uXG4gIExleENvbmZpZy5wYXJzZUNvbmZpZyhjbWQpO1xuXG4gIC8vIFN0YXJ0IGNsZWFuaW5nIHNwaW5uZXJcbiAgc3Bpbm5lci5zdGFydCgnQ2xlYW5pbmcgZmlsZXMuLi4nKTtcblxuICB0cnkge1xuICAgIC8vIFJlbW92ZSBub2RlX21vZHVsZXNcbiAgICBhd2FpdCByZW1vdmVNb2R1bGVzKCk7XG5cbiAgICAvLyBSZW1vdmUgdGVzdCBjb3ZlcmFnZSByZXBvcnRzXG4gICAgYXdhaXQgcmVtb3ZlRmlsZXMoJy4vY292ZXJhZ2UnLCB0cnVlKTtcblxuICAgIC8vIFJlbW92ZSBucG0gbG9nc1xuICAgIGF3YWl0IHJlbW92ZUZpbGVzKCcuL25wbS1kZWJ1Zy5sb2cnLCB0cnVlKTtcblxuICAgIGlmKHNuYXBzaG90cykge1xuICAgICAgYXdhaXQgcmVtb3ZlRmlsZXMoJy4vKiovX19zbmFwc2hvdHNfXycsIHRydWUpO1xuICAgIH1cblxuICAgIC8vIFN0b3Agc3Bpbm5lclxuICAgIHNwaW5uZXIuc3VjY2VlZCgnU3VjY2Vzc2Z1bGx5IGNsZWFuZWQhJyk7XG5cbiAgICAvLyBTdG9wIHByb2Nlc3NcbiAgICBjYWxsYmFjaygwKTtcbiAgICByZXR1cm4gMDtcbiAgfSBjYXRjaChlcnJvcikge1xuICAgIC8vIERpc3BsYXkgZXJyb3IgbWVzc2FnZVxuICAgIGxvZyhgXFxuJHtjbGlOYW1lfSBFcnJvcjogJHtlcnJvci5tZXNzYWdlfWAsICdlcnJvcicsIHF1aWV0KTtcblxuICAgIC8vIFN0b3Agc3Bpbm5lclxuICAgIHNwaW5uZXIuZmFpbCgnRmFpbGVkIHRvIGNsZWFuIHByb2plY3QuJyk7XG5cbiAgICAvLyBLaWxsIHByb2Nlc3NcbiAgICBjYWxsYmFjayhlcnJvci5zdGF0dXMpO1xuICAgIHJldHVybiBlcnJvci5zdGF0dXM7XG4gIH1cbn07XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFJQSx1QkFBd0I7QUFDeEIsaUJBQXdEO0FBQ3hELGlCQUFrQjtBQUVYLE1BQU0sUUFBUSxPQUFPLEtBQVUsV0FBZ0IsTUFBTyxFQUFDLE9BQXdCO0FBQ3BGLFFBQU0sRUFBQyxVQUFVLE9BQU8sT0FBTyxjQUFhO0FBRzVDLFFBQU0sVUFBVSw4QkFBYyxLQUFLO0FBR25DLHNCQUFJLEdBQUcsaUNBQWlDLFFBQVEsS0FBSztBQUdyRCw2QkFBVSxZQUFZLEdBQUc7QUFHekIsVUFBUSxNQUFNLG1CQUFtQjtBQUVqQyxNQUFJO0FBRUYsVUFBTSw4QkFBYztBQUdwQixVQUFNLDRCQUFZLGNBQWMsSUFBSTtBQUdwQyxVQUFNLDRCQUFZLG1CQUFtQixJQUFJO0FBRXpDLFFBQUcsV0FBVztBQUNaLFlBQU0sNEJBQVksc0JBQXNCLElBQUk7QUFBQSxJQUM5QztBQUdBLFlBQVEsUUFBUSx1QkFBdUI7QUFHdkMsYUFBUyxDQUFDO0FBQ1YsV0FBTztBQUFBLEVBQ1QsU0FBUSxPQUFOO0FBRUEsd0JBQUk7QUFBQSxFQUFLLGtCQUFrQixNQUFNLFdBQVcsU0FBUyxLQUFLO0FBRzFELFlBQVEsS0FBSywwQkFBMEI7QUFHdkMsYUFBUyxNQUFNLE1BQU07QUFDckIsV0FBTyxNQUFNO0FBQUEsRUFDZjtBQUNGOyIsCiAgIm5hbWVzIjogW10KfQo=
30
+ };
31
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2NsZWFuLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtMZXhDb25maWd9IGZyb20gJy4uL0xleENvbmZpZy5qcyc7XG5pbXBvcnQge2NyZWF0ZVNwaW5uZXIsIHJlbW92ZUZpbGVzLCByZW1vdmVNb2R1bGVzfSBmcm9tICcuLi91dGlscy9hcHAuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uL3V0aWxzL2xvZy5qcyc7XG5cbmV4cG9ydCBjb25zdCBjbGVhbiA9IGFzeW5jIChjbWQ6IGFueSwgY2FsbGJhY2s6IGFueSA9ICgpID0+ICh7fSkpOiBQcm9taXNlPG51bWJlcj4gPT4ge1xuICBjb25zdCB7Y2xpTmFtZSA9ICdMZXgnLCBxdWlldCwgc25hcHNob3RzfSA9IGNtZDtcblxuICAvLyBTcGlubmVyXG4gIGNvbnN0IHNwaW5uZXIgPSBjcmVhdGVTcGlubmVyKHF1aWV0KTtcblxuICAvLyBEaXNwbGF5IHN0YXR1c1xuICBsb2coYCR7Y2xpTmFtZX0gY2xlYW5pbmcgZGlyZWN0b3J5Li4uYCwgJ2luZm8nLCBxdWlldCk7XG5cbiAgLy8gR2V0IGN1c3RvbSBjb25maWd1cmF0aW9uXG4gIExleENvbmZpZy5wYXJzZUNvbmZpZyhjbWQpO1xuXG4gIC8vIFN0YXJ0IGNsZWFuaW5nIHNwaW5uZXJcbiAgc3Bpbm5lci5zdGFydCgnQ2xlYW5pbmcgZmlsZXMuLi4nKTtcblxuICB0cnkge1xuICAgIC8vIFJlbW92ZSBub2RlX21vZHVsZXNcbiAgICBhd2FpdCByZW1vdmVNb2R1bGVzKCk7XG5cbiAgICAvLyBSZW1vdmUgdGVzdCBjb3ZlcmFnZSByZXBvcnRzXG4gICAgYXdhaXQgcmVtb3ZlRmlsZXMoJy4vY292ZXJhZ2UnLCB0cnVlKTtcblxuICAgIC8vIFJlbW92ZSBucG0gbG9nc1xuICAgIGF3YWl0IHJlbW92ZUZpbGVzKCcuL25wbS1kZWJ1Zy5sb2cnLCB0cnVlKTtcblxuICAgIGlmKHNuYXBzaG90cykge1xuICAgICAgYXdhaXQgcmVtb3ZlRmlsZXMoJy4vKiovX19zbmFwc2hvdHNfXycsIHRydWUpO1xuICAgIH1cblxuICAgIC8vIFN0b3Agc3Bpbm5lclxuICAgIHNwaW5uZXIuc3VjY2VlZCgnU3VjY2Vzc2Z1bGx5IGNsZWFuZWQhJyk7XG5cbiAgICAvLyBTdG9wIHByb2Nlc3NcbiAgICBjYWxsYmFjaygwKTtcbiAgICByZXR1cm4gMDtcbiAgfSBjYXRjaChlcnJvcikge1xuICAgIC8vIERpc3BsYXkgZXJyb3IgbWVzc2FnZVxuICAgIGxvZyhgXFxuJHtjbGlOYW1lfSBFcnJvcjogJHtlcnJvci5tZXNzYWdlfWAsICdlcnJvcicsIHF1aWV0KTtcblxuICAgIC8vIFN0b3Agc3Bpbm5lclxuICAgIHNwaW5uZXIuZmFpbCgnRmFpbGVkIHRvIGNsZWFuIHByb2plY3QuJyk7XG5cbiAgICAvLyBLaWxsIHByb2Nlc3NcbiAgICBjYWxsYmFjayhlcnJvci5zdGF0dXMpO1xuICAgIHJldHVybiBlcnJvci5zdGF0dXM7XG4gIH1cbn07XG4iXSwKICAibWFwcGluZ3MiOiAiQUFJQSxTQUFRLGlCQUFnQjtBQUN4QixTQUFRLGVBQWUsYUFBYSxxQkFBb0I7QUFDeEQsU0FBUSxXQUFVO0FBRVgsTUFBTSxRQUFRLE9BQU8sS0FBVSxXQUFnQixPQUFPLENBQUMsT0FBd0I7QUFDcEYsUUFBTSxFQUFDLFVBQVUsT0FBTyxPQUFPLFVBQVMsSUFBSTtBQUc1QyxRQUFNLFVBQVUsY0FBYyxLQUFLO0FBR25DLE1BQUksR0FBRyxpQ0FBaUMsUUFBUSxLQUFLO0FBR3JELFlBQVUsWUFBWSxHQUFHO0FBR3pCLFVBQVEsTUFBTSxtQkFBbUI7QUFFakMsTUFBSTtBQUVGLFVBQU0sY0FBYztBQUdwQixVQUFNLFlBQVksY0FBYyxJQUFJO0FBR3BDLFVBQU0sWUFBWSxtQkFBbUIsSUFBSTtBQUV6QyxRQUFHLFdBQVc7QUFDWixZQUFNLFlBQVksc0JBQXNCLElBQUk7QUFBQSxJQUM5QztBQUdBLFlBQVEsUUFBUSx1QkFBdUI7QUFHdkMsYUFBUyxDQUFDO0FBQ1YsV0FBTztBQUFBLEVBQ1QsU0FBUSxPQUFOO0FBRUEsUUFBSTtBQUFBLEVBQUssa0JBQWtCLE1BQU0sV0FBVyxTQUFTLEtBQUs7QUFHMUQsWUFBUSxLQUFLLDBCQUEwQjtBQUd2QyxhQUFTLE1BQU0sTUFBTTtBQUNyQixXQUFPLE1BQU07QUFBQSxFQUNmO0FBQ0Y7IiwKICAibmFtZXMiOiBbXQp9Cg==