|
|
|
@ -16,10 +16,10 @@ import org.mozilla.fenix.sync.SyncedTabsAdapter
|
|
|
|
|
import org.mozilla.fenix.tabstray.browser.BrowserTabsAdapter
|
|
|
|
|
import org.mozilla.fenix.tabstray.browser.BrowserTrayInteractor
|
|
|
|
|
import org.mozilla.fenix.tabstray.syncedtabs.TabClickDelegate
|
|
|
|
|
import org.mozilla.fenix.tabstray.viewholders.AbstractTrayViewHolder
|
|
|
|
|
import org.mozilla.fenix.tabstray.viewholders.NormalBrowserTabViewHolder
|
|
|
|
|
import org.mozilla.fenix.tabstray.viewholders.PrivateBrowserTabViewHolder
|
|
|
|
|
import org.mozilla.fenix.tabstray.viewholders.SyncedTabViewHolder
|
|
|
|
|
import org.mozilla.fenix.tabstray.viewholders.AbstractPageViewHolder
|
|
|
|
|
import org.mozilla.fenix.tabstray.viewholders.NormalBrowserPageViewHolder
|
|
|
|
|
import org.mozilla.fenix.tabstray.viewholders.PrivateBrowserPageViewHolder
|
|
|
|
|
import org.mozilla.fenix.tabstray.viewholders.SyncedTabsPageViewHolder
|
|
|
|
|
|
|
|
|
|
class TrayPagerAdapter(
|
|
|
|
|
private val context: Context,
|
|
|
|
@ -28,36 +28,36 @@ class TrayPagerAdapter(
|
|
|
|
|
private val navInteractor: NavigationInteractor,
|
|
|
|
|
private val interactor: TabsTrayInteractor,
|
|
|
|
|
private val browserStore: BrowserStore
|
|
|
|
|
) : RecyclerView.Adapter<AbstractTrayViewHolder>() {
|
|
|
|
|
) : RecyclerView.Adapter<AbstractPageViewHolder>() {
|
|
|
|
|
|
|
|
|
|
private val normalAdapter by lazy { BrowserTabsAdapter(context, browserInteractor, store) }
|
|
|
|
|
private val privateAdapter by lazy { BrowserTabsAdapter(context, browserInteractor, store) }
|
|
|
|
|
private val syncedTabsAdapter by lazy { SyncedTabsAdapter(TabClickDelegate(navInteractor)) }
|
|
|
|
|
|
|
|
|
|
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): AbstractTrayViewHolder {
|
|
|
|
|
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): AbstractPageViewHolder {
|
|
|
|
|
val itemView = LayoutInflater.from(parent.context).inflate(viewType, parent, false)
|
|
|
|
|
|
|
|
|
|
val selectedTab = browserStore.state.selectedTab
|
|
|
|
|
|
|
|
|
|
return when (viewType) {
|
|
|
|
|
NormalBrowserTabViewHolder.LAYOUT_ID -> {
|
|
|
|
|
NormalBrowserTabViewHolder(
|
|
|
|
|
NormalBrowserPageViewHolder.LAYOUT_ID -> {
|
|
|
|
|
NormalBrowserPageViewHolder(
|
|
|
|
|
itemView,
|
|
|
|
|
store,
|
|
|
|
|
interactor,
|
|
|
|
|
browserStore.state.normalTabs.indexOf(selectedTab)
|
|
|
|
|
)
|
|
|
|
|
}
|
|
|
|
|
PrivateBrowserTabViewHolder.LAYOUT_ID -> {
|
|
|
|
|
PrivateBrowserTabViewHolder(
|
|
|
|
|
PrivateBrowserPageViewHolder.LAYOUT_ID -> {
|
|
|
|
|
PrivateBrowserPageViewHolder(
|
|
|
|
|
itemView,
|
|
|
|
|
store,
|
|
|
|
|
interactor,
|
|
|
|
|
browserStore.state.privateTabs.indexOf(selectedTab)
|
|
|
|
|
)
|
|
|
|
|
}
|
|
|
|
|
SyncedTabViewHolder.LAYOUT_ID -> {
|
|
|
|
|
SyncedTabViewHolder(
|
|
|
|
|
SyncedTabsPageViewHolder.LAYOUT_ID -> {
|
|
|
|
|
SyncedTabsPageViewHolder(
|
|
|
|
|
itemView,
|
|
|
|
|
store
|
|
|
|
|
)
|
|
|
|
@ -66,7 +66,7 @@ class TrayPagerAdapter(
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
override fun onBindViewHolder(viewHolder: AbstractTrayViewHolder, position: Int) {
|
|
|
|
|
override fun onBindViewHolder(viewHolder: AbstractPageViewHolder, position: Int) {
|
|
|
|
|
val adapter = when (position) {
|
|
|
|
|
POSITION_NORMAL_TABS -> normalAdapter
|
|
|
|
|
POSITION_PRIVATE_TABS -> privateAdapter
|
|
|
|
@ -78,9 +78,9 @@ class TrayPagerAdapter(
|
|
|
|
|
|
|
|
|
|
override fun getItemViewType(position: Int): Int {
|
|
|
|
|
return when (position) {
|
|
|
|
|
POSITION_NORMAL_TABS -> NormalBrowserTabViewHolder.LAYOUT_ID
|
|
|
|
|
POSITION_PRIVATE_TABS -> PrivateBrowserTabViewHolder.LAYOUT_ID
|
|
|
|
|
POSITION_SYNCED_TABS -> SyncedTabViewHolder.LAYOUT_ID
|
|
|
|
|
POSITION_NORMAL_TABS -> NormalBrowserPageViewHolder.LAYOUT_ID
|
|
|
|
|
POSITION_PRIVATE_TABS -> PrivateBrowserPageViewHolder.LAYOUT_ID
|
|
|
|
|
POSITION_SYNCED_TABS -> SyncedTabsPageViewHolder.LAYOUT_ID
|
|
|
|
|
else -> throw IllegalStateException("Unknown position.")
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|