Merge pull request #4616 from k9mail/contact_picture_click
Click on contact picture (de)selects message in message list
This commit is contained in:
commit
0d6a78addf
6 changed files with 85 additions and 38 deletions
|
@ -17,6 +17,7 @@ import android.view.View
|
|||
import android.view.View.OnClickListener
|
||||
import android.view.ViewGroup
|
||||
import android.widget.BaseAdapter
|
||||
import android.widget.ImageView
|
||||
import android.widget.TextView
|
||||
import androidx.core.graphics.drawable.DrawableCompat
|
||||
import androidx.core.view.isVisible
|
||||
|
@ -24,7 +25,6 @@ import com.fsck.k9.FontSizes
|
|||
import com.fsck.k9.contacts.ContactPictureLoader
|
||||
import com.fsck.k9.controller.MessageReference
|
||||
import com.fsck.k9.mail.Address
|
||||
import com.fsck.k9.ui.ContactBadge
|
||||
import com.fsck.k9.ui.R
|
||||
import com.fsck.k9.ui.messagelist.MessageListAppearance
|
||||
import com.fsck.k9.ui.messagelist.MessageListItem
|
||||
|
@ -71,7 +71,14 @@ class MessageListAdapter internal constructor(
|
|||
private val flagClickListener = OnClickListener { view: View ->
|
||||
val messageViewHolder = view.tag as MessageViewHolder
|
||||
val messageListItem = getItem(messageViewHolder.position)
|
||||
listItemListener.toggleMessageFlag(messageListItem)
|
||||
listItemListener.onToggleMessageFlag(messageListItem)
|
||||
}
|
||||
|
||||
private val contactPictureClickListener = OnClickListener { view: View ->
|
||||
val parentView = view.parent.parent as View
|
||||
val messageViewHolder = parentView.tag as MessageViewHolder
|
||||
val messageListItem = getItem(messageViewHolder.position)
|
||||
listItemListener.onToggleMessageSelection(messageListItem)
|
||||
}
|
||||
|
||||
private fun recipientSigil(toMe: Boolean, ccMe: Boolean): String {
|
||||
|
@ -105,7 +112,9 @@ class MessageListAdapter internal constructor(
|
|||
|
||||
val holder = MessageViewHolder(view)
|
||||
|
||||
holder.contactBadge.isVisible = appearance.showContactPicture
|
||||
view.findViewById<View>(R.id.contact_picture_container).isVisible = appearance.showContactPicture
|
||||
holder.contactPicture.setOnClickListener(contactPictureClickListener)
|
||||
|
||||
holder.chip.isVisible = appearance.showAccountChip
|
||||
|
||||
appearance.fontSizes.setViewTextSize(holder.subject, subjectViewFontSize)
|
||||
|
@ -132,6 +141,16 @@ class MessageListAdapter internal constructor(
|
|||
|
||||
val holder = view.tag as MessageViewHolder
|
||||
|
||||
if (appearance.showContactPicture) {
|
||||
if (isSelected) {
|
||||
holder.contactPicture.isVisible = false
|
||||
holder.selected.isVisible = true
|
||||
} else {
|
||||
holder.selected.isVisible = false
|
||||
holder.contactPicture.isVisible = true
|
||||
}
|
||||
}
|
||||
|
||||
with(message) {
|
||||
val maybeBoldTypeface = if (isRead) Typeface.NORMAL else Typeface.BOLD
|
||||
val displayDate = DateUtils.getRelativeTimeSpanString(context, messageDate)
|
||||
|
@ -148,8 +167,8 @@ class MessageListAdapter internal constructor(
|
|||
holder.flagged.isChecked = isStarred
|
||||
}
|
||||
holder.position = position
|
||||
if (holder.contactBadge.isVisible) {
|
||||
updateContactBadge(holder.contactBadge, counterPartyAddress)
|
||||
if (appearance.showContactPicture && holder.contactPicture.isVisible) {
|
||||
setContactPicture(holder.contactPicture, counterPartyAddress)
|
||||
}
|
||||
setBackgroundColor(view, isSelected, isRead, isActive)
|
||||
updateWithThreadCount(holder, displayThreadCount)
|
||||
|
@ -223,19 +242,11 @@ class MessageListAdapter internal constructor(
|
|||
}
|
||||
}
|
||||
|
||||
private fun updateContactBadge(contactBadge: ContactBadge, counterpartyAddress: Address?) {
|
||||
private fun setContactPicture(contactPictureView: ImageView, counterpartyAddress: Address?) {
|
||||
if (counterpartyAddress != null) {
|
||||
contactBadge.setContact(counterpartyAddress)
|
||||
/*
|
||||
* At least in Android 2.2 a different background + padding is used when no
|
||||
* email address is available. ListView reuses the views but ContactBadge
|
||||
* doesn't reset the padding, so we do it ourselves.
|
||||
*/
|
||||
contactBadge.setPadding(0, 0, 0, 0)
|
||||
contactsPictureLoader.setContactPicture(contactBadge, counterpartyAddress)
|
||||
contactsPictureLoader.setContactPicture(contactPictureView, counterpartyAddress)
|
||||
} else {
|
||||
contactBadge.assignContactUri(null)
|
||||
contactBadge.setImageResource(R.drawable.ic_contact_picture)
|
||||
contactPictureView.setImageResource(R.drawable.ic_contact_picture)
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -290,5 +301,6 @@ class MessageListAdapter internal constructor(
|
|||
}
|
||||
|
||||
interface MessageListItemActionListener {
|
||||
fun toggleMessageFlag(item: MessageListItem)
|
||||
fun onToggleMessageSelection(item: MessageListItem)
|
||||
fun onToggleMessageFlag(item: MessageListItem)
|
||||
}
|
||||
|
|
|
@ -69,6 +69,8 @@ import com.fsck.k9.ui.messagelist.MessageListViewModel;
|
|||
|
||||
import net.jcip.annotations.GuardedBy;
|
||||
|
||||
import org.jetbrains.annotations.NotNull;
|
||||
|
||||
import timber.log.Timber;
|
||||
|
||||
import static com.fsck.k9.Account.Expunge.EXPUNGE_MANUALLY;
|
||||
|
@ -1180,17 +1182,22 @@ public class MessageListFragment extends Fragment implements OnItemClickListener
|
|||
return;
|
||||
}
|
||||
|
||||
toggleMessageSelectWithAdapterPosition(adapterPosition);
|
||||
MessageListItem messageListItem = adapter.getItem(adapterPosition);
|
||||
toggleMessageSelect(messageListItem);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void toggleMessageFlag(MessageListItem messageListItem) {
|
||||
public void onToggleMessageSelection(@NotNull MessageListItem messageListItem) {
|
||||
toggleMessageSelect(messageListItem);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onToggleMessageFlag(MessageListItem messageListItem) {
|
||||
boolean flagged = messageListItem.isStarred();
|
||||
setFlag(messageListItem, Flag.FLAGGED, !flagged);
|
||||
}
|
||||
|
||||
private void toggleMessageSelectWithAdapterPosition(int adapterPosition) {
|
||||
MessageListItem messageListItem = adapter.getItem(adapterPosition);
|
||||
private void toggleMessageSelect(MessageListItem messageListItem) {
|
||||
long uniqueId = messageListItem.getUniqueId();
|
||||
|
||||
boolean selected = this.selected.contains(uniqueId);
|
||||
|
|
|
@ -4,13 +4,13 @@ import android.view.View
|
|||
import android.widget.CheckBox
|
||||
import android.widget.ImageView
|
||||
import android.widget.TextView
|
||||
import com.fsck.k9.ui.ContactBadge
|
||||
import com.fsck.k9.ui.R
|
||||
|
||||
class MessageViewHolder(view: View) {
|
||||
var position = -1
|
||||
|
||||
val contactBadge: ContactBadge = view.findViewById(R.id.contact_badge)
|
||||
val selected: View = view.findViewById(R.id.selected)
|
||||
val contactPicture: ImageView = view.findViewById(R.id.contact_picture)
|
||||
val subject: TextView = view.findViewById(R.id.subject)
|
||||
val preview: TextView = view.findViewById(R.id.preview)
|
||||
val date: TextView = view.findViewById(R.id.date)
|
||||
|
|
15
app/ui/src/main/res/drawable/ic_check_circle_large.xml
Normal file
15
app/ui/src/main/res/drawable/ic_check_circle_large.xml
Normal file
|
@ -0,0 +1,15 @@
|
|||
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:width="40dp"
|
||||
android:height="40dp"
|
||||
android:viewportWidth="40"
|
||||
android:viewportHeight="40">
|
||||
<path
|
||||
android:pathData="M20,20m-20,0a20,20 0,1 1,40 0a20,20 0,1 1,-40 0"
|
||||
android:strokeWidth="1"
|
||||
android:fillColor="#1976d2"
|
||||
android:strokeColor="#00000000"/>
|
||||
<path
|
||||
android:pathData="m16.795,23.875 l-4.17,-4.17 -1.42,1.41 5.59,5.59 12,-12 -1.41,-1.41z"
|
||||
android:strokeWidth="1"
|
||||
android:fillColor="#ffffff"/>
|
||||
</vector>
|
|
@ -7,18 +7,32 @@
|
|||
android:layout_gravity="center_vertical"
|
||||
>
|
||||
|
||||
<com.fsck.k9.ui.ContactBadge
|
||||
android:id="@+id/contact_badge"
|
||||
android:layout_marginRight="10dp"
|
||||
android:layout_marginTop="4dip"
|
||||
android:layout_marginBottom="3dip"
|
||||
android:layout_height="40dip"
|
||||
android:layout_width="40dip"
|
||||
android:layout_gravity="center_vertical"
|
||||
android:layout_marginLeft="16dp"
|
||||
tools:src="@drawable/ic_contact_picture"
|
||||
android:background="@android:color/transparent"/>
|
||||
<FrameLayout
|
||||
android:id="@+id/contact_picture_container"
|
||||
android:layout_width="40dp"
|
||||
android:layout_height="40dp"
|
||||
android:layout_gravity="center_vertical"
|
||||
android:layout_marginLeft="16dp"
|
||||
android:layout_marginTop="4dp"
|
||||
android:layout_marginRight="10dp"
|
||||
android:layout_marginBottom="3dp">
|
||||
|
||||
<de.hdodenhof.circleimageview.CircleImageView
|
||||
android:id="@+id/contact_picture"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="match_parent"
|
||||
android:background="@android:color/transparent"
|
||||
tools:src="@drawable/ic_contact_picture" />
|
||||
|
||||
<ImageView
|
||||
android:id="@+id/selected"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="match_parent"
|
||||
android:src="@drawable/ic_check_circle_large"
|
||||
android:visibility="gone"
|
||||
android:contentDescription="@null" />
|
||||
|
||||
</FrameLayout>
|
||||
|
||||
<RelativeLayout
|
||||
android:id="@+id/list_item_inner"
|
||||
|
|
|
@ -19,7 +19,6 @@ import com.fsck.k9.RobolectricTest
|
|||
import com.fsck.k9.contacts.ContactPictureLoader
|
||||
import com.fsck.k9.mail.Address
|
||||
import com.fsck.k9.textString
|
||||
import com.fsck.k9.ui.ContactBadge
|
||||
import com.fsck.k9.ui.R
|
||||
import com.fsck.k9.ui.messagelist.MessageListAppearance
|
||||
import com.fsck.k9.ui.messagelist.MessageListItem
|
||||
|
@ -105,7 +104,7 @@ class MessageListAdapterTest : RobolectricTest() {
|
|||
|
||||
val view = adapter.createAndBindView()
|
||||
|
||||
assertTrue(view.contactPictureView.isGone)
|
||||
assertTrue(view.contactPictureContainerView.isGone)
|
||||
}
|
||||
|
||||
@Test
|
||||
|
@ -114,7 +113,7 @@ class MessageListAdapterTest : RobolectricTest() {
|
|||
|
||||
val view = adapter.createAndBindView()
|
||||
|
||||
assertTrue(view.contactPictureView.isVisible)
|
||||
assertTrue(view.contactPictureContainerView.isVisible)
|
||||
}
|
||||
|
||||
@Test
|
||||
|
@ -525,7 +524,7 @@ class MessageListAdapterTest : RobolectricTest() {
|
|||
|
||||
val View.accountChipView: View get() = findViewById(R.id.account_color_chip)
|
||||
val View.starView: CheckBox get() = findViewById(R.id.star)
|
||||
val View.contactPictureView: ContactBadge get() = findViewById(R.id.contact_badge)
|
||||
val View.contactPictureContainerView: View get() = findViewById(R.id.contact_picture_container)
|
||||
val View.threadCountView: TextView get() = findViewById(R.id.thread_count)
|
||||
val View.firstLineView: TextView get() = findViewById(R.id.subject)
|
||||
val View.secondLineView: TextView get() = findViewById(R.id.preview)
|
||||
|
|
Loading…
Reference in a new issue