|
|
|
@ -12,6 +12,8 @@ import androidx.core.content.ContextCompat
|
|
|
|
|
import androidx.core.view.isVisible
|
|
|
|
|
import androidx.recyclerview.widget.RecyclerView
|
|
|
|
|
import kotlinx.android.synthetic.main.view_conversation.view.*
|
|
|
|
|
import kotlinx.android.synthetic.main.view_profile_picture.view.*
|
|
|
|
|
import kotlinx.coroutines.*
|
|
|
|
|
import network.loki.messenger.R
|
|
|
|
|
import org.session.libsession.utilities.recipients.Recipient
|
|
|
|
|
import org.thoughtcrime.securesms.conversation.v2.utilities.MentionManagerUtilities.populateUserPublicKeyCacheIfNeeded
|
|
|
|
@ -40,7 +42,8 @@ class ConversationView : LinearLayout {
|
|
|
|
|
// region Updating
|
|
|
|
|
fun bind(thread: ThreadRecord, isTyping: Boolean, glide: GlideRequests) {
|
|
|
|
|
this.thread = thread
|
|
|
|
|
populateUserPublicKeyCacheIfNeeded(thread.threadId, context) // FIXME: This is a bad place to do this
|
|
|
|
|
profilePictureView.glide = glide
|
|
|
|
|
post {
|
|
|
|
|
val unreadCount = thread.unreadCount
|
|
|
|
|
if (thread.recipient.isBlocked) {
|
|
|
|
|
accentView.setBackgroundResource(R.color.destructive)
|
|
|
|
@ -55,9 +58,8 @@ class ConversationView : LinearLayout {
|
|
|
|
|
unreadCountTextView.setTextSize(TypedValue.COMPLEX_UNIT_DIP, textSize)
|
|
|
|
|
unreadCountTextView.setTypeface(Typeface.DEFAULT, if (unreadCount < 100) Typeface.BOLD else Typeface.NORMAL)
|
|
|
|
|
unreadCountIndicator.isVisible = (unreadCount != 0)
|
|
|
|
|
profilePictureView.glide = glide
|
|
|
|
|
profilePictureView.update(thread.recipient, thread.threadId)
|
|
|
|
|
val senderDisplayName = getUserDisplayName(thread.recipient) ?: thread.recipient.address.toString()
|
|
|
|
|
val senderDisplayName = getUserDisplayName(thread.recipient)
|
|
|
|
|
?: thread.recipient.address.toString()
|
|
|
|
|
conversationViewDisplayNameTextView.text = senderDisplayName
|
|
|
|
|
timestampTextView.text = DateUtils.getDisplayFormattedTimeSpanString(context, Locale.getDefault(), thread.date)
|
|
|
|
|
val recipient = thread.recipient
|
|
|
|
@ -91,6 +93,13 @@ class ConversationView : LinearLayout {
|
|
|
|
|
thread.isRead -> statusIndicatorImageView.setImageResource(R.drawable.ic_filled_circle_check)
|
|
|
|
|
else -> statusIndicatorImageView.setImageResource(R.drawable.ic_circle_check)
|
|
|
|
|
}
|
|
|
|
|
GlobalScope.launch(Dispatchers.IO) {
|
|
|
|
|
populateUserPublicKeyCacheIfNeeded(thread.threadId, context) // FIXME: This is a bad place to do this
|
|
|
|
|
withContext(Dispatchers.Main) {
|
|
|
|
|
profilePictureView.update(thread.recipient, thread.threadId)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fun recycle() {
|
|
|
|
|