Merge "Add flow for updating zen mode status on modes pages" into main
This commit is contained in:
@@ -0,0 +1,80 @@
|
|||||||
|
/*
|
||||||
|
* 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.app.AutomaticZenRule;
|
||||||
|
import android.content.Context;
|
||||||
|
|
||||||
|
import androidx.annotation.NonNull;
|
||||||
|
import androidx.annotation.Nullable;
|
||||||
|
import androidx.preference.Preference;
|
||||||
|
|
||||||
|
import com.android.settingslib.core.AbstractPreferenceController;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Base class for any preference controllers pertaining to any single Zen mode.
|
||||||
|
*/
|
||||||
|
abstract class AbstractZenModePreferenceController extends AbstractPreferenceController {
|
||||||
|
|
||||||
|
@Nullable
|
||||||
|
protected ZenModesBackend mBackend;
|
||||||
|
|
||||||
|
@Nullable // only until updateZenMode() is called
|
||||||
|
private ZenMode mZenMode;
|
||||||
|
|
||||||
|
@NonNull
|
||||||
|
final String mKey;
|
||||||
|
|
||||||
|
// ZenModesBackend should only be passed in if the preference controller may set the user's
|
||||||
|
// policy for this zen mode. Otherwise, if the preference controller is essentially read-only
|
||||||
|
// and leads to a further Settings screen, backend should be null.
|
||||||
|
AbstractZenModePreferenceController(@NonNull Context context, @NonNull String key,
|
||||||
|
@Nullable ZenModesBackend backend) {
|
||||||
|
super(context);
|
||||||
|
mBackend = backend;
|
||||||
|
mKey = key;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@NonNull
|
||||||
|
public String getPreferenceKey() {
|
||||||
|
return mKey;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Called by the parent Fragment onStart, which means it will happen before resume.
|
||||||
|
public void updateZenMode(@NonNull Preference preference, @NonNull ZenMode zenMode) {
|
||||||
|
mZenMode = zenMode;
|
||||||
|
updateState(preference);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Nullable
|
||||||
|
public ZenMode getMode() {
|
||||||
|
return mZenMode;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Nullable
|
||||||
|
public AutomaticZenRule getAZR() {
|
||||||
|
if (mZenMode == null || mZenMode.getRule() == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
return mZenMode.getRule();
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Implementations of this class should override
|
||||||
|
* {@link AbstractPreferenceController#updateState(Preference)} to specify what should
|
||||||
|
* happen when the preference is updated */
|
||||||
|
}
|
@@ -0,0 +1,156 @@
|
|||||||
|
/*
|
||||||
|
* 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.app.AutomaticZenRule;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.util.Log;
|
||||||
|
import android.widget.Toast;
|
||||||
|
|
||||||
|
import androidx.annotation.NonNull;
|
||||||
|
import androidx.annotation.Nullable;
|
||||||
|
import androidx.preference.Preference;
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
|
|
||||||
|
import com.android.settings.R;
|
||||||
|
import com.android.settingslib.core.AbstractPreferenceController;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Base class for Settings pages used to configure individual modes.
|
||||||
|
*/
|
||||||
|
abstract class ZenModeSettingsBase extends ZenModesSettingsBase {
|
||||||
|
static final String TAG = "ZenModeSettings";
|
||||||
|
static final String MODE_ID = "MODE_ID";
|
||||||
|
|
||||||
|
@Nullable // only until reloadMode() is called
|
||||||
|
private ZenMode mZenMode;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onAttach(@NonNull Context context) {
|
||||||
|
super.onAttach(context);
|
||||||
|
|
||||||
|
// TODO: b/322373473 - Update if modes page ends up using a different method of passing id
|
||||||
|
Bundle bundle = getArguments();
|
||||||
|
if (bundle != null && bundle.containsKey(MODE_ID)) {
|
||||||
|
String id = bundle.getString(MODE_ID);
|
||||||
|
if (!reloadMode(id)) {
|
||||||
|
Log.d(TAG, "Mode id " + id + " not found");
|
||||||
|
toastAndFinish();
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
Log.d(TAG, "Mode id required to set mode config settings");
|
||||||
|
toastAndFinish();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Refresh stored ZenMode data.
|
||||||
|
* @param id the mode ID
|
||||||
|
* @return whether we successfully got mode data from the backend.
|
||||||
|
*/
|
||||||
|
private boolean reloadMode(String id) {
|
||||||
|
mZenMode = mBackend.getMode(id);
|
||||||
|
if (mZenMode == null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Refresh ZenMode data any time the system's zen mode state changes (either the zen mode value
|
||||||
|
* itself, or the config), and also (once updated) update the info for all controllers.
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
protected void updateZenModeState() {
|
||||||
|
if (mZenMode == null) {
|
||||||
|
// This shouldn't happen, but guard against it in case
|
||||||
|
toastAndFinish();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
String id = mZenMode.getId();
|
||||||
|
if (!reloadMode(id)) {
|
||||||
|
Log.d(TAG, "Mode id=" + id + " not found");
|
||||||
|
toastAndFinish();
|
||||||
|
}
|
||||||
|
updateControllers();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void updateControllers() {
|
||||||
|
if (getPreferenceControllers() == null || mZenMode == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
final PreferenceScreen screen = getPreferenceScreen();
|
||||||
|
if (screen == null) {
|
||||||
|
Log.d(TAG, "PreferenceScreen not found");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
for (List<AbstractPreferenceController> list : getPreferenceControllers()) {
|
||||||
|
for (AbstractPreferenceController controller : list) {
|
||||||
|
if (!controller.isAvailable()) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
// Find preference associated with controller
|
||||||
|
final String key = controller.getPreferenceKey();
|
||||||
|
final Preference preference = screen.findPreference(key);
|
||||||
|
if (preference != null) {
|
||||||
|
AbstractZenModePreferenceController zenController =
|
||||||
|
(AbstractZenModePreferenceController) controller;
|
||||||
|
zenController.updateZenMode(preference, mZenMode);
|
||||||
|
} else {
|
||||||
|
Log.d(TAG,
|
||||||
|
String.format("Cannot find preference with key %s in Controller %s",
|
||||||
|
key, controller.getClass().getSimpleName()));
|
||||||
|
}
|
||||||
|
} catch (ClassCastException e) {
|
||||||
|
// Skip any controllers that aren't AbstractZenModePreferenceController.
|
||||||
|
Log.d(TAG, "Could not cast: " + controller.getClass().getSimpleName());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void toastAndFinish() {
|
||||||
|
Toast.makeText(mContext, R.string.zen_mode_rule_not_found_text, Toast.LENGTH_SHORT)
|
||||||
|
.show();
|
||||||
|
this.finish();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get current mode data.
|
||||||
|
*/
|
||||||
|
@Nullable
|
||||||
|
public ZenMode getMode() {
|
||||||
|
return mZenMode;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get AutomaticZenRule associated with current mode data, or null if it doesn't exist.
|
||||||
|
*/
|
||||||
|
@Nullable
|
||||||
|
public AutomaticZenRule getAZR() {
|
||||||
|
if (mZenMode == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
return mZenMode.getRule();
|
||||||
|
}
|
||||||
|
}
|
@@ -1,89 +0,0 @@
|
|||||||
/*
|
|
||||||
* 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.annotation.NonNull;
|
|
||||||
import android.annotation.Nullable;
|
|
||||||
import android.content.Context;
|
|
||||||
import android.os.Bundle;
|
|
||||||
import android.util.Log;
|
|
||||||
import android.widget.Toast;
|
|
||||||
|
|
||||||
import com.android.settings.R;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Base class for Settings pages used to configure individual modes.
|
|
||||||
*/
|
|
||||||
abstract class ZenModesRuleSettingsBase extends ZenModesSettingsBase {
|
|
||||||
static final String TAG = "ZenModesRuleSettings";
|
|
||||||
static final String MODE_ID = "MODE_ID";
|
|
||||||
|
|
||||||
@Nullable
|
|
||||||
protected ZenMode mZenMode;
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onAttach(@NonNull Context context) {
|
|
||||||
super.onAttach(context);
|
|
||||||
|
|
||||||
// TODO: b/322373473 - Update if modes page ends up using a different method of passing id
|
|
||||||
Bundle bundle = getArguments();
|
|
||||||
if (bundle != null && bundle.containsKey(MODE_ID)) {
|
|
||||||
String id = bundle.getString(MODE_ID);
|
|
||||||
if (!reloadMode(id)) {
|
|
||||||
Log.d(TAG, "Mode id " + id + " not found");
|
|
||||||
toastAndFinish();
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
Log.d(TAG, "Mode id required to set mode config settings");
|
|
||||||
toastAndFinish();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Refresh stored ZenMode data.
|
|
||||||
* @param id the mode ID
|
|
||||||
* @return whether we successfully got mode data from the backend.
|
|
||||||
*/
|
|
||||||
private boolean reloadMode(String id) {
|
|
||||||
mZenMode = mBackend.getMode(id);
|
|
||||||
return mZenMode != null;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Refresh ZenMode data any time the system's zen mode state changes (either the zen mode value
|
|
||||||
* itself, or the config).
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
protected void updateZenModeState() {
|
|
||||||
if (mZenMode == null) {
|
|
||||||
// This shouldn't happen, but guard against it in case
|
|
||||||
toastAndFinish();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
String id = mZenMode.getId();
|
|
||||||
if (!reloadMode(id)) {
|
|
||||||
Log.d(TAG, "Mode id=" + id + " not found");
|
|
||||||
toastAndFinish();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void toastAndFinish() {
|
|
||||||
Toast.makeText(mContext, R.string.zen_mode_rule_not_found_text, Toast.LENGTH_SHORT)
|
|
||||||
.show();
|
|
||||||
this.finish();
|
|
||||||
}
|
|
||||||
}
|
|
Reference in New Issue
Block a user