Skip to content

Commit

Permalink
For mozilla-mobile#11431 - Scroll to restored tab in tab tray
Browse files Browse the repository at this point in the history
  • Loading branch information
ekager committed Jul 6, 2020
1 parent 2668a68 commit 38a16cb
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 22 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -192,6 +192,7 @@ class TabTrayDialogFragment : AppCompatDialogFragment() {
getString(R.string.snackbar_deleted_undo),
{
sessionManager.add(snapshot.session, isSelected, engineSessionState = state)
tabTrayView.scrollToTab(snapshot.session.id)
},
operation = { },
elevation = ELEVATION,
Expand Down
52 changes: 30 additions & 22 deletions app/src/main/java/org/mozilla/fenix/tabtray/TabTrayView.kt
Original file line number Diff line number Diff line change
Expand Up @@ -126,7 +126,7 @@ class TabTrayView(
}
if (!hasLoaded) {
hasLoaded = true
scrollToSelectedTab()
scrollToTab(view.context.components.core.store.state.selectedTabId)
if (view.context.settings().accessibilityServicesEnabled) {
lifecycleScope.launch {
delay(SELECTION_DELAY.toLong())
Expand All @@ -145,27 +145,30 @@ class TabTrayView(
}
}

tabTrayItemMenu = TabTrayItemMenu(view.context, { view.tab_layout.selectedTabPosition == 0 }) {
when (it) {
is TabTrayItemMenu.Item.ShareAllTabs -> interactor.onShareTabsClicked(
isPrivateModeSelected
)
is TabTrayItemMenu.Item.SaveToCollection -> interactor.onSaveToCollectionClicked()
is TabTrayItemMenu.Item.CloseAllTabs -> interactor.onCloseAllTabsClicked(
isPrivateModeSelected
)
tabTrayItemMenu =
TabTrayItemMenu(view.context, { view.tab_layout.selectedTabPosition == 0 }) {
when (it) {
is TabTrayItemMenu.Item.ShareAllTabs -> interactor.onShareTabsClicked(
isPrivateModeSelected
)
is TabTrayItemMenu.Item.SaveToCollection -> interactor.onSaveToCollectionClicked()
is TabTrayItemMenu.Item.CloseAllTabs -> interactor.onCloseAllTabsClicked(
isPrivateModeSelected
)
}
}
}

view.tab_tray_overflow.setOnClickListener {
container.context.components.analytics.metrics.track(Event.TabsTrayMenuOpened)
menu = tabTrayItemMenu.menuBuilder.build(container.context)
menu?.show(it)
?.also { pu ->
(pu.contentView as? CardView)?.setCardBackgroundColor(ContextCompat.getColor(
view.context,
R.color.foundation_normal_theme
))
(pu.contentView as? CardView)?.setCardBackgroundColor(
ContextCompat.getColor(
view.context,
R.color.foundation_normal_theme
)
)
}
}

Expand Down Expand Up @@ -211,7 +214,7 @@ class TabTrayView(
filterTabs.invoke(filter)

updateState(view.context.components.core.store.state)
scrollToSelectedTab()
scrollToTab(view.context.components.core.store.state.selectedTabId)

if (isPrivateModeSelected) {
container.context.components.analytics.metrics.track(Event.TabsTrayPrivateModeTapped)
Expand All @@ -220,8 +223,11 @@ class TabTrayView(
}
}

override fun onTabReselected(tab: TabLayout.Tab?) { /*noop*/ }
override fun onTabUnselected(tab: TabLayout.Tab?) { /*noop*/ }
override fun onTabReselected(tab: TabLayout.Tab?) { /*noop*/
}

override fun onTabUnselected(tab: TabLayout.Tab?) { /*noop*/
}

fun updateState(state: BrowserState) {
view.let {
Expand Down Expand Up @@ -266,14 +272,16 @@ class TabTrayView(
private fun toggleFabText(private: Boolean) {
if (private) {
fabView.new_tab_button.extend()
fabView.new_tab_button.contentDescription = view.context.resources.getString(R.string.add_private_tab)
fabView.new_tab_button.contentDescription =
view.context.resources.getString(R.string.add_private_tab)
} else {
fabView.new_tab_button.shrink()
fabView.new_tab_button.contentDescription = view.context.resources.getString(R.string.add_tab)
fabView.new_tab_button.contentDescription =
view.context.resources.getString(R.string.add_tab)
}
}

private fun scrollToSelectedTab() {
fun scrollToTab(sessionId: String?) {
(view.tabsTray as? BrowserTabsTray)?.also { tray ->
val tabs = if (isPrivateModeSelected) {
view.context.components.core.store.state.privateTabs
Expand All @@ -282,7 +290,7 @@ class TabTrayView(
}

val selectedBrowserTabIndex = tabs
.indexOfFirst { it.id == view.context.components.core.store.state.selectedTabId }
.indexOfFirst { it.id == sessionId }

tray.layoutManager?.scrollToPosition(selectedBrowserTabIndex)
}
Expand Down

0 comments on commit 38a16cb

Please sign in to comment.