* Different color if active. * Trigger description / "ON" / "Paused" / "Tap to set up" depending on enabled and active status (strings may be revised later). This CL also adds a helper class to create ZenModes, reducing boilerplate in unit tests. Bug: 346575288 Test: atest com.android.settings.notification.modes Flag: android.app.modes_ui Change-Id: Ia0e16b8be5284d13bed4366cbee0f92748bf2f85
82 lines
3.1 KiB
Java
82 lines
3.1 KiB
Java
/*
|
|
* Copyright (C) 2024 The Android Open Source Project
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
package com.android.settings.notification.modes;
|
|
|
|
import android.content.Context;
|
|
import android.service.notification.ZenDeviceEffects;
|
|
|
|
import androidx.annotation.NonNull;
|
|
import androidx.preference.Preference;
|
|
import androidx.preference.TwoStatePreference;
|
|
|
|
import com.android.settingslib.notification.modes.ZenMode;
|
|
import com.android.settingslib.notification.modes.ZenModesBackend;
|
|
|
|
class ZenModeDisplayEffectPreferenceController extends AbstractZenModePreferenceController
|
|
implements Preference.OnPreferenceChangeListener {
|
|
|
|
public ZenModeDisplayEffectPreferenceController(Context context, String key,
|
|
ZenModesBackend backend) {
|
|
super(context, key, backend);
|
|
}
|
|
|
|
@Override
|
|
public void updateState(Preference preference, @NonNull ZenMode zenMode) {
|
|
TwoStatePreference pref = (TwoStatePreference) preference;
|
|
ZenDeviceEffects effects = zenMode.getDeviceEffects();
|
|
switch (getPreferenceKey()) {
|
|
case "effect_greyscale":
|
|
pref.setChecked(effects.shouldDisplayGrayscale());
|
|
break;
|
|
case "effect_aod":
|
|
pref.setChecked(effects.shouldSuppressAmbientDisplay());
|
|
break;
|
|
case "effect_wallpaper":
|
|
pref.setChecked(effects.shouldDimWallpaper());
|
|
break;
|
|
case "effect_dark_theme":
|
|
pref.setChecked(effects.shouldUseNightMode());
|
|
break;
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public boolean onPreferenceChange(@NonNull Preference preference, Object newValue) {
|
|
final boolean allow = (Boolean) newValue;
|
|
return saveMode(zenMode -> {
|
|
ZenDeviceEffects.Builder updatedEffects = new ZenDeviceEffects.Builder(
|
|
zenMode.getDeviceEffects());
|
|
switch (getPreferenceKey()) {
|
|
case "effect_greyscale":
|
|
updatedEffects.setShouldDisplayGrayscale(allow);
|
|
break;
|
|
case "effect_aod":
|
|
updatedEffects.setShouldSuppressAmbientDisplay(allow);
|
|
break;
|
|
case "effect_wallpaper":
|
|
updatedEffects.setShouldDimWallpaper(allow);
|
|
break;
|
|
case "effect_dark_theme":
|
|
updatedEffects.setShouldUseNightMode(allow);
|
|
break;
|
|
}
|
|
zenMode.getRule().setDeviceEffects(updatedEffects.build());
|
|
return zenMode;
|
|
});
|
|
}
|
|
}
|