Close #22223: Move to the selected page when switching modes

upstream-sync
Jonathan Almeida 3 years ago committed by mergify[bot]
parent 99be352552
commit e3b6e00331

@ -5,6 +5,7 @@
package org.mozilla.fenix.tabstray package org.mozilla.fenix.tabstray
import androidx.annotation.VisibleForTesting import androidx.annotation.VisibleForTesting
import androidx.viewpager2.widget.ViewPager2
import com.google.android.material.tabs.TabLayout import com.google.android.material.tabs.TabLayout
import mozilla.components.browser.state.store.BrowserStore import mozilla.components.browser.state.store.BrowserStore
import mozilla.components.support.base.feature.LifecycleAwareFeature import mozilla.components.support.base.feature.LifecycleAwareFeature
@ -21,6 +22,7 @@ import org.mozilla.fenix.utils.Do
*/ */
class TabLayoutMediator( class TabLayoutMediator(
private val tabLayout: TabLayout, private val tabLayout: TabLayout,
private val tabPager: ViewPager2,
interactor: TabsTrayInteractor, interactor: TabsTrayInteractor,
private val browsingModeManager: BrowsingModeManager, private val browsingModeManager: BrowsingModeManager,
private val tabsTrayStore: TabsTrayStore, private val tabsTrayStore: TabsTrayStore,
@ -55,6 +57,7 @@ class TabLayoutMediator(
fun selectTabAtPosition(position: Int) { fun selectTabAtPosition(position: Int) {
tabLayout.getTabAt(position)?.select() tabLayout.getTabAt(position)?.select()
tabPager.setCurrentItem(position, false)
tabsTrayStore.dispatch(TabsTrayAction.PageSelected(Page.positionToPage(position))) tabsTrayStore.dispatch(TabsTrayAction.PageSelected(Page.positionToPage(position)))
} }
} }

@ -254,6 +254,7 @@ class TabsTrayFragment : AppCompatDialogFragment() {
tabLayoutMediator.set( tabLayoutMediator.set(
feature = TabLayoutMediator( feature = TabLayoutMediator(
tabLayout = tabsTrayBinding.tabLayout, tabLayout = tabsTrayBinding.tabLayout,
tabPager = tabsTrayBinding.tabsTray,
interactor = tabsTrayInteractor, interactor = tabsTrayInteractor,
browsingModeManager = activity.browsingModeManager, browsingModeManager = activity.browsingModeManager,
tabsTrayStore = tabsTrayStore, tabsTrayStore = tabsTrayStore,

@ -4,6 +4,7 @@
package org.mozilla.fenix.tabstray package org.mozilla.fenix.tabstray
import androidx.viewpager2.widget.ViewPager2
import com.google.android.material.tabs.TabLayout import com.google.android.material.tabs.TabLayout
import io.mockk.every import io.mockk.every
import io.mockk.mockk import io.mockk.mockk
@ -23,10 +24,11 @@ class TabLayoutMediatorTest {
private val metrics: MetricController = mockk(relaxed = true) private val metrics: MetricController = mockk(relaxed = true)
private val tabLayout: TabLayout = mockk(relaxed = true) private val tabLayout: TabLayout = mockk(relaxed = true)
private val tab: TabLayout.Tab = mockk(relaxed = true) private val tab: TabLayout.Tab = mockk(relaxed = true)
private val viewPager: ViewPager2 = mockk(relaxed = true)
@Test @Test
fun `page to normal tab position when mode is also normal`() { fun `page to normal tab position when mode is also normal`() {
val mediator = TabLayoutMediator(tabLayout, interactor, modeManager, tabsTrayStore, metrics) val mediator = TabLayoutMediator(tabLayout, viewPager, interactor, modeManager, tabsTrayStore, metrics)
every { modeManager.mode }.answers { BrowsingMode.Normal } every { modeManager.mode }.answers { BrowsingMode.Normal }
every { tabLayout.getTabAt(POSITION_NORMAL_TABS) }.answers { tab } every { tabLayout.getTabAt(POSITION_NORMAL_TABS) }.answers { tab }
@ -34,12 +36,13 @@ class TabLayoutMediatorTest {
mediator.selectActivePage() mediator.selectActivePage()
verify { tab.select() } verify { tab.select() }
verify { viewPager.setCurrentItem(POSITION_NORMAL_TABS, false) }
verify { tabsTrayStore.dispatch(TabsTrayAction.PageSelected(Page.positionToPage(POSITION_NORMAL_TABS))) } verify { tabsTrayStore.dispatch(TabsTrayAction.PageSelected(Page.positionToPage(POSITION_NORMAL_TABS))) }
} }
@Test @Test
fun `page to private tab position when mode is also private`() { fun `page to private tab position when mode is also private`() {
val mediator = TabLayoutMediator(tabLayout, interactor, modeManager, tabsTrayStore, metrics) val mediator = TabLayoutMediator(tabLayout, viewPager, interactor, modeManager, tabsTrayStore, metrics)
every { modeManager.mode }.answers { BrowsingMode.Private } every { modeManager.mode }.answers { BrowsingMode.Private }
every { tabLayout.getTabAt(POSITION_PRIVATE_TABS) }.answers { tab } every { tabLayout.getTabAt(POSITION_PRIVATE_TABS) }.answers { tab }
@ -52,7 +55,7 @@ class TabLayoutMediatorTest {
@Test @Test
fun `selectTabAtPosition will dispatch the correct TabsTrayStore action`() { fun `selectTabAtPosition will dispatch the correct TabsTrayStore action`() {
val mediator = TabLayoutMediator(tabLayout, interactor, modeManager, tabsTrayStore, metrics) val mediator = TabLayoutMediator(tabLayout, viewPager, interactor, modeManager, tabsTrayStore, metrics)
every { tabLayout.getTabAt(POSITION_NORMAL_TABS) }.answers { tab } every { tabLayout.getTabAt(POSITION_NORMAL_TABS) }.answers { tab }
every { tabLayout.getTabAt(POSITION_PRIVATE_TABS) }.answers { tab } every { tabLayout.getTabAt(POSITION_PRIVATE_TABS) }.answers { tab }
@ -73,7 +76,7 @@ class TabLayoutMediatorTest {
@Test @Test
fun `lifecycle methods adds and removes observer`() { fun `lifecycle methods adds and removes observer`() {
val mediator = TabLayoutMediator(tabLayout, interactor, modeManager, tabsTrayStore, metrics) val mediator = TabLayoutMediator(tabLayout, viewPager, interactor, modeManager, tabsTrayStore, metrics)
every { modeManager.mode }.answers { BrowsingMode.Private } every { modeManager.mode }.answers { BrowsingMode.Private }

Loading…
Cancel
Save