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 /src | |
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
Diffstat (limited to 'src')
-rw-r--r-- | src/com/android/dialer/calllog/DefaultVoicemailNotifier.java | 17 |
1 files changed, 16 insertions, 1 deletions
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); |