CustomPermissionsDialogue
Custom Permissions Dialogue is the only permissions library that supports ALL permission request scenarios. This library handles multiple edge cases such as not enabling all permissions or permanently rejecting a permission request.
Install / Use
/learn @rayliverified/CustomPermissionsDialogueREADME
Custom Permissions Dialogue

Custom Permissions Dialogue is the only permissions library that supports ALL permission request scenarios. This library handles multiple edge cases such as not enabling all permissions or permanently rejecting a permission request.
Custom Permissions Dialogue is also the FIRST permissions library with a graphical interface. Not only does Custom Permissions Dialogue offer the most advanced functionality, it looks fantastic while doing so!

This library is part of the Custom UI collection of beautiful, minimalistic, and customizable Android UI components.
Gradle Dependency
Add this line to your build.gradle project. Use the latest release version for the version code.
repositories {
maven { url 'https://jitpack.io' }
}
implementation 'com.github.searchy2:CustomPermissionsDialogue:latest-version'
Usage
Code
Custom Permissions Dialogue uses the Builder format to initialize a popup permissions dialogue programmatically. To request a single permissions, just drag and drop the following code into your project. It's that simple!

PermissionsDialogue.Builder permissionsDialogue = new PermissionsDialogue.Builder(getActivity())
.setMessage(getString(R.string.app_name) + " is a sample permissions app and requires the following permissions: ")
.setShowIcon(false)
.setRequireStorage(PermissionsDialogue.REQUIRED)
.setOnContinueClicked(new PermissionsDialogue.OnContinueClicked() {
@Override
public void OnClick(View view, Dialog dialog) {
dialog.dismiss();
}
})
.setDecorView(getWindow().getDecorView())
.build();
permissionsDialogue.show();
IMPORTANT: The Dialog Fragment is extremely picky about the Activity passed into the builder. If the improper Activity is passed, the dialogue will crash! Here's how to pass the proper Activity in the following cases:
- Activity - construct with
ClassName.this - Fragment - construct with
getActivity() - ViewHolder - construct with
getActivity().getApplicationContext()
Do not attempt to construct the dialogue with getContext(). The Builder requires an Activity and passing a Context does not work!
Hint: Passing the DecorView to the Dialogue Builder in setDecorView will create a nice blurred background. Here's how to pass the correct DecorView:
- Activity - use
getWindow().getDecorView() - Fragment - use
getActivity().getWindow().getDecorView() - Viewholder - use
((Activity) mContext).getWindow().getDecorView()
Manifest
Remember to add the permissions your app requires to your manifest file. The following code contains a list of all regular Android permissions.
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
<uses-permission android:name="android.permission.ACCESS_NOTIFICATION_POLICY"/>
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/>
<uses-permission android:name="android.permission.CALL_PHONE"/>
<uses-permission android:name="android.permission.CAMERA"/>
<uses-permission android:name="android.permission.CHANGE_CONFIGURATION"/>
<uses-permission android:name="android.permission.CHANGE_NETWORK_STATE"/>
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE"/>
<uses-permission android:name="android.permission.GET_ACCOUNTS"/>
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.MODIFY_AUDIO_SETTINGS"/>
<uses-permission android:name="android.permission.NFC"/>
<uses-permission android:name="android.permission.READ_CALENDAR"/>
<uses-permission android:name="android.permission.READ_CALL_LOG"/>
<uses-permission android:name="android.permission.READ_CONTACTS"/>
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.READ_PHONE_STATE"/>
<uses-permission android:name="android.permission.READ_SMS"/>
<uses-permission android:name="android.permission.READ_SYNC_SETTINGS"/>
<uses-permission android:name="android.permission.READ_SYNC_STATS"/>
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/>
<uses-permission android:name="android.permission.RECEIVE_MMS"/>
<uses-permission android:name="android.permission.RECEIVE_SMS"/>
<uses-permission android:name="android.permission.RECORD_AUDIO"/>
<uses-permission android:name="android.permission.SEND_SMS"/>
<uses-permission android:name="android.permission.SET_ALARM"/>
<uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW"/>
<uses-permission android:name="android.permission.VIBRATE"/>
<uses-permission android:name="android.permission.WAKE_LOCK"/>
<uses-permission android:name="android.permission.WRITE_CALENDAR"/>
<uses-permission android:name="android.permission.WRITE_CALL_LOG"/>
<uses-permission android:name="android.permission.WRITE_CONTACTS"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.WRITE_SETTINGS"/>
<uses-permission android:name="android.permission.WRITE_SMS"/>
<uses-permission android:name="android.permission.WRITE_SYNC_SETTINGS"/>
Customization
Custom Permissions Dialogue supports extensive customization options to fit your permission request needs.
Layouts
All - Showcases all Custom Permissions Dialogue permissions.

PermissionsDialogue.Builder permissionsDialogue = new PermissionsDialogue.Builder(getActivity())
.setMessage(getString(R.string.app_name) + " is a sample permissions app and requires the following permissions: ")
.setIcon(R.mipmap.ic_launcher)
.setRequirePhone(PermissionsDialogue.REQUIRED)
.setRequireSMS(PermissionsDialogue.REQUIRED)
.setRequireContacts(PermissionsDialogue.REQUIRED)
.setRequireStorage(PermissionsDialogue.REQUIRED)
.setRequireCamera(PermissionsDialogue.OPTIONAL)
.setRequireAudio(PermissionsDialogue.OPTIONAL)
.setRequireCalendar(PermissionsDialogue.OPTIONAL)
.setRequireLocation(PermissionsDialogue.OPTIONAL)
.setOnContinueClicked(new PermissionsDialogue.OnContinueClicked() {
@Override
public void OnClick(View view, Dialog dialog) {
dialog.dismiss();
}
})
.setDecorView(getWindow().getDecorView())
.build();
permissionsDialogue.show();
Required - Displays all required permissions for the user to grant.

PermissionsDialogue.Builder permissionsDialogue = new PermissionsDialogue.Builder(getActivity())
.setMessage(getString(R.string.app_name) + " is a sample permissions app and requires the following permissions: ")
.setIcon(R.mipmap.ic_launcher)
.setRequirePhone(PermissionsDialogue.REQUIRED)
.setRequireSMS(PermissionsDialogue.REQUIRED)
.setRequireContacts(PermissionsDialogue.REQUIRED)
.setRequireStorage(PermissionsDialogue.REQUIRED)
.setOnContinueClicked(new PermissionsDialogue.OnContinueClicked() {
@Override
public void OnClick(View view, Dialog dialog) {
dialog.dismiss();
}
})
.setDecorView(getWindow().getDecorView())
.build();
permissionsDialogue.show();
Optional - Optional permissions allows user to selectively enable permissions.

PermissionsDialogue.Builder permissionsDialogue = new PermissionsDialogue.Builder(getActivity())
.setRequireCamera(PermissionsDialogue.OPTIONAL)
.setRequireAudio(PermissionsDialogue.OPTIONAL)
.setRequireCalendar(PermissionsDialogue.OPTIONAL)
.setRequireLocation(PermissionsDialogue.OPTIONAL)
.setCameraDescription("Capture images")
.setAudioDescription("Record audio messages")
.setCalendarDescription("Add notes to cale
