From 52179dd90b8ea07f70e47cbf25be12f7084a7e50 Mon Sep 17 00:00:00 2001 From: Den Galkin Date: Wed, 13 Mar 2024 16:45:25 +0100 Subject: [PATCH] fix(android): resolve ANR issue when calling `getContacts` --- .../community/contacts/ContactsPlugin.java | 44 +++++++++++++------ 1 file changed, 30 insertions(+), 14 deletions(-) diff --git a/android/src/main/java/getcapacitor/community/contacts/ContactsPlugin.java b/android/src/main/java/getcapacitor/community/contacts/ContactsPlugin.java index afa0aa5..82d3dd2 100644 --- a/android/src/main/java/getcapacitor/community/contacts/ContactsPlugin.java +++ b/android/src/main/java/getcapacitor/community/contacts/ContactsPlugin.java @@ -18,6 +18,8 @@ import com.getcapacitor.annotation.PermissionCallback; import java.util.HashMap; import java.util.Map; +import java.util.concurrent.ExecutorService; +import java.util.concurrent.Executors; @CapacitorPlugin( name = "Contacts", @@ -102,20 +104,34 @@ public void getContacts(PluginCall call) { if (!isContactsPermissionGranted()) { requestContactsPermission(call); } else { - HashMap contacts = implementation.getContacts( - new GetContactsProjectionInput(call.getObject("projection")) - ); - - JSArray contactsJSArray = new JSArray(); - - for (Map.Entry entry : contacts.entrySet()) { - ContactPayload value = entry.getValue(); - contactsJSArray.put(value.getJSObject()); - } - - JSObject result = new JSObject(); - result.put("contacts", contactsJSArray); - call.resolve(result); + ExecutorService executor = Executors.newSingleThreadExecutor(); + + executor.execute(new Runnable() { + @Override + public void run() { + HashMap contacts = implementation.getContacts( + new GetContactsProjectionInput(call.getObject("projection")) + ); + + JSArray contactsJSArray = new JSArray(); + for (Map.Entry entry : contacts.entrySet()) { + ContactPayload value = entry.getValue(); + contactsJSArray.put(value.getJSObject()); + } + + JSObject result = new JSObject(); + result.put("contacts", contactsJSArray); + + bridge.getActivity().runOnUiThread(new Runnable() { + @Override + public void run() { + call.resolve(result); + } + }); + } + }); + + executor.shutdown(); } }