mirror of
https://github.com/M66B/FairEmail.git
synced 2026-03-31 14:17:03 +02:00
Use recyclerview for account/identity selection
This commit is contained in:
@@ -23,17 +23,19 @@ import static android.app.Activity.RESULT_OK;
|
||||
|
||||
import android.app.Dialog;
|
||||
import android.content.Context;
|
||||
import android.content.DialogInterface;
|
||||
import android.graphics.Color;
|
||||
import android.os.Bundle;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
import android.view.ViewGroup;
|
||||
import android.widget.ArrayAdapter;
|
||||
import android.widget.TextView;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.annotation.Nullable;
|
||||
import androidx.appcompat.app.AlertDialog;
|
||||
import androidx.constraintlayout.widget.Group;
|
||||
import androidx.recyclerview.widget.LinearLayoutManager;
|
||||
import androidx.recyclerview.widget.RecyclerView;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
@@ -44,36 +46,34 @@ public class FragmentDialogSelectAccount extends FragmentDialogBase {
|
||||
public Dialog onCreateDialog(@Nullable Bundle savedInstanceState) {
|
||||
final Context context = getContext();
|
||||
|
||||
final int dp6 = Helper.dp2pixels(context, 6);
|
||||
final int dp12 = Helper.dp2pixels(context, 12);
|
||||
final View dview = LayoutInflater.from(context).inflate(R.layout.dialog_account_select, null);
|
||||
RecyclerView rvSelect = dview.findViewById(R.id.rvSelect);
|
||||
final ContentLoadingProgressBar pbWait = dview.findViewById(R.id.pbWait);
|
||||
final Group grpReady = dview.findViewById(R.id.grpReady);
|
||||
|
||||
final ArrayAdapter<EntityAccount> adapter = new ArrayAdapter<EntityAccount>(context, R.layout.spinner_account, android.R.id.text1) {
|
||||
@NonNull
|
||||
@Override
|
||||
public View getView(int position, @Nullable View convertView, @NonNull ViewGroup parent) {
|
||||
View view = super.getView(position, convertView, parent);
|
||||
rvSelect.setHasFixedSize(false);
|
||||
rvSelect.setLayoutManager(new LinearLayoutManager(context));
|
||||
|
||||
try {
|
||||
EntityAccount account = getItem(position);
|
||||
Dialog dialog = new AlertDialog.Builder(context)
|
||||
.setIcon(R.drawable.twotone_account_circle_24)
|
||||
.setTitle(R.string.title_list_accounts)
|
||||
.setView(dview)
|
||||
.setNegativeButton(android.R.string.cancel, null)
|
||||
.create();
|
||||
|
||||
View vwColor = view.findViewById(R.id.vwColor);
|
||||
TextView tv = view.findViewById(android.R.id.text1);
|
||||
|
||||
int vpad = (getCount() > 10 ? dp6 : dp12);
|
||||
tv.setPadding(0, vpad, 0, vpad);
|
||||
|
||||
vwColor.setBackgroundColor(account.color == null ? Color.TRANSPARENT : account.color);
|
||||
tv.setText(account.name);
|
||||
} catch (Throwable ex) {
|
||||
Log.e(ex);
|
||||
}
|
||||
|
||||
return view;
|
||||
}
|
||||
};
|
||||
|
||||
// TODO: spinner
|
||||
new SimpleTask<List<EntityAccount>>() {
|
||||
@Override
|
||||
protected void onPreExecute(Bundle args) {
|
||||
pbWait.setVisibility(View.VISIBLE);
|
||||
grpReady.setVisibility(View.GONE);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void onPostExecute(Bundle args) {
|
||||
pbWait.setVisibility(View.GONE);
|
||||
grpReady.setVisibility(View.VISIBLE);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected List<EntityAccount> onExecute(Context context, Bundle args) {
|
||||
boolean all = (args != null && args.getBoolean("all"));
|
||||
@@ -91,7 +91,20 @@ public class FragmentDialogSelectAccount extends FragmentDialogBase {
|
||||
for (EntityAccount account : new ArrayList<>(accounts))
|
||||
if (!account.isOutlook())
|
||||
accounts.remove(account);
|
||||
adapter.addAll(accounts);
|
||||
|
||||
AdapterAccount adapter = new AdapterAccount(context, accounts, new AdapterAccount.IListener() {
|
||||
@Override
|
||||
public void onSelected(EntityAccount account) {
|
||||
Bundle args = getArguments();
|
||||
args.putLong("account", account.id);
|
||||
args.putInt("protocol", account.protocol);
|
||||
args.putString("name", account.name);
|
||||
args.putString("user", account.user);
|
||||
sendResult(RESULT_OK);
|
||||
dialog.dismiss();
|
||||
}
|
||||
});
|
||||
rvSelect.setAdapter(adapter);
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -100,22 +113,92 @@ public class FragmentDialogSelectAccount extends FragmentDialogBase {
|
||||
}
|
||||
}.execute(this, getArguments(), "select:account");
|
||||
|
||||
return new AlertDialog.Builder(context)
|
||||
.setIcon(R.drawable.twotone_account_circle_24)
|
||||
.setTitle(R.string.title_list_accounts)
|
||||
.setAdapter(adapter, new DialogInterface.OnClickListener() {
|
||||
@Override
|
||||
public void onClick(DialogInterface dialog, int which) {
|
||||
EntityAccount account = adapter.getItem(which);
|
||||
Bundle args = getArguments();
|
||||
args.putLong("account", account.id);
|
||||
args.putInt("protocol", account.protocol);
|
||||
args.putString("name", account.name);
|
||||
args.putString("user", account.user);
|
||||
sendResult(RESULT_OK);
|
||||
}
|
||||
})
|
||||
.setNegativeButton(android.R.string.cancel, null)
|
||||
.create();
|
||||
return dialog;
|
||||
}
|
||||
}
|
||||
|
||||
public static class AdapterAccount extends RecyclerView.Adapter<AdapterAccount.ViewHolder> {
|
||||
private Context context;
|
||||
private LayoutInflater inflater;
|
||||
|
||||
private int dp6;
|
||||
private int dp12;
|
||||
private List<EntityAccount> items;
|
||||
private IListener listener;
|
||||
|
||||
public class ViewHolder extends RecyclerView.ViewHolder implements View.OnClickListener {
|
||||
private View vwColor;
|
||||
private TextView tv;
|
||||
|
||||
ViewHolder(View itemView) {
|
||||
super(itemView);
|
||||
vwColor = itemView.findViewById(R.id.vwColor);
|
||||
tv = itemView.findViewById(android.R.id.text1);
|
||||
}
|
||||
|
||||
private void wire() {
|
||||
itemView.setOnClickListener(this);
|
||||
}
|
||||
|
||||
private void unwire() {
|
||||
itemView.setOnClickListener(null);
|
||||
}
|
||||
|
||||
private void bindTo(EntityAccount account) {
|
||||
int vpad = (getItemCount() > 10 ? dp6 : dp12);
|
||||
tv.setPadding(0, vpad, 0, vpad);
|
||||
|
||||
vwColor.setBackgroundColor(account.color == null ? Color.TRANSPARENT : account.color);
|
||||
tv.setText(account.name);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onClick(View v) {
|
||||
int pos = getAdapterPosition();
|
||||
if (pos == RecyclerView.NO_POSITION)
|
||||
return;
|
||||
|
||||
EntityAccount account = items.get(pos);
|
||||
listener.onSelected(account);
|
||||
}
|
||||
}
|
||||
|
||||
AdapterAccount(Context context, List<EntityAccount> accounts, IListener listener) {
|
||||
this.context = context;
|
||||
this.inflater = LayoutInflater.from(context);
|
||||
this.dp6 = Helper.dp2pixels(context, 6);
|
||||
this.dp12 = Helper.dp2pixels(context, 12);
|
||||
|
||||
setHasStableIds(true);
|
||||
this.items = accounts;
|
||||
this.listener = listener;
|
||||
}
|
||||
|
||||
@Override
|
||||
public long getItemId(int position) {
|
||||
return items.get(position).id;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getItemCount() {
|
||||
return items.size();
|
||||
}
|
||||
|
||||
@Override
|
||||
@NonNull
|
||||
public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
|
||||
return new ViewHolder(inflater.inflate(R.layout.spinner_account, parent, false));
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onBindViewHolder(@NonNull ViewHolder holder, int position) {
|
||||
holder.unwire();
|
||||
EntityAccount account = items.get(position);
|
||||
holder.bindTo(account);
|
||||
holder.wire();
|
||||
}
|
||||
|
||||
public interface IListener {
|
||||
void onSelected(EntityAccount account);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user