Skip to content
This repository has been archived by the owner on Feb 20, 2023. It is now read-only.

Commit

Permalink
Request desktop site from home screen.
Browse files Browse the repository at this point in the history
  • Loading branch information
mcarare committed Mar 29, 2021
1 parent ec07eec commit 8b096a7
Show file tree
Hide file tree
Showing 12 changed files with 80 additions and 19 deletions.
22 changes: 18 additions & 4 deletions app/src/main/java/org/mozilla/fenix/HomeActivity.kt
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ import kotlinx.coroutines.Job
import kotlinx.coroutines.delay
import kotlinx.coroutines.launch
import mozilla.appservices.places.BookmarkRoot
import mozilla.components.browser.state.action.ContentAction
import mozilla.components.browser.state.search.SearchEngine
import mozilla.components.browser.state.selector.getNormalOrPrivateTabs
import mozilla.components.browser.state.state.SessionState
Expand Down Expand Up @@ -122,7 +123,7 @@ import java.lang.ref.WeakReference
* - browser screen
*/
@OptIn(ExperimentalCoroutinesApi::class)
@SuppressWarnings("TooManyFunctions", "LargeClass")
@SuppressWarnings("TooManyFunctions", "LargeClass", "LongParameterList")
open class HomeActivity : LocaleAwareAppCompatActivity(), NavHostActivity {
// DO NOT MOVE ANYTHING ABOVE THIS, GETTING INIT TIME IS CRITICAL
// we need to store startup timestamp for warm startup. we cant directly store
Expand Down Expand Up @@ -739,10 +740,11 @@ open class HomeActivity : LocaleAwareAppCompatActivity(), NavHostActivity {
customTabSessionId: String? = null,
engine: SearchEngine? = null,
forceSearch: Boolean = false,
flags: EngineSession.LoadUrlFlags = EngineSession.LoadUrlFlags.none()
flags: EngineSession.LoadUrlFlags = EngineSession.LoadUrlFlags.none(),
requestDesktopMode: Boolean = false
) {
openToBrowser(from, customTabSessionId)
load(searchTermOrURL, newTab, engine, forceSearch, flags)
load(searchTermOrURL, newTab, engine, forceSearch, flags, requestDesktopMode)
}

fun openToBrowser(from: BrowserDirection, customTabSessionId: String? = null) {
Expand Down Expand Up @@ -808,7 +810,8 @@ open class HomeActivity : LocaleAwareAppCompatActivity(), NavHostActivity {
newTab: Boolean,
engine: SearchEngine?,
forceSearch: Boolean,
flags: EngineSession.LoadUrlFlags = EngineSession.LoadUrlFlags.none()
flags: EngineSession.LoadUrlFlags = EngineSession.LoadUrlFlags.none(),
requestDesktopMode: Boolean? = null
) {
val startTime = components.core.engine.profiler?.getProfilerTime()
val mode = browsingModeManager.mode
Expand All @@ -825,6 +828,17 @@ open class HomeActivity : LocaleAwareAppCompatActivity(), NavHostActivity {
// and let it try to load whatever was entered.
if ((!forceSearch && searchTermOrURL.isUrl()) || engine == null) {
loadUrlUseCase.invoke(searchTermOrURL.toNormalizedUrl(), flags)

if (requestDesktopMode == true) {
val requestDesktopSiteUseCase =
components.useCases.sessionUseCases.requestDesktopSite
requestDesktopSiteUseCase.invoke(requestDesktopMode)
components.core.store.dispatch(
ContentAction.UpdateDesktopModeAction(
components.core.store.state.selectedTabId.toString(), true
))
settings().openNextTabInDesktopMode = false
}
} else {
if (newTab) {
components.useCases.searchUseCases.newTabSearch
Expand Down
4 changes: 4 additions & 0 deletions app/src/main/java/org/mozilla/fenix/home/HomeFragment.kt
Original file line number Diff line number Diff line change
Expand Up @@ -252,6 +252,7 @@ class HomeFragment : Fragment() {
restoreUseCase = components.useCases.tabsUseCases.restore,
reloadUrlUseCase = components.useCases.sessionUseCases.reload,
selectTabUseCase = components.useCases.tabsUseCases.selectTab,
requestDesktopSiteUseCase = components.useCases.sessionUseCases.requestDesktopSite,
fragmentStore = homeFragmentStore,
navController = findNavController(),
viewLifecycleScope = viewLifecycleOwner.lifecycleScope,
Expand Down Expand Up @@ -854,6 +855,9 @@ class HomeFragment : Fragment() {
HomeFragmentDirections.actionGlobalAddonsManagementFragment()
)
}
is HomeMenu.Item.DesktopMode -> {
context.settings().openNextTabInDesktopMode = it.checked
}
}
},
onHighlightPresent = { menuButtonView.get()?.setHighlight(it) },
Expand Down
13 changes: 13 additions & 0 deletions app/src/main/java/org/mozilla/fenix/home/HomeMenu.kt
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ import mozilla.components.browser.menu.BrowserMenuHighlight
import mozilla.components.browser.menu.ext.getHighlight
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.concept.sync.AccountObserver
import mozilla.components.concept.sync.AuthType
Expand Down Expand Up @@ -48,6 +49,7 @@ class HomeMenu(
object Downloads : Item()
object Quit : Item()
object Sync : Item()
data class DesktopMode(val checked: Boolean) : Item()
}

private val primaryTextColor =
Expand Down Expand Up @@ -176,6 +178,14 @@ class HomeMenu(
onItemTapped.invoke(Item.Downloads)
}

val desktopItem = BrowserMenuImageSwitch(
imageResource = R.drawable.ic_desktop,
label = context.getString(R.string.browser_menu_desktop_site),
initialState = { context.settings().openNextTabInDesktopMode }
) { checked ->
onItemTapped.invoke(Item.DesktopMode(checked))
}

// Only query account manager if it has been initialized.
// We don't want to cause its initialization just for this check.
val accountAuthItem = if (context.components.backgroundServices.accountManagerAvailableQueue.isReady()) {
Expand All @@ -193,6 +203,9 @@ class HomeMenu(
syncedTabsItem,
bookmarksItem,
historyItem,
BrowserMenuDivider(),
desktopItem,
BrowserMenuDivider(),
downloadsItem,
BrowserMenuDivider(),
addons,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ import androidx.navigation.NavController
import kotlinx.coroutines.CoroutineScope
import kotlinx.coroutines.Dispatchers
import kotlinx.coroutines.launch
import mozilla.components.browser.state.action.ContentAction
import mozilla.components.browser.state.selector.getNormalOrPrivateTabs
import mozilla.components.browser.state.state.availableSearchEngines
import mozilla.components.browser.state.state.searchEngines
Expand Down Expand Up @@ -39,6 +40,7 @@ import org.mozilla.fenix.components.tips.Tip
import org.mozilla.fenix.ext.components
import org.mozilla.fenix.ext.metrics
import org.mozilla.fenix.ext.nav
import org.mozilla.fenix.ext.settings
import org.mozilla.fenix.home.HomeFragment
import org.mozilla.fenix.home.HomeFragmentAction
import org.mozilla.fenix.home.HomeFragmentDirections
Expand Down Expand Up @@ -181,6 +183,7 @@ class DefaultSessionControlController(
private val restoreUseCase: TabsUseCases.RestoreUseCase,
private val reloadUrlUseCase: SessionUseCases.ReloadUrlUseCase,
private val selectTabUseCase: TabsUseCases.SelectTabUseCase,
private val requestDesktopSiteUseCase: SessionUseCases.RequestDesktopSiteUseCase,
private val fragmentStore: HomeFragmentStore,
private val navController: NavController,
private val viewLifecycleScope: CoroutineScope,
Expand Down Expand Up @@ -403,6 +406,15 @@ class DefaultSessionControlController(
selectTab = true,
startLoading = true
)

if (settings.openNextTabInDesktopMode) {
requestDesktopSiteUseCase.invoke(true)
activity.components.core.store.dispatch(
ContentAction.UpdateDesktopModeAction(
activity.components.core.store.state.selectedTabId.toString(), true
))
settings.openNextTabInDesktopMode = false
}
activity.openToBrowser(BrowserDirection.FromHome)
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ import org.mozilla.fenix.components.metrics.MetricController
import org.mozilla.fenix.components.metrics.MetricsUtils
import org.mozilla.fenix.crashes.CrashListActivity
import org.mozilla.fenix.ext.navigateSafe
import org.mozilla.fenix.ext.settings
import org.mozilla.fenix.settings.SupportUtils
import org.mozilla.fenix.utils.Settings

Expand All @@ -32,7 +33,7 @@ import org.mozilla.fenix.utils.Settings
*/
@Suppress("TooManyFunctions")
interface SearchController {
fun handleUrlCommitted(url: String)
fun handleUrlCommitted(url: String, fromHomeScreen: Boolean = false)
fun handleEditingCancelled()
fun handleTextChanged(text: String)
fun handleUrlTapped(url: String)
Expand Down Expand Up @@ -60,7 +61,7 @@ class SearchDialogController(
private val clearToolbar: () -> Unit
) : SearchController {

override fun handleUrlCommitted(url: String) {
override fun handleUrlCommitted(url: String, fromHomeScreen: Boolean) {
when (url) {
"about:crashes" -> {
// The list of past crashes can be accessed via "settings > about", but desktop and
Expand All @@ -73,16 +74,19 @@ class SearchDialogController(
SearchDialogFragmentDirections.actionGlobalAddonsManagementFragment()
navController.navigateSafe(R.id.searchDialogFragment, directions)
}
"moz://a" -> openSearchOrUrl(SupportUtils.getMozillaPageUrl(SupportUtils.MozillaPage.MANIFESTO))
"moz://a" -> openSearchOrUrl(
SupportUtils.getMozillaPageUrl(SupportUtils.MozillaPage.MANIFESTO),
fromHomeScreen
)
else ->
if (url.isNotBlank()) {
openSearchOrUrl(url)
openSearchOrUrl(url, fromHomeScreen)
}
}
dismissDialog()
}

private fun openSearchOrUrl(url: String) {
private fun openSearchOrUrl(url: String, fromHomeScreen: Boolean) {
clearToolbarFocus()

val searchEngine = fragmentStore.state.searchEngineSource.searchEngine
Expand All @@ -91,7 +95,8 @@ class SearchDialogController(
searchTermOrURL = url,
newTab = fragmentStore.state.tabId == null,
from = BrowserDirection.FromSearchDialog,
engine = searchEngine
engine = searchEngine,
requestDesktopMode = fromHomeScreen && activity.settings().openNextTabInDesktopMode
)

val event = if (url.isUrl() || searchEngine == null) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -167,21 +167,22 @@ class SearchDialogFragment : AppCompatDialogFragment(), UserInteractionHandler {
}
)
)
val fromHomeFragment =
findNavController().previousBackStackEntry?.destination?.id == R.id.homeFragment

toolbarView = ToolbarView(
requireContext(),
interactor,
historyStorageProvider(),
isPrivate,
view.toolbar,
requireComponents.core.engine
requireComponents.core.engine,
fromHomeFragment
)

val awesomeBar = view.awesome_bar
awesomeBar.customizeForBottomToolbar = requireContext().settings().shouldUseBottomToolbar

val fromHomeFragment =
findNavController().previousBackStackEntry?.destination?.id == R.id.homeFragment
awesomeBarView = AwesomeBarView(
activity,
interactor,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,8 @@ class SearchDialogInteractor(
private val searchController: SearchDialogController
) : AwesomeBarInteractor, ToolbarInteractor {

override fun onUrlCommitted(url: String) {
searchController.handleUrlCommitted(url)
override fun onUrlCommitted(url: String, fromHomeScreen: Boolean) {
searchController.handleUrlCommitted(url, fromHomeScreen)
}

override fun onEditingCanceled() {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ interface ToolbarInteractor {
* Called when a user hits the return key while [ToolbarView] has focus.
* @param url the text inside the [ToolbarView] when committed
*/
fun onUrlCommitted(url: String)
fun onUrlCommitted(url: String, fromHomeScreen: Boolean = false)

/**
* Called when a user removes focus from the [ToolbarView]
Expand All @@ -49,13 +49,15 @@ interface ToolbarInteractor {
/**
* View that contains and configures the BrowserToolbar to only be used in its editing mode.
*/
@Suppress("LongParameterList")
class ToolbarView(
private val context: Context,
private val interactor: ToolbarInteractor,
private val historyStorage: HistoryStorage?,
private val isPrivate: Boolean,
val view: BrowserToolbar,
engine: Engine
engine: Engine,
fromHomeFragment: Boolean
) {

@VisibleForTesting
Expand All @@ -70,7 +72,7 @@ class ToolbarView(
// from resizing in case the BrowserFragment is being displayed before the
// keyboard is gone: https://github.com/mozilla-mobile/fenix/issues/8399
hideKeyboard()
interactor.onUrlCommitted(it)
interactor.onUrlCommitted(it, fromHomeFragment)
false
}

Expand Down
5 changes: 5 additions & 0 deletions app/src/main/java/org/mozilla/fenix/utils/Settings.kt
Original file line number Diff line number Diff line change
Expand Up @@ -1020,4 +1020,9 @@ class Settings(private val appContext: Context) : PreferencesHolder {
default = false,
featureFlag = FeatureFlags.addressesFeature
)

var openNextTabInDesktopMode by booleanPreference(
appContext.getPreferenceKey(R.string.pref_key_open_next_tab_desktop_mode),
default = false
)
}
2 changes: 2 additions & 0 deletions app/src/main/res/values/preference_keys.xml
Original file line number Diff line number Diff line change
Expand Up @@ -257,6 +257,8 @@

<string name="pref_key_return_to_browser" translatable="false">pref_key_return_to_browser</string>

<string name="pref_key_open_next_tab_desktop_mode" translatable="false">pref_key_open_next_tab_desktop_mode</string>

<!-- Secret Info Setting Keys -->
<string name="pref_key_secret_debug_info" translatable="false">pref_key_secret_debug_info</string>
<string name="pref_key_leanplum_user_id" translatable="false">pref_key_leanplum_user_id</string>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -140,6 +140,7 @@ class DefaultSessionControlControllerTest {
every { analytics.metrics } returns metrics

val restoreUseCase: TabsUseCases.RestoreUseCase = mockk(relaxed = true)
val requestDesktopSiteUseCase: SessionUseCases.RequestDesktopSiteUseCase = mockk(relaxed = true)

controller = spyk(DefaultSessionControlController(
activity = activity,
Expand All @@ -152,6 +153,7 @@ class DefaultSessionControlControllerTest {
reloadUrlUseCase = reloadUrlUseCase.reload,
selectTabUseCase = selectTabUseCase.selectTab,
restoreUseCase = restoreUseCase,
requestDesktopSiteUseCase = requestDesktopSiteUseCase,
fragmentStore = fragmentStore,
navController = navController,
viewLifecycleScope = scope,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -179,6 +179,7 @@ class ToolbarViewTest {
historyStorage = null,
isPrivate = isPrivate,
view = toolbar,
engine = engine
engine = engine,
fromHomeFragment = false
)
}

0 comments on commit 8b096a7

Please sign in to comment.