Update Sound settings.
- change the summary to show the automatic rules info instead. - removed ringtone preference category - add dividers above DND and Emergency broadcast Change-Id: Iee497d194b70af72cfd69b315d639ca62720643b Fix: 34975939 Test: make RunSettingsRoboTests
This commit is contained in:
@@ -6320,7 +6320,7 @@
|
|||||||
</plurals>
|
</plurals>
|
||||||
|
|
||||||
<!-- Sound: Title for the Do not Disturb option and associated settings page. [CHAR LIMIT=50]-->
|
<!-- Sound: Title for the Do not Disturb option and associated settings page. [CHAR LIMIT=50]-->
|
||||||
<string name="zen_mode_settings_title">Do Not Disturb</string>
|
<string name="zen_mode_settings_title">Do Not Disturb preferences</string>
|
||||||
|
|
||||||
<!-- Do not disturb: Title for the Priority interruptions option and associated settings page. [CHAR LIMIT=30] -->
|
<!-- Do not disturb: Title for the Priority interruptions option and associated settings page. [CHAR LIMIT=30] -->
|
||||||
<string name="zen_mode_priority_settings_title">Priority only allows</string>
|
<string name="zen_mode_priority_settings_title">Priority only allows</string>
|
||||||
|
@@ -56,38 +56,34 @@
|
|||||||
android:title="@string/zen_mode_settings_title"
|
android:title="@string/zen_mode_settings_title"
|
||||||
settings:useAdminDisabledSummary="true"
|
settings:useAdminDisabledSummary="true"
|
||||||
settings:keywords="@string/keywords_sounds_and_notifications_interruptions"
|
settings:keywords="@string/keywords_sounds_and_notifications_interruptions"
|
||||||
android:fragment="com.android.settings.notification.ZenModeSettings" />
|
android:fragment="com.android.settings.notification.ZenModeSettings"
|
||||||
|
settings:allowDividerAbove="true" />
|
||||||
|
|
||||||
<PreferenceCategory
|
<!-- Phone ringtone -->
|
||||||
android:key="ringtones_preferecence_category"
|
<com.android.settings.DefaultRingtonePreference
|
||||||
android:title="@string/ringtones_category_preference_title" >
|
android:key="ringtone"
|
||||||
|
android:title="@string/ringtone_title"
|
||||||
|
android:dialogTitle="@string/ringtone_title"
|
||||||
|
android:summary="@string/summary_placeholder"
|
||||||
|
android:ringtoneType="ringtone"
|
||||||
|
settings:allowDividerAbove="true" />
|
||||||
|
|
||||||
<!-- Phone ringtone -->
|
<!-- Default notification ringtone -->
|
||||||
<com.android.settings.DefaultRingtonePreference
|
<com.android.settings.DefaultRingtonePreference
|
||||||
android:key="ringtone"
|
android:key="notification_ringtone"
|
||||||
android:title="@string/ringtone_title"
|
android:title="@string/notification_ringtone_title"
|
||||||
android:dialogTitle="@string/ringtone_title"
|
android:dialogTitle="@string/notification_ringtone_title"
|
||||||
android:summary="@string/summary_placeholder"
|
android:summary="@string/summary_placeholder"
|
||||||
android:ringtoneType="ringtone" />
|
android:ringtoneType="notification" />
|
||||||
|
|
||||||
<!-- Default notification ringtone -->
|
<!-- Default alarm ringtone -->
|
||||||
<com.android.settings.DefaultRingtonePreference
|
<com.android.settings.DefaultRingtonePreference
|
||||||
android:key="notification_ringtone"
|
android:key="alarm_ringtone"
|
||||||
android:title="@string/notification_ringtone_title"
|
android:title="@string/alarm_ringtone_title"
|
||||||
android:dialogTitle="@string/notification_ringtone_title"
|
android:dialogTitle="@string/alarm_ringtone_title"
|
||||||
android:summary="@string/summary_placeholder"
|
android:summary="@string/summary_placeholder"
|
||||||
android:ringtoneType="notification" />
|
android:persistent="false"
|
||||||
|
android:ringtoneType="alarm" />
|
||||||
<!-- Default alarm ringtone -->
|
|
||||||
<com.android.settings.DefaultRingtonePreference
|
|
||||||
android:key="alarm_ringtone"
|
|
||||||
android:title="@string/alarm_ringtone_title"
|
|
||||||
android:dialogTitle="@string/alarm_ringtone_title"
|
|
||||||
android:summary="@string/summary_placeholder"
|
|
||||||
android:persistent="false"
|
|
||||||
android:ringtoneType="alarm" />
|
|
||||||
|
|
||||||
</PreferenceCategory>
|
|
||||||
|
|
||||||
<!-- Other sounds -->
|
<!-- Other sounds -->
|
||||||
<PreferenceCategory
|
<PreferenceCategory
|
||||||
@@ -144,7 +140,8 @@
|
|||||||
<com.android.settingslib.RestrictedPreference
|
<com.android.settingslib.RestrictedPreference
|
||||||
android:key="cell_broadcast_settings"
|
android:key="cell_broadcast_settings"
|
||||||
android:title="@string/cell_broadcast_settings"
|
android:title="@string/cell_broadcast_settings"
|
||||||
settings:useAdminDisabledSummary="true">
|
settings:useAdminDisabledSummary="true"
|
||||||
|
settings:allowDividerAbove="true" >
|
||||||
<intent
|
<intent
|
||||||
android:action="android.intent.action.MAIN"
|
android:action="android.intent.action.MAIN"
|
||||||
android:targetPackage="com.android.cellbroadcastreceiver"
|
android:targetPackage="com.android.cellbroadcastreceiver"
|
||||||
|
@@ -16,22 +16,18 @@
|
|||||||
|
|
||||||
package com.android.settings.notification;
|
package com.android.settings.notification;
|
||||||
|
|
||||||
import android.app.NotificationManager;
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.support.v7.preference.Preference;
|
import android.support.v7.preference.Preference;
|
||||||
import com.android.settings.R;
|
|
||||||
|
|
||||||
public class ZenModePreferenceController extends AdjustVolumeRestrictedPreferenceController {
|
public class ZenModePreferenceController extends AdjustVolumeRestrictedPreferenceController {
|
||||||
|
|
||||||
private static final String KEY_ZEN_MODE = "zen_mode";
|
private static final String KEY_ZEN_MODE = "zen_mode";
|
||||||
private String mSummaryPrefix;
|
|
||||||
|
|
||||||
private ZenModeSettings.SummaryBuilder mSummaryBuilder;
|
private ZenModeSettings.SummaryBuilder mSummaryBuilder;
|
||||||
|
|
||||||
public ZenModePreferenceController(Context context) {
|
public ZenModePreferenceController(Context context) {
|
||||||
super(context);
|
super(context);
|
||||||
mSummaryBuilder = new ZenModeSettings.SummaryBuilder(context);
|
mSummaryBuilder = new ZenModeSettings.SummaryBuilder(context);
|
||||||
mSummaryPrefix = context.getString(R.string.zen_mode_priority_settings_title) + " ";
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -48,8 +44,7 @@ public class ZenModePreferenceController extends AdjustVolumeRestrictedPreferenc
|
|||||||
public void updateState(Preference preference) {
|
public void updateState(Preference preference) {
|
||||||
super.updateState(preference);
|
super.updateState(preference);
|
||||||
if (preference.isEnabled()) {
|
if (preference.isEnabled()) {
|
||||||
preference.setSummary(mSummaryPrefix + mSummaryBuilder.getPrioritySettingSummary(
|
preference.setSummary(mSummaryBuilder.getAutomaticRulesSummary());
|
||||||
NotificationManager.from(mContext).getNotificationPolicy()));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -16,6 +16,7 @@
|
|||||||
|
|
||||||
package com.android.settings.notification;
|
package com.android.settings.notification;
|
||||||
|
|
||||||
|
import android.app.AutomaticZenRule;
|
||||||
import android.app.NotificationManager;
|
import android.app.NotificationManager;
|
||||||
import android.app.NotificationManager.Policy;
|
import android.app.NotificationManager.Policy;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
@@ -26,6 +27,9 @@ import android.support.v7.preference.PreferenceScreen;
|
|||||||
|
|
||||||
import com.android.internal.logging.nano.MetricsProto.MetricsEvent;
|
import com.android.internal.logging.nano.MetricsProto.MetricsEvent;
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Map.Entry;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
public class ZenModeSettings extends ZenModeSettingsBase {
|
public class ZenModeSettings extends ZenModeSettingsBase {
|
||||||
private static final String KEY_PRIORITY_SETTINGS = "priority_settings";
|
private static final String KEY_PRIORITY_SETTINGS = "priority_settings";
|
||||||
@@ -137,6 +141,29 @@ public class ZenModeSettings extends ZenModeSettingsBase {
|
|||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
String getAutomaticRulesSummary() {
|
||||||
|
final int count = getEnabledAutomaticRulesCount();
|
||||||
|
return count == 0 ? mContext.getString(R.string.zen_mode_settings_summary_off)
|
||||||
|
: mContext.getResources().getQuantityString(
|
||||||
|
R.plurals.zen_mode_settings_summary_on, count, count);
|
||||||
|
}
|
||||||
|
|
||||||
|
@VisibleForTesting
|
||||||
|
int getEnabledAutomaticRulesCount() {
|
||||||
|
int count = 0;
|
||||||
|
final Map<String, AutomaticZenRule> ruleMap =
|
||||||
|
NotificationManager.from(mContext).getAutomaticZenRules();
|
||||||
|
if (ruleMap != null) {
|
||||||
|
for (Entry<String, AutomaticZenRule> ruleEntry : ruleMap.entrySet()) {
|
||||||
|
final AutomaticZenRule rule = ruleEntry.getValue();
|
||||||
|
if (rule != null && rule.isEnabled()) {
|
||||||
|
count++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return count;
|
||||||
|
}
|
||||||
|
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
String append(String s, boolean condition, int resId) {
|
String append(String s, boolean condition, int resId) {
|
||||||
if (condition) {
|
if (condition) {
|
||||||
|
@@ -21,6 +21,7 @@ import android.app.NotificationManager.Policy;
|
|||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.support.v7.preference.Preference;
|
import android.support.v7.preference.Preference;
|
||||||
|
|
||||||
|
import com.android.settings.R;
|
||||||
import com.android.settings.SettingsRobolectricTestRunner;
|
import com.android.settings.SettingsRobolectricTestRunner;
|
||||||
import com.android.settings.TestConfig;
|
import com.android.settings.TestConfig;
|
||||||
|
|
||||||
@@ -30,11 +31,14 @@ import org.junit.runner.RunWith;
|
|||||||
import org.mockito.Mock;
|
import org.mockito.Mock;
|
||||||
import org.mockito.MockitoAnnotations;
|
import org.mockito.MockitoAnnotations;
|
||||||
import org.robolectric.annotation.Config;
|
import org.robolectric.annotation.Config;
|
||||||
|
import org.robolectric.shadows.ShadowApplication;
|
||||||
import org.robolectric.util.ReflectionHelpers;
|
import org.robolectric.util.ReflectionHelpers;
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
import static org.mockito.Matchers.anyString;
|
import static org.mockito.Matchers.anyString;
|
||||||
|
import static org.mockito.Mockito.doReturn;
|
||||||
import static org.mockito.Mockito.never;
|
import static org.mockito.Mockito.never;
|
||||||
|
import static org.mockito.Mockito.spy;
|
||||||
import static org.mockito.Mockito.verify;
|
import static org.mockito.Mockito.verify;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
@@ -42,8 +46,6 @@ import static org.mockito.Mockito.when;
|
|||||||
@Config(manifest = TestConfig.MANIFEST_PATH, sdk = TestConfig.SDK_VERSION)
|
@Config(manifest = TestConfig.MANIFEST_PATH, sdk = TestConfig.SDK_VERSION)
|
||||||
public class ZenModePreferenceControllerTest {
|
public class ZenModePreferenceControllerTest {
|
||||||
|
|
||||||
@Mock
|
|
||||||
private Context mContext;
|
|
||||||
@Mock
|
@Mock
|
||||||
private Preference mPreference;
|
private Preference mPreference;
|
||||||
@Mock
|
@Mock
|
||||||
@@ -51,15 +53,21 @@ public class ZenModePreferenceControllerTest {
|
|||||||
@Mock
|
@Mock
|
||||||
private Policy mPolicy;
|
private Policy mPolicy;
|
||||||
|
|
||||||
|
private Context mContext;
|
||||||
private ZenModePreferenceController mController;
|
private ZenModePreferenceController mController;
|
||||||
|
private ZenModeSettings.SummaryBuilder mSummaryBuilder;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
|
ShadowApplication shadowApplication = ShadowApplication.getInstance();
|
||||||
|
shadowApplication.setSystemService(Context.NOTIFICATION_SERVICE, mNotificationManager);
|
||||||
|
mContext = shadowApplication.getApplicationContext();
|
||||||
mController = new ZenModePreferenceController(mContext);
|
mController = new ZenModePreferenceController(mContext);
|
||||||
when(mContext.getSystemService(Context.NOTIFICATION_SERVICE))
|
|
||||||
.thenReturn(mNotificationManager);
|
|
||||||
when(mNotificationManager.getNotificationPolicy()).thenReturn(mPolicy);
|
when(mNotificationManager.getNotificationPolicy()).thenReturn(mPolicy);
|
||||||
|
mSummaryBuilder = spy(new ZenModeSettings.SummaryBuilder(mContext));
|
||||||
|
ReflectionHelpers.setField(mController, "mSummaryBuilder", mSummaryBuilder);
|
||||||
|
doReturn(0).when(mSummaryBuilder).getEnabledAutomaticRulesCount();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -72,8 +80,12 @@ public class ZenModePreferenceControllerTest {
|
|||||||
when(mPreference.isEnabled()).thenReturn(true);
|
when(mPreference.isEnabled()).thenReturn(true);
|
||||||
|
|
||||||
mController.updateState(mPreference);
|
mController.updateState(mPreference);
|
||||||
|
verify(mPreference).setSummary(mContext.getString(R.string.zen_mode_settings_summary_off));
|
||||||
|
|
||||||
verify(mPreference).setSummary(anyString());
|
doReturn(1).when(mSummaryBuilder).getEnabledAutomaticRulesCount();
|
||||||
|
mController.updateState(mPreference);
|
||||||
|
verify(mPreference).setSummary(mContext.getResources().getQuantityString(
|
||||||
|
R.plurals.zen_mode_settings_summary_on, 1, 1));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
Reference in New Issue
Block a user