Use ZenMode.getIconKey() and ZenIconLoader.getIcon() in Settings
Bug: 360399800 Bug: 361597532 Test: atest com.android.settings.notification.modes Flag: android.app.modes_ui Change-Id: I82baaeaaa0d722f8042c7ac6be33b8654418391f
This commit is contained in:
@@ -24,12 +24,14 @@ import android.view.ViewGroup;
|
|||||||
import android.widget.ImageView;
|
import android.widget.ImageView;
|
||||||
|
|
||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
|
import androidx.annotation.Nullable;
|
||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
import androidx.preference.PreferenceScreen;
|
import androidx.preference.PreferenceScreen;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.dashboard.DashboardFragment;
|
import com.android.settings.dashboard.DashboardFragment;
|
||||||
import com.android.settings.widget.EntityHeaderController;
|
import com.android.settings.widget.EntityHeaderController;
|
||||||
|
import com.android.settingslib.notification.modes.ZenIcon;
|
||||||
import com.android.settingslib.notification.modes.ZenIconLoader;
|
import com.android.settingslib.notification.modes.ZenIconLoader;
|
||||||
import com.android.settingslib.notification.modes.ZenMode;
|
import com.android.settingslib.notification.modes.ZenMode;
|
||||||
import com.android.settingslib.widget.LayoutPreference;
|
import com.android.settingslib.widget.LayoutPreference;
|
||||||
@@ -42,7 +44,7 @@ abstract class AbstractZenModeHeaderController extends AbstractZenModePreference
|
|||||||
|
|
||||||
private final DashboardFragment mFragment;
|
private final DashboardFragment mFragment;
|
||||||
private EntityHeaderController mHeaderController;
|
private EntityHeaderController mHeaderController;
|
||||||
private String mCurrentIconKey;
|
@Nullable private ZenIcon.Key mCurrentIconKey;
|
||||||
|
|
||||||
AbstractZenModeHeaderController(
|
AbstractZenModeHeaderController(
|
||||||
@NonNull Context context,
|
@NonNull Context context,
|
||||||
@@ -88,10 +90,10 @@ abstract class AbstractZenModeHeaderController extends AbstractZenModePreference
|
|||||||
if (!Objects.equal(mCurrentIconKey, zenMode.getIconKey())) {
|
if (!Objects.equal(mCurrentIconKey, zenMode.getIconKey())) {
|
||||||
mCurrentIconKey = zenMode.getIconKey();
|
mCurrentIconKey = zenMode.getIconKey();
|
||||||
FutureUtil.whenDone(
|
FutureUtil.whenDone(
|
||||||
zenMode.getIcon(mContext, ZenIconLoader.getInstance()),
|
ZenIconLoader.getInstance().getIcon(mContext, zenMode),
|
||||||
icon -> {
|
icon -> {
|
||||||
checkNotNull(mHeaderController)
|
checkNotNull(mHeaderController)
|
||||||
.setIcon(iconStylist.apply(icon))
|
.setIcon(iconStylist.apply(icon.drawable()))
|
||||||
.done(/* rebindActions= */ false);
|
.done(/* rebindActions= */ false);
|
||||||
iconView.jumpDrawablesToCurrentState(); // Skip animation on first load.
|
iconView.jumpDrawablesToCurrentState(); // Skip animation on first load.
|
||||||
},
|
},
|
||||||
|
@@ -34,7 +34,6 @@ import androidx.recyclerview.widget.RecyclerView;
|
|||||||
import androidx.recyclerview.widget.SimpleItemAnimator;
|
import androidx.recyclerview.widget.SimpleItemAnimator;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settingslib.notification.modes.ZenIconLoader;
|
|
||||||
import com.android.settingslib.notification.modes.ZenMode;
|
import com.android.settingslib.notification.modes.ZenMode;
|
||||||
import com.android.settingslib.widget.LayoutPreference;
|
import com.android.settingslib.widget.LayoutPreference;
|
||||||
|
|
||||||
@@ -87,10 +86,7 @@ class ZenModeIconPickerListPreferenceController extends AbstractZenModePreferenc
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
void updateState(Preference preference, @NonNull ZenMode zenMode) {
|
void updateState(Preference preference, @NonNull ZenMode zenMode) {
|
||||||
@DrawableRes int iconResId = zenMode.getRule().getIconResId();
|
@DrawableRes int iconResId = zenMode.getIconKey().resId();
|
||||||
if (iconResId == 0) {
|
|
||||||
iconResId = ZenIconLoader.getIconResourceIdFromType(zenMode.getType());
|
|
||||||
}
|
|
||||||
updateIconSelection(iconResId);
|
updateIconSelection(iconResId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -93,11 +93,11 @@ class ZenModesListItemPreference extends RestrictedPreference {
|
|||||||
|
|
||||||
setIconSize(ICON_SIZE_SMALL);
|
setIconSize(ICON_SIZE_SMALL);
|
||||||
FutureUtil.whenDone(
|
FutureUtil.whenDone(
|
||||||
mZenMode.getIcon(mContext, ZenIconLoader.getInstance()),
|
ZenIconLoader.getInstance().getIcon(mContext, mZenMode),
|
||||||
icon -> setIcon(
|
icon -> setIcon(
|
||||||
zenMode.isActive()
|
zenMode.isActive()
|
||||||
? IconUtil.applyAccentTint(mContext, icon)
|
? IconUtil.applyAccentTint(mContext, icon.drawable())
|
||||||
: IconUtil.applyNormalTint(mContext, icon)),
|
: IconUtil.applyNormalTint(mContext, icon.drawable())),
|
||||||
mContext.getMainExecutor());
|
mContext.getMainExecutor());
|
||||||
|
|
||||||
updateTextColor(zenMode);
|
updateTextColor(zenMode);
|
||||||
|
@@ -24,8 +24,11 @@ import android.platform.test.annotations.EnableFlags;
|
|||||||
import android.platform.test.flag.junit.SetFlagsRule;
|
import android.platform.test.flag.junit.SetFlagsRule;
|
||||||
|
|
||||||
import com.android.settingslib.notification.modes.TestModeBuilder;
|
import com.android.settingslib.notification.modes.TestModeBuilder;
|
||||||
|
import com.android.settingslib.notification.modes.ZenIconLoader;
|
||||||
import com.android.settingslib.notification.modes.ZenMode;
|
import com.android.settingslib.notification.modes.ZenMode;
|
||||||
|
|
||||||
|
import com.google.common.util.concurrent.MoreExecutors;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Rule;
|
import org.junit.Rule;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
@@ -47,6 +50,7 @@ public class ZenModesListItemPreferenceTest {
|
|||||||
public void setup() {
|
public void setup() {
|
||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
mContext = RuntimeEnvironment.application;
|
mContext = RuntimeEnvironment.application;
|
||||||
|
ZenIconLoader.setInstance(new ZenIconLoader(MoreExecutors.newDirectExecutorService()));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
Reference in New Issue
Block a user