@modern-js/monorepo-generator 2.4.16 → 2.4.18

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 (3) hide show
  1. package/dist/index.js +0 -4
  2. package/package.json +12 -12
  3. package/src/index.ts +185 -0
package/dist/index.js CHANGED
@@ -44326,7 +44326,6 @@ var require_downloadPackage = __commonJSMin((exports) => {
44326
44326
  if (response.status !== 200) {
44327
44327
  throw new Error(`download tar package get bad status code: ${response.status}`);
44328
44328
  }
44329
- const contentLength = Number(response.headers["content-length"]);
44330
44329
  const randomId = Math.floor(Math.random() * 1e4);
44331
44330
  const tempTgzFilePath = `${_os.default.tmpdir()}/temp-${randomId}.tgz`;
44332
44331
  const dest = _utils.fs.createWriteStream(tempTgzFilePath);
@@ -44339,9 +44338,6 @@ var require_downloadPackage = __commonJSMin((exports) => {
44339
44338
  resolve();
44340
44339
  });
44341
44340
  });
44342
- if ((await _utils.fs.stat(tempTgzFilePath)).size !== contentLength) {
44343
- throw new Error("download tar package get bad content length");
44344
- }
44345
44341
  await new Promise((resolve, reject) => {
44346
44342
  _utils.fs.createReadStream(tempTgzFilePath).pipe(_tar.default.x({
44347
44343
  strip: 1,
package/package.json CHANGED
@@ -11,7 +11,7 @@
11
11
  "modern",
12
12
  "modern.js"
13
13
  ],
14
- "version": "2.4.16",
14
+ "version": "2.4.18",
15
15
  "jsnext:source": "./src/index.ts",
16
16
  "main": "./dist/index.js",
17
17
  "files": [
@@ -20,21 +20,21 @@
20
20
  ],
21
21
  "devDependencies": {
22
22
  "@babel/runtime": "^7.18.0",
23
- "@modern-js/codesmith": "1.6.3",
24
- "@modern-js/codesmith-api-app": "1.6.3",
25
- "@modern-js/codesmith-api-json": "1.6.3",
23
+ "@modern-js/codesmith": "1.6.4",
24
+ "@modern-js/codesmith-api-app": "1.6.4",
25
+ "@modern-js/codesmith-api-json": "1.6.4",
26
26
  "@types/jest": "^27",
27
27
  "@types/node": "^14",
28
28
  "jest": "^27",
29
29
  "typescript": "^4",
30
- "@modern-js/base-generator": "2.4.16",
31
- "@modern-js/changeset-generator": "2.4.16",
32
- "@modern-js/generator-common": "2.4.16",
33
- "@modern-js/generator-utils": "2.4.16",
34
- "@modern-js/plugin-i18n": "1.22.5",
35
- "@modern-js/packages-generator": "2.4.16",
36
- "@scripts/build": "1.22.5",
37
- "@scripts/jest-config": "1.22.5"
30
+ "@modern-js/base-generator": "2.4.18",
31
+ "@modern-js/changeset-generator": "2.4.18",
32
+ "@modern-js/generator-common": "2.4.18",
33
+ "@modern-js/generator-utils": "2.4.18",
34
+ "@modern-js/plugin-i18n": "1.22.7",
35
+ "@modern-js/packages-generator": "2.4.18",
36
+ "@scripts/build": "1.22.7",
37
+ "@scripts/jest-config": "1.22.7"
38
38
  },
39
39
  "sideEffects": false,
40
40
  "modernConfig": {
package/src/index.ts ADDED
@@ -0,0 +1,185 @@
1
+ import path from 'path';
2
+ import {
3
+ canUsePnpm,
4
+ canUseYarn,
5
+ GeneratorContext,
6
+ GeneratorCore,
7
+ } from '@modern-js/codesmith';
8
+ import { AppAPI } from '@modern-js/codesmith-api-app';
9
+ import { JsonAPI } from '@modern-js/codesmith-api-json';
10
+ import {
11
+ i18n as commonI18n,
12
+ BaseGenerator,
13
+ Solution,
14
+ MonorepoSchema,
15
+ PackageManager,
16
+ ChangesetGenerator,
17
+ PackagesGenerator,
18
+ } from '@modern-js/generator-common';
19
+ import {
20
+ getPackageManagerText,
21
+ getModernVersion,
22
+ } from '@modern-js/generator-utils';
23
+ import { i18n, localeKeys } from './locale';
24
+
25
+ const getGeneratorPath = (generator: string, distTag: string) => {
26
+ if (process.env.CODESMITH_ENV === 'development') {
27
+ return path.dirname(require.resolve(generator));
28
+ } else if (distTag) {
29
+ return `${generator}@${distTag}`;
30
+ }
31
+ return generator;
32
+ };
33
+
34
+ export const handleTemplateFile = async (
35
+ context: GeneratorContext,
36
+ generator: GeneratorCore,
37
+ appApi: AppAPI,
38
+ ) => {
39
+ const { hasPlugin, generatorPlugin, ...extra } = context.config;
40
+
41
+ let schema = MonorepoSchema;
42
+ let inputValue = {};
43
+
44
+ if (hasPlugin) {
45
+ await generatorPlugin.installPlugins(Solution.Monorepo, extra);
46
+ schema = generatorPlugin.getInputSchema(Solution.Monorepo);
47
+ inputValue = generatorPlugin.getInputValue();
48
+ context.config.gitCommitMessage =
49
+ generatorPlugin.getGitMessage() || context.config.gitCommitMessage;
50
+ }
51
+
52
+ const ans = await appApi.getInputBySchema(schema, {
53
+ ...context.config,
54
+ ...inputValue,
55
+ isMonorepo: true,
56
+ });
57
+
58
+ const modernVersion = await getModernVersion(
59
+ Solution.Monorepo,
60
+ context.config.registry,
61
+ context.config.distTag,
62
+ );
63
+
64
+ generator.logger.debug(`ans=`, ans);
65
+
66
+ const { packageManager } = ans;
67
+ await appApi.runSubGenerator(
68
+ getGeneratorPath(BaseGenerator, context.config.distTag),
69
+ undefined,
70
+ { ...context.config, hasPlugin: false },
71
+ );
72
+
73
+ await appApi.forgeTemplate(
74
+ 'templates/base-template/**/*',
75
+ undefined,
76
+ (resourceKey: string) =>
77
+ resourceKey
78
+ .replace('templates/base-template/', '')
79
+ .replace('.handlebars', ''),
80
+ { packageManager, modernVersion },
81
+ );
82
+
83
+ if (packageManager === PackageManager.Pnpm) {
84
+ await appApi.forgeTemplate(
85
+ 'templates/pnpm-template/**/*',
86
+ undefined,
87
+ (resourceKey: string) =>
88
+ resourceKey
89
+ .replace('templates/pnpm-template/', '')
90
+ .replace('.handlebars', ''),
91
+ );
92
+ }
93
+
94
+ if (packageManager === PackageManager.Yarn) {
95
+ await appApi.forgeTemplate(
96
+ 'templates/yarn-template/**/*',
97
+ undefined,
98
+ (resourceKey: string) =>
99
+ resourceKey
100
+ .replace('templates/yarn-template/', '')
101
+ .replace('.handlebars', ''),
102
+ );
103
+
104
+ const jsonAPI = new JsonAPI(generator);
105
+
106
+ await jsonAPI.update(
107
+ context.materials.default.get(
108
+ path.join(generator.outputPath, 'package.json'),
109
+ ),
110
+ {
111
+ query: {},
112
+ update: {
113
+ $set: {
114
+ 'scripts.prepare': 'lerna run prepare',
115
+ },
116
+ },
117
+ },
118
+ );
119
+ }
120
+
121
+ await appApi.runSubGenerator(
122
+ getGeneratorPath(ChangesetGenerator, context.config.distTag),
123
+ );
124
+
125
+ const { packagesInfo } = context.config;
126
+ if (packagesInfo && Object.keys(packagesInfo).length > 0) {
127
+ await appApi.runSubGenerator(
128
+ getGeneratorPath(PackagesGenerator, context.config.distTag),
129
+ undefined,
130
+ context.config,
131
+ );
132
+ }
133
+ };
134
+
135
+ export default async (context: GeneratorContext, generator: GeneratorCore) => {
136
+ const appApi = new AppAPI(context, generator);
137
+
138
+ const { locale, successInfo } = context.config;
139
+ commonI18n.changeLanguage({ locale });
140
+ i18n.changeLanguage({ locale });
141
+ appApi.i18n.changeLanguage({ locale });
142
+
143
+ // monorepo 场景下必须使用 pnpm 或者 yarn
144
+ if (!(await canUsePnpm()) && !(await canUseYarn())) {
145
+ generator.logger.warn(i18n.t(localeKeys.environment.yarn_pnpm));
146
+ // eslint-disable-next-line no-process-exit
147
+ process.exit(1);
148
+ }
149
+
150
+ generator.logger.debug(`start run @modern-js/monorepo-generator`);
151
+ generator.logger.debug(`context=${JSON.stringify(context)}`);
152
+ generator.logger.debug(`context.data=${JSON.stringify(context.data)}`);
153
+
154
+ try {
155
+ await handleTemplateFile(context, generator, appApi);
156
+ } catch (e) {
157
+ generator.logger.error(e);
158
+ // eslint-disable-next-line no-process-exit
159
+ process.exit(1);
160
+ }
161
+
162
+ if (context.handleForged) {
163
+ await context.handleForged(
164
+ Solution.Monorepo,
165
+ context,
166
+ context.config.hasPlugin,
167
+ );
168
+ }
169
+
170
+ try {
171
+ await appApi.runGitAndInstall(context.config.gitCommitMessage);
172
+ } catch (e) {
173
+ // eslint-disable-next-line no-process-exit
174
+ process.exit(1);
175
+ }
176
+
177
+ appApi.showSuccessInfo(
178
+ successInfo ||
179
+ i18n.t(localeKeys.success, {
180
+ packageManager: getPackageManagerText(context.config.packageManager),
181
+ }),
182
+ );
183
+
184
+ generator.logger.debug(`forge @modern-js/monorepo-generator succeed `);
185
+ };