diff --git a/app/src/main/java/kr/co/vividnext/sodalive/v2/widget/feed/FeedLiveView.kt b/app/src/main/java/kr/co/vividnext/sodalive/v2/widget/feed/FeedLiveView.kt new file mode 100644 index 00000000..ef394ce3 --- /dev/null +++ b/app/src/main/java/kr/co/vividnext/sodalive/v2/widget/feed/FeedLiveView.kt @@ -0,0 +1,81 @@ +package kr.co.vividnext.sodalive.v2.widget.feed + +import android.content.Context +import android.graphics.Outline +import android.util.AttributeSet +import android.view.View +import android.view.ViewGroup +import android.view.ViewOutlineProvider +import android.widget.ImageView +import android.widget.TextView +import androidx.constraintlayout.widget.ConstraintLayout +import kr.co.vividnext.sodalive.R +import kotlin.math.roundToInt + +class FeedLiveView @JvmOverloads constructor( + context: Context, + attrs: AttributeSet? = null, + defStyleAttr: Int = 0 +) : ConstraintLayout(context, attrs, defStyleAttr) { + + private var profileImage: ImageView? = null + private var endedMessageText: TextView? = null + private var titleText: TextView? = null + private var createdAtText: TextView? = null + private var currentItem: FeedItem.Live? = null + private var clickListener: ((FeedItem) -> Unit)? = null + + override fun onFinishInflate() { + super.onFinishInflate() + profileImage = findViewById(R.id.iv_feed_live_profile) + endedMessageText = findViewById(R.id.tv_feed_live_ended_message) + titleText = findViewById(R.id.tv_feed_live_title) + createdAtText = findViewById(R.id.tv_feed_live_created_at) + profileImageView().clipToOutline = true + profileImageView().outlineProvider = circleOutlineProvider() + } + + fun bind(item: FeedItem.Live) { + currentItem = item + endedMessageTextView().text = item.endedMessage + requireNotNull(titleText).text = item.liveTitle + requireNotNull(createdAtText).text = item.createdAtText + applyClickState(item) + } + + fun profileImageView(): ImageView = requireNotNull(profileImage) + + fun endedMessageTextView(): TextView = requireNotNull(endedMessageText) + + fun setFeedSize(size: FeedSize) { + updateRootWidth(size.rootWidthDp.dpToPx()) + } + + fun setOnFeedClick(listener: ((FeedItem) -> Unit)?) { + clickListener = listener + currentItem?.let(::applyClickState) + } + + private fun applyClickState(item: FeedItem.Live) { + val listener = clickListener + setOnClickListener(if (listener == null) null else View.OnClickListener { listener(item) }) + isClickable = listener != null + } + + private fun updateRootWidth(width: Int) { + val currentLayoutParams = layoutParams + layoutParams = if (currentLayoutParams == null) { + ViewGroup.LayoutParams(width, ViewGroup.LayoutParams.WRAP_CONTENT) + } else { + currentLayoutParams.apply { this.width = width } + } + } + + private fun circleOutlineProvider() = object : ViewOutlineProvider() { + override fun getOutline(view: View, outline: Outline) { + outline.setOval(0, 0, view.width, view.height) + } + } + + private fun Int.dpToPx(): Int = (this * resources.displayMetrics.density).roundToInt() +} diff --git a/app/src/main/res/layout/view_feed_live.xml b/app/src/main/res/layout/view_feed_live.xml new file mode 100644 index 00000000..a110bf2b --- /dev/null +++ b/app/src/main/res/layout/view_feed_live.xml @@ -0,0 +1,72 @@ + + + + + + + + + + + + + +