Fix an issue when following/unfollowing in a list of accounts

This commit is contained in:
Thomas 2022-11-13 16:07:21 +01:00
parent 89851a68bc
commit f78184216d

View file

@ -54,7 +54,6 @@ import es.dmoral.toasty.Toasty;
public class AccountAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder> { public class AccountAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder> {
private static ProfileActivity.action doAction;
private final List<Account> accountList; private final List<Account> accountList;
private Context context; private Context context;
@ -82,7 +81,7 @@ public class AccountAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder
if (account.relationShip != null) { if (account.relationShip != null) {
doAction = ProfileActivity.action.FOLLOW; ProfileActivity.action doAction = ProfileActivity.action.FOLLOW;
accountViewHolder.binding.followAction.setContentDescription(context.getString(R.string.action_follow)); accountViewHolder.binding.followAction.setContentDescription(context.getString(R.string.action_follow));
accountViewHolder.binding.followAction.setVisibility(View.VISIBLE); accountViewHolder.binding.followAction.setVisibility(View.VISIBLE);
accountViewHolder.binding.followAction.setEnabled(true); accountViewHolder.binding.followAction.setEnabled(true);
@ -188,17 +187,18 @@ public class AccountAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder
accountViewHolder.binding.followAction.setOnClickListener(null); accountViewHolder.binding.followAction.setOnClickListener(null);
ProfileActivity.action finalDoAction = doAction;
accountViewHolder.binding.followAction.setOnClickListener(v -> { accountViewHolder.binding.followAction.setOnClickListener(v -> {
if (doAction == ProfileActivity.action.NOTHING) { if (finalDoAction == ProfileActivity.action.NOTHING) {
Toasty.info(context, context.getString(R.string.nothing_to_do), Toast.LENGTH_LONG).show(); Toasty.info(context, context.getString(R.string.nothing_to_do), Toast.LENGTH_LONG).show();
} else if (doAction == ProfileActivity.action.FOLLOW) { } else if (finalDoAction == ProfileActivity.action.FOLLOW) {
accountViewHolder.binding.followAction.setEnabled(false); accountViewHolder.binding.followAction.setEnabled(false);
accountsVM.follow(BaseMainActivity.currentInstance, BaseMainActivity.currentToken, account.id, true, false) accountsVM.follow(BaseMainActivity.currentInstance, BaseMainActivity.currentToken, account.id, true, false)
.observe((LifecycleOwner) context, relationShip -> { .observe((LifecycleOwner) context, relationShip -> {
account.relationShip = relationShip; account.relationShip = relationShip;
adapter.notifyItemChanged(position); adapter.notifyItemChanged(position);
}); });
} else if (doAction == ProfileActivity.action.UNFOLLOW) { } else if (finalDoAction == ProfileActivity.action.UNFOLLOW) {
boolean confirm_unfollow = sharedpreferences.getBoolean(context.getString(R.string.SET_UNFOLLOW_VALIDATION), true); boolean confirm_unfollow = sharedpreferences.getBoolean(context.getString(R.string.SET_UNFOLLOW_VALIDATION), true);
if (confirm_unfollow) { if (confirm_unfollow) {
AlertDialog.Builder unfollowConfirm = new AlertDialog.Builder(context, Helper.dialogStyle()); AlertDialog.Builder unfollowConfirm = new AlertDialog.Builder(context, Helper.dialogStyle());