mirror of
https://github.com/fork-maintainers/iceraven-browser
synced 2024-11-11 13:11:01 +00:00
parent
2397695fe5
commit
538a7917e4
@ -297,7 +297,7 @@ class DefaultBrowserToolbarController(
|
||||
val appLinksUseCases =
|
||||
activity.components.useCases.appLinksUseCases
|
||||
val getRedirect = appLinksUseCases.appLinkRedirect
|
||||
sessionManager.selectedSession?.let {
|
||||
currentSession?.let {
|
||||
val redirect = getRedirect.invoke(it.url)
|
||||
redirect.appIntent?.flags = Intent.FLAG_ACTIVITY_NEW_TASK
|
||||
appLinksUseCases.openAppLink.invoke(redirect.appIntent)
|
||||
|
@ -7,9 +7,12 @@ package org.mozilla.fenix.customtabs
|
||||
import android.content.Context
|
||||
import android.graphics.Typeface
|
||||
import androidx.annotation.ColorRes
|
||||
import androidx.core.content.ContextCompat.getColor
|
||||
import mozilla.components.browser.menu.BrowserMenuBuilder
|
||||
import mozilla.components.browser.menu.BrowserMenuHighlight
|
||||
import mozilla.components.browser.menu.item.BrowserMenuCategory
|
||||
import mozilla.components.browser.menu.item.BrowserMenuDivider
|
||||
import mozilla.components.browser.menu.item.BrowserMenuHighlightableItem
|
||||
import mozilla.components.browser.menu.item.BrowserMenuImageSwitch
|
||||
import mozilla.components.browser.menu.item.BrowserMenuImageText
|
||||
import mozilla.components.browser.menu.item.BrowserMenuItemToolbar
|
||||
@ -18,7 +21,9 @@ import mozilla.components.browser.session.Session
|
||||
import mozilla.components.browser.session.SessionManager
|
||||
import org.mozilla.fenix.R
|
||||
import org.mozilla.fenix.components.toolbar.ToolbarMenu
|
||||
import org.mozilla.fenix.ext.components
|
||||
import org.mozilla.fenix.ext.getStringWithArgSafe
|
||||
import org.mozilla.fenix.ext.settings
|
||||
import org.mozilla.fenix.theme.ThemeManager
|
||||
|
||||
/**
|
||||
@ -97,12 +102,18 @@ class CustomTabToolbarMenu(
|
||||
BrowserMenuItemToolbar(listOf(back, forward, refresh))
|
||||
}
|
||||
|
||||
private fun shouldShowOpenInApp(): Boolean = session?.let { session ->
|
||||
val appLink = context.components.useCases.appLinksUseCases.appLinkRedirect
|
||||
appLink(session.url).hasExternalApp()
|
||||
} ?: false
|
||||
|
||||
private val menuItems by lazy {
|
||||
val menuItems = listOf(
|
||||
poweredBy,
|
||||
BrowserMenuDivider(),
|
||||
desktopMode,
|
||||
findInPage,
|
||||
openInApp.apply { visible = ::shouldShowOpenInApp },
|
||||
openInFenix,
|
||||
BrowserMenuDivider(),
|
||||
menuToolbar
|
||||
@ -126,6 +137,19 @@ class CustomTabToolbarMenu(
|
||||
onItemTapped.invoke(ToolbarMenu.Item.FindInPage)
|
||||
}
|
||||
|
||||
private val openInApp = BrowserMenuHighlightableItem(
|
||||
label = context.getString(R.string.browser_menu_open_app_link),
|
||||
startImageResource = R.drawable.ic_app_links,
|
||||
iconTintColorResource = primaryTextColor(),
|
||||
highlight = BrowserMenuHighlight.LowPriority(
|
||||
label = context.getString(R.string.browser_menu_open_app_link),
|
||||
notificationTint = getColor(context, R.color.whats_new_notification_color)
|
||||
),
|
||||
isHighlighted = { !context.settings().openInAppOpened }
|
||||
) {
|
||||
onItemTapped.invoke(ToolbarMenu.Item.OpenInApp)
|
||||
}
|
||||
|
||||
private val openInFenix = SimpleBrowserMenuItem(
|
||||
label = context.getString(R.string.browser_menu_open_in_fenix, appName),
|
||||
textColorResource = primaryTextColor()
|
||||
|
Loading…
Reference in New Issue
Block a user