|
|
@ -10,10 +10,9 @@ import android.view.ViewOutlineProvider
|
|
|
|
import androidx.appcompat.content.res.AppCompatResources
|
|
|
|
import androidx.appcompat.content.res.AppCompatResources
|
|
|
|
import androidx.recyclerview.widget.RecyclerView
|
|
|
|
import androidx.recyclerview.widget.RecyclerView
|
|
|
|
import kotlinx.android.extensions.LayoutContainer
|
|
|
|
import kotlinx.android.extensions.LayoutContainer
|
|
|
|
import kotlinx.android.synthetic.main.list_element.divider_line
|
|
|
|
|
|
|
|
import kotlinx.android.synthetic.main.list_element.list_element_title
|
|
|
|
import kotlinx.android.synthetic.main.list_element.list_element_title
|
|
|
|
import kotlinx.android.synthetic.main.list_element.list_item_close_button
|
|
|
|
import kotlinx.android.synthetic.main.list_element.list_item_action_button
|
|
|
|
import kotlinx.android.synthetic.main.list_element.list_item_icon
|
|
|
|
import kotlinx.android.synthetic.main.list_element.list_item_favicon
|
|
|
|
import kotlinx.android.synthetic.main.list_element.list_item_url
|
|
|
|
import kotlinx.android.synthetic.main.list_element.list_item_url
|
|
|
|
import mozilla.components.feature.tab.collections.TabCollection
|
|
|
|
import mozilla.components.feature.tab.collections.TabCollection
|
|
|
|
import mozilla.components.support.ktx.android.content.getColorFromAttr
|
|
|
|
import mozilla.components.support.ktx.android.content.getColorFromAttr
|
|
|
@ -29,6 +28,7 @@ import mozilla.components.feature.tab.collections.Tab as ComponentTab
|
|
|
|
class TabInCollectionViewHolder(
|
|
|
|
class TabInCollectionViewHolder(
|
|
|
|
val view: View,
|
|
|
|
val view: View,
|
|
|
|
val interactor: CollectionInteractor,
|
|
|
|
val interactor: CollectionInteractor,
|
|
|
|
|
|
|
|
private val differentLastItem: Boolean = false,
|
|
|
|
override val containerView: View? = view
|
|
|
|
override val containerView: View? = view
|
|
|
|
) : RecyclerView.ViewHolder(view), LayoutContainer {
|
|
|
|
) : RecyclerView.ViewHolder(view), LayoutContainer {
|
|
|
|
|
|
|
|
|
|
|
@ -36,11 +36,11 @@ class TabInCollectionViewHolder(
|
|
|
|
private set
|
|
|
|
private set
|
|
|
|
lateinit var tab: ComponentTab
|
|
|
|
lateinit var tab: ComponentTab
|
|
|
|
private set
|
|
|
|
private set
|
|
|
|
var isLastTab = false
|
|
|
|
var isLastItem = false
|
|
|
|
|
|
|
|
|
|
|
|
init {
|
|
|
|
init {
|
|
|
|
list_item_icon.clipToOutline = true
|
|
|
|
list_item_favicon.clipToOutline = true
|
|
|
|
list_item_icon.outlineProvider = object : ViewOutlineProvider() {
|
|
|
|
list_item_favicon.outlineProvider = object : ViewOutlineProvider() {
|
|
|
|
override fun getOutline(view: View, outline: Outline?) {
|
|
|
|
override fun getOutline(view: View, outline: Outline?) {
|
|
|
|
outline?.setRoundRect(
|
|
|
|
outline?.setRoundRect(
|
|
|
|
0,
|
|
|
|
0,
|
|
|
@ -56,8 +56,8 @@ class TabInCollectionViewHolder(
|
|
|
|
interactor.onCollectionOpenTabClicked(tab)
|
|
|
|
interactor.onCollectionOpenTabClicked(tab)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
list_item_close_button.increaseTapArea(buttonIncreaseDps)
|
|
|
|
list_item_action_button.increaseTapArea(buttonIncreaseDps)
|
|
|
|
list_item_close_button.setOnClickListener {
|
|
|
|
list_item_action_button.setOnClickListener {
|
|
|
|
interactor.onCollectionRemoveTab(collection, tab)
|
|
|
|
interactor.onCollectionRemoveTab(collection, tab)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -65,7 +65,7 @@ class TabInCollectionViewHolder(
|
|
|
|
fun bindSession(collection: TabCollection, tab: ComponentTab, isLastTab: Boolean) {
|
|
|
|
fun bindSession(collection: TabCollection, tab: ComponentTab, isLastTab: Boolean) {
|
|
|
|
this.collection = collection
|
|
|
|
this.collection = collection
|
|
|
|
this.tab = tab
|
|
|
|
this.tab = tab
|
|
|
|
this.isLastTab = isLastTab
|
|
|
|
this.isLastItem = isLastTab
|
|
|
|
updateTabUI()
|
|
|
|
updateTabUI()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -73,15 +73,13 @@ class TabInCollectionViewHolder(
|
|
|
|
list_item_url.text = tab.url.toShortUrl(view.context.components.publicSuffixList)
|
|
|
|
list_item_url.text = tab.url.toShortUrl(view.context.components.publicSuffixList)
|
|
|
|
|
|
|
|
|
|
|
|
list_element_title.text = tab.title
|
|
|
|
list_element_title.text = tab.title
|
|
|
|
list_item_icon.context.components.core.icons.loadIntoView(list_item_icon, tab.url)
|
|
|
|
list_item_favicon.context.components.core.icons.loadIntoView(list_item_favicon, tab.url)
|
|
|
|
|
|
|
|
|
|
|
|
// If I'm the last one...
|
|
|
|
// If last item and we want to change UI for it
|
|
|
|
if (isLastTab) {
|
|
|
|
if (isLastItem && differentLastItem) {
|
|
|
|
view.background = AppCompatResources.getDrawable(view.context, R.drawable.rounded_bottom_corners)
|
|
|
|
view.background = AppCompatResources.getDrawable(view.context, R.drawable.rounded_bottom_corners)
|
|
|
|
divider_line.visibility = View.GONE
|
|
|
|
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
view.setBackgroundColor(view.context.getColorFromAttr(R.attr.above))
|
|
|
|
view.setBackgroundColor(view.context.getColorFromAttr(R.attr.above))
|
|
|
|
divider_line.visibility = View.VISIBLE
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|