@nlabs/lex 1.39.0 → 1.41.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.eslintrc +1 -0
- package/.vscode/settings.json +1 -1
- package/babel.config.json +13 -0
- package/dist/LexConfig.js +40 -36
- package/dist/commands/build.js +98 -52
- package/dist/commands/bulid.test.js +314 -5
- package/dist/commands/clean.js +4 -4
- package/dist/commands/clean.test.js +63 -0
- package/dist/commands/compile.js +32 -35
- package/dist/commands/compile.test.js +93 -0
- package/dist/commands/config.js +4 -4
- package/dist/commands/copy.js +1 -1
- package/dist/commands/create.js +10 -10
- package/dist/commands/dev.js +12 -12
- package/dist/commands/init.js +17 -17
- package/dist/commands/link.js +3 -3
- package/dist/commands/lint.js +53 -39
- package/dist/commands/migrate.js +4 -4
- package/dist/commands/publish.js +7 -7
- package/dist/commands/test.js +14 -14
- package/dist/commands/update.js +10 -10
- package/dist/commands/upgrade.js +7 -7
- package/dist/commands/versions.js +8 -9
- package/dist/commands/versions.test.js +49 -0
- package/dist/create/changelog.js +3 -3
- package/dist/lex.js +16 -16
- package/dist/lint.js +8 -0
- package/dist/utils/app.js +1 -1
- package/dist/utils/file.js +20 -10
- package/jest.config.cjs +55 -0
- package/jest.config.lex.js +27 -28
- package/jest.setup.ts +3 -0
- package/package.json +76 -71
- package/resolver.cjs +86 -0
- package/test/javascript.js +6 -0
- package/test/typescript.ts +6 -0
- package/tsconfig.build.json +1 -1
- package/tsconfig.json +1 -1
- package/tsconfig.template.json +5 -5
- package/webpack.config.js +78 -65
- package/dist/resolver.js +0 -70
- package/jest.config.js +0 -14
- package/jest.setup.js +0 -3
package/.eslintrc
CHANGED
package/.vscode/settings.json
CHANGED
package/dist/LexConfig.js
CHANGED
|
@@ -1,35 +1,38 @@
|
|
|
1
1
|
import { existsSync, readFileSync, writeFileSync } from "fs";
|
|
2
|
-
import
|
|
3
|
-
import {
|
|
2
|
+
import { extname as pathExtname, resolve as pathResolve } from "path";
|
|
3
|
+
import { URL } from "url";
|
|
4
4
|
import { relativeFilePath } from "./utils/file.js";
|
|
5
5
|
import { log } from "./utils/log.js";
|
|
6
6
|
const cwd = process.cwd();
|
|
7
|
+
const defaultConfigValues = {
|
|
8
|
+
configFiles: [],
|
|
9
|
+
entryHTML: "index.html",
|
|
10
|
+
entryJs: "index.js",
|
|
11
|
+
esbuild: {},
|
|
12
|
+
env: null,
|
|
13
|
+
jest: {},
|
|
14
|
+
outputFullPath: pathResolve(cwd, "./dist"),
|
|
15
|
+
outputHash: false,
|
|
16
|
+
outputPath: "./dist",
|
|
17
|
+
packageManager: "npm",
|
|
18
|
+
preset: "web",
|
|
19
|
+
sourceFullPath: pathResolve(cwd, "./src"),
|
|
20
|
+
sourcePath: "./src",
|
|
21
|
+
targetEnvironment: "web",
|
|
22
|
+
useGraphQl: false,
|
|
23
|
+
useTypescript: false,
|
|
24
|
+
webpack: {}
|
|
25
|
+
};
|
|
7
26
|
class LexConfig {
|
|
8
27
|
static config = {
|
|
9
|
-
|
|
10
|
-
entryHTML: "index.html",
|
|
11
|
-
entryJs: "index.js",
|
|
12
|
-
esbuild: {},
|
|
13
|
-
env: null,
|
|
14
|
-
jest: {},
|
|
15
|
-
outputFullPath: path.resolve(cwd, "./dist"),
|
|
16
|
-
outputHash: false,
|
|
17
|
-
outputPath: "./dist",
|
|
18
|
-
packageManager: "npm",
|
|
19
|
-
preset: "web",
|
|
20
|
-
sourceFullPath: path.resolve(cwd, "./src"),
|
|
21
|
-
sourcePath: "./src",
|
|
22
|
-
targetEnvironment: "web",
|
|
23
|
-
useGraphQl: false,
|
|
24
|
-
useTypescript: false,
|
|
25
|
-
webpack: {}
|
|
28
|
+
...defaultConfigValues
|
|
26
29
|
};
|
|
27
30
|
static set useTypescript(value) {
|
|
28
31
|
LexConfig.config.useTypescript = value;
|
|
29
32
|
const { sourceFullPath } = LexConfig.config;
|
|
30
33
|
const { entryJs } = LexConfig.config;
|
|
31
34
|
if (entryJs === "index.js" && value) {
|
|
32
|
-
const indexPath =
|
|
35
|
+
const indexPath = pathResolve(cwd, sourceFullPath, "index.tsx");
|
|
33
36
|
const hasIndexTsx = existsSync(indexPath);
|
|
34
37
|
if (hasIndexTsx) {
|
|
35
38
|
LexConfig.config.entryJs = "index.tsx";
|
|
@@ -46,10 +49,10 @@ class LexConfig {
|
|
|
46
49
|
LexConfig.useTypescript = useTypescript;
|
|
47
50
|
}
|
|
48
51
|
if (outputPath !== void 0 && outputFullPath === void 0) {
|
|
49
|
-
updatedConfig.outputFullPath =
|
|
52
|
+
updatedConfig.outputFullPath = pathResolve(cwd2, outputPath);
|
|
50
53
|
}
|
|
51
54
|
if (sourcePath !== void 0 && sourceFullPath === void 0) {
|
|
52
|
-
updatedConfig.sourceFullPath =
|
|
55
|
+
updatedConfig.sourceFullPath = pathResolve(cwd2, sourcePath);
|
|
53
56
|
}
|
|
54
57
|
LexConfig.config = { ...LexConfig.config, ...updatedConfig };
|
|
55
58
|
return LexConfig.config;
|
|
@@ -60,14 +63,14 @@ class LexConfig {
|
|
|
60
63
|
const { environment, outputPath, sourcePath, typescript } = cmd;
|
|
61
64
|
if (outputPath !== void 0) {
|
|
62
65
|
params.outputPath = outputPath;
|
|
63
|
-
params.outputFullPath =
|
|
66
|
+
params.outputFullPath = pathResolve(cwd, outputPath);
|
|
64
67
|
}
|
|
65
68
|
if (sourcePath !== void 0) {
|
|
66
69
|
params.sourcePath = sourcePath;
|
|
67
|
-
params.sourceFullPath =
|
|
70
|
+
params.sourceFullPath = pathResolve(cwd, sourcePath);
|
|
68
71
|
}
|
|
69
72
|
if (typescript !== void 0) {
|
|
70
|
-
params.useTypescript =
|
|
73
|
+
params.useTypescript = true;
|
|
71
74
|
}
|
|
72
75
|
if (environment !== void 0) {
|
|
73
76
|
params.targetEnvironment = environment === "web" ? "web" : "node";
|
|
@@ -83,21 +86,21 @@ class LexConfig {
|
|
|
83
86
|
);
|
|
84
87
|
}
|
|
85
88
|
// Get configuration
|
|
86
|
-
static parseConfig(cmd, isRoot = true) {
|
|
89
|
+
static async parseConfig(cmd, isRoot = true) {
|
|
87
90
|
const { cliName = "Lex", lexConfig, lexConfigName, quiet, typescript } = cmd;
|
|
88
91
|
const configName = lexConfigName || "lex.config.js";
|
|
89
|
-
const defaultConfigPath = isRoot ?
|
|
92
|
+
const defaultConfigPath = isRoot ? pathResolve(cwd, `./${configName}`) : relativeFilePath(configName, cwd);
|
|
90
93
|
const configPath = lexConfig || defaultConfigPath;
|
|
91
94
|
const configExists = existsSync(configPath);
|
|
92
95
|
if (configExists) {
|
|
93
96
|
log(`Using ${cliName} configuration file: ${configPath}`, "note", quiet);
|
|
94
|
-
const ext =
|
|
97
|
+
const ext = pathExtname(configPath);
|
|
95
98
|
if (ext === ".json") {
|
|
96
99
|
const configContent = readFileSync(configPath, "utf8");
|
|
97
100
|
if (configContent) {
|
|
98
101
|
let configJson;
|
|
99
102
|
try {
|
|
100
|
-
configJson = JSON.parse(configContent);
|
|
103
|
+
configJson = JSON.parse(configContent)?.default || {};
|
|
101
104
|
} catch (error) {
|
|
102
105
|
configJson = {};
|
|
103
106
|
}
|
|
@@ -107,8 +110,8 @@ class LexConfig {
|
|
|
107
110
|
${cliName} Error: Config file malformed, ${configPath}`, "error", quiet);
|
|
108
111
|
}
|
|
109
112
|
} else if (ext === ".js") {
|
|
110
|
-
const lexCustomConfig =
|
|
111
|
-
LexConfig.addConfigParams(cmd, lexCustomConfig);
|
|
113
|
+
const lexCustomConfig = await import(configPath);
|
|
114
|
+
LexConfig.addConfigParams(cmd, lexCustomConfig.default || {});
|
|
112
115
|
} else {
|
|
113
116
|
log(`
|
|
114
117
|
${cliName} Error: Config file must be a JS or JSON file.`, "error", quiet);
|
|
@@ -119,14 +122,15 @@ ${cliName} Error: Config file must be a JS or JSON file.`, "error", quiet);
|
|
|
119
122
|
}
|
|
120
123
|
}
|
|
121
124
|
static checkTypescriptConfig() {
|
|
122
|
-
const tsconfigPath =
|
|
125
|
+
const tsconfigPath = pathResolve(cwd, "./tsconfig.json");
|
|
123
126
|
if (!existsSync(tsconfigPath)) {
|
|
124
|
-
const dirName =
|
|
125
|
-
writeFileSync(tsconfigPath, readFileSync(
|
|
127
|
+
const dirName = new URL(".", import.meta.url).pathname;
|
|
128
|
+
writeFileSync(tsconfigPath, readFileSync(pathResolve(dirName, "../../../tsconfig.base.json")));
|
|
126
129
|
}
|
|
127
130
|
}
|
|
128
131
|
}
|
|
129
132
|
export {
|
|
130
|
-
LexConfig
|
|
133
|
+
LexConfig,
|
|
134
|
+
defaultConfigValues
|
|
131
135
|
};
|
|
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"]
}

|
|
136
|
+
//# 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 {URL} 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 const defaultConfigValues: 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\nexport class LexConfig {\n  static config: LexConfigType = {\n    ...defaultConfigValues\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 = true;\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 async parseConfig(cmd, isRoot: boolean = true): Promise<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)?.default || {};\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 = await import(configPath);\n        LexConfig.addConfigParams(cmd, lexCustomConfig.default || {});\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    const tsconfigPath: string = pathResolve(cwd, './tsconfig.json');\n\n    if(!existsSync(tsconfigPath)) {\n      const dirName = new URL('.', import.meta.url).pathname;\n      writeFileSync(tsconfigPath, readFileSync(pathResolve(dirName, '../../../tsconfig.base.json')));\n    }\n  }\n}\n"],
  "mappings": "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",
  "names": ["cwd"]
}

|
package/dist/commands/build.js
CHANGED
|
@@ -1,20 +1,20 @@
|
|
|
1
1
|
import graphqlLoaderPlugin from "@luckycatfactory/esbuild-graphql-loader";
|
|
2
2
|
import { build as esBuild } from "esbuild";
|
|
3
3
|
import { execa } from "execa";
|
|
4
|
-
import
|
|
5
|
-
import {
|
|
4
|
+
import { resolve as pathResolve } from "path";
|
|
5
|
+
import { URL } from "url";
|
|
6
6
|
import { LexConfig } from "../LexConfig.js";
|
|
7
7
|
import { checkLinkedModules, createSpinner, removeFiles } from "../utils/app.js";
|
|
8
|
-
import {
|
|
8
|
+
import { relativeNodePath } from "../utils/file.js";
|
|
9
9
|
import { log } from "../utils/log.js";
|
|
10
|
-
const buildWithEsBuild = async (spinner,
|
|
10
|
+
const buildWithEsBuild = async (spinner, commandOptions, callback) => {
|
|
11
11
|
const {
|
|
12
12
|
cliName = "Lex",
|
|
13
13
|
outputPath,
|
|
14
14
|
quiet,
|
|
15
15
|
sourcePath,
|
|
16
|
-
watch
|
|
17
|
-
} =
|
|
16
|
+
watch = false
|
|
17
|
+
} = commandOptions;
|
|
18
18
|
const {
|
|
19
19
|
targetEnvironment,
|
|
20
20
|
useGraphQl,
|
|
@@ -52,83 +52,127 @@ ${cliName} Error: ${error.message}`, "error", quiet);
|
|
|
52
52
|
console.error(error);
|
|
53
53
|
}
|
|
54
54
|
spinner.fail("Code build failed.");
|
|
55
|
-
callback(
|
|
56
|
-
return
|
|
55
|
+
callback(1);
|
|
56
|
+
return 1;
|
|
57
57
|
}
|
|
58
58
|
callback(0);
|
|
59
59
|
return 0;
|
|
60
60
|
};
|
|
61
61
|
const buildWithWebpack = async (spinner, cmd, callback) => {
|
|
62
62
|
const {
|
|
63
|
-
|
|
63
|
+
analyze,
|
|
64
64
|
cliName = "Lex",
|
|
65
65
|
config,
|
|
66
|
+
configName,
|
|
67
|
+
defineProcessEnvNodeEnv,
|
|
68
|
+
devtool,
|
|
69
|
+
disableInterpret,
|
|
70
|
+
entry,
|
|
71
|
+
env,
|
|
72
|
+
failOnWarnings,
|
|
73
|
+
json,
|
|
74
|
+
merge,
|
|
66
75
|
mode,
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
76
|
+
name,
|
|
77
|
+
nodeEnv,
|
|
78
|
+
noDevtool,
|
|
79
|
+
noStats,
|
|
80
|
+
noTarget,
|
|
81
|
+
noWatch,
|
|
82
|
+
noWatchOptionsStdin,
|
|
83
|
+
outputPath,
|
|
75
84
|
quiet = false,
|
|
76
|
-
|
|
85
|
+
stats,
|
|
86
|
+
target,
|
|
87
|
+
watch,
|
|
88
|
+
watchOptionsStdin
|
|
77
89
|
} = cmd;
|
|
78
90
|
let webpackConfig;
|
|
91
|
+
const dirName = new URL(".", import.meta.url).pathname;
|
|
79
92
|
if (config) {
|
|
80
93
|
const isRelativeConfig = config.substr(0, 2) === "./";
|
|
81
|
-
|
|
82
|
-
webpackConfig = fullConfigPath;
|
|
94
|
+
webpackConfig = isRelativeConfig ? pathResolve(process.cwd(), config) : config;
|
|
83
95
|
} else {
|
|
84
|
-
|
|
85
|
-
webpackConfig = path.resolve(dirName, "../../webpack.config.js");
|
|
96
|
+
webpackConfig = pathResolve(dirName, "../../webpack.config.js");
|
|
86
97
|
}
|
|
87
98
|
const webpackOptions = [
|
|
88
99
|
"--color",
|
|
89
100
|
"--progress",
|
|
90
|
-
"--stats-error-details",
|
|
91
101
|
"--config",
|
|
92
102
|
webpackConfig
|
|
93
103
|
];
|
|
104
|
+
if (analyze) {
|
|
105
|
+
webpackOptions.push("--analyze");
|
|
106
|
+
}
|
|
107
|
+
if (configName) {
|
|
108
|
+
webpackOptions.push("--config-name", configName);
|
|
109
|
+
}
|
|
110
|
+
if (defineProcessEnvNodeEnv) {
|
|
111
|
+
webpackOptions.push("--define-process-env-node-env", defineProcessEnvNodeEnv);
|
|
112
|
+
}
|
|
113
|
+
if (devtool) {
|
|
114
|
+
webpackOptions.push("--devtool", devtool);
|
|
115
|
+
}
|
|
116
|
+
if (disableInterpret) {
|
|
117
|
+
webpackOptions.push("--disable-interpret");
|
|
118
|
+
}
|
|
119
|
+
if (entry) {
|
|
120
|
+
webpackOptions.push("--entry", entry);
|
|
121
|
+
}
|
|
122
|
+
if (env) {
|
|
123
|
+
webpackOptions.push("--env", env);
|
|
124
|
+
}
|
|
125
|
+
if (failOnWarnings) {
|
|
126
|
+
webpackOptions.push("--fail-on-warnings");
|
|
127
|
+
}
|
|
128
|
+
if (json) {
|
|
129
|
+
webpackOptions.push("--json", json);
|
|
130
|
+
}
|
|
94
131
|
if (mode) {
|
|
95
132
|
webpackOptions.push("--mode", mode);
|
|
96
133
|
}
|
|
97
|
-
if (
|
|
98
|
-
webpackOptions.push("--
|
|
134
|
+
if (merge) {
|
|
135
|
+
webpackOptions.push("--merge");
|
|
99
136
|
}
|
|
100
|
-
if (
|
|
101
|
-
webpackOptions.push("--
|
|
137
|
+
if (name) {
|
|
138
|
+
webpackOptions.push("--name", name);
|
|
102
139
|
}
|
|
103
|
-
if (
|
|
104
|
-
webpackOptions.push("--
|
|
140
|
+
if (noDevtool) {
|
|
141
|
+
webpackOptions.push("--no-devtool");
|
|
105
142
|
}
|
|
106
|
-
if (
|
|
107
|
-
webpackOptions.push("--
|
|
143
|
+
if (noStats) {
|
|
144
|
+
webpackOptions.push("--no-stats");
|
|
108
145
|
}
|
|
109
|
-
if (
|
|
110
|
-
webpackOptions.push("--
|
|
146
|
+
if (noTarget) {
|
|
147
|
+
webpackOptions.push("--no-target");
|
|
111
148
|
}
|
|
112
|
-
if (
|
|
113
|
-
webpackOptions.push("--
|
|
149
|
+
if (noWatch) {
|
|
150
|
+
webpackOptions.push("--no-watch");
|
|
114
151
|
}
|
|
115
|
-
if (
|
|
116
|
-
webpackOptions.push("--
|
|
152
|
+
if (noWatchOptionsStdin) {
|
|
153
|
+
webpackOptions.push("--no-watch-options-stdin");
|
|
117
154
|
}
|
|
118
|
-
if (
|
|
119
|
-
webpackOptions.push("--
|
|
155
|
+
if (nodeEnv) {
|
|
156
|
+
webpackOptions.push("--node-env", nodeEnv);
|
|
120
157
|
}
|
|
121
|
-
if (
|
|
122
|
-
webpackOptions.push("--
|
|
158
|
+
if (outputPath) {
|
|
159
|
+
webpackOptions.push("--output-path", outputPath);
|
|
160
|
+
}
|
|
161
|
+
if (stats) {
|
|
162
|
+
webpackOptions.push("--stats", stats);
|
|
163
|
+
}
|
|
164
|
+
if (target) {
|
|
165
|
+
webpackOptions.push("--target", target);
|
|
123
166
|
}
|
|
124
167
|
if (watch) {
|
|
125
168
|
webpackOptions.push("--watch");
|
|
126
169
|
}
|
|
170
|
+
if (watchOptionsStdin) {
|
|
171
|
+
webpackOptions.push("--watch-options-stdin");
|
|
172
|
+
}
|
|
127
173
|
try {
|
|
128
|
-
const
|
|
129
|
-
|
|
130
|
-
const webpackPath = relativeFilePath("webpack-cli/bin/cli.js", nodePath);
|
|
131
|
-
await execa(webpackPath, webpackOptions, { encoding: "utf-8", stdio: "inherit" });
|
|
174
|
+
const webpackPath = relativeNodePath("webpack-cli/bin/cli.js", "../..");
|
|
175
|
+
await execa(webpackPath, webpackOptions, { encoding: "utf8", stdio: "inherit" });
|
|
132
176
|
spinner.succeed("Build completed successfully!");
|
|
133
177
|
callback(0);
|
|
134
178
|
return 0;
|
|
@@ -136,8 +180,8 @@ const buildWithWebpack = async (spinner, cmd, callback) => {
|
|
|
136
180
|
log(`
|
|
137
181
|
${cliName} Error: ${error.message}`, "error", quiet);
|
|
138
182
|
spinner.fail("Build failed.");
|
|
139
|
-
callback(
|
|
140
|
-
return
|
|
183
|
+
callback(1);
|
|
184
|
+
return 1;
|
|
141
185
|
}
|
|
142
186
|
};
|
|
143
187
|
const build = async (cmd, callback = () => ({})) => {
|
|
@@ -145,12 +189,12 @@ const build = async (cmd, callback = () => ({})) => {
|
|
|
145
189
|
bundler = "webpack",
|
|
146
190
|
cliName = "Lex",
|
|
147
191
|
quiet = false,
|
|
148
|
-
remove,
|
|
149
|
-
variables
|
|
192
|
+
remove = false,
|
|
193
|
+
variables = "{}"
|
|
150
194
|
} = cmd;
|
|
151
195
|
const spinner = createSpinner(quiet);
|
|
152
196
|
log(`${cliName} building...`, "info", quiet);
|
|
153
|
-
LexConfig.parseConfig(cmd);
|
|
197
|
+
await LexConfig.parseConfig(cmd);
|
|
154
198
|
const { outputFullPath, useTypescript } = LexConfig.config;
|
|
155
199
|
checkLinkedModules();
|
|
156
200
|
let variablesObj = { NODE_ENV: "production" };
|
|
@@ -177,9 +221,11 @@ ${cliName} Error: Environment variables option is not a valid JSON object.`, "er
|
|
|
177
221
|
}
|
|
178
222
|
return buildWithWebpack(spinner, cmd, callback);
|
|
179
223
|
};
|
|
224
|
+
var build_default = build;
|
|
180
225
|
export {
|
|
181
226
|
build,
|
|
182
227
|
buildWithEsBuild,
|
|
183
|
-
buildWithWebpack
|
|
228
|
+
buildWithWebpack,
|
|
229
|
+
build_default as default
|
|
184
230
|
};
|
|
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": []
}

|
|
231
|
+
//# 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 {URL} 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 interface BuildOptions {\n  readonly bundler?: 'webpack' | 'esbuild';\n  readonly cliName?: string;\n  readonly outputPath?: string;\n  readonly quiet?: boolean;\n  readonly remove?: boolean;\n  readonly sourcePath?: string;\n  readonly variables?: string;\n  readonly watch?: boolean;\n}\n\nexport type BuildCallback = (status: number) => void;\n\nexport const buildWithEsBuild = async (spinner, commandOptions: BuildOptions, callback: BuildCallback) => {\n  const {\n    cliName = 'Lex',\n    outputPath,\n    quiet,\n    sourcePath,\n    watch = false\n  } = commandOptions;\n  const {\n    targetEnvironment,\n    useGraphQl,\n    useTypescript\n  } = LexConfig.config;\n  const loader: any = {\n    '.js': 'js'\n  };\n\n  if(useTypescript) {\n    loader['.ts'] = 'ts';\n    loader['.tsx'] = 'tsx';\n  }\n\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: watch as never\n    });\n\n    spinner.succeed('Build completed successfully!');\n  } catch(error) {\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n    if(!quiet) {\n      console.error(error);\n    }\n\n    spinner.fail('Code build failed.');\n\n    callback(1);\n    return 1;\n  }\n\n  callback(0);\n  return 0;\n};\n\nexport const buildWithWebpack = async (spinner, cmd, callback) => {\n  const {\n    analyze,\n    cliName = 'Lex',\n    config,\n    configName,\n    defineProcessEnvNodeEnv,\n    devtool,\n    disableInterpret,\n    entry,\n    env,\n    failOnWarnings,\n    json,\n    merge,\n    mode,\n    name,\n    nodeEnv,\n    noDevtool,\n    noStats,\n    noTarget,\n    noWatch,\n    noWatchOptionsStdin,\n    outputPath,\n    quiet = false,\n    stats,\n    target,\n    watch,\n    watchOptionsStdin\n  } = cmd;\n\n  // Get custom webpack configuration\n  let webpackConfig: string;\n  const dirName = new URL('.', import.meta.url).pathname;\n\n  if(config) {\n    const isRelativeConfig: boolean = config.substr(0, 2) === './';\n    webpackConfig = isRelativeConfig ? pathResolve(process.cwd(), config) : config;\n  } else {\n    webpackConfig = pathResolve(dirName, '../../webpack.config.js');\n  }\n\n  const webpackOptions: string[] = [\n    '--color',\n    '--progress',\n    '--config', webpackConfig\n  ];\n\n  if(analyze) {\n    webpackOptions.push('--analyze');\n  }\n\n  if(configName) {\n    webpackOptions.push('--config-name', configName);\n  }\n\n  if(defineProcessEnvNodeEnv) {\n    webpackOptions.push('--define-process-env-node-env', defineProcessEnvNodeEnv);\n  }\n\n  if(devtool) {\n    webpackOptions.push('--devtool', devtool);\n  }\n\n  if(disableInterpret) {\n    webpackOptions.push('--disable-interpret');\n  }\n\n  if(entry) {\n    webpackOptions.push('--entry', entry);\n  }\n\n  if(env) {\n    webpackOptions.push('--env', env);\n  }\n\n  if(failOnWarnings) {\n    webpackOptions.push('--fail-on-warnings');\n  }\n\n  if(json) {\n    webpackOptions.push('--json', json);\n  }\n\n  if(mode) {\n    webpackOptions.push('--mode', mode);\n  }\n\n  if(merge) {\n    webpackOptions.push('--merge');\n  }\n\n  if(name) {\n    webpackOptions.push('--name', name);\n  }\n\n  if(noDevtool) {\n    webpackOptions.push('--no-devtool');\n  }\n\n  if(noStats) {\n    webpackOptions.push('--no-stats');\n  }\n\n  if(noTarget) {\n    webpackOptions.push('--no-target');\n  }\n\n  if(noWatch) {\n    webpackOptions.push('--no-watch');\n  }\n\n  if(noWatchOptionsStdin) {\n    webpackOptions.push('--no-watch-options-stdin');\n  }\n\n  if(nodeEnv) {\n    webpackOptions.push('--node-env', nodeEnv);\n  }\n\n  if(outputPath) {\n    webpackOptions.push('--output-path', outputPath);\n  }\n\n  if(stats) {\n    webpackOptions.push('--stats', stats);\n  }\n\n  if(target) {\n    webpackOptions.push('--target', target);\n  }\n\n  if(watch) {\n    webpackOptions.push('--watch');\n  }\n\n  if(watchOptionsStdin) {\n    webpackOptions.push('--watch-options-stdin');\n  }\n\n  // Compile using webpack\n  try {\n    const webpackPath: string = relativeNodePath('webpack-cli/bin/cli.js', '../..');\n    await execa(webpackPath, webpackOptions, {encoding: 'utf8', 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(1);\n    return 1;\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 = false,\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  await 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\nexport default build;\n"],
  "mappings": "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",
  "names": []
}

|