diff --git a/res/xml/gentle_notification_settings.xml b/res/xml/gentle_notification_settings.xml
deleted file mode 100644
index 56c3c406494..00000000000
--- a/res/xml/gentle_notification_settings.xml
+++ /dev/null
@@ -1,57 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/src/com/android/settings/notification/GentleDrawablePreferenceController.java b/src/com/android/settings/notification/GentleDrawablePreferenceController.java
deleted file mode 100644
index b4e18db27d3..00000000000
--- a/src/com/android/settings/notification/GentleDrawablePreferenceController.java
+++ /dev/null
@@ -1,81 +0,0 @@
-/*
- * Copyright (C) 2019 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;
-
-import android.content.Context;
-import android.provider.Settings;
-import android.widget.ImageView;
-
-import com.android.settings.R;
-import com.android.settings.core.BasePreferenceController;
-import com.android.settingslib.widget.LayoutPreference;
-
-import androidx.annotation.VisibleForTesting;
-import androidx.preference.Preference;
-
-public class GentleDrawablePreferenceController extends BasePreferenceController {
-
- @VisibleForTesting
- static final int ON = 1;
-
- private NotificationBackend mBackend;
-
- public GentleDrawablePreferenceController(Context context, String preferenceKey) {
- super(context, preferenceKey);
- mBackend = new NotificationBackend();
- }
-
- @VisibleForTesting
- void setBackend(NotificationBackend backend) {
- mBackend = backend;
- }
-
- @Override
- public void updateState(Preference preference) {
- LayoutPreference pref = (LayoutPreference) preference;
- boolean showOnLockscreen = showOnLockscreen();
- boolean showOnStatusBar = showOnStatusBar();
-
- ImageView view = pref.findViewById(R.id.drawable);
-
- if (showOnLockscreen) {
- if (showOnStatusBar) {
- view.setImageResource(R.drawable.gentle_notifications_shade_status_lock);
- } else {
- view.setImageResource(R.drawable.gentle_notifications_shade_lock);
- }
- } else if (showOnStatusBar) {
- view.setImageResource(R.drawable.gentle_notifications_shade_status);
- } else {
- view.setImageResource(R.drawable.gentle_notifications_shade);
- }
- }
-
- @Override
- public int getAvailabilityStatus() {
- return AVAILABLE;
- }
-
- private boolean showOnLockscreen() {
- return Settings.Secure.getInt(mContext.getContentResolver(),
- Settings.Secure.LOCK_SCREEN_SHOW_SILENT_NOTIFICATIONS, ON) == ON;
- }
-
- private boolean showOnStatusBar() {
- return !mBackend.shouldHideSilentStatusBarIcons(mContext);
- }
-}
diff --git a/src/com/android/settings/notification/GentleNotificationSettings.java b/src/com/android/settings/notification/GentleNotificationSettings.java
deleted file mode 100644
index 5de6ab787a3..00000000000
--- a/src/com/android/settings/notification/GentleNotificationSettings.java
+++ /dev/null
@@ -1,74 +0,0 @@
-/*
- * Copyright (C) 2019 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;
-
-import android.app.settings.SettingsEnums;
-import android.content.Context;
-import android.provider.SearchIndexableResource;
-
-import com.android.settings.R;
-import com.android.settings.dashboard.DashboardFragment;
-import com.android.settings.search.BaseSearchIndexProvider;
-import com.android.settingslib.search.SearchIndexable;
-
-import java.util.Arrays;
-import java.util.List;
-
-@SearchIndexable
-public class GentleNotificationSettings extends DashboardFragment {
- private static final String TAG = "GentleNotiSettings";
-
- @Override
- public int getMetricsCategory() {
- return SettingsEnums.GENTLE_NOTIFICATIONS_SCREEN;
- }
-
- @Override
- protected String getLogTag() {
- return TAG;
- }
-
- @Override
- protected int getPreferenceScreenResId() {
- return R.xml.gentle_notification_settings;
- }
-
- @Override
- public void onAttach(Context context) {
- super.onAttach(context);
-
- use(SilentStatusBarPreferenceController.class).setListener(
- shown -> updatePreferenceStates());
-
- use(SilentLockscreenPreferenceController.class).setListener(
- shown -> updatePreferenceStates());
- }
-
- /**
- * For Search.
- */
- public static final SearchIndexProvider SEARCH_INDEX_DATA_PROVIDER =
- new BaseSearchIndexProvider() {
- @Override
- public List getXmlResourcesToIndex(
- Context context, boolean enabled) {
- final SearchIndexableResource sir = new SearchIndexableResource(context);
- sir.xmlResId = R.xml.gentle_notification_settings;
- return Arrays.asList(sir);
- }
- };
-}
diff --git a/src/com/android/settings/notification/SilentLockscreenPreferenceController.java b/src/com/android/settings/notification/SilentLockscreenPreferenceController.java
deleted file mode 100644
index 317f7da6e33..00000000000
--- a/src/com/android/settings/notification/SilentLockscreenPreferenceController.java
+++ /dev/null
@@ -1,70 +0,0 @@
-/*
- * Copyright (C) 2019 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;
-
-import static android.provider.Settings.Secure.NOTIFICATION_NEW_INTERRUPTION_MODEL;
-
-import android.content.Context;
-import android.os.UserHandle;
-import android.provider.Settings;
-
-import com.android.settings.core.TogglePreferenceController;
-
-import com.google.common.annotations.VisibleForTesting;
-
-public class SilentLockscreenPreferenceController extends TogglePreferenceController {
-
- private static final String KEY = "lock_screen";
- private Listener mListener;
-
- public SilentLockscreenPreferenceController(Context context) {
- super(context, KEY);
- }
-
- @Override
- public boolean isChecked() {
- return Settings.Secure.getInt(mContext.getContentResolver(),
- Settings.Secure.LOCK_SCREEN_SHOW_SILENT_NOTIFICATIONS, 1) == 1;
- }
-
- @Override
- public boolean setChecked(boolean isChecked) {
- Settings.Secure.putInt(mContext.getContentResolver(),
- Settings.Secure.LOCK_SCREEN_SHOW_SILENT_NOTIFICATIONS, isChecked ? 1 : 0);
- if (mListener != null) {
- mListener.onChange(isChecked);
- }
- return true;
- }
-
- @Override
- public int getAvailabilityStatus() {
- return Settings.Secure.getInt(
- mContext.getContentResolver(), NOTIFICATION_NEW_INTERRUPTION_MODEL, 1) != 0
- ? AVAILABLE : UNSUPPORTED_ON_DEVICE;
- }
-
- public void setListener(Listener listener) {
- mListener = listener;
- }
-
- interface Listener {
- void onChange(boolean shown);
- }
-}
-
-
diff --git a/src/com/android/settings/notification/SilentStatusBarPreferenceController.java b/src/com/android/settings/notification/SilentStatusBarPreferenceController.java
deleted file mode 100644
index e561508014e..00000000000
--- a/src/com/android/settings/notification/SilentStatusBarPreferenceController.java
+++ /dev/null
@@ -1,77 +0,0 @@
-/*
- * Copyright (C) 2019 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;
-
-import static android.provider.Settings.Secure.NOTIFICATION_NEW_INTERRUPTION_MODEL;
-
-import android.content.Context;
-import android.os.UserHandle;
-import android.provider.Settings;
-
-import com.android.settings.core.TogglePreferenceController;
-
-import com.google.common.annotations.VisibleForTesting;
-
-public class SilentStatusBarPreferenceController extends TogglePreferenceController {
-
- private static final String KEY = "silent_icons";
- private static final int MY_USER_ID = UserHandle.myUserId();
- private NotificationBackend mBackend;
- private Listener mListener;
-
- public SilentStatusBarPreferenceController(Context context) {
- super(context, KEY);
- mBackend = new NotificationBackend();
- }
-
- @VisibleForTesting
- void setBackend(NotificationBackend backend) {
- mBackend = backend;
- }
-
- @Override
- public boolean isChecked() {
- return !mBackend.shouldHideSilentStatusBarIcons(mContext);
- }
-
- @Override
- public boolean setChecked(boolean isChecked) {
- mBackend.setHideSilentStatusIcons(!isChecked);
- if (mListener != null) {
- mListener.onChange(isChecked);
- }
- return true;
- }
-
- @Override
- public int getAvailabilityStatus() {
- return Settings.Secure.getInt(
- mContext.getContentResolver(), NOTIFICATION_NEW_INTERRUPTION_MODEL, 1) != 0
- ? AVAILABLE : UNSUPPORTED_ON_DEVICE;
- }
-
- public void setListener(Listener listener) {
- mListener = listener;
- }
-
- interface Listener {
- void onChange(boolean shown);
- }
-
-}
-
-
diff --git a/tests/robotests/src/com/android/settings/notification/GentleDrawablePreferenceControllerTest.java b/tests/robotests/src/com/android/settings/notification/GentleDrawablePreferenceControllerTest.java
deleted file mode 100644
index c8d1e018bea..00000000000
--- a/tests/robotests/src/com/android/settings/notification/GentleDrawablePreferenceControllerTest.java
+++ /dev/null
@@ -1,113 +0,0 @@
-/*
- * Copyright (C) 2019 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;
-
-import static com.google.common.truth.Truth.assertThat;
-
-import static org.mockito.Mockito.verify;
-import static org.mockito.Mockito.when;
-
-import android.content.Context;
-import android.provider.Settings;
-import android.widget.ImageView;
-
-import com.android.settings.R;
-import com.android.settingslib.widget.LayoutPreference;
-
-import org.junit.Before;
-import org.junit.Test;
-import org.junit.runner.RunWith;
-import org.mockito.Mock;
-import org.mockito.MockitoAnnotations;
-import org.robolectric.RobolectricTestRunner;
-import org.robolectric.RuntimeEnvironment;
-
-import androidx.preference.Preference;
-
-@RunWith(RobolectricTestRunner.class)
-public class GentleDrawablePreferenceControllerTest {
-
- private Context mContext;
-
- private GentleDrawablePreferenceController mController;
- @Mock
- private LayoutPreference mPreference;
- @Mock
- NotificationBackend mBackend;
- @Mock
- ImageView mView;
-
- private static final String KEY = "gentle_notifications";
-
- @Before
- public void setUp() {
- MockitoAnnotations.initMocks(this);
- mContext = RuntimeEnvironment.application;
- mController = new GentleDrawablePreferenceController(mContext, KEY);
- mController.setBackend(mBackend);
- when(mPreference.findViewById(R.id.drawable)).thenReturn(mView);
- }
-
- @Test
- public void display_shouldDisplay() {
- assertThat(mController.isAvailable()).isTrue();
- }
-
- @Test
- public void updateState_lock() {
- Settings.Secure.putInt(mContext.getContentResolver(),
- Settings.Secure.LOCK_SCREEN_SHOW_SILENT_NOTIFICATIONS, 1);
- when(mBackend.shouldHideSilentStatusBarIcons(mContext)).thenReturn(true);
-
- mController.updateState(mPreference);
-
- verify(mView).setImageResource(R.drawable.gentle_notifications_shade_lock);
- }
-
- @Test
- public void updateState_status() {
- Settings.Secure.putInt(mContext.getContentResolver(),
- Settings.Secure.LOCK_SCREEN_SHOW_SILENT_NOTIFICATIONS, 0);
- when(mBackend.shouldHideSilentStatusBarIcons(mContext)).thenReturn(false);
-
- mController.updateState(mPreference);
-
- verify(mView).setImageResource(R.drawable.gentle_notifications_shade_status);
- }
-
- @Test
- public void updateState_both() {
- Settings.Secure.putInt(mContext.getContentResolver(),
- Settings.Secure.LOCK_SCREEN_SHOW_SILENT_NOTIFICATIONS, 1);
- when(mBackend.shouldHideSilentStatusBarIcons(mContext)).thenReturn(false);
-
- mController.updateState(mPreference);
-
- verify(mView).setImageResource(R.drawable.gentle_notifications_shade_status_lock);
- }
-
- @Test
- public void updateState_neither() {
- Settings.Secure.putInt(mContext.getContentResolver(),
- Settings.Secure.LOCK_SCREEN_SHOW_SILENT_NOTIFICATIONS, 0);
- when(mBackend.shouldHideSilentStatusBarIcons(mContext)).thenReturn(true);
-
- mController.updateState(mPreference);
-
- verify(mView).setImageResource(R.drawable.gentle_notifications_shade);
- }
-}
diff --git a/tests/robotests/src/com/android/settings/notification/SilentLockscreenPreferenceControllerTest.java b/tests/robotests/src/com/android/settings/notification/SilentLockscreenPreferenceControllerTest.java
deleted file mode 100644
index dcfdea59a8a..00000000000
--- a/tests/robotests/src/com/android/settings/notification/SilentLockscreenPreferenceControllerTest.java
+++ /dev/null
@@ -1,117 +0,0 @@
-/*
- * Copyright (C) 2019 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;
-
-import static android.provider.Settings.Secure.NOTIFICATION_NEW_INTERRUPTION_MODEL;
-
-import static com.google.common.truth.Truth.assertThat;
-
-import static org.mockito.ArgumentMatchers.any;
-import static org.mockito.Mockito.mock;
-import static org.mockito.Mockito.verify;
-import static org.mockito.Mockito.when;
-
-import android.content.Context;
-import android.provider.Settings;
-
-import org.junit.Before;
-import org.junit.Test;
-import org.junit.runner.RunWith;
-import org.mockito.Mock;
-import org.mockito.MockitoAnnotations;
-import org.robolectric.RobolectricTestRunner;
-import org.robolectric.RuntimeEnvironment;
-
-import androidx.preference.Preference;
-import androidx.preference.PreferenceScreen;
-
-@RunWith(RobolectricTestRunner.class)
-public class SilentLockscreenPreferenceControllerTest {
-
- @Mock
- private PreferenceScreen mScreen;
-
- private Context mContext;
- private SilentLockscreenPreferenceController mController;
- private Preference mPreference;
-
- @Before
- public void setUp() {
- MockitoAnnotations.initMocks(this);
- mContext = RuntimeEnvironment.application;
- mController = new SilentLockscreenPreferenceController(mContext);
- mPreference = new Preference(mContext);
- mPreference.setKey(mController.getPreferenceKey());
- when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mPreference);
- }
-
- @Test
- public void isAvailable_featureEnabled() {
- Settings.Secure.putInt(
- mContext.getContentResolver(), NOTIFICATION_NEW_INTERRUPTION_MODEL, 1);
- assertThat(mController.isAvailable()).isTrue();
- }
-
- @Test
- public void isAvailable_featureDisabled() {
- Settings.Secure.putInt(
- mContext.getContentResolver(), NOTIFICATION_NEW_INTERRUPTION_MODEL, 0);
- assertThat(mController.isAvailable()).isFalse();
- }
-
- @Test
- public void isChecked_settingIsOff_false() {
- Settings.Secure.putInt(mContext.getContentResolver(),
- Settings.Secure.LOCK_SCREEN_SHOW_SILENT_NOTIFICATIONS, 0);
- assertThat(mController.isChecked()).isFalse();
- }
-
- @Test
- public void isChecked_settingIsOn_true() {
- Settings.Secure.putInt(mContext.getContentResolver(),
- Settings.Secure.LOCK_SCREEN_SHOW_SILENT_NOTIFICATIONS, 1);
- assertThat(mController.isChecked()).isTrue();
- }
-
- @Test
- public void onPreferenceChange_on() {
- mController.onPreferenceChange(mPreference, true);
- assertThat(Settings.Secure.getInt(mContext.getContentResolver(),
- Settings.Secure.LOCK_SCREEN_SHOW_SILENT_NOTIFICATIONS, 0)).isEqualTo(1);
- }
-
- @Test
- public void onPreferenceChange_off() {
- mController.onPreferenceChange(mPreference, false);
- assertThat(Settings.Secure.getInt(mContext.getContentResolver(),
- Settings.Secure.LOCK_SCREEN_SHOW_SILENT_NOTIFICATIONS, 1)).isEqualTo(0);
- }
-
- @Test
- public void listenerTriggered() {
- SilentLockscreenPreferenceController.Listener listener = mock(
- SilentLockscreenPreferenceController.Listener.class);
- mController.setListener(listener);
-
- mController.setChecked(false);
- verify(listener).onChange(false);
-
- mController.setChecked(true);
- verify(listener).onChange(true);
- }
-}
-
diff --git a/tests/robotests/src/com/android/settings/notification/SilentStatusBarPreferenceControllerTest.java b/tests/robotests/src/com/android/settings/notification/SilentStatusBarPreferenceControllerTest.java
deleted file mode 100644
index 55a85494e43..00000000000
--- a/tests/robotests/src/com/android/settings/notification/SilentStatusBarPreferenceControllerTest.java
+++ /dev/null
@@ -1,118 +0,0 @@
-/*
- * Copyright (C) 2019 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;
-
-import static android.provider.Settings.Secure.NOTIFICATION_NEW_INTERRUPTION_MODEL;
-
-import static com.google.common.truth.Truth.assertThat;
-
-import static org.mockito.ArgumentMatchers.any;
-import static org.mockito.Mockito.mock;
-import static org.mockito.Mockito.verify;
-import static org.mockito.Mockito.when;
-
-import android.content.Context;
-import android.provider.Settings;
-
-import com.android.settings.testutils.FakeFeatureFactory;
-
-import org.junit.Before;
-import org.junit.Test;
-import org.junit.runner.RunWith;
-import org.mockito.Mock;
-import org.mockito.MockitoAnnotations;
-import org.robolectric.RobolectricTestRunner;
-import org.robolectric.RuntimeEnvironment;
-
-import androidx.preference.Preference;
-import androidx.preference.PreferenceScreen;
-
-@RunWith(RobolectricTestRunner.class)
-public class SilentStatusBarPreferenceControllerTest {
-
- @Mock
- private NotificationBackend mBackend;
- @Mock
- private PreferenceScreen mScreen;
-
- private Context mContext;
- private SilentStatusBarPreferenceController mController;
- private Preference mPreference;
-
- @Before
- public void setUp() {
- MockitoAnnotations.initMocks(this);
- mContext = RuntimeEnvironment.application;
- mController = new SilentStatusBarPreferenceController(mContext);
- mController.setBackend(mBackend);
- mPreference = new Preference(mContext);
- mPreference.setKey(mController.getPreferenceKey());
- when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mPreference);
- }
-
- @Test
- public void isAvailable_featureEnabled() {
- Settings.Secure.putInt(
- mContext.getContentResolver(), NOTIFICATION_NEW_INTERRUPTION_MODEL, 1);
- assertThat(mController.isAvailable()).isTrue();
- }
-
- @Test
- public void isAvailable_featureDisabled() {
- Settings.Secure.putInt(
- mContext.getContentResolver(), NOTIFICATION_NEW_INTERRUPTION_MODEL, 0);
- assertThat(mController.isAvailable()).isFalse();
- }
-
- @Test
- public void isChecked_settingIsOff_false() {
- when(mBackend.shouldHideSilentStatusBarIcons(any())).thenReturn(true);
- assertThat(mController.isChecked()).isFalse();
- }
-
- @Test
- public void isChecked_settingIsOn_true() {
- when(mBackend.shouldHideSilentStatusBarIcons(any())).thenReturn(false);
- assertThat(mController.isChecked()).isTrue();
- }
-
- @Test
- public void onPreferenceChange_on() {
- mController.onPreferenceChange(mPreference, true);
- verify(mBackend).setHideSilentStatusIcons(false);
- }
-
- @Test
- public void onPreferenceChange_off() {
- mController.onPreferenceChange(mPreference, false);
- verify(mBackend).setHideSilentStatusIcons(true);
- }
-
- @Test
- public void listenerTriggered() {
- SilentStatusBarPreferenceController.Listener listener = mock(
- SilentStatusBarPreferenceController.Listener.class);
- mController.setListener(listener);
-
- mController.setChecked(false);
- verify(listener).onChange(false);
-
- mController.setChecked(true);
- verify(listener).onChange(true);
- }
-}
-