pob 19.1.1 → 20.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.
- package/CHANGELOG.md +22 -0
- package/lib/generators/app/PobAppGenerator.js +120 -120
- package/lib/generators/app/e2e-testing/AppE2ETestingGenerator.js +11 -11
- package/lib/generators/app/ignorePaths.js +24 -24
- package/lib/generators/app/nextjs/AppNextjsGenerator.js +9 -9
- package/lib/generators/app/remix/AppRemixGenerator.js +7 -7
- package/lib/generators/common/babel/CommonBabelGenerator.js +146 -146
- package/lib/generators/common/format-lint/CommonLintGenerator.js +185 -185
- package/lib/generators/common/format-lint/updateEslintConfig.js +14 -15
- package/lib/generators/common/husky/CommonHuskyGenerator.js +44 -44
- package/lib/generators/common/old-dependencies/CommonRemoveOldDependenciesGenerator.js +44 -44
- package/lib/generators/common/release/CommonReleaseGenerator.js +40 -40
- package/lib/generators/common/testing/CommonTestingGenerator.js +190 -190
- package/lib/generators/common/testing/templates/index.js +3 -3
- package/lib/generators/common/transpiler/CommonTranspilerGenerator.js +163 -163
- package/lib/generators/common/typescript/CommonTypescriptGenerator.js +79 -79
- package/lib/generators/common/typescript/templates/tsconfig.js.json.ejs +12 -0
- package/lib/generators/core/ci/CoreCIGenerator.js +72 -72
- package/lib/generators/core/clean/CoreCleanGenerator.js +4 -4
- package/lib/generators/core/editorconfig/CoreEditorConfigGenerator.js +3 -3
- package/lib/generators/core/git/CoreGitGenerator.js +43 -43
- package/lib/generators/core/git/generators/github/CoreGitGithubGenerator.js +43 -43
- package/lib/generators/core/gitignore/CoreGitignoreGenerator.js +19 -19
- package/lib/generators/core/npm/CoreNpmGenerator.js +20 -20
- package/lib/generators/core/package/CorePackageGenerator.js +98 -98
- package/lib/generators/core/package/askName.js +4 -4
- package/lib/generators/core/renovate/CoreRenovateGenerator.js +28 -28
- package/lib/generators/core/sort-package/CoreSortPackageGenerator.js +6 -6
- package/lib/generators/core/vscode/CoreVSCodeGenerator.js +43 -43
- package/lib/generators/core/yarn/CoreYarnGenerator.js +70 -70
- package/lib/generators/lib/PobLibGenerator.js +111 -111
- package/lib/generators/lib/doc/LibDocGenerator.js +45 -45
- package/lib/generators/lib/readme/LibReadmeGenerator.js +21 -21
- package/lib/generators/monorepo/PobMonorepoGenerator.js +89 -89
- package/lib/generators/monorepo/lerna/MonorepoLernaGenerator.js +47 -47
- package/lib/generators/monorepo/typescript/MonorepoTypescriptGenerator.js +38 -38
- package/lib/generators/monorepo/workspaces/MonorepoWorkspacesGenerator.js +57 -57
- package/lib/generators/pob/PobBaseGenerator.js +81 -81
- package/lib/pob-dirname.cjs +1 -1
- package/lib/pob.js +143 -143
- package/lib/utils/dependenciesPackages.cjs +4 -4
- package/lib/utils/ensureJsonFileFormatted.js +5 -5
- package/lib/utils/inMonorepo.js +8 -8
- package/lib/utils/json5.js +1 -1
- package/lib/utils/package.js +43 -43
- package/lib/utils/packagejson.cjs +2 -2
- package/lib/utils/templateUtils.js +1 -1
- package/lib/utils/writeAndFormat.js +9 -10
- package/package.json +10 -10
|
@@ -1,17 +1,17 @@
|
|
|
1
|
-
import Generator from
|
|
2
|
-
import * as packageUtils from
|
|
1
|
+
import Generator from "yeoman-generator";
|
|
2
|
+
import * as packageUtils from "../../../utils/package.js";
|
|
3
3
|
|
|
4
4
|
// run "yarn create remix remix" first, then "cd remix ; pob app"
|
|
5
5
|
export default class AppRemixGenerator extends Generator {
|
|
6
6
|
writing() {
|
|
7
|
-
const pkg = this.fs.readJSON(this.destinationPath(
|
|
7
|
+
const pkg = this.fs.readJSON(this.destinationPath("package.json"));
|
|
8
8
|
|
|
9
9
|
packageUtils.addScripts(pkg, {
|
|
10
|
-
build:
|
|
11
|
-
start:
|
|
12
|
-
|
|
10
|
+
build: "cross-env NODE_ENV=production remix build",
|
|
11
|
+
start: "cross-env NODE_ENV=development remix dev",
|
|
12
|
+
"start:prod": "cross-env NODE_ENV=production remix-serve build",
|
|
13
13
|
});
|
|
14
14
|
|
|
15
|
-
this.fs.writeJSON(this.destinationPath(
|
|
15
|
+
this.fs.writeJSON(this.destinationPath("package.json"), pkg);
|
|
16
16
|
}
|
|
17
17
|
}
|
|
@@ -1,101 +1,101 @@
|
|
|
1
|
-
import semver from
|
|
2
|
-
import Generator from
|
|
3
|
-
import * as packageUtils from
|
|
4
|
-
import { copyAndFormatTpl } from
|
|
1
|
+
import semver from "semver";
|
|
2
|
+
import Generator from "yeoman-generator";
|
|
3
|
+
import * as packageUtils from "../../../utils/package.js";
|
|
4
|
+
import { copyAndFormatTpl } from "../../../utils/writeAndFormat.js";
|
|
5
5
|
|
|
6
6
|
export default class CommonBabelGenerator extends Generator {
|
|
7
7
|
constructor(args, opts) {
|
|
8
8
|
super(args, opts);
|
|
9
9
|
|
|
10
|
-
this.option(
|
|
10
|
+
this.option("updateOnly", {
|
|
11
11
|
type: Boolean,
|
|
12
12
|
required: false,
|
|
13
13
|
default: false,
|
|
14
|
-
desc:
|
|
14
|
+
desc: "Avoid asking questions",
|
|
15
15
|
});
|
|
16
16
|
|
|
17
|
-
this.option(
|
|
17
|
+
this.option("testing", {
|
|
18
18
|
type: Boolean,
|
|
19
19
|
required: false,
|
|
20
20
|
default: false,
|
|
21
|
-
desc:
|
|
21
|
+
desc: "Has testing.",
|
|
22
22
|
});
|
|
23
23
|
|
|
24
|
-
this.option(
|
|
24
|
+
this.option("fromPob", {
|
|
25
25
|
type: Boolean,
|
|
26
26
|
required: false,
|
|
27
27
|
default: false,
|
|
28
28
|
});
|
|
29
29
|
|
|
30
|
-
this.option(
|
|
30
|
+
this.option("isApp", {
|
|
31
31
|
type: Boolean,
|
|
32
32
|
required: false,
|
|
33
33
|
default: false,
|
|
34
34
|
});
|
|
35
35
|
|
|
36
|
-
this.option(
|
|
36
|
+
this.option("isAppLibrary", {
|
|
37
37
|
type: Boolean,
|
|
38
38
|
required: false,
|
|
39
39
|
default: false,
|
|
40
40
|
});
|
|
41
41
|
|
|
42
|
-
this.option(
|
|
42
|
+
this.option("useAppConfig", {
|
|
43
43
|
type: Boolean,
|
|
44
44
|
required: false,
|
|
45
45
|
default: false,
|
|
46
46
|
});
|
|
47
47
|
|
|
48
|
-
this.option(
|
|
48
|
+
this.option("buildDirectory", {
|
|
49
49
|
type: String,
|
|
50
50
|
required: false,
|
|
51
|
-
default:
|
|
51
|
+
default: "dist",
|
|
52
52
|
});
|
|
53
53
|
|
|
54
|
-
this.option(
|
|
54
|
+
this.option("onlyLatestLTS", {
|
|
55
55
|
type: Boolean,
|
|
56
56
|
required: false,
|
|
57
57
|
default: false,
|
|
58
|
-
desc:
|
|
58
|
+
desc: "only latest lts",
|
|
59
59
|
});
|
|
60
60
|
}
|
|
61
61
|
|
|
62
62
|
initializing() {
|
|
63
|
-
const pkg = this.fs.readJSON(this.destinationPath(
|
|
63
|
+
const pkg = this.fs.readJSON(this.destinationPath("package.json"));
|
|
64
64
|
|
|
65
65
|
if (pkg.pob && pkg.pob.babelEnvs) {
|
|
66
66
|
let babelEnvs = pkg.pob.babelEnvs;
|
|
67
67
|
if (
|
|
68
68
|
!babelEnvs.some(
|
|
69
69
|
(env) =>
|
|
70
|
-
env.target ===
|
|
71
|
-
String(env.version) === (this.options.onlyLatestLTS ?
|
|
70
|
+
env.target === "node" &&
|
|
71
|
+
String(env.version) === (this.options.onlyLatestLTS ? "20" : "18")
|
|
72
72
|
) &&
|
|
73
73
|
babelEnvs.some(
|
|
74
74
|
(env) =>
|
|
75
|
-
env.target ===
|
|
76
|
-
([
|
|
77
|
-
(this.options.onlyLatestLTS && String(env.version) ===
|
|
75
|
+
env.target === "node" &&
|
|
76
|
+
(["8", "6", "10", "12", "14", "16"].includes(String(env.version)) ||
|
|
77
|
+
(this.options.onlyLatestLTS && String(env.version) === "18"))
|
|
78
78
|
)
|
|
79
79
|
) {
|
|
80
80
|
babelEnvs.unshift({
|
|
81
|
-
target:
|
|
82
|
-
version: this.options.onlyLatestLTS ?
|
|
81
|
+
target: "node",
|
|
82
|
+
version: this.options.onlyLatestLTS ? "20" : "18",
|
|
83
83
|
omitVersionInFileName: this.options.onlyLatestLTS ? true : undefined,
|
|
84
84
|
});
|
|
85
85
|
}
|
|
86
86
|
babelEnvs = babelEnvs.filter(
|
|
87
87
|
(env) =>
|
|
88
|
-
env.target !==
|
|
89
|
-
env.version >= (this.options.onlyLatestLTS ? 20 : 18)
|
|
88
|
+
env.target !== "node" ||
|
|
89
|
+
env.version >= (this.options.onlyLatestLTS ? 20 : 18)
|
|
90
90
|
);
|
|
91
91
|
|
|
92
92
|
pkg.pob.babelEnvs = babelEnvs;
|
|
93
|
-
this.fs.writeJSON(this.destinationPath(
|
|
93
|
+
this.fs.writeJSON(this.destinationPath("package.json"), pkg);
|
|
94
94
|
}
|
|
95
95
|
}
|
|
96
96
|
|
|
97
97
|
async prompting() {
|
|
98
|
-
const pkg = this.fs.readJSON(this.destinationPath(
|
|
98
|
+
const pkg = this.fs.readJSON(this.destinationPath("package.json"));
|
|
99
99
|
|
|
100
100
|
const hasInitialPkgPob = !!pkg.pob;
|
|
101
101
|
|
|
@@ -104,32 +104,32 @@ export default class CommonBabelGenerator extends Generator {
|
|
|
104
104
|
const babelEnvs = pkg.pob.babelEnvs || [];
|
|
105
105
|
|
|
106
106
|
const targets = [
|
|
107
|
-
babelEnvs.some((env) => env.target ===
|
|
108
|
-
babelEnvs.some((env) => env.target ===
|
|
107
|
+
babelEnvs.some((env) => env.target === "node") ? "node" : undefined,
|
|
108
|
+
babelEnvs.some((env) => env.target === "browser") ? "browser" : undefined,
|
|
109
109
|
].filter(Boolean);
|
|
110
110
|
const nodeVersions = [
|
|
111
111
|
...new Set(
|
|
112
112
|
babelEnvs
|
|
113
|
-
.filter((env) => env.target ===
|
|
113
|
+
.filter((env) => env.target === "node")
|
|
114
114
|
.map((env) => {
|
|
115
115
|
if (
|
|
116
|
-
env.version ===
|
|
117
|
-
env.version ===
|
|
118
|
-
(this.options.onlyLatestLTS && env.version ===
|
|
116
|
+
env.version === "14" ||
|
|
117
|
+
env.version === "16" ||
|
|
118
|
+
(this.options.onlyLatestLTS && env.version === "18")
|
|
119
119
|
) {
|
|
120
|
-
return this.options.onlyLatestLTS ?
|
|
120
|
+
return this.options.onlyLatestLTS ? "20" : "18";
|
|
121
121
|
}
|
|
122
122
|
return env.version;
|
|
123
|
-
})
|
|
123
|
+
})
|
|
124
124
|
),
|
|
125
125
|
];
|
|
126
126
|
const browserVersions = babelEnvs
|
|
127
|
-
.filter((env) => env.target ===
|
|
128
|
-
.map((env) => (env.version === undefined ?
|
|
127
|
+
.filter((env) => env.target === "browser")
|
|
128
|
+
.map((env) => (env.version === undefined ? "supported" : env.version));
|
|
129
129
|
const formats = [
|
|
130
|
-
babelEnvs.some((env) => env.formats?.includes(
|
|
131
|
-
babelEnvs.some((env) => !env.formats || env.formats.includes(
|
|
132
|
-
?
|
|
130
|
+
babelEnvs.some((env) => env.formats?.includes("cjs")) ? "cjs" : undefined,
|
|
131
|
+
babelEnvs.some((env) => !env.formats || env.formats.includes("es"))
|
|
132
|
+
? "es"
|
|
133
133
|
: undefined,
|
|
134
134
|
].filter(Boolean);
|
|
135
135
|
const jsx =
|
|
@@ -142,38 +142,38 @@ export default class CommonBabelGenerator extends Generator {
|
|
|
142
142
|
if (!hasInitialPkgPob || !this.options.updateOnly) {
|
|
143
143
|
babelConfig = await this.prompt([
|
|
144
144
|
{
|
|
145
|
-
type:
|
|
146
|
-
name:
|
|
145
|
+
type: "checkbox",
|
|
146
|
+
name: "targets",
|
|
147
147
|
message:
|
|
148
148
|
"Babel targets: (don't select anything if you don't want babel)",
|
|
149
149
|
default: targets,
|
|
150
150
|
choices: [
|
|
151
151
|
{
|
|
152
|
-
name:
|
|
153
|
-
value:
|
|
152
|
+
name: "Node",
|
|
153
|
+
value: "node",
|
|
154
154
|
},
|
|
155
155
|
{
|
|
156
|
-
name:
|
|
157
|
-
value:
|
|
156
|
+
name: "Browser",
|
|
157
|
+
value: "browser",
|
|
158
158
|
},
|
|
159
159
|
],
|
|
160
160
|
},
|
|
161
161
|
|
|
162
162
|
{
|
|
163
|
-
type:
|
|
164
|
-
name:
|
|
165
|
-
message:
|
|
166
|
-
when: ({ targets = [] }) => targets.includes(
|
|
163
|
+
type: "checkbox",
|
|
164
|
+
name: "nodeVersions",
|
|
165
|
+
message: "Babel node versions: (https://github.com/nodejs/Release)",
|
|
166
|
+
when: ({ targets = [] }) => targets.includes("node"),
|
|
167
167
|
validate: (versions) => versions.length > 0,
|
|
168
168
|
default: nodeVersions,
|
|
169
169
|
choices: [
|
|
170
170
|
{
|
|
171
|
-
name:
|
|
172
|
-
value:
|
|
171
|
+
name: "20 (Active LTS)",
|
|
172
|
+
value: "20",
|
|
173
173
|
},
|
|
174
174
|
{
|
|
175
|
-
name:
|
|
176
|
-
value:
|
|
175
|
+
name: "18 (Maintenance LTS)",
|
|
176
|
+
value: "18",
|
|
177
177
|
},
|
|
178
178
|
],
|
|
179
179
|
},
|
|
@@ -198,23 +198,23 @@ export default class CommonBabelGenerator extends Generator {
|
|
|
198
198
|
// },
|
|
199
199
|
|
|
200
200
|
{
|
|
201
|
-
type:
|
|
202
|
-
name:
|
|
203
|
-
message:
|
|
201
|
+
type: "confirm",
|
|
202
|
+
name: "jsx",
|
|
203
|
+
message: "Enable JSX ?",
|
|
204
204
|
when: ({ targets = [] }) => targets.length > 0,
|
|
205
205
|
default: jsx,
|
|
206
206
|
},
|
|
207
207
|
]);
|
|
208
208
|
}
|
|
209
209
|
|
|
210
|
-
if (babelConfig.targets.includes(
|
|
211
|
-
babelConfig.browserVersions = [
|
|
210
|
+
if (babelConfig.targets.includes("browser")) {
|
|
211
|
+
babelConfig.browserVersions = ["supported"];
|
|
212
212
|
}
|
|
213
213
|
|
|
214
214
|
if (hasInitialPkgPob && pkg.main && !pkg.exports) {
|
|
215
215
|
const result = await this.prompt({
|
|
216
|
-
type:
|
|
217
|
-
name:
|
|
216
|
+
type: "confirm",
|
|
217
|
+
name: "setupExports",
|
|
218
218
|
message: 'Setup package.json "exports" field based on "main" ?',
|
|
219
219
|
});
|
|
220
220
|
|
|
@@ -225,26 +225,26 @@ export default class CommonBabelGenerator extends Generator {
|
|
|
225
225
|
|
|
226
226
|
const newBabelEnvs = [
|
|
227
227
|
...(babelConfig.nodeVersions || []).map((version) => ({
|
|
228
|
-
target:
|
|
228
|
+
target: "node",
|
|
229
229
|
version,
|
|
230
230
|
formats:
|
|
231
|
-
babelConfig.formats && babelConfig.formats.includes(
|
|
231
|
+
babelConfig.formats && babelConfig.formats.includes("cjs")
|
|
232
232
|
? // eslint-disable-next-line unicorn/no-nested-ternary
|
|
233
|
-
version ===
|
|
233
|
+
version === "18" || version === "20"
|
|
234
234
|
? babelConfig.formats
|
|
235
235
|
: undefined
|
|
236
236
|
: undefined,
|
|
237
237
|
omitVersionInFileName:
|
|
238
238
|
// todo add `|| babelConfig.nodeVersions.length === 1` in next major
|
|
239
|
-
version ===
|
|
239
|
+
version === "20" && this.options.onlyLatestLTS ? true : undefined,
|
|
240
240
|
})),
|
|
241
241
|
...(babelConfig.browserVersions || []).map((version) => ({
|
|
242
|
-
target:
|
|
243
|
-
version: version ===
|
|
242
|
+
target: "browser",
|
|
243
|
+
version: version === "supported" ? undefined : version,
|
|
244
244
|
formats:
|
|
245
|
-
babelConfig.formats && babelConfig.formats.includes(
|
|
245
|
+
babelConfig.formats && babelConfig.formats.includes("cjs")
|
|
246
246
|
? // eslint-disable-next-line unicorn/no-nested-ternary
|
|
247
|
-
version ===
|
|
247
|
+
version === "supported"
|
|
248
248
|
? babelConfig.formats
|
|
249
249
|
: undefined
|
|
250
250
|
: undefined,
|
|
@@ -260,7 +260,7 @@ export default class CommonBabelGenerator extends Generator {
|
|
|
260
260
|
}
|
|
261
261
|
} else {
|
|
262
262
|
pkg.pob.babelEnvs = newBabelEnvs;
|
|
263
|
-
pkg.pob.entries = pkg.pob.entries || [
|
|
263
|
+
pkg.pob.entries = pkg.pob.entries || ["index"];
|
|
264
264
|
if (pkg.pob.jsx) {
|
|
265
265
|
pkg.pob.jsx = jsx;
|
|
266
266
|
} else {
|
|
@@ -268,11 +268,11 @@ export default class CommonBabelGenerator extends Generator {
|
|
|
268
268
|
}
|
|
269
269
|
}
|
|
270
270
|
|
|
271
|
-
this.fs.writeJSON(this.destinationPath(
|
|
271
|
+
this.fs.writeJSON(this.destinationPath("package.json"), pkg);
|
|
272
272
|
}
|
|
273
273
|
|
|
274
274
|
configuring() {
|
|
275
|
-
const pkg = this.fs.readJSON(this.destinationPath(
|
|
275
|
+
const pkg = this.fs.readJSON(this.destinationPath("package.json"));
|
|
276
276
|
this.entries = pkg.pob.entries;
|
|
277
277
|
this.babelEnvs = pkg.pob.babelEnvs || [];
|
|
278
278
|
|
|
@@ -301,57 +301,57 @@ export default class CommonBabelGenerator extends Generator {
|
|
|
301
301
|
}
|
|
302
302
|
|
|
303
303
|
default() {
|
|
304
|
-
const pkg = this.fs.readJSON(this.destinationPath(
|
|
304
|
+
const pkg = this.fs.readJSON(this.destinationPath("package.json"));
|
|
305
305
|
const useBabel = this.babelEnvs && this.babelEnvs.length > 0;
|
|
306
306
|
const useTypescript = useBabel || pkg.pob?.typescript;
|
|
307
307
|
const hasTargetNode = useBabel
|
|
308
|
-
? this.babelEnvs.find((env) => env.target ===
|
|
308
|
+
? this.babelEnvs.find((env) => env.target === "node")
|
|
309
309
|
: useTypescript; // todo pkg.pob.typescriptTargets
|
|
310
310
|
const hasTargetBrowser = this.babelEnvs.find(
|
|
311
|
-
(env) => env.target ===
|
|
311
|
+
(env) => env.target === "browser"
|
|
312
312
|
);
|
|
313
313
|
|
|
314
314
|
/* dependencies */
|
|
315
315
|
|
|
316
316
|
packageUtils.addOrRemoveDevDependencies(
|
|
317
317
|
pkg,
|
|
318
|
-
useBabel || (pkg.peerDependencies && pkg.peerDependencies[
|
|
319
|
-
[
|
|
318
|
+
useBabel || (pkg.peerDependencies && pkg.peerDependencies["@babel/core"]),
|
|
319
|
+
["@babel/core"]
|
|
320
320
|
);
|
|
321
|
-
packageUtils.addOrRemoveDevDependencies(pkg, useBabel, [
|
|
321
|
+
packageUtils.addOrRemoveDevDependencies(pkg, useBabel, ["pob-babel"]);
|
|
322
322
|
|
|
323
|
-
if (pkg.dependencies && pkg.dependencies[
|
|
323
|
+
if (pkg.dependencies && pkg.dependencies["pob-babel"]) {
|
|
324
324
|
// update pob-babel in alp-dev
|
|
325
|
-
packageUtils.addDependencies(pkg, [
|
|
325
|
+
packageUtils.addDependencies(pkg, ["pob-babel"], "^");
|
|
326
326
|
}
|
|
327
|
-
if (pkg.dependencies && pkg.dependencies[
|
|
327
|
+
if (pkg.dependencies && pkg.dependencies["@babel/runtime"]) {
|
|
328
328
|
// update pob-babel in alp-dev
|
|
329
|
-
packageUtils.addDependencies(pkg, [
|
|
329
|
+
packageUtils.addDependencies(pkg, ["@babel/runtime"], "^");
|
|
330
330
|
}
|
|
331
331
|
|
|
332
|
-
const isLibraryRollupPlugin = pkg.name.includes(
|
|
332
|
+
const isLibraryRollupPlugin = pkg.name.includes("rollup-plugin");
|
|
333
333
|
|
|
334
334
|
packageUtils.addOrRemoveDevDependencies(
|
|
335
335
|
pkg,
|
|
336
336
|
(useBabel && pkg.pob.jsx) ||
|
|
337
|
-
(pkg.devDependencies?.[
|
|
338
|
-
[
|
|
337
|
+
(pkg.devDependencies?.["@babel/preset-react"] && isLibraryRollupPlugin),
|
|
338
|
+
["@babel/preset-react"]
|
|
339
339
|
);
|
|
340
340
|
|
|
341
341
|
packageUtils.removeDevDependencies(pkg, [
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
342
|
+
"babel-preset-env", // now @babel/preset-env
|
|
343
|
+
"babel-preset-jsdoc",
|
|
344
|
+
"babel-plugin-add-jsdoc-annotations",
|
|
345
|
+
"babel-preset-modern-browsers",
|
|
346
346
|
]);
|
|
347
347
|
|
|
348
348
|
packageUtils.addOrRemoveDevDependencies(
|
|
349
349
|
pkg,
|
|
350
350
|
this.babelEnvs.find(
|
|
351
|
-
(env) => env.target ===
|
|
351
|
+
(env) => env.target === "browser" && env.version === undefined
|
|
352
352
|
) ||
|
|
353
|
-
(pkg.devDependencies?.[
|
|
354
|
-
[
|
|
353
|
+
(pkg.devDependencies?.["@babel/preset-env"] && isLibraryRollupPlugin),
|
|
354
|
+
["@babel/preset-env"]
|
|
355
355
|
);
|
|
356
356
|
|
|
357
357
|
/* engines */
|
|
@@ -361,47 +361,47 @@ export default class CommonBabelGenerator extends Generator {
|
|
|
361
361
|
const minNodeVersion = useBabel
|
|
362
362
|
? Math.min(
|
|
363
363
|
...this.babelEnvs
|
|
364
|
-
.filter((env) => env.target ===
|
|
365
|
-
.map((env) => env.version)
|
|
364
|
+
.filter((env) => env.target === "node")
|
|
365
|
+
.map((env) => env.version)
|
|
366
366
|
)
|
|
367
367
|
: // eslint-disable-next-line unicorn/no-unreadable-iife
|
|
368
|
-
(() => (this.options.onlyLatestLTS ?
|
|
368
|
+
(() => (this.options.onlyLatestLTS ? "20" : "18"))();
|
|
369
369
|
switch (String(minNodeVersion)) {
|
|
370
|
-
case
|
|
371
|
-
case
|
|
372
|
-
case
|
|
373
|
-
case
|
|
374
|
-
case
|
|
375
|
-
pkg.engines.node =
|
|
370
|
+
case "10":
|
|
371
|
+
case "12":
|
|
372
|
+
case "14":
|
|
373
|
+
case "16":
|
|
374
|
+
case "18":
|
|
375
|
+
pkg.engines.node = ">=18.12.0";
|
|
376
376
|
break;
|
|
377
|
-
case
|
|
378
|
-
pkg.engines.node =
|
|
377
|
+
case "20":
|
|
378
|
+
pkg.engines.node = ">=20.9.0";
|
|
379
379
|
break;
|
|
380
380
|
default:
|
|
381
381
|
throw new Error(`Invalid min node version: ${minNodeVersion}`);
|
|
382
382
|
}
|
|
383
383
|
|
|
384
|
-
if (pkg.dependencies && pkg.dependencies[
|
|
385
|
-
pkg.dependencies[
|
|
384
|
+
if (pkg.dependencies && pkg.dependencies["@types/node"]) {
|
|
385
|
+
pkg.dependencies["@types/node"] = `>=${minNodeVersion}.0.0`;
|
|
386
386
|
}
|
|
387
387
|
if (
|
|
388
388
|
pkg.devDependencies &&
|
|
389
|
-
pkg.devDependencies[
|
|
389
|
+
pkg.devDependencies["@types/node"] &&
|
|
390
390
|
!semver.satisfies(
|
|
391
|
-
pkg.devDependencies[
|
|
392
|
-
`>=${minNodeVersion}.0.0
|
|
391
|
+
pkg.devDependencies["@types/node"],
|
|
392
|
+
`>=${minNodeVersion}.0.0`
|
|
393
393
|
)
|
|
394
394
|
) {
|
|
395
|
-
pkg.devDependencies[
|
|
395
|
+
pkg.devDependencies["@types/node"] = `>=${minNodeVersion}.0.0`;
|
|
396
396
|
}
|
|
397
397
|
} else {
|
|
398
|
-
packageUtils.removeDependencies(pkg, [
|
|
399
|
-
packageUtils.removeDevDependencies(pkg, [
|
|
398
|
+
packageUtils.removeDependencies(pkg, ["@types/node"]);
|
|
399
|
+
packageUtils.removeDevDependencies(pkg, ["@types/node"]);
|
|
400
400
|
// Supports oldest current or active LTS version of node
|
|
401
401
|
if (this.options.onlyLatestLTS) {
|
|
402
|
-
pkg.engines.node =
|
|
402
|
+
pkg.engines.node = ">=20.9.0";
|
|
403
403
|
} else {
|
|
404
|
-
pkg.engines.node =
|
|
404
|
+
pkg.engines.node = ">=18.12.0";
|
|
405
405
|
}
|
|
406
406
|
}
|
|
407
407
|
|
|
@@ -414,11 +414,11 @@ export default class CommonBabelGenerator extends Generator {
|
|
|
414
414
|
pkg.browserslist = {
|
|
415
415
|
...(Array.isArray(pkg.browserslist) ? {} : pkg.browserslist),
|
|
416
416
|
production: [
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
417
|
+
"defaults",
|
|
418
|
+
"> 0.2%",
|
|
419
|
+
"not ie < 12",
|
|
420
|
+
"not safari < 10",
|
|
421
|
+
"not ios_saf < 10",
|
|
422
422
|
],
|
|
423
423
|
// configured in babel preset
|
|
424
424
|
// modern: ['defaults and >1% and supports es6-module'],
|
|
@@ -431,72 +431,72 @@ export default class CommonBabelGenerator extends Generator {
|
|
|
431
431
|
pkg.browserslist = {
|
|
432
432
|
...pkg.browserslist,
|
|
433
433
|
production: [
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
434
|
+
"defaults",
|
|
435
|
+
"> 0.2%",
|
|
436
|
+
"not ie < 12",
|
|
437
|
+
"not safari < 10",
|
|
438
|
+
"not ios_saf < 10",
|
|
439
439
|
],
|
|
440
440
|
};
|
|
441
441
|
} else {
|
|
442
442
|
delete pkg.browserslist;
|
|
443
443
|
}
|
|
444
444
|
|
|
445
|
-
this.fs.writeJSON(this.destinationPath(
|
|
445
|
+
this.fs.writeJSON(this.destinationPath("package.json"), pkg);
|
|
446
446
|
}
|
|
447
447
|
|
|
448
448
|
writing() {
|
|
449
|
-
this.fs.delete(
|
|
449
|
+
this.fs.delete("types.js");
|
|
450
450
|
|
|
451
|
-
const pkg = this.fs.readJSON(this.destinationPath(
|
|
451
|
+
const pkg = this.fs.readJSON(this.destinationPath("package.json"));
|
|
452
452
|
|
|
453
453
|
const useBabel = this.babelEnvs && this.babelEnvs.length > 0;
|
|
454
|
-
const entries = pkg.pob.entries || [
|
|
454
|
+
const entries = pkg.pob.entries || ["index"];
|
|
455
455
|
|
|
456
456
|
/* pob-babel config */
|
|
457
457
|
|
|
458
|
-
packageUtils.removeDevDependencies(pkg, [
|
|
459
|
-
packageUtils.removeDependencies(pkg, [
|
|
458
|
+
packageUtils.removeDevDependencies(pkg, ["@rollup/plugin-run"]);
|
|
459
|
+
packageUtils.removeDependencies(pkg, ["alp-rollup-plugin-config"]);
|
|
460
460
|
|
|
461
|
-
this.fs.delete(
|
|
461
|
+
this.fs.delete("rollup.config.js");
|
|
462
462
|
if (useBabel) {
|
|
463
463
|
if (this.options.isApp) {
|
|
464
464
|
copyAndFormatTpl(
|
|
465
465
|
this.fs,
|
|
466
|
-
this.templatePath(
|
|
467
|
-
this.destinationPath(
|
|
466
|
+
this.templatePath("app.rollup.config.mjs.ejs"),
|
|
467
|
+
this.destinationPath("rollup.config.mjs"),
|
|
468
468
|
{
|
|
469
469
|
config: this.options.useAppConfig,
|
|
470
470
|
outDirectory: this.options.buildDirectory,
|
|
471
|
-
enableRun: !this.options.isAppLibrary && entries.includes(
|
|
472
|
-
}
|
|
471
|
+
enableRun: !this.options.isAppLibrary && entries.includes("index"),
|
|
472
|
+
}
|
|
473
473
|
);
|
|
474
474
|
} else {
|
|
475
475
|
copyAndFormatTpl(
|
|
476
476
|
this.fs,
|
|
477
|
-
this.templatePath(
|
|
478
|
-
this.destinationPath(
|
|
477
|
+
this.templatePath("lib.rollup.config.mjs.ejs"),
|
|
478
|
+
this.destinationPath("rollup.config.mjs"),
|
|
479
479
|
{
|
|
480
480
|
outDirectory: this.options.buildDirectory,
|
|
481
|
-
}
|
|
481
|
+
}
|
|
482
482
|
);
|
|
483
483
|
}
|
|
484
484
|
} else if (!pkg.pob.typescript && pkg.pob.rollup !== false) {
|
|
485
|
-
this.fs.delete(
|
|
485
|
+
this.fs.delete("rollup.config.mjs");
|
|
486
486
|
}
|
|
487
487
|
|
|
488
488
|
/* jest babel config */
|
|
489
489
|
|
|
490
|
-
this.fs.delete(
|
|
491
|
-
this.fs.delete(
|
|
492
|
-
this.fs.delete(
|
|
493
|
-
if (this.fs.exists(this.destinationPath(
|
|
490
|
+
this.fs.delete(".babelrc");
|
|
491
|
+
this.fs.delete("babel.config.json");
|
|
492
|
+
this.fs.delete("babel.config.mjs");
|
|
493
|
+
if (this.fs.exists(this.destinationPath("babel.config.js"))) {
|
|
494
494
|
this.fs.move(
|
|
495
|
-
this.destinationPath(
|
|
496
|
-
this.destinationPath(
|
|
495
|
+
this.destinationPath("babel.config.js"),
|
|
496
|
+
this.destinationPath("babel.config.cjs")
|
|
497
497
|
);
|
|
498
498
|
}
|
|
499
499
|
|
|
500
|
-
this.fs.writeJSON(this.destinationPath(
|
|
500
|
+
this.fs.writeJSON(this.destinationPath("package.json"), pkg);
|
|
501
501
|
}
|
|
502
502
|
}
|