diff options
author | Nancy Chen <nancychen@google.com> | 2016-01-14 11:48:00 -0800 |
---|---|---|
committer | Nancy Chen <nancychen@google.com> | 2016-01-14 18:28:23 -0800 |
commit | 201e021fe24e36ae2d94eadd4701933dd099d309 (patch) | |
tree | 97a2d25587911e73c182aef6fe04196a88973a03 | |
parent | 662aed1de350c38751a962528651535a35a22789 (diff) |
Use telephony voicemail notification settings for vvm.
Previously visual voicemail notifications did not align with the
telephony voicemail notification settings that the user could visit
through dialer settings. After adding an API to access those telephony
settings, dialer can now read those settings and use them when providing
notifications for visual voicemail.
Also provide a VoicemailNotificationSettingsLookup class to enable
separate functionality for N and pre-N.
Bug: 24164917
Change-Id: I45d746b485be2f1db90b66a96885ba1485743b49
3 files changed, 94 insertions, 1 deletions
diff --git a/src-N/com/android/dialer/calllog/VoicemailNotificationSettingsLookup.java b/src-N/com/android/dialer/calllog/VoicemailNotificationSettingsLookup.java new file mode 100644 index 000000000..4ca0c65e6 --- /dev/null +++ b/src-N/com/android/dialer/calllog/VoicemailNotificationSettingsLookup.java @@ -0,0 +1,44 @@ +/* + * Copyright (C) 2016 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.dialer.calllog; + +import android.app.Notification; +import android.content.ComponentName; +import android.content.Context; +import android.net.Uri; +import android.telecom.PhoneAccountHandle; +import android.telephony.TelephonyManager; + +import com.android.dialer.calllog.DefaultVoicemailNotifier.NewCall; + +/** + * Class to do lookup for voicemail ringtone and vibration. On N and above, this will look up + * voicemail notification settings from Telephony. + */ +public class VoicemailNotificationSettingsLookup { + public static Uri getVoicemailRingtoneUri(Context context, PhoneAccountHandle accountHandle) { + return getTelephonyManager(context).getVoicemailRingtoneUri(accountHandle); + } + + public static int getNotificationDefaults(Context context, PhoneAccountHandle accountHandle) { + return getTelephonyManager(context).isVoicemailVibrationEnabled(accountHandle) + ? Notification.DEFAULT_VIBRATE : 0; + } + + private static TelephonyManager getTelephonyManager(Context context) { + return (TelephonyManager) context.getSystemService(Context.TELEPHONY_SERVICE); + } +} diff --git a/src-pre-N/com/android/dialer/calllog/VoicemailNotificationSettingsLookup.java b/src-pre-N/com/android/dialer/calllog/VoicemailNotificationSettingsLookup.java new file mode 100644 index 000000000..5e161f2ba --- /dev/null +++ b/src-pre-N/com/android/dialer/calllog/VoicemailNotificationSettingsLookup.java @@ -0,0 +1,34 @@ +/* + * Copyright (C) 2016 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.dialer.calllog; + +import android.app.Notification; +import android.content.Context; +import android.net.Uri; +import android.telecom.PhoneAccountHandle; + +/** + * Class to do lookup for voicemail ringtone. On pre-N, this is just the system defaults. + */ +public class VoicemailNotificationSettingsLookup { + public static Uri getVoicemailRingtoneUri(Context context, PhoneAccountHandle accountHandle) { + return null; + } + + public static int getNotificationDefaults(Context context, PhoneAccountHandle accountHandle) { + return Notification.DEFAULT_ALL; + } +} diff --git a/src/com/android/dialer/calllog/DefaultVoicemailNotifier.java b/src/com/android/dialer/calllog/DefaultVoicemailNotifier.java index 2b894a12d..d0156cf7f 100644 --- a/src/com/android/dialer/calllog/DefaultVoicemailNotifier.java +++ b/src/com/android/dialer/calllog/DefaultVoicemailNotifier.java @@ -24,6 +24,7 @@ import com.google.common.collect.Maps; import android.app.Notification; import android.app.NotificationManager; import android.app.PendingIntent; +import android.content.ComponentName; import android.content.ContentResolver; import android.content.ContentUris; import android.content.Context; @@ -33,6 +34,7 @@ import android.database.Cursor; import android.net.Uri; import android.provider.CallLog.Calls; import android.provider.ContactsContract.PhoneLookup; +import android.telecom.PhoneAccountHandle; import android.telephony.PhoneNumberUtils; import android.text.TextUtils; import android.util.Log; @@ -194,13 +196,26 @@ public class DefaultVoicemailNotifier { // TODO: Use the photo of contact if all calls are from the same person. final int icon = android.R.drawable.stat_notify_voicemail; + Uri ringtoneUri = null; + int notificationDefaults = 0; + if (callToNotify != null) { + PhoneAccountHandle accountHandle = new PhoneAccountHandle( + ComponentName.unflattenFromString(callToNotify.accountComponentName), + callToNotify.accountId); + ringtoneUri = VoicemailNotificationSettingsLookup + .getVoicemailRingtoneUri(mContext, accountHandle); + notificationDefaults = VoicemailNotificationSettingsLookup + .getNotificationDefaults(mContext, accountHandle); + } + Notification.Builder notificationBuilder = new Notification.Builder(mContext) .setSmallIcon(icon) .setContentTitle(title) .setContentText(callers) .setStyle(new Notification.BigTextStyle().bigText(transcription)) .setColor(resources.getColor(R.color.dialer_theme_color)) - .setDefaults(callToNotify != null ? Notification.DEFAULT_ALL : 0) + .setSound(ringtoneUri) + .setDefaults(notificationDefaults) .setDeleteIntent(createMarkNewVoicemailsAsOldIntent()) .setAutoCancel(true); |