[MEP] renew the default data selection UI
- renew the default Data/Call/SMS selection Bug: 199902896 Test: build pass and local UI test Change-Id: I5c6ad4b35d38112d5e88330a3fc9638be533bc94
This commit is contained in:
@@ -29,7 +29,7 @@ import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
import android.view.ViewGroup;
|
||||
import android.widget.BaseAdapter;
|
||||
import android.widget.ImageView;
|
||||
import android.widget.ListView;
|
||||
import android.widget.TextView;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
@@ -38,7 +38,6 @@ import androidx.annotation.VisibleForTesting;
|
||||
import androidx.appcompat.app.AlertDialog;
|
||||
|
||||
import com.android.settings.R;
|
||||
import com.android.settings.Utils;
|
||||
import com.android.settings.network.SubscriptionUtil;
|
||||
|
||||
import java.util.ArrayList;
|
||||
@@ -52,16 +51,19 @@ public class SimListDialogFragment extends SimDialogFragment implements
|
||||
DialogInterface.OnClickListener {
|
||||
private static final String TAG = "SimListDialogFragment";
|
||||
protected static final String KEY_INCLUDE_ASK_EVERY_TIME = "include_ask_every_time";
|
||||
protected static final String KEY_SHOW_CANCEL_ITEM = "show_cancel_item";
|
||||
private static final int LIST_VIEW_DIVIDER_LINE_WEIGHT = 2;
|
||||
|
||||
protected SelectSubscriptionAdapter mAdapter;
|
||||
@VisibleForTesting
|
||||
List<SubscriptionInfo> mSubscriptions;
|
||||
|
||||
public static SimListDialogFragment newInstance(int dialogType, int titleResId,
|
||||
boolean includeAskEveryTime) {
|
||||
boolean includeAskEveryTime, boolean isCancelItemShowed) {
|
||||
final SimListDialogFragment fragment = new SimListDialogFragment();
|
||||
final Bundle args = initArguments(dialogType, titleResId);
|
||||
args.putBoolean(KEY_INCLUDE_ASK_EVERY_TIME, includeAskEveryTime);
|
||||
args.putBoolean(KEY_SHOW_CANCEL_ITEM, isCancelItemShowed);
|
||||
fragment.setArguments(args);
|
||||
return fragment;
|
||||
}
|
||||
@@ -72,12 +74,20 @@ public class SimListDialogFragment extends SimDialogFragment implements
|
||||
mSubscriptions = new ArrayList<>();
|
||||
|
||||
final AlertDialog.Builder builder = new AlertDialog.Builder(getContext());
|
||||
builder.setTitle(getTitleResId());
|
||||
View titleView = LayoutInflater.from(getContext()).inflate(
|
||||
R.layout.sim_confirm_dialog_title_multiple_enabled_profiles_supported, null);
|
||||
TextView titleTextView = titleView.findViewById(R.id.title);
|
||||
titleTextView.setText(getContext().getString(getTitleResId()));
|
||||
builder.setCustomTitle(titleTextView);
|
||||
|
||||
mAdapter = new SelectSubscriptionAdapter(builder.getContext(), mSubscriptions);
|
||||
|
||||
setAdapter(builder);
|
||||
final Dialog dialog = builder.create();
|
||||
|
||||
final AlertDialog dialog = builder.create();
|
||||
ListView listView = dialog.getListView();
|
||||
if (listView != null) {
|
||||
listView.setDividerHeight(LIST_VIEW_DIVIDER_LINE_WEIGHT);
|
||||
}
|
||||
updateDialog();
|
||||
return dialog;
|
||||
}
|
||||
@@ -112,10 +122,22 @@ public class SimListDialogFragment extends SimDialogFragment implements
|
||||
}
|
||||
return;
|
||||
}
|
||||
if (getArguments().getBoolean(KEY_INCLUDE_ASK_EVERY_TIME)) {
|
||||
final List<SubscriptionInfo> tmp = new ArrayList<>(currentSubscriptions.size() + 1);
|
||||
tmp.add(null);
|
||||
boolean includeAskEveryTime = getArguments().getBoolean(KEY_INCLUDE_ASK_EVERY_TIME);
|
||||
boolean isCancelItemShowed = getArguments().getBoolean(KEY_SHOW_CANCEL_ITEM);
|
||||
if (includeAskEveryTime || isCancelItemShowed) {
|
||||
int arraySize = currentSubscriptions.size()
|
||||
+ (includeAskEveryTime ? 1 : 0)
|
||||
+ (isCancelItemShowed ? 1 : 0);
|
||||
final List<SubscriptionInfo> tmp = new ArrayList<>(arraySize);
|
||||
if (includeAskEveryTime) {
|
||||
// add the value of 'AskEveryTime' item
|
||||
tmp.add(null);
|
||||
}
|
||||
tmp.addAll(currentSubscriptions);
|
||||
if (isCancelItemShowed) {
|
||||
// add the value of 'Cancel' item
|
||||
tmp.add(null);
|
||||
}
|
||||
currentSubscriptions = tmp;
|
||||
}
|
||||
if (currentSubscriptions.equals(mSubscriptions)) {
|
||||
@@ -177,19 +199,23 @@ public class SimListDialogFragment extends SimDialogFragment implements
|
||||
|
||||
final TextView title = convertView.findViewById(R.id.title);
|
||||
final TextView summary = convertView.findViewById(R.id.summary);
|
||||
final ImageView icon = convertView.findViewById(R.id.icon);
|
||||
|
||||
if (sub == null) {
|
||||
title.setText(R.string.sim_calls_ask_first_prefs_title);
|
||||
summary.setText("");
|
||||
icon.setImageDrawable(mContext.getDrawable(R.drawable.ic_feedback_24dp));
|
||||
icon.setImageTintList(
|
||||
Utils.getColorAttr(mContext, android.R.attr.textColorSecondary));
|
||||
if (position == 0) {
|
||||
title.setText(R.string.sim_calls_ask_first_prefs_title);
|
||||
} else {
|
||||
title.setText(R.string.sim_action_cancel);
|
||||
}
|
||||
summary.setVisibility(View.GONE);
|
||||
} else {
|
||||
title.setText(SubscriptionUtil.getUniqueSubscriptionDisplayName(sub, mContext));
|
||||
summary.setText(isMdnProvisioned(sub.getNumber()) ? sub.getNumber() : "");
|
||||
icon.setImageBitmap(sub.createIconBitmap(mContext));
|
||||
|
||||
String phoneNumber = isMdnProvisioned(sub.getNumber()) ? sub.getNumber() : "";
|
||||
if (!TextUtils.isEmpty(phoneNumber)) {
|
||||
summary.setVisibility(View.VISIBLE);
|
||||
summary.setText(phoneNumber);
|
||||
} else {
|
||||
summary.setVisibility(View.GONE);
|
||||
}
|
||||
}
|
||||
return convertView;
|
||||
}
|
||||
|
Reference in New Issue
Block a user