/* * 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.app.calllog; import android.content.ContentValues; 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.model.Contact; import com.android.contacts.common.model.ContactLoader; import com.android.dialer.calldetails.CallDetailsActivity; import com.android.dialer.calldetails.CallDetailsEntries; import com.android.dialer.callintent.CallInitiationType; import com.android.dialer.callintent.CallIntentBuilder; import com.android.dialer.dialercontact.DialerContact; import com.android.dialer.lightbringer.LightbringerComponent; import com.android.dialer.util.CallUtil; import com.android.dialer.util.IntentUtil; import java.util.ArrayList; /** * Used to create an intent to attach to an action in the call log. * *
The intent is constructed lazily with the given information.
*/
public abstract class IntentProvider {
private static final String TAG = IntentProvider.class.getSimpleName();
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, CallInitiationType.Type.CALL_LOG)
.setPhoneAccountHandle(accountHandle)
.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, CallInitiationType.Type.CALL_LOG)
.setPhoneAccountHandle(accountHandle)
.setIsVideoCall(true)
.build();
}
};
}
public static IntentProvider getLightbringerIntentProvider(String number) {
return new IntentProvider() {
@Override
public Intent getIntent(Context context) {
return LightbringerComponent.get(context).getLightbringer().getIntent(context, number);
}
};
}
public static IntentProvider getReturnVoicemailCallIntentProvider() {
return new IntentProvider() {
@Override
public Intent getIntent(Context context) {
return new CallIntentBuilder(CallUtil.getVoicemailUri(), CallInitiationType.Type.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 callDetailsEntries The call details of the other calls grouped together with the call.
* @param contact The contact with which this call details intent pertains to.
* @return The call details intent provider.
*/
public static IntentProvider getCallDetailIntentProvider(
CallDetailsEntries callDetailsEntries, DialerContact contact, boolean canReportCallerId) {
return new IntentProvider() {
@Override
public Intent getIntent(Context context) {
return CallDetailsActivity.newInstance(
context, callDetailsEntries, contact, canReportCallerId);
}
};
}
/** 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