import Siesta import SwiftUI struct ChannelVideosView: View { let channel: Channel @State private var presentingShareSheet = false @State private var shareURL: URL? @StateObject private var store = Store() @Environment(\.dismiss) private var dismiss @Environment(\.inNavigationView) private var inNavigationView #if os(iOS) @Environment(\.horizontalSizeClass) private var horizontalSizeClass #endif @EnvironmentObject private var accounts @EnvironmentObject private var navigation @EnvironmentObject private var subscriptions @Namespace private var focusNamespace var videos: [ContentItem] { ContentItem.array(of: store.item?.videos ?? []) } var body: some View { #if os(iOS) if inNavigationView { content } else { PlayerControlsView { content } } #else PlayerControlsView { content } #endif } var content: some View { VStack { #if os(tvOS) HStack { Text(navigationTitle) .font(.title2) .frame(alignment: .leading) Spacer() FavoriteButton(item: FavoriteItem(section: .channel(channel.id, channel.name))) .labelStyle(.iconOnly) if let subscribers = store.item?.subscriptionsString { Text("**\(subscribers)** subscribers") .foregroundColor(.secondary) } subscriptionToggleButton } .frame(maxWidth: .infinity) #endif VerticalCells(items: videos) #if !os(iOS) .prefersDefaultFocus(in: focusNamespace) #endif } .environment(\.inChannelView, true) #if !os(iOS) .focusScope(focusNamespace) #endif #if !os(tvOS) .toolbar { ToolbarItem(placement: .navigation) { ShareButton( contentItem: contentItem, presentingShareSheet: $presentingShareSheet, shareURL: $shareURL ) } ToolbarItem { HStack { Text("**\(store.item?.subscriptionsString ?? "loading")** subscribers") .foregroundColor(.secondary) .opacity(store.item?.subscriptionsString != nil ? 1 : 0) subscriptionToggleButton FavoriteButton(item: FavoriteItem(section: .channel(channel.id, channel.name))) } } } #else .background(.thickMaterial) #endif #if os(iOS) .sheet(isPresented: $presentingShareSheet) { if let shareURL = shareURL { ShareSheet(activityItems: [shareURL]) } } #endif .modifier(UnsubscribeAlertModifier()) .onAppear { if store.item.isNil { resource.addObserver(store) resource.load() } } .navigationTitle(navigationTitle) } private var resource: Resource { let resource = accounts.api.channel(channel.id) resource.addObserver(store) return resource } private var subscriptionToggleButton: some View { Group { if accounts.app.supportsSubscriptions && accounts.signedIn { if subscriptions.isSubscribing(channel.id) { Button("Unsubscribe") { navigation.presentUnsubscribeAlert(channel) } } else { Button("Subscribe") { subscriptions.subscribe(channel.id) { navigation.sidebarSectionChanged.toggle() } } } } } } private var contentItem: ContentItem { ContentItem(channel: channel) } private var navigationTitle: String { store.item?.name ?? channel.name } }