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

|
|
206
|
+
};
|
|
207
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/commands/compile.ts"],
  "sourcesContent": ["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {execa} from 'execa';\nimport {existsSync, lstatSync, readdirSync} from 'fs';\nimport * as glob from 'glob';\nimport * as path from 'path';\nimport {fileURLToPath} from 'url';\n\nimport {LexConfig} from '../LexConfig.js';\nimport {checkLinkedModules, copyFiles, createSpinner, getFilesByExt, removeFiles} from '../utils/app.js';\nimport {relativeFilePath} from '../utils/file.js';\nimport {log} from '../utils/log.js';\n\nexport const hasFileType = (startPath: string, ext: string[]): boolean => {\n  if(!existsSync(startPath)) {\n    return false;\n  }\n\n  const files: string[] = readdirSync(startPath);\n\n  return files.some((file: string) => {\n    const filename: string = path.join(startPath, file);\n    const fileExt: string = path.extname(filename);\n    const stat = lstatSync(filename);\n\n    if(stat.isDirectory()) {\n      // Recursive search\n      return hasFileType(filename, ext);\n    }\n\n    return ext.includes(fileExt);\n  });\n};\n\nexport const compile = async (cmd: any, callback: any = () => ({})): Promise<number> => {\n  const {cliName = 'Lex', config, quiet, remove, watch} = cmd;\n\n  // Spinner\n  const spinner = createSpinner(quiet);\n\n  // Display status\n  log(`${cliName} compiling...`, 'info', quiet);\n\n  // Get custom configuration\n  LexConfig.parseConfig(cmd);\n\n  // Compile type\n  const {outputFullPath, preset, sourceFullPath, useTypescript} = LexConfig.config;\n  const dirName = fileURLToPath(new URL('.', import.meta.url));\n  const nodePath: string = path.resolve(dirName, '../../node_modules');\n\n  // Check for linked modules\n  checkLinkedModules();\n\n  // Clean output directory before we start adding in new files\n  if(remove) {\n    await removeFiles(outputFullPath);\n  }\n\n  // Add tsconfig file if none exists\n  if(useTypescript) {\n    // Make sure tsconfig.json exists\n    LexConfig.checkTypescriptConfig();\n\n    // Check static types with typescript\n    const typescriptPath: string = relativeFilePath('typescript/bin/tsc', nodePath);\n    const typescriptOptions: string[] = config ?\n      ['-p', config] :\n      [\n        '--allowSyntheticDefaultImports',\n        '--baseUrl', sourceFullPath,\n        '--declaration',\n        '--inlineSourceMap',\n        '--jsx', 'react-jsx',\n        '--lib', ['ES5', 'ES6', 'ES2015', 'ES7', 'ES2016', 'ES2017', 'ES2018', 'ESNext', 'DOM'],\n        '--module', 'commonjs',\n        '--moduleResolution', 'node',\n        '--noImplicitReturns',\n        '--noImplicitThis',\n        '--outDir', outputFullPath,\n        '--removeComments',\n        '--resolveJsonModule',\n        '--rootDir', sourceFullPath,\n        '--sourceRoot', sourceFullPath,\n        '--target', 'ES5',\n        '--typeRoots', ['node_modules/@types', 'node_modules/json-d-ts']\n      ];\n\n    const delcarationPresets = [\n      'web'\n    ];\n\n    if(delcarationPresets.includes(preset)) {\n      typescriptOptions.push('--emitDeclarationOnly');\n    }\n\n    // Start type checking spinner\n    spinner.start('Static type checking with Typescript...');\n\n    // Type checking\n    try {\n      await execa(typescriptPath, typescriptOptions, {encoding: 'utf-8'});\n\n      // Stop spinner\n      spinner.succeed('Successfully completed type checking!');\n    } catch(error) {\n      // Display error message\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      if(!quiet) {\n        console.error(error);\n      }\n\n      // Stop spinner\n      spinner.fail('Type checking failed.');\n\n      // Kill Process\n      callback(error.status);\n      return error.status;\n    }\n  }\n\n  // Source files\n  const globOptions = {\n    cwd: sourceFullPath,\n    dot: false,\n    nodir: true,\n    nosort: true\n  };\n  const tsFiles: string[] = glob.sync(`${sourceFullPath}/**/**.ts*`, globOptions);\n  const jsFiles: string[] = glob.sync(`${sourceFullPath}/**/**.js`, globOptions);\n  const sourceFiles: string[] = [...tsFiles, ...jsFiles];\n\n  // ESBuild options\n  const esbuildPath: string = relativeFilePath('esbuild/bin/esbuild', nodePath);\n  const esbuildOptions: string[] = [\n    ...sourceFiles,\n    '--color=true',\n    '--format=cjs',\n    '--loader:.js=js',\n    '--outdir=lib',\n    '--platform=node',\n    '--sourcemap=inline',\n    '--target=node18'\n  ];\n\n  console.log({useTypescript});\n  if(useTypescript) {\n    esbuildOptions.push('--loader:.ts=ts', '--loader:.tsx=tsx');\n  }\n\n  if(watch) {\n    esbuildOptions.push('--watch');\n  }\n\n  // Use PostCSS for CSS files\n  const cssFiles: string[] = getFilesByExt('.css', LexConfig.config);\n\n  if(cssFiles.length) {\n    const postcssPath: string = relativeFilePath('postcss-cli/index.js', nodePath);\n    console.log({nodePath, postcssPath});\n    const dirName = fileURLToPath(new URL('.', import.meta.url));\n    const postcssOptions: string[] = [\n      `${sourceFullPath}/**/**.css`,\n      '--base',\n      sourceFullPath,\n      '--dir',\n      outputFullPath,\n      '--config',\n      path.resolve(dirName, '../../.postcssrc.js')\n    ];\n\n    try {\n      await execa(postcssPath, postcssOptions, {encoding: 'utf-8'});\n      spinner.succeed(`Successfully formatted ${cssFiles.length} css files!`);\n    } catch(error) {\n      // Display error message\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      // Stop spinner\n      spinner.fail('Failed formatting css.');\n\n      // Kill Process\n      callback(error.status);\n      return error.status;\n    }\n  }\n\n  // Copy image files\n  const gifFiles: string[] = getFilesByExt('.gif', LexConfig.config);\n  const jpgFiles: string[] = getFilesByExt('.jpg', LexConfig.config);\n  const pngFiles: string[] = getFilesByExt('.png', LexConfig.config);\n  const svgFiles: string[] = getFilesByExt('.svg', LexConfig.config);\n  const imageFiles: string[] = [...gifFiles, ...jpgFiles, ...pngFiles, ...svgFiles];\n\n  if(imageFiles.length) {\n    try {\n      await copyFiles(imageFiles, 'image', spinner, LexConfig.config);\n    } catch(error) {\n      // Display error message\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      // Stop spinner\n      spinner.fail('Failed to move images to output directory.');\n\n      // Kill Process\n      callback(error.status);\n      return error.status;\n    }\n  }\n\n  // Copy font files\n  const ttfFiles: string[] = getFilesByExt('.ttf', LexConfig.config);\n  const otfFiles: string[] = getFilesByExt('.otf', LexConfig.config);\n  const woffFiles: string[] = getFilesByExt('.woff', LexConfig.config);\n  const woff2Files: string[] = getFilesByExt('.woff2', LexConfig.config);\n  const fontFiles: string[] = [...ttfFiles, ...otfFiles, ...woffFiles, ...woff2Files];\n\n  if(fontFiles.length) {\n    try {\n      await copyFiles(fontFiles, 'font', spinner, LexConfig.config);\n    } catch(error) {\n      // Display error message\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      // Stop spinner\n      spinner.fail('Failed to move fonts to output directory.');\n\n      // Kill Process\n      callback(error.status);\n      return error.status;\n    }\n  }\n\n  // Copy markdown files\n  const mdFiles: string[] = getFilesByExt('.md', LexConfig.config);\n\n  if(mdFiles.length) {\n    try {\n      await copyFiles(mdFiles, 'documents', spinner, LexConfig.config);\n    } catch(error) {\n      // Display error message\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n      // Stop spinner\n      spinner.fail('Failed to move docs to output directory.');\n\n      // Kill Process\n      callback(error.status);\n      return error.status;\n    }\n  }\n\n  // Start compile spinner\n  spinner.start(watch ? 'Watching for changes...' : 'Compiling with ESBuild...');\n\n  try {\n    await execa(esbuildPath, esbuildOptions, {encoding: 'utf-8'});\n\n    // Stop spinner\n    spinner.succeed('Compile completed successfully!');\n  } catch(error) {\n    // Display error message\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n    if(!quiet) {\n      console.error(error);\n    }\n\n    // Stop spinner\n    spinner.fail('Code compiling failed.');\n\n    // Kill Process\n    callback(error.status);\n    return error.status;\n  }\n\n  // Stop process\n  callback(0);\n  return 0;\n};\n"],
  "mappings": "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",
  "names": ["dirName"]
}

|
package/dist/commands/config.js
CHANGED
|
@@ -1,75 +1,43 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
for (var name in all)
|
|
9
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
-
};
|
|
11
|
-
var __copyProps = (to, from, except, desc) => {
|
|
12
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
-
for (let key of __getOwnPropNames(from))
|
|
14
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
15
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
16
|
-
}
|
|
17
|
-
return to;
|
|
18
|
-
};
|
|
19
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
20
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
21
|
-
mod
|
|
22
|
-
));
|
|
23
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
24
|
-
var config_exports = {};
|
|
25
|
-
__export(config_exports, {
|
|
26
|
-
config: () => config
|
|
27
|
-
});
|
|
28
|
-
module.exports = __toCommonJS(config_exports);
|
|
29
|
-
var fs = __toESM(require("fs-extra"));
|
|
30
|
-
var import_startCase = __toESM(require("lodash/startCase"));
|
|
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
|
-
const config = (type, cmd, callback = () => ({})) => {
|
|
1
|
+
import { writeFileSync } from "fs";
|
|
2
|
+
import startCase from "lodash/startCase.js";
|
|
3
|
+
import * as path from "path";
|
|
4
|
+
import { LexConfig } from "../LexConfig.js";
|
|
5
|
+
import { createSpinner } from "../utils/app.js";
|
|
6
|
+
import { log } from "../utils/log.js";
|
|
7
|
+
const config = async (type, cmd, callback = () => ({})) => {
|
|
36
8
|
const { cliName = "Lex", json, quiet } = cmd;
|
|
37
9
|
const validTypes = ["app", "jest", "webpack"];
|
|
38
10
|
if (!validTypes.includes(type)) {
|
|
39
|
-
|
|
11
|
+
log(`
|
|
40
12
|
${cliName} Error: Option for ${type} not found. Configurations only available for app, jest, and webpack.`, "error", quiet);
|
|
41
13
|
callback(1);
|
|
42
14
|
return Promise.resolve(1);
|
|
43
15
|
}
|
|
44
|
-
|
|
45
|
-
|
|
16
|
+
log(`${cliName} generating configuration for ${startCase(type)}...`, "info", quiet);
|
|
17
|
+
LexConfig.parseConfig(cmd);
|
|
46
18
|
let configOptions;
|
|
47
19
|
switch (type) {
|
|
48
20
|
case "app":
|
|
49
|
-
configOptions =
|
|
50
|
-
break;
|
|
51
|
-
case "esbuild":
|
|
52
|
-
configOptions = require("../../esbuildOptions");
|
|
21
|
+
configOptions = LexConfig.config;
|
|
53
22
|
break;
|
|
54
23
|
case "jest":
|
|
55
|
-
configOptions =
|
|
24
|
+
configOptions = import("../../jest.config.lex");
|
|
56
25
|
break;
|
|
57
26
|
case "webpack":
|
|
58
|
-
configOptions =
|
|
27
|
+
configOptions = import("../../webpack.config");
|
|
59
28
|
break;
|
|
60
29
|
}
|
|
61
30
|
const jsonOutput = JSON.stringify(configOptions, null, 2);
|
|
62
31
|
if (json) {
|
|
63
|
-
const spinner =
|
|
32
|
+
const spinner = createSpinner(quiet);
|
|
64
33
|
spinner.start("Creating JSON output...");
|
|
65
|
-
|
|
34
|
+
writeFileSync(json, jsonOutput);
|
|
66
35
|
spinner.succeed(`Successfully saved JSON output to ${path.relative(process.cwd(), json)}`);
|
|
67
36
|
}
|
|
68
37
|
callback(0);
|
|
69
38
|
return Promise.resolve(0);
|
|
70
39
|
};
|
|
71
|
-
|
|
72
|
-
0 && (module.exports = {
|
|
40
|
+
export {
|
|
73
41
|
config
|
|
74
|
-
}
|
|
75
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
42
|
+
};
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2NvbmZpZy50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTgtUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmltcG9ydCB7d3JpdGVGaWxlU3luY30gZnJvbSAnZnMnO1xuaW1wb3J0IHN0YXJ0Q2FzZSBmcm9tICdsb2Rhc2gvc3RhcnRDYXNlLmpzJztcbmltcG9ydCAqIGFzIHBhdGggZnJvbSAncGF0aCc7XG5cbmltcG9ydCB7TGV4Q29uZmlnfSBmcm9tICcuLi9MZXhDb25maWcuanMnO1xuaW1wb3J0IHtjcmVhdGVTcGlubmVyfSBmcm9tICcuLi91dGlscy9hcHAuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uL3V0aWxzL2xvZy5qcyc7XG5cbmV4cG9ydCBjb25zdCBjb25maWcgPSBhc3luYyAodHlwZTogc3RyaW5nLCBjbWQ6IGFueSwgY2FsbGJhY2s6IGFueSA9ICgpID0+ICh7fSkpOiBQcm9taXNlPG51bWJlcj4gPT4ge1xuICBjb25zdCB7Y2xpTmFtZSA9ICdMZXgnLCBqc29uLCBxdWlldH0gPSBjbWQ7XG4gIGNvbnN0IHZhbGlkVHlwZXM6IHN0cmluZ1tdID0gWydhcHAnLCAnamVzdCcsICd3ZWJwYWNrJ107XG5cbiAgaWYoIXZhbGlkVHlwZXMuaW5jbHVkZXModHlwZSkpIHtcbiAgICBsb2coYFxcbiR7Y2xpTmFtZX0gRXJyb3I6IE9wdGlvbiBmb3IgJHt0eXBlfSBub3QgZm91bmQuIENvbmZpZ3VyYXRpb25zIG9ubHkgYXZhaWxhYmxlIGZvciBhcHAsIGplc3QsIGFuZCB3ZWJwYWNrLmAsICdlcnJvcicsIHF1aWV0KTtcbiAgICBjYWxsYmFjaygxKTtcbiAgICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKDEpO1xuICB9XG5cbiAgLy8gRGlzcGxheSBzdGF0dXNcbiAgbG9nKGAke2NsaU5hbWV9IGdlbmVyYXRpbmcgY29uZmlndXJhdGlvbiBmb3IgJHtzdGFydENhc2UodHlwZSl9Li4uYCwgJ2luZm8nLCBxdWlldCk7XG5cbiAgLy8gR2V0IGN1c3RvbSBjb25maWd1cmF0aW9uXG4gIExleENvbmZpZy5wYXJzZUNvbmZpZyhjbWQpO1xuXG4gIGxldCBjb25maWdPcHRpb25zO1xuXG4gIHN3aXRjaCh0eXBlKSB7XG4gICAgY2FzZSAnYXBwJzpcbiAgICAgIGNvbmZpZ09wdGlvbnMgPSBMZXhDb25maWcuY29uZmlnO1xuICAgICAgYnJlYWs7XG4gICAgY2FzZSAnamVzdCc6XG4gICAgICBjb25maWdPcHRpb25zID0gaW1wb3J0KCcuLi8uLi9qZXN0LmNvbmZpZy5sZXgnKTtcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgJ3dlYnBhY2snOlxuICAgICAgY29uZmlnT3B0aW9ucyA9IGltcG9ydCgnLi4vLi4vd2VicGFjay5jb25maWcnKTtcbiAgICAgIGJyZWFrO1xuICB9XG5cbiAgLy8gT3V0cHV0IGNvbmZpZyB0byBjb25zb2xlXG4gIGNvbnN0IGpzb25PdXRwdXQ6IHN0cmluZyA9IEpTT04uc3RyaW5naWZ5KGNvbmZpZ09wdGlvbnMsIG51bGwsIDIpO1xuXG4gIGlmKGpzb24pIHtcbiAgICAvLyBTcGlubmVyXG4gICAgY29uc3Qgc3Bpbm5lciA9IGNyZWF0ZVNwaW5uZXIocXVpZXQpO1xuXG4gICAgLy8gU3RhcnQgc3Bpbm5lclxuICAgIHNwaW5uZXIuc3RhcnQoJ0NyZWF0aW5nIEpTT04gb3V0cHV0Li4uJyk7XG5cbiAgICAvLyBTYXZlIGpzb24gbG9jYWxseVxuICAgIHdyaXRlRmlsZVN5bmMoanNvbiwganNvbk91dHB1dCk7XG5cbiAgICAvLyBTdWNjZXNzIHNwaW5uZXJcbiAgICBzcGlubmVyLnN1Y2NlZWQoYFN1Y2Nlc3NmdWxseSBzYXZlZCBKU09OIG91dHB1dCB0byAke3BhdGgucmVsYXRpdmUocHJvY2Vzcy5jd2QoKSwganNvbil9YCk7XG4gIH1cblxuICBjYWxsYmFjaygwKTtcbiAgcmV0dXJuIFByb21pc2UucmVzb2x2ZSgwKTtcbn07XG4iXSwKICAibWFwcGluZ3MiOiAiQUFJQSxTQUFRLHFCQUFvQjtBQUM1QixPQUFPLGVBQWU7QUFDdEIsWUFBWSxVQUFVO0FBRXRCLFNBQVEsaUJBQWdCO0FBQ3hCLFNBQVEscUJBQW9CO0FBQzVCLFNBQVEsV0FBVTtBQUVYLE1BQU0sU0FBUyxPQUFPLE1BQWMsS0FBVSxXQUFnQixPQUFPLENBQUMsT0FBd0I7QUFDbkcsUUFBTSxFQUFDLFVBQVUsT0FBTyxNQUFNLE1BQUssSUFBSTtBQUN2QyxRQUFNLGFBQXVCLENBQUMsT0FBTyxRQUFRLFNBQVM7QUFFdEQsTUFBRyxDQUFDLFdBQVcsU0FBUyxJQUFJLEdBQUc7QUFDN0IsUUFBSTtBQUFBLEVBQUssNkJBQTZCLDZFQUE2RSxTQUFTLEtBQUs7QUFDakksYUFBUyxDQUFDO0FBQ1YsV0FBTyxRQUFRLFFBQVEsQ0FBQztBQUFBLEVBQzFCO0FBR0EsTUFBSSxHQUFHLHdDQUF3QyxVQUFVLElBQUksUUFBUSxRQUFRLEtBQUs7QUFHbEYsWUFBVSxZQUFZLEdBQUc7QUFFekIsTUFBSTtBQUVKLFVBQU8sTUFBTTtBQUFBLElBQ1gsS0FBSztBQUNILHNCQUFnQixVQUFVO0FBQzFCO0FBQUEsSUFDRixLQUFLO0FBQ0gsc0JBQWdCLE9BQU8sdUJBQXVCO0FBQzlDO0FBQUEsSUFDRixLQUFLO0FBQ0gsc0JBQWdCLE9BQU8sc0JBQXNCO0FBQzdDO0FBQUEsRUFDSjtBQUdBLFFBQU0sYUFBcUIsS0FBSyxVQUFVLGVBQWUsTUFBTSxDQUFDO0FBRWhFLE1BQUcsTUFBTTtBQUVQLFVBQU0sVUFBVSxjQUFjLEtBQUs7QUFHbkMsWUFBUSxNQUFNLHlCQUF5QjtBQUd2QyxrQkFBYyxNQUFNLFVBQVU7QUFHOUIsWUFBUSxRQUFRLHFDQUFxQyxLQUFLLFNBQVMsUUFBUSxJQUFJLEdBQUcsSUFBSSxHQUFHO0FBQUEsRUFDM0Y7QUFFQSxXQUFTLENBQUM7QUFDVixTQUFPLFFBQVEsUUFBUSxDQUFDO0FBQzFCOyIsCiAgIm5hbWVzIjogW10KfQo=
|
package/dist/commands/copy.js
CHANGED
|
@@ -1,57 +1,29 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
6
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
-
var __export = (target, all) => {
|
|
8
|
-
for (var name in all)
|
|
9
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
-
};
|
|
11
|
-
var __copyProps = (to, from, except, desc) => {
|
|
12
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
-
for (let key of __getOwnPropNames(from))
|
|
14
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
15
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
16
|
-
}
|
|
17
|
-
return to;
|
|
18
|
-
};
|
|
19
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
20
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
21
|
-
mod
|
|
22
|
-
));
|
|
23
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
24
|
-
var copy_exports = {};
|
|
25
|
-
__export(copy_exports, {
|
|
26
|
-
copy: () => copy
|
|
27
|
-
});
|
|
28
|
-
module.exports = __toCommonJS(copy_exports);
|
|
29
|
-
var fs = __toESM(require("fs-extra"));
|
|
30
|
-
var import_app = require("../utils/app");
|
|
31
|
-
var import_log = require("../utils/log");
|
|
1
|
+
import { existsSync, lstatSync } from "fs";
|
|
2
|
+
import { copyFileSync, copyFolderRecursiveSync } from "../utils/app.js";
|
|
3
|
+
import { log } from "../utils/log.js";
|
|
32
4
|
const copy = (from, to, cmd, callback = () => ({})) => {
|
|
33
5
|
const { cliName = "Lex", quiet } = cmd;
|
|
34
|
-
|
|
35
|
-
if (!
|
|
36
|
-
|
|
6
|
+
log(`${cliName} copying "${to}"...`, "info", quiet);
|
|
7
|
+
if (!existsSync(from)) {
|
|
8
|
+
log(`
|
|
37
9
|
${cliName} Error: Path not found, "${from}"...`, "error", quiet);
|
|
38
10
|
callback(1);
|
|
39
11
|
return Promise.resolve(1);
|
|
40
12
|
}
|
|
41
|
-
if (
|
|
13
|
+
if (lstatSync(from).isDirectory()) {
|
|
42
14
|
try {
|
|
43
|
-
|
|
15
|
+
copyFolderRecursiveSync(from, to);
|
|
44
16
|
} catch (error) {
|
|
45
|
-
|
|
17
|
+
log(`
|
|
46
18
|
${cliName} Error: Cannot copy "${from}". ${error.message}`, "error", quiet);
|
|
47
19
|
callback(1);
|
|
48
20
|
return Promise.resolve(1);
|
|
49
21
|
}
|
|
50
22
|
} else {
|
|
51
23
|
try {
|
|
52
|
-
|
|
24
|
+
copyFileSync(from, to);
|
|
53
25
|
} catch (error) {
|
|
54
|
-
|
|
26
|
+
log(`
|
|
55
27
|
${cliName} Error: Cannot copy "${from}" ${error.message}`, "error", quiet);
|
|
56
28
|
callback(1);
|
|
57
29
|
return Promise.resolve(1);
|
|
@@ -60,8 +32,7 @@ ${cliName} Error: Cannot copy "${from}" ${error.message}`, "error", quiet);
|
|
|
60
32
|
callback(0);
|
|
61
33
|
return Promise.resolve(0);
|
|
62
34
|
};
|
|
63
|
-
|
|
64
|
-
0 && (module.exports = {
|
|
35
|
+
export {
|
|
65
36
|
copy
|
|
66
|
-
}
|
|
67
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
37
|
+
};
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbW1hbmRzL2NvcHkudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE4LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQge2V4aXN0c1N5bmMsIGxzdGF0U3luY30gZnJvbSAnZnMnO1xuXG5pbXBvcnQge2NvcHlGaWxlU3luYywgY29weUZvbGRlclJlY3Vyc2l2ZVN5bmN9IGZyb20gJy4uL3V0aWxzL2FwcC5qcyc7XG5pbXBvcnQge2xvZ30gZnJvbSAnLi4vdXRpbHMvbG9nLmpzJztcblxuZXhwb3J0IGNvbnN0IGNvcHkgPSAoZnJvbTogc3RyaW5nLCB0bzogc3RyaW5nLCBjbWQ6IGFueSwgY2FsbGJhY2s6IGFueSA9ICgpID0+ICh7fSkpOiBQcm9taXNlPG51bWJlcj4gPT4ge1xuICBjb25zdCB7Y2xpTmFtZSA9ICdMZXgnLCBxdWlldH0gPSBjbWQ7XG5cbiAgLy8gRGlzcGxheSBtZXNzYWdlXG4gIGxvZyhgJHtjbGlOYW1lfSBjb3B5aW5nIFwiJHt0b31cIi4uLmAsICdpbmZvJywgcXVpZXQpO1xuXG4gIGlmKCFleGlzdHNTeW5jKGZyb20pKSB7XG4gICAgbG9nKGBcXG4ke2NsaU5hbWV9IEVycm9yOiBQYXRoIG5vdCBmb3VuZCwgXCIke2Zyb219XCIuLi5gLCAnZXJyb3InLCBxdWlldCk7XG4gICAgY2FsbGJhY2soMSk7XG4gICAgcmV0dXJuIFByb21pc2UucmVzb2x2ZSgxKTtcbiAgfVxuXG4gIGlmKGxzdGF0U3luYyhmcm9tKS5pc0RpcmVjdG9yeSgpKSB7XG4gICAgdHJ5IHtcbiAgICAgIC8vIENvcHkgZGlyZWN0b3J5XG4gICAgICBjb3B5Rm9sZGVyUmVjdXJzaXZlU3luYyhmcm9tLCB0byk7XG4gICAgfSBjYXRjaChlcnJvcikge1xuICAgICAgbG9nKGBcXG4ke2NsaU5hbWV9IEVycm9yOiBDYW5ub3QgY29weSBcIiR7ZnJvbX1cIi4gJHtlcnJvci5tZXNzYWdlfWAsICdlcnJvcicsIHF1aWV0KTtcbiAgICAgIGNhbGxiYWNrKDEpO1xuICAgICAgcmV0dXJuIFByb21pc2UucmVzb2x2ZSgxKTtcbiAgICB9XG4gIH0gZWxzZSB7XG4gICAgdHJ5IHtcbiAgICAgIC8vIENvcHkgZmlsZVxuICAgICAgY29weUZpbGVTeW5jKGZyb20sIHRvKTtcbiAgICB9IGNhdGNoKGVycm9yKSB7XG4gICAgICBsb2coYFxcbiR7Y2xpTmFtZX0gRXJyb3I6IENhbm5vdCBjb3B5IFwiJHtmcm9tfVwiICR7ZXJyb3IubWVzc2FnZX1gLCAnZXJyb3InLCBxdWlldCk7XG4gICAgICBjYWxsYmFjaygxKTtcbiAgICAgIHJldHVybiBQcm9taXNlLnJlc29sdmUoMSk7XG4gICAgfVxuICB9XG5cbiAgY2FsbGJhY2soMCk7XG4gIHJldHVybiBQcm9taXNlLnJlc29sdmUoMCk7XG59O1xuIl0sCiAgIm1hcHBpbmdzIjogIkFBSUEsU0FBUSxZQUFZLGlCQUFnQjtBQUVwQyxTQUFRLGNBQWMsK0JBQThCO0FBQ3BELFNBQVEsV0FBVTtBQUVYLE1BQU0sT0FBTyxDQUFDLE1BQWMsSUFBWSxLQUFVLFdBQWdCLE9BQU8sQ0FBQyxPQUF3QjtBQUN2RyxRQUFNLEVBQUMsVUFBVSxPQUFPLE1BQUssSUFBSTtBQUdqQyxNQUFJLEdBQUcsb0JBQW9CLFVBQVUsUUFBUSxLQUFLO0FBRWxELE1BQUcsQ0FBQyxXQUFXLElBQUksR0FBRztBQUNwQixRQUFJO0FBQUEsRUFBSyxtQ0FBbUMsWUFBWSxTQUFTLEtBQUs7QUFDdEUsYUFBUyxDQUFDO0FBQ1YsV0FBTyxRQUFRLFFBQVEsQ0FBQztBQUFBLEVBQzFCO0FBRUEsTUFBRyxVQUFVLElBQUksRUFBRSxZQUFZLEdBQUc7QUFDaEMsUUFBSTtBQUVGLDhCQUF3QixNQUFNLEVBQUU7QUFBQSxJQUNsQyxTQUFRLE9BQU47QUFDQSxVQUFJO0FBQUEsRUFBSywrQkFBK0IsVUFBVSxNQUFNLFdBQVcsU0FBUyxLQUFLO0FBQ2pGLGVBQVMsQ0FBQztBQUNWLGFBQU8sUUFBUSxRQUFRLENBQUM7QUFBQSxJQUMxQjtBQUFBLEVBQ0YsT0FBTztBQUNMLFFBQUk7QUFFRixtQkFBYSxNQUFNLEVBQUU7QUFBQSxJQUN2QixTQUFRLE9BQU47QUFDQSxVQUFJO0FBQUEsRUFBSywrQkFBK0IsU0FBUyxNQUFNLFdBQVcsU0FBUyxLQUFLO0FBQ2hGLGVBQVMsQ0FBQztBQUNWLGFBQU8sUUFBUSxRQUFRLENBQUM7QUFBQSxJQUMxQjtBQUFBLEVBQ0Y7QUFFQSxXQUFTLENBQUM7QUFDVixTQUFPLFFBQVEsUUFBUSxDQUFDO0FBQzFCOyIsCiAgIm5hbWVzIjogW10KfQo=
|