Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 3adafdcc authored by jeffreyhuang's avatar jeffreyhuang
Browse files

Dynamic preferences for IMEI

 - Support N-sim devices for imei preference

Bug: 36458278
Test: make RunSettingsRoboTests -j40
Change-Id: I0dda78b44e0c64ddd69c9a30e90c49f03b2260f3
parent a414573d
Loading
Loading
Loading
Loading
+2 −6
Original line number Diff line number Diff line
@@ -2664,9 +2664,7 @@
    <!-- [CHAR LIMIT=100] Main settings screen item's summary for the SD card and storage settings -->
    <string name="storage_settings_summary" product="default">Unmount SD card, view available storage</string>
    <!-- About phone screen, title for IMEI for multi-sim devices -->
    <string name="imei_multi_sim_slot_1">IMEI (sim slot 1)</string>
    <!-- About phone screen, title for IMEI for multi-sim devices -->
    <string name="imei_multi_sim_slot_2">IMEI (sim slot 2)</string>
    <string name="imei_multi_sim">IMEI (sim slot %1$d)</string>
    <!-- Do not translate. About phone, status item title -->
    <string name="status_imei">IMEI</string>
    <!-- Do not translate. About phone, status item title -->
@@ -2688,9 +2686,7 @@
    <!-- About phone, status item title.  The phone PRL Version of the current device.-->
    <string name="status_prl_version">PRL version</string>
    <!-- About phone screen, title for MEID for multi-sim devices -->
    <string name="meid_multi_sim_sim_slot_1">MEID (sim slot 1)</string>
    <!-- About phone screen, title for MEID for multi-sim devices -->
    <string name="meid_multi_sim_sim_slot_2">MEID (sim slot 2)</string>
    <string name="meid_multi_sim">MEID (sim slot %1$d)</string>
    <!-- About phone, status item title.  The phone MEID number of the current LTE/CDMA device. [CHAR LIMIT=30] -->
    <string name="status_meid_number">MEID</string>
    <!-- About phone, status item title.  The ICCID of the current LTE device. [CHAR LIMIT=30] -->
+15 −9
Original line number Diff line number Diff line
@@ -25,18 +25,21 @@
    <!-- Phone number -->
    <Preference
        android:key="phone_number"
        android:order="0"
        android:title="@string/status_number"
        android:summary="@string/summary_placeholder"/>

    <!-- SIM status Sim Slot 1 -->
    <Preference
        android:key="sim_status_sim_1"
        android:order="10"
        android:title="@string/sim_status_title"
        android:summary="@string/summary_placeholder"/>

    <!-- SIM status Sim Slot 2-->
    <Preference
        android:key="sim_status_sim_2"
        android:order="11"
        android:title="@string/sim_status_title_sim_slot_2"
        android:summary="@string/summary_placeholder"/>

@@ -44,32 +47,29 @@
    <!-- Model & hardware -->
    <Preference
        android:key="device_model"
        android:order="21"
        android:title="@string/hardware_info"
        android:summary="@string/summary_placeholder"/>

    <!-- IMEI Sim Slot 1 -->
    <!-- IMEI -->
    <Preference
        android:key="imei_info_sim_slot_1"
        android:key="imei_info"
        android:order="22"
        android:title="@string/status_imei"
        settings:keywords="@string/keywords_imei_info"
        android:summary="@string/summary_placeholder"/>

    <!-- IMEI Sim Slot 2 -->
    <Preference
        android:key="imei_info_sim_slot_2"
        android:title="@string/imei_multi_sim_slot_2"
        settings:keywords="@string/keywords_imei_info"
        android:summary="@string/summary_placeholder"/>

    <!-- Android version -->
    <Preference
        android:key="firmware_version"
        android:order="32"
        android:title="@string/firmware_version"
        android:summary="@string/summary_placeholder"/>

    <!--IP address -->
    <Preference
        android:key="wifi_ip_address"
        android:order="33"
        android:title="@string/wifi_ip_address"
        android:summary="@string/summary_placeholder"
        settings:allowDividerAbove="true"/>
@@ -77,12 +77,14 @@
    <!-- Wi-Fi MAC address -->
    <Preference
        android:key="wifi_mac_address"
        android:order="34"
        android:title="@string/status_wifi_mac_address"
        android:summary="@string/summary_placeholder"/>

    <!-- Bluetooth address -->
    <Preference
        android:key="bt_address"
        android:order="35"
        android:title="@string/status_bt_address"
        android:summary="@string/summary_placeholder"/>

@@ -90,6 +92,7 @@
    <!-- Legal information -->
    <Preference
        android:key="legal_container"
        android:order="36"
        android:title="@string/legal_information"
        android:fragment="com.android.settings.LegalSettings"
        settings:allowDividerAbove="true"/>
@@ -97,6 +100,7 @@
    <!-- Regulatory labels -->
    <Preference
        android:key="regulatory_info"
        android:order="37"
        android:title="@string/regulatory_labels">
        <intent android:action="android.settings.SHOW_REGULATORY_INFO"/>
    </Preference>
@@ -104,6 +108,7 @@
    <!-- Safety & regulatory manual -->
    <Preference
        android:key="safety_info"
        android:order="38"
        android:title="@string/safety_and_regulatory_info">
        <intent android:action="android.settings.SHOW_SAFETY_AND_REGULATORY_INFO"/>
    </Preference>
@@ -111,6 +116,7 @@
    <!-- Build number -->
    <Preference
        android:key="build_number"
        android:order="39"
        android:title="@string/build_number"
        android:summary="@string/summary_placeholder"
        settings:allowDividerAbove="true"/>
+3 −6
Original line number Diff line number Diff line
@@ -34,17 +34,16 @@ import com.android.settings.deviceinfo.FccEquipmentIdPreferenceController;
import com.android.settings.deviceinfo.FeedbackPreferenceController;
import com.android.settings.deviceinfo.FirmwareVersionPreferenceController;
import com.android.settings.deviceinfo.IpAddressPreferenceController;
import com.android.settings.deviceinfo.WifiMacAddressPreferenceController;
import com.android.settings.deviceinfo.imei.ImeiInfoDualSimPreferenceController;
import com.android.settings.deviceinfo.imei.ImeiInfoPreferenceControllerV2;
import com.android.settings.deviceinfo.KernelVersionPreferenceController;
import com.android.settings.deviceinfo.ManualPreferenceController;
import com.android.settings.deviceinfo.RegulatoryInfoPreferenceController;
import com.android.settings.deviceinfo.SafetyInfoPreferenceController;
import com.android.settings.deviceinfo.SecurityPatchPreferenceController;
import com.android.settings.deviceinfo.WifiMacAddressPreferenceController;
import com.android.settings.deviceinfo.firmwareversion.FirmwareVersionPreferenceControllerV2;
import com.android.settings.deviceinfo.imei.ImeiInfoPreferenceControllerV2;
import com.android.settings.deviceinfo.simstatus.SimStatusDualSimPreferenceController;
import com.android.settings.deviceinfo.simstatus.SimStatusPreferenceControllerV2;
import com.android.settings.deviceinfo.firmwareversion.FirmwareVersionPreferenceControllerV2;
import com.android.settings.search.BaseSearchIndexProvider;
import com.android.settings.search.Indexable;
import com.android.settingslib.core.AbstractPreferenceController;
@@ -140,8 +139,6 @@ public class DeviceInfoSettings extends DashboardFragment implements Indexable {

            controllers.add(new ImeiInfoPreferenceControllerV2(context, fragment));

            controllers.add(new ImeiInfoDualSimPreferenceController(context, fragment));

            controllers.add(new FirmwareVersionPreferenceControllerV2(context, fragment));

            controllers.add(new IpAddressPreferenceController(context, lifecycle));
+0 −99
Original line number Diff line number Diff line
/*
 * Copyright (C) 2017 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.settings.deviceinfo.imei;

import static android.telephony.TelephonyManager.PHONE_TYPE_CDMA;

import android.app.Fragment;
import android.content.Context;
import android.support.annotation.VisibleForTesting;
import android.support.v7.preference.Preference;
import android.support.v7.preference.PreferenceScreen;
import android.telephony.TelephonyManager;
import android.text.TextUtils;

import com.android.settings.core.PreferenceControllerMixin;
import com.android.settingslib.deviceinfo.AbstractSimStatusImeiInfoPreferenceController;

/**
 * Controller that manages preference for single and dual sim devices.
 */
public abstract class AbstractImeiInfoPreferenceController extends
        AbstractSimStatusImeiInfoPreferenceController implements PreferenceControllerMixin {

    protected final boolean mIsMultiSim;
    protected final TelephonyManager mTelephonyManager;

    private Preference mPreference;
    private Fragment mFragment;

    public AbstractImeiInfoPreferenceController(Context context, Fragment fragment) {
        super(context);

        mFragment = fragment;
        mTelephonyManager = (TelephonyManager) context.getSystemService(Context.TELEPHONY_SERVICE);
        mIsMultiSim = mTelephonyManager.getPhoneCount() > 1;
    }

    @Override
    public void displayPreference(PreferenceScreen screen) {
        super.displayPreference(screen);
        mPreference = screen.findPreference(getPreferenceKey());
        if (mPreference == null) {
            return;
        }
        final int phoneType = mTelephonyManager.getPhoneType();
        if (phoneType == PHONE_TYPE_CDMA) {
            mPreference.setTitle(getTitleForCdmaPhone());
            mPreference.setSummary(getMeid());
        } else {
            // GSM phone
            mPreference.setTitle(getTitleForGsmPhone());
            mPreference.setSummary(mTelephonyManager.getImei(getSimSlot()));
        }
    }

    @Override
    public boolean handlePreferenceTreeClick(Preference preference) {
        if (!TextUtils.equals(preference.getKey(), getPreferenceKey())) {
            return false;
        }

        ImeiInfoDialogFragment.show(mFragment, getSimSlot(), mPreference.getTitle().toString());
        return true;
    }

    /**
     * @return The preference title for phones based on CDMA technology.
     */
    protected abstract String getTitleForCdmaPhone();

    /**
     * @return The preference title for phones based on GSM technology.
     */
    protected abstract String getTitleForGsmPhone();

    /**
     * @return The sim slot to retrieve IMEI/CDMA information about.
     */
    protected abstract int getSimSlot();

    @VisibleForTesting
    String getMeid() {
        return mTelephonyManager.getMeid(getSimSlot());
    }
}
+0 −57
Original line number Diff line number Diff line
/*
 * Copyright (C) 2017 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.settings.deviceinfo.imei;

import android.app.Fragment;
import android.content.Context;

import com.android.settings.R;

public class ImeiInfoDualSimPreferenceController extends AbstractImeiInfoPreferenceController {

    private static final String KEY_IMEI_INFO_DUAL_SIM = "imei_info_sim_slot_2";
    private static final int SIM_SLOT = 1;

    public ImeiInfoDualSimPreferenceController(Context context, Fragment fragment) {
        super(context, fragment);
    }

    @Override
    public boolean isAvailable() {
        return super.isAvailable() && mIsMultiSim;
    }

    @Override
    public String getPreferenceKey() {
        return KEY_IMEI_INFO_DUAL_SIM;
    }

    @Override
    protected String getTitleForCdmaPhone() {
        return mContext.getResources().getString(R.string.meid_multi_sim_sim_slot_2);
    }

    @Override
    protected String getTitleForGsmPhone() {
        return mContext.getResources().getString(R.string.imei_multi_sim_slot_2);
    }

    @Override
    protected int getSimSlot() {
        return SIM_SLOT;
    }
}
Loading