Applies recycler view to accounts
This commit is contained in:
parent
3c96ee66ca
commit
f809094efa
|
@ -21,12 +21,12 @@ import android.os.AsyncTask;
|
||||||
import android.os.Build;
|
import android.os.Build;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.support.design.widget.FloatingActionButton;
|
import android.support.design.widget.FloatingActionButton;
|
||||||
|
import android.support.v7.widget.RecyclerView;
|
||||||
import android.text.Html;
|
import android.text.Html;
|
||||||
import android.text.util.Linkify;
|
import android.text.util.Linkify;
|
||||||
import android.view.LayoutInflater;
|
import android.view.LayoutInflater;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
import android.widget.BaseAdapter;
|
|
||||||
import android.widget.ImageView;
|
import android.widget.ImageView;
|
||||||
import android.widget.LinearLayout;
|
import android.widget.LinearLayout;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
@ -55,7 +55,7 @@ import fr.gouv.etalab.mastodon.asynctasks.PostActionAsyncTask;
|
||||||
* Created by Thomas on 27/04/2017.
|
* Created by Thomas on 27/04/2017.
|
||||||
* Adapter for accounts
|
* Adapter for accounts
|
||||||
*/
|
*/
|
||||||
public class AccountsListAdapter extends BaseAdapter implements OnPostActionInterface {
|
public class AccountsListAdapter extends RecyclerView.Adapter implements OnPostActionInterface {
|
||||||
|
|
||||||
private List<Account> accounts;
|
private List<Account> accounts;
|
||||||
private LayoutInflater layoutInflater;
|
private LayoutInflater layoutInflater;
|
||||||
|
@ -73,35 +73,18 @@ public class AccountsListAdapter extends BaseAdapter implements OnPostActionInte
|
||||||
this.targetedId = targetedId;
|
this.targetedId = targetedId;
|
||||||
}
|
}
|
||||||
|
|
||||||
public enum action{
|
|
||||||
FOLLOW,
|
|
||||||
UNFOLLOW,
|
|
||||||
UNBLOCK,
|
|
||||||
NOTHING,
|
|
||||||
UNMUTE
|
|
||||||
}
|
|
||||||
|
|
||||||
private API.StatusAction doAction;
|
private API.StatusAction doAction;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getCount() {
|
public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
|
||||||
return accounts.size();
|
return new ViewHolder(layoutInflater.inflate(R.layout.drawer_account, parent, false));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object getItem(int position) {
|
public void onBindViewHolder(RecyclerView.ViewHolder viewHolder, int position) {
|
||||||
return accounts.get(position);
|
final AccountsListAdapter.ViewHolder holder = (AccountsListAdapter.ViewHolder) viewHolder;
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public long getItemId(int position) {
|
|
||||||
return position;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public View getView(final int position, View convertView, ViewGroup parent) {
|
|
||||||
|
|
||||||
ImageLoader imageLoader = ImageLoader.getInstance();
|
ImageLoader imageLoader = ImageLoader.getInstance();
|
||||||
File cacheDir = new File(context.getCacheDir(), context.getString(R.string.app_name));
|
File cacheDir = new File(context.getCacheDir(), context.getString(R.string.app_name));
|
||||||
ImageLoaderConfiguration configImg = new ImageLoaderConfiguration.Builder(context)
|
ImageLoaderConfiguration configImg = new ImageLoaderConfiguration.Builder(context)
|
||||||
|
@ -116,26 +99,7 @@ public class AccountsListAdapter extends BaseAdapter implements OnPostActionInte
|
||||||
DisplayImageOptions options = new DisplayImageOptions.Builder().displayer(new SimpleBitmapDisplayer()).cacheInMemory(false)
|
DisplayImageOptions options = new DisplayImageOptions.Builder().displayer(new SimpleBitmapDisplayer()).cacheInMemory(false)
|
||||||
.cacheOnDisk(true).resetViewBeforeLoading(true).build();
|
.cacheOnDisk(true).resetViewBeforeLoading(true).build();
|
||||||
final Account account = accounts.get(position);
|
final Account account = accounts.get(position);
|
||||||
final ViewHolder holder;
|
|
||||||
|
|
||||||
if (convertView == null) {
|
|
||||||
convertView = layoutInflater.inflate(R.layout.drawer_account, parent, false);
|
|
||||||
holder = new ViewHolder();
|
|
||||||
holder.account_pp = (ImageView) convertView.findViewById(R.id.account_pp);
|
|
||||||
holder.account_dn = (TextView) convertView.findViewById(R.id.account_dn);
|
|
||||||
holder.account_ac = (TextView) convertView.findViewById(R.id.account_ac);
|
|
||||||
holder.account_un = (TextView) convertView.findViewById(R.id.account_un);
|
|
||||||
holder.account_ds = (TextView) convertView.findViewById(R.id.account_ds);
|
|
||||||
holder.account_sc = (TextView) convertView.findViewById(R.id.account_sc);
|
|
||||||
holder.account_fgc = (TextView) convertView.findViewById(R.id.account_fgc);
|
|
||||||
holder.account_frc = (TextView) convertView.findViewById(R.id.account_frc);
|
|
||||||
holder.account_follow = (FloatingActionButton) convertView.findViewById(R.id.account_follow);
|
|
||||||
holder.account_follow_request = (TextView) convertView.findViewById(R.id.account_follow_request);
|
|
||||||
holder.account_container = (LinearLayout) convertView.findViewById(R.id.account_container);
|
|
||||||
convertView.setTag(holder);
|
|
||||||
} else {
|
|
||||||
holder = (ViewHolder) convertView.getTag();
|
|
||||||
}
|
|
||||||
|
|
||||||
if( action == RetrieveAccountsAsyncTask.Type.BLOCKED)
|
if( action == RetrieveAccountsAsyncTask.Type.BLOCKED)
|
||||||
account.setFollowType(Account.followAction.BLOCK);
|
account.setFollowType(Account.followAction.BLOCK);
|
||||||
|
@ -232,9 +196,20 @@ public class AccountsListAdapter extends BaseAdapter implements OnPostActionInte
|
||||||
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
return convertView;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public long getItemId(int position) {
|
||||||
|
return position;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getItemCount() {
|
||||||
|
return accounts.size();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onPostAction(int statusCode, API.StatusAction statusAction, String targetedId, Error error) {
|
public void onPostAction(int statusCode, API.StatusAction statusAction, String targetedId, Error error) {
|
||||||
if( error != null){
|
if( error != null){
|
||||||
|
@ -272,7 +247,7 @@ public class AccountsListAdapter extends BaseAdapter implements OnPostActionInte
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private class ViewHolder {
|
private class ViewHolder extends RecyclerView.ViewHolder{
|
||||||
ImageView account_pp;
|
ImageView account_pp;
|
||||||
TextView account_ac;
|
TextView account_ac;
|
||||||
TextView account_dn;
|
TextView account_dn;
|
||||||
|
@ -284,6 +259,21 @@ public class AccountsListAdapter extends BaseAdapter implements OnPostActionInte
|
||||||
FloatingActionButton account_follow;
|
FloatingActionButton account_follow;
|
||||||
TextView account_follow_request;
|
TextView account_follow_request;
|
||||||
LinearLayout account_container;
|
LinearLayout account_container;
|
||||||
|
|
||||||
|
ViewHolder(View itemView) {
|
||||||
|
super(itemView);
|
||||||
|
account_pp = itemView.findViewById(R.id.account_pp);
|
||||||
|
account_dn = itemView.findViewById(R.id.account_dn);
|
||||||
|
account_ac = itemView.findViewById(R.id.account_ac);
|
||||||
|
account_un = itemView.findViewById(R.id.account_un);
|
||||||
|
account_ds = itemView.findViewById(R.id.account_ds);
|
||||||
|
account_sc = itemView.findViewById(R.id.account_sc);
|
||||||
|
account_fgc = itemView.findViewById(R.id.account_fgc);
|
||||||
|
account_frc = itemView.findViewById(R.id.account_frc);
|
||||||
|
account_follow = itemView.findViewById(R.id.account_follow);
|
||||||
|
account_follow_request = itemView.findViewById(R.id.account_follow_request);
|
||||||
|
account_container = itemView.findViewById(R.id.account_container);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
Loading…
Reference in New Issue