diff options
author | Brandon Maxwell <maxwelb@google.com> | 2016-04-22 22:15:58 +0000 |
---|---|---|
committer | android-build-merger <android-build-merger@google.com> | 2016-04-22 22:15:58 +0000 |
commit | ea29b6647bbb8ab2067b21bbf0d103da24c4b884 (patch) | |
tree | 1eb1394df94aee01f2ddcdc6532e4595cbb8f370 /src/com/android/dialer/filterednumber/BlockedNumbersFragment.java | |
parent | 4dfe1be35b1736aa7398c7774ad6c111e65a0b3a (diff) | |
parent | e27b1da7a4c4b3bfc1a22d0aa1db4c32c24ea478 (diff) |
Merge "Adding migrate promo to blocked numbers setting ui" into nyc-dev am: fd95466 am: 5fffba0
am: e27b1da
* commit 'e27b1da7a4c4b3bfc1a22d0aa1db4c32c24ea478':
Adding migrate promo to blocked numbers setting ui
Change-Id: I1871490040968ee816d30885db225cde78b05ade
Diffstat (limited to 'src/com/android/dialer/filterednumber/BlockedNumbersFragment.java')
-rw-r--r-- | src/com/android/dialer/filterednumber/BlockedNumbersFragment.java | 52 |
1 files changed, 43 insertions, 9 deletions
diff --git a/src/com/android/dialer/filterednumber/BlockedNumbersFragment.java b/src/com/android/dialer/filterednumber/BlockedNumbersFragment.java index 87ba8bef6..b64f18691 100644 --- a/src/com/android/dialer/filterednumber/BlockedNumbersFragment.java +++ b/src/com/android/dialer/filterednumber/BlockedNumbersFragment.java @@ -15,6 +15,8 @@ */ package com.android.dialer.filterednumber; +import com.google.common.base.MoreObjects; + import android.app.ListFragment; import android.app.LoaderManager; import android.content.Context; @@ -32,11 +34,12 @@ import android.view.ViewGroup; import android.widget.ImageView; import android.widget.TextView; -import com.android.contacts.common.compat.CompatUtils; import com.android.contacts.common.lettertiles.LetterTileDrawable; +import com.android.contacts.common.testing.NeededForTesting; import com.android.dialer.R; import com.android.dialer.compat.FilteredNumberCompat; import com.android.dialer.database.FilteredNumberContract; +import com.android.dialer.filterednumber.BlockedNumbersMigrator.Listener; import com.android.dialer.filterednumber.FilteredNumbersUtil.CheckForSendToVoicemailContactListener; import com.android.dialer.filterednumber.FilteredNumbersUtil.ImportSendToVoicemailContactsListener; import com.android.dialer.voicemail.VisualVoicemailEnabledChecker; @@ -46,9 +49,12 @@ public class BlockedNumbersFragment extends ListFragment VisualVoicemailEnabledChecker.Callback { private static final char ADD_BLOCKED_NUMBER_ICON_LETTER = '+'; + private BlockedNumbersMigrator blockedNumbersMigratorForTest; + protected View migratePromoView; + private TextView blockedNumbersText; + private TextView footerText; private BlockedNumbersAdapter mAdapter; private VisualVoicemailEnabledChecker mVoicemailEnabledChecker; - private View mImportSettings; private View mBlockedNumbersDisabledForEmergency; private View mBlockedNumberListDivider; @@ -81,6 +87,9 @@ public class BlockedNumbersFragment extends ListFragment } setListAdapter(mAdapter); + blockedNumbersText = (TextView) getListView().findViewById(R.id.blocked_number_text_view); + migratePromoView = getListView().findViewById(R.id.migrate_promo); + getListView().findViewById(R.id.migrate_promo_allow_button).setOnClickListener(this); mImportSettings = getListView().findViewById(R.id.import_settings); mBlockedNumbersDisabledForEmergency = getListView().findViewById(R.id.blocked_numbers_disabled_for_emergency); @@ -89,6 +98,8 @@ public class BlockedNumbersFragment extends ListFragment getListView().findViewById(R.id.view_numbers_button).setOnClickListener(this); getListView().findViewById(R.id.add_number_linear_layout).setOnClickListener(this); + footerText = (TextView) getActivity().findViewById( + R.id.blocked_number_footer_textview); mVoicemailEnabledChecker = new VisualVoicemailEnabledChecker(getContext(),this); mVoicemailEnabledChecker.asyncUpdate(); updateActiveVoicemailProvider(); @@ -124,13 +135,16 @@ public class BlockedNumbersFragment extends ListFragment // new blocked numbers from the Blocked Management UI. They will be shown a promo card // asking them to migrate to new blocking instead. if (FilteredNumberCompat.canUseNewFiltering()) { + migratePromoView.setVisibility(View.VISIBLE); + blockedNumbersText.setVisibility(View.GONE); getListView().findViewById(R.id.add_number_linear_layout).setVisibility(View.GONE); getListView().findViewById(R.id.add_number_linear_layout).setOnClickListener(null); - mBlockedNumberListDivider.setVisibility(View.INVISIBLE); - - mImportSettings.setSystemUiVisibility(View.GONE); + mBlockedNumberListDivider.setVisibility(View.GONE); + mImportSettings.setVisibility(View.GONE); getListView().findViewById(R.id.import_button).setOnClickListener(null); getListView().findViewById(R.id.view_numbers_button).setOnClickListener(null); + mBlockedNumbersDisabledForEmergency.setVisibility(View.GONE); + footerText.setVisibility(View.GONE); } else { FilteredNumbersUtil.checkForSendToVoicemailContact( getActivity(), new CheckForSendToVoicemailContactListener() { @@ -143,7 +157,9 @@ public class BlockedNumbersFragment extends ListFragment }); } - if (FilteredNumbersUtil.hasRecentEmergencyCall(getContext())) { + // All views except migrate and the block list are hidden when new filtering is available + if (!FilteredNumberCompat.canUseNewFiltering() + && FilteredNumbersUtil.hasRecentEmergencyCall(getContext())) { mBlockedNumbersDisabledForEmergency.setVisibility(View.VISIBLE); } else { mBlockedNumbersDisabledForEmergency.setVisibility(View.GONE); @@ -190,7 +206,8 @@ public class BlockedNumbersFragment extends ListFragment @Override public void onClick(final View view) { - BlockedNumbersSettingsActivity activity = (BlockedNumbersSettingsActivity) getActivity(); + final BlockedNumbersSettingsActivity activity = + (BlockedNumbersSettingsActivity) getActivity(); if (activity == null) { return; } @@ -208,8 +225,22 @@ public class BlockedNumbersFragment extends ListFragment mImportSettings.setVisibility(View.GONE); } }); + } else if (resId == R.id.migrate_promo_allow_button) { + view.setEnabled(false); + MoreObjects.firstNonNull(blockedNumbersMigratorForTest, + new BlockedNumbersMigrator(getContext().getContentResolver())) + .migrate(new Listener() { + @Override + public void onComplete() { + getContext().startActivity( + FilteredNumberCompat.createManageBlockedNumbersIntent(getContext())); + // Remove this activity from the backstack + activity.finish(); + } + }); } } + @Override public void onVisualVoicemailEnabledStatusChanged(boolean newStatus){ updateActiveVoicemailProvider(); @@ -219,12 +250,15 @@ public class BlockedNumbersFragment extends ListFragment if (getActivity() == null || getActivity().isFinishing()) { return; } - TextView footerText = (TextView) getActivity().findViewById( - R.id.blocked_number_footer_textview); if (mVoicemailEnabledChecker.isVisualVoicemailEnabled()) { footerText.setText(R.string.block_number_footer_message_vvm); } else { footerText.setText(R.string.block_number_footer_message_no_vvm); } } + + @NeededForTesting + void setBlockedNumbersMigratorForTest(BlockedNumbersMigrator blockedNumbersMigrator) { + blockedNumbersMigratorForTest = blockedNumbersMigrator; + } } |