React Native Permissions Versions Save

An unified permissions API for React Native on iOS, Android and Windows.

3.8.1

10 months ago

3.8.0

1 year ago
  • Add new architecture support (#748 by @WoLewicki)

3.7.3

1 year ago
  • Add support for reactNativePermissionsIOS.json config file (closes #753)

3.7.2

1 year ago
  • Include missing react-native.config.js file in the npm package (#752 by @johnf)
  • Replace cosmiconfig dependency by read-pkg (fixes this issue)

3.7.1

1 year ago
  • Only request the App Tracking Transparency iOS permission when the app is focused (as it's not allowed in background). This means that this code (which was a workaround):
useEffect(() => {
  const listener = AppState.addEventListener('change', (status) => {
    if (Platform.OS === 'ios' && status === 'active') {
      request(PERMISSIONS.IOS.APP_TRACKING_TRANSPARENCY)
        .then((result) => console.log(result))
        .catch((error) => console.log(error));
    }
  });

  return listener.remove;
}, []);

       Can safely be replaced by:

useEffect(() => {
  if (Platform.OS === 'ios') {
    request(PERMISSIONS.IOS.APP_TRACKING_TRANSPARENCY)
      .then((result) => console.log(result))
      .catch((error) => console.log(error));
  }
}, []);

3.7.0

1 year ago

The new react-native setup-ios-permissions command

This release come with a new permission handler linkage system for iOS: the react-native setup-ios-permissions command. No need to update your Podfile file anymore, everything is now handled by your package.json.

The benefits from this solution are many, but the main ones are that it should fixes Xcode cache issues and the well-known use_frameworks issue (no more workaround needed! 🎉)

📌 The "old way" will continue to work until the next major update, but it has been removed from the latest documentation since this is not the preferred way anymore.

To migrate, remove all the extra code from your Podfile (and the use_frameworks workaround if you used it):

- # Convert all permission pods into static libraries
- pre_install do |installer|
-   Pod::Installer::Xcode::TargetValidator.send(:define_method, :verify_no_static_framework_transitive_dependencies) {}
-   installer.pod_targets.each do |pod|
-     if pod.name.eql?('RNPermissions') || pod.name.start_with?('Permission-')
-       def pod.build_type;
-         # Uncomment the line corresponding to your CocoaPods version
-         # Pod::BuildType.static_library # >= 1.9
-         # Pod::Target::BuildType.static_library # < 1.9
-       end
-     end
-   end
- end

target 'MyAwesomeApp' do

    # …

-  permissions_path = '../node_modules/react-native-permissions/ios'

-  pod 'Permission-Camera', :path => "#{permissions_path}/Camera"
-  pod 'Permission-LocationWhenInUse', :path => "#{permissions_path}/LocationWhenInUse"
-  pod 'Permission-Notifications', :path => "#{permissions_path}/Notifications"
-  pod 'Permission-SpeechRecognition', :path => "#{permissions_path}/SpeechRecognition"

Add a reactNativePermissionsIOS config in your package.json:

{
  "reactNativePermissionsIOS": [
    "Camera",
    "LocationWhenInUse",
    "Notifications",
    "SpeechRecognition"
  ]
}

Then run react-native setup-ios-permissions and pod install. That's all! ✨


P.-S. As these commands must be run each tome each time you update this config, delete your node_modules directory or update this library, I highly recommand to use a postinstall script to simplify this:

{
  "reactNativePermissionsIOS": [
    "Camera",
    "LocationWhenInUse",
    "Notifications",
    "SpeechRecognition"
  ],
  "devDependencies": {
    "pod-install": "0.1.38"
  },
  "scripts": {
    "postinstall": "react-native setup-ios-permissions && pod-install"
  }
}

Also in this release:

  • Update project dependencies to React Native 0.71 in order to prepare new architecture support.
  • Update the example app UI (with react-native-paper v5):

3.6.0

1 year ago
  • Add support for new Android 13 permissions (#701 by @bang9):
    • android.permission.BODY_SENSORS_BACKGROUND
    • android.permission.NEARBY_WIFI_DEVICES
    • android.permission.READ_MEDIA_AUDIO
    • android.permission.READ_MEDIA_IMAGES
    • android.permission.READ_MEDIA_VIDEO

3.5.0

1 year ago

⚠️ You have to target at least SDK 33 to perform the request:

buildscript {
  ext {
    buildToolsVersion = "33.0.0" // <- set at least 33.x
    minSdkVersion = 21
    compileSdkVersion = 33 // <- set at least 33
    targetSdkVersion = 33 // <- set at least 33

    // …

3.4.0

1 year ago

Previous Android flow

Android flow - Before

New Android flow

ℹ️  It should not be breaking if you followed the previous flow.

Android flow - After

Known issues

  • On Android, there is currently no way, without relying on SharedPreferences (a trick that break Ask next time setting and Only this time grant status), to determine if a permission is BLOCKED without requesting it.
  • Dismissing the popup on Android 11+ will result in BLOCKED (see https://github.com/facebook/react-native/issues/30158). It's a flaw in the Android permission system, not specific to this library or React Native.