mirror of
https://github.com/oxen-io/session-android.git
synced 2025-02-17 15:38:27 +00:00
Show groups when searching for contacts.
Currently, if you're searching for a contact to start a conversation with or send a share to (via the Android sharing system), groups do not appear. With this change, groups will now appear when searching, located under their own heading. Fixes #7202. Closes #7577
This commit is contained in:
parent
5dc5503896
commit
18039bc3f4
@ -90,6 +90,7 @@
|
|||||||
<!-- ContactsCursorLoader -->
|
<!-- ContactsCursorLoader -->
|
||||||
<string name="ContactsCursorLoader_recent_chats">Recent chats</string>
|
<string name="ContactsCursorLoader_recent_chats">Recent chats</string>
|
||||||
<string name="ContactsCursorLoader_contacts">Contacts</string>
|
<string name="ContactsCursorLoader_contacts">Contacts</string>
|
||||||
|
<string name="ContactsCursorLoader_groups">Groups</string>
|
||||||
|
|
||||||
<!-- ContactsDatabase -->
|
<!-- ContactsDatabase -->
|
||||||
<string name="ContactsDatabase_message_s">Message %s</string>
|
<string name="ContactsDatabase_message_s">Message %s</string>
|
||||||
|
@ -23,6 +23,7 @@ import android.support.v4.widget.SwipeRefreshLayout;
|
|||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
|
||||||
import org.thoughtcrime.securesms.components.ContactFilterToolbar;
|
import org.thoughtcrime.securesms.components.ContactFilterToolbar;
|
||||||
|
import org.thoughtcrime.securesms.contacts.ContactsCursorLoader.DisplayMode;
|
||||||
import org.thoughtcrime.securesms.util.DirectoryHelper;
|
import org.thoughtcrime.securesms.util.DirectoryHelper;
|
||||||
import org.thoughtcrime.securesms.util.DynamicLanguage;
|
import org.thoughtcrime.securesms.util.DynamicLanguage;
|
||||||
import org.thoughtcrime.securesms.util.DynamicNoActionBarTheme;
|
import org.thoughtcrime.securesms.util.DynamicNoActionBarTheme;
|
||||||
@ -61,10 +62,9 @@ public abstract class ContactSelectionActivity extends PassphraseRequiredActionB
|
|||||||
@Override
|
@Override
|
||||||
protected void onCreate(Bundle icicle, boolean ready) {
|
protected void onCreate(Bundle icicle, boolean ready) {
|
||||||
if (!getIntent().hasExtra(ContactSelectionListFragment.DISPLAY_MODE)) {
|
if (!getIntent().hasExtra(ContactSelectionListFragment.DISPLAY_MODE)) {
|
||||||
getIntent().putExtra(ContactSelectionListFragment.DISPLAY_MODE,
|
int displayMode = TextSecurePreferences.isSmsEnabled(this) ? DisplayMode.FLAG_ALL
|
||||||
TextSecurePreferences.isSmsEnabled(this)
|
: DisplayMode.FLAG_PUSH | DisplayMode.FLAG_GROUPS;
|
||||||
? ContactSelectionListFragment.DISPLAY_MODE_ALL
|
getIntent().putExtra(ContactSelectionListFragment.DISPLAY_MODE, displayMode);
|
||||||
: ContactSelectionListFragment.DISPLAY_MODE_PUSH_ONLY);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
setContentView(R.layout.contact_selection_activity);
|
setContentView(R.layout.contact_selection_activity);
|
||||||
|
@ -45,6 +45,7 @@ import org.thoughtcrime.securesms.components.RecyclerViewFastScroller;
|
|||||||
import org.thoughtcrime.securesms.contacts.ContactSelectionListAdapter;
|
import org.thoughtcrime.securesms.contacts.ContactSelectionListAdapter;
|
||||||
import org.thoughtcrime.securesms.contacts.ContactSelectionListItem;
|
import org.thoughtcrime.securesms.contacts.ContactSelectionListItem;
|
||||||
import org.thoughtcrime.securesms.contacts.ContactsCursorLoader;
|
import org.thoughtcrime.securesms.contacts.ContactsCursorLoader;
|
||||||
|
import org.thoughtcrime.securesms.contacts.ContactsCursorLoader.DisplayMode;
|
||||||
import org.thoughtcrime.securesms.database.CursorRecyclerViewAdapter;
|
import org.thoughtcrime.securesms.database.CursorRecyclerViewAdapter;
|
||||||
import org.thoughtcrime.securesms.mms.GlideApp;
|
import org.thoughtcrime.securesms.mms.GlideApp;
|
||||||
import org.thoughtcrime.securesms.permissions.Permissions;
|
import org.thoughtcrime.securesms.permissions.Permissions;
|
||||||
@ -75,12 +76,7 @@ public class ContactSelectionListFragment extends Fragment
|
|||||||
public static final String REFRESHABLE = "refreshable";
|
public static final String REFRESHABLE = "refreshable";
|
||||||
public static final String RECENTS = "recents";
|
public static final String RECENTS = "recents";
|
||||||
|
|
||||||
public final static int DISPLAY_MODE_ALL = ContactsCursorLoader.MODE_ALL;
|
private TextView emptyText;
|
||||||
public final static int DISPLAY_MODE_PUSH_ONLY = ContactsCursorLoader.MODE_PUSH_ONLY;
|
|
||||||
public final static int DISPLAY_MODE_SMS_ONLY = ContactsCursorLoader.MODE_SMS_ONLY;
|
|
||||||
|
|
||||||
private TextView emptyText;
|
|
||||||
|
|
||||||
private Set<String> selectedContacts;
|
private Set<String> selectedContacts;
|
||||||
private OnContactSelectedListener onContactSelectedListener;
|
private OnContactSelectedListener onContactSelectedListener;
|
||||||
private SwipeRefreshLayout swipeRefresh;
|
private SwipeRefreshLayout swipeRefresh;
|
||||||
@ -221,7 +217,7 @@ public class ContactSelectionListFragment extends Fragment
|
|||||||
@Override
|
@Override
|
||||||
public Loader<Cursor> onCreateLoader(int id, Bundle args) {
|
public Loader<Cursor> onCreateLoader(int id, Bundle args) {
|
||||||
return new ContactsCursorLoader(getActivity(),
|
return new ContactsCursorLoader(getActivity(),
|
||||||
getActivity().getIntent().getIntExtra(DISPLAY_MODE, DISPLAY_MODE_ALL),
|
getActivity().getIntent().getIntExtra(DISPLAY_MODE, DisplayMode.FLAG_ALL),
|
||||||
cursorFilter, getActivity().getIntent().getBooleanExtra(RECENTS, false));
|
cursorFilter, getActivity().getIntent().getBooleanExtra(RECENTS, false));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -44,6 +44,7 @@ import com.soundcloud.android.crop.Crop;
|
|||||||
|
|
||||||
import org.thoughtcrime.securesms.components.PushRecipientsPanel;
|
import org.thoughtcrime.securesms.components.PushRecipientsPanel;
|
||||||
import org.thoughtcrime.securesms.components.PushRecipientsPanel.RecipientsPanelChangedListener;
|
import org.thoughtcrime.securesms.components.PushRecipientsPanel.RecipientsPanelChangedListener;
|
||||||
|
import org.thoughtcrime.securesms.contacts.ContactsCursorLoader.DisplayMode;
|
||||||
import org.thoughtcrime.securesms.contacts.RecipientsEditor;
|
import org.thoughtcrime.securesms.contacts.RecipientsEditor;
|
||||||
import org.thoughtcrime.securesms.contacts.avatars.ContactColors;
|
import org.thoughtcrime.securesms.contacts.avatars.ContactColors;
|
||||||
import org.thoughtcrime.securesms.contacts.avatars.ResourceContactPhoto;
|
import org.thoughtcrime.securesms.contacts.avatars.ResourceContactPhoto;
|
||||||
@ -314,8 +315,11 @@ public class GroupCreateActivity extends PassphraseRequiredActionBarActivity
|
|||||||
@Override
|
@Override
|
||||||
public void onClick(View v) {
|
public void onClick(View v) {
|
||||||
Intent intent = new Intent(GroupCreateActivity.this, PushContactSelectionActivity.class);
|
Intent intent = new Intent(GroupCreateActivity.this, PushContactSelectionActivity.class);
|
||||||
if (groupToUpdate.isPresent()) intent.putExtra(ContactSelectionListFragment.DISPLAY_MODE,
|
if (groupToUpdate.isPresent()) {
|
||||||
ContactSelectionListFragment.DISPLAY_MODE_PUSH_ONLY);
|
intent.putExtra(ContactSelectionListFragment.DISPLAY_MODE, DisplayMode.FLAG_PUSH);
|
||||||
|
} else {
|
||||||
|
intent.putExtra(ContactSelectionListFragment.DISPLAY_MODE, DisplayMode.FLAG_PUSH | DisplayMode.FLAG_SMS);
|
||||||
|
}
|
||||||
startActivityForResult(intent, PICK_CONTACT);
|
startActivityForResult(intent, PICK_CONTACT);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -26,6 +26,7 @@ import android.widget.Toast;
|
|||||||
|
|
||||||
import org.thoughtcrime.securesms.components.ContactFilterToolbar;
|
import org.thoughtcrime.securesms.components.ContactFilterToolbar;
|
||||||
import org.thoughtcrime.securesms.components.ContactFilterToolbar.OnFilterChangedListener;
|
import org.thoughtcrime.securesms.components.ContactFilterToolbar.OnFilterChangedListener;
|
||||||
|
import org.thoughtcrime.securesms.contacts.ContactsCursorLoader.DisplayMode;
|
||||||
import org.thoughtcrime.securesms.database.Address;
|
import org.thoughtcrime.securesms.database.Address;
|
||||||
import org.thoughtcrime.securesms.database.DatabaseFactory;
|
import org.thoughtcrime.securesms.database.DatabaseFactory;
|
||||||
import org.thoughtcrime.securesms.recipients.Recipient;
|
import org.thoughtcrime.securesms.recipients.Recipient;
|
||||||
@ -49,7 +50,7 @@ public class InviteActivity extends PassphraseRequiredActionBarActivity implemen
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onCreate(Bundle savedInstanceState, boolean ready) {
|
protected void onCreate(Bundle savedInstanceState, boolean ready) {
|
||||||
getIntent().putExtra(ContactSelectionListFragment.DISPLAY_MODE, ContactSelectionListFragment.DISPLAY_MODE_SMS_ONLY);
|
getIntent().putExtra(ContactSelectionListFragment.DISPLAY_MODE, DisplayMode.FLAG_SMS);
|
||||||
getIntent().putExtra(ContactSelectionListFragment.MULTI_SELECT, true);
|
getIntent().putExtra(ContactSelectionListFragment.MULTI_SELECT, true);
|
||||||
getIntent().putExtra(ContactSelectionListFragment.REFRESHABLE, false);
|
getIntent().putExtra(ContactSelectionListFragment.REFRESHABLE, false);
|
||||||
|
|
||||||
|
@ -38,6 +38,8 @@ import android.view.View;
|
|||||||
import android.widget.ImageView;
|
import android.widget.ImageView;
|
||||||
|
|
||||||
import org.thoughtcrime.securesms.components.SearchToolbar;
|
import org.thoughtcrime.securesms.components.SearchToolbar;
|
||||||
|
import org.thoughtcrime.securesms.contacts.ContactsCursorLoader;
|
||||||
|
import org.thoughtcrime.securesms.contacts.ContactsCursorLoader.DisplayMode;
|
||||||
import org.thoughtcrime.securesms.database.Address;
|
import org.thoughtcrime.securesms.database.Address;
|
||||||
import org.thoughtcrime.securesms.database.DatabaseFactory;
|
import org.thoughtcrime.securesms.database.DatabaseFactory;
|
||||||
import org.thoughtcrime.securesms.database.ThreadDatabase;
|
import org.thoughtcrime.securesms.database.ThreadDatabase;
|
||||||
@ -92,8 +94,8 @@ public class ShareActivity extends PassphraseRequiredActionBarActivity
|
|||||||
if (!getIntent().hasExtra(ContactSelectionListFragment.DISPLAY_MODE)) {
|
if (!getIntent().hasExtra(ContactSelectionListFragment.DISPLAY_MODE)) {
|
||||||
getIntent().putExtra(ContactSelectionListFragment.DISPLAY_MODE,
|
getIntent().putExtra(ContactSelectionListFragment.DISPLAY_MODE,
|
||||||
TextSecurePreferences.isSmsEnabled(this)
|
TextSecurePreferences.isSmsEnabled(this)
|
||||||
? ContactSelectionListFragment.DISPLAY_MODE_ALL
|
? DisplayMode.FLAG_ALL
|
||||||
: ContactSelectionListFragment.DISPLAY_MODE_PUSH_ONLY);
|
: DisplayMode.FLAG_PUSH | DisplayMode.FLAG_GROUPS);
|
||||||
}
|
}
|
||||||
|
|
||||||
getIntent().putExtra(ContactSelectionListFragment.REFRESHABLE, false);
|
getIntent().putExtra(ContactSelectionListFragment.REFRESHABLE, false);
|
||||||
|
@ -30,6 +30,7 @@ import android.util.Log;
|
|||||||
import org.thoughtcrime.securesms.R;
|
import org.thoughtcrime.securesms.R;
|
||||||
import org.thoughtcrime.securesms.database.Address;
|
import org.thoughtcrime.securesms.database.Address;
|
||||||
import org.thoughtcrime.securesms.database.DatabaseFactory;
|
import org.thoughtcrime.securesms.database.DatabaseFactory;
|
||||||
|
import org.thoughtcrime.securesms.database.GroupDatabase;
|
||||||
import org.thoughtcrime.securesms.database.RecipientDatabase;
|
import org.thoughtcrime.securesms.database.RecipientDatabase;
|
||||||
import org.thoughtcrime.securesms.database.ThreadDatabase;
|
import org.thoughtcrime.securesms.database.ThreadDatabase;
|
||||||
import org.thoughtcrime.securesms.database.model.ThreadRecord;
|
import org.thoughtcrime.securesms.database.model.ThreadRecord;
|
||||||
@ -38,6 +39,7 @@ import org.thoughtcrime.securesms.recipients.Recipient;
|
|||||||
import org.thoughtcrime.securesms.util.NumberUtil;
|
import org.thoughtcrime.securesms.util.NumberUtil;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* CursorLoader that initializes a ContactsDatabase instance
|
* CursorLoader that initializes a ContactsDatabase instance
|
||||||
@ -48,9 +50,12 @@ public class ContactsCursorLoader extends CursorLoader {
|
|||||||
|
|
||||||
private static final String TAG = ContactsCursorLoader.class.getSimpleName();
|
private static final String TAG = ContactsCursorLoader.class.getSimpleName();
|
||||||
|
|
||||||
public static final int MODE_ALL = 0;
|
public static final class DisplayMode {
|
||||||
public static final int MODE_PUSH_ONLY = 1;
|
public static final int FLAG_PUSH = 1;
|
||||||
public static final int MODE_SMS_ONLY = 2;
|
public static final int FLAG_SMS = 1 << 1;
|
||||||
|
public static final int FLAG_GROUPS = 1 << 2;
|
||||||
|
public static final int FLAG_ALL = FLAG_PUSH | FLAG_SMS | FLAG_GROUPS;
|
||||||
|
}
|
||||||
|
|
||||||
private static final String[] CONTACT_PROJECTION = new String[]{ContactsDatabase.NAME_COLUMN,
|
private static final String[] CONTACT_PROJECTION = new String[]{ContactsDatabase.NAME_COLUMN,
|
||||||
ContactsDatabase.NUMBER_COLUMN,
|
ContactsDatabase.NUMBER_COLUMN,
|
||||||
@ -59,9 +64,9 @@ public class ContactsCursorLoader extends CursorLoader {
|
|||||||
ContactsDatabase.CONTACT_TYPE_COLUMN};
|
ContactsDatabase.CONTACT_TYPE_COLUMN};
|
||||||
|
|
||||||
|
|
||||||
private final String filter;
|
private final String filter;
|
||||||
private final int mode;
|
private final int mode;
|
||||||
private final boolean recents;
|
private final boolean recents;
|
||||||
|
|
||||||
public ContactsCursorLoader(@NonNull Context context, int mode, String filter, boolean recents)
|
public ContactsCursorLoader(@NonNull Context context, int mode, String filter, boolean recents)
|
||||||
{
|
{
|
||||||
@ -74,55 +79,148 @@ public class ContactsCursorLoader extends CursorLoader {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Cursor loadInBackground() {
|
public Cursor loadInBackground() {
|
||||||
ContactsDatabase contactsDatabase = DatabaseFactory.getContactsDatabase(getContext());
|
List<Cursor> cursorList = TextUtils.isEmpty(filter) ? getUnfilteredResults()
|
||||||
ThreadDatabase threadDatabase = DatabaseFactory.getThreadDatabase(getContext());
|
: getFilteredResults();
|
||||||
ArrayList<Cursor> cursorList = new ArrayList<>(4);
|
if (cursorList.size() > 0) {
|
||||||
|
return new MergeCursor(cursorList.toArray(new Cursor[0]));
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
if (recents && TextUtils.isEmpty(filter)) {
|
private List<Cursor> getUnfilteredResults() {
|
||||||
try (Cursor recentConversations = DatabaseFactory.getThreadDatabase(getContext()).getRecentConversationList(5)) {
|
ArrayList<Cursor> cursorList = new ArrayList<>();
|
||||||
MatrixCursor synthesizedContacts = new MatrixCursor(CONTACT_PROJECTION);
|
|
||||||
synthesizedContacts.addRow(new Object[] {getContext().getString(R.string.ContactsCursorLoader_recent_chats), "", ContactsContract.CommonDataKinds.Phone.TYPE_MOBILE, "", ContactsDatabase.DIVIDER_TYPE});
|
|
||||||
|
|
||||||
ThreadDatabase.Reader reader = threadDatabase.readerFor(recentConversations);
|
if (recents) {
|
||||||
|
Cursor recentConversations = getRecentConversationsCursor();
|
||||||
|
if (recentConversations.getCount() > 0) {
|
||||||
|
cursorList.add(getRecentsHeaderCursor());
|
||||||
|
cursorList.add(recentConversations);
|
||||||
|
cursorList.add(getContactsHeaderCursor());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
cursorList.addAll(getContactsCursors());
|
||||||
|
return cursorList;
|
||||||
|
}
|
||||||
|
|
||||||
ThreadRecord threadRecord;
|
private List<Cursor> getFilteredResults() {
|
||||||
|
ArrayList<Cursor> cursorList = new ArrayList<>();
|
||||||
|
|
||||||
while ((threadRecord = reader.getNext()) != null) {
|
if (groupsEnabled(mode)) {
|
||||||
synthesizedContacts.addRow(new Object[] {threadRecord.getRecipient().toShortString(),
|
Cursor groups = getGroupsCursor();
|
||||||
threadRecord.getRecipient().getAddress().serialize(),
|
if (groups.getCount() > 0) {
|
||||||
ContactsContract.CommonDataKinds.Phone.TYPE_MOBILE,
|
List<Cursor> contacts = getContactsCursors();
|
||||||
"", ContactsDatabase.RECENT_TYPE});
|
if (!isCursorListEmpty(contacts)) {
|
||||||
|
cursorList.add(getContactsHeaderCursor());
|
||||||
|
cursorList.addAll(contacts);
|
||||||
|
cursorList.add(getGroupsHeaderCursor());
|
||||||
}
|
}
|
||||||
|
cursorList.add(groups);
|
||||||
synthesizedContacts.addRow(new Object[] {getContext().getString(R.string.ContactsCursorLoader_contacts), "", ContactsContract.CommonDataKinds.Phone.TYPE_MOBILE, "", ContactsDatabase.DIVIDER_TYPE});
|
} else {
|
||||||
if (synthesizedContacts.getCount() > 2) cursorList.add(synthesizedContacts);
|
cursorList.addAll(getContactsCursors());
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
cursorList.addAll(getContactsCursors());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Permissions.hasAny(getContext(), Manifest.permission.READ_CONTACTS, Manifest.permission.WRITE_CONTACTS)) {
|
if (NumberUtil.isValidSmsOrEmail(filter)) {
|
||||||
if (mode != MODE_SMS_ONLY) {
|
cursorList.add(getNewNumberCursor());
|
||||||
cursorList.add(contactsDatabase.queryTextSecureContacts(filter));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (mode == MODE_ALL) {
|
|
||||||
cursorList.add(contactsDatabase.querySystemContacts(filter));
|
|
||||||
} else if (mode == MODE_SMS_ONLY) {
|
|
||||||
cursorList.add(filterNonPushContacts(contactsDatabase.querySystemContacts(filter)));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!TextUtils.isEmpty(filter) && NumberUtil.isValidSmsOrEmail(filter)) {
|
return cursorList;
|
||||||
MatrixCursor newNumberCursor = new MatrixCursor(CONTACT_PROJECTION, 1);
|
}
|
||||||
|
|
||||||
newNumberCursor.addRow(new Object[] {getContext().getString(R.string.contact_selection_list__unknown_contact),
|
private Cursor getRecentsHeaderCursor() {
|
||||||
filter, ContactsContract.CommonDataKinds.Phone.TYPE_CUSTOM,
|
MatrixCursor recentsHeader = new MatrixCursor(CONTACT_PROJECTION);
|
||||||
"\u21e2", ContactsDatabase.NEW_TYPE});
|
recentsHeader.addRow(new Object[]{ getContext().getString(R.string.ContactsCursorLoader_recent_chats),
|
||||||
|
"",
|
||||||
|
ContactsContract.CommonDataKinds.Phone.TYPE_MOBILE,
|
||||||
|
"",
|
||||||
|
ContactsDatabase.DIVIDER_TYPE });
|
||||||
|
return recentsHeader;
|
||||||
|
}
|
||||||
|
|
||||||
cursorList.add(newNumberCursor);
|
private Cursor getContactsHeaderCursor() {
|
||||||
|
MatrixCursor contactsHeader = new MatrixCursor(CONTACT_PROJECTION, 1);
|
||||||
|
contactsHeader.addRow(new Object[] { getContext().getString(R.string.ContactsCursorLoader_contacts),
|
||||||
|
"",
|
||||||
|
ContactsContract.CommonDataKinds.Phone.TYPE_MOBILE,
|
||||||
|
"",
|
||||||
|
ContactsDatabase.DIVIDER_TYPE });
|
||||||
|
return contactsHeader;
|
||||||
|
}
|
||||||
|
|
||||||
|
private Cursor getGroupsHeaderCursor() {
|
||||||
|
MatrixCursor groupHeader = new MatrixCursor(CONTACT_PROJECTION, 1);
|
||||||
|
groupHeader.addRow(new Object[]{ getContext().getString(R.string.ContactsCursorLoader_groups),
|
||||||
|
"",
|
||||||
|
ContactsContract.CommonDataKinds.Phone.TYPE_MOBILE,
|
||||||
|
"",
|
||||||
|
ContactsDatabase.DIVIDER_TYPE });
|
||||||
|
return groupHeader;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private Cursor getRecentConversationsCursor() {
|
||||||
|
ThreadDatabase threadDatabase = DatabaseFactory.getThreadDatabase(getContext());
|
||||||
|
|
||||||
|
MatrixCursor recentConversations = new MatrixCursor(CONTACT_PROJECTION, 5);
|
||||||
|
try (Cursor rawConversations = threadDatabase.getRecentConversationList(5)) {
|
||||||
|
ThreadDatabase.Reader reader = threadDatabase.readerFor(rawConversations);
|
||||||
|
ThreadRecord threadRecord;
|
||||||
|
while ((threadRecord = reader.getNext()) != null) {
|
||||||
|
recentConversations.addRow(new Object[] { threadRecord.getRecipient().toShortString(),
|
||||||
|
threadRecord.getRecipient().getAddress().serialize(),
|
||||||
|
ContactsContract.CommonDataKinds.Phone.TYPE_MOBILE,
|
||||||
|
"",
|
||||||
|
ContactsDatabase.RECENT_TYPE });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return recentConversations;
|
||||||
|
}
|
||||||
|
|
||||||
|
private List<Cursor> getContactsCursors() {
|
||||||
|
ContactsDatabase contactsDatabase = DatabaseFactory.getContactsDatabase(getContext());
|
||||||
|
List<Cursor> cursorList = new ArrayList<>(2);
|
||||||
|
|
||||||
|
if (!Permissions.hasAny(getContext(), Manifest.permission.READ_CONTACTS, Manifest.permission.WRITE_CONTACTS)) {
|
||||||
|
return cursorList;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (cursorList.size() > 0) return new MergeCursor(cursorList.toArray(new Cursor[0]));
|
if (pushEnabled(mode)) {
|
||||||
else return null;
|
cursorList.add(contactsDatabase.queryTextSecureContacts(filter));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (pushEnabled(mode) && smsEnabled(mode)) {
|
||||||
|
cursorList.add(contactsDatabase.querySystemContacts(filter));
|
||||||
|
} else if (smsEnabled(mode)) {
|
||||||
|
cursorList.add(filterNonPushContacts(contactsDatabase.querySystemContacts(filter)));
|
||||||
|
}
|
||||||
|
return cursorList;
|
||||||
|
}
|
||||||
|
|
||||||
|
private Cursor getGroupsCursor() {
|
||||||
|
MatrixCursor groupContacts = new MatrixCursor(CONTACT_PROJECTION);
|
||||||
|
try (GroupDatabase.Reader reader = DatabaseFactory.getGroupDatabase(getContext()).getGroupsFilteredByTitle(filter)) {
|
||||||
|
GroupDatabase.GroupRecord groupRecord;
|
||||||
|
while ((groupRecord = reader.getNext()) != null) {
|
||||||
|
groupContacts.addRow(new Object[] { groupRecord.getTitle(),
|
||||||
|
groupRecord.getEncodedId(),
|
||||||
|
ContactsContract.CommonDataKinds.Phone.TYPE_CUSTOM,
|
||||||
|
"",
|
||||||
|
ContactsDatabase.NORMAL_TYPE });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return groupContacts;
|
||||||
|
}
|
||||||
|
|
||||||
|
private Cursor getNewNumberCursor() {
|
||||||
|
MatrixCursor newNumberCursor = new MatrixCursor(CONTACT_PROJECTION, 1);
|
||||||
|
newNumberCursor.addRow(new Object[] { getContext().getString(R.string.contact_selection_list__unknown_contact),
|
||||||
|
filter,
|
||||||
|
ContactsContract.CommonDataKinds.Phone.TYPE_CUSTOM,
|
||||||
|
"\u21e2",
|
||||||
|
ContactsDatabase.NEW_TYPE });
|
||||||
|
return newNumberCursor;
|
||||||
}
|
}
|
||||||
|
|
||||||
private @NonNull Cursor filterNonPushContacts(@NonNull Cursor cursor) {
|
private @NonNull Cursor filterNonPushContacts(@NonNull Cursor cursor) {
|
||||||
@ -147,4 +245,24 @@ public class ContactsCursorLoader extends CursorLoader {
|
|||||||
cursor.close();
|
cursor.close();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static boolean isCursorListEmpty(List<Cursor> list) {
|
||||||
|
int sum = 0;
|
||||||
|
for (Cursor cursor : list) {
|
||||||
|
sum += cursor.getCount();
|
||||||
|
}
|
||||||
|
return sum == 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static boolean pushEnabled(int mode) {
|
||||||
|
return (mode & DisplayMode.FLAG_PUSH) > 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static boolean smsEnabled(int mode) {
|
||||||
|
return (mode & DisplayMode.FLAG_SMS) > 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static boolean groupsEnabled(int mode) {
|
||||||
|
return (mode & DisplayMode.FLAG_GROUPS) > 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -22,6 +22,7 @@ import org.thoughtcrime.securesms.util.Util;
|
|||||||
import org.whispersystems.libsignal.util.guava.Optional;
|
import org.whispersystems.libsignal.util.guava.Optional;
|
||||||
import org.whispersystems.signalservice.api.messages.SignalServiceAttachmentPointer;
|
import org.whispersystems.signalservice.api.messages.SignalServiceAttachmentPointer;
|
||||||
|
|
||||||
|
import java.io.Closeable;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.security.NoSuchAlgorithmException;
|
import java.security.NoSuchAlgorithmException;
|
||||||
import java.security.SecureRandom;
|
import java.security.SecureRandom;
|
||||||
@ -304,7 +305,7 @@ public class GroupDatabase extends Database {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class Reader {
|
public static class Reader implements Closeable {
|
||||||
|
|
||||||
private final Cursor cursor;
|
private final Cursor cursor;
|
||||||
|
|
||||||
@ -338,6 +339,7 @@ public class GroupDatabase extends Database {
|
|||||||
cursor.getInt(cursor.getColumnIndexOrThrow(MMS)) == 1);
|
cursor.getInt(cursor.getColumnIndexOrThrow(MMS)) == 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public void close() {
|
public void close() {
|
||||||
if (this.cursor != null)
|
if (this.cursor != null)
|
||||||
this.cursor.close();
|
this.cursor.close();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user