andylamax
12/01/2023, 7:57 PMkotlin-wrappers:kotlin-react-corekotlin-reactpackage.jsonkotlin-wrappers:kotlin-reactkotlin-wrappers:kotlin-react-corereactpeerDependencykotlin-wrappers:kotlin-reactkotlin-wrappers:kkotlin-react-corereactturansky
12/01/2023, 8:58 PMpackage.jsonandylamax
12/02/2023, 12:17 AMjsMainApi(npm("react"))jsMainApi(npmPeer("react"))turansky
12/02/2023, 2:44 AMbe the best solution and benefit all consumers???And as result we will receive random React version in application 😞 It's not what I expect.
What if you will declare peer dependency in library? Will it work?Copy codejsMainApi(npmPeer("react"))
andylamax
12/02/2023, 8:03 AMAnd as a result we will receive random react version
this can be mitigated by explicitly adding the react dependency you need to use your final appllication (not library code)
jsMainApi(wrappers.react.core)
jsMainApi(npm("react","x.x.x"))andylamax
12/02/2023, 8:05 AMwhat if you will declare peer dependency in library??
I honestly haven't tried that, is this the best long term solution?? shouldn't a library like this (like many react libraries) have react as a peer dependency instead of it being a direct dependency??
andylamax
12/02/2023, 8:40 AMjsMainApi(peerNpm("react"))andylamax
12/02/2023, 8:52 AM@tanstack/react-tablekotlin-tanstack-react-tablereact-routerkotlin-react-routerreact-selectkotlin-react-selectdevNpmturansky
12/02/2023, 9:24 AMpackage.jsonandylamax
12/02/2023, 10:56 AMFor application developers we fix versions which we support in wrappersBut
kotlin-reactkotlin-react-coreenforcePlatformturansky
12/02/2023, 11:04 AMturansky
12/02/2023, 11:25 AMMy question still remains though.
is it the best solution to define react as a core dependency in a library??As you see - you have full control inside your project. Application developers have synchronized Gradle and NPM dependencies by default. Library developers can move some dependencies (all or some of them) in "peer" section if they want.