diff --git a/app/src/main/java/kr/co/vividnext/sodalive/v2/main/content/ui/ContentOriginalSeriesAdapter.kt b/app/src/main/java/kr/co/vividnext/sodalive/v2/main/content/ui/ContentOriginalSeriesAdapter.kt new file mode 100644 index 00000000..1d51d026 --- /dev/null +++ b/app/src/main/java/kr/co/vividnext/sodalive/v2/main/content/ui/ContentOriginalSeriesAdapter.kt @@ -0,0 +1,56 @@ +package kr.co.vividnext.sodalive.v2.main.content.ui + +import android.graphics.Outline +import android.view.LayoutInflater +import android.view.View +import android.view.ViewGroup +import android.view.ViewOutlineProvider +import androidx.recyclerview.widget.RecyclerView +import kr.co.vividnext.sodalive.R +import kr.co.vividnext.sodalive.databinding.ItemContentOriginalSeriesBinding +import kr.co.vividnext.sodalive.extensions.loadUrl +import kr.co.vividnext.sodalive.v2.main.content.model.ContentOriginalSeriesUiModel + +class ContentOriginalSeriesAdapter( + private val onSeriesClick: (ContentOriginalSeriesUiModel) -> Unit = {} +) : RecyclerView.Adapter() { + + private var items: List = emptyList() + + fun submitItems(items: List) { + this.items = items + notifyDataSetChanged() + } + + override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder { + return ViewHolder( + ItemContentOriginalSeriesBinding.inflate(LayoutInflater.from(parent.context), parent, false), + onSeriesClick + ) + } + + override fun onBindViewHolder(holder: ViewHolder, position: Int) { + holder.bind(items[position]) + } + + override fun getItemCount(): Int = items.size + + class ViewHolder( + private val binding: ItemContentOriginalSeriesBinding, + private val onSeriesClick: (ContentOriginalSeriesUiModel) -> Unit + ) : RecyclerView.ViewHolder(binding.root) { + init { + binding.layoutContentOriginalSeriesThumbnail.clipToOutline = true + binding.layoutContentOriginalSeriesThumbnail.outlineProvider = object : ViewOutlineProvider() { + override fun getOutline(view: View, outline: Outline) { + outline.setRoundRect(0, 0, view.width, view.height, view.resources.getDimension(R.dimen.radius_14)) + } + } + } + + fun bind(item: ContentOriginalSeriesUiModel) = with(binding) { + ivContentOriginalSeriesThumbnail.loadUrl(item.coverImageUrl) + root.setOnClickListener { onSeriesClick(item) } + } + } +} diff --git a/app/src/main/res/layout/item_content_original_series.xml b/app/src/main/res/layout/item_content_original_series.xml new file mode 100644 index 00000000..94339b89 --- /dev/null +++ b/app/src/main/res/layout/item_content_original_series.xml @@ -0,0 +1,29 @@ + + + + + + + + + +