jellyflood/Shared/ViewModels/LibraryViewModel/NextUpLibraryViewModel.swift

46 lines
1.4 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 Combine
import Defaults
import Foundation
import JellyfinAPI
final class NextUpLibraryViewModel: PagingLibraryViewModel<BaseItemDto> {
init() {
super.init(parent: TitledLibraryParent(displayTitle: L10n.nextUp, id: "nextUp"))
}
override func get(page: Int) async throws -> [BaseItemDto] {
let parameters = parameters(for: page)
let request = Paths.getNextUp(parameters: parameters)
let response = try await userSession.client.send(request)
return response.value.items ?? []
}
private func parameters(for page: Int) -> Paths.GetNextUpParameters {
let maxNextUp = Defaults[.Customization.Home.maxNextUp]
var parameters = Paths.GetNextUpParameters()
parameters.enableUserData = true
parameters.fields = .MinimumFields
parameters.limit = pageSize
if maxNextUp > 0 {
parameters.nextUpDateCutoff = Date.now.addingTimeInterval(-maxNextUp)
}
parameters.enableRewatching = Defaults[.Customization.Home.resumeNextUp]
parameters.startIndex = page
parameters.userID = userSession.user.id
return parameters
}
}