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.
102 lines
3.4 KiB
Kotlin
102 lines
3.4 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.tabstray
|
|
|
|
import android.view.View
|
|
import android.widget.ImageButton
|
|
import kotlinx.coroutines.CoroutineScope
|
|
import kotlinx.coroutines.ExperimentalCoroutinesApi
|
|
import kotlinx.coroutines.cancel
|
|
import kotlinx.coroutines.flow.collect
|
|
import kotlinx.coroutines.flow.map
|
|
import mozilla.components.lib.state.ext.flowScoped
|
|
import mozilla.components.support.base.feature.LifecycleAwareFeature
|
|
import mozilla.components.support.ktx.kotlinx.coroutines.flow.ifAnyChanged
|
|
import org.mozilla.fenix.R
|
|
import org.mozilla.fenix.tabstray.browser.BrowserTrayInteractor
|
|
import org.mozilla.fenix.utils.Settings
|
|
|
|
/**
|
|
* Do not show accessible new tab button when accessibility service is disabled
|
|
*
|
|
* This binding is coupled with [FloatingActionButtonBinding].
|
|
* When [FloatingActionButtonBinding] is visible this should not be visible
|
|
*/
|
|
class AccessibleNewTabButtonBinding(
|
|
private val store: TabsTrayStore,
|
|
private val settings: Settings,
|
|
private val newTabButton: ImageButton,
|
|
private val browserTrayInteractor: BrowserTrayInteractor
|
|
) : LifecycleAwareFeature {
|
|
|
|
private var scope: CoroutineScope? = null
|
|
|
|
@OptIn(ExperimentalCoroutinesApi::class)
|
|
override fun start() {
|
|
if (!settings.accessibilityServicesEnabled) {
|
|
newTabButton.visibility = View.GONE
|
|
return
|
|
}
|
|
|
|
scope = store.flowScoped { flow ->
|
|
flow.map { it }
|
|
.ifAnyChanged { state ->
|
|
arrayOf(
|
|
state.selectedPage,
|
|
state.syncing
|
|
)
|
|
}
|
|
.collect { state ->
|
|
setAccessibleNewTabButton(state.selectedPage, state.syncing)
|
|
}
|
|
}
|
|
}
|
|
|
|
override fun stop() {
|
|
scope?.cancel()
|
|
}
|
|
|
|
private fun setAccessibleNewTabButton(selectedPage: Page, syncing: Boolean) {
|
|
when (selectedPage) {
|
|
Page.NormalTabs -> {
|
|
newTabButton.apply {
|
|
visibility = View.VISIBLE
|
|
setImageResource(R.drawable.ic_new)
|
|
setOnClickListener {
|
|
browserTrayInteractor.onFabClicked(false)
|
|
}
|
|
}
|
|
}
|
|
Page.PrivateTabs -> {
|
|
newTabButton.apply {
|
|
visibility = View.VISIBLE
|
|
setImageResource(R.drawable.ic_new)
|
|
setOnClickListener {
|
|
browserTrayInteractor.onFabClicked(true)
|
|
}
|
|
}
|
|
}
|
|
Page.SyncedTabs -> {
|
|
newTabButton.apply {
|
|
visibility =
|
|
when (syncing) {
|
|
true -> View.GONE
|
|
false -> View.VISIBLE
|
|
}
|
|
|
|
setImageResource(R.drawable.ic_fab_sync)
|
|
setOnClickListener {
|
|
// Notify the store observers (one of which is the SyncedTabsFeature), that
|
|
// a sync was requested.
|
|
if (!syncing) {
|
|
store.dispatch(TabsTrayAction.SyncNow)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|