这是indexloc提供的服务,不要输入任何密码
Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
21 changes: 15 additions & 6 deletions android/src/main/java/com/calendarevents/CalendarEvents.java
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,6 @@
import android.database.DatabaseUtils;
import android.net.Uri;
import android.provider.CalendarContract;
import android.support.v4.app.ActivityCompat;
import android.support.v4.content.ContextCompat;
import android.database.Cursor;
import android.accounts.Account;
Expand All @@ -30,6 +29,8 @@
import com.facebook.react.bridge.WritableNativeArray;
import com.facebook.react.bridge.WritableNativeMap;
import com.facebook.react.bridge.Dynamic;
import com.facebook.react.modules.core.PermissionAwareActivity;
import com.facebook.react.modules.core.PermissionListener;

import java.sql.Array;
import java.text.ParseException;
Expand All @@ -41,7 +42,7 @@
import java.util.TimeZone;
import android.util.Log;

public class CalendarEvents extends ReactContextBaseJavaModule {
public class CalendarEvents extends ReactContextBaseJavaModule implements PermissionListener {

private static int PERMISSION_REQUEST_CODE = 37;
private final ReactContext reactContext;
Expand All @@ -66,15 +67,21 @@ private void requestCalendarReadWritePermission(final Promise promise)
promise.reject("E_ACTIVITY_DOES_NOT_EXIST", "Activity doesn't exist");
return;
}
if (!(currentActivity instanceof PermissionAwareActivity)) {
promise.reject("E_ACTIVITY_NOT_PERMISSION_AWARE", "Activity does not implement the PermissionAwareActivity interface");
return;
}
PermissionAwareActivity activity = (PermissionAwareActivity)currentActivity;
PERMISSION_REQUEST_CODE++;
permissionsPromises.put(PERMISSION_REQUEST_CODE, promise);
ActivityCompat.requestPermissions(currentActivity, new String[]{
activity.requestPermissions(new String[]{
Manifest.permission.WRITE_CALENDAR,
Manifest.permission.READ_CALENDAR
}, PERMISSION_REQUEST_CODE);
}, PERMISSION_REQUEST_CODE, this);
}

public static void onRequestPermissionsResult(int requestCode, String permissions[], int[] grantResults) {
@Override
public boolean onRequestPermissionsResult(int requestCode, String permissions[], int[] grantResults) {
if (permissionsPromises.containsKey(requestCode)) {

// If request is cancelled, the result arrays are empty.
Expand All @@ -89,6 +96,8 @@ public static void onRequestPermissionsResult(int requestCode, String permission
}
permissionsPromises.remove(requestCode);
}

return permissionsPromises.size() == 0;
}

private boolean haveCalendarReadWritePermissions() {
Expand Down Expand Up @@ -1324,4 +1333,4 @@ public void uriForCalendar(Promise promise) {
promise.resolve(CalendarContract.Events.CONTENT_URI.toString());
}
//endregion
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -25,8 +25,4 @@ public List<NativeModule> createNativeModules(

return modules;
}

public static void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) {
CalendarEvents.onRequestPermissionsResult(requestCode, permissions, grantResults);
}
}