| /* |
| * Copyright (C) 2011 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.content.ContentValues; |
| import android.content.ContentUris; |
| import android.content.Context; |
| import android.content.Intent; |
| import android.net.Uri; |
| import android.provider.ContactsContract; |
| import android.telecom.PhoneAccountHandle; |
| |
| import com.android.contacts.common.CallUtil; |
| import com.android.contacts.common.model.Contact; |
| import com.android.contacts.common.model.ContactLoader; |
| import com.android.dialer.CallDetailActivity; |
| import com.android.dialer.util.IntentUtil; |
| import com.android.dialer.util.IntentUtil.CallIntentBuilder; |
| import com.android.dialer.util.TelecomUtil; |
| import com.android.incallui.Call.LogState; |
| |
| import java.util.ArrayList; |
| |
| /** |
| * Used to create an intent to attach to an action in the call log. |
| * <p> |
| * The intent is constructed lazily with the given information. |
| */ |
| public abstract class IntentProvider { |
| |
| private static final String TAG = IntentProvider.class.getSimpleName(); |
| |
| public abstract Intent getIntent(Context context); |
| |
| public static IntentProvider getReturnCallIntentProvider(final String number) { |
| return getReturnCallIntentProvider(number, null); |
| } |
| |
| public static IntentProvider getReturnCallIntentProvider(final String number, |
| final PhoneAccountHandle accountHandle) { |
| return new IntentProvider() { |
| @Override |
| public Intent getIntent(Context context) { |
| return new CallIntentBuilder(number) |
| .setPhoneAccountHandle(accountHandle) |
| .setCallInitiationType(LogState.INITIATION_CALL_LOG) |
| .build(); |
| } |
| }; |
| } |
| |
| public static IntentProvider getReturnVideoCallIntentProvider(final String number) { |
| return getReturnVideoCallIntentProvider(number, null); |
| } |
| |
| public static IntentProvider getReturnVideoCallIntentProvider(final String number, |
| final PhoneAccountHandle accountHandle) { |
| return new IntentProvider() { |
| @Override |
| public Intent getIntent(Context context) { |
| return new CallIntentBuilder(number) |
| .setPhoneAccountHandle(accountHandle) |
| .setCallInitiationType(LogState.INITIATION_CALL_LOG) |
| .setIsVideoCall(true) |
| .build(); |
| } |
| }; |
| } |
| |
| public static IntentProvider getReturnVoicemailCallIntentProvider() { |
| return new IntentProvider() { |
| @Override |
| public Intent getIntent(Context context) { |
| return new CallIntentBuilder(CallUtil.getVoicemailUri()) |
| .setCallInitiationType(LogState.INITIATION_CALL_LOG) |
| .build(); |
| } |
| }; |
| } |
| |
| public static IntentProvider getSendSmsIntentProvider(final String number) { |
| return new IntentProvider() { |
| @Override |
| public Intent getIntent(Context context) { |
| return IntentUtil.getSendSmsIntent(number); |
| } |
| }; |
| } |
| |
| /** |
| * Retrieves the call details intent provider for an entry in the call log. |
| * |
| * @param id The call ID of the first call in the call group. |
| * @param extraIds The call ID of the other calls grouped together with the call. |
| * @param voicemailUri If call log entry is for a voicemail, the voicemail URI. |
| * @return The call details intent provider. |
| */ |
| public static IntentProvider getCallDetailIntentProvider( |
| final long id, final long[] extraIds, final String voicemailUri) { |
| return new IntentProvider() { |
| @Override |
| public Intent getIntent(Context context) { |
| Intent intent = new Intent(context, CallDetailActivity.class); |
| // Check if the first item is a voicemail. |
| if (voicemailUri != null) { |
| intent.putExtra(CallDetailActivity.EXTRA_VOICEMAIL_URI, |
| Uri.parse(voicemailUri)); |
| } |
| |
| if (extraIds != null && extraIds.length > 0) { |
| intent.putExtra(CallDetailActivity.EXTRA_CALL_LOG_IDS, extraIds); |
| } else { |
| // If there is a single item, use the direct URI for it. |
| intent.setData(ContentUris.withAppendedId(TelecomUtil.getCallLogUri(context), |
| id)); |
| } |
| return intent; |
| } |
| }; |
| } |
| |
| /** |
| * Retrieves an add contact intent for the given contact and phone call details. |
| */ |
| public static IntentProvider getAddContactIntentProvider( |
| final Uri lookupUri, |
| final CharSequence name, |
| final CharSequence number, |
| final int numberType, |
| final boolean isNewContact) { |
| return new IntentProvider() { |
| @Override |
| public Intent getIntent(Context context) { |
| Contact contactToSave = null; |
| |
| if (lookupUri != null) { |
| contactToSave = ContactLoader.parseEncodedContactEntity(lookupUri); |
| } |
| |
| if (contactToSave != null) { |
| // Populate the intent with contact information stored in the lookup URI. |
| // Note: This code mirrors code in Contacts/QuickContactsActivity. |
| final Intent intent; |
| if (isNewContact) { |
| intent = IntentUtil.getNewContactIntent(); |
| } else { |
| intent = IntentUtil.getAddToExistingContactIntent(); |
| } |
| |
| ArrayList<ContentValues> values = contactToSave.getContentValues(); |
| // Only pre-fill the name field if the provided display name is an nickname |
| // or better (e.g. structured name, nickname) |
| if (contactToSave.getDisplayNameSource() |
| >= ContactsContract.DisplayNameSources.NICKNAME) { |
| intent.putExtra(ContactsContract.Intents.Insert.NAME, |
| contactToSave.getDisplayName()); |
| } else if (contactToSave.getDisplayNameSource() |
| == ContactsContract.DisplayNameSources.ORGANIZATION) { |
| // This is probably an organization. Instead of copying the organization |
| // name into a name entry, copy it into the organization entry. This |
| // way we will still consider the contact an organization. |
| final ContentValues organization = new ContentValues(); |
| organization.put(ContactsContract.CommonDataKinds.Organization.COMPANY, |
| contactToSave.getDisplayName()); |
| organization.put(ContactsContract.Data.MIMETYPE, |
| ContactsContract.CommonDataKinds.Organization.CONTENT_ITEM_TYPE); |
| values.add(organization); |
| } |
| |
| // Last time used and times used are aggregated values from the usage stat |
| // table. They need to be removed from data values so the SQL table can insert |
| // properly |
| for (ContentValues value : values) { |
| value.remove(ContactsContract.Data.LAST_TIME_USED); |
| value.remove(ContactsContract.Data.TIMES_USED); |
| } |
| |
| intent.putExtra(ContactsContract.Intents.Insert.DATA, values); |
| |
| return intent; |
| } else { |
| // If no lookup uri is provided, rely on the available phone number and name. |
| if (isNewContact) { |
| return IntentUtil.getNewContactIntent(name, number, numberType); |
| } else { |
| return IntentUtil.getAddToExistingContactIntent(name, number, numberType); |
| } |
| } |
| } |
| }; |
| } |
| } |