1
0
mirror of https://github.com/yattee/yattee.git synced 2025-01-06 01:20:31 +05:30
yattee/Shared/Player/PlayerQueueView.swift

168 lines
5.6 KiB
Swift
Raw Normal View History

2021-11-06 01:27:22 +05:30
import Defaults
import Foundation
import SwiftUI
struct PlayerQueueView: View {
var sidebarQueue: Bool
2022-06-25 22:03:35 +05:30
@Binding var fullScreen: Bool
@FetchRequest(sortDescriptors: [.init(key: "watchedAt", ascending: false)])
var watches: FetchedResults<Watch>
@EnvironmentObject<AccountsModel> private var accounts
2022-06-26 17:01:26 +05:30
@EnvironmentObject<NavigationModel> private var navigation
@EnvironmentObject<PlaylistsModel> private var playlists
@EnvironmentObject<PlayerModel> private var player
2021-11-06 01:27:22 +05:30
@Default(.saveHistory) private var saveHistory
@Default(.showHistoryInPlayer) private var showHistoryInPlayer
2021-11-06 01:27:22 +05:30
var body: some View {
List {
Group {
playingNext
2021-11-04 04:30:17 +05:30
if sidebarQueue {
related
}
if saveHistory, showHistoryInPlayer {
2021-11-06 01:27:22 +05:30
playedPreviously
}
}
2021-11-03 04:32:02 +05:30
#if !os(iOS)
2021-11-08 21:59:35 +05:30
.padding(.vertical, 5)
.listRowInsets(EdgeInsets())
#endif
}
#if os(macOS)
2021-11-08 21:59:35 +05:30
.listStyle(.inset)
#elseif os(iOS)
2021-11-08 21:59:35 +05:30
.listStyle(.grouped)
#else
2021-11-08 21:59:35 +05:30
.listStyle(.plain)
#endif
}
var playingNext: some View {
Section(header: Text("Playing Next")) {
if player.queue.isEmpty {
Text("Playback queue is empty")
.foregroundColor(.secondary)
}
ForEach(player.queue) { item in
2022-06-25 22:03:35 +05:30
PlayerQueueRow(item: item, fullScreen: $fullScreen)
.onAppear {
player.loadQueueVideoDetails(item)
}
.contextMenu {
removeButton(item)
removeAllButton()
}
}
}
}
private var visibleWatches: [Watch] {
watches.filter { $0.videoID != player.currentVideo?.videoID }
}
var playedPreviously: some View {
Group {
if !visibleWatches.isEmpty {
Section(header: Text("Played Previously")) {
ForEach(visibleWatches, id: \.videoID) { watch in
PlayerQueueRow(
item: PlayerQueueItem.from(watch, video: player.historyVideo(watch.videoID)),
history: true,
2022-06-25 22:03:35 +05:30
fullScreen: $fullScreen
)
.onAppear {
player.loadHistoryVideoDetails(watch.videoID)
}
.contextMenu {
removeHistoryButton(watch)
}
}
}
}
}
}
2021-11-03 04:32:02 +05:30
private var related: some View {
Group {
if !player.currentVideo.isNil, !player.currentVideo!.related.isEmpty {
Section(header: Text("Related")) {
ForEach(player.currentVideo!.related) { video in
2022-06-25 22:03:35 +05:30
PlayerQueueRow(item: PlayerQueueItem(video), fullScreen: $fullScreen)
2021-11-03 04:32:02 +05:30
.contextMenu {
Button {
2021-11-03 04:32:02 +05:30
player.playNext(video)
} label: {
Label("Play Next", systemImage: "text.insert")
2021-11-03 04:32:02 +05:30
}
Button {
2021-11-03 04:32:02 +05:30
player.enqueueVideo(video)
} label: {
Label("Play Last", systemImage: "text.append")
2021-11-03 04:32:02 +05:30
}
2022-06-26 17:01:26 +05:30
if accounts.app.supportsUserPlaylists && accounts.signedIn {
Section {
Button {
navigation.presentAddToPlaylist(video)
} label: {
Label("Add to playlist...", systemImage: "text.badge.plus")
}
if let playlist = playlists.lastUsed {
Button {
playlists.addVideo(playlistID: playlist.id, videoID: video.videoID, navigation: navigation)
} label: {
Label("Add to \(playlist.title)", systemImage: "text.badge.star")
}
}
}
}
2021-11-03 04:32:02 +05:30
}
}
}
}
}
}
private func removeButton(_ item: PlayerQueueItem) -> some View {
Button {
player.remove(item)
} label: {
Label("Remove", systemImage: "trash")
}
}
private func removeAllButton() -> some View {
Button {
player.removeQueueItems()
} label: {
Label("Remove All", systemImage: "trash.fill")
}
}
2021-11-28 20:07:55 +05:30
private func removeHistoryButton(_ watch: Watch) -> some View {
Button {
player.removeWatch(watch)
} label: {
Label("Remove", systemImage: "trash")
}
2021-11-28 20:07:55 +05:30
}
}
struct PlayerQueueView_Previews: PreviewProvider {
static var previews: some View {
VStack {
2022-06-25 22:03:35 +05:30
PlayerQueueView(sidebarQueue: true, fullScreen: .constant(true))
}
.injectFixtureEnvironmentObjects()
}
}