2022-11-09 13:34:04 +00:00
|
|
|
import SwiftUI
|
|
|
|
|
|
|
|
struct HistoryView: View {
|
2022-11-15 11:22:27 +00:00
|
|
|
var limit = 10
|
|
|
|
|
2022-11-09 13:34:04 +00:00
|
|
|
@FetchRequest(sortDescriptors: [.init(key: "watchedAt", ascending: false)])
|
|
|
|
var watches: FetchedResults<Watch>
|
|
|
|
|
2022-11-24 20:36:05 +00:00
|
|
|
@ObservedObject private var player = PlayerModel.shared
|
2022-11-09 13:34:04 +00:00
|
|
|
|
|
|
|
var body: some View {
|
|
|
|
LazyVStack {
|
2022-11-11 17:50:13 +00:00
|
|
|
if visibleWatches.isEmpty {
|
2022-11-25 18:31:48 +00:00
|
|
|
VStack(spacing: 20) {
|
2022-11-11 17:50:13 +00:00
|
|
|
HStack {
|
|
|
|
Image(systemName: "clock")
|
|
|
|
Text("Playback history is empty")
|
|
|
|
}.foregroundColor(.secondary)
|
2022-11-09 13:34:04 +00:00
|
|
|
}
|
2022-11-11 17:50:13 +00:00
|
|
|
} else {
|
|
|
|
ForEach(visibleWatches, id: \.videoID) { watch in
|
2022-12-15 11:09:36 +00:00
|
|
|
let video = player.historyVideo(watch.videoID) ?? watch.video
|
|
|
|
|
|
|
|
ContentItemView(item: .init(video: video))
|
|
|
|
.environment(\.listingStyle, .list)
|
|
|
|
.contextMenu {
|
|
|
|
VideoContextMenuView(video: video)
|
|
|
|
}
|
2022-11-09 13:34:04 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2022-12-22 18:36:35 +00:00
|
|
|
.animation(nil, value: visibleWatches)
|
2022-11-14 17:46:50 +00:00
|
|
|
.onAppear {
|
|
|
|
visibleWatches
|
|
|
|
.forEach(player.loadHistoryVideoDetails)
|
|
|
|
}
|
2022-11-09 13:34:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
private var visibleWatches: [Watch] {
|
|
|
|
Array(watches.filter { $0.videoID != player.currentVideo?.videoID }.prefix(limit))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
struct HistoryView_Previews: PreviewProvider {
|
|
|
|
static var previews: some View {
|
|
|
|
HistoryView()
|
|
|
|
}
|
|
|
|
}
|