diff --git a/packages/SystemUI/src/com/android/systemui/Prefs.java b/packages/SystemUI/src/com/android/systemui/Prefs.java index 28ed84f376429..907616c62f294 100644 --- a/packages/SystemUI/src/com/android/systemui/Prefs.java +++ b/packages/SystemUI/src/com/android/systemui/Prefs.java @@ -44,6 +44,7 @@ public final class Prefs { Key.TV_PICTURE_IN_PICTURE_ONBOARDING_SHOWN, Key.QS_HOTSPOT_ADDED, Key.QS_DATA_SAVER_ADDED, + Key.QS_DATA_SAVER_DIALOG_SHOWN, Key.QS_INVERT_COLORS_ADDED, Key.QS_WORK_ADDED, Key.QS_NIGHT_ADDED, @@ -63,6 +64,7 @@ public final class Prefs { String TV_PICTURE_IN_PICTURE_ONBOARDING_SHOWN = "TvPictureInPictureOnboardingShown"; String QS_HOTSPOT_ADDED = "QsHotspotAdded"; String QS_DATA_SAVER_ADDED = "QsDataSaverAdded"; + String QS_DATA_SAVER_DIALOG_SHOWN = "QsDataSaverDialogShown"; String QS_INVERT_COLORS_ADDED = "QsInvertColorsAdded"; String QS_WORK_ADDED = "QsWorkAdded"; String QS_NIGHT_ADDED = "QsNightAdded"; diff --git a/packages/SystemUI/src/com/android/systemui/qs/tiles/DataSaverTile.java b/packages/SystemUI/src/com/android/systemui/qs/tiles/DataSaverTile.java index dded595902565..0ce805ea41b29 100644 --- a/packages/SystemUI/src/com/android/systemui/qs/tiles/DataSaverTile.java +++ b/packages/SystemUI/src/com/android/systemui/qs/tiles/DataSaverTile.java @@ -14,12 +14,15 @@ package com.android.systemui.qs.tiles; +import android.content.DialogInterface; import android.content.Intent; import com.android.internal.logging.MetricsLogger; import com.android.internal.logging.MetricsProto.MetricsEvent; +import com.android.systemui.Prefs; import com.android.systemui.R; import com.android.systemui.qs.QSTile; +import com.android.systemui.statusbar.phone.SystemUIDialog; import com.android.systemui.statusbar.policy.DataSaverController; public class DataSaverTile extends QSTile implements @@ -53,6 +56,29 @@ public class DataSaverTile extends QSTile implements @Override protected void handleClick() { + if (Prefs.getBoolean(mContext, Prefs.Key.QS_DATA_SAVER_DIALOG_SHOWN, false)) { + // Do it right away. + toggleDataSaver(); + return; + } + // Shows dialog first + SystemUIDialog dialog = new SystemUIDialog(mContext); + dialog.setTitle(com.android.internal.R.string.data_saver_enable_title); + dialog.setMessage(com.android.internal.R.string.data_saver_description); + dialog.setPositiveButton(com.android.internal.R.string.data_saver_enable_button, + new DialogInterface.OnClickListener() { + @Override + public void onClick(DialogInterface dialog, int which) { + toggleDataSaver(); + } + }); + dialog.setNegativeButton(com.android.internal.R.string.cancel, null); + dialog.setShowForAllUsers(true); + dialog.show(); + Prefs.putBoolean(mContext, Prefs.Key.QS_DATA_SAVER_DIALOG_SHOWN, true); + } + + private void toggleDataSaver() { mState.value = !mDataSaverController.isDataSaverEnabled(); MetricsLogger.action(mContext, getMetricsCategory(), mState.value); mDataSaverController.setDataSaverEnabled(mState.value);