tvOS History improvements

This commit is contained in:
Arkadiusz Fal 2021-10-14 00:05:19 +02:00
parent 70c089e696
commit 2c275d9353
4 changed files with 42 additions and 9 deletions

View File

@ -127,6 +127,16 @@ extension PlayerModel {
}
}
func playHistory(_ item: PlayerQueueItem) {
let newItem = enqueueVideo(item.video, prepending: true)
advanceToItem(newItem!)
if let historyItemIndex = history.firstIndex(of: item) {
history.remove(at: historyItemIndex)
}
}
@discardableResult func removeHistory(_ item: PlayerQueueItem) -> PlayerQueueItem? {
if let index = history.firstIndex(where: { $0 == item }) {
return history.remove(at: index)

View File

@ -14,11 +14,7 @@ struct PlayerQueueRow: View {
player.addCurrentItemToHistory()
if history {
let newItem = player.enqueueVideo(item.video, prepending: true)
player.advanceToItem(newItem!)
if let historyItemIndex = player.history.firstIndex(of: item) {
player.history.remove(at: historyItemIndex)
}
player.playHistory(item)
} else {
player.advanceToItem(item)
}

View File

@ -45,6 +45,7 @@ final class PlayerViewController: UIViewController {
let controller = UIHostingController(rootView:
AnyView(
NowPlayingView(infoViewController: true)
.frame(maxHeight: 600)
.environmentObject(playerModel)
)
)

View File

@ -33,15 +33,13 @@ struct NowPlayingView: View {
.padding(.bottom, 20)
}
if !infoViewController {
header("Playing Next")
}
if player.queue.isEmpty {
Spacer()
Text("Playback queue is empty")
.padding(.leading, 40)
.padding([.vertical, .leading], 40)
.foregroundColor(.secondary)
}
@ -58,6 +56,34 @@ struct NowPlayingView: View {
}
}
}
header("Played Previously")
if player.history.isEmpty {
Spacer()
Text("History is empty")
.padding([.vertical, .leading], 40)
.foregroundColor(.secondary)
}
ForEach(player.history) { item in
Button {
player.playHistory(item)
player.presentPlayer()
} label: {
VideoBanner(video: item.video)
}
.contextMenu {
Button("Delete", role: .destructive) {
player.removeHistory(item)
}
Button("Delete History", role: .destructive) {
player.removeHistoryItems()
}
}
}
}
.padding(.vertical)
.padding(.horizontal, 40)