From c95a269460e5aa611b2ca744770334d7ef8c6a55 Mon Sep 17 00:00:00 2001 From: arkon Date: Sat, 9 Oct 2021 17:26:53 -0400 Subject: [PATCH] Use single layout for grid badges --- .../browse/SourceComfortableGridHolder.kt | 6 +- ...idHolder.kt => SourceCompactGridHolder.kt} | 14 +-- .../ui/browse/source/browse/SourceItem.kt | 2 +- .../library/LibraryComfortableGridHolder.kt | 12 +- .../ui/library/LibraryCompactGridHolder.kt | 12 +- .../layout/source_comfortable_grid_item.xml | 109 +---------------- .../res/layout/source_compact_grid_item.xml | 108 +---------------- .../res/layout/source_grid_item_badges.xml | 111 ++++++++++++++++++ 8 files changed, 138 insertions(+), 236 deletions(-) rename app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/{SourceGridHolder.kt => SourceCompactGridHolder.kt} (81%) create mode 100644 app/src/main/res/layout/source_grid_item_badges.xml diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/SourceComfortableGridHolder.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/SourceComfortableGridHolder.kt index b3dd99071..e7b5ee56e 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/SourceComfortableGridHolder.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/SourceComfortableGridHolder.kt @@ -39,11 +39,11 @@ class SourceComfortableGridHolder(private val view: View, private val adapter: F binding.thumbnail.alpha = if (manga.favorite) 0.3f else 1.0f // For rounded corners - binding.leftBadges.clipToOutline = true - binding.rightBadges.clipToOutline = true + binding.badges.leftBadges.clipToOutline = true + binding.badges.rightBadges.clipToOutline = true // Set favorite badge - binding.favoriteText.isVisible = manga.favorite + binding.badges.favoriteText.isVisible = manga.favorite setImage(manga) } diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/SourceGridHolder.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/SourceCompactGridHolder.kt similarity index 81% rename from app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/SourceGridHolder.kt rename to app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/SourceCompactGridHolder.kt index f0cc03385..53af51d7c 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/SourceGridHolder.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/SourceCompactGridHolder.kt @@ -9,7 +9,7 @@ import coil.transition.CrossfadeTransition import eu.davidea.flexibleadapter.FlexibleAdapter import eu.kanade.tachiyomi.data.coil.MangaCoverFetcher import eu.kanade.tachiyomi.data.database.models.Manga -import eu.kanade.tachiyomi.databinding.SourceComfortableGridItemBinding +import eu.kanade.tachiyomi.databinding.SourceCompactGridItemBinding import eu.kanade.tachiyomi.widget.StateImageViewTarget /** @@ -20,10 +20,10 @@ import eu.kanade.tachiyomi.widget.StateImageViewTarget * @param adapter the adapter handling this holder. * @constructor creates a new catalogue holder. */ -open class SourceGridHolder(private val view: View, private val adapter: FlexibleAdapter<*>) : - SourceHolder(view, adapter) { +open class SourceCompactGridHolder(private val view: View, private val adapter: FlexibleAdapter<*>) : + SourceHolder(view, adapter) { - override val binding = SourceComfortableGridItemBinding.bind(view) + override val binding = SourceCompactGridItemBinding.bind(view) /** * Method called from [CatalogueAdapter.onBindViewHolder]. It updates the data for this @@ -39,11 +39,11 @@ open class SourceGridHolder(private val view: View, private val adapter: Flexibl binding.thumbnail.alpha = if (manga.favorite) 0.3f else 1.0f // For rounded corners - binding.leftBadges.clipToOutline = true - binding.rightBadges.clipToOutline = true + binding.badges.leftBadges.clipToOutline = true + binding.badges.rightBadges.clipToOutline = true // Set favorite badge - binding.favoriteText.isVisible = manga.favorite + binding.badges.favoriteText.isVisible = manga.favorite setImage(manga) } diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/SourceItem.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/SourceItem.kt index b905246c2..49188ed70 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/SourceItem.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/browse/source/browse/SourceItem.kt @@ -48,7 +48,7 @@ class SourceItem(val manga: Manga, private val displayMode: Preference { val binding = SourceComfortableGridItemBinding.bind(view) diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/library/LibraryComfortableGridHolder.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/library/LibraryComfortableGridHolder.kt index 518e2ae29..6cc9a39bf 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/library/LibraryComfortableGridHolder.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/library/LibraryComfortableGridHolder.kt @@ -36,26 +36,26 @@ class LibraryComfortableGridHolder( binding.title.text = item.manga.title // For rounded corners - binding.leftBadges.clipToOutline = true - binding.rightBadges.clipToOutline = true + binding.badges.leftBadges.clipToOutline = true + binding.badges.rightBadges.clipToOutline = true // Update the unread count and its visibility. - with(binding.unreadText) { + with(binding.badges.unreadText) { isVisible = item.unreadCount > 0 text = item.unreadCount.toString() } // Update the download count and its visibility. - with(binding.downloadText) { + with(binding.badges.downloadText) { isVisible = item.downloadCount > 0 text = item.downloadCount.toString() } // Update the source language and its visibility - with(binding.languageText) { + with(binding.badges.languageText) { isVisible = item.sourceLanguage.isNotEmpty() text = item.sourceLanguage } // set local visibility if its local manga - binding.localText.isVisible = item.isLocal + binding.badges.localText.isVisible = item.isLocal // For rounded corners binding.card.clipToOutline = true diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/library/LibraryCompactGridHolder.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/library/LibraryCompactGridHolder.kt index 45c8349f8..e5459fbdc 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/library/LibraryCompactGridHolder.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/library/LibraryCompactGridHolder.kt @@ -34,26 +34,26 @@ open class LibraryCompactGridHolder( binding.title.text = item.manga.title // For rounded corners - binding.leftBadges.clipToOutline = true - binding.rightBadges.clipToOutline = true + binding.badges.leftBadges.clipToOutline = true + binding.badges.rightBadges.clipToOutline = true // Update the unread count and its visibility. - with(binding.unreadText) { + with(binding.badges.unreadText) { isVisible = item.unreadCount > 0 text = item.unreadCount.toString() } // Update the download count and its visibility. - with(binding.downloadText) { + with(binding.badges.downloadText) { isVisible = item.downloadCount > 0 text = item.downloadCount.toString() } // Update the source language and its visibility - with(binding.languageText) { + with(binding.badges.languageText) { isVisible = item.sourceLanguage.isNotEmpty() text = item.sourceLanguage } // set local visibility if its local manga - binding.localText.isVisible = item.isLocal + binding.badges.localText.isVisible = item.isLocal // For rounded corners binding.card.clipToOutline = true diff --git a/app/src/main/res/layout/source_comfortable_grid_item.xml b/app/src/main/res/layout/source_comfortable_grid_item.xml index 91f570f5b..0fc5d1020 100644 --- a/app/src/main/res/layout/source_comfortable_grid_item.xml +++ b/app/src/main/res/layout/source_comfortable_grid_item.xml @@ -31,114 +31,9 @@ tools:ignore="ContentDescription" tools:src="@mipmap/ic_launcher" /> - - - - - - - - - - - - - - - - - - - - - + layout="@layout/source_grid_item_badges" /> - - - - - - - - - - - - - - - - - - - - + layout="@layout/source_grid_item_badges" /> + + + + + + + + + + + + + + + + + + + + + + +