package org.mozilla.fenix.components.toolbar import android.view.LayoutInflater import android.view.View import android.view.ViewGroup import androidx.core.content.ContextCompat import kotlinx.android.extensions.LayoutContainer import mozilla.components.browser.domains.autocomplete.ShippedDomainsProvider import mozilla.components.browser.session.Session import mozilla.components.browser.toolbar.BrowserToolbar import mozilla.components.support.ktx.android.util.dpToFloat import mozilla.components.support.ktx.android.util.dpToPx import org.mozilla.fenix.R import org.mozilla.fenix.theme.ThemeManager import org.mozilla.fenix.customtabs.CustomTabToolbarMenu import org.mozilla.fenix.ext.components interface BrowserToolbarViewInteractor { fun onBrowserToolbarClicked() fun onBrowserToolbarMenuItemTapped(item: ToolbarMenu.Item) } class BrowserToolbarView( private val container: ViewGroup, private val interactor: BrowserToolbarViewInteractor, private val customTabSession: Session? ) : LayoutContainer { override val containerView: View? get() = container private val urlBackground = LayoutInflater.from(container.context) .inflate(R.layout.layout_url_background, container, false) val view: BrowserToolbar = LayoutInflater.from(container.context) .inflate(R.layout.component_search, container, true) .findViewById(R.id.toolbar) val toolbarIntegration: ToolbarIntegration init { with(container.context) { val sessionManager = components.core.sessionManager val isCustomTabSession = customTabSession != null view.apply { elevation = TOOLBAR_ELEVATION.dpToFloat(resources.displayMetrics) onUrlClicked = { interactor.onBrowserToolbarClicked() false } browserActionMargin = browserActionMarginDp.dpToPx(resources.displayMetrics) urlBoxView = if (isCustomTabSession) null else urlBackground progressBarGravity = if (isCustomTabSession) PROGRESS_BOTTOM else PROGRESS_TOP textColor = ContextCompat.getColor(context, R.color.photonGrey30) hint = context.getString(R.string.search_hint) suggestionBackgroundColor = ContextCompat.getColor( container.context, R.color.suggestion_highlight_color ) textColor = ContextCompat.getColor( container.context, ThemeManager.resolveAttribute(R.attr.primaryText, container.context) ) hintColor = ContextCompat.getColor( container.context, ThemeManager.resolveAttribute(R.attr.secondaryText, container.context) ) } val menuToolbar = if (isCustomTabSession) { CustomTabToolbarMenu( this, sessionManager, customTabSession?.id, onItemTapped = { interactor.onBrowserToolbarMenuItemTapped(it) } ) } else { DefaultToolbarMenu( this, hasAccountProblem = components.backgroundServices.accountManager.accountNeedsReauth(), requestDesktopStateProvider = { sessionManager.selectedSession?.desktopMode ?: false }, onItemTapped = { interactor.onBrowserToolbarMenuItemTapped(it) } ) } toolbarIntegration = ToolbarIntegration( this, view, container, menuToolbar, ShippedDomainsProvider().also { it.initialize(this) }, components.core.historyStorage, components.core.sessionManager, customTabSession?.id, customTabSession?.private ?: sessionManager.selectedSession?.private ?: false ) } } @Suppress("UNUSED_PARAMETER") fun update(state: BrowserFragmentState) { // Intentionally leaving this as a stub for now since we don't actually want to update currently } companion object { private const val TOOLBAR_ELEVATION = 16 private const val PROGRESS_BOTTOM = 0 private const val PROGRESS_TOP = 1 const val browserActionMarginDp = 8 } }