jellyflood/Swiftfin tvOS/Views/SettingsView/CustomizeViewsSettings/CustomizeViewsSettings.swift
Joe Kribs 4ca788338d
[tvOS] PagingLibraryView - Mirror iOS "Hot Reload" Functionality (#1408)
* Update missing strings. Mirror iOS setting changes to make sure tvOS PagingLIbraryView updates with changes as well. Lay the groundwork for filtering.

* Revert back to rows over offset

* Reorder a bit.

* Move default layout to no values in closure. For whatever reason, I cannot do this to the non-defaults.

* 95% there

* Move `onChange`s to the `innerContent` to alleviate Type Checker issues

* All Value-less closures are moved with teh exception of viewModel.filterViewModel?.currentFilters

* Prepare for future letter picker location
2025-01-24 16:14:34 -05:00

84 lines
2.7 KiB
Swift

//
// Swiftfin is subject to the terms of the Mozilla Public
// License, v2.0. If a copy of the MPL was not distributed with this
// file, you can obtain one at https://mozilla.org/MPL/2.0/.
//
// Copyright (c) 2025 Jellyfin & Jellyfin Contributors
//
import Defaults
import SwiftUI
struct CustomizeViewsSettings: View {
@Default(.Customization.shouldShowMissingSeasons)
private var shouldShowMissingSeasons
@Default(.Customization.shouldShowMissingEpisodes)
private var shouldShowMissingEpisodes
@Default(.Customization.showPosterLabels)
private var showPosterLabels
@Default(.Customization.nextUpPosterType)
private var nextUpPosterType
@Default(.Customization.recentlyAddedPosterType)
private var recentlyAddedPosterType
@Default(.Customization.latestInLibraryPosterType)
private var latestInLibraryPosterType
@Default(.Customization.similarPosterType)
private var similarPosterType
@Default(.Customization.searchPosterType)
private var searchPosterType
@Default(.Customization.Library.displayType)
private var libraryViewType
@EnvironmentObject
private var router: CustomizeSettingsCoordinator.Router
var body: some View {
SplitFormWindowView()
.descriptionView {
Image(systemName: "gearshape")
.resizable()
.aspectRatio(contentMode: .fit)
.frame(maxWidth: 400)
}
.contentView {
Section(L10n.missingItems) {
Toggle(L10n.showMissingSeasons, isOn: $shouldShowMissingSeasons)
Toggle(L10n.showMissingEpisodes, isOn: $shouldShowMissingEpisodes)
}
Section(L10n.posters) {
ChevronButton(L10n.indicators)
.onSelect {
router.route(to: \.indicatorSettings)
}
Toggle(L10n.showPosterLabels, isOn: $showPosterLabels)
InlineEnumToggle(title: L10n.next, selection: $nextUpPosterType)
InlineEnumToggle(title: L10n.recentlyAdded, selection: $recentlyAddedPosterType)
InlineEnumToggle(title: L10n.latestWithString(L10n.library), selection: $latestInLibraryPosterType)
InlineEnumToggle(title: L10n.recommended, selection: $similarPosterType)
InlineEnumToggle(title: L10n.search, selection: $searchPosterType)
}
LibrarySection()
ItemSection()
HomeSection()
}
.withDescriptionTopPadding()
.navigationTitle(L10n.customize)
}
}