Refactor ContactSelectionListAdapter and associated views.
Fixes #3181 Closes #3197 // FREEBIEpull/1/head
parent
3e890e11d9
commit
636b11abea
@ -0,0 +1,126 @@
|
|||||||
|
package org.thoughtcrime.securesms.contacts;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.support.annotation.Nullable;
|
||||||
|
import android.util.AttributeSet;
|
||||||
|
import android.view.View;
|
||||||
|
import android.widget.CheckBox;
|
||||||
|
import android.widget.ImageView;
|
||||||
|
import android.widget.RelativeLayout;
|
||||||
|
import android.widget.TextView;
|
||||||
|
|
||||||
|
import org.thoughtcrime.securesms.R;
|
||||||
|
import org.thoughtcrime.securesms.recipients.Recipient;
|
||||||
|
import org.thoughtcrime.securesms.recipients.RecipientFactory;
|
||||||
|
|
||||||
|
public class ContactSelectionListItem extends RelativeLayout implements Recipient.RecipientModifiedListener {
|
||||||
|
|
||||||
|
private ImageView contactPhotoImage;
|
||||||
|
private TextView numberView;
|
||||||
|
private TextView nameView;
|
||||||
|
private TextView labelView;
|
||||||
|
private CheckBox checkBox;
|
||||||
|
|
||||||
|
private long id;
|
||||||
|
private String number;
|
||||||
|
private Recipient recipient;
|
||||||
|
|
||||||
|
public ContactSelectionListItem(Context context) {
|
||||||
|
super(context);
|
||||||
|
}
|
||||||
|
|
||||||
|
public ContactSelectionListItem(Context context, AttributeSet attrs) {
|
||||||
|
super(context, attrs);
|
||||||
|
}
|
||||||
|
|
||||||
|
public ContactSelectionListItem(Context context, AttributeSet attrs, int defStyleAttr) {
|
||||||
|
super(context, attrs, defStyleAttr);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onFinishInflate() {
|
||||||
|
this.contactPhotoImage = (ImageView) findViewById(R.id.contact_photo_image);
|
||||||
|
this.numberView = (TextView) findViewById(R.id.number);
|
||||||
|
this.labelView = (TextView) findViewById(R.id.label);
|
||||||
|
this.nameView = (TextView) findViewById(R.id.name);
|
||||||
|
this.checkBox = (CheckBox) findViewById(R.id.check_box);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void set(long id, int type, String name, String number, String label, int color, boolean multiSelect) {
|
||||||
|
this.id = id;
|
||||||
|
this.number = number;
|
||||||
|
|
||||||
|
if (number != null) {
|
||||||
|
this.recipient = RecipientFactory.getRecipientsFromString(getContext(), number, true)
|
||||||
|
.getPrimaryRecipient();
|
||||||
|
}
|
||||||
|
|
||||||
|
this.nameView.setTextColor(color);
|
||||||
|
this.numberView.setTextColor(color);
|
||||||
|
|
||||||
|
setText(type, name, number, label);
|
||||||
|
setContactPhotoImage(recipient);
|
||||||
|
|
||||||
|
if (multiSelect) this.checkBox.setVisibility(View.VISIBLE);
|
||||||
|
else this.checkBox.setVisibility(View.GONE);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setChecked(boolean selected) {
|
||||||
|
this.checkBox.setChecked(selected);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void unbind() {
|
||||||
|
if (recipient != null) {
|
||||||
|
recipient.removeListener(this);
|
||||||
|
recipient = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setText(int type, String name, String number, String label) {
|
||||||
|
if (number == null || number.isEmpty()) {
|
||||||
|
this.nameView.setEnabled(false);
|
||||||
|
this.numberView.setText("");
|
||||||
|
this.labelView.setVisibility(View.GONE);
|
||||||
|
} else if (type == ContactsDatabase.PUSH_TYPE) {
|
||||||
|
this.numberView.setText(number);
|
||||||
|
this.nameView.setEnabled(true);
|
||||||
|
this.labelView.setVisibility(View.GONE);
|
||||||
|
} else {
|
||||||
|
this.numberView.setText(number);
|
||||||
|
this.nameView.setEnabled(true);
|
||||||
|
this.labelView.setText(label);
|
||||||
|
this.labelView.setVisibility(View.VISIBLE);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.nameView.setText(name);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setContactPhotoImage(@Nullable Recipient recipient) {
|
||||||
|
if (recipient!= null) {
|
||||||
|
contactPhotoImage.setImageDrawable(recipient.getContactPhoto());
|
||||||
|
recipient.addListener(this);
|
||||||
|
} else {
|
||||||
|
contactPhotoImage.setImageDrawable(null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onModified(final Recipient recipient) {
|
||||||
|
if (this.recipient == recipient) {
|
||||||
|
this.contactPhotoImage.post(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
contactPhotoImage.setImageDrawable(recipient.getContactPhoto());
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public long getContactId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getNumber() {
|
||||||
|
return number;
|
||||||
|
}
|
||||||
|
}
|
@ -1,97 +0,0 @@
|
|||||||
/**
|
|
||||||
* Copyright (C) 2014 Open Whisper Systems
|
|
||||||
*
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation, either version 3 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package org.thoughtcrime.securesms.util;
|
|
||||||
|
|
||||||
import android.content.Context;
|
|
||||||
import android.graphics.Bitmap;
|
|
||||||
import android.graphics.drawable.BitmapDrawable;
|
|
||||||
import android.graphics.drawable.Drawable;
|
|
||||||
import android.graphics.drawable.DrawableContainer;
|
|
||||||
import android.widget.ImageView;
|
|
||||||
|
|
||||||
import com.makeramen.RoundedDrawable;
|
|
||||||
|
|
||||||
import org.thoughtcrime.securesms.recipients.Recipient;
|
|
||||||
import org.thoughtcrime.securesms.recipients.RecipientFactory;
|
|
||||||
|
|
||||||
import java.lang.ref.WeakReference;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Runnable to load contact photos if they have them
|
|
||||||
*
|
|
||||||
* @author Jake McGinty
|
|
||||||
*/
|
|
||||||
public class BitmapWorkerRunnable implements Runnable {
|
|
||||||
private final static String TAG = BitmapWorkerRunnable.class.getSimpleName();
|
|
||||||
|
|
||||||
private final WeakReference<ImageView> imageViewReference;
|
|
||||||
private final Context context;
|
|
||||||
private final int size;
|
|
||||||
public final String number;
|
|
||||||
|
|
||||||
public BitmapWorkerRunnable(Context context, ImageView imageView, String number, int size) {
|
|
||||||
this.imageViewReference = new WeakReference<>(imageView);
|
|
||||||
this.context = context;
|
|
||||||
this.size = size;
|
|
||||||
this.number = number;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
final Recipient recipient = RecipientFactory.getRecipientsFromString(context, number, false).getPrimaryRecipient();
|
|
||||||
final Drawable contactPhoto = recipient.getContactPhoto();
|
|
||||||
|
|
||||||
if (contactPhoto != null) {
|
|
||||||
final ImageView imageView = imageViewReference.get();
|
|
||||||
final TaggedFutureTask<?> bitmapWorkerTask = AsyncDrawable.getBitmapWorkerTask(imageView);
|
|
||||||
|
|
||||||
if (bitmapWorkerTask.getTag().equals(number) && imageView != null) {
|
|
||||||
imageView.post(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
imageView.setImageDrawable(contactPhoto);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static class AsyncDrawable extends BitmapDrawable {
|
|
||||||
private final WeakReference<TaggedFutureTask<?>> bitmapWorkerTaskReference;
|
|
||||||
|
|
||||||
public AsyncDrawable(TaggedFutureTask<?> bitmapWorkerTask) {
|
|
||||||
bitmapWorkerTaskReference =
|
|
||||||
new WeakReference<TaggedFutureTask<?>>(bitmapWorkerTask);
|
|
||||||
}
|
|
||||||
|
|
||||||
public TaggedFutureTask<?> getBitmapWorkerTask() {
|
|
||||||
return bitmapWorkerTaskReference.get();
|
|
||||||
}
|
|
||||||
|
|
||||||
public static TaggedFutureTask<?> getBitmapWorkerTask(ImageView imageView) {
|
|
||||||
if (imageView != null) {
|
|
||||||
final Drawable drawable = imageView.getDrawable();
|
|
||||||
if (drawable instanceof AsyncDrawable) {
|
|
||||||
final AsyncDrawable asyncDrawable = (AsyncDrawable) drawable;
|
|
||||||
return asyncDrawable.getBitmapWorkerTask();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Reference in New Issue