diff options
Diffstat (limited to 'java/com/android/dialer/speeddial/loader/SpeedDialUiItemLoader.java')
-rw-r--r-- | java/com/android/dialer/speeddial/loader/SpeedDialUiItemLoader.java | 23 |
1 files changed, 18 insertions, 5 deletions
diff --git a/java/com/android/dialer/speeddial/loader/SpeedDialUiItemLoader.java b/java/com/android/dialer/speeddial/loader/SpeedDialUiItemLoader.java index 955793d72..71540da51 100644 --- a/java/com/android/dialer/speeddial/loader/SpeedDialUiItemLoader.java +++ b/java/com/android/dialer/speeddial/loader/SpeedDialUiItemLoader.java @@ -29,6 +29,7 @@ import android.support.annotation.MainThread; import android.support.annotation.WorkerThread; import android.util.ArrayMap; import android.util.ArraySet; +import com.android.contacts.common.preference.ContactsPreferences; import com.android.dialer.common.Assert; import com.android.dialer.common.LogUtil; import com.android.dialer.common.concurrent.Annotations.BackgroundExecutor; @@ -46,7 +47,6 @@ import com.google.common.collect.ImmutableList; import com.google.common.util.concurrent.ListenableFuture; import com.google.common.util.concurrent.ListeningExecutorService; import java.util.ArrayList; -import java.util.HashSet; import java.util.List; import java.util.Map; import java.util.Set; @@ -83,6 +83,7 @@ public final class SpeedDialUiItemLoader { private final ListeningExecutorService backgroundExecutor; // Used to ensure that only one refresh flow runs at a time. private final DialerFutureSerializer dialerFutureSerializer = new DialerFutureSerializer(); + private final ContactsPreferences contactsPreferences; @Inject public SpeedDialUiItemLoader( @@ -90,6 +91,7 @@ public final class SpeedDialUiItemLoader { @BackgroundExecutor ListeningExecutorService backgroundExecutor) { this.appContext = appContext; this.backgroundExecutor = backgroundExecutor; + this.contactsPreferences = new ContactsPreferences(appContext); } /** @@ -113,10 +115,16 @@ public final class SpeedDialUiItemLoader { @WorkerThread private ImmutableList<SpeedDialUiItem> insertNewContactEntry(Uri contactUri) { Assert.isWorkerThread(); + contactsPreferences.refreshValue(ContactsPreferences.DISPLAY_ORDER_KEY); try (Cursor cursor = appContext .getContentResolver() - .query(contactUri, SpeedDialUiItem.PHONE_PROJECTION, null, null, null)) { + .query( + contactUri, + SpeedDialUiItem.getPhoneProjection(isPrimaryDisplayNameOrder()), + null, + null, + null)) { if (cursor == null) { LogUtil.e("SpeedDialUiItemLoader.insertNewContactEntry", "Cursor was null"); return loadSpeedDialUiItemsInternal(); @@ -152,6 +160,7 @@ public final class SpeedDialUiItemLoader { @WorkerThread private ImmutableList<SpeedDialUiItem> loadSpeedDialUiItemsInternal() { Assert.isWorkerThread(); + contactsPreferences.refreshValue(ContactsPreferences.DISPLAY_ORDER_KEY); SpeedDialEntryDao db = getSpeedDialEntryDao(); // This is the list of contacts that we will display to the user @@ -280,7 +289,7 @@ public final class SpeedDialUiItemLoader { List<SpeedDialEntry> entries) { Assert.isWorkerThread(); // Fetch the contact ids from the SpeedDialEntries - Set<String> contactIds = new HashSet<>(); + Set<String> contactIds = new ArraySet<>(); entries.forEach(entry -> contactIds.add(Long.toString(entry.contactId()))); if (contactIds.isEmpty()) { return new ArrayMap<>(); @@ -294,7 +303,7 @@ public final class SpeedDialUiItemLoader { .getContentResolver() .query( Phone.CONTENT_URI, - SpeedDialUiItem.PHONE_PROJECTION, + SpeedDialUiItem.getPhoneProjection(isPrimaryDisplayNameOrder()), selection.getSelection(), selection.getSelectionArgs(), null)) { @@ -388,7 +397,7 @@ public final class SpeedDialUiItemLoader { .getContentResolver() .query( Phone.CONTENT_URI, - SpeedDialUiItem.PHONE_PROJECTION, + SpeedDialUiItem.getPhoneProjection(isPrimaryDisplayNameOrder()), selection.getSelection(), selection.getSelectionArgs(), null)) { @@ -476,4 +485,8 @@ public final class SpeedDialUiItemLoader { private SpeedDialEntryDao getSpeedDialEntryDao() { return new SpeedDialEntryDatabaseHelper(appContext); } + + private boolean isPrimaryDisplayNameOrder() { + return contactsPreferences.getDisplayOrder() == ContactsPreferences.DISPLAY_ORDER_PRIMARY; + } } |