-
Notifications
You must be signed in to change notification settings - Fork 935
Description
Description
config ignores peerDependencies and instead reads devDependencies:
cli/packages/cli-config/src/findDependencies.ts
Lines 18 to 21 in 33646ef
| const deps = [ | |
| ...Object.keys(pjson.dependencies || {}), | |
| ...Object.keys(pjson.devDependencies || {}), | |
| ]; |
This leads to errors in react-native-windows autolinking (and possibly in other scenarios) where dependencies are only declared under peerDependencies and not devDependencies, for instance in @react-native-webapis/web-storage we have the following:
{
"peerDependencies": {
"@callstack/react-native-visionos": ">=0.73",
"react": ">=18.2.0",
"react-native": ">=0.72",
"react-native-macos": ">=0.72",
"react-native-windows": ">=0.72"
},
"peerDependenciesMeta": {
"@callstack/react-native-visionos": {
"optional": true
},
"react-native-macos": {
"optional": true
},
"react-native-windows": {
"optional": true
}
},
"devDependencies": {
"react-native": "^0.73.0"
}
}In this case, config outputs:
"platforms": {
"ios": {},
"android": {}
},If I add react-native-windows to devDependencies, config outputs:
"platforms": {
"ios": {},
"android": {},
"windows": {
"npmPackageName": "react-native-windows"
}
},In my opinion, the correct fix should be to replace devDependencies with peerDependencies, but I don't know if this will break current scenarios so we should probably keep it as is and just add peerDependencies to the list in findDependencies.ts.
Reproducible Demo
In any project, you can run the following:
yarn add @react-native-webapis/web-storage@0.2.6
cd node_modules/@react-native-webapis/web-storage
yarn react-native config