You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
150 lines
5.2 KiB
Kotlin
150 lines
5.2 KiB
Kotlin
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
package org.mozilla.fenix.home.sessioncontrol.viewholders
|
|
|
|
import android.content.Context
|
|
import android.graphics.PorterDuff.Mode.SRC_IN
|
|
import android.view.View
|
|
import android.view.ViewGroup
|
|
import androidx.recyclerview.widget.RecyclerView
|
|
import kotlinx.android.extensions.LayoutContainer
|
|
import kotlinx.android.synthetic.main.collection_home_list_row.*
|
|
import kotlinx.android.synthetic.main.collection_home_list_row.view.*
|
|
import mozilla.components.browser.menu.BrowserMenuBuilder
|
|
import mozilla.components.browser.menu.item.SimpleBrowserMenuItem
|
|
import mozilla.components.feature.tab.collections.TabCollection
|
|
import org.mozilla.fenix.R
|
|
import org.mozilla.fenix.theme.ThemeManager
|
|
import org.mozilla.fenix.components.description
|
|
import org.mozilla.fenix.ext.getIconColor
|
|
import org.mozilla.fenix.ext.increaseTapArea
|
|
import org.mozilla.fenix.home.sessioncontrol.CollectionInteractor
|
|
|
|
class CollectionViewHolder(
|
|
val view: View,
|
|
val interactor: CollectionInteractor,
|
|
override val containerView: View? = view
|
|
) :
|
|
RecyclerView.ViewHolder(view), LayoutContainer {
|
|
|
|
private lateinit var collection: TabCollection
|
|
private var expanded = false
|
|
private var sessionHasOpenTabs = false
|
|
private var collectionMenu: CollectionItemMenu
|
|
|
|
init {
|
|
collectionMenu = CollectionItemMenu(view.context, sessionHasOpenTabs) {
|
|
when (it) {
|
|
is CollectionItemMenu.Item.DeleteCollection -> interactor.onDeleteCollectionTapped(collection)
|
|
is CollectionItemMenu.Item.AddTab -> interactor.onCollectionAddTabTapped(collection)
|
|
is CollectionItemMenu.Item.RenameCollection -> interactor.onRenameCollectionTapped(collection)
|
|
is CollectionItemMenu.Item.OpenTabs -> interactor.onCollectionOpenTabsTapped(collection)
|
|
}
|
|
}
|
|
|
|
collection_overflow_button.run {
|
|
increaseTapArea(buttonIncreaseDps)
|
|
setOnClickListener {
|
|
collectionMenu.menuBuilder
|
|
.build(view.context)
|
|
.show(anchor = it)
|
|
}
|
|
}
|
|
|
|
collection_share_button.run {
|
|
increaseTapArea(buttonIncreaseDps)
|
|
setOnClickListener {
|
|
interactor.onCollectionShareTabsClicked(collection)
|
|
}
|
|
}
|
|
|
|
view.clipToOutline = true
|
|
view.setOnClickListener {
|
|
interactor.onToggleCollectionExpanded(collection, !expanded)
|
|
}
|
|
}
|
|
|
|
fun bindSession(collection: TabCollection, expanded: Boolean, sessionHasOpenTabs: Boolean) {
|
|
this.collection = collection
|
|
this.expanded = expanded
|
|
this.sessionHasOpenTabs = sessionHasOpenTabs
|
|
collectionMenu.sessionHasOpenTabs = sessionHasOpenTabs
|
|
updateCollectionUI()
|
|
}
|
|
|
|
private fun updateCollectionUI() {
|
|
view.collection_title.text = collection.title
|
|
view.collection_description.text = collection.description(view.context)
|
|
val layoutParams = view.layoutParams as ViewGroup.MarginLayoutParams
|
|
|
|
view.isActivated = expanded
|
|
if (expanded) {
|
|
layoutParams.bottomMargin = 0
|
|
collection_title.setPadding(0, 0, 0, EXPANDED_PADDING)
|
|
view.collection_description.visibility = View.GONE
|
|
} else {
|
|
layoutParams.bottomMargin = COLLAPSED_MARGIN
|
|
view.collection_description.visibility = View.VISIBLE
|
|
}
|
|
|
|
view.collection_icon.setColorFilter(
|
|
collection.getIconColor(view.context),
|
|
SRC_IN
|
|
)
|
|
}
|
|
|
|
companion object {
|
|
const val buttonIncreaseDps = 16
|
|
const val EXPANDED_PADDING = 60
|
|
const val COLLAPSED_MARGIN = 12
|
|
const val LAYOUT_ID = R.layout.collection_home_list_row
|
|
const val maxTitleLength = 20
|
|
}
|
|
}
|
|
|
|
class CollectionItemMenu(
|
|
private val context: Context,
|
|
var sessionHasOpenTabs: Boolean,
|
|
private val onItemTapped: (Item) -> Unit = {}
|
|
) {
|
|
sealed class Item {
|
|
object DeleteCollection : Item()
|
|
object AddTab : Item()
|
|
object RenameCollection : Item()
|
|
object OpenTabs : Item()
|
|
}
|
|
|
|
val menuBuilder by lazy { BrowserMenuBuilder(menuItems) }
|
|
|
|
private val menuItems by lazy {
|
|
listOf(
|
|
SimpleBrowserMenuItem(
|
|
context.getString(R.string.collection_open_tabs)
|
|
) {
|
|
onItemTapped.invoke(Item.OpenTabs)
|
|
},
|
|
|
|
SimpleBrowserMenuItem(
|
|
context.getString(R.string.collection_rename)
|
|
) {
|
|
onItemTapped.invoke(Item.RenameCollection)
|
|
},
|
|
|
|
SimpleBrowserMenuItem(
|
|
context.getString(R.string.add_tab)
|
|
) {
|
|
onItemTapped.invoke(Item.AddTab)
|
|
}.apply { visible = { sessionHasOpenTabs } },
|
|
|
|
SimpleBrowserMenuItem(
|
|
context.getString(R.string.collection_delete),
|
|
textColorResource = ThemeManager.resolveAttribute(R.attr.destructive, context)
|
|
) {
|
|
onItemTapped.invoke(Item.DeleteCollection)
|
|
}
|
|
)
|
|
}
|
|
}
|