@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.
- package/dist/index.js +0 -4
- package/package.json +12 -12
- 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.
|
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.
|
24
|
-
"@modern-js/codesmith-api-app": "1.6.
|
25
|
-
"@modern-js/codesmith-api-json": "1.6.
|
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.
|
31
|
-
"@modern-js/changeset-generator": "2.4.
|
32
|
-
"@modern-js/generator-common": "2.4.
|
33
|
-
"@modern-js/generator-utils": "2.4.
|
34
|
-
"@modern-js/plugin-i18n": "1.22.
|
35
|
-
"@modern-js/packages-generator": "2.4.
|
36
|
-
"@scripts/build": "1.22.
|
37
|
-
"@scripts/jest-config": "1.22.
|
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
|
+
};
|