Following BuckleScript & Reason Rebranding to offer a unified experience, what was know as Reason React Native is now ReScript React Native.
To make this short: all packages that were published on the behalf of Reason React Native organisation are now published as the ReScript React Native organisation.
This means:
reason-react-native
is nowrescript-react-native
reason-react-navigation
is nowrescript-react-navigation
@reason-react-native/*
are now@rescript-react-native/*
Should I migrate now all my packages?
It depends on what version of React Native your are using. There is no rush, really.
You use React Native 0.63
You can keep using reason-react-native
and friends for now. Revisit this post when you will need to upgrade to 0.64.
You use React Native 0.64
Here you have 2 possibles upgrades path:
Keep using reason-react-native
Before renaming all packages, we offered a last release for reason-react-native
to cover React Native 0.64. You can use that until you are ready to switch to ReScript named packages. If you want to know what this will involve, keep reading.
Switch to rescript-react-native
The package rescript-react-native
starts with version 0.64.1. You can try to use it for earlier version of React Native of course, but you might end up to minor inconsistencies, especially for bindings that have been tuned for 0.64. Check out breaking changes in release notes to know what this is all about.
If you are ready to move to ReScript naming, you can use all the new packages. Except rescript-react-native
, other packages of this organisation have just been renamed for most of them, without any changes.
You can expects minor change between reason-react-native@0.64
& rescript-react-native@0.64
but this should not cause you any major trouble to switch.
You will probably notice some Js.t have been converted to record syntax, some polymorphic variants changes and minor things like that, but compiler should just tell you what to do.
Please note that @rescript/react
is required for switching
You cannot use reason-react
and @rescript/react
as they exposes the same module.
This means this will be "all or nothing".
Some bindings rely on React
module, so they now depend on @rescript/react
. This is true for rescript-react-native
and some other modules.
This is briefly mentionned in rescript-react-native@0.64.1
release notes but you will also need bs-platform@^9.0.0
.
Before you ask, rescript
package is now a thing and up for testing (you can track this using the ReScript forum, Announcements section). This is considered beta at the time of writing this post, so we will change this peer dependency in a near future, when it's officially stable. This will replace bs-platform
, probably in next "major" release (0.65 or maybe a 0.64.x-rescript).
tl;dr
If you want to switch to the new naming, you need to be ready to use
- React 17 and
@rescript/react@^0.10
- React Native 0.64 with
rescript-react-native@^0.64.1
- ReScript 9 via
bs-platform@^9.0.0
If you have any questions regarding these changes and how to proceed, feel free to open a discussion on GitHub, or use ReScript forum.
Wait.. That's it?
You might have a question that is still pending: "where is gone the promise of cross-platform code that ReasonML was supposed to offer? I was thinking I could someday use my Reason React Native code to compile it to a lower level language that JavaScript to have blazing fast performance... "
Like I did in the past in my sweet dreams, you may be looking for this. And maybe this will be a reality one day in the future. Some people want this JSX like convenience to build native apps. Some will argue that there are things that you can use today. But React Native ecosytem is more mature than existing solutions.
React Native can safely be used in production today, and it is for many successful companies. All the modules availables (from the core or the community) make it very easy to avoid writing specific code per platform. Performance is better and better for every release. Recently Hermes JavaScript engine was released for iOS and it's really fast. And don't forget TurboModules!
You can not only write mobile apps this days, but also web apps, thanks to React Native for Web, and even native desktop apps, thanks to React Native Windows + macOS. More than enough to ship amazing products to production, today.
What's next
I guess for the near future, nothing crazy will happen for ReScript React Native. We have to update some bindings from time to time, but beside having to switch from bs-platform
to rescript
, things should go smoothly.
Feel free to open a discussion if you want bindings for some modules (or just help to write them).
When stars are not correctly aligned and some package have incorrect bindings, remember that you can always use the fantastic patch-package to fix things real quick, and then open an issue at the right place.
❤️ I mostly maintain all this packages all by myself this days, so feel free to Sponsor Me on GitHub and just share kind words on Twitter to keep me motivated. I hope you enjoy this work like I do.