Merge "[Settings] Support of Primary IMEI feature"
This commit is contained in:
@@ -55,6 +55,7 @@ import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.concurrent.ExecutorService;
|
||||
import java.util.concurrent.Executors;
|
||||
import java.util.function.Consumer;
|
||||
|
||||
@SearchIndexable
|
||||
public class MyDeviceInfoFragment extends DashboardFragment
|
||||
@@ -79,7 +80,6 @@ public class MyDeviceInfoFragment extends DashboardFragment
|
||||
@Override
|
||||
public void onAttach(Context context) {
|
||||
super.onAttach(context);
|
||||
use(ImeiInfoPreferenceController.class).setHost(this /* parent */);
|
||||
use(DeviceNamePreferenceController.class).setHost(this /* parent */);
|
||||
mBuildNumberPreferenceController = use(BuildNumberPreferenceController.class);
|
||||
mBuildNumberPreferenceController.setHost(this /* parent */);
|
||||
@@ -126,12 +126,27 @@ public class MyDeviceInfoFragment extends DashboardFragment
|
||||
controllers.add(new FccEquipmentIdPreferenceController(context));
|
||||
controllers.add(new UptimePreferenceController(context, lifecycle));
|
||||
|
||||
Consumer<String> imeiInfoList = imeiKey -> {
|
||||
ImeiInfoPreferenceController imeiRecord =
|
||||
new ImeiInfoPreferenceController(context, imeiKey);
|
||||
imeiRecord.init(fragment, slotSimStatus);
|
||||
controllers.add(imeiRecord);
|
||||
};
|
||||
|
||||
if (fragment != null) {
|
||||
imeiInfoList.accept(ImeiInfoPreferenceController.DEFAULT_KEY);
|
||||
}
|
||||
|
||||
for (int slotIndex = 0; slotIndex < slotSimStatus.size(); slotIndex ++) {
|
||||
SimStatusPreferenceController slotRecord =
|
||||
new SimStatusPreferenceController(context,
|
||||
slotSimStatus.getPreferenceKey(slotIndex));
|
||||
slotRecord.init(fragment, slotSimStatus);
|
||||
controllers.add(slotRecord);
|
||||
|
||||
if (fragment != null) {
|
||||
imeiInfoList.accept(ImeiInfoPreferenceController.DEFAULT_KEY + (1 + slotIndex));
|
||||
}
|
||||
}
|
||||
|
||||
EidStatus eidStatus = new EidStatus(slotSimStatus, context, executor);
|
||||
|
@@ -23,6 +23,7 @@ import android.os.UserManager;
|
||||
import android.telephony.SubscriptionInfo;
|
||||
import android.telephony.SubscriptionManager;
|
||||
import android.telephony.TelephonyManager;
|
||||
import android.util.Log;
|
||||
|
||||
import androidx.annotation.VisibleForTesting;
|
||||
import androidx.fragment.app.Fragment;
|
||||
@@ -33,70 +34,80 @@ import androidx.preference.PreferenceScreen;
|
||||
import com.android.settings.R;
|
||||
import com.android.settings.core.BasePreferenceController;
|
||||
import com.android.settings.deviceinfo.PhoneNumberSummaryPreference;
|
||||
import com.android.settings.deviceinfo.simstatus.SlotSimStatus;
|
||||
import com.android.settings.network.SubscriptionUtil;
|
||||
import com.android.settingslib.Utils;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* Controller that manages preference for single and multi sim devices.
|
||||
*/
|
||||
public class ImeiInfoPreferenceController extends BasePreferenceController {
|
||||
|
||||
private static final String KEY_PREFERENCE_CATEGORY = "device_detail_category";
|
||||
private static final String TAG = "ImeiInfoPreferenceController";
|
||||
|
||||
private final boolean mIsMultiSim;
|
||||
private final TelephonyManager mTelephonyManager;
|
||||
private final List<Preference> mPreferenceList = new ArrayList<>();
|
||||
private static final String KEY_PREFERENCE_CATEGORY = "device_detail_category";
|
||||
public static final String DEFAULT_KEY = "imei_info";
|
||||
|
||||
private TelephonyManager mTelephonyManager;
|
||||
private Fragment mFragment;
|
||||
private SlotSimStatus mSlotSimStatus;
|
||||
|
||||
public ImeiInfoPreferenceController(Context context, String key) {
|
||||
super(context, key);
|
||||
mTelephonyManager = (TelephonyManager) context.getSystemService(Context.TELEPHONY_SERVICE);
|
||||
mIsMultiSim = mTelephonyManager.getPhoneCount() > 1;
|
||||
}
|
||||
|
||||
public void setHost(Fragment fragment) {
|
||||
public void init(Fragment fragment, SlotSimStatus slotSimStatus) {
|
||||
mFragment = fragment;
|
||||
mSlotSimStatus = slotSimStatus;
|
||||
}
|
||||
|
||||
private boolean isMultiSim() {
|
||||
return (mSlotSimStatus != null) && (mSlotSimStatus.size() > 1);
|
||||
}
|
||||
|
||||
private int keyToSlotIndex(String key) {
|
||||
int simSlot = SubscriptionManager.INVALID_SIM_SLOT_INDEX;
|
||||
try {
|
||||
simSlot = Integer.valueOf(key.replace(DEFAULT_KEY, "")) - 1;
|
||||
} catch (Exception exception) {
|
||||
Log.i(TAG, "Invalid key : " + key);
|
||||
}
|
||||
return simSlot;
|
||||
}
|
||||
|
||||
private SubscriptionInfo getSubscriptionInfo(int simSlot) {
|
||||
return (mSlotSimStatus == null) ? null : mSlotSimStatus.getSubscriptionInfo(simSlot);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void displayPreference(PreferenceScreen screen) {
|
||||
super.displayPreference(screen);
|
||||
if (!SubscriptionUtil.isSimHardwareVisible(mContext)) {
|
||||
if ((!SubscriptionUtil.isSimHardwareVisible(mContext)) || (mSlotSimStatus == null)) {
|
||||
return;
|
||||
}
|
||||
final Preference preference = screen.findPreference(getPreferenceKey());
|
||||
final PreferenceCategory category = screen.findPreference(KEY_PREFERENCE_CATEGORY);
|
||||
|
||||
mPreferenceList.add(preference);
|
||||
updatePreference(preference, 0 /* simSlot */);
|
||||
|
||||
final int imeiPreferenceOrder = preference.getOrder();
|
||||
// Add additional preferences for each sim in the device
|
||||
for (int simSlotNumber = 1; simSlotNumber < mTelephonyManager.getPhoneCount();
|
||||
simSlotNumber++) {
|
||||
final Preference multiSimPreference = createNewPreference(screen.getContext());
|
||||
multiSimPreference.setCopyingEnabled(true);
|
||||
multiSimPreference.setOrder(imeiPreferenceOrder + simSlotNumber);
|
||||
multiSimPreference.setKey(getPreferenceKey() + simSlotNumber);
|
||||
category.addPreference(multiSimPreference);
|
||||
mPreferenceList.add(multiSimPreference);
|
||||
updatePreference(multiSimPreference, simSlotNumber);
|
||||
mTelephonyManager = mContext.getSystemService(TelephonyManager.class);
|
||||
Preference preference = screen.findPreference(DEFAULT_KEY);
|
||||
if (!isAvailable() || preference == null || !preference.isVisible()) {
|
||||
return;
|
||||
}
|
||||
PreferenceCategory category = screen.findPreference(KEY_PREFERENCE_CATEGORY);
|
||||
|
||||
int imeiPreferenceOrder = preference.getOrder();
|
||||
screen.removePreference(preference);
|
||||
preference.setVisible(false);
|
||||
|
||||
// Add additional preferences for each imei slot in the device
|
||||
for (int simSlotNumber = 0; simSlotNumber < mSlotSimStatus.size(); simSlotNumber++) {
|
||||
Preference multiImeiPreference = createNewPreference(screen.getContext());
|
||||
multiImeiPreference.setOrder(imeiPreferenceOrder + 1 + simSlotNumber);
|
||||
multiImeiPreference.setKey(DEFAULT_KEY + (1 + simSlotNumber));
|
||||
category.addPreference(multiImeiPreference);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void updateState(Preference preference) {
|
||||
if (preference == null) {
|
||||
return;
|
||||
}
|
||||
int size = mPreferenceList.size();
|
||||
for (int i = 0; i < size; i++) {
|
||||
Preference pref = mPreferenceList.get(i);
|
||||
updatePreference(pref, i);
|
||||
}
|
||||
updatePreference(preference, keyToSlotIndex(preference.getKey()));
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -112,8 +123,8 @@ public class ImeiInfoPreferenceController extends BasePreferenceController {
|
||||
|
||||
@Override
|
||||
public boolean handlePreferenceTreeClick(Preference preference) {
|
||||
final int simSlot = mPreferenceList.indexOf(preference);
|
||||
if (simSlot == -1) {
|
||||
final int simSlot = keyToSlotIndex(preference.getKey());
|
||||
if (simSlot < 0) {
|
||||
return false;
|
||||
}
|
||||
|
||||
@@ -124,9 +135,10 @@ public class ImeiInfoPreferenceController extends BasePreferenceController {
|
||||
|
||||
@Override
|
||||
public int getAvailabilityStatus() {
|
||||
return SubscriptionUtil.isSimHardwareVisible(mContext) &&
|
||||
mContext.getSystemService(UserManager.class).isAdminUser()
|
||||
&& !Utils.isWifiOnly(mContext) ? AVAILABLE : UNSUPPORTED_ON_DEVICE;
|
||||
boolean isAvailable = SubscriptionUtil.isSimHardwareVisible(mContext) &&
|
||||
mContext.getSystemService(UserManager.class).isAdminUser() &&
|
||||
!Utils.isWifiOnly(mContext);
|
||||
return isAvailable ? AVAILABLE : UNSUPPORTED_ON_DEVICE;
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -135,29 +147,48 @@ public class ImeiInfoPreferenceController extends BasePreferenceController {
|
||||
}
|
||||
|
||||
private void updatePreference(Preference preference, int simSlot) {
|
||||
SubscriptionInfo subInfo = getSubscriptionInfo(simSlot);
|
||||
preference.setEnabled(subInfo != null);
|
||||
preference.setCopyingEnabled(subInfo != null);
|
||||
preference.setTitle(getTitle(simSlot));
|
||||
preference.setSummary(getSummary());
|
||||
}
|
||||
|
||||
private CharSequence getTitleForGsmPhone(int simSlot) {
|
||||
return mIsMultiSim ? mContext.getString(R.string.imei_multi_sim, simSlot + 1)
|
||||
private CharSequence getTitleForGsmPhone(int simSlot, boolean isPrimaryImei) {
|
||||
int titleId = isPrimaryImei ? R.string.imei_multi_sim_primary : R.string.imei_multi_sim;
|
||||
return isMultiSim() ? mContext.getString(titleId, simSlot + 1)
|
||||
: mContext.getString(R.string.status_imei);
|
||||
}
|
||||
|
||||
private CharSequence getTitleForCdmaPhone(int simSlot) {
|
||||
return mIsMultiSim ? mContext.getString(R.string.meid_multi_sim, simSlot + 1)
|
||||
private CharSequence getTitleForCdmaPhone(int simSlot, boolean isPrimaryImei) {
|
||||
int titleId = isPrimaryImei ? R.string.meid_multi_sim_primary : R.string.meid_multi_sim;
|
||||
return isMultiSim() ? mContext.getString(titleId, simSlot + 1)
|
||||
: mContext.getString(R.string.status_meid_number);
|
||||
}
|
||||
|
||||
private CharSequence getTitle(int simSlot) {
|
||||
final int phoneType = getPhoneType(simSlot);
|
||||
return phoneType == PHONE_TYPE_CDMA ? getTitleForCdmaPhone(simSlot)
|
||||
: getTitleForGsmPhone(simSlot);
|
||||
protected boolean isPrimaryImei(int simSlot) {
|
||||
CharSequence imei = getSummary(simSlot);
|
||||
if (imei == null) {
|
||||
return false;
|
||||
}
|
||||
String primaryImei = null;
|
||||
try {
|
||||
primaryImei = mTelephonyManager.getPrimaryImei();
|
||||
} catch (Exception exception) {
|
||||
Log.i(TAG, "PrimaryImei not available. " + exception);
|
||||
}
|
||||
return (primaryImei != null) && primaryImei.equals(imei.toString());
|
||||
}
|
||||
|
||||
private int getPhoneType(int slotIndex) {
|
||||
SubscriptionInfo subInfo = SubscriptionManager.from(mContext)
|
||||
.getActiveSubscriptionInfoForSimSlotIndex(slotIndex);
|
||||
private CharSequence getTitle(int simSlot) {
|
||||
boolean isPrimaryImei = isMultiSim() && isPrimaryImei(simSlot);
|
||||
final int phoneType = getPhoneType(simSlot);
|
||||
return phoneType == PHONE_TYPE_CDMA ? getTitleForCdmaPhone(simSlot, isPrimaryImei)
|
||||
: getTitleForGsmPhone(simSlot, isPrimaryImei);
|
||||
}
|
||||
|
||||
public int getPhoneType(int slotIndex) {
|
||||
SubscriptionInfo subInfo = getSubscriptionInfo(slotIndex);
|
||||
return mTelephonyManager.getCurrentPhoneType(subInfo != null ? subInfo.getSubscriptionId()
|
||||
: SubscriptionManager.DEFAULT_SUBSCRIPTION_ID);
|
||||
}
|
||||
|
Reference in New Issue
Block a user