@modern-js/monorepo-generator 3.0.3 → 3.0.5

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/package.json CHANGED
@@ -11,7 +11,7 @@
11
11
  "modern",
12
12
  "modern.js"
13
13
  ],
14
- "version": "3.0.3",
14
+ "version": "3.0.5",
15
15
  "jsnext:source": "./src/index.ts",
16
16
  "main": "./dist/index.js",
17
17
  "files": [
@@ -27,14 +27,14 @@
27
27
  "@types/node": "^14",
28
28
  "jest": "^27",
29
29
  "typescript": "^4",
30
- "@modern-js/changeset-generator": "3.0.3",
31
- "@modern-js/generator-utils": "3.0.3",
32
- "@modern-js/plugin-i18n": "2.1.0",
33
- "@modern-js/packages-generator": "3.0.3",
34
- "@modern-js/generator-common": "3.0.3",
35
- "@modern-js/base-generator": "3.0.3",
36
- "@scripts/build": "2.1.0",
37
- "@scripts/jest-config": "2.1.0"
30
+ "@modern-js/generator-common": "3.0.5",
31
+ "@modern-js/changeset-generator": "3.0.5",
32
+ "@modern-js/plugin-i18n": "2.3.0",
33
+ "@modern-js/packages-generator": "3.0.5",
34
+ "@modern-js/generator-utils": "3.0.5",
35
+ "@modern-js/base-generator": "3.0.5",
36
+ "@scripts/jest-config": "2.3.0",
37
+ "@scripts/build": "2.3.0"
38
38
  },
39
39
  "sideEffects": false,
40
40
  "publishConfig": {
package/src/index.ts ADDED
@@ -0,0 +1,194 @@
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
+ getMonorepoSchema,
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 ans: Record<string, unknown> = {};
42
+
43
+ if (hasPlugin) {
44
+ await generatorPlugin.installPlugins(Solution.Monorepo, extra);
45
+ const schema = generatorPlugin.getInputSchema();
46
+ const inputValue = generatorPlugin.getInputValue();
47
+ context.config.gitCommitMessage =
48
+ generatorPlugin.getGitMessage() || context.config.gitCommitMessage;
49
+ ans = await appApi.getInputBySchema(
50
+ schema,
51
+ 'formily',
52
+ {
53
+ ...context.config,
54
+ ...inputValue,
55
+ isMonorepo: true,
56
+ },
57
+ {},
58
+ {},
59
+ );
60
+ } else {
61
+ ans = await appApi.getInputBySchemaFunc(getMonorepoSchema, {
62
+ ...context.config,
63
+ isMonorepo: true,
64
+ });
65
+ }
66
+
67
+ const modernVersion = await getModernVersion(
68
+ Solution.Monorepo,
69
+ context.config.registry,
70
+ context.config.distTag,
71
+ );
72
+
73
+ generator.logger.debug(`ans=`, ans);
74
+
75
+ const { packageManager } = ans;
76
+ await appApi.runSubGenerator(
77
+ getGeneratorPath(BaseGenerator, context.config.distTag),
78
+ undefined,
79
+ { ...context.config, hasPlugin: false },
80
+ );
81
+
82
+ await appApi.forgeTemplate(
83
+ 'templates/base-template/**/*',
84
+ undefined,
85
+ (resourceKey: string) =>
86
+ resourceKey
87
+ .replace('templates/base-template/', '')
88
+ .replace('.handlebars', ''),
89
+ { packageManager, modernVersion },
90
+ );
91
+
92
+ if (packageManager === PackageManager.Pnpm) {
93
+ await appApi.forgeTemplate(
94
+ 'templates/pnpm-template/**/*',
95
+ undefined,
96
+ (resourceKey: string) =>
97
+ resourceKey
98
+ .replace('templates/pnpm-template/', '')
99
+ .replace('.handlebars', ''),
100
+ );
101
+ }
102
+
103
+ if (packageManager === PackageManager.Yarn) {
104
+ await appApi.forgeTemplate(
105
+ 'templates/yarn-template/**/*',
106
+ undefined,
107
+ (resourceKey: string) =>
108
+ resourceKey
109
+ .replace('templates/yarn-template/', '')
110
+ .replace('.handlebars', ''),
111
+ );
112
+
113
+ const jsonAPI = new JsonAPI(generator);
114
+
115
+ await jsonAPI.update(
116
+ context.materials.default.get(
117
+ path.join(generator.outputPath, 'package.json'),
118
+ ),
119
+ {
120
+ query: {},
121
+ update: {
122
+ $set: {
123
+ 'scripts.prepare': 'lerna run prepare',
124
+ },
125
+ },
126
+ },
127
+ );
128
+ }
129
+
130
+ await appApi.runSubGenerator(
131
+ getGeneratorPath(ChangesetGenerator, context.config.distTag),
132
+ );
133
+
134
+ const { packagesInfo } = context.config;
135
+ if (packagesInfo && Object.keys(packagesInfo).length > 0) {
136
+ await appApi.runSubGenerator(
137
+ getGeneratorPath(PackagesGenerator, context.config.distTag),
138
+ undefined,
139
+ context.config,
140
+ );
141
+ }
142
+ };
143
+
144
+ export default async (context: GeneratorContext, generator: GeneratorCore) => {
145
+ const appApi = new AppAPI(context, generator);
146
+
147
+ const { locale, successInfo } = context.config;
148
+ commonI18n.changeLanguage({ locale });
149
+ i18n.changeLanguage({ locale });
150
+ appApi.i18n.changeLanguage({ locale });
151
+
152
+ // monorepo 场景下必须使用 pnpm 或者 yarn
153
+ if (!(await canUsePnpm()) && !(await canUseYarn())) {
154
+ generator.logger.warn(i18n.t(localeKeys.environment.yarn_pnpm));
155
+ // eslint-disable-next-line no-process-exit
156
+ process.exit(1);
157
+ }
158
+
159
+ generator.logger.debug(`start run @modern-js/monorepo-generator`);
160
+ generator.logger.debug(`context=${JSON.stringify(context)}`);
161
+ generator.logger.debug(`context.data=${JSON.stringify(context.data)}`);
162
+
163
+ try {
164
+ await handleTemplateFile(context, generator, appApi);
165
+ } catch (e) {
166
+ generator.logger.error(e);
167
+ // eslint-disable-next-line no-process-exit
168
+ process.exit(1);
169
+ }
170
+
171
+ if (context.handleForged) {
172
+ await context.handleForged(
173
+ Solution.Monorepo,
174
+ context,
175
+ context.config.hasPlugin,
176
+ );
177
+ }
178
+
179
+ try {
180
+ await appApi.runGitAndInstall(context.config.gitCommitMessage);
181
+ } catch (e) {
182
+ // eslint-disable-next-line no-process-exit
183
+ process.exit(1);
184
+ }
185
+
186
+ appApi.showSuccessInfo(
187
+ successInfo ||
188
+ i18n.t(localeKeys.success, {
189
+ packageManager: getPackageManagerText(context.config.packageManager),
190
+ }),
191
+ );
192
+
193
+ generator.logger.debug(`forge @modern-js/monorepo-generator succeed `);
194
+ };
@@ -16,7 +16,7 @@
16
16
  "upgrade": "modern upgrade"
17
17
  },
18
18
  "engines": {
19
- "node": ">=14.17.6"
19
+ "node": ">=16.18.1"
20
20
  },
21
21
  "lint-staged": {
22
22
  "*.{ts,tsx}": [