@qse/edu-scripts 1.14.18 → 2.0.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.
Files changed (92) hide show
  1. package/CHANGELOG.md +2 -487
  2. package/asset/rspack-dev-server-client.js +534 -0
  3. package/{src/asset → asset}/template/edu-scripts.override.js.tpl +2 -2
  4. package/{lib/asset → asset}/template/tailwind.config.js.tpl +1 -1
  5. package/babel.config.json +6 -0
  6. package/dist/cli.d.mts +1 -0
  7. package/dist/cli.mjs +1426 -0
  8. package/dist/index.d.mts +83 -0
  9. package/dist/index.mjs +13 -0
  10. package/eslint.config.mjs +3 -0
  11. package/{jest.config.js → jest.config.mjs} +8 -4
  12. package/package.json +52 -58
  13. package/src/{auto-refactor.js → auto-refactor.ts} +51 -59
  14. package/src/{build.js → build.ts} +22 -16
  15. package/src/{cli.js → cli.ts} +25 -21
  16. package/src/{commit-dist.js → commit-dist.ts} +28 -21
  17. package/src/config/paths.ts +52 -0
  18. package/src/config/plugins/mock-server/{index.js → index.ts} +30 -41
  19. package/src/config/plugins/{postcss-safe-area.js → postcss-safe-area.ts} +4 -2
  20. package/src/config/{webpackConfig.js → webpackConfig.ts} +152 -126
  21. package/src/config/{webpackDevServerConfig.js → webpackDevServerConfig.ts} +18 -18
  22. package/src/{deploy.js → deploy.ts} +36 -25
  23. package/src/{generator.js → generator.ts} +5 -14
  24. package/src/start.ts +52 -0
  25. package/src/utils/FileSizeReporter.ts +166 -0
  26. package/src/utils/{appConfig.js → appConfig.ts} +5 -4
  27. package/src/utils/{beforeStart.js → beforeStart.ts} +18 -29
  28. package/src/utils/{changeDeployVersion.js → changeDeployVersion.ts} +43 -48
  29. package/src/utils/defineConfig.ts +19 -36
  30. package/src/utils/{exec.js → exec.ts} +3 -3
  31. package/src/utils/{getConfig.js → getConfig.ts} +7 -5
  32. package/src/utils/getOverride.ts +32 -0
  33. package/src/utils/resolveModule.ts +3 -0
  34. package/tsconfig.json +3 -15
  35. package/tsdown.config.ts +5 -0
  36. package/docs/changelog.md +0 -5
  37. package/docs/debug.md +0 -17
  38. package/docs/deploy.md +0 -54
  39. package/docs/faq.md +0 -144
  40. package/docs/feat.md +0 -167
  41. package/docs/grayscale.md +0 -31
  42. package/docs/index.md +0 -5
  43. package/docs/mode.md +0 -42
  44. package/docs/override.md +0 -193
  45. package/docs/refactor-react-16.md +0 -37
  46. package/docs/refactor.md +0 -67
  47. package/docs/static.md +0 -24
  48. package/lib/asset/template/edu-scripts.override.js.tpl +0 -7
  49. package/lib/auto-refactor.js +0 -151
  50. package/lib/build.js +0 -59
  51. package/lib/cli.js +0 -66
  52. package/lib/commit-dist.js +0 -79
  53. package/lib/config/babel.dependencies.js +0 -79
  54. package/lib/config/babel.js +0 -107
  55. package/lib/config/paths.js +0 -36
  56. package/lib/config/plugins/babel-plugin-add-webpack-chunk-name.js +0 -31
  57. package/lib/config/plugins/mock-server/defineMock.d.ts +0 -6
  58. package/lib/config/plugins/mock-server/defineMock.js +0 -31
  59. package/lib/config/plugins/mock-server/index.js +0 -122
  60. package/lib/config/plugins/postcss-safe-area.js +0 -19
  61. package/lib/config/plugins/ws-utils-createSocketURL.js +0 -118
  62. package/lib/config/webpackConfig.js +0 -462
  63. package/lib/config/webpackDevServerConfig.js +0 -72
  64. package/lib/deploy.js +0 -143
  65. package/lib/generator.js +0 -50
  66. package/lib/index.d.ts +0 -2
  67. package/lib/index.js +0 -32
  68. package/lib/start.js +0 -36
  69. package/lib/utils/FileSizeReporter.js +0 -107
  70. package/lib/utils/appConfig.js +0 -32
  71. package/lib/utils/beforeStart.js +0 -62
  72. package/lib/utils/changeDeployVersion.js +0 -89
  73. package/lib/utils/defineConfig.d.ts +0 -93
  74. package/lib/utils/defineConfig.js +0 -31
  75. package/lib/utils/exec.js +0 -7
  76. package/lib/utils/getConfig.js +0 -20
  77. package/lib/utils/getOverride.js +0 -61
  78. package/src/asset/dll/libcommon3-manifest.json +0 -181
  79. package/src/asset/template/edu-app-env.d.ts.tpl +0 -20
  80. package/src/asset/template/tailwind.config.js.tpl +0 -11
  81. package/src/asset/template/tsconfig.json.tpl +0 -24
  82. package/src/config/babel.dependencies.js +0 -66
  83. package/src/config/babel.js +0 -94
  84. package/src/config/paths.js +0 -38
  85. package/src/config/plugins/babel-plugin-add-webpack-chunk-name.js +0 -55
  86. package/src/config/plugins/ws-utils-createSocketURL.js +0 -140
  87. package/src/start.js +0 -44
  88. package/src/utils/FileSizeReporter.js +0 -151
  89. package/src/utils/getOverride.js +0 -48
  90. /package/{lib/asset → asset}/dll/libcommon3-manifest.json +0 -0
  91. /package/{lib/asset → asset}/template/edu-app-env.d.ts.tpl +0 -0
  92. /package/{lib/asset → asset}/template/tsconfig.json.tpl +0 -0
package/lib/generator.js DELETED
@@ -1,50 +0,0 @@
1
- // src/generator.js
2
- var path = require("path");
3
- var fs = require("fs-extra");
4
- var paths = require("./config/paths");
5
- var chalk = require("chalk");
6
- var getTmpPath = (...args) => path.resolve(__dirname, "asset", "template", ...args);
7
- async function generatorOverride() {
8
- if (fs.existsSync(paths.override)) {
9
- console.log(chalk.red(`文件已存在 ${paths.override}`));
10
- process.exit(0);
11
- }
12
- fs.copySync(getTmpPath("edu-scripts.override.js.tpl"), paths.override);
13
- console.log(chalk.green(`成功生成 ${paths.override}`));
14
- }
15
- async function generatorTsconfig() {
16
- if (fs.existsSync(paths.tsconfig)) {
17
- console.log(chalk.red(`文件已存在 ${paths.tsconfig}`));
18
- process.exit(0);
19
- }
20
- fs.copySync(getTmpPath("tsconfig.json.tpl"), paths.tsconfig);
21
- fs.copySync(getTmpPath("edu-app-env.d.ts.tpl"), paths.eduAppEnv);
22
- console.log(chalk.green(`成功生成 ${paths.tsconfig}`));
23
- }
24
- async function generatorTailwind() {
25
- if (fs.existsSync(paths.tailwind)) {
26
- console.log(chalk.red(`文件已存在 ${paths.tailwind}`));
27
- process.exit(0);
28
- }
29
- fs.copySync(getTmpPath("tailwind.config.js.tpl"), paths.tailwind);
30
- const code = ["@tailwind base;", "@tailwind components;", "@tailwind utilities;"].join("\n");
31
- const globalLessFile = paths.resolveApp("src", "index.less");
32
- if (fs.existsSync(globalLessFile)) {
33
- const content = fs.readFileSync(globalLessFile, "utf-8");
34
- if (!content.includes("@tailwind base")) {
35
- fs.writeFileSync(globalLessFile, [code, content].join("\n"));
36
- }
37
- console.log(chalk.green(`成功生成 ${paths.tailwind}`));
38
- return;
39
- }
40
- console.log(
41
- chalk.green(
42
- [`成功生成 ${paths.tailwind}`, "", "添加以下代码到入口处的 index.less 中", code].join("\n")
43
- )
44
- );
45
- }
46
- module.exports = {
47
- override: generatorOverride,
48
- ts: generatorTsconfig,
49
- tailwind: generatorTailwind
50
- };
package/lib/index.d.ts DELETED
@@ -1,2 +0,0 @@
1
- export { defineConfig } from './utils/defineConfig';
2
- export { defineMock } from './config/plugins/mock-server/defineMock';
package/lib/index.js DELETED
@@ -1,32 +0,0 @@
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
-
19
- // src/index.ts
20
- var src_exports = {};
21
- __export(src_exports, {
22
- defineConfig: () => import_defineConfig.defineConfig,
23
- defineMock: () => import_defineMock.defineMock
24
- });
25
- module.exports = __toCommonJS(src_exports);
26
- var import_defineConfig = require("./utils/defineConfig");
27
- var import_defineMock = require("./config/plugins/mock-server/defineMock");
28
- // Annotate the CommonJS export names for ESM import in node:
29
- 0 && (module.exports = {
30
- defineConfig,
31
- defineMock
32
- });
package/lib/start.js DELETED
@@ -1,36 +0,0 @@
1
- // src/start.js
2
- process.env.NODE_ENV = "development";
3
- process.env.BABEL_ENV = "development";
4
- process.env.BROWSERSLIST = "chrome >= 70";
5
- process.env.WEBPACK_DEV_SERVER_BASE_PORT = "3000";
6
- process.on("unhandledRejection", (err) => {
7
- throw err;
8
- });
9
- var WebpackDevServer = require("webpack-dev-server");
10
- var webpack = require("webpack");
11
- var getConfig = require("./utils/getConfig");
12
- var chalk = require("chalk");
13
- module.exports = async function start(args) {
14
- const basePort = process.env.WEBPACK_DEV_SERVER_BASE_PORT;
15
- const port = await WebpackDevServer.getFreePort(args.port || process.env.PORT);
16
- if (!(args.port || process.env.PORT) && +port !== +basePort) {
17
- console.log(chalk.bgYellow(`${basePort} 端口已被占用,现切换到 ${port} 端口运行`));
18
- }
19
- args.port = port;
20
- process.env.PORT = port;
21
- const compiler = webpack(getConfig(args));
22
- const devServer = new WebpackDevServer(compiler.options.devServer, compiler);
23
- devServer.start();
24
- [("SIGINT", "SIGTERM")].forEach(function(sig) {
25
- process.on(sig, function() {
26
- devServer.stop();
27
- process.exit();
28
- });
29
- });
30
- if (process.env.CI !== "true") {
31
- process.stdin.on("end", function() {
32
- devServer.stop();
33
- process.exit();
34
- });
35
- }
36
- };
@@ -1,107 +0,0 @@
1
- // src/utils/FileSizeReporter.js
2
- var fs = require("fs");
3
- var path = require("path");
4
- var chalk = require("chalk");
5
- var filesize = require("filesize");
6
- var recursive = require("recursive-readdir");
7
- var stripAnsi = require("strip-ansi");
8
- var gzipSize = require("gzip-size").sync;
9
- function canReadAsset(asset) {
10
- return /\.(js|css)$/.test(asset) && !/service-worker\.js/.test(asset) && !/precache-manifest\.[0-9a-f]+\.js/.test(asset);
11
- }
12
- function printFileSizesAfterBuild(webpackStats, previousSizeMap, buildFolder, maxBundleGzipSize, maxChunkGzipSize) {
13
- var root = previousSizeMap.root;
14
- var sizes = previousSizeMap.sizes;
15
- var assets = (webpackStats.stats || [webpackStats]).map(
16
- (stats) => stats.toJson({ all: false, assets: true }).assets.filter((asset) => canReadAsset(asset.name)).map((asset) => {
17
- var fileContents = fs.readFileSync(path.join(root, asset.name));
18
- var size = gzipSize(fileContents);
19
- var previousSize = sizes[removeFileNameHash(root, asset.name)];
20
- var difference = getDifferenceLabel(size, previousSize);
21
- return {
22
- folder: path.join(path.basename(buildFolder), path.dirname(asset.name)),
23
- name: path.basename(asset.name),
24
- size,
25
- sizeLabel: filesize(size) + (difference ? " (" + difference + ")" : "")
26
- };
27
- })
28
- ).reduce((single, all) => all.concat(single), []);
29
- if (assets.length === 0)
30
- return;
31
- console.log("\ngzip 后文件大小:\n");
32
- assets.sort((a, b) => b.size - a.size);
33
- var mainAssetIdx = assets.findIndex((asset) => /_\d+\.\d+\.\d+\./.test(asset.name));
34
- assets.unshift(assets.splice(mainAssetIdx, 1)[0]);
35
- var longestSizeLabelLength = Math.max.apply(
36
- null,
37
- assets.map((a) => stripAnsi(a.sizeLabel).length)
38
- );
39
- var suggestBundleSplitting = false;
40
- assets.forEach((asset) => {
41
- var sizeLabel = asset.sizeLabel;
42
- var sizeLength = stripAnsi(sizeLabel).length;
43
- if (sizeLength < longestSizeLabelLength) {
44
- var rightPadding = " ".repeat(longestSizeLabelLength - sizeLength);
45
- sizeLabel += rightPadding;
46
- }
47
- var isMainBundle = /_\d+\.\d+\.\d+\./.test(asset.name);
48
- var maxRecommendedSize = isMainBundle ? maxBundleGzipSize : maxChunkGzipSize;
49
- var isLarge = maxRecommendedSize && asset.size > maxRecommendedSize;
50
- if (isLarge && path.extname(asset.name) === ".js") {
51
- suggestBundleSplitting = true;
52
- }
53
- console.log(
54
- " " + (isLarge ? chalk.yellow(sizeLabel) : sizeLabel) + " " + chalk.dim(asset.folder + path.sep) + chalk.cyan(asset.name)
55
- );
56
- if (isMainBundle) {
57
- console.log("");
58
- }
59
- });
60
- if (suggestBundleSplitting) {
61
- console.log();
62
- console.log(chalk.yellow("产物大小明显大于推荐的大小 (主文件 30k, chunk 1M, 黄色标注为偏大)"));
63
- console.log(chalk.yellow("考虑下使用代码分割解决"));
64
- console.log(chalk.yellow("也可以使用 npm run analyze 命令分析产物"));
65
- }
66
- console.log();
67
- }
68
- function removeFileNameHash(buildFolder, fileName) {
69
- return fileName.replace(buildFolder, "").replace(/\\/g, "/").replace(/\/\d+\.\d+\.\d+\//, "/").replace(/\/?(.*)(\.[0-9a-f]+)(\.chunk)?(\.js|\.css)/, (match, p1, p2, p3, p4) => p1 + p4);
70
- }
71
- function getDifferenceLabel(currentSize, previousSize) {
72
- var FIFTY_KILOBYTES = 1024 * 50;
73
- var difference = currentSize - previousSize;
74
- var fileSize = !Number.isNaN(difference) ? filesize(difference) : 0;
75
- if (difference >= FIFTY_KILOBYTES) {
76
- return chalk.red("+" + fileSize);
77
- } else if (difference < FIFTY_KILOBYTES && difference > 0) {
78
- return chalk.yellow("+" + fileSize);
79
- } else if (difference < 0) {
80
- return chalk.green(fileSize);
81
- } else {
82
- return "";
83
- }
84
- }
85
- function measureFileSizesBeforeBuild(buildFolder) {
86
- return new Promise((resolve) => {
87
- recursive(buildFolder, (err, fileNames) => {
88
- var sizes;
89
- if (!err && fileNames) {
90
- sizes = fileNames.filter(canReadAsset).reduce((memo, fileName) => {
91
- var contents = fs.readFileSync(fileName);
92
- var key = removeFileNameHash(buildFolder, fileName);
93
- memo[key] = gzipSize(contents);
94
- return memo;
95
- }, {});
96
- }
97
- resolve({
98
- root: buildFolder,
99
- sizes: sizes || {}
100
- });
101
- });
102
- });
103
- }
104
- module.exports = {
105
- measureFileSizesBeforeBuild,
106
- printFileSizesAfterBuild
107
- };
@@ -1,32 +0,0 @@
1
- // src/utils/appConfig.js
2
- var paths = require("../config/paths");
3
- var appPkg = require(paths.package);
4
- var fs = require("fs");
5
- var edu = appPkg.edu || {};
6
- if (edu.single || edu.mainProject) {
7
- if (edu.single) {
8
- edu.mode = "single";
9
- delete edu.single;
10
- }
11
- if (edu.mainProject) {
12
- edu.mode = "main";
13
- delete edu.mainProject;
14
- }
15
- fs.writeFileSync(paths.package, JSON.stringify(appPkg, null, 2), "utf-8");
16
- }
17
- var appConfig = {
18
- /** @type {'main'|'single'} */
19
- get mode() {
20
- return edu.mode;
21
- },
22
- get mainProject() {
23
- return this.mode === "main";
24
- },
25
- get single() {
26
- return this.mode === "single";
27
- },
28
- get grayscale() {
29
- return !!edu.grayscale;
30
- }
31
- };
32
- module.exports = appConfig;
@@ -1,62 +0,0 @@
1
- // src/utils/beforeStart.js
2
- var fs = require("fs");
3
- var paths = require("../config/paths");
4
- var chalk = require("chalk");
5
- var pkg = require("../../package.json");
6
- var updateNotifier = require("update-notifier");
7
- var semver = require("semver");
8
- var notifier = updateNotifier({
9
- pkg,
10
- shouldNotifyInNpmScript: true,
11
- updateCheckInterval: 1e3 * 60
12
- // 时刻保持更新
13
- });
14
- if (notifier.update && ["minor", "major"].includes(notifier.update.type)) {
15
- const message = "发现新版本 " + chalk.dim("{currentVersion}") + chalk.reset(" → ") + chalk.green("{latestVersion}") + " \n运行 " + chalk.cyan("{updateCommand}") + " 进行更新\n\n" + chalk.bold.red("请始终保持最新版本\n") + "更新日志: " + chalk.green(`${pkg.homepage}#/changelog`);
16
- notifier.notify({ message });
17
- process.exit(1);
18
- }
19
- var appPkg = require(paths.package);
20
- var appConfig = require("./appConfig");
21
- if (semver.valid(appPkg.version) === null) {
22
- console.log(
23
- chalk.red(`package.version 不符合 semver 规范 https://docs.npmjs.com/about-semantic-versioning`)
24
- );
25
- process.exit(1);
26
- }
27
- switch (appConfig.mode) {
28
- case "main":
29
- console.log(chalk.bgMagenta("正在使用教育主工程模式"));
30
- break;
31
- case "single":
32
- console.log(chalk.bgMagenta("正在使用独立项目模式"));
33
- break;
34
- default:
35
- console.log(chalk.bgMagenta("正在使用教育集成模式"));
36
- break;
37
- }
38
- if (appConfig.grayscale) {
39
- console.log(chalk.bgYellow("正在使用灰度测试模式"));
40
- }
41
- if (!(appConfig.single || appConfig.mainProject)) {
42
- if (fs.existsSync(paths.static)) {
43
- console.log(chalk.bgYellow("教育集成工程不能含有 public/static, 现已自动删除"));
44
- try {
45
- fs.rmSync(paths.static, { recursive: true });
46
- } catch (e) {
47
- }
48
- }
49
- }
50
- if (!fs.existsSync(paths.public) && !process.argv.includes("auto-refactor")) {
51
- console.log(chalk.red(`public 文件夹不存在,请先按文档改造项目`));
52
- console.log(`文档: ${chalk.underline(pkg.homepage)}`);
53
- console.log(`
54
- 使用 ${chalk.green("npx edu-scripts auto-refactor")} 自动改造
55
- `);
56
- process.exit(0);
57
- }
58
- if (appPkg.browserslist) {
59
- console.log(chalk.yellow("已删除 package.json 中 browserslist,该值由内部自动控制\n"));
60
- delete appPkg.browserslist;
61
- fs.writeFileSync(paths.package, JSON.stringify(appPkg, null, 2), "utf-8");
62
- }
@@ -1,89 +0,0 @@
1
- // src/utils/changeDeployVersion.js
2
- var t = require("@babel/types");
3
- var { parse } = require("@babel/parser");
4
- var generate = require("@babel/generator").default;
5
- var traverse = require("@babel/traverse").default;
6
- var { format } = require("prettier");
7
- var TARGET_IDENTIFIER_NAME = "project_apiArr";
8
- var MODULE_IDENTIFIER_NAME = "module";
9
- function changeDeployVersion(code, pkg) {
10
- const { name, version, grayscale } = pkg;
11
- let ast;
12
- try {
13
- ast = parse(code);
14
- } catch (error) {
15
- throw new Error(`代码解析错误: ${error.message}`);
16
- }
17
- const keyName = grayscale ? "grayscale" : "main";
18
- function findTargetDeclarator(ast2) {
19
- let res;
20
- traverse(ast2, {
21
- VariableDeclarator(path) {
22
- if (t.isIdentifier(path.node.id, { name: TARGET_IDENTIFIER_NAME }) && t.isArrayExpression(path.node.init)) {
23
- res = path;
24
- }
25
- }
26
- });
27
- return res;
28
- }
29
- function findModuleObject(path) {
30
- let res;
31
- path.traverse({
32
- ObjectExpression(path2) {
33
- if (path2.node.properties.some(
34
- (node) => t.isIdentifier(node.key, { name: MODULE_IDENTIFIER_NAME }) && t.isLiteral(node.value, { value: name })
35
- )) {
36
- res = path2;
37
- }
38
- }
39
- });
40
- return res;
41
- }
42
- function modifyModuleVersion(path) {
43
- let hasModify = false;
44
- path.traverse({
45
- Property(path2) {
46
- if (path2.node.key.name === keyName) {
47
- path2.node.value.value = version;
48
- hasModify = true;
49
- }
50
- }
51
- });
52
- if (!hasModify) {
53
- path.node.properties.push(t.objectProperty(t.identifier(keyName), t.stringLiteral(version)));
54
- }
55
- }
56
- function deleteModuleComments(path) {
57
- path.traverse({
58
- ObjectExpression(path2) {
59
- delete path2.node.leadingComments;
60
- }
61
- });
62
- }
63
- function addModuleToTarget(path) {
64
- const elements = path.node.init.elements;
65
- elements.splice(
66
- elements.length - 2,
67
- 0,
68
- t.objectExpression([
69
- t.objectProperty(t.identifier(MODULE_IDENTIFIER_NAME), t.stringLiteral(name)),
70
- t.objectProperty(t.identifier(keyName), t.stringLiteral(version))
71
- ])
72
- );
73
- }
74
- const targetPath = findTargetDeclarator(ast);
75
- if (!targetPath)
76
- throw new Error(`ver.js 不合规范,未找到参数 ${TARGET_IDENTIFIER_NAME}`);
77
- const moduleObjPath = findModuleObject(targetPath);
78
- if (moduleObjPath) {
79
- modifyModuleVersion(moduleObjPath);
80
- } else {
81
- addModuleToTarget(targetPath);
82
- }
83
- deleteModuleComments(targetPath);
84
- return format(generate(ast, { minified: true }).code, {
85
- parser: "babel",
86
- printWidth: 120
87
- });
88
- }
89
- module.exports = changeDeployVersion;
@@ -1,93 +0,0 @@
1
- import { Chalk } from 'chalk';
2
- import type { Compiler, Configuration } from 'webpack';
3
- import type { Configuration as DevServerConfiguration, ProxyConfigArray } from 'webpack-dev-server';
4
- export type BabelImportPlugin = [
5
- 'import',
6
- {
7
- libraryName: string;
8
- libraryDirectory: string;
9
- camel2DashComponentName?: boolean;
10
- style?: boolean | 'css' | ((name: string) => string);
11
- },
12
- string
13
- ];
14
- export type BabelConfig = {
15
- presets: any[];
16
- plugins: (string | BabelImportPlugin | any[])[];
17
- };
18
- export type Config = {
19
- webpack?: (config: Configuration) => Configuration | undefined;
20
- devServer?: (config: DevServerConfiguration) => DevServerConfiguration | undefined;
21
- babel?: (config: BabelConfig, type: 'src' | 'node_modules') => any | undefined;
22
- /**
23
- * webpack alias 配置,会与内置 alias 合并
24
- *
25
- * @default
26
- * { '@': './src' }
27
- */
28
- alias?: Record<string, string>;
29
- /**
30
- * webpack externals 配置,会与内置 externals 合并
31
- */
32
- externals?: Record<string, string>;
33
- /**
34
- * terser pure_funcs,esbuild pure 配置,传 [] 可以不清空 console.log
35
- * @default ['console.log']
36
- */
37
- pure_funcs?: string[];
38
- /**
39
- * 编译 node_modules 下文件
40
- *
41
- * @default true
42
- */
43
- transformNodeModules?: boolean;
44
- /**
45
- * 指定压缩工具,esbuild 比 terser 快 20-40 倍,实际压缩率差 10%左右
46
- *
47
- * @default 'esbuild'
48
- */
49
- minify?: boolean | 'terser' | 'esbuild';
50
- /**
51
- * 打包时压缩图片资源
52
- * @default true
53
- */
54
- minifyImage?: boolean;
55
- /** 自定义全局参数 */
56
- define?: Record<string, any>;
57
- /**
58
- * context 填写的顺序很重要,前面的会优先匹配。可以重复定义 /api 来覆盖默认的配置
59
- *
60
- * proxy 会自动删除请求头 referer,避免某些后端校验失败的问题
61
- * @see https://webpack.js.org/configuration/dev-server/#devserverproxy
62
- * @default /api -> /qsxxwapdev/api
63
- * @example { '/api': 'http://localhost:3000' }
64
- * @example [{ context: ['/api'], target: 'http://localhost:3000' }]
65
- */
66
- proxy?: ProxyConfigArray | Record<string, string>;
67
- extraPostCSSPlugins?: any[];
68
- /**
69
- * 开启 mock 功能,会自动加载 mock 文件夹下的文件
70
- *
71
- * 默认情况下自动判断根目录是否存在 mock 文件夹,如果存在则开启 mock 功能。
72
- * 如果设置 false,会关闭 mock 功能
73
- */
74
- mock?: boolean;
75
- /**
76
- * 开发模式启动后只执行一次的函数,用来展示启动后的提示信息,或者自定义的逻辑
77
- */
78
- startup?: (params: {
79
- /** 控制台输出内容 */
80
- logger: ReturnType<Compiler['getInfrastructureLogger']>;
81
- /** 字体颜色相关工具 */
82
- chalk: Chalk;
83
- /** webpack compiler 自定义的时候会用到 */
84
- compiler: Compiler;
85
- }) => void;
86
- /**
87
- * 是否开启装饰器语法支持 只支持 legacy 版本
88
- * @see https://babeljs.io/docs/en/babel-plugin-proposal-decorators
89
- * @default false
90
- */
91
- decorators?: boolean;
92
- };
93
- export declare function defineConfig(config: Config): Config;
@@ -1,31 +0,0 @@
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
-
19
- // src/utils/defineConfig.ts
20
- var defineConfig_exports = {};
21
- __export(defineConfig_exports, {
22
- defineConfig: () => defineConfig
23
- });
24
- module.exports = __toCommonJS(defineConfig_exports);
25
- function defineConfig(config) {
26
- return config;
27
- }
28
- // Annotate the CommonJS export names for ESM import in node:
29
- 0 && (module.exports = {
30
- defineConfig
31
- });
package/lib/utils/exec.js DELETED
@@ -1,7 +0,0 @@
1
- // src/utils/exec.js
2
- var cp = require("child_process");
3
- var exec = (cmd) => {
4
- console.log(`> ${cmd}`);
5
- return cp.execSync(cmd, { stdio: "inherit", encoding: "utf-8" });
6
- };
7
- module.exports = exec;
@@ -1,20 +0,0 @@
1
- // src/utils/getConfig.js
2
- var getWebpackConfig = require("../config/webpackConfig");
3
- var getWebpackDevServerConfig = require("../config/webpackDevServerConfig");
4
- var getOverride = require("./getOverride");
5
- function getConfig(args) {
6
- const override = getOverride();
7
- let webpackConfig = getWebpackConfig(args, override);
8
- if (override.webpack) {
9
- webpackConfig = override.webpack(webpackConfig) || webpackConfig;
10
- }
11
- if (process.env.NODE_ENV === "development") {
12
- let devServerConfig = getWebpackDevServerConfig(args, override);
13
- if (override.devServer) {
14
- devServerConfig = override.devServer(devServerConfig) || devServerConfig;
15
- }
16
- webpackConfig.devServer = devServerConfig;
17
- }
18
- return webpackConfig;
19
- }
20
- module.exports = getConfig;
@@ -1,61 +0,0 @@
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 __copyProps = (to, from, except, desc) => {
8
- if (from && typeof from === "object" || typeof from === "function") {
9
- for (let key of __getOwnPropNames(from))
10
- if (!__hasOwnProp.call(to, key) && key !== except)
11
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
12
- }
13
- return to;
14
- };
15
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
16
- // If the importer is in node compatibility mode or this is not an ESM
17
- // file that has been converted to a CommonJS file using a Babel-
18
- // compatible transform (i.e. "__esModule" has not been set), then set
19
- // "default" to the CommonJS "module.exports" for node compatibility.
20
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
21
- mod
22
- ));
23
-
24
- // src/utils/getOverride.js
25
- var fs = require("fs");
26
- var paths = require("../config/paths");
27
- var defaultOverride = {
28
- transformNodeModules: true,
29
- minifyImage: true,
30
- minify: "esbuild",
31
- proxy: [],
32
- extraPostCSSPlugins: []
33
- };
34
- var override = null;
35
- module.exports = function getOverride() {
36
- if (override)
37
- return override;
38
- override = Object.assign({}, defaultOverride);
39
- if (fs.existsSync(paths.override)) {
40
- const userOverride = require(paths.override);
41
- if (typeof userOverride !== "object")
42
- throw new Error("格式错误,请使用 npx edu g override 生成文件");
43
- Object.assign(override, userOverride);
44
- }
45
- if (override.minify === true)
46
- override.minify = defaultOverride.minify;
47
- if (override.babel) {
48
- const old = override.babel;
49
- override.babel = (config, context) => {
50
- const newConfig = old(config, context) || config;
51
- let plugin = config.plugins.find(
52
- (plugin2) => Array.isArray(plugin2) && /^(babel-plugin-)?import$/.test(plugin2[0])
53
- );
54
- if (plugin) {
55
- plugin[0] = require.resolve("babel-plugin-import");
56
- }
57
- return newConfig;
58
- };
59
- }
60
- return override;
61
- };