Mathieu Acthernoene df0b484a93 Add flowcharts | 5 jaren geleden | |
---|---|---|
android | 5 jaren geleden | |
example | 5 jaren geleden | |
ios | 5 jaren geleden | |
src | 5 jaren geleden | |
.editorconfig | 5 jaren geleden | |
.eslintignore | 5 jaren geleden | |
.eslintrc.js | 5 jaren geleden | |
.gitignore | 5 jaren geleden | |
.prettierignore | 5 jaren geleden | |
.prettierrc | 5 jaren geleden | |
.yarnrc | 5 jaren geleden | |
CODEOWNERS | 5 jaren geleden | |
LICENSE | 5 jaren geleden | |
README.md | 5 jaren geleden | |
RNPermissions.podspec | 5 jaren geleden | |
package.json | 5 jaren geleden | |
tsconfig.json | 5 jaren geleden | |
yarn.lock | 5 jaren geleden |
Check and request user permissions in React Native
version | react-native version |
---|---|
2.0.0+ | 0.60.0+ |
1.1.1 | 0.40.0 - 0.52.2 |
For 2.0.0 with 0.59-, you can use jetify -r
$ npm install --save react-native-permissions@next
# --- or ---
$ yarn add react-native-permissions@next
By default no permission handler is installed. Add update your Podfile with the ones you want, then run pod install
.
target 'YourAwesomeProject' do
# โฆ
permissions_path = '../node_modules/react-native-permissions/ios'
pod 'Permission-BluetoothPeripheral', :path => "#{permissions_path}/BluetoothPeripheral.podspec"
pod 'Permission-Calendars', :path => "#{permissions_path}/Calendars.podspec"
pod 'Permission-Camera', :path => "#{permissions_path}/Camera.podspec"
pod 'Permission-Contacts', :path => "#{permissions_path}/Contacts.podspec"
pod 'Permission-FaceID', :path => "#{permissions_path}/FaceID.podspec"
pod 'Permission-LocationAlways', :path => "#{permissions_path}/LocationAlways.podspec"
pod 'Permission-LocationWhenInUse', :path => "#{permissions_path}/LocationWhenInUse.podspec"
pod 'Permission-MediaLibrary', :path => "#{permissions_path}/MediaLibrary.podspec"
pod 'Permission-Microphone', :path => "#{permissions_path}/Microphone.podspec"
pod 'Permission-Motion', :path => "#{permissions_path}/Motion.podspec"
pod 'Permission-Notifications', :path => "#{permissions_path}/Notifications.podspec"
pod 'Permission-PhotoLibrary', :path => "#{permissions_path}/PhotoLibrary.podspec"
pod 'Permission-Reminders', :path => "#{permissions_path}/Reminders.podspec"
pod 'Permission-Siri', :path => "#{permissions_path}/Siri.podspec"
pod 'Permission-SpeechRecognition', :path => "#{permissions_path}/SpeechRecognition.podspec"
pod 'Permission-StoreKit', :path => "#{permissions_path}/StoreKit.podspec"
end
โ ๏ธ Donโt forget to add permissions to AndroidManifest.xml
for android and
Info.plist
for iOS.
Because this package targets React Native 0.60+, you will probably donโt need to link it. Otherwise if you follow all the previous steps and it still doesnโt work, try to link this library manually.
Add this line to your ios/Podfile
file, then run pod install
.
target 'YourAwesomeProject' do
# โฆ
pod 'RNPermissions', :path => '../node_modules/react-native-permissions'
end
android/settings.gradle
:include ':react-native-permissions'
project(':react-native-permissions').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-permissions/android')
android/app/build.gradle
:dependencies {
// ...
implementation project(':react-native-permissions')
}
MainApplication.java
:import com.reactnativecommunity.rnpermissions.RNPermissionsPackage; // <- add the RNPermissionsPackage import
public class MainApplication extends Application implements ReactApplication {
// โฆ
@Override
protected List<ReactPackage> getPackages() {
@SuppressWarnings("UnnecessaryLocalVariable")
List<ReactPackage> packages = new PackageList(this).getPackages();
// โฆ
packages.add(new RNPermissionsPackage());
return packages;
}
// โฆ
}
Permission are not handled in the same way on iOS and Android. This library provides an abstraction over the platforms behaviors. To understand it a little better, have a look to these two flowcharts:
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ check(PERMISSIONS.IOS.CAMERA) โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ
Is the feature available
on this deviceย ?
โ โโโโโโ
โโโโโโโโโโโโโ NO โโโโโโโโโโโโโโโโ
โ โโโโโโ โ
โโโโโโโ โผ
โ YES โ โโโโโโโโโโโโโโโโโโโโโโโ
โโโโโโโ โ RESULTS.UNAVAILABLE โ
โ โโโโโโโโโโโโโโโโโโโโโโโ
Is the permission
requestableย ?
โ โโโโโโ
โโโโโโโโโโโโโ NO โโโโโโโโโโโโโโโโ
โ โโโโโโ โ
โโโโโโโ โผ
โ YES โ โโโโโโโโโโโโโโโโโโโโโ
โโโโโโโ โ RESULTS.BLOCKED / โ
โ โ RESULTS.GRANTED โ
โผ โโโโโโโโโโโโโโโโโโโโโ
โโโโโโโโโโโโโโโโโโ
โ RESULTS.DENIED โ
โโโโโโโโโโโโโโโโโโ
โ
โผ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ request(PERMISSIONS.IOS.CAMERA) โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ
Does the user accepted
the requestย ?
โ โโโโโโ
โโโโโโโโโโโโโ NO โโโโโโโโโโโโโโโโ
โ โโโโโโ โ
โโโโโโโ โผ
โ YES โ โโโโโโโโโโโโโโโโโโโ
โโโโโโโ โ RESULTS.BLOCKED โ
โ โโโโโโโโโโโโโโโโโโโ
โผ
โโโโโโโโโโโโโโโโโโโ
โ RESULTS.GRANTED โ
โโโโโโโโโโโโโโโโโโโ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ check(PERMISSIONS.ANDROID.CAMERA) โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ
Is the feature available
on this deviceย ?
โ โโโโโโ
โโโโโโโโโโโโโ NO โโโโโโโโโโโโโโโโ
โ โโโโโโ โ
โโโโโโโ โผ
โ YES โ โโโโโโโโโโโโโโโโโโโโโโโ
โโโโโโโ โ RESULTS.UNAVAILABLE โ
โ โโโโโโโโโโโโโโโโโโโโโโโ
Is the permission
requestableย ?
โ โโโโโโ
โโโโโโโโโโโโโ NO โโโโโโโโโโโโโโโโ
โ โโโโโโ โ
โโโโโโโ โผ
โ YES โ โโโโโโโโโโโโโโโโโโโโโ
โโโโโโโ โ RESULTS.BLOCKED / โ
โ โ RESULTS.GRANTED โ
โผ โโโโโโโโโโโโโโโโโโโโโ
โโโโโโโโโโโโโโโโโโ
โ RESULTS.DENIED โโโโโโโโโโโโโโโโโโโโโโโโโ
โโโโโโโโโโโโโโโโโโ โ
โ โ
โผ โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ โโโโโโ
โ request(PERMISSIONS.ANDROID.CAMERA) โ โ NO โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ โโโโโโ
โ โ
Does the user accepted โ
the requestย ? โ
โ โโโโโโ Does the user checked
โโโโโโโโโโโโโ NO โโโโโโ"Neverย askย again"ย ?
โ โโโโโโ โ
โโโโโโโ โโโโโโโ
โ YES โ โ YES โ
โโโโโโโ โโโโโโโ
โ โ
โผ โผ
โโโโโโโโโโโโโโโโโโโ โโโโโโโโโโโโโโโโโโโ
โ RESULTS.GRANTED โ โ RESULTS.BLOCKED โ
โโโโโโโโโโโโโโโโโโโ โโโโโโโโโโโโโโโโโโโ
Promises resolve into one of these statuses:
Return value | Notes |
---|---|
RESULTS.UNAVAILABLE |
This feature is not available (on this device / in this context) |
RESULTS.DENIED |
The permission has not been requested / is denied but requestable |
RESULTS.GRANTED |
The permission is granted |
RESULTS.BLOCKED |
The permission is denied and not requestable anymore |
import {PERMISSIONS} from 'react-native-permissions';
// Android permissions
PERMISSIONS.ANDROID.ACCEPT_HANDOVER;
PERMISSIONS.ANDROID.ACCESS_BACKGROUND_LOCATION;
PERMISSIONS.ANDROID.ACCESS_COARSE_LOCATION;
PERMISSIONS.ANDROID.ACCESS_FINE_LOCATION;
PERMISSIONS.ANDROID.ACTIVITY_RECOGNITION;
PERMISSIONS.ANDROID.ADD_VOICEMAIL;
PERMISSIONS.ANDROID.ANSWER_PHONE_CALLS;
PERMISSIONS.ANDROID.BODY_SENSORS;
PERMISSIONS.ANDROID.CALL_PHONE;
PERMISSIONS.ANDROID.CAMERA;
PERMISSIONS.ANDROID.GET_ACCOUNTS;
PERMISSIONS.ANDROID.PROCESS_OUTGOING_CALLS;
PERMISSIONS.ANDROID.READ_CALENDAR;
PERMISSIONS.ANDROID.READ_CALL_LOG;
PERMISSIONS.ANDROID.READ_CONTACTS;
PERMISSIONS.ANDROID.READ_EXTERNAL_STORAGE;
PERMISSIONS.ANDROID.READ_PHONE_NUMBERS;
PERMISSIONS.ANDROID.READ_PHONE_STATE;
PERMISSIONS.ANDROID.READ_SMS;
PERMISSIONS.ANDROID.RECEIVE_MMS;
PERMISSIONS.ANDROID.RECEIVE_SMS;
PERMISSIONS.ANDROID.RECEIVE_WAP_PUSH;
PERMISSIONS.ANDROID.RECORD_AUDIO;
PERMISSIONS.ANDROID.SEND_SMS;
PERMISSIONS.ANDROID.USE_SIP;
PERMISSIONS.ANDROID.WRITE_CALENDAR;
PERMISSIONS.ANDROID.WRITE_CALL_LOG;
PERMISSIONS.ANDROID.WRITE_CONTACTS;
PERMISSIONS.ANDROID.WRITE_EXTERNAL_STORAGE;
// iOS permissions
PERMISSIONS.IOS.BLUETOOTH_PERIPHERAL;
PERMISSIONS.IOS.CALENDARS;
PERMISSIONS.IOS.CAMERA;
PERMISSIONS.IOS.CONTACTS;
PERMISSIONS.IOS.FACE_ID;
PERMISSIONS.IOS.LOCATION_ALWAYS;
PERMISSIONS.IOS.LOCATION_WHEN_IN_USE;
PERMISSIONS.IOS.MEDIA_LIBRARY;
PERMISSIONS.IOS.MICROPHONE;
PERMISSIONS.IOS.MOTION;
PERMISSIONS.IOS.PHOTO_LIBRARY;
PERMISSIONS.IOS.REMINDERS;
PERMISSIONS.IOS.SIRI;
PERMISSIONS.IOS.SPEECH_RECOGNITION;
PERMISSIONS.IOS.STOREKIT;
types used in usage examples
type PermissionStatus = 'unavailable' | 'denied' | 'blocked' | 'granted';
Check one permission status.
function check(permission: string): Promise<PermissionStatus>;
import {check, PERMISSIONS, RESULTS} from 'react-native-permissions';
check(PERMISSIONS.IOS.LOCATION_ALWAYS)
.then(result => {
switch (result) {
case RESULTS.UNAVAILABLE:
console.log('the feature is not available');
break;
case RESULTS.GRANTED:
console.log('permission is granted');
break;
case RESULTS.DENIED:
console.log('permission is denied and / or requestable');
break;
case RESULTS.BLOCKED:
console.log('permission is denied and not requestable');
break;
}
})
.catch(error => {
// โฆ
});
Request one permission.
type Rationale = {
title: string;
message: string;
buttonPositive?: string;
buttonNegative?: string;
buttonNeutral?: string;
};
function request(
permission: string,
rationale?: Rationale,
): Promise<PermissionStatus>;
import {request, PERMISSIONS} from 'react-native-permissions';
request(PERMISSIONS.IOS.LOCATION_ALWAYS).then(result => {
// โฆ
});
Check notifications permission status and get settings values.
interface NotificationSettings {
// properties only availables on iOS
// unavailable settings will not be included in the response object
alert?: boolean;
badge?: boolean;
sound?: boolean;
lockScreen?: boolean;
carPlay?: boolean;
notificationCenter?: boolean;
criticalAlert?: boolean;
}
function checkNotifications(): Promise<{
status: PermissionStatus;
settings: NotificationSettings;
}>;
import {checkNotifications} from 'react-native-permissions';
checkNotifications().then(({status, settings}) => {
// โฆ
});
Request notifications permission status and get settings values.
// only used on iOS
type NotificationOption =
| 'alert'
| 'badge'
| 'sound'
| 'criticalAlert'
| 'carPlay'
| 'provisional';
interface NotificationSettings {
// properties only availables on iOS
// unavailable settings will not be included in the response object
alert?: boolean;
badge?: boolean;
sound?: boolean;
lockScreen?: boolean;
carPlay?: boolean;
notificationCenter?: boolean;
criticalAlert?: boolean;
}
function requestNotifications(
options: NotificationOption[],
): Promise<{
status: PermissionStatus;
settings: NotificationSettings;
}>;
import {requestNotifications} from 'react-native-permissions';
requestNotifications(['alert', 'sound']).then(({status, settings}) => {
// โฆ
});
Open application settings.
function openSettings(): Promise<void>;
import {openSettings} from 'react-native-permissions';
openSettings().catch(() => console.warn('cannot open settings'));