A Java, Kotlin, or XML file with references to any Support class, now migrated to AndroidX.
All the jetificables under a dependency (npm package).
Rewrite Support classes to AndroidX equivalents.
The process of jetify a jetificable.
By the end of 2018, Android released Jetpack that comprises a full rewrite of the Support Library now called AndroidX.
To support this, they ask you to set the following properties with true
in your gradle.properties file:
android.useAndroidX=true
android.enableJetifier=true
In addition to this, you also need to require artifacts and import classes with their new names.
So you might be thinking, I've already done this on my App, so I still don't understand *"Why this package exists?", so let me answer this with another question:
What about your dependencies?
When we move to the world of React Native, all your dependencies instead of being libraries (JAR, AAR, and ZIP files
) as they are in a normal Android App, they are npm packages and live under the node_modules folder, so this means that unless all the React Native packages (including React Native itself) you are using have already migrated to AndroidX, you will have to manually rewrite all the Support classes usages and point them to their respective AndroidX equivalent as the Jetifier tool Android provides won't help you do this because it only handles Android libraries.
You can track the progress of React Native migration to AndroidX in this issue and I also recommend you to open an issue (if not already opened) and even better, submit a PR, to all your dependencies that haven't migrated yet.
- An index (jetificableGroups.json) file will be created (or updated if already there) under your package root with the jetificables of all your dependencies (npm packages).
- All the jetificables of your dependencies (npm packages) present in the index (jetificableGroups.json) will be jetified.
This process should be fast (under 10 sec) on the first run (no index available) and super extremely fast (aprox 2 sec) on the following executions (index available).
Using npm
$ npm install --save @jumpn/react-native-jetifier
Using yarn
$ yarn add @jumpn/react-native-jetifier
After having installed this package you will have an executable file called react-native-jetifier
available under your node_modules/.bin
folder.
Follow the following steps that will ensude your dependencies (npm packages) will be jetified even if you decide to remove or add some:
Execute react-native-jetifier
to jetify your dependencies (npm packages) and create the index (jetificableGroups.json
).
Using npm
$ npx react-native-jetifier
Using yarn
$ yarn react-native-jetifier
Add it under the npm postinstall script in your package.json to keep your dependencies jetified when you remove or add some.
Using npm
{
"scripts": {
"postinstall": "npx react-native-jetifier"
}
}
Using yarn
{
"scripts": {
"postinstall": "yarn react-native-jetifier"
}
}
Since all the jetificable paths are read from the index file (jetificableGroups.json
) to improve perfomance, it's highly recommended to commit it to your repository so on a clean clone react-native-jetifier
will use it instead of creating a new one.
I have been thinking for a while about the reasons you might want to do this and I found none, but well, if you want to unjetify your dependencies (npm packages) do the following:
Using npm
$ npm install --force
Using yarn
$ yarn install --force
MIT ©️ Jumpn Limited