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.
57 lines
1.9 KiB
Kotlin
57 lines
1.9 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.ext
|
|
|
|
import mozilla.components.browser.state.state.TabSessionState
|
|
import mozilla.components.browser.state.state.isActive
|
|
import mozilla.components.support.ktx.kotlin.trimmed
|
|
|
|
/**
|
|
* Returns true if the [TabSessionState] has a search term.
|
|
*/
|
|
fun TabSessionState.hasSearchTerm(): Boolean {
|
|
return content.searchTerms.isNotEmpty() || !historyMetadata?.searchTerm.isNullOrBlank()
|
|
}
|
|
|
|
/**
|
|
* Returns true if the [TabSessionState] is considered active based on the [maxActiveTime].
|
|
*/
|
|
internal fun TabSessionState.isNormalTabActive(maxActiveTime: Long): Boolean {
|
|
return isActive(maxActiveTime) && !content.private
|
|
}
|
|
|
|
/**
|
|
* Returns true if the [TabSessionState] have a search term.
|
|
*/
|
|
internal fun TabSessionState.isNormalTabActiveWithSearchTerm(maxActiveTime: Long): Boolean {
|
|
return isNormalTabActive(maxActiveTime) && hasSearchTerm()
|
|
}
|
|
|
|
/**
|
|
* Returns true if the [TabSessionState] has a search term but may or may not be active.
|
|
*/
|
|
internal fun TabSessionState.isNormalTabWithSearchTerm(): Boolean {
|
|
return hasSearchTerm() && !content.private
|
|
}
|
|
|
|
/**
|
|
* Returns true if the [TabSessionState] is considered active based on the [maxActiveTime].
|
|
*/
|
|
internal fun TabSessionState.isNormalTabInactive(maxActiveTime: Long): Boolean {
|
|
return !isActive(maxActiveTime) && !content.private
|
|
}
|
|
|
|
/**
|
|
* Returns true if the [TabSessionState] is not private.
|
|
*/
|
|
internal fun TabSessionState.isNormalTab(): Boolean {
|
|
return !content.private
|
|
}
|
|
|
|
/**
|
|
* Returns a [String] for displaying a [TabSessionState]'s title or its url when a title is not available.
|
|
*/
|
|
fun TabSessionState.toDisplayTitle(): String = content.title.ifEmpty { content.url.trimmed() }
|