jellyflood/Swiftfin/Views/HomeView/Components/NextUpView.swift

77 lines
2.1 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) 2024 Jellyfin & Jellyfin Contributors
//
import CollectionHStack
import Defaults
import JellyfinAPI
import SwiftUI
extension HomeView {
struct NextUpView: View {
@Default(.Customization.nextUpPosterType)
private var nextUpPosterType
@EnvironmentObject
private var router: HomeCoordinator.Router
@ObservedObject
var viewModel: NextUpLibraryViewModel
private var onSetPlayed: (BaseItemDto) -> Void
var body: some View {
if viewModel.elements.isNotEmpty {
PosterHStack(
title: L10n.nextUp,
type: nextUpPosterType,
items: viewModel.elements
)
.content { item in
if item.type == .episode {
PosterButton.EpisodeContentSubtitleContent(item: item)
} else {
PosterButton.TitleSubtitleContentView(item: item)
}
}
.contextMenu { item in
Button {
onSetPlayed(item)
} label: {
Label(L10n.played, systemImage: "checkmark.circle")
}
}
.onSelect { item in
router.route(to: \.item, item)
}
.trailing {
SeeAllButton()
.onSelect {
router.route(to: \.library, viewModel)
}
}
}
}
}
}
extension HomeView.NextUpView {
init(viewModel: NextUpLibraryViewModel) {
self.init(
viewModel: viewModel,
onSetPlayed: { _ in }
)
}
func onSetPlayed(perform action: @escaping (BaseItemDto) -> Void) -> Self {
copy(modifying: \.onSetPlayed, with: action)
}
}