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); - } -} -