Add master toggle to enable/disable screen savers
The new control toggles the Settings.Secure.SCREENSAVER_ENABLED setting, which controls if a screen saver is enabled. Also removed the "Never" option from the WhenToDream picker, since this is now controlled via the toggle. Test: locally on device Bug: 222360260 Change-Id: Ibcf52b5e2d1ad0c295f32c4c18bfc89082d074ce
This commit is contained in:
@@ -16,6 +16,7 @@
|
||||
|
||||
package com.android.settings.dream;
|
||||
|
||||
import static com.android.settings.dream.DreamMainSwitchPreferenceController.MAIN_SWITCH_PREF_KEY;
|
||||
import static com.android.settingslib.dream.DreamBackend.EITHER;
|
||||
import static com.android.settingslib.dream.DreamBackend.NEVER;
|
||||
import static com.android.settingslib.dream.DreamBackend.WHILE_CHARGING;
|
||||
@@ -25,10 +26,13 @@ import android.app.settings.SettingsEnums;
|
||||
import android.content.Context;
|
||||
import android.os.Bundle;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
import android.view.ViewGroup;
|
||||
import android.widget.Button;
|
||||
import android.widget.Switch;
|
||||
|
||||
import androidx.annotation.VisibleForTesting;
|
||||
import androidx.preference.PreferenceCategory;
|
||||
import androidx.recyclerview.widget.RecyclerView;
|
||||
|
||||
import com.android.settings.R;
|
||||
@@ -38,12 +42,14 @@ import com.android.settingslib.core.AbstractPreferenceController;
|
||||
import com.android.settingslib.dream.DreamBackend;
|
||||
import com.android.settingslib.dream.DreamBackend.WhenToDream;
|
||||
import com.android.settingslib.search.SearchIndexable;
|
||||
import com.android.settingslib.widget.MainSwitchPreference;
|
||||
import com.android.settingslib.widget.OnMainSwitchChangeListener;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
@SearchIndexable
|
||||
public class DreamSettings extends DashboardFragment {
|
||||
public class DreamSettings extends DashboardFragment implements OnMainSwitchChangeListener {
|
||||
|
||||
private static final String TAG = "DreamSettings";
|
||||
static final String WHILE_CHARGING_ONLY = "while_charging_only";
|
||||
@@ -51,6 +57,13 @@ public class DreamSettings extends DashboardFragment {
|
||||
static final String EITHER_CHARGING_OR_DOCKED = "either_charging_or_docked";
|
||||
static final String NEVER_DREAM = "never";
|
||||
|
||||
private static final String MAIN_PREF_CATEGORY = "dream_main_category";
|
||||
|
||||
private MainSwitchPreference mMainSwitchPreference;
|
||||
private PreferenceCategory mMainPrefCategory;
|
||||
private Button mPreviewButton;
|
||||
private RecyclerView mRecyclerView;
|
||||
|
||||
@WhenToDream
|
||||
static int getSettingFromPrefKey(String key) {
|
||||
switch (key) {
|
||||
@@ -135,37 +148,58 @@ public class DreamSettings extends DashboardFragment {
|
||||
|
||||
private static List<AbstractPreferenceController> buildPreferenceControllers(Context context) {
|
||||
final List<AbstractPreferenceController> controllers = new ArrayList<>();
|
||||
controllers.add(new DreamPickerController(context));
|
||||
controllers.add(new WhenToDreamPreferenceController(context));
|
||||
return controllers;
|
||||
}
|
||||
|
||||
@Override
|
||||
public RecyclerView onCreateRecyclerView(LayoutInflater inflater, ViewGroup parent,
|
||||
Bundle bundle) {
|
||||
|
||||
final ViewGroup root = getActivity().findViewById(android.R.id.content);
|
||||
final Button previewButton = (Button) getActivity().getLayoutInflater().inflate(
|
||||
R.layout.dream_preview_button, root, false);
|
||||
root.addView(previewButton);
|
||||
public void onCreate(Bundle icicle) {
|
||||
super.onCreate(icicle);
|
||||
|
||||
final DreamBackend dreamBackend = DreamBackend.getInstance(getContext());
|
||||
previewButton.setOnClickListener(v -> dreamBackend.preview(dreamBackend.getActiveDream()));
|
||||
|
||||
final RecyclerView recyclerView = super.onCreateRecyclerView(inflater, parent, bundle);
|
||||
previewButton.post(() -> {
|
||||
recyclerView.setPadding(0, 0, 0, previewButton.getMeasuredHeight());
|
||||
});
|
||||
return recyclerView;
|
||||
mMainSwitchPreference = findPreference(MAIN_SWITCH_PREF_KEY);
|
||||
if (mMainSwitchPreference != null) {
|
||||
mMainSwitchPreference.addOnSwitchChangeListener(this);
|
||||
}
|
||||
|
||||
mMainPrefCategory = findPreference(MAIN_PREF_CATEGORY);
|
||||
if (mMainPrefCategory != null) {
|
||||
mMainPrefCategory.setEnabled(dreamBackend.isEnabled());
|
||||
}
|
||||
}
|
||||
|
||||
public static final BaseSearchIndexProvider SEARCH_INDEX_DATA_PROVIDER
|
||||
= new BaseSearchIndexProvider(R.xml.dream_fragment_overview) {
|
||||
@Override
|
||||
public RecyclerView onCreateRecyclerView(LayoutInflater inflater, ViewGroup parent,
|
||||
Bundle bundle) {
|
||||
final DreamBackend dreamBackend = DreamBackend.getInstance(getContext());
|
||||
|
||||
@Override
|
||||
public List<AbstractPreferenceController> createPreferenceControllers(Context context) {
|
||||
return buildPreferenceControllers(context);
|
||||
}
|
||||
};
|
||||
final ViewGroup root = getActivity().findViewById(android.R.id.content);
|
||||
mPreviewButton = (Button) getActivity().getLayoutInflater().inflate(
|
||||
R.layout.dream_preview_button, root, false);
|
||||
mPreviewButton.setVisibility(dreamBackend.isEnabled() ? View.VISIBLE : View.GONE);
|
||||
root.addView(mPreviewButton);
|
||||
mPreviewButton.setOnClickListener(v -> dreamBackend.preview(dreamBackend.getActiveDream()));
|
||||
|
||||
mRecyclerView = super.onCreateRecyclerView(inflater, parent, bundle);
|
||||
updatePaddingForPreviewButton();
|
||||
return mRecyclerView;
|
||||
}
|
||||
|
||||
private void updatePaddingForPreviewButton() {
|
||||
mPreviewButton.post(() -> {
|
||||
mRecyclerView.setPadding(0, 0, 0, mPreviewButton.getMeasuredHeight());
|
||||
});
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onSwitchChanged(Switch switchView, boolean isChecked) {
|
||||
mMainPrefCategory.setEnabled(isChecked);
|
||||
mPreviewButton.setVisibility(isChecked ? View.VISIBLE : View.GONE);
|
||||
updatePaddingForPreviewButton();
|
||||
}
|
||||
|
||||
public static final BaseSearchIndexProvider SEARCH_INDEX_DATA_PROVIDER =
|
||||
new BaseSearchIndexProvider(R.xml.dream_fragment_overview);
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user