blob: 14faebc1e5e2321cb1b5a5b60e1bb02bcb4889b8 [file] [log] [blame]
/**
* Copyright (C) 2014 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.phone;
import android.app.ActionBar;
import android.content.Context;
import android.content.Intent;
import android.content.res.Resources;
import android.telecom.PhoneAccountHandle;
import android.telephony.SubscriptionInfo;
import android.telephony.SubscriptionManager;
import android.telephony.TelephonyManager;
import android.text.TextUtils;
import com.android.internal.telephony.Phone;
import com.android.internal.telephony.PhoneFactory;
/**
* Helper for manipulating intents or components with subscription-related information.
*
* In settings, subscription ids and labels are passed along to indicate that settings
* are being changed for particular subscriptions. This helper provides functions for
* helping extract this info and perform common operations using this info.
*/
public class SubscriptionInfoHelper {
// Extra on intent containing the id of a subscription.
public static final String SUB_ID_EXTRA =
"com.android.phone.settings.SubscriptionInfoHelper.SubscriptionId";
// Extra on intent containing the label of a subscription.
private static final String SUB_LABEL_EXTRA =
"com.android.phone.settings.SubscriptionInfoHelper.SubscriptionLabel";
private Context mContext;
private int mSubId = SubscriptionManager.INVALID_SUBSCRIPTION_ID;
private String mSubLabel;
/**
* Instantiates the helper, by extracting the subscription id and label from the intent.
*/
public SubscriptionInfoHelper(Context context, Intent intent) {
mContext = context;
PhoneAccountHandle phoneAccountHandle =
intent.getParcelableExtra(TelephonyManager.EXTRA_PHONE_ACCOUNT_HANDLE);
if (phoneAccountHandle != null) {
mSubId = PhoneUtils.getSubIdForPhoneAccountHandle(phoneAccountHandle);
}
if (mSubId == SubscriptionManager.INVALID_SUBSCRIPTION_ID) {
mSubId = intent.getIntExtra(SUB_ID_EXTRA, SubscriptionManager.INVALID_SUBSCRIPTION_ID);
}
mSubLabel = intent.getStringExtra(SUB_LABEL_EXTRA);
}
/**
* @param newActivityClass The class of the activity for the intent to start.
* @return Intent containing extras for the subscription id and label if they exist.
*/
public Intent getIntent(Class newActivityClass) {
Intent intent = new Intent(mContext, newActivityClass);
if (hasSubId()) {
intent.putExtra(SUB_ID_EXTRA, mSubId);
}
if (!TextUtils.isEmpty(mSubLabel)) {
intent.putExtra(SUB_LABEL_EXTRA, mSubLabel);
}
return intent;
}
public static void addExtrasToIntent(Intent intent, SubscriptionInfo subscription) {
if (subscription == null) {
return;
}
intent.putExtra(SubscriptionInfoHelper.SUB_ID_EXTRA, subscription.getSubscriptionId());
intent.putExtra(
SubscriptionInfoHelper.SUB_LABEL_EXTRA, subscription.getDisplayName() == null ? null
: subscription.getDisplayName().toString());
}
/**
* @return Phone object. If a subscription id exists, it returns the phone for the id.
*/
public Phone getPhone() {
return hasSubId()
? PhoneFactory.getPhone(SubscriptionManager.getPhoneId(mSubId))
: PhoneGlobals.getPhone();
}
/**
* Sets the action bar title to the string specified by the given resource id, formatting
* it with the subscription label. This assumes the resource string is formattable with a
* string-type specifier.
*
* If the subscription label does not exists, leave the existing title.
*/
public void setActionBarTitle(ActionBar actionBar, Resources res, int resId) {
if (actionBar == null || TextUtils.isEmpty(mSubLabel)) {
return;
}
if (!TelephonyManager.from(mContext).isMultiSimEnabled()) {
return;
}
String title = String.format(res.getString(resId), mSubLabel);
actionBar.setTitle(title);
}
public boolean hasSubId() {
return mSubId != SubscriptionManager.INVALID_SUBSCRIPTION_ID;
}
public int getSubId() {
return mSubId;
}
}