mirror of
https://github.com/tapframe/NuvioStreaming.git
synced 2026-05-17 15:32:01 +00:00
feat; option to hide catalog underline
This commit is contained in:
parent
46a82dce9a
commit
5cdda57913
9 changed files with 64 additions and 0 deletions
|
|
@ -506,6 +506,8 @@
|
||||||
<string name="settings_homescreen_show_hero_description">Display hero carousel at top of home.</string>
|
<string name="settings_homescreen_show_hero_description">Display hero carousel at top of home.</string>
|
||||||
<string name="layout_hide_unreleased">Hide Unreleased Content</string>
|
<string name="layout_hide_unreleased">Hide Unreleased Content</string>
|
||||||
<string name="layout_hide_unreleased_sub">Hide movies and shows that haven't been released yet.</string>
|
<string name="layout_hide_unreleased_sub">Hide movies and shows that haven't been released yet.</string>
|
||||||
|
<string name="settings_homescreen_hide_catalog_underline">Hide Catalog Underline</string>
|
||||||
|
<string name="settings_homescreen_hide_catalog_underline_description">Remove the accent line under catalog and collection titles throughout the app.</string>
|
||||||
<string name="settings_homescreen_summary">%1$d of %2$d catalogs visible • %3$d hero sources selected</string>
|
<string name="settings_homescreen_summary">%1$d of %2$d catalogs visible • %3$d hero sources selected</string>
|
||||||
<string name="settings_homescreen_summary_hint">Open a catalog only when you need to rename or reorder it.</string>
|
<string name="settings_homescreen_summary_hint">Open a catalog only when you need to rename or reorder it.</string>
|
||||||
<string name="settings_homescreen_visible">Visible</string>
|
<string name="settings_homescreen_visible">Visible</string>
|
||||||
|
|
|
||||||
|
|
@ -33,6 +33,7 @@ data class HomeCatalogSettingsItem(
|
||||||
data class HomeCatalogSettingsUiState(
|
data class HomeCatalogSettingsUiState(
|
||||||
val heroEnabled: Boolean = true,
|
val heroEnabled: Boolean = true,
|
||||||
val hideUnreleasedContent: Boolean = false,
|
val hideUnreleasedContent: Boolean = false,
|
||||||
|
val hideCatalogUnderline: Boolean = false,
|
||||||
val items: List<HomeCatalogSettingsItem> = emptyList(),
|
val items: List<HomeCatalogSettingsItem> = emptyList(),
|
||||||
) {
|
) {
|
||||||
val signature: String
|
val signature: String
|
||||||
|
|
@ -41,6 +42,8 @@ data class HomeCatalogSettingsUiState(
|
||||||
append('|')
|
append('|')
|
||||||
append(hideUnreleasedContent)
|
append(hideUnreleasedContent)
|
||||||
append('|')
|
append('|')
|
||||||
|
append(hideCatalogUnderline)
|
||||||
|
append('|')
|
||||||
append(
|
append(
|
||||||
items.joinToString(separator = "|") { item ->
|
items.joinToString(separator = "|") { item ->
|
||||||
"${item.key}:${item.order}:${item.enabled}:${item.heroSourceEnabled}:${item.customTitle}"
|
"${item.key}:${item.order}:${item.enabled}:${item.heroSourceEnabled}:${item.customTitle}"
|
||||||
|
|
@ -59,6 +62,7 @@ internal data class HomeCatalogPreference(
|
||||||
internal data class HomeCatalogSettingsSnapshot(
|
internal data class HomeCatalogSettingsSnapshot(
|
||||||
val heroEnabled: Boolean,
|
val heroEnabled: Boolean,
|
||||||
val hideUnreleasedContent: Boolean,
|
val hideUnreleasedContent: Boolean,
|
||||||
|
val hideCatalogUnderline: Boolean,
|
||||||
val preferences: Map<String, HomeCatalogPreference>,
|
val preferences: Map<String, HomeCatalogPreference>,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
@ -75,6 +79,7 @@ private data class StoredHomeCatalogPreference(
|
||||||
private data class StoredHomeCatalogSettingsPayload(
|
private data class StoredHomeCatalogSettingsPayload(
|
||||||
val heroEnabled: Boolean = true,
|
val heroEnabled: Boolean = true,
|
||||||
val hideUnreleasedContent: Boolean = false,
|
val hideUnreleasedContent: Boolean = false,
|
||||||
|
val hideCatalogUnderline: Boolean = false,
|
||||||
val items: List<StoredHomeCatalogPreference> = emptyList(),
|
val items: List<StoredHomeCatalogPreference> = emptyList(),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
@ -95,12 +100,14 @@ object HomeCatalogSettingsRepository {
|
||||||
private var preferences: MutableMap<String, StoredHomeCatalogPreference> = mutableMapOf()
|
private var preferences: MutableMap<String, StoredHomeCatalogPreference> = mutableMapOf()
|
||||||
private var heroEnabled = true
|
private var heroEnabled = true
|
||||||
private var hideUnreleasedContent = false
|
private var hideUnreleasedContent = false
|
||||||
|
private var hideCatalogUnderline = false
|
||||||
|
|
||||||
fun onProfileChanged() {
|
fun onProfileChanged() {
|
||||||
hasLoaded = false
|
hasLoaded = false
|
||||||
preferences.clear()
|
preferences.clear()
|
||||||
heroEnabled = true
|
heroEnabled = true
|
||||||
hideUnreleasedContent = false
|
hideUnreleasedContent = false
|
||||||
|
hideCatalogUnderline = false
|
||||||
definitions = emptyList()
|
definitions = emptyList()
|
||||||
collectionDefinitions = emptyList()
|
collectionDefinitions = emptyList()
|
||||||
_uiState.value = HomeCatalogSettingsUiState()
|
_uiState.value = HomeCatalogSettingsUiState()
|
||||||
|
|
@ -113,6 +120,7 @@ object HomeCatalogSettingsRepository {
|
||||||
preferences.clear()
|
preferences.clear()
|
||||||
heroEnabled = true
|
heroEnabled = true
|
||||||
hideUnreleasedContent = false
|
hideUnreleasedContent = false
|
||||||
|
hideCatalogUnderline = false
|
||||||
_uiState.value = HomeCatalogSettingsUiState()
|
_uiState.value = HomeCatalogSettingsUiState()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -144,6 +152,7 @@ object HomeCatalogSettingsRepository {
|
||||||
return HomeCatalogSettingsSnapshot(
|
return HomeCatalogSettingsSnapshot(
|
||||||
heroEnabled = heroEnabled,
|
heroEnabled = heroEnabled,
|
||||||
hideUnreleasedContent = hideUnreleasedContent,
|
hideUnreleasedContent = hideUnreleasedContent,
|
||||||
|
hideCatalogUnderline = hideCatalogUnderline,
|
||||||
preferences = preferences.mapValues { (_, value) ->
|
preferences = preferences.mapValues { (_, value) ->
|
||||||
HomeCatalogPreference(
|
HomeCatalogPreference(
|
||||||
customTitle = value.customTitle,
|
customTitle = value.customTitle,
|
||||||
|
|
@ -172,6 +181,14 @@ object HomeCatalogSettingsRepository {
|
||||||
HomeRepository.applyCurrentSettings()
|
HomeRepository.applyCurrentSettings()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fun setHideCatalogUnderline(enabled: Boolean) {
|
||||||
|
ensureLoaded()
|
||||||
|
if (hideCatalogUnderline == enabled) return
|
||||||
|
hideCatalogUnderline = enabled
|
||||||
|
publish()
|
||||||
|
persist()
|
||||||
|
}
|
||||||
|
|
||||||
fun setHeroSourceEnabled(key: String, enabled: Boolean) {
|
fun setHeroSourceEnabled(key: String, enabled: Boolean) {
|
||||||
updatePreference(key) { preference ->
|
updatePreference(key) { preference ->
|
||||||
if (!enabled) {
|
if (!enabled) {
|
||||||
|
|
@ -200,6 +217,7 @@ object HomeCatalogSettingsRepository {
|
||||||
ensureLoaded()
|
ensureLoaded()
|
||||||
heroEnabled = true
|
heroEnabled = true
|
||||||
hideUnreleasedContent = false
|
hideUnreleasedContent = false
|
||||||
|
hideCatalogUnderline = false
|
||||||
preferences.clear()
|
preferences.clear()
|
||||||
normalizePreferences()
|
normalizePreferences()
|
||||||
publish()
|
publish()
|
||||||
|
|
@ -246,6 +264,7 @@ object HomeCatalogSettingsRepository {
|
||||||
if (parsedPayload != null) {
|
if (parsedPayload != null) {
|
||||||
heroEnabled = parsedPayload.heroEnabled
|
heroEnabled = parsedPayload.heroEnabled
|
||||||
hideUnreleasedContent = parsedPayload.hideUnreleasedContent
|
hideUnreleasedContent = parsedPayload.hideUnreleasedContent
|
||||||
|
hideCatalogUnderline = parsedPayload.hideCatalogUnderline
|
||||||
preferences = parsedPayload.items.associateBy { it.key }.toMutableMap()
|
preferences = parsedPayload.items.associateBy { it.key }.toMutableMap()
|
||||||
publish()
|
publish()
|
||||||
return
|
return
|
||||||
|
|
@ -345,6 +364,7 @@ object HomeCatalogSettingsRepository {
|
||||||
_uiState.value = HomeCatalogSettingsUiState(
|
_uiState.value = HomeCatalogSettingsUiState(
|
||||||
heroEnabled = heroEnabled,
|
heroEnabled = heroEnabled,
|
||||||
hideUnreleasedContent = hideUnreleasedContent,
|
hideUnreleasedContent = hideUnreleasedContent,
|
||||||
|
hideCatalogUnderline = hideCatalogUnderline,
|
||||||
items = items,
|
items = items,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
@ -355,6 +375,7 @@ object HomeCatalogSettingsRepository {
|
||||||
StoredHomeCatalogSettingsPayload(
|
StoredHomeCatalogSettingsPayload(
|
||||||
heroEnabled = heroEnabled,
|
heroEnabled = heroEnabled,
|
||||||
hideUnreleasedContent = hideUnreleasedContent,
|
hideUnreleasedContent = hideUnreleasedContent,
|
||||||
|
hideCatalogUnderline = hideCatalogUnderline,
|
||||||
items = preferences.values.sortedBy { it.order },
|
items = preferences.values.sortedBy { it.order },
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
|
@ -437,6 +458,7 @@ object HomeCatalogSettingsRepository {
|
||||||
}
|
}
|
||||||
return SyncHomeCatalogPayload(
|
return SyncHomeCatalogPayload(
|
||||||
hideUnreleasedContent = hideUnreleasedContent,
|
hideUnreleasedContent = hideUnreleasedContent,
|
||||||
|
hideCatalogUnderline = hideCatalogUnderline,
|
||||||
items = items,
|
items = items,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
@ -444,6 +466,7 @@ object HomeCatalogSettingsRepository {
|
||||||
fun applyFromRemote(payload: SyncHomeCatalogPayload) {
|
fun applyFromRemote(payload: SyncHomeCatalogPayload) {
|
||||||
ensureLoaded()
|
ensureLoaded()
|
||||||
hideUnreleasedContent = payload.hideUnreleasedContent
|
hideUnreleasedContent = payload.hideUnreleasedContent
|
||||||
|
hideCatalogUnderline = payload.hideCatalogUnderline
|
||||||
if (payload.items.isNotEmpty()) {
|
if (payload.items.isNotEmpty()) {
|
||||||
val existingHeroState = preferences.mapValues { it.value.heroSourceEnabled }
|
val existingHeroState = preferences.mapValues { it.value.heroSourceEnabled }
|
||||||
preferences = payload.items.associate { item ->
|
preferences = payload.items.associate { item ->
|
||||||
|
|
|
||||||
|
|
@ -42,6 +42,7 @@ data class SyncCatalogItem(
|
||||||
@Serializable
|
@Serializable
|
||||||
data class SyncHomeCatalogPayload(
|
data class SyncHomeCatalogPayload(
|
||||||
@SerialName("hide_unreleased_content") val hideUnreleasedContent: Boolean = false,
|
@SerialName("hide_unreleased_content") val hideUnreleasedContent: Boolean = false,
|
||||||
|
@SerialName("hide_catalog_underline") val hideCatalogUnderline: Boolean = false,
|
||||||
val items: List<SyncCatalogItem> = emptyList(),
|
val items: List<SyncCatalogItem> = emptyList(),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -4,11 +4,15 @@ import androidx.compose.foundation.layout.BoxWithConstraints
|
||||||
import androidx.compose.foundation.layout.PaddingValues
|
import androidx.compose.foundation.layout.PaddingValues
|
||||||
import androidx.compose.foundation.layout.fillMaxWidth
|
import androidx.compose.foundation.layout.fillMaxWidth
|
||||||
import androidx.compose.runtime.Composable
|
import androidx.compose.runtime.Composable
|
||||||
|
import androidx.compose.runtime.getValue
|
||||||
|
import androidx.compose.runtime.remember
|
||||||
import androidx.compose.ui.Modifier
|
import androidx.compose.ui.Modifier
|
||||||
import androidx.compose.ui.unit.Dp
|
import androidx.compose.ui.unit.Dp
|
||||||
|
import androidx.lifecycle.compose.collectAsStateWithLifecycle
|
||||||
import com.nuvio.app.core.ui.NuvioShelfSection
|
import com.nuvio.app.core.ui.NuvioShelfSection
|
||||||
import com.nuvio.app.core.ui.NuvioViewAllPillSize
|
import com.nuvio.app.core.ui.NuvioViewAllPillSize
|
||||||
import com.nuvio.app.core.ui.rememberPosterCardStyleUiState
|
import com.nuvio.app.core.ui.rememberPosterCardStyleUiState
|
||||||
|
import com.nuvio.app.features.home.HomeCatalogSettingsRepository
|
||||||
import com.nuvio.app.features.home.HomeCatalogSection
|
import com.nuvio.app.features.home.HomeCatalogSection
|
||||||
import com.nuvio.app.features.home.MetaPreview
|
import com.nuvio.app.features.home.MetaPreview
|
||||||
import com.nuvio.app.features.home.stableKey
|
import com.nuvio.app.features.home.stableKey
|
||||||
|
|
@ -64,6 +68,10 @@ private fun HomeCatalogRowSectionContent(
|
||||||
onPosterLongClick: ((MetaPreview) -> Unit)?,
|
onPosterLongClick: ((MetaPreview) -> Unit)?,
|
||||||
) {
|
) {
|
||||||
val posterCardStyle = rememberPosterCardStyleUiState()
|
val posterCardStyle = rememberPosterCardStyleUiState()
|
||||||
|
val homeCatalogSettings by remember {
|
||||||
|
HomeCatalogSettingsRepository.snapshot()
|
||||||
|
HomeCatalogSettingsRepository.uiState
|
||||||
|
}.collectAsStateWithLifecycle()
|
||||||
|
|
||||||
NuvioShelfSection(
|
NuvioShelfSection(
|
||||||
title = section.title,
|
title = section.title,
|
||||||
|
|
@ -71,6 +79,7 @@ private fun HomeCatalogRowSectionContent(
|
||||||
modifier = modifier,
|
modifier = modifier,
|
||||||
headerHorizontalPadding = sectionPadding,
|
headerHorizontalPadding = sectionPadding,
|
||||||
rowContentPadding = PaddingValues(horizontal = sectionPadding),
|
rowContentPadding = PaddingValues(horizontal = sectionPadding),
|
||||||
|
showHeaderAccent = !homeCatalogSettings.hideCatalogUnderline,
|
||||||
onViewAllClick = onViewAllClick,
|
onViewAllClick = onViewAllClick,
|
||||||
viewAllPillSize = NuvioViewAllPillSize.Compact,
|
viewAllPillSize = NuvioViewAllPillSize.Compact,
|
||||||
key = { item -> item.stableKey() },
|
key = { item -> item.stableKey() },
|
||||||
|
|
|
||||||
|
|
@ -15,6 +15,8 @@ import androidx.compose.material3.CardDefaults
|
||||||
import androidx.compose.material3.MaterialTheme
|
import androidx.compose.material3.MaterialTheme
|
||||||
import androidx.compose.material3.Text
|
import androidx.compose.material3.Text
|
||||||
import androidx.compose.runtime.Composable
|
import androidx.compose.runtime.Composable
|
||||||
|
import androidx.compose.runtime.getValue
|
||||||
|
import androidx.compose.runtime.remember
|
||||||
import androidx.compose.ui.Alignment
|
import androidx.compose.ui.Alignment
|
||||||
import androidx.compose.ui.Modifier
|
import androidx.compose.ui.Modifier
|
||||||
import androidx.compose.ui.layout.ContentScale
|
import androidx.compose.ui.layout.ContentScale
|
||||||
|
|
@ -23,6 +25,7 @@ import androidx.compose.ui.text.style.TextOverflow
|
||||||
import androidx.compose.ui.unit.Dp
|
import androidx.compose.ui.unit.Dp
|
||||||
import androidx.compose.ui.unit.dp
|
import androidx.compose.ui.unit.dp
|
||||||
import androidx.compose.ui.unit.sp
|
import androidx.compose.ui.unit.sp
|
||||||
|
import androidx.lifecycle.compose.collectAsStateWithLifecycle
|
||||||
import com.nuvio.app.core.ui.NuvioShelfSection
|
import com.nuvio.app.core.ui.NuvioShelfSection
|
||||||
import com.nuvio.app.core.ui.PosterLandscapeAspectRatio
|
import com.nuvio.app.core.ui.PosterLandscapeAspectRatio
|
||||||
import com.nuvio.app.core.ui.landscapePosterWidth
|
import com.nuvio.app.core.ui.landscapePosterWidth
|
||||||
|
|
@ -30,6 +33,7 @@ import com.nuvio.app.core.ui.posterCardClickable
|
||||||
import com.nuvio.app.core.ui.rememberPosterCardStyleUiState
|
import com.nuvio.app.core.ui.rememberPosterCardStyleUiState
|
||||||
import com.nuvio.app.features.collection.Collection
|
import com.nuvio.app.features.collection.Collection
|
||||||
import com.nuvio.app.features.collection.CollectionFolder
|
import com.nuvio.app.features.collection.CollectionFolder
|
||||||
|
import com.nuvio.app.features.home.HomeCatalogSettingsRepository
|
||||||
import com.nuvio.app.features.home.PosterShape
|
import com.nuvio.app.features.home.PosterShape
|
||||||
|
|
||||||
@Composable
|
@Composable
|
||||||
|
|
@ -71,12 +75,18 @@ private fun HomeCollectionRowSectionContent(
|
||||||
animateGifs: Boolean,
|
animateGifs: Boolean,
|
||||||
onFolderClick: ((collectionId: String, folderId: String) -> Unit)?,
|
onFolderClick: ((collectionId: String, folderId: String) -> Unit)?,
|
||||||
) {
|
) {
|
||||||
|
val homeCatalogSettings by remember {
|
||||||
|
HomeCatalogSettingsRepository.snapshot()
|
||||||
|
HomeCatalogSettingsRepository.uiState
|
||||||
|
}.collectAsStateWithLifecycle()
|
||||||
|
|
||||||
NuvioShelfSection(
|
NuvioShelfSection(
|
||||||
title = collection.title,
|
title = collection.title,
|
||||||
entries = collection.folders,
|
entries = collection.folders,
|
||||||
modifier = modifier,
|
modifier = modifier,
|
||||||
headerHorizontalPadding = sectionPadding,
|
headerHorizontalPadding = sectionPadding,
|
||||||
rowContentPadding = PaddingValues(horizontal = sectionPadding),
|
rowContentPadding = PaddingValues(horizontal = sectionPadding),
|
||||||
|
showHeaderAccent = !homeCatalogSettings.hideCatalogUnderline,
|
||||||
key = { folder -> "collection_${collection.id}_folder_${folder.id}" },
|
key = { folder -> "collection_${collection.id}_folder_${folder.id}" },
|
||||||
) { folder ->
|
) { folder ->
|
||||||
CollectionFolderCard(
|
CollectionFolderCard(
|
||||||
|
|
|
||||||
|
|
@ -42,6 +42,8 @@ import nuvio.composeapp.generated.resources.layout_hide_unreleased
|
||||||
import nuvio.composeapp.generated.resources.layout_hide_unreleased_sub
|
import nuvio.composeapp.generated.resources.layout_hide_unreleased_sub
|
||||||
import nuvio.composeapp.generated.resources.settings_homescreen_empty_message
|
import nuvio.composeapp.generated.resources.settings_homescreen_empty_message
|
||||||
import nuvio.composeapp.generated.resources.settings_homescreen_empty_title
|
import nuvio.composeapp.generated.resources.settings_homescreen_empty_title
|
||||||
|
import nuvio.composeapp.generated.resources.settings_homescreen_hide_catalog_underline
|
||||||
|
import nuvio.composeapp.generated.resources.settings_homescreen_hide_catalog_underline_description
|
||||||
import nuvio.composeapp.generated.resources.settings_homescreen_keep_home_focused
|
import nuvio.composeapp.generated.resources.settings_homescreen_keep_home_focused
|
||||||
import nuvio.composeapp.generated.resources.settings_homescreen_limit_reached
|
import nuvio.composeapp.generated.resources.settings_homescreen_limit_reached
|
||||||
import nuvio.composeapp.generated.resources.settings_homescreen_no_sources_selected
|
import nuvio.composeapp.generated.resources.settings_homescreen_no_sources_selected
|
||||||
|
|
@ -65,6 +67,7 @@ internal fun LazyListScope.homescreenSettingsContent(
|
||||||
isTablet: Boolean,
|
isTablet: Boolean,
|
||||||
heroEnabled: Boolean,
|
heroEnabled: Boolean,
|
||||||
hideUnreleasedContent: Boolean,
|
hideUnreleasedContent: Boolean,
|
||||||
|
hideCatalogUnderline: Boolean,
|
||||||
items: List<HomeCatalogSettingsItem>,
|
items: List<HomeCatalogSettingsItem>,
|
||||||
) {
|
) {
|
||||||
val selectedHeroSourceCount = items.count { it.heroSourceEnabled }
|
val selectedHeroSourceCount = items.count { it.heroSourceEnabled }
|
||||||
|
|
@ -98,6 +101,14 @@ internal fun LazyListScope.homescreenSettingsContent(
|
||||||
isTablet = isTablet,
|
isTablet = isTablet,
|
||||||
onCheckedChange = HomeCatalogSettingsRepository::setHideUnreleasedContent,
|
onCheckedChange = HomeCatalogSettingsRepository::setHideUnreleasedContent,
|
||||||
)
|
)
|
||||||
|
SettingsGroupDivider(isTablet = isTablet)
|
||||||
|
SettingsSwitchRow(
|
||||||
|
title = stringResource(Res.string.settings_homescreen_hide_catalog_underline),
|
||||||
|
description = stringResource(Res.string.settings_homescreen_hide_catalog_underline_description),
|
||||||
|
checked = hideCatalogUnderline,
|
||||||
|
isTablet = isTablet,
|
||||||
|
onCheckedChange = HomeCatalogSettingsRepository::setHideCatalogUnderline,
|
||||||
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -78,6 +78,7 @@ fun HomescreenSettingsScreen(
|
||||||
isTablet = false,
|
isTablet = false,
|
||||||
heroEnabled = homescreenSettingsUiState.heroEnabled,
|
heroEnabled = homescreenSettingsUiState.heroEnabled,
|
||||||
hideUnreleasedContent = homescreenSettingsUiState.hideUnreleasedContent,
|
hideUnreleasedContent = homescreenSettingsUiState.hideUnreleasedContent,
|
||||||
|
hideCatalogUnderline = homescreenSettingsUiState.hideCatalogUnderline,
|
||||||
items = homescreenSettingsUiState.items,
|
items = homescreenSettingsUiState.items,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -237,6 +237,7 @@ fun SettingsScreen(
|
||||||
traktSettingsUiState = traktSettingsUiState,
|
traktSettingsUiState = traktSettingsUiState,
|
||||||
homescreenHeroEnabled = homescreenSettingsUiState.heroEnabled,
|
homescreenHeroEnabled = homescreenSettingsUiState.heroEnabled,
|
||||||
homescreenHideUnreleasedContent = homescreenSettingsUiState.hideUnreleasedContent,
|
homescreenHideUnreleasedContent = homescreenSettingsUiState.hideUnreleasedContent,
|
||||||
|
homescreenHideCatalogUnderline = homescreenSettingsUiState.hideCatalogUnderline,
|
||||||
homescreenItems = homescreenSettingsUiState.items,
|
homescreenItems = homescreenSettingsUiState.items,
|
||||||
metaScreenSettingsUiState = metaScreenSettingsUiState,
|
metaScreenSettingsUiState = metaScreenSettingsUiState,
|
||||||
continueWatchingPreferencesUiState = continueWatchingPreferencesUiState,
|
continueWatchingPreferencesUiState = continueWatchingPreferencesUiState,
|
||||||
|
|
@ -283,6 +284,7 @@ fun SettingsScreen(
|
||||||
traktSettingsUiState = traktSettingsUiState,
|
traktSettingsUiState = traktSettingsUiState,
|
||||||
homescreenHeroEnabled = homescreenSettingsUiState.heroEnabled,
|
homescreenHeroEnabled = homescreenSettingsUiState.heroEnabled,
|
||||||
homescreenHideUnreleasedContent = homescreenSettingsUiState.hideUnreleasedContent,
|
homescreenHideUnreleasedContent = homescreenSettingsUiState.hideUnreleasedContent,
|
||||||
|
homescreenHideCatalogUnderline = homescreenSettingsUiState.hideCatalogUnderline,
|
||||||
homescreenItems = homescreenSettingsUiState.items,
|
homescreenItems = homescreenSettingsUiState.items,
|
||||||
metaScreenSettingsUiState = metaScreenSettingsUiState,
|
metaScreenSettingsUiState = metaScreenSettingsUiState,
|
||||||
continueWatchingPreferencesUiState = continueWatchingPreferencesUiState,
|
continueWatchingPreferencesUiState = continueWatchingPreferencesUiState,
|
||||||
|
|
@ -339,6 +341,7 @@ private fun MobileSettingsScreen(
|
||||||
traktSettingsUiState: TraktSettingsUiState,
|
traktSettingsUiState: TraktSettingsUiState,
|
||||||
homescreenHeroEnabled: Boolean,
|
homescreenHeroEnabled: Boolean,
|
||||||
homescreenHideUnreleasedContent: Boolean,
|
homescreenHideUnreleasedContent: Boolean,
|
||||||
|
homescreenHideCatalogUnderline: Boolean,
|
||||||
homescreenItems: List<HomeCatalogSettingsItem>,
|
homescreenItems: List<HomeCatalogSettingsItem>,
|
||||||
metaScreenSettingsUiState: MetaScreenSettingsUiState,
|
metaScreenSettingsUiState: MetaScreenSettingsUiState,
|
||||||
continueWatchingPreferencesUiState: ContinueWatchingPreferencesUiState,
|
continueWatchingPreferencesUiState: ContinueWatchingPreferencesUiState,
|
||||||
|
|
@ -530,6 +533,7 @@ private fun MobileSettingsScreen(
|
||||||
isTablet = false,
|
isTablet = false,
|
||||||
heroEnabled = homescreenHeroEnabled,
|
heroEnabled = homescreenHeroEnabled,
|
||||||
hideUnreleasedContent = homescreenHideUnreleasedContent,
|
hideUnreleasedContent = homescreenHideUnreleasedContent,
|
||||||
|
hideCatalogUnderline = homescreenHideCatalogUnderline,
|
||||||
items = homescreenItems,
|
items = homescreenItems,
|
||||||
)
|
)
|
||||||
SettingsPage.MetaScreen -> metaScreenSettingsContent(
|
SettingsPage.MetaScreen -> metaScreenSettingsContent(
|
||||||
|
|
@ -638,6 +642,7 @@ private fun TabletSettingsScreen(
|
||||||
traktSettingsUiState: TraktSettingsUiState,
|
traktSettingsUiState: TraktSettingsUiState,
|
||||||
homescreenHeroEnabled: Boolean,
|
homescreenHeroEnabled: Boolean,
|
||||||
homescreenHideUnreleasedContent: Boolean,
|
homescreenHideUnreleasedContent: Boolean,
|
||||||
|
homescreenHideCatalogUnderline: Boolean,
|
||||||
homescreenItems: List<HomeCatalogSettingsItem>,
|
homescreenItems: List<HomeCatalogSettingsItem>,
|
||||||
metaScreenSettingsUiState: MetaScreenSettingsUiState,
|
metaScreenSettingsUiState: MetaScreenSettingsUiState,
|
||||||
continueWatchingPreferencesUiState: ContinueWatchingPreferencesUiState,
|
continueWatchingPreferencesUiState: ContinueWatchingPreferencesUiState,
|
||||||
|
|
@ -888,6 +893,7 @@ private fun TabletSettingsScreen(
|
||||||
isTablet = true,
|
isTablet = true,
|
||||||
heroEnabled = homescreenHeroEnabled,
|
heroEnabled = homescreenHeroEnabled,
|
||||||
hideUnreleasedContent = homescreenHideUnreleasedContent,
|
hideUnreleasedContent = homescreenHideUnreleasedContent,
|
||||||
|
hideCatalogUnderline = homescreenHideCatalogUnderline,
|
||||||
items = homescreenItems,
|
items = homescreenItems,
|
||||||
)
|
)
|
||||||
SettingsPage.MetaScreen -> metaScreenSettingsContent(
|
SettingsPage.MetaScreen -> metaScreenSettingsContent(
|
||||||
|
|
|
||||||
|
|
@ -588,6 +588,7 @@ internal fun settingsSearchEntries(
|
||||||
listOf(
|
listOf(
|
||||||
PlaybackSearchRow("home-hero", stringResource(Res.string.settings_homescreen_show_hero), stringResource(Res.string.settings_homescreen_show_hero_description)),
|
PlaybackSearchRow("home-hero", stringResource(Res.string.settings_homescreen_show_hero), stringResource(Res.string.settings_homescreen_show_hero_description)),
|
||||||
PlaybackSearchRow("home-hide-unreleased", stringResource(Res.string.layout_hide_unreleased), stringResource(Res.string.layout_hide_unreleased_sub)),
|
PlaybackSearchRow("home-hide-unreleased", stringResource(Res.string.layout_hide_unreleased), stringResource(Res.string.layout_hide_unreleased_sub)),
|
||||||
|
PlaybackSearchRow("home-hide-catalog-underline", stringResource(Res.string.settings_homescreen_hide_catalog_underline), stringResource(Res.string.settings_homescreen_hide_catalog_underline_description)),
|
||||||
PlaybackSearchRow("home-hero-sources", stringResource(Res.string.settings_homescreen_section_hero_sources)),
|
PlaybackSearchRow("home-hero-sources", stringResource(Res.string.settings_homescreen_section_hero_sources)),
|
||||||
PlaybackSearchRow("home-catalogs", stringResource(Res.string.settings_homescreen_section_catalogs)),
|
PlaybackSearchRow("home-catalogs", stringResource(Res.string.settings_homescreen_section_catalogs)),
|
||||||
).forEach { row ->
|
).forEach { row ->
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue