2.0.0 • Published 2 years ago

react-native-url-polyfill v2.0.0

Weekly downloads
41,860
License
MIT
Repository
github
Last release
2 years ago

react-native-url-polyfill is a full implementation of the WHATWG URL Standard that has been optimized for React Native.

  • Trustworthy. Follows closely the URL Standard spec, and relys on unit tests and Detox e2e tests within React Native.
  • Light. Instead of using directly whatwg-url, this polyfill uses a forked version (whatwg-url-without-unicode) where unicode support has been stripped out — Going down from 361 KB to 54 KB.
  • Blob support. Supports React Native's Blob without additional steps.

Why do we need this?

React Native does include a polyfill for URL, but this polyfill is homemade — in order to keep it light-weight — and was initially created to handle specific use cases.

Meanwhile, React Native has grown around that polyfill, then some unexpected errors have arisen.

Known issues (non-exhaustive) with React Native's URL are:

Unfortunately, adding react-native-url-polyfill to React Native source code will means adding šŸ“¦ 84.76 KB to the JavaScript bundle, even if you don't use URL because šŸš‡ Metro doesn't support optional imports.

That's why you may need this external dependency. So, if you use URL within your app, you probably want to take a look at the installation steps below!

Installation

First, you need to install the polyfill, which can be done with Yarn or npm.

Yarn

yarn add react-native-url-polyfill

npm

npm install --save react-native-url-polyfill

Then, the polyfill can be used in multiple ways. Pick your preferred option.

ā„¹ļø To verify if the polyfill has been correctly applied, you can check if the global variable REACT_NATIVE_URL_POLYFILL contains the current package and version like: react-native-url-polyfill@CURRENT_VERSION.

Option 1 (Simple)

Locate your JavaScript entry-point file, commonly called index.js at the root of your React Native project.

Then, import react-native-url-polyfill/auto at the top of your entry-point file, the polyfill will be automatically applied.

import 'react-native-url-polyfill/auto';

Option 2 (Flexible)

If you want to apply the polyfill when you're ready, you can import setupURLPolyfill and call it yourself.

āš ļø Metro doesn't support optional imports.

If you do not apply the polyfill, it will still be added to your JavaScript bundle. Even if it's wrapped in a condition, Metro won't strip it in production.

import { setupURLPolyfill } from 'react-native-url-polyfill';

setupURLPolyfill();

Option 3 (Convenient)

If you prefer not to apply this polyfill over React Native's default URL, you can still import those classes manually when you want them.

import { URL, URLSearchParams } from 'react-native-url-polyfill';

const url = new URL('https://github.com');
const searchParams = new URLSearchParams('q=GitHub');

License

react-native-url-polyfill is MIT licensed.

@biconomy-sdk-dev/web3-auth-nativeinfoset-react-nativehilyticsjitsi-meet-rnreact-native-jitsi-meet-lib@rn-toolkit/navigation@infinitebrahmanuniverse/nolb-react-native-umotionfans@everything-registry/sub-chunk-2597ally-sdk@triframe/arbiter-reactermis-chat-react-native-coresupertokens-react-nativevexo-analyticsvolo-sdk-react-native@bouncecode/mrlogin-sdk-rn@candypay/elements-mobile-sdk@prisma/react-nativejitsi-meet-stepupjitsi-fmtechlean-react-nativelean-react-native-expolivekit-react-nativesolana-test-package@waku/react-native-polyfills@walletconnect/react-native-compat@web3auth/react-native-sdk@wcpos/core@wepin/react-native-sdk@thirdweb-dev/react-native-compat@tosspayments/widget-sdk-react-native@tosspayments/payment-sdk-react-native@theoplayer/react-native-ui@viewstools/morph@vidyvault/react-native@vcrx/react-native@useawards/useaward-expo@usecapsule/react-native-wallet@yunzhoukit/yunzhou-react-native@zocks-communications/client-sdk-react-nativearchitect-react-native-sdk@clerk/clerk-expo@cloudflare/realtimekit-react-native@cloudflare/realtimekit-react-native-ui@goplayerzero/sdk-react-native@classon/react-native@classon/react-native-test@dytesdk/mobile@dytesdk/react-native-core@dytesdk/react-native-ui-kit@gnonative/react-native@granite-js/react-native@ground-x/embedded-wallet-rn-sdk@aakatrov/jitsi-react-native-sdk@admin-layout/mobile-navigation-router@egiftcard/react-native-compat@cod3x/react-native@cristianachavez/orbis-sdk@crqlar/expo-sdk@criipto/verify-expo@aloai/alo-chat-react-native@collaboware/solid-authn-react-native@coinbase/mobile-wallet-protocol-host@coralogix/react-native-sdk@nosebit/meauth-react-native@bpx-chain/synapse-react-native-polyfillsstream-chat-react-native-coresolid-authn-react-nativetstubetweetnacl-expo-pollyfill@baqhub/sdk-react-native@basis-theory/basis-theory-react-native@blackbox-vision/react-native-mercadopago-tokenize-checkout@biconomy-devx/web3-auth-native@biconomy/web3-auth-native@billyjacoby/clerk-react-nativeunimedia-finance@livekit/react-native@narwhal/data-engine-mobile@moonup/moon-react-native@privyid/pena-react-native@seoltab/react-native@sendlab/otel-react-nativemsw-rn-wrappermobilenftminteropenledger-markdown-html-devopenlogin-expo-sdkorbis-sdkoneid-react-nativepassportexpopassportsdkreact-native-cometchat-calling-componentscannersdkscanningsdkreact-native-jitsi-meet-sdk-fmtechreact-native-goaffproreact-native-raiplayerrn-sestek-webchatrn-reddit-editorsalmonwalletv2
2.0.0

2 years ago

1.3.0

5 years ago

1.2.0

5 years ago

1.2.0-rc.1

5 years ago

1.2.0-rc.0

5 years ago

1.1.2

6 years ago

1.1.2-rc.0

6 years ago

1.1.1

6 years ago

1.1.0

6 years ago

1.0.0

6 years ago