From f3465a9c0760692c39bba97ab72fc21a4b12ff19 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Miroslav=20Jona=C5=A1?= Date: Wed, 21 Dec 2022 16:22:52 +0100 Subject: [PATCH] fix(core): consult root package.json when resolving peer deps on package generation (#13949) --- packages/nx/src/utils/create-package-json.ts | 49 +++++++++++++------- 1 file changed, 33 insertions(+), 16 deletions(-) diff --git a/packages/nx/src/utils/create-package-json.ts b/packages/nx/src/utils/create-package-json.ts index be34fc5482256..28466c31b00ce 100644 --- a/packages/nx/src/utils/create-package-json.ts +++ b/packages/nx/src/utils/create-package-json.ts @@ -56,18 +56,28 @@ export function createPackageJson( }); Object.entries(npmDeps.peerDependencies).forEach(([packageName, version]) => { if (!packageJson.peerDependencies?.[packageName]) { - packageJson.dependencies ??= {}; - packageJson.dependencies[packageName] = version; + if (rootPackageJson.dependencies?.[packageName]) { + packageJson.dependencies ??= {}; + packageJson.dependencies[packageName] = version; + return; + } + + const isOptionalPeer = + npmDeps.peerDependenciesMeta[packageName]?.optional; + if (!isOptionalPeer) { + packageJson.peerDependencies ??= {}; + packageJson.peerDependencies[packageName] = version; + } else if (!options.isProduction) { + // add peer optional dependencies if not in production + packageJson.peerDependencies ??= {}; + packageJson.peerDependencies[packageName] = version; + packageJson.peerDependenciesMeta ??= {}; + packageJson.peerDependenciesMeta[packageName] = { + optional: true, + }; + } } }); - if (options.isProduction && packageJson.peerDependencies) { - const mandatoryPeedDeps = filterOptionalPeerDependencies(packageJson); - if (mandatoryPeedDeps) { - packageJson.peerDependencies = mandatoryPeedDeps; - } else { - delete packageJson.peerDependencies; - } - } packageJson.devDependencies &&= sortObjectByKeys(packageJson.devDependencies); packageJson.dependencies &&= sortObjectByKeys(packageJson.dependencies); @@ -87,7 +97,8 @@ function findAllNpmDeps( list: { dependencies: Record; peerDependencies: Record; - } = { dependencies: {}, peerDependencies: {} }, + peerDependenciesMeta: Record; + } = { dependencies: {}, peerDependencies: {}, peerDependenciesMeta: {} }, seen = new Set() ) { const node = graph.externalNodes[projectName]; @@ -125,6 +136,7 @@ function recursivelyCollectPeerDependencies( list: { dependencies: Record; peerDependencies: Record; + peerDependenciesMeta: Record; }, seen = new Set() ) { @@ -145,13 +157,18 @@ function recursivelyCollectPeerDependencies( .map((dependency) => graph.externalNodes[dependency]) .filter(Boolean) .forEach((node) => { - if ( - !packageJson.peerDependenciesMeta?.[node.data.packageName] - ?.optional && - !seen.has(node.name) - ) { + if (!seen.has(node.name)) { seen.add(node.name); list.peerDependencies[node.data.packageName] = node.data.version; + if ( + packageJson.peerDependenciesMeta && + packageJson.peerDependenciesMeta[node.data.packageName] && + packageJson.peerDependenciesMeta[node.data.packageName].optional + ) { + list.peerDependenciesMeta[node.data.packageName] = { + optional: true, + }; + } recursivelyCollectPeerDependencies(node.name, graph, list, seen); } });