• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (C) 2013 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License
15  */
16 
17 package com.android.dialer.calllog;
18 
19 import android.content.ComponentName;
20 import android.content.Context;
21 import android.support.annotation.Nullable;
22 import android.telecom.PhoneAccount;
23 import android.telecom.PhoneAccountHandle;
24 import android.text.TextUtils;
25 
26 import com.android.contacts.common.compat.CompatUtils;
27 import com.android.dialer.util.TelecomUtil;
28 
29 import java.util.ArrayList;
30 import java.util.List;
31 
32 /**
33  * Methods to help extract {@code PhoneAccount} information from database and Telecomm sources.
34  */
35 public class PhoneAccountUtils {
36     /**
37      * Return a list of phone accounts that are subscription/SIM accounts.
38      */
getSubscriptionPhoneAccounts(Context context)39     public static List<PhoneAccountHandle> getSubscriptionPhoneAccounts(Context context) {
40         List<PhoneAccountHandle> subscriptionAccountHandles = new ArrayList<PhoneAccountHandle>();
41         final List<PhoneAccountHandle> accountHandles =
42                 TelecomUtil.getCallCapablePhoneAccounts(context);
43         for (PhoneAccountHandle accountHandle : accountHandles) {
44             PhoneAccount account = TelecomUtil.getPhoneAccount(context, accountHandle);
45             if (account.hasCapabilities(PhoneAccount.CAPABILITY_SIM_SUBSCRIPTION)) {
46                 subscriptionAccountHandles.add(accountHandle);
47             }
48         }
49         return subscriptionAccountHandles;
50     }
51 
52     /**
53      * Compose PhoneAccount object from component name and account id.
54      */
55     @Nullable
getAccount(@ullable String componentString, @Nullable String accountId)56     public static PhoneAccountHandle getAccount(@Nullable String componentString,
57             @Nullable String accountId) {
58         if (TextUtils.isEmpty(componentString) || TextUtils.isEmpty(accountId)) {
59             return null;
60         }
61         final ComponentName componentName = ComponentName.unflattenFromString(componentString);
62         if (componentName == null) {
63             return null;
64         }
65         return new PhoneAccountHandle(componentName, accountId);
66     }
67 
68     /**
69      * Extract account label from PhoneAccount object.
70      */
71     @Nullable
getAccountLabel(Context context, @Nullable PhoneAccountHandle accountHandle)72     public static String getAccountLabel(Context context,
73             @Nullable PhoneAccountHandle accountHandle) {
74         PhoneAccount account = getAccountOrNull(context, accountHandle);
75         if (account != null && account.getLabel() != null) {
76             return account.getLabel().toString();
77         }
78         return null;
79     }
80 
81     /**
82      * Extract account color from PhoneAccount object.
83      */
getAccountColor(Context context, @Nullable PhoneAccountHandle accountHandle)84     public static int getAccountColor(Context context, @Nullable PhoneAccountHandle accountHandle) {
85         final PhoneAccount account = TelecomUtil.getPhoneAccount(context, accountHandle);
86 
87         // For single-sim devices the PhoneAccount will be NO_HIGHLIGHT_COLOR by default, so it is
88         // safe to always use the account highlight color.
89         return account == null ? PhoneAccount.NO_HIGHLIGHT_COLOR : account.getHighlightColor();
90     }
91 
92     /**
93      * Determine whether a phone account supports call subjects.
94      *
95      * @return {@code true} if call subjects are supported, {@code false} otherwise.
96      */
getAccountSupportsCallSubject(Context context, @Nullable PhoneAccountHandle accountHandle)97     public static boolean getAccountSupportsCallSubject(Context context,
98             @Nullable PhoneAccountHandle accountHandle) {
99         final PhoneAccount account = TelecomUtil.getPhoneAccount(context, accountHandle);
100 
101         return account == null ? false :
102                 account.hasCapabilities(PhoneAccount.CAPABILITY_CALL_SUBJECT);
103     }
104 
105     /**
106      * Retrieve the account metadata, but if the account does not exist or the device has only a
107      * single registered and enabled account, return null.
108      */
109     @Nullable
getAccountOrNull(Context context, @Nullable PhoneAccountHandle accountHandle)110     private static PhoneAccount getAccountOrNull(Context context,
111             @Nullable PhoneAccountHandle accountHandle) {
112         if (TelecomUtil.getCallCapablePhoneAccounts(context).size() <= 1) {
113             return null;
114         }
115         return TelecomUtil.getPhoneAccount(context, accountHandle);
116     }
117 }
118