@eui/tools 6.1.0 → 6.1.2
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/.version.properties +1 -1
- package/CHANGELOG.md +25 -0
- package/bin/eui-scripts.js +2 -0
- package/bin/scripts/audit-package.js +10 -0
- package/bin/scripts/csdr-upgrade-deps.js +1 -4
- package/package.json +1 -1
- package/sandbox.js +137 -18
- package/scripts/csdr/audit/audit-utils.js +3 -98
- package/scripts/csdr/audit/deps.js +89 -0
- package/scripts/csdr/audit/styles.js +469 -0
- package/scripts/csdr/audit/yarn.js +105 -0
- package/scripts/csdr/config/global.js +17 -17
- package/scripts/csdr/config/packages.js +67 -5
- package/scripts/csdr/config/projects.js +14 -4
- package/scripts/csdr/config/sync.js +0 -1
- package/scripts/csdr/init/global.js +122 -0
- package/scripts/csdr/init/init-utils.js +8 -358
- package/scripts/csdr/init/init.js +19 -12
- package/scripts/csdr/init/packages.js +142 -0
- package/scripts/csdr/init/projects.js +112 -0
- package/scripts/csdr/init/remotes.js +21 -0
- package/scripts/csdr/install/common.js +26 -391
- package/scripts/csdr/install/local-dev.js +54 -50
- package/scripts/csdr/install/packages.js +183 -3
- package/scripts/csdr/install/projects.js +198 -9
- package/scripts/csdr/release/package/ui.js +6 -85
- package/scripts/csdr/sync/sync-utils.js +8 -8
|
@@ -14,6 +14,15 @@ module.exports.getCsdrPackages = () => {
|
|
|
14
14
|
return innerGlobal.getCsdrConfig(false).packages;
|
|
15
15
|
}
|
|
16
16
|
|
|
17
|
+
module.exports.getCsdrPackagesArray = () => {
|
|
18
|
+
const pkgs = this.getCsdrPackages();
|
|
19
|
+
const pkgsArray = Object.keys(this.getCsdrPackages()).map((p) => {
|
|
20
|
+
return pkgs[p];
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
return pkgsArray;
|
|
24
|
+
}
|
|
25
|
+
|
|
17
26
|
module.exports.getCsdrPackagesFull = (flattenChildren = true) => {
|
|
18
27
|
const packages = innerGlobal.getCsdrConfig(flattenChildren).packages;
|
|
19
28
|
const packagesKeys = Object.keys(packages);
|
|
@@ -71,6 +80,11 @@ module.exports.getPackageByNpmPkg = (npmPkg, fromCsdrConfig) => {
|
|
|
71
80
|
return;
|
|
72
81
|
}
|
|
73
82
|
|
|
83
|
+
module.exports.isLocalPackage = (npmPkg) => {
|
|
84
|
+
return getPackages().filter((p) => {
|
|
85
|
+
return p.npmPkg === npmPkg
|
|
86
|
+
})[0] !== null;
|
|
87
|
+
}
|
|
74
88
|
|
|
75
89
|
|
|
76
90
|
module.exports.getPackage = (pkgName, fromCsdrConfig, optional) => {
|
|
@@ -215,10 +229,56 @@ module.exports.getRemotePackages = () => {
|
|
|
215
229
|
})
|
|
216
230
|
}
|
|
217
231
|
|
|
218
|
-
module.exports.getCsdrRemotePackages = () => {
|
|
219
|
-
|
|
232
|
+
module.exports.getCsdrRemotePackages = (euiVersionNumber, hostNameTarget) => {
|
|
233
|
+
|
|
234
|
+
const euiVersionFilterFn = (r) => {
|
|
235
|
+
return r.name.indexOf(`eui${euiVersionNumber}`) > -1;
|
|
236
|
+
}
|
|
237
|
+
|
|
238
|
+
const appTargetFilterFn = (r) => {
|
|
239
|
+
if (r.build) {
|
|
240
|
+
if (!r.build.appTarget || r.build.appTarget === 'MWP_ONLY') {
|
|
241
|
+
if (hostNameTarget === 'my-workplace') {
|
|
242
|
+
return true;
|
|
243
|
+
}
|
|
244
|
+
} else if (r.build.appTarget === 'SEDIA_ONLY') {
|
|
245
|
+
if (hostNameTarget === 'sedia') {
|
|
246
|
+
return true;
|
|
247
|
+
}
|
|
248
|
+
} else if (r.build.appTarget === 'MWP_SEDIA') {
|
|
249
|
+
if (hostNameTarget === 'my-workplace' || hostNameTarget === 'sedia') {
|
|
250
|
+
return true;
|
|
251
|
+
}
|
|
252
|
+
} else {
|
|
253
|
+
return false;
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
}
|
|
257
|
+
|
|
258
|
+
const remotes = this.getCsdrPackagesArray().filter(pkg => {
|
|
220
259
|
return pkg.remote;
|
|
221
260
|
})
|
|
261
|
+
|
|
262
|
+
if (!euiVersionNumber && !hostNameTarget) {
|
|
263
|
+
return remotes;
|
|
264
|
+
|
|
265
|
+
} else if (euiVersionNumber && !hostNameTarget) {
|
|
266
|
+
return remotes.filter((r) => {
|
|
267
|
+
return euiVersionFilterFn(r);
|
|
268
|
+
});
|
|
269
|
+
|
|
270
|
+
} else if (!euiVersionNumber && hostNameTarget) {
|
|
271
|
+
return remotes.filter((r) => {
|
|
272
|
+
return appTargetFilterFn(r);
|
|
273
|
+
});
|
|
274
|
+
|
|
275
|
+
} else {
|
|
276
|
+
return remotes.filter((r) => {
|
|
277
|
+
return euiVersionFilterFn(r);
|
|
278
|
+
}).filter((r) => {
|
|
279
|
+
return appTargetFilterFn(r);
|
|
280
|
+
})
|
|
281
|
+
}
|
|
222
282
|
}
|
|
223
283
|
|
|
224
284
|
module.exports.getBuildablePackagesWithDeps = () => {
|
|
@@ -258,10 +318,11 @@ const getEuiVersionCore = (pkg) => {
|
|
|
258
318
|
let version;
|
|
259
319
|
|
|
260
320
|
const depsCompositeFile = path.join(pkg.paths.pkgRootDirectory, 'dependencies-composite.json');
|
|
261
|
-
tools.logInfo(
|
|
321
|
+
tools.logInfo(`---- Try fetching version from ${depsCompositeFile}`);
|
|
262
322
|
|
|
263
323
|
if (!tools.isFileExists(depsCompositeFile)) {
|
|
264
324
|
tools.logInfo('---- no dependencies-composite.json file found');
|
|
325
|
+
|
|
265
326
|
} else {
|
|
266
327
|
const deps = tools.getJsonFileContent(depsCompositeFile);
|
|
267
328
|
const euiDepsBase = deps['@eui/deps-base'];
|
|
@@ -286,7 +347,7 @@ const getEuiVersionCore = (pkg) => {
|
|
|
286
347
|
|
|
287
348
|
module.exports.getRemoteEuiVersion = (pkg) => {
|
|
288
349
|
if (pkg.parent !== true && pkg.tsPackage !== false) {
|
|
289
|
-
tools.logInfo(`checking ${pkg.name}
|
|
350
|
+
tools.logInfo(`checking --> ${pkg.name} <--`);
|
|
290
351
|
|
|
291
352
|
let version;
|
|
292
353
|
|
|
@@ -310,7 +371,7 @@ module.exports.getRemoteEuiVersion = (pkg) => {
|
|
|
310
371
|
|
|
311
372
|
const getPackageEuiVersion = module.exports.getPackageEuiVersion = (pkg) => {
|
|
312
373
|
if (pkg.parent !== true && pkg.tsPackage !== false) {
|
|
313
|
-
tools.logInfo(`checking ${pkg.name}
|
|
374
|
+
tools.logInfo(`checking --> ${pkg.name} <--`);
|
|
314
375
|
|
|
315
376
|
let version;
|
|
316
377
|
|
|
@@ -362,3 +423,4 @@ module.exports.getTSConfigPath = (resolvePath, packagePath) => {
|
|
|
362
423
|
module.exports.getTSConfigFileName = (tsConfigPath) => {
|
|
363
424
|
return tsConfigPath.split('/')[tsConfigPath.split('/').length - 1];
|
|
364
425
|
}
|
|
426
|
+
|
|
@@ -224,7 +224,7 @@ const getEuiVersionCore = (project) => {
|
|
|
224
224
|
let version;
|
|
225
225
|
|
|
226
226
|
const depsCompositeFile = path.join(project.folder, 'dependencies-composite.json');
|
|
227
|
-
tools.logInfo(
|
|
227
|
+
tools.logInfo(`---- Try fetching version from ${depsCompositeFile}`);
|
|
228
228
|
|
|
229
229
|
if (!tools.isFileExists(depsCompositeFile)) {
|
|
230
230
|
tools.logInfo('---- no dependencies-composite.json file found');
|
|
@@ -253,17 +253,28 @@ const getEuiVersionCore = (project) => {
|
|
|
253
253
|
|
|
254
254
|
|
|
255
255
|
module.exports.getProjectEuiVersion = (project) => {
|
|
256
|
-
|
|
256
|
+
|
|
257
|
+
const version = getEuiVersionCore(project);
|
|
258
|
+
|
|
259
|
+
if (version) {
|
|
260
|
+
tools.logInfo(`---- version found : ${version}\n`);
|
|
261
|
+
} else {
|
|
262
|
+
tools.logInfo('---- version detection skipped');
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
return version;
|
|
257
266
|
}
|
|
258
267
|
|
|
259
268
|
|
|
260
269
|
module.exports.getLocalProjectsEuiVersion = () => {
|
|
261
|
-
tools.logInfo('
|
|
270
|
+
tools.logInfo('Getting local projects installed eUI version...');
|
|
262
271
|
|
|
263
272
|
const prjs = getProjects();
|
|
264
273
|
let versionsFound = [];
|
|
265
274
|
|
|
266
275
|
prjs.forEach((p) => {
|
|
276
|
+
tools.logInfo(`checking ${p.name}`);
|
|
277
|
+
|
|
267
278
|
let version = 'DEFAULT';
|
|
268
279
|
|
|
269
280
|
if (p.build && p.build.euiVersion) {
|
|
@@ -272,7 +283,6 @@ module.exports.getLocalProjectsEuiVersion = () => {
|
|
|
272
283
|
version = getEuiVersionCore(p);
|
|
273
284
|
}
|
|
274
285
|
|
|
275
|
-
tools.logInfo(`checking ${p.name} - version found : ${version}`);
|
|
276
286
|
versionsFound.push(version);
|
|
277
287
|
})
|
|
278
288
|
|
|
@@ -52,7 +52,6 @@ module.exports.run = () => {
|
|
|
52
52
|
}
|
|
53
53
|
})
|
|
54
54
|
|
|
55
|
-
// for projects, we need to take the known rootName based on the folder from the CSDR global config
|
|
56
55
|
hostFolders.forEach((hostFolder) => {
|
|
57
56
|
const csdrPrj = csdrProjects.filter((prj) => {
|
|
58
57
|
return prj.name === hostFolder;
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
// GLOBAL
|
|
4
|
+
const path = require('path');
|
|
5
|
+
|
|
6
|
+
// LOCAL
|
|
7
|
+
const tools = require('../../utils/tools');
|
|
8
|
+
const configUtils = require('../config/config-utils');
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
module.exports.processLocalEuiVersions = () => {
|
|
13
|
+
tools.logTitle('Processing injections for local installed eUI versions if needed');
|
|
14
|
+
|
|
15
|
+
return Promise.resolve()
|
|
16
|
+
.then(() => {
|
|
17
|
+
let euiVersionsLocal = [
|
|
18
|
+
...configUtils.packages.getLocalPackagesEuiVersion(),
|
|
19
|
+
...configUtils.projects.getLocalProjectsEuiVersion(),
|
|
20
|
+
];
|
|
21
|
+
euiVersionsLocal = tools.removeArrayDuplicates(euiVersionsLocal);
|
|
22
|
+
|
|
23
|
+
if (euiVersionsLocal.length > 1) {
|
|
24
|
+
tools.logError('Multiple versions of eUI found in local CSDR...aborting');
|
|
25
|
+
tools.logError(`Ensure tha you've not installed packages that differs in versions, check the log above to identify which one is problematic`);
|
|
26
|
+
console.log(euiVersionsLocal);
|
|
27
|
+
throw new Error('MULTIPLE_LOCAL_EUI_VERSIONS_FOUND');
|
|
28
|
+
|
|
29
|
+
} else {
|
|
30
|
+
tools.logSuccess('eUI version checked OK');
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
const euiVersion = euiVersionsLocal[0];
|
|
34
|
+
|
|
35
|
+
if (!euiVersion || euiVersion === 'DEFAULT') {
|
|
36
|
+
tools.logInfo('Default eUI version found or empty...skipping');
|
|
37
|
+
|
|
38
|
+
} else {
|
|
39
|
+
tools.logInfo(`Processing resolutions replacement for eUI version found : ${euiVersion}`);
|
|
40
|
+
|
|
41
|
+
const rootPackageJsonFile = path.join(process.cwd(), 'package.json');
|
|
42
|
+
const rootPackageJson = require(rootPackageJsonFile);
|
|
43
|
+
|
|
44
|
+
const resolutionsJsonFile = path.join(__dirname, 'resources', euiVersion, 'resolutions.json');
|
|
45
|
+
|
|
46
|
+
if (tools.isFileExists(resolutionsJsonFile)) {
|
|
47
|
+
const resolutionsJson = require(resolutionsJsonFile);
|
|
48
|
+
|
|
49
|
+
tools.logInfo('Injecting resolutions content');
|
|
50
|
+
console.log(resolutionsJson);
|
|
51
|
+
rootPackageJson.resolutions = resolutionsJson;
|
|
52
|
+
|
|
53
|
+
tools.logInfo('Updating root package.json');
|
|
54
|
+
tools.writeJsonFileSync(rootPackageJsonFile, rootPackageJson);
|
|
55
|
+
} else {
|
|
56
|
+
tools.logInfo('Not found...skipping');
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
tools.logInfo(`Processing .browserlistrc replacement for eUI version found : ${euiVersion}`);
|
|
60
|
+
|
|
61
|
+
const blResourcesFile = path.join(__dirname, 'resources', euiVersion, 'browserslistrc');
|
|
62
|
+
const blDestFile = path.join(process.cwd(), '.browserslistrc');
|
|
63
|
+
|
|
64
|
+
if (tools.isFileExists(blResourcesFile)) {
|
|
65
|
+
tools.copy(blResourcesFile, blDestFile);
|
|
66
|
+
} else {
|
|
67
|
+
tools.logInfo('Not found...skipping');
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
tools.logInfo(`Processing yarn.lock replacement for eUI version found : ${euiVersion}`);
|
|
71
|
+
|
|
72
|
+
const yResourcesFile = path.join(__dirname, 'resources', euiVersion, 'yarn.lock');
|
|
73
|
+
const yDestFile = path.join(process.cwd(), 'yarn.lock');
|
|
74
|
+
|
|
75
|
+
if (tools.isFileExists(yResourcesFile)) {
|
|
76
|
+
tools.copy(yResourcesFile, yDestFile);
|
|
77
|
+
} else {
|
|
78
|
+
tools.logInfo('Not found...skipping');
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
})
|
|
82
|
+
.catch((e) => {
|
|
83
|
+
throw e;
|
|
84
|
+
})
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
|
|
88
|
+
module.exports.processResolutionsForNodeVersion = () => {
|
|
89
|
+
return Promise.resolve()
|
|
90
|
+
.then(() => {
|
|
91
|
+
tools.logTitle('Processing injections for detected nodeJS version');
|
|
92
|
+
|
|
93
|
+
let nodeVersion = process.versions.node;
|
|
94
|
+
nodeVersion = `${nodeVersion.split('.')[0]}.x`;
|
|
95
|
+
|
|
96
|
+
const rootPackageJsonFile = path.join(process.cwd(), 'package.json');
|
|
97
|
+
const rootPackageJson = require(rootPackageJsonFile);
|
|
98
|
+
|
|
99
|
+
const nodeVersionResource = `nodejs-${nodeVersion}`;
|
|
100
|
+
|
|
101
|
+
const resolutionsJsonFile = path.join(__dirname, 'resources', nodeVersionResource, 'resolutions.json');
|
|
102
|
+
|
|
103
|
+
tools.logInfo(`Checking nodejsResolution resource for path: ${resolutionsJsonFile}`);
|
|
104
|
+
|
|
105
|
+
if (tools.isFileExists(resolutionsJsonFile)) {
|
|
106
|
+
const resolutionsJson = require(resolutionsJsonFile);
|
|
107
|
+
|
|
108
|
+
tools.logInfo('Injecting resolutions content');
|
|
109
|
+
console.log(resolutionsJson);
|
|
110
|
+
rootPackageJson.resolutions = resolutionsJson;
|
|
111
|
+
|
|
112
|
+
tools.logInfo('Updating root package.json');
|
|
113
|
+
tools.writeJsonFileSync(rootPackageJsonFile, rootPackageJson);
|
|
114
|
+
|
|
115
|
+
} else {
|
|
116
|
+
tools.logInfo('Not found...skipping');
|
|
117
|
+
}
|
|
118
|
+
})
|
|
119
|
+
.catch((e) => {
|
|
120
|
+
throw e;
|
|
121
|
+
})
|
|
122
|
+
}
|
|
@@ -1,361 +1,11 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
// GLOBAL
|
|
4
|
-
const path = require('path');
|
|
5
|
-
|
|
6
|
-
// LOCAL
|
|
7
|
-
const tools = require('../../utils/tools');
|
|
8
|
-
const injectionUtils = require('../../utils/pre-build/injection/injection-utils');
|
|
9
|
-
const configUtils = require('../config/config-utils');
|
|
10
|
-
const gitUtils = require('../../utils/git-utils');
|
|
11
|
-
const installUtils = require('../install/install-utils');
|
|
12
|
-
|
|
13
|
-
// INNER MODULES
|
|
14
|
-
const innerPrompt = require('./prompt');
|
|
15
|
-
const innerMeta = require('./meta');
|
|
16
|
-
const innerRepos = require('./repos');
|
|
17
|
-
|
|
18
3
|
// INNER MODULES - RE-EXPORTS
|
|
19
|
-
module.exports.
|
|
20
|
-
module.exports.
|
|
21
|
-
module.exports.
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
if (pkg.parent) {
|
|
28
|
-
tools.logInfo('Parent package ... skipping import');
|
|
29
|
-
return Promise.resolve();
|
|
30
|
-
|
|
31
|
-
} else {
|
|
32
|
-
if (pkg.tsPackage !== false) {
|
|
33
|
-
return Promise.resolve()
|
|
34
|
-
.then(() => {
|
|
35
|
-
if (!pkg.element) {
|
|
36
|
-
return configUtils.angular.registerAngularPackage(pkg, args.reset);
|
|
37
|
-
} else if (pkg.element) {
|
|
38
|
-
return configUtils.angular.registerAngularProjectDef(pkg, args.reset, true);
|
|
39
|
-
} else {
|
|
40
|
-
return configUtils.angular.registerAngularProjectDef(pkg, args.reset);
|
|
41
|
-
}
|
|
42
|
-
})
|
|
43
|
-
.then(() => {
|
|
44
|
-
if (pkg.pathInclude !== false && !pkg.element) {
|
|
45
|
-
return configUtils.angular.registerModulePaths(pkg, args.reset);
|
|
46
|
-
}
|
|
47
|
-
})
|
|
48
|
-
|
|
49
|
-
.then(() => {
|
|
50
|
-
tools.logSuccess('OK => package imported');
|
|
51
|
-
})
|
|
52
|
-
|
|
53
|
-
.catch((e) => {
|
|
54
|
-
throw e;
|
|
55
|
-
})
|
|
56
|
-
|
|
57
|
-
} else {
|
|
58
|
-
tools.logInfo('Non TS package... skipping registration');
|
|
59
|
-
return Promise.resolve();
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
module.exports.importPackages = (args = {}) => {
|
|
69
|
-
|
|
70
|
-
tools.logTitle('Importing configuration of packages');
|
|
71
|
-
|
|
72
|
-
const packages = configUtils.packages.getPackages();
|
|
73
|
-
|
|
74
|
-
return Promise.resolve()
|
|
75
|
-
.then(() => {
|
|
76
|
-
configUtils.angular.checkConfigFiles(args.reset);
|
|
77
|
-
})
|
|
78
|
-
.then(() => Promise.resolve().then(() => {
|
|
79
|
-
return packages.reduce((promise, pkg) => {
|
|
80
|
-
return promise.then(() => (
|
|
81
|
-
importPackage(pkg, args)
|
|
82
|
-
));
|
|
83
|
-
}, Promise.resolve());
|
|
84
|
-
}))
|
|
85
|
-
|
|
86
|
-
.then(() => {
|
|
87
|
-
tools.logSuccess('OK => all packages successfully imported');
|
|
88
|
-
})
|
|
89
|
-
|
|
90
|
-
.catch((e) => {
|
|
91
|
-
throw e;
|
|
92
|
-
})
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
module.exports.cloneHostPackage = (projectName) => {
|
|
97
|
-
tools.logTitle('Installing host package');
|
|
98
|
-
|
|
99
|
-
let pkg;
|
|
100
|
-
|
|
101
|
-
return Promise.resolve()
|
|
102
|
-
.then(() => {
|
|
103
|
-
const project = configUtils.projects.getProject(projectName);
|
|
104
|
-
|
|
105
|
-
if (!project.hostPackage) {
|
|
106
|
-
tools.logInfo('project hostPackage not defined...skipping');
|
|
107
|
-
|
|
108
|
-
} else {
|
|
109
|
-
pkg = configUtils.packages.getPackageByNpmPkg(project.hostPackage, true);
|
|
110
|
-
if (!pkg) {
|
|
111
|
-
throw new Error('Invalid host package provided / unknown to CSDR config');
|
|
112
|
-
}
|
|
113
|
-
return gitUtils.cloneAndCheckout(pkg.repository, path.join(process.cwd(), 'packages', pkg.name), 'develop');
|
|
114
|
-
}
|
|
115
|
-
})
|
|
116
|
-
|
|
117
|
-
.then(() => {
|
|
118
|
-
const newPackages = [];
|
|
119
|
-
newPackages.push(pkg.name);
|
|
120
|
-
return configUtils.global.updateConfig(null, newPackages);
|
|
121
|
-
})
|
|
122
|
-
|
|
123
|
-
.catch((e) => {
|
|
124
|
-
throw e;
|
|
125
|
-
})
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
module.exports.installHostPackage = (projectName) => {
|
|
130
|
-
tools.logTitle('Installing host package');
|
|
131
|
-
|
|
132
|
-
return Promise.resolve()
|
|
133
|
-
.then(() => {
|
|
134
|
-
const project = configUtils.projects.getProject(projectName);
|
|
135
|
-
|
|
136
|
-
if (!project.hostPackage) {
|
|
137
|
-
tools.logInfo('project hostPackage not defined...skipping');
|
|
138
|
-
|
|
139
|
-
} else {
|
|
140
|
-
const pkg = configUtils.packages.getPackageByNpmPkg(project.hostPackage, true);
|
|
141
|
-
if (!pkg) {
|
|
142
|
-
throw new Error('Invalid host package provided / unknown to CSDR config');
|
|
143
|
-
}
|
|
144
|
-
return installUtils.projects.installHostPackage(project, pkg.npmPkg);
|
|
145
|
-
}
|
|
146
|
-
})
|
|
147
|
-
|
|
148
|
-
.catch((e) => {
|
|
149
|
-
throw e;
|
|
150
|
-
})
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
module.exports.importScripts = () => {
|
|
155
|
-
return Promise.resolve()
|
|
156
|
-
.then(() => {
|
|
157
|
-
tools.logTitle("Init scripts for local projects");
|
|
158
|
-
const projects = configUtils.projects.getProjects();
|
|
159
|
-
|
|
160
|
-
const rootPackageJsonFile = path.join(process.cwd(), 'package.json')
|
|
161
|
-
const rootPackageJson = require(rootPackageJsonFile);
|
|
162
|
-
|
|
163
|
-
projects.forEach((p) => {
|
|
164
|
-
tools.logInfo(`Project : ${p.name}`);
|
|
165
|
-
|
|
166
|
-
const scriptsFile = path.join(process.cwd(), p.folder, 'scripts.json');
|
|
167
|
-
if (!tools.isFileExists(scriptsFile)) {
|
|
168
|
-
tools.logInfo('no scripts.json file found - skipping');
|
|
169
|
-
} else {
|
|
170
|
-
tools.logInfo('Processing scripts.json file');
|
|
171
|
-
const scriptsJson = require(scriptsFile);
|
|
172
|
-
rootPackageJson.scripts = { ...rootPackageJson.scripts, ...scriptsJson };
|
|
173
|
-
}
|
|
174
|
-
});
|
|
175
|
-
|
|
176
|
-
tools.logInfo('Updating root package.json');
|
|
177
|
-
tools.writeJsonFileSync(rootPackageJsonFile, rootPackageJson);
|
|
178
|
-
})
|
|
179
|
-
.catch((e) => {
|
|
180
|
-
throw e;
|
|
181
|
-
})
|
|
182
|
-
}
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
module.exports.importExternalFeatures = () => {
|
|
186
|
-
return Promise.resolve()
|
|
187
|
-
.then(() => {
|
|
188
|
-
tools.logTitle("Import external features for local projects");
|
|
189
|
-
|
|
190
|
-
return configUtils.projects.getProjects().reduce((promise, prj) => {
|
|
191
|
-
return promise.then(() => (
|
|
192
|
-
injectionUtils.externals.injectExternalFeatures(prj)
|
|
193
|
-
));
|
|
194
|
-
}, Promise.resolve());
|
|
195
|
-
})
|
|
196
|
-
.catch((e) => {
|
|
197
|
-
throw e;
|
|
198
|
-
})
|
|
199
|
-
}
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
module.exports.importExternalSources = () => {
|
|
203
|
-
return Promise.resolve()
|
|
204
|
-
.then(() => {
|
|
205
|
-
tools.logTitle("Import external sources for local projects");
|
|
206
|
-
|
|
207
|
-
return configUtils.projects.getProjects().reduce((promise, prj) => {
|
|
208
|
-
return promise.then(() => (
|
|
209
|
-
injectionUtils.externals.injectExternalAppSources(prj)
|
|
210
|
-
));
|
|
211
|
-
}, Promise.resolve());
|
|
212
|
-
})
|
|
213
|
-
.catch((e) => {
|
|
214
|
-
throw e;
|
|
215
|
-
})
|
|
216
|
-
}
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
module.exports.importExternalMock = () => {
|
|
221
|
-
return Promise.resolve()
|
|
222
|
-
.then(() => {
|
|
223
|
-
tools.logTitle("Import external mock for local projects");
|
|
224
|
-
|
|
225
|
-
return configUtils.projects.getProjects().reduce((promise, prj) => {
|
|
226
|
-
return promise.then(() => (
|
|
227
|
-
injectionUtils.externals.injectExternalMock(prj)
|
|
228
|
-
));
|
|
229
|
-
}, Promise.resolve());
|
|
230
|
-
|
|
231
|
-
})
|
|
232
|
-
.catch((e) => {
|
|
233
|
-
throw e;
|
|
234
|
-
})
|
|
235
|
-
}
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
module.exports.importExtraTsConfig = () => {
|
|
240
|
-
tools.logTitle("Init extra ts config for local projects");
|
|
241
|
-
|
|
242
|
-
return Promise.resolve()
|
|
243
|
-
.then(() => {
|
|
244
|
-
|
|
245
|
-
configUtils.projects.getProjects().forEach((p) => {
|
|
246
|
-
tools.logInfo(`Check extra tsconfig for project : ${p.name}`);
|
|
247
|
-
configUtils.angular.registerProjectExtraPaths(p);
|
|
248
|
-
})
|
|
249
|
-
})
|
|
250
|
-
.catch((e) => {
|
|
251
|
-
throw e;
|
|
252
|
-
})
|
|
253
|
-
}
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
module.exports.processLocalEuiVersions = () => {
|
|
257
|
-
tools.logTitle('Processing injections for local installed eUI versions if needed');
|
|
258
|
-
|
|
259
|
-
return Promise.resolve()
|
|
260
|
-
.then(() => {
|
|
261
|
-
let euiVersionsLocal = [
|
|
262
|
-
...configUtils.packages.getLocalPackagesEuiVersion(),
|
|
263
|
-
...configUtils.projects.getLocalProjectsEuiVersion(),
|
|
264
|
-
];
|
|
265
|
-
euiVersionsLocal = tools.removeArrayDuplicates(euiVersionsLocal);
|
|
266
|
-
|
|
267
|
-
if (euiVersionsLocal.length > 1) {
|
|
268
|
-
tools.logError('Multiple versions of eUI found in local CSDR...aborting');
|
|
269
|
-
console.log(euiVersionsLocal);
|
|
270
|
-
throw new Error('MULTIPLE_LOCAL_EUI_VERSIONS_FOUND');
|
|
271
|
-
}
|
|
272
|
-
|
|
273
|
-
const euiVersion = euiVersionsLocal[0];
|
|
274
|
-
|
|
275
|
-
if (!euiVersion || euiVersion === 'DEFAULT') {
|
|
276
|
-
tools.logInfo('Default eUI version found or empty...skipping');
|
|
277
|
-
|
|
278
|
-
} else {
|
|
279
|
-
tools.logInfo(`Processing resolutions replacement for eUI version found : ${euiVersion}`);
|
|
280
|
-
|
|
281
|
-
const rootPackageJsonFile = path.join(process.cwd(), 'package.json');
|
|
282
|
-
const rootPackageJson = require(rootPackageJsonFile);
|
|
283
|
-
|
|
284
|
-
const resolutionsJsonFile = path.join(__dirname, 'resources', euiVersion, 'resolutions.json');
|
|
285
|
-
|
|
286
|
-
if (tools.isFileExists(resolutionsJsonFile)) {
|
|
287
|
-
const resolutionsJson = require(resolutionsJsonFile);
|
|
288
|
-
|
|
289
|
-
tools.logInfo('Injecting resolutions content');
|
|
290
|
-
console.log(resolutionsJson);
|
|
291
|
-
rootPackageJson.resolutions = resolutionsJson;
|
|
292
|
-
|
|
293
|
-
tools.logInfo('Updating root package.json');
|
|
294
|
-
tools.writeJsonFileSync(rootPackageJsonFile, rootPackageJson);
|
|
295
|
-
} else {
|
|
296
|
-
tools.logWarning('Not found...skipping');
|
|
297
|
-
}
|
|
298
|
-
|
|
299
|
-
tools.logInfo(`Processing .browserlistrc replacement for eUI version found : ${euiVersion}`);
|
|
300
|
-
|
|
301
|
-
const blResourcesFile = path.join(__dirname, 'resources', euiVersion, 'browserslistrc');
|
|
302
|
-
const blDestFile = path.join(process.cwd(), '.browserslistrc');
|
|
303
|
-
|
|
304
|
-
if (tools.isFileExists(blResourcesFile)) {
|
|
305
|
-
tools.copy(blResourcesFile, blDestFile);
|
|
306
|
-
} else {
|
|
307
|
-
tools.logWarning('Not found...skipping');
|
|
308
|
-
}
|
|
309
|
-
|
|
310
|
-
tools.logInfo(`Processing yarn.lock replacement for eUI version found : ${euiVersion}`);
|
|
311
|
-
|
|
312
|
-
const yResourcesFile = path.join(__dirname, 'resources', euiVersion, 'yarn.lock');
|
|
313
|
-
const yDestFile = path.join(process.cwd(), 'yarn.lock');
|
|
314
|
-
|
|
315
|
-
if (tools.isFileExists(yResourcesFile)) {
|
|
316
|
-
tools.copy(yResourcesFile, yDestFile);
|
|
317
|
-
} else {
|
|
318
|
-
tools.logWarning('Not found...skipping');
|
|
319
|
-
}
|
|
320
|
-
}
|
|
321
|
-
})
|
|
322
|
-
.catch((e) => {
|
|
323
|
-
throw e;
|
|
324
|
-
})
|
|
325
|
-
}
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
module.exports.processResolutionsForNodeVersion = () => {
|
|
329
|
-
return Promise.resolve()
|
|
330
|
-
.then(() => {
|
|
331
|
-
tools.logTitle('Processing injections for detected nodeJS version');
|
|
332
|
-
|
|
333
|
-
let nodeVersion = process.versions.node;
|
|
334
|
-
nodeVersion = `${nodeVersion.split('.')[0]}.x`;
|
|
335
|
-
|
|
336
|
-
const rootPackageJsonFile = path.join(process.cwd(), 'package.json');
|
|
337
|
-
const rootPackageJson = require(rootPackageJsonFile);
|
|
338
|
-
|
|
339
|
-
const nodeVersionResource = `nodejs-${nodeVersion}`;
|
|
340
|
-
|
|
341
|
-
const resolutionsJsonFile = path.join(__dirname, 'resources', nodeVersionResource, 'resolutions.json');
|
|
342
|
-
|
|
343
|
-
tools.logInfo(`Checking nodejsResolution resource for path: ${resolutionsJsonFile}`);
|
|
344
|
-
|
|
345
|
-
if (tools.isFileExists(resolutionsJsonFile)) {
|
|
346
|
-
const resolutionsJson = require(resolutionsJsonFile);
|
|
347
|
-
|
|
348
|
-
tools.logInfo('Injecting resolutions content');
|
|
349
|
-
console.log(resolutionsJson);
|
|
350
|
-
rootPackageJson.resolutions = resolutionsJson;
|
|
351
|
-
|
|
352
|
-
tools.logInfo('Updating root package.json');
|
|
353
|
-
tools.writeJsonFileSync(rootPackageJsonFile, rootPackageJson);
|
|
354
|
-
} else {
|
|
355
|
-
tools.logWarning('Not found...skipping');
|
|
356
|
-
}
|
|
357
|
-
})
|
|
358
|
-
.catch((e) => {
|
|
359
|
-
throw e;
|
|
360
|
-
})
|
|
361
|
-
}
|
|
4
|
+
module.exports.global = require('./global');
|
|
5
|
+
module.exports.init = require('./init');
|
|
6
|
+
module.exports.meta = require('./meta');
|
|
7
|
+
module.exports.packages = require('./packages');
|
|
8
|
+
module.exports.projects = require('./projects');
|
|
9
|
+
module.exports.prompt = require('./prompt');
|
|
10
|
+
module.exports.remotes = require('./remotes');
|
|
11
|
+
module.exports.repos = require('./repos');
|