mirror of
https://github.com/libre-tube/LibreTube.git
synced 2025-04-28 07:50:31 +05:30
Merge pull request #1456 from Bnyro/master
improve alternative trending layout
This commit is contained in:
commit
712fa75fbc
@ -6,6 +6,7 @@ import android.view.LayoutInflater
|
|||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import androidx.fragment.app.FragmentManager
|
import androidx.fragment.app.FragmentManager
|
||||||
import androidx.recyclerview.widget.RecyclerView
|
import androidx.recyclerview.widget.RecyclerView
|
||||||
|
import com.github.libretube.api.obj.StreamItem
|
||||||
import com.github.libretube.databinding.VideoRowBinding
|
import com.github.libretube.databinding.VideoRowBinding
|
||||||
import com.github.libretube.extensions.formatShort
|
import com.github.libretube.extensions.formatShort
|
||||||
import com.github.libretube.extensions.setWatchProgressLength
|
import com.github.libretube.extensions.setWatchProgressLength
|
||||||
@ -16,8 +17,9 @@ import com.github.libretube.util.ImageHelper
|
|||||||
import com.github.libretube.util.NavigationHelper
|
import com.github.libretube.util.NavigationHelper
|
||||||
|
|
||||||
class ChannelAdapter(
|
class ChannelAdapter(
|
||||||
private val videoFeed: MutableList<com.github.libretube.api.obj.StreamItem>,
|
private val videoFeed: MutableList<StreamItem>,
|
||||||
private val childFragmentManager: FragmentManager
|
private val childFragmentManager: FragmentManager,
|
||||||
|
private val showChannelInfo: Boolean = false
|
||||||
) :
|
) :
|
||||||
RecyclerView.Adapter<ChannelViewHolder>() {
|
RecyclerView.Adapter<ChannelViewHolder>() {
|
||||||
|
|
||||||
@ -25,7 +27,7 @@ class ChannelAdapter(
|
|||||||
return videoFeed.size
|
return videoFeed.size
|
||||||
}
|
}
|
||||||
|
|
||||||
fun updateItems(newItems: List<com.github.libretube.api.obj.StreamItem>) {
|
fun updateItems(newItems: List<StreamItem>) {
|
||||||
val feedSize = videoFeed.size
|
val feedSize = videoFeed.size
|
||||||
videoFeed.addAll(newItems)
|
videoFeed.addAll(newItems)
|
||||||
notifyItemRangeInserted(feedSize, newItems.size)
|
notifyItemRangeInserted(feedSize, newItems.size)
|
||||||
@ -39,25 +41,36 @@ class ChannelAdapter(
|
|||||||
|
|
||||||
@SuppressLint("SetTextI18n")
|
@SuppressLint("SetTextI18n")
|
||||||
override fun onBindViewHolder(holder: ChannelViewHolder, position: Int) {
|
override fun onBindViewHolder(holder: ChannelViewHolder, position: Int) {
|
||||||
val trending = videoFeed[position]
|
val video = videoFeed[position]
|
||||||
holder.binding.apply {
|
holder.binding.apply {
|
||||||
videoTitle.text = trending.title
|
videoTitle.text = video.title
|
||||||
|
|
||||||
videoInfo.text =
|
videoInfo.text =
|
||||||
trending.views.formatShort() + " • " +
|
video.views.formatShort() + " • " +
|
||||||
DateUtils.getRelativeTimeSpanString(trending.uploaded!!)
|
DateUtils.getRelativeTimeSpanString(video.uploaded!!)
|
||||||
|
|
||||||
thumbnailDuration.text =
|
thumbnailDuration.text =
|
||||||
DateUtils.formatElapsedTime(trending.duration!!)
|
DateUtils.formatElapsedTime(video.duration!!)
|
||||||
ImageHelper.loadImage(trending.thumbnail, thumbnail)
|
|
||||||
root.setOnClickListener {
|
ImageHelper.loadImage(video.thumbnail, thumbnail)
|
||||||
NavigationHelper.navigateVideo(root.context, trending.url)
|
|
||||||
|
if (showChannelInfo) {
|
||||||
|
ImageHelper.loadImage(video.uploaderAvatar, channelImage)
|
||||||
|
channelName.text = video.uploaderName
|
||||||
}
|
}
|
||||||
val videoId = trending.url!!.toID()
|
|
||||||
|
root.setOnClickListener {
|
||||||
|
NavigationHelper.navigateVideo(root.context, video.url)
|
||||||
|
}
|
||||||
|
|
||||||
|
val videoId = video.url!!.toID()
|
||||||
root.setOnLongClickListener {
|
root.setOnLongClickListener {
|
||||||
VideoOptionsBottomSheet(videoId)
|
VideoOptionsBottomSheet(videoId)
|
||||||
.show(childFragmentManager, VideoOptionsBottomSheet::class.java.name)
|
.show(childFragmentManager, VideoOptionsBottomSheet::class.java.name)
|
||||||
true
|
true
|
||||||
}
|
}
|
||||||
watchProgress.setWatchProgressLength(videoId, trending.duration!!)
|
|
||||||
|
watchProgress.setWatchProgressLength(videoId, video.duration!!)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -115,7 +115,8 @@ class HomeFragment : BaseFragment() {
|
|||||||
|
|
||||||
binding.recview.adapter = ChannelAdapter(
|
binding.recview.adapter = ChannelAdapter(
|
||||||
response.toMutableList(),
|
response.toMutableList(),
|
||||||
childFragmentManager
|
childFragmentManager,
|
||||||
|
true
|
||||||
)
|
)
|
||||||
} else {
|
} else {
|
||||||
binding.recview.layoutManager = GridLayoutManager(
|
binding.recview.layoutManager = GridLayoutManager(
|
||||||
|
Loading…
x
Reference in New Issue
Block a user