New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

@jumpn/react-native-jetifier

Package Overview
Dependencies
Maintainers
2
Versions
5
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@jumpn/react-native-jetifier

React Native Jetifier

  • 0.1.4
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
535
decreased by-13.99%
Maintainers
2
Weekly downloads
 
Created
Source

React Native Jetifier (@jumpn/react-native-jetifier)

Glosary

Jetificable

A Java, Kotlin, or XML file with references to any Support class, now migrated to AndroidX.

Jetificable Group

All the jetificables under a dependency (npm package).

Jetify

Rewrite Support classes to AndroidX equivalents.

Jetification

The process of jetify a jetificable.

Why this package exists?

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.

How jetification is done?

  1. 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).
  2. 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).

Installation

Using npm

$ npm install --save @jumpn/react-native-jetifier

Using yarn

$ yarn add @jumpn/react-native-jetifier

Usage

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 it after installation

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

Setup it to run on npm postinstall

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"
  }
}

Commit the index file (jetificableGroups.json) to your repository

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.

Unjetify if needed

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

License

MIT :copyright: Jumpn Limited

Keywords

FAQs

Package last updated on 27 Jun 2019

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc