Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (C) 2016 The Android Open Source Project |
| 3 | * |
| 4 | * Licensed under the Apache License, Version 2.0 (the "License"); |
| 5 | * you may not use this file except in compliance with the License. |
| 6 | * You may obtain a copy of the License at |
| 7 | * |
| 8 | * http://www.apache.org/licenses/LICENSE-2.0 |
| 9 | * |
| 10 | * Unless required by applicable law or agreed to in writing, software |
| 11 | * distributed under the License is distributed on an "AS IS" BASIS, |
| 12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 13 | * See the License for the specific language governing permissions and |
| 14 | * limitations under the License. |
| 15 | */ |
| 16 | |
| 17 | package com.android.contacts; |
| 18 | |
Walter Jang | 13710d5 | 2016-07-08 14:36:20 -0700 | [diff] [blame] | 19 | import android.accounts.Account; |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 20 | import android.app.FragmentManager; |
| 21 | import android.app.FragmentTransaction; |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 22 | import android.content.Intent; |
| 23 | import android.graphics.Color; |
| 24 | import android.graphics.PorterDuff; |
| 25 | import android.os.Bundle; |
Walter Jang | 13710d5 | 2016-07-08 14:36:20 -0700 | [diff] [blame] | 26 | import android.provider.ContactsContract.Intents; |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 27 | import android.support.annotation.LayoutRes; |
| 28 | import android.support.design.widget.NavigationView; |
Wenyi Wang | 8e73c36 | 2016-06-23 18:03:53 -0700 | [diff] [blame] | 29 | import android.support.v4.content.ContextCompat; |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 30 | import android.support.v4.view.GravityCompat; |
| 31 | import android.support.v4.widget.DrawerLayout; |
| 32 | import android.support.v7.app.ActionBarDrawerToggle; |
| 33 | import android.support.v7.app.AppCompatActivity; |
| 34 | import android.support.v7.widget.Toolbar; |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 35 | import android.util.Log; |
| 36 | import android.view.LayoutInflater; |
| 37 | import android.view.Menu; |
| 38 | import android.view.MenuItem; |
| 39 | import android.view.SubMenu; |
Wenyi Wang | 8e73c36 | 2016-06-23 18:03:53 -0700 | [diff] [blame] | 40 | import android.view.View; |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 41 | import android.view.ViewGroup; |
Gary Mai | f354d18 | 2016-07-25 13:59:30 -0700 | [diff] [blame] | 42 | import android.widget.LinearLayout; |
Walter Jang | 13710d5 | 2016-07-08 14:36:20 -0700 | [diff] [blame] | 43 | import android.widget.Toast; |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 44 | |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 45 | import com.android.contacts.activities.ActionBarAdapter; |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 46 | import com.android.contacts.common.ContactsUtils; |
Wenyi Wang | 8e73c36 | 2016-06-23 18:03:53 -0700 | [diff] [blame] | 47 | import com.android.contacts.common.compat.CompatUtils; |
Walter Jang | 9294263 | 2016-07-14 19:49:32 +0000 | [diff] [blame] | 48 | import com.android.contacts.common.list.AccountFilterActivity; |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 49 | import com.android.contacts.common.list.ContactListFilter; |
| 50 | import com.android.contacts.common.list.ContactListFilterController; |
Walter Jang | 13710d5 | 2016-07-08 14:36:20 -0700 | [diff] [blame] | 51 | import com.android.contacts.common.model.AccountTypeManager; |
| 52 | import com.android.contacts.common.model.account.AccountWithDataSet; |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 53 | import com.android.contacts.common.preference.ContactsPreferenceActivity; |
| 54 | import com.android.contacts.common.util.AccountFilterUtil; |
Walter Jang | 13710d5 | 2016-07-08 14:36:20 -0700 | [diff] [blame] | 55 | import com.android.contacts.common.util.AccountsListAdapter.AccountListFilter; |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 56 | import com.android.contacts.common.util.ImplicitIntentsUtil; |
Wenyi Wang | 92d7e51 | 2016-10-03 14:57:19 -0700 | [diff] [blame^] | 57 | import com.android.contacts.common.util.MaterialColorMapUtils; |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 58 | import com.android.contacts.common.util.ViewUtil; |
Gary Mai | 363af60 | 2016-09-28 10:01:23 -0700 | [diff] [blame] | 59 | import com.android.contacts.editor.ContactEditorFragment; |
Walter Jang | 55d0e71 | 2016-08-31 17:11:36 -0700 | [diff] [blame] | 60 | import com.android.contacts.editor.SelectAccountDialogFragment; |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 61 | import com.android.contacts.group.GroupListItem; |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 62 | import com.android.contacts.group.GroupMembersFragment; |
Walter Jang | 428824e | 2016-09-09 13:18:35 -0700 | [diff] [blame] | 63 | import com.android.contacts.group.GroupMetaData; |
Walter Jang | 13710d5 | 2016-07-08 14:36:20 -0700 | [diff] [blame] | 64 | import com.android.contacts.group.GroupNameEditDialogFragment; |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 65 | import com.android.contacts.group.GroupUtil; |
| 66 | import com.android.contacts.group.GroupsFragment; |
| 67 | import com.android.contacts.group.GroupsFragment.GroupsListener; |
| 68 | import com.android.contacts.interactions.AccountFiltersFragment; |
| 69 | import com.android.contacts.interactions.AccountFiltersFragment.AccountFiltersListener; |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 70 | import com.android.contacts.list.DefaultContactBrowseListFragment; |
| 71 | import com.android.contacts.list.MultiSelectContactsListFragment; |
Marcus Hagerott | fac695a | 2016-08-24 17:02:40 -0700 | [diff] [blame] | 72 | import com.android.contacts.common.model.account.AccountDisplayInfo; |
| 73 | import com.android.contacts.common.model.account.AccountDisplayInfoFactory; |
Tingting Wang | ac9596e | 2016-08-02 22:24:24 -0700 | [diff] [blame] | 74 | import com.android.contacts.util.SharedPreferenceUtil; |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 75 | import com.android.contactsbind.HelpUtils; |
Marcus Hagerott | 6caf23f | 2016-08-18 15:02:42 -0700 | [diff] [blame] | 76 | import com.android.contactsbind.ObjectFactory; |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 77 | |
Wenyi Wang | f8a5ab4 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 78 | import java.util.HashMap; |
| 79 | import java.util.Iterator; |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 80 | import java.util.List; |
Wenyi Wang | f8a5ab4 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 81 | import java.util.Map; |
| 82 | import java.util.Map.Entry; |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 83 | |
| 84 | /** |
| 85 | * A common superclass for Contacts activities with a navigation drawer. |
| 86 | */ |
| 87 | public abstract class ContactsDrawerActivity extends AppCompatContactsActivity implements |
| 88 | AccountFiltersListener, |
| 89 | GroupsListener, |
Walter Jang | 13710d5 | 2016-07-08 14:36:20 -0700 | [diff] [blame] | 90 | NavigationView.OnNavigationItemSelectedListener, |
Marcus Hagerott | 8d62cd2 | 2016-08-01 17:31:38 -0700 | [diff] [blame] | 91 | SelectAccountDialogFragment.Listener { |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 92 | |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 93 | /** Possible views of Contacts app. */ |
| 94 | public enum ContactsView { |
| 95 | NONE, |
| 96 | ALL_CONTACTS, |
| 97 | DUPLICATES, |
| 98 | GROUP_VIEW, |
| 99 | ACCOUNT_VIEW, |
| 100 | } |
| 101 | |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 102 | protected static String TAG = "ContactsDrawerActivity"; |
| 103 | |
Walter Jang | 13710d5 | 2016-07-08 14:36:20 -0700 | [diff] [blame] | 104 | private static final String TAG_GROUPS = "groups"; |
| 105 | private static final String TAG_FILTERS = "filters"; |
| 106 | private static final String TAG_SELECT_ACCOUNT_DIALOG = "selectAccountDialog"; |
| 107 | private static final String TAG_GROUP_NAME_EDIT_DIALOG = "groupNameEditDialog"; |
| 108 | |
| 109 | private static final String KEY_NEW_GROUP_ACCOUNT = "newGroupAccount"; |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 110 | private static final String KEY_CONTACTS_VIEW = "contactsView"; |
Walter Jang | 13710d5 | 2016-07-08 14:36:20 -0700 | [diff] [blame] | 111 | |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 112 | protected ContactsView mCurrentView; |
Wenyi Wang | 45c210a | 2016-07-15 10:51:52 -0700 | [diff] [blame] | 113 | |
Wenyi Wang | 8e73c36 | 2016-06-23 18:03:53 -0700 | [diff] [blame] | 114 | private class ContactsActionBarDrawerToggle extends ActionBarDrawerToggle { |
| 115 | |
| 116 | private Runnable mRunnable; |
Tingting Wang | ac9596e | 2016-08-02 22:24:24 -0700 | [diff] [blame] | 117 | private boolean mMenuClickedBefore = SharedPreferenceUtil.getHamburgerMenuClickedBefore( |
| 118 | ContactsDrawerActivity.this); |
Wenyi Wang | 8e73c36 | 2016-06-23 18:03:53 -0700 | [diff] [blame] | 119 | |
| 120 | public ContactsActionBarDrawerToggle(AppCompatActivity activity, DrawerLayout drawerLayout, |
| 121 | Toolbar toolbar, int openDrawerContentDescRes, int closeDrawerContentDescRes) { |
| 122 | super(activity, drawerLayout, toolbar, openDrawerContentDescRes, |
| 123 | closeDrawerContentDescRes); |
| 124 | } |
| 125 | |
| 126 | @Override |
| 127 | public void onDrawerOpened(View drawerView) { |
| 128 | super.onDrawerOpened(drawerView); |
Tingting Wang | ac9596e | 2016-08-02 22:24:24 -0700 | [diff] [blame] | 129 | if (!mMenuClickedBefore) { |
| 130 | SharedPreferenceUtil.setHamburgerMenuClickedBefore(ContactsDrawerActivity.this); |
| 131 | mMenuClickedBefore = true; |
| 132 | } |
Wenyi Wang | 8e73c36 | 2016-06-23 18:03:53 -0700 | [diff] [blame] | 133 | invalidateOptionsMenu(); |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 134 | // Stop search and selection mode like Gmail and Keep. Otherwise, if user switches to |
| 135 | // another fragment in navigation drawer, the current search/selection mode will be |
| 136 | // overlaid by the action bar of the newly-created fragment. |
| 137 | stopSearchAndSelection(); |
Wenyi Wang | 92d7e51 | 2016-10-03 14:57:19 -0700 | [diff] [blame^] | 138 | updateStatusBarBackground(); |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 139 | } |
| 140 | |
| 141 | private void stopSearchAndSelection() { |
| 142 | final MultiSelectContactsListFragment listFragment; |
| 143 | if (isAllContactsView() || isAccountView()) { |
| 144 | listFragment = getAllFragment(); |
| 145 | } else if (isGroupView()) { |
| 146 | listFragment = getGroupFragment(); |
| 147 | } else { |
| 148 | listFragment = null; |
| 149 | } |
| 150 | if (listFragment == null) { |
| 151 | return; |
| 152 | } |
| 153 | final ActionBarAdapter actionBarAdapter = listFragment.getActionBarAdapter(); |
| 154 | if (actionBarAdapter == null) { |
| 155 | return; |
| 156 | } |
| 157 | if (actionBarAdapter.isSearchMode()) { |
| 158 | actionBarAdapter.setSearchMode(false); |
| 159 | } else if (actionBarAdapter.isSelectionMode()) { |
| 160 | actionBarAdapter.setSelectionMode(false); |
| 161 | } |
Wenyi Wang | 8e73c36 | 2016-06-23 18:03:53 -0700 | [diff] [blame] | 162 | } |
| 163 | |
| 164 | @Override |
| 165 | public void onDrawerClosed(View view) { |
| 166 | super.onDrawerClosed(view); |
| 167 | invalidateOptionsMenu(); |
| 168 | } |
| 169 | |
| 170 | @Override |
| 171 | public void onDrawerStateChanged(int newState) { |
| 172 | super.onDrawerStateChanged(newState); |
| 173 | // Set transparent status bar when drawer starts to move. |
Wenyi Wang | f9289ec | 2016-06-28 19:40:38 -0700 | [diff] [blame] | 174 | if (newState != DrawerLayout.STATE_IDLE) { |
Wenyi Wang | 92d7e51 | 2016-10-03 14:57:19 -0700 | [diff] [blame^] | 175 | updateStatusBarBackground(); |
Wenyi Wang | 8e73c36 | 2016-06-23 18:03:53 -0700 | [diff] [blame] | 176 | } |
| 177 | if (mRunnable != null && newState == DrawerLayout.STATE_IDLE) { |
| 178 | mRunnable.run(); |
| 179 | mRunnable = null; |
| 180 | } |
| 181 | } |
| 182 | |
| 183 | public void runWhenIdle(Runnable runnable) { |
| 184 | mRunnable = runnable; |
| 185 | } |
| 186 | } |
| 187 | |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 188 | protected ContactListFilterController mContactListFilterController; |
| 189 | protected DrawerLayout mDrawer; |
Wenyi Wang | 8e73c36 | 2016-06-23 18:03:53 -0700 | [diff] [blame] | 190 | protected ContactsActionBarDrawerToggle mToggle; |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 191 | protected Toolbar mToolbar; |
| 192 | protected NavigationView mNavigationView; |
| 193 | protected GroupsFragment mGroupsFragment; |
| 194 | protected AccountFiltersFragment mAccountFiltersFragment; |
| 195 | |
Walter Jang | 13710d5 | 2016-07-08 14:36:20 -0700 | [diff] [blame] | 196 | // The account the new group will be created under. |
| 197 | private AccountWithDataSet mNewGroupAccount; |
| 198 | |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 199 | // Checkable menu item lookup maps. Every map declared here should be added to |
| 200 | // clearCheckedMenus() so that they can be cleared. |
| 201 | // TODO find a better way to handle selected menu item state, when switching to fragments. |
| 202 | protected Map<Long, MenuItem> mGroupMenuMap = new HashMap<>(); |
| 203 | protected Map<ContactListFilter, MenuItem> mFilterMenuMap = new HashMap<>(); |
| 204 | protected Map<Integer, MenuItem> mIdMenuMap = new HashMap<>(); |
Wenyi Wang | 45c210a | 2016-07-15 10:51:52 -0700 | [diff] [blame] | 205 | |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 206 | @Override |
| 207 | protected void onCreate(Bundle savedState) { |
| 208 | super.onCreate(savedState); |
| 209 | |
| 210 | mContactListFilterController = ContactListFilterController.getInstance(this); |
| 211 | mContactListFilterController.checkFilterValidity(false); |
| 212 | |
| 213 | super.setContentView(R.layout.contacts_drawer_activity); |
| 214 | |
| 215 | // Set up the action bar. |
| 216 | mToolbar = getView(R.id.toolbar); |
| 217 | setSupportActionBar(mToolbar); |
| 218 | |
| 219 | // Add shadow under toolbar. |
| 220 | ViewUtil.addRectangularOutlineProvider(findViewById(R.id.toolbar_parent), getResources()); |
| 221 | |
| 222 | // Set up hamburger button. |
| 223 | mDrawer = (DrawerLayout) findViewById(R.id.drawer_layout); |
Wenyi Wang | 8e73c36 | 2016-06-23 18:03:53 -0700 | [diff] [blame] | 224 | mToggle = new ContactsActionBarDrawerToggle(this, mDrawer, mToolbar, |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 225 | R.string.navigation_drawer_open, R.string.navigation_drawer_close); |
Wenyi Wang | 8e73c36 | 2016-06-23 18:03:53 -0700 | [diff] [blame] | 226 | mDrawer.setDrawerListener(mToggle); |
| 227 | mToggle.syncState(); |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 228 | |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 229 | // Set up navigation mode. |
| 230 | if (savedState != null) { |
| 231 | mCurrentView = ContactsView.values()[savedState.getInt(KEY_CONTACTS_VIEW)]; |
| 232 | } else { |
| 233 | mCurrentView = ContactsView.ALL_CONTACTS; |
| 234 | } |
| 235 | |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 236 | // Set up hamburger menu items. |
| 237 | mNavigationView = (NavigationView) findViewById(R.id.nav_view); |
| 238 | mNavigationView.setNavigationItemSelectedListener(this); |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 239 | setUpMenu(); |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 240 | |
Wenyi Wang | cb117bd | 2016-06-17 13:26:57 -0700 | [diff] [blame] | 241 | loadGroupsAndFilters(); |
Wenyi Wang | f8a5ab4 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 242 | |
Walter Jang | 13710d5 | 2016-07-08 14:36:20 -0700 | [diff] [blame] | 243 | if (savedState != null && savedState.containsKey(KEY_NEW_GROUP_ACCOUNT)) { |
| 244 | mNewGroupAccount = AccountWithDataSet.unstringify( |
| 245 | savedState.getString(KEY_NEW_GROUP_ACCOUNT)); |
| 246 | } |
| 247 | } |
| 248 | |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 249 | private void setUpMenu() { |
| 250 | final Menu menu = mNavigationView.getMenu(); |
| 251 | |
| 252 | if (ObjectFactory.getDuplicatesFragment() == null) { |
| 253 | menu.removeItem(R.id.nav_find_duplicates); |
| 254 | } else { |
| 255 | final MenuItem findDupMenu = menu.findItem(R.id.nav_find_duplicates); |
| 256 | mIdMenuMap.put(R.id.nav_find_duplicates, findDupMenu); |
| 257 | if (isDuplicatesView()) { |
| 258 | updateMenuSelection(findDupMenu); |
| 259 | } |
| 260 | } |
| 261 | |
| 262 | if (!HelpUtils.isHelpAndFeedbackAvailable()) { |
| 263 | menu.removeItem(R.id.nav_help); |
| 264 | } |
| 265 | |
| 266 | final MenuItem allContactsMenu = menu.findItem(R.id.nav_all_contacts); |
| 267 | mIdMenuMap.put(R.id.nav_all_contacts, allContactsMenu); |
| 268 | if (isAllContactsView()) { |
| 269 | updateMenuSelection(allContactsMenu); |
| 270 | } |
Wenyi Wang | 6927bf3 | 2016-08-15 18:31:24 -0700 | [diff] [blame] | 271 | } |
| 272 | |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 273 | public Toolbar getToolbar() { |
| 274 | return mToolbar; |
Wenyi Wang | 45c210a | 2016-07-15 10:51:52 -0700 | [diff] [blame] | 275 | } |
| 276 | |
Walter Jang | 13710d5 | 2016-07-08 14:36:20 -0700 | [diff] [blame] | 277 | @Override |
| 278 | protected void onSaveInstanceState(Bundle outState) { |
| 279 | super.onSaveInstanceState(outState); |
| 280 | if (mNewGroupAccount != null) { |
| 281 | outState.putString(KEY_NEW_GROUP_ACCOUNT, mNewGroupAccount.stringify()); |
| 282 | } |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 283 | outState.putInt(KEY_CONTACTS_VIEW, mCurrentView.ordinal()); |
Wenyi Wang | f8a5ab4 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 284 | } |
| 285 | |
Wenyi Wang | f9289ec | 2016-06-28 19:40:38 -0700 | [diff] [blame] | 286 | @Override |
| 287 | protected void onResume() { |
| 288 | super.onResume(); |
| 289 | if (mDrawer.isDrawerOpen(GravityCompat.START)) { |
Wenyi Wang | 92d7e51 | 2016-10-03 14:57:19 -0700 | [diff] [blame^] | 290 | updateStatusBarBackground(); |
Wenyi Wang | f9289ec | 2016-06-28 19:40:38 -0700 | [diff] [blame] | 291 | } |
| 292 | } |
| 293 | |
Wenyi Wang | 92d7e51 | 2016-10-03 14:57:19 -0700 | [diff] [blame^] | 294 | public void updateStatusBarBackground() { |
| 295 | updateStatusBarBackground(/* color */ -1); |
| 296 | } |
| 297 | |
| 298 | public void updateStatusBarBackground(int color) { |
| 299 | if (!CompatUtils.isLollipopCompatible()) return; |
| 300 | if (color == -1) { |
| 301 | mDrawer.setStatusBarBackgroundColor(MaterialColorMapUtils.getStatusBarColor(this)); |
| 302 | } else { |
| 303 | mDrawer.setStatusBarBackgroundColor(color); |
Wenyi Wang | f9289ec | 2016-06-28 19:40:38 -0700 | [diff] [blame] | 304 | } |
Wenyi Wang | 92d7e51 | 2016-10-03 14:57:19 -0700 | [diff] [blame^] | 305 | mDrawer.invalidate(); |
| 306 | getWindow().setStatusBarColor(Color.TRANSPARENT); |
Wenyi Wang | f9289ec | 2016-06-28 19:40:38 -0700 | [diff] [blame] | 307 | } |
| 308 | |
Wenyi Wang | cb117bd | 2016-06-17 13:26:57 -0700 | [diff] [blame] | 309 | // Set up fragment manager to load groups and filters. |
| 310 | protected void loadGroupsAndFilters() { |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 311 | final FragmentManager fragmentManager = getFragmentManager(); |
| 312 | final FragmentTransaction transaction = fragmentManager.beginTransaction(); |
| 313 | addGroupsAndFiltersFragments(transaction); |
| 314 | transaction.commitAllowingStateLoss(); |
| 315 | fragmentManager.executePendingTransactions(); |
| 316 | } |
| 317 | |
| 318 | @Override |
| 319 | public void setContentView(@LayoutRes int layoutResID) { |
| 320 | final ViewGroup parent = (ViewGroup) findViewById(R.id.content_frame); |
| 321 | if (parent != null) { |
| 322 | parent.removeAllViews(); |
| 323 | } |
| 324 | LayoutInflater.from(this).inflate(layoutResID, parent); |
| 325 | } |
| 326 | |
| 327 | protected void addGroupsAndFiltersFragments(FragmentTransaction transaction) { |
| 328 | final FragmentManager fragmentManager = getFragmentManager(); |
Walter Jang | 13710d5 | 2016-07-08 14:36:20 -0700 | [diff] [blame] | 329 | mGroupsFragment = (GroupsFragment) fragmentManager.findFragmentByTag(TAG_GROUPS); |
Walter Jang | 060f324 | 2016-09-07 15:23:22 -0700 | [diff] [blame] | 330 | if (mGroupsFragment == null) { |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 331 | mGroupsFragment = new GroupsFragment(); |
Walter Jang | 13710d5 | 2016-07-08 14:36:20 -0700 | [diff] [blame] | 332 | transaction.add(mGroupsFragment, TAG_GROUPS); |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 333 | } |
Walter Jang | 060f324 | 2016-09-07 15:23:22 -0700 | [diff] [blame] | 334 | mGroupsFragment.setListener(this); |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 335 | |
Walter Jang | 060f324 | 2016-09-07 15:23:22 -0700 | [diff] [blame] | 336 | mAccountFiltersFragment = (AccountFiltersFragment) |
| 337 | fragmentManager.findFragmentByTag(TAG_FILTERS); |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 338 | if (mAccountFiltersFragment == null) { |
| 339 | mAccountFiltersFragment = new AccountFiltersFragment(); |
Walter Jang | 13710d5 | 2016-07-08 14:36:20 -0700 | [diff] [blame] | 340 | transaction.add(mAccountFiltersFragment, TAG_FILTERS); |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 341 | } |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 342 | mAccountFiltersFragment.setListener(this); |
| 343 | } |
| 344 | |
| 345 | @Override |
| 346 | public void onGroupsLoaded(List<GroupListItem> groupListItems) { |
| 347 | final Menu menu = mNavigationView.getMenu(); |
| 348 | final MenuItem groupsMenuItem = menu.findItem(R.id.nav_groups); |
| 349 | final SubMenu subMenu = groupsMenuItem.getSubMenu(); |
| 350 | subMenu.removeGroup(R.id.nav_groups_items); |
Wenyi Wang | f8a5ab4 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 351 | mGroupMenuMap = new HashMap<>(); |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 352 | |
Walter Jang | 5a49696 | 2016-09-09 18:32:50 -0700 | [diff] [blame] | 353 | final GroupMetaData groupMetaData = getGroupMetaData(); |
Wenyi Wang | 45c210a | 2016-07-15 10:51:52 -0700 | [diff] [blame] | 354 | |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 355 | if (groupListItems != null) { |
| 356 | // Add each group |
| 357 | for (final GroupListItem groupListItem : groupListItems) { |
| 358 | if (GroupUtil.isEmptyFFCGroup(groupListItem)) { |
| 359 | continue; |
| 360 | } |
| 361 | final String title = groupListItem.getTitle(); |
| 362 | final MenuItem menuItem = |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 363 | subMenu.add(R.id.nav_groups_items, Menu.NONE, Menu.NONE, title); |
Wenyi Wang | f8a5ab4 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 364 | mGroupMenuMap.put(groupListItem.getGroupId(), menuItem); |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 365 | if (isGroupView() && groupMetaData != null |
| 366 | && groupMetaData.groupId == groupListItem.getGroupId()) { |
| 367 | updateMenuSelection(menuItem); |
| 368 | } |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 369 | menuItem.setIcon(R.drawable.ic_menu_label); |
| 370 | menuItem.setOnMenuItemClickListener(new MenuItem.OnMenuItemClickListener() { |
| 371 | @Override |
| 372 | public boolean onMenuItemClick(MenuItem item) { |
Wenyi Wang | 8e73c36 | 2016-06-23 18:03:53 -0700 | [diff] [blame] | 373 | mToggle.runWhenIdle(new Runnable() { |
| 374 | @Override |
| 375 | public void run() { |
Wenyi Wang | 8607705 | 2016-06-29 18:21:21 -0700 | [diff] [blame] | 376 | onGroupMenuItemClicked(groupListItem.getGroupId(), |
| 377 | groupListItem.getTitle()); |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 378 | updateMenuSelection(menuItem); |
Wenyi Wang | 8e73c36 | 2016-06-23 18:03:53 -0700 | [diff] [blame] | 379 | } |
| 380 | }); |
| 381 | mDrawer.closeDrawer(GravityCompat.START); |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 382 | return true; |
| 383 | } |
| 384 | }); |
| 385 | } |
| 386 | } |
| 387 | |
Wenyi Wang | cb117bd | 2016-06-17 13:26:57 -0700 | [diff] [blame] | 388 | // Don't show "Create new..." menu if there's no group-writable accounts available. |
| 389 | if (!ContactsUtils.areGroupWritableAccountsAvailable(this)) { |
| 390 | return; |
| 391 | } |
| 392 | |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 393 | // Create a menu item in the sub menu to add new groups |
Wenyi Wang | 45c210a | 2016-07-15 10:51:52 -0700 | [diff] [blame] | 394 | final MenuItem menuItem = subMenu.add(R.id.nav_groups_items, Menu.NONE, |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 395 | Menu.NONE, getString(R.string.menu_new_group_action_bar)); |
Wenyi Wang | 8cd7c5c | 2016-06-16 14:03:42 -0700 | [diff] [blame] | 396 | menuItem.setIcon(R.drawable.ic_add); |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 397 | menuItem.setOnMenuItemClickListener(new MenuItem.OnMenuItemClickListener() { |
| 398 | @Override |
| 399 | public boolean onMenuItemClick(MenuItem item) { |
Wenyi Wang | 8e73c36 | 2016-06-23 18:03:53 -0700 | [diff] [blame] | 400 | mToggle.runWhenIdle(new Runnable() { |
| 401 | @Override |
| 402 | public void run() { |
| 403 | onCreateGroupMenuItemClicked(); |
| 404 | } |
| 405 | }); |
| 406 | mDrawer.closeDrawer(GravityCompat.START); |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 407 | return true; |
| 408 | } |
| 409 | }); |
Wenyi Wang | f8a5ab4 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 410 | |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 411 | if (isGroupView() && groupMetaData != null) { |
| 412 | updateGroupMenu(groupMetaData); |
Wenyi Wang | f8a5ab4 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 413 | } |
| 414 | } |
| 415 | |
Walter Jang | 5a49696 | 2016-09-09 18:32:50 -0700 | [diff] [blame] | 416 | public void updateGroupMenu(GroupMetaData groupMetaData) { |
Wenyi Wang | f8a5ab4 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 417 | clearCheckedMenus(); |
Walter Jang | 428824e | 2016-09-09 13:18:35 -0700 | [diff] [blame] | 418 | if (groupMetaData != null && mGroupMenuMap != null |
| 419 | && mGroupMenuMap.get(groupMetaData.groupId) != null) { |
Walter Jang | 5a49696 | 2016-09-09 18:32:50 -0700 | [diff] [blame] | 420 | setMenuChecked(mGroupMenuMap.get(groupMetaData.groupId), true); |
Wenyi Wang | f8a5ab4 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 421 | } |
| 422 | } |
| 423 | |
Walter Jang | 428824e | 2016-09-09 13:18:35 -0700 | [diff] [blame] | 424 | protected GroupMetaData getGroupMetaData() { |
Wenyi Wang | f8a5ab4 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 425 | return null; |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 426 | } |
| 427 | |
Wenyi Wang | 92d7e51 | 2016-10-03 14:57:19 -0700 | [diff] [blame^] | 428 | public boolean isGroupView() { |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 429 | return mCurrentView == ContactsView.GROUP_VIEW; |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 430 | } |
| 431 | |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 432 | protected boolean isDuplicatesView() { |
| 433 | return mCurrentView == ContactsView.DUPLICATES; |
| 434 | } |
| 435 | |
| 436 | protected boolean isAllContactsView() { |
| 437 | return mCurrentView == ContactsView.ALL_CONTACTS; |
| 438 | } |
| 439 | |
| 440 | protected boolean isAccountView() { |
| 441 | return mCurrentView == ContactsView.ACCOUNT_VIEW; |
| 442 | } |
| 443 | |
| 444 | public boolean isInSecondLevel() { |
| 445 | return isGroupView() || isDuplicatesView(); |
| 446 | } |
| 447 | |
| 448 | protected abstract void onGroupMenuItemClicked(long groupId, String title); |
| 449 | |
Walter Jang | 1110d67 | 2016-07-25 17:55:12 +0000 | [diff] [blame] | 450 | protected void onCreateGroupMenuItemClicked() { |
Walter Jang | 13710d5 | 2016-07-08 14:36:20 -0700 | [diff] [blame] | 451 | // Select the account to create the group |
| 452 | final Bundle extras = getIntent().getExtras(); |
| 453 | final Account account = extras == null ? null : |
| 454 | (Account) extras.getParcelable(Intents.Insert.EXTRA_ACCOUNT); |
| 455 | if (account == null) { |
Walter Jang | 552e582 | 2016-09-10 12:03:24 -0700 | [diff] [blame] | 456 | selectAccountForNewGroup(); |
Walter Jang | 13710d5 | 2016-07-08 14:36:20 -0700 | [diff] [blame] | 457 | } else { |
| 458 | final String dataSet = extras == null |
| 459 | ? null : extras.getString(Intents.Insert.EXTRA_DATA_SET); |
| 460 | final AccountWithDataSet accountWithDataSet = new AccountWithDataSet( |
| 461 | account.name, account.type, dataSet); |
| 462 | onAccountChosen(accountWithDataSet, /* extraArgs */ null); |
| 463 | } |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 464 | } |
| 465 | |
| 466 | @Override |
| 467 | public void onFiltersLoaded(List<ContactListFilter> accountFilterItems) { |
Marcus Hagerott | fac695a | 2016-08-24 17:02:40 -0700 | [diff] [blame] | 468 | final AccountDisplayInfoFactory accountDisplayFactory = AccountDisplayInfoFactory. |
| 469 | fromListFilters(this, accountFilterItems); |
| 470 | |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 471 | final Menu menu = mNavigationView.getMenu(); |
| 472 | final MenuItem filtersMenuItem = menu.findItem(R.id.nav_filters); |
| 473 | final SubMenu subMenu = filtersMenuItem.getSubMenu(); |
| 474 | subMenu.removeGroup(R.id.nav_filters_items); |
Wenyi Wang | f8a5ab4 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 475 | mFilterMenuMap = new HashMap<>(); |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 476 | |
| 477 | if (accountFilterItems == null || accountFilterItems.size() < 2) { |
| 478 | return; |
| 479 | } |
| 480 | |
Marcus Hagerott | 6caf23f | 2016-08-18 15:02:42 -0700 | [diff] [blame] | 481 | |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 482 | for (int i = 0; i < accountFilterItems.size(); i++) { |
| 483 | final ContactListFilter filter = accountFilterItems.get(i); |
Marcus Hagerott | fac695a | 2016-08-24 17:02:40 -0700 | [diff] [blame] | 484 | final AccountDisplayInfo displayableAccount = |
| 485 | accountDisplayFactory.getAccountDisplayInfoFor(filter); |
| 486 | final CharSequence menuName = displayableAccount.getNameLabel(); |
Wenyi Wang | 45c210a | 2016-07-15 10:51:52 -0700 | [diff] [blame] | 487 | final MenuItem menuItem = subMenu.add(R.id.nav_filters_items, Menu.NONE, |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 488 | Menu.NONE, menuName); |
| 489 | if (isAccountView() && filter == mContactListFilterController.getFilter()) { |
| 490 | updateMenuSelection(menuItem); |
| 491 | } |
Wenyi Wang | f8a5ab4 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 492 | mFilterMenuMap.put(filter, menuItem); |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 493 | final Intent intent = new Intent(); |
Walter Jang | 9294263 | 2016-07-14 19:49:32 +0000 | [diff] [blame] | 494 | intent.putExtra(AccountFilterActivity.EXTRA_CONTACT_LIST_FILTER, filter); |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 495 | menuItem.setOnMenuItemClickListener(new MenuItem.OnMenuItemClickListener() { |
| 496 | @Override |
| 497 | public boolean onMenuItemClick(MenuItem item) { |
Wenyi Wang | 8e73c36 | 2016-06-23 18:03:53 -0700 | [diff] [blame] | 498 | mToggle.runWhenIdle(new Runnable() { |
| 499 | @Override |
| 500 | public void run() { |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 501 | onFilterMenuItemClicked(intent); |
| 502 | updateMenuSelection(menuItem); |
Wenyi Wang | 8e73c36 | 2016-06-23 18:03:53 -0700 | [diff] [blame] | 503 | } |
| 504 | }); |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 505 | mDrawer.closeDrawer(GravityCompat.START); |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 506 | return true; |
| 507 | } |
| 508 | }); |
Walter Jang | 98d41d7 | 2016-09-15 13:12:51 -0700 | [diff] [blame] | 509 | if (displayableAccount.getIcon() != null) { |
| 510 | menuItem.setIcon(displayableAccount.getIcon()); |
| 511 | // Get rid of the default menu item overlay and show original account icons. |
| 512 | menuItem.getIcon().setColorFilter(Color.TRANSPARENT, PorterDuff.Mode.SRC_ATOP); |
| 513 | } |
Gary Mai | f354d18 | 2016-07-25 13:59:30 -0700 | [diff] [blame] | 514 | // Create a dummy action view to attach extra hidden content description to the menuItem |
| 515 | // for Talkback. We want Talkback to read out the account type but not have it be part |
| 516 | // of the menuItem title. |
Gary Mai | f354d18 | 2016-07-25 13:59:30 -0700 | [diff] [blame] | 517 | LinearLayout view = (LinearLayout) LayoutInflater.from(this) |
| 518 | .inflate(R.layout.account_type_info, null); |
Marcus Hagerott | fac695a | 2016-08-24 17:02:40 -0700 | [diff] [blame] | 519 | view.setContentDescription(displayableAccount.getTypeLabel()); |
Gary Mai | f354d18 | 2016-07-25 13:59:30 -0700 | [diff] [blame] | 520 | view.setVisibility(View.VISIBLE); |
| 521 | menuItem.setActionView(view); |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 522 | } |
Wenyi Wang | f8a5ab4 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 523 | |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 524 | if (isAccountView()) { |
| 525 | updateFilterMenu(mContactListFilterController.getFilter()); |
Wenyi Wang | f8a5ab4 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 526 | } |
| 527 | } |
| 528 | |
Wenyi Wang | 587b8f2 | 2016-08-17 17:40:45 -0700 | [diff] [blame] | 529 | public void updateFilterMenu(ContactListFilter filter) { |
Wenyi Wang | f8a5ab4 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 530 | clearCheckedMenus(); |
Wenyi Wang | cc8f272 | 2016-09-07 14:52:32 -0700 | [diff] [blame] | 531 | if (filter != null && filter.isContactsFilterType()) { |
Wenyi Wang | f8a5ab4 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 532 | if (mIdMenuMap != null && mIdMenuMap.get(R.id.nav_all_contacts) != null) { |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 533 | setMenuChecked(mIdMenuMap.get(R.id.nav_all_contacts), true); |
Wenyi Wang | f8a5ab4 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 534 | } |
| 535 | } else { |
| 536 | if (mFilterMenuMap != null && mFilterMenuMap.get(filter) != null) { |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 537 | setMenuChecked(mFilterMenuMap.get(filter), true); |
Wenyi Wang | f8a5ab4 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 538 | } |
| 539 | } |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 540 | } |
| 541 | |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 542 | protected void onFilterMenuItemClicked(Intent intent) { |
| 543 | AccountFilterUtil.handleAccountFilterResult(mContactListFilterController, |
| 544 | AppCompatActivity.RESULT_OK, intent); |
Wenyi Wang | f8a5ab4 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 545 | } |
| 546 | |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 547 | @Override |
Wenyi Wang | 8e73c36 | 2016-06-23 18:03:53 -0700 | [diff] [blame] | 548 | public boolean onNavigationItemSelected(final MenuItem item) { |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 549 | final int id = item.getItemId(); |
Wenyi Wang | 8e73c36 | 2016-06-23 18:03:53 -0700 | [diff] [blame] | 550 | mToggle.runWhenIdle(new Runnable() { |
| 551 | @Override |
| 552 | public void run() { |
| 553 | if (id == R.id.nav_settings) { |
| 554 | startActivity(createPreferenceIntent()); |
| 555 | } else if (id == R.id.nav_help) { |
| 556 | HelpUtils.launchHelpAndFeedbackForMainScreen(ContactsDrawerActivity.this); |
| 557 | } else if (id == R.id.nav_all_contacts) { |
| 558 | switchToAllContacts(); |
Wenyi Wang | 8e73c36 | 2016-06-23 18:03:53 -0700 | [diff] [blame] | 559 | } else if (id == R.id.nav_find_duplicates) { |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 560 | if (!isDuplicatesView()) { |
| 561 | launchFindDuplicates(); |
| 562 | updateMenuSelection(item); |
| 563 | } |
Wenyi Wang | 8e73c36 | 2016-06-23 18:03:53 -0700 | [diff] [blame] | 564 | } else if (item.getIntent() != null) { |
| 565 | ImplicitIntentsUtil.startActivityInApp(ContactsDrawerActivity.this, |
| 566 | item.getIntent()); |
| 567 | } else { |
| 568 | Log.w(TAG, "Unhandled navigation view item selection"); |
| 569 | } |
| 570 | } |
| 571 | }); |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 572 | |
| 573 | mDrawer.closeDrawer(GravityCompat.START); |
| 574 | return true; |
| 575 | } |
| 576 | |
| 577 | private Intent createPreferenceIntent() { |
| 578 | final Intent intent = new Intent(this, ContactsPreferenceActivity.class); |
| 579 | intent.putExtra(ContactsPreferenceActivity.EXTRA_NEW_LOCAL_PROFILE, |
Gary Mai | 363af60 | 2016-09-28 10:01:23 -0700 | [diff] [blame] | 580 | ContactEditorFragment.INTENT_EXTRA_NEW_LOCAL_PROFILE); |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 581 | return intent; |
| 582 | } |
| 583 | |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 584 | public void switchToAllContacts() { |
Wenyi Wang | cc8f272 | 2016-09-07 14:52:32 -0700 | [diff] [blame] | 585 | resetFilter(); |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 586 | |
| 587 | final Menu menu = mNavigationView.getMenu(); |
| 588 | final MenuItem allContacts = menu.findItem(R.id.nav_all_contacts); |
| 589 | updateMenuSelection(allContacts); |
| 590 | |
| 591 | setTitle(getString(R.string.contactsList)); |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 592 | } |
| 593 | |
Wenyi Wang | 32912eb | 2016-09-29 17:17:07 -0700 | [diff] [blame] | 594 | private void resetFilter() { |
Wenyi Wang | cc8f272 | 2016-09-07 14:52:32 -0700 | [diff] [blame] | 595 | final Intent intent = new Intent(); |
| 596 | final ContactListFilter filter = AccountFilterUtil.createContactsFilter(this); |
| 597 | intent.putExtra(AccountFilterActivity.EXTRA_CONTACT_LIST_FILTER, filter); |
| 598 | AccountFilterUtil.handleAccountFilterResult( |
| 599 | mContactListFilterController, AppCompatActivity.RESULT_OK, intent); |
| 600 | } |
| 601 | |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 602 | protected abstract void launchFindDuplicates(); |
| 603 | |
| 604 | protected abstract DefaultContactBrowseListFragment getAllFragment(); |
| 605 | |
| 606 | protected abstract GroupMembersFragment getGroupFragment(); |
| 607 | |
| 608 | public abstract void showFabWithAnimation(boolean showFab); |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 609 | |
Wenyi Wang | f8a5ab4 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 610 | private void clearCheckedMenus() { |
| 611 | clearCheckedMenu(mFilterMenuMap); |
| 612 | clearCheckedMenu(mGroupMenuMap); |
| 613 | clearCheckedMenu(mIdMenuMap); |
| 614 | } |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 615 | |
Wenyi Wang | f8a5ab4 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 616 | private void clearCheckedMenu(Map<?, MenuItem> map) { |
| 617 | final Iterator it = map.entrySet().iterator(); |
| 618 | while (it.hasNext()) { |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 619 | Entry pair = (Entry) it.next(); |
| 620 | setMenuChecked(map.get(pair.getKey()), false); |
Wenyi Wang | f8a5ab4 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 621 | } |
| 622 | } |
Walter Jang | 13710d5 | 2016-07-08 14:36:20 -0700 | [diff] [blame] | 623 | |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 624 | private void setMenuChecked(MenuItem menuItem, boolean checked) { |
| 625 | menuItem.setCheckable(checked); |
| 626 | menuItem.setChecked(checked); |
| 627 | } |
| 628 | |
Walter Jang | 552e582 | 2016-09-10 12:03:24 -0700 | [diff] [blame] | 629 | private void selectAccountForNewGroup() { |
Walter Jang | 13710d5 | 2016-07-08 14:36:20 -0700 | [diff] [blame] | 630 | final List<AccountWithDataSet> accounts = AccountTypeManager.getInstance(this) |
Walter Jang | 552e582 | 2016-09-10 12:03:24 -0700 | [diff] [blame] | 631 | .getGroupWritableAccounts(); |
Walter Jang | 13710d5 | 2016-07-08 14:36:20 -0700 | [diff] [blame] | 632 | if (accounts.isEmpty()) { |
| 633 | // We shouldn't present the add group button if there are no writable accounts |
| 634 | // but check it since it's possible we are started with an Intent. |
| 635 | Toast.makeText(this, R.string.groupCreateFailedToast, Toast.LENGTH_SHORT).show(); |
| 636 | return; |
| 637 | } |
| 638 | // If there is a single writable account, use it w/o showing a dialog. |
| 639 | if (accounts.size() == 1) { |
| 640 | onAccountChosen(accounts.get(0), /* extraArgs */ null); |
| 641 | return; |
| 642 | } |
| 643 | SelectAccountDialogFragment.show(getFragmentManager(), null, |
| 644 | R.string.dialog_new_group_account, AccountListFilter.ACCOUNTS_GROUP_WRITABLE, |
| 645 | /* extraArgs */ null, TAG_SELECT_ACCOUNT_DIALOG); |
| 646 | } |
| 647 | |
| 648 | @Override |
| 649 | public void onAccountChosen(AccountWithDataSet account, Bundle extraArgs) { |
| 650 | mNewGroupAccount = account; |
Wenyi Wang | cc8f272 | 2016-09-07 14:52:32 -0700 | [diff] [blame] | 651 | GroupNameEditDialogFragment.newInstanceForCreation( |
| 652 | mNewGroupAccount, GroupUtil.ACTION_CREATE_GROUP) |
Marcus Hagerott | 8d62cd2 | 2016-08-01 17:31:38 -0700 | [diff] [blame] | 653 | .show(getFragmentManager(), TAG_GROUP_NAME_EDIT_DIALOG); |
Walter Jang | 13710d5 | 2016-07-08 14:36:20 -0700 | [diff] [blame] | 654 | } |
| 655 | |
| 656 | @Override |
| 657 | public void onAccountSelectorCancelled() { |
| 658 | } |
Wenyi Wang | 7967545 | 2016-08-17 10:43:28 -0700 | [diff] [blame] | 659 | |
| 660 | private void updateMenuSelection(MenuItem menuItem) { |
| 661 | clearCheckedMenus(); |
| 662 | setMenuChecked(menuItem, true); |
| 663 | } |
Wenyi Wang | bb22924 | 2016-05-25 16:04:13 -0700 | [diff] [blame] | 664 | } |