Browse Source

MangaSummaryView: Fix incomplete description on tablet ui (#6518)

Ivan Iskandar 3 years ago
parent
commit
cf5e60f8eb

+ 2 - 2
app/src/main/java/eu/kanade/tachiyomi/ui/manga/info/MangaInfoHeaderAdapter.kt

@@ -290,9 +290,9 @@ class MangaInfoHeaderAdapter(
             binding.mangaCover.loadAnyAutoPause(manga)
 
             // Manga info section
-            binding.mangaSummarySection.isVisible = !manga.description.isNullOrBlank() || !manga.genre.isNullOrBlank()
-            binding.mangaSummarySection.description = manga.description
             binding.mangaSummarySection.setTags(manga.getGenres(), controller::performGenreSearch)
+            binding.mangaSummarySection.description = manga.description
+            binding.mangaSummarySection.isVisible = !manga.description.isNullOrBlank() || !manga.genre.isNullOrBlank()
         }
 
         /**

+ 7 - 2
app/src/main/java/eu/kanade/tachiyomi/widget/MangaSummaryView.kt

@@ -59,7 +59,9 @@ class MangaSummaryView @JvmOverloads constructor(
                 doOnNextLayout {
                     updateExpandState()
                 }
-                requestLayout()
+                if (!isInLayout) {
+                    requestLayout()
+                }
             }
         }
 
@@ -141,7 +143,10 @@ class MangaSummaryView @JvmOverloads constructor(
     }
 
     override fun onMeasure(widthMeasureSpec: Int, heightMeasureSpec: Int) {
-        if (!recalculateHeights) {
+        // Wait until parent view has determined the exact width
+        // because this affect the description line count
+        val measureWidthFreely = MeasureSpec.getMode(widthMeasureSpec) != MeasureSpec.EXACTLY
+        if (!recalculateHeights || measureWidthFreely) {
             super.onMeasure(widthMeasureSpec, heightMeasureSpec)
             return
         }