diff --git a/app/src/main/java/io/github/wulkanowy/ui/modules/message/tab/MessageTabAdapter.kt b/app/src/main/java/io/github/wulkanowy/ui/modules/message/tab/MessageTabAdapter.kt
index 55f03ef84..234d17eb2 100644
--- a/app/src/main/java/io/github/wulkanowy/ui/modules/message/tab/MessageTabAdapter.kt
+++ b/app/src/main/java/io/github/wulkanowy/ui/modules/message/tab/MessageTabAdapter.kt
@@ -1,15 +1,18 @@
package io.github.wulkanowy.ui.modules.message.tab
+import android.content.res.ColorStateList
import android.graphics.Typeface
import android.view.LayoutInflater
import android.view.ViewGroup
import android.widget.CompoundButton
import androidx.core.view.isVisible
+import androidx.core.widget.ImageViewCompat
import androidx.recyclerview.widget.DiffUtil
import androidx.recyclerview.widget.RecyclerView
import io.github.wulkanowy.R
import io.github.wulkanowy.databinding.ItemMessageBinding
import io.github.wulkanowy.databinding.ItemMessageChipsBinding
+import io.github.wulkanowy.utils.getThemeAttrColor
import io.github.wulkanowy.utils.toFormattedString
import javax.inject.Inject
@@ -85,21 +88,35 @@ class MessageTabAdapter @Inject constructor() :
val message = item.message
with(holder.binding) {
- val style = if (message.unread) Typeface.BOLD else Typeface.NORMAL
+ val normalFont = Typeface.create("sans-serif", Typeface.NORMAL)
+ val boldFont = Typeface.create("sans-serif-black", Typeface.NORMAL)
+
+ val primaryColor = root.context.getThemeAttrColor(android.R.attr.textColorPrimary)
+ val secondaryColor = root.context.getThemeAttrColor(android.R.attr.textColorSecondary)
+
+ val currentFont = if (message.unread) boldFont else normalFont
+ val currentTextColor = if (message.unread) primaryColor else secondaryColor
with(messageItemAuthor) {
text = message.correspondents
- setTypeface(null, style)
+ setTextColor(currentTextColor)
+ typeface = currentFont
}
- messageItemSubject.run {
+ with(messageItemSubject) {
text = message.subject.ifBlank { context.getString(R.string.message_no_subject) }
- setTypeface(null, style)
+ setTextColor(currentTextColor)
+ typeface = currentFont
}
- messageItemDate.run {
+ with(messageItemDate) {
text = message.date.toFormattedString()
- setTypeface(null, style)
+ setTextColor(currentTextColor)
+ typeface = currentFont
}
- messageItemAttachmentIcon.isVisible = message.hasAttachments
+ with(messageItemAttachmentIcon) {
+ ImageViewCompat.setImageTintList(this, ColorStateList.valueOf(currentTextColor))
+ isVisible = message.hasAttachments
+ }
+ messageItemUnreadIndicator.isVisible = message.unread
root.setOnClickListener {
holder.bindingAdapterPosition.let {
@@ -111,7 +128,7 @@ class MessageTabAdapter @Inject constructor() :
root.setOnLongClickListener {
onLongItemClickListener(item)
- return@setOnLongClickListener true
+ true
}
with(messageItemCheckbox) {
diff --git a/app/src/main/res/drawable/ic_circle.xml b/app/src/main/res/drawable/ic_circle.xml
new file mode 100644
index 000000000..d2932fe62
--- /dev/null
+++ b/app/src/main/res/drawable/ic_circle.xml
@@ -0,0 +1,10 @@
+
+
+
+
+
+
+
diff --git a/app/src/main/res/layout/item_message.xml b/app/src/main/res/layout/item_message.xml
index c25faacc8..39fbaad01 100644
--- a/app/src/main/res/layout/item_message.xml
+++ b/app/src/main/res/layout/item_message.xml
@@ -30,6 +30,7 @@
android:layout_marginEnd="10dp"
android:ellipsize="end"
android:singleLine="true"
+ android:textColor="?android:textColorSecondary"
android:textSize="15sp"
app:layout_constraintEnd_toStartOf="@+id/messageItemDate"
app:layout_constraintStart_toEndOf="@id/messageItemCheckbox"
@@ -40,10 +41,13 @@
android:id="@+id/messageItemDate"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
+ android:layout_marginEnd="8dp"
android:gravity="end"
+ android:textColor="?android:textColorSecondary"
android:textSize="13sp"
- app:layout_constraintEnd_toEndOf="parent"
+ app:layout_constraintEnd_toStartOf="@id/messageItemUnreadIndicator"
app:layout_constraintTop_toTopOf="parent"
+ app:layout_goneMarginEnd="0dp"
tools:text="@tools:sample/date/ddmmyy" />
+
+