2021-11-06 01:27:22 +05:30
|
|
|
import Defaults
|
2021-10-06 01:50:09 +05:30
|
|
|
import SwiftUI
|
|
|
|
|
|
|
|
struct NowPlayingView: View {
|
2021-11-03 04:32:02 +05:30
|
|
|
enum ViewSection: CaseIterable {
|
2021-12-05 01:05:41 +05:30
|
|
|
case nowPlaying, playingNext, playedPreviously, related, comments
|
2021-11-03 04:32:02 +05:30
|
|
|
}
|
|
|
|
|
2021-12-05 01:05:41 +05:30
|
|
|
var sections = [ViewSection.nowPlaying, .playingNext, .playedPreviously, .related]
|
2021-10-22 20:30:09 +05:30
|
|
|
var inInfoViewController = false
|
2021-10-06 01:50:09 +05:30
|
|
|
|
2021-12-05 01:05:41 +05:30
|
|
|
@State private var repliesID: Comment.ID?
|
|
|
|
|
|
|
|
@EnvironmentObject<CommentsModel> private var comments
|
2021-10-06 01:50:09 +05:30
|
|
|
@EnvironmentObject<PlayerModel> private var player
|
2021-12-05 01:05:41 +05:30
|
|
|
@EnvironmentObject<RecentsModel> private var recents
|
2021-10-06 01:50:09 +05:30
|
|
|
|
2021-11-06 01:27:22 +05:30
|
|
|
@Default(.saveHistory) private var saveHistory
|
|
|
|
|
2021-10-06 01:50:09 +05:30
|
|
|
var body: some View {
|
2021-10-22 20:30:09 +05:30
|
|
|
if inInfoViewController {
|
2021-10-06 01:50:09 +05:30
|
|
|
content
|
|
|
|
.background(.thinMaterial)
|
|
|
|
.mask(RoundedRectangle(cornerRadius: 24))
|
|
|
|
} else {
|
|
|
|
content
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
var content: some View {
|
2021-10-23 15:43:05 +05:30
|
|
|
List {
|
|
|
|
Group {
|
2021-11-03 04:32:02 +05:30
|
|
|
if sections.contains(.nowPlaying), let item = player.currentItem {
|
2021-10-23 15:43:05 +05:30
|
|
|
Section(header: Text("Now Playing")) {
|
2021-10-06 01:50:09 +05:30
|
|
|
Button {
|
|
|
|
player.presentPlayer()
|
|
|
|
} label: {
|
|
|
|
VideoBanner(video: item.video)
|
|
|
|
}
|
2021-12-03 01:49:10 +05:30
|
|
|
.contextMenu {
|
|
|
|
Button("Close Video") {
|
|
|
|
player.closeCurrentItem()
|
|
|
|
}
|
|
|
|
|
|
|
|
Button("Cancel", role: .cancel) {}
|
|
|
|
}
|
2021-10-06 01:50:09 +05:30
|
|
|
}
|
|
|
|
.onPlayPauseCommand(perform: player.togglePlay)
|
|
|
|
}
|
|
|
|
|
2021-11-03 04:32:02 +05:30
|
|
|
if sections.contains(.playingNext) {
|
|
|
|
Section(header: Text("Playing Next")) {
|
|
|
|
if player.queue.isEmpty {
|
|
|
|
Text("Playback queue is empty")
|
|
|
|
.padding([.vertical, .leading], 40)
|
|
|
|
.foregroundColor(.secondary)
|
|
|
|
}
|
2021-10-23 15:43:05 +05:30
|
|
|
|
2021-11-03 04:32:02 +05:30
|
|
|
ForEach(player.queue) { item in
|
|
|
|
Button {
|
|
|
|
player.advanceToItem(item)
|
|
|
|
player.presentPlayer()
|
|
|
|
} label: {
|
|
|
|
VideoBanner(video: item.video)
|
|
|
|
}
|
|
|
|
.contextMenu {
|
|
|
|
Button("Delete", role: .destructive) {
|
|
|
|
player.remove(item)
|
|
|
|
}
|
|
|
|
}
|
2021-10-23 15:43:05 +05:30
|
|
|
}
|
2021-11-03 04:32:02 +05:30
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if sections.contains(.related), !player.currentVideo.isNil, !player.currentVideo!.related.isEmpty {
|
|
|
|
Section(header: inInfoViewController ? AnyView(EmptyView()) : AnyView(Text("Related"))) {
|
|
|
|
ForEach(player.currentVideo!.related) { video in
|
|
|
|
Button {
|
|
|
|
player.playNow(video)
|
|
|
|
player.presentPlayer()
|
|
|
|
} label: {
|
|
|
|
VideoBanner(video: video)
|
|
|
|
}
|
|
|
|
.contextMenu {
|
|
|
|
Button("Play Next") {
|
|
|
|
player.playNext(video)
|
|
|
|
}
|
|
|
|
Button("Play Last") {
|
|
|
|
player.enqueueVideo(video)
|
|
|
|
}
|
|
|
|
Button("Cancel", role: .cancel) {}
|
2021-10-23 15:43:05 +05:30
|
|
|
}
|
2021-10-06 01:50:09 +05:30
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2021-10-14 03:35:19 +05:30
|
|
|
|
2021-11-06 01:27:22 +05:30
|
|
|
if sections.contains(.playedPreviously), saveHistory, !player.history.isEmpty {
|
2021-10-23 15:43:05 +05:30
|
|
|
Section(header: Text("Played Previously")) {
|
|
|
|
ForEach(player.history) { item in
|
|
|
|
Button {
|
|
|
|
player.playHistory(item)
|
|
|
|
player.presentPlayer()
|
|
|
|
} label: {
|
|
|
|
VideoBanner(video: item.video, playbackTime: item.playbackTime, videoDuration: item.videoDuration)
|
|
|
|
}
|
|
|
|
.contextMenu {
|
2021-11-05 23:53:28 +05:30
|
|
|
Button("Remove", role: .destructive) {
|
2021-10-23 15:43:05 +05:30
|
|
|
player.removeHistory(item)
|
|
|
|
}
|
|
|
|
|
2021-11-05 23:53:28 +05:30
|
|
|
Button("Remove All", role: .destructive) {
|
2021-10-23 15:43:05 +05:30
|
|
|
player.removeHistoryItems()
|
|
|
|
}
|
|
|
|
}
|
2021-10-14 03:35:19 +05:30
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2021-12-05 01:05:41 +05:30
|
|
|
|
|
|
|
if sections.contains(.comments) {
|
|
|
|
Section {
|
|
|
|
ForEach(comments.all) { comment in
|
|
|
|
CommentView(comment: comment, repliesID: $repliesID)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2021-10-06 01:50:09 +05:30
|
|
|
}
|
2021-10-23 15:43:05 +05:30
|
|
|
.listRowInsets(EdgeInsets(top: 0, leading: 0, bottom: 0, trailing: 20))
|
|
|
|
.padding(.vertical, 20)
|
2021-10-06 01:50:09 +05:30
|
|
|
}
|
2021-10-23 15:43:05 +05:30
|
|
|
.padding(.horizontal, inInfoViewController ? 40 : 0)
|
|
|
|
.listStyle(.grouped)
|
|
|
|
.frame(minWidth: 0, maxWidth: .infinity, minHeight: 560, maxHeight: .infinity, alignment: .leading)
|
2021-10-06 01:50:09 +05:30
|
|
|
}
|
|
|
|
|
|
|
|
func header(_ text: String) -> some View {
|
|
|
|
Text(text)
|
2021-10-22 20:30:09 +05:30
|
|
|
.font((inInfoViewController ? Font.system(size: 40) : .title3).bold())
|
2021-10-06 01:50:09 +05:30
|
|
|
.foregroundColor(.secondary)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
struct NowPlayingView_Previews: PreviewProvider {
|
|
|
|
static var previews: some View {
|
|
|
|
NowPlayingView()
|
|
|
|
.injectFixtureEnvironmentObjects()
|
2021-10-22 20:30:09 +05:30
|
|
|
|
|
|
|
NowPlayingView(inInfoViewController: true)
|
|
|
|
.injectFixtureEnvironmentObjects()
|
2021-10-06 01:50:09 +05:30
|
|
|
}
|
|
|
|
}
|