diff options
Diffstat (limited to 'Jel/Views/Library/Item/ItemMediaView.swift')
-rw-r--r-- | Jel/Views/Library/Item/ItemMediaView.swift | 85 |
1 files changed, 36 insertions, 49 deletions
diff --git a/Jel/Views/Library/Item/ItemMediaView.swift b/Jel/Views/Library/Item/ItemMediaView.swift index 4b8f863..c7fe0cb 100644 --- a/Jel/Views/Library/Item/ItemMediaView.swift +++ b/Jel/Views/Library/Item/ItemMediaView.swift @@ -9,58 +9,55 @@ import SwiftUI import JellyfinKit import VisibilityTrackingScrollView -struct ItemMediaView: View { +struct ItemMediaView<Content: View>: View { @EnvironmentObject var jellyfinClient: JellyfinClientController @StateObject var authState: AuthStateController = AuthStateController.shared @State var item: BaseItemDto - @State var loading: Bool = true + @ViewBuilder var playButton: () -> Content @State var pageScrolled: Bool = false var body: some View { GeometryReader {geo in - if loading { - ProgressView() - .progressViewStyle(.circular) - } else { - ScrollView() { - ItemHeaderView(item: item) - .padding(.bottom) - .background { - GeometryReader {geo in - EmptyView() - .onChange(of: geo.frame(in: .global).minY) { - let minY = geo.frame(in: .global).minY - - pageScrolled = minY < 0 - } - } - } - - VStack(alignment: .leading) { - Text(item.taglines?.count ?? 0 > 0 ? item.taglines?[0] ?? "" : "") - .font(.headline) - .frame(maxWidth: .infinity, alignment: .leading) - .padding(.bottom) - - ForEach(item.overview?.components(separatedBy: "<br>") ?? [], id: \.self) {overview in - Text(overview) + ScrollView() { + ItemHeaderView(item: item) + .padding(.bottom) + .background { + GeometryReader {geo in + EmptyView() + .onChange(of: geo.frame(in: .global).minY) { + let minY = geo.frame(in: .global).minY + + pageScrolled = minY < 0 + } } - - ItemGenresView(item: item) } - .if(max(geo.safeAreaInsets.leading, geo.safeAreaInsets.trailing) > 0) {view in - view - .padding(max(geo.safeAreaInsets.leading, geo.safeAreaInsets.trailing)) - } - .if(max(geo.safeAreaInsets.leading, geo.safeAreaInsets.trailing) <= 0) {view in - view - .padding() + + playButton() + + VStack(alignment: .leading) { + Text(item.taglines?.count ?? 0 > 0 ? item.taglines?[0] ?? "" : "") + .font(.headline) + .frame(maxWidth: .infinity, alignment: .leading) + .padding(.bottom) + + ForEach(item.overview?.components(separatedBy: "<br>") ?? [], id: \.self) {overview in + Text(overview) } + + ItemGenresView(item: item) + } + .if(max(geo.safeAreaInsets.leading, geo.safeAreaInsets.trailing) > 0) {view in + view + .padding(max(geo.safeAreaInsets.leading, geo.safeAreaInsets.trailing)) + } + .if(max(geo.safeAreaInsets.leading, geo.safeAreaInsets.trailing) <= 0) {view in + view + .padding() } - .ignoresSafeArea() } + .ignoresSafeArea() } .navigationBarTitleDisplayMode(.inline) .navigationTitle(item.name ?? "Untitled") @@ -72,17 +69,7 @@ struct ItemMediaView: View { } } .scrollIndicators(.hidden) - .onAppear { - Task { - do { - let request = Paths.getItem(userID: authState.userId ?? "", itemID: item.id ?? "") - let response = try await jellyfinClient.send(request) - item = response.value - loading = false - } catch { - } - } - } + } } |