1
0
mirror of https://github.com/yattee/yattee.git synced 2025-01-10 11:30:32 +05:30
yattee/Shared/Subscriptions/ChannelsView.swift

194 lines
6.5 KiB
Swift
Raw Permalink Normal View History

2022-12-13 16:39:20 +05:30
import Defaults
import SDWebImageSwiftUI
import SwiftUI
struct ChannelsView: View {
2022-12-13 17:44:20 +05:30
@ObservedObject private var feed = FeedModel.shared
2022-12-11 20:45:42 +05:30
@ObservedObject private var subscriptions = SubscribedChannelsModel.shared
@ObservedObject private var accounts = AccountsModel.shared
2022-12-17 02:56:14 +05:30
@ObservedObject private var feedCount = UnwatchedFeedCountModel.shared
2023-04-23 01:09:27 +05:30
private var navigation = NavigationModel.shared
2022-12-13 16:39:20 +05:30
@Default(.showCacheStatus) private var showCacheStatus
@Default(.showUnwatchedFeedBadges) private var showUnwatchedFeedBadges
@Default(.keepChannelsWithUnwatchedFeedOnTop) private var keepChannelsWithUnwatchedFeedOnTop
@Default(.showChannelAvatarInChannelsLists) private var showChannelAvatarInChannelsLists
@State private var channelLinkActive = false
@State private var channelForLink: Channel?
2022-12-13 16:39:20 +05:30
var body: some View {
List {
Section(header: header) {
ForEach(channels) { channel in
2023-04-23 01:09:27 +05:30
let label = HStack {
if showChannelAvatarInChannelsLists {
ChannelAvatarView(channel: channel, subscribedBadge: false)
2023-04-23 01:09:27 +05:30
.frame(width: 35, height: 35)
} else {
Image(systemName: RecentsModel.symbolSystemImage(channel.name))
.imageScale(.large)
.foregroundColor(.accentColor)
.frame(width: 35, height: 35)
}
Text(channel.name)
.lineLimit(1)
2023-04-23 01:09:27 +05:30
}
.backport
2023-04-23 01:09:27 +05:30
.badge(showUnwatchedFeedBadges ? feedCount.unwatchedByChannelText(channel) : nil)
Group {
#if os(tvOS)
Button {
navigation.openChannel(channel, navigationStyle: .tab)
} label: {
label
}
#else
Button {
channelForLink = channel
channelLinkActive = channelForLink != nil
} label: {
2023-04-23 01:09:27 +05:30
label
.contentShape(Rectangle())
.foregroundColor(.primary)
2023-04-23 01:09:27 +05:30
}
.buttonStyle(.plain)
2023-04-23 01:09:27 +05:30
#endif
}
.contextMenu {
if subscriptions.isSubscribing(channel.id) {
toggleWatchedButton(channel)
}
Button {
subscriptions.unsubscribe(channel.id)
} label: {
Label("Unsubscribe", systemImage: "xmark.circle")
}
}
}
#if os(tvOS)
.padding(.horizontal, 50)
#endif
Color.clear.padding(.bottom, 50)
.listRowBackground(Color.clear)
.backport
.listRowSeparator(false)
}
}
2023-06-08 15:47:16 +05:30
#if !os(tvOS)
.background(
2023-05-29 20:01:01 +05:30
NavigationLink(destination: ChannelVideosView(channel: channelForLink ?? Video.fixture.channel), isActive: $channelLinkActive, label: EmptyView.init)
)
2023-06-08 15:47:16 +05:30
#endif
.onAppear {
subscriptions.load()
}
.onChange(of: accounts.current) { _ in
subscriptions.load(force: true)
}
#if os(iOS)
.refreshControl { refreshControl in
subscriptions.load(force: true) {
refreshControl.endRefreshing()
}
}
.backport
.refreshable {
2023-10-15 17:16:30 +05:30
await subscriptions.load(force: true)
}
#endif
#if !os(tvOS)
.background(
Button("Refresh") {
subscriptions.load(force: true)
}
.keyboardShortcut("r")
.opacity(0)
)
#endif
#if !os(macOS)
.onReceive(NotificationCenter.default.publisher(for: UIApplication.willEnterForegroundNotification)) { _ in
subscriptions.load()
}
#endif
#if os(tvOS)
.padding(.horizontal, 30)
#endif
}
var channels: [Channel] {
keepChannelsWithUnwatchedFeedOnTop ? subscriptions.allByUnwatchedCount : subscriptions.all
}
var header: some View {
HStack {
#if os(tvOS)
SubscriptionsPageButton()
#endif
2022-12-13 16:39:20 +05:30
if showCacheStatus {
Spacer()
2022-12-13 16:39:20 +05:30
CacheStatusHeader(
refreshTime: subscriptions.formattedCacheTime,
isLoading: subscriptions.isLoading
)
}
#if os(tvOS)
2022-12-13 16:39:20 +05:30
if !showCacheStatus {
Spacer()
}
Button {
subscriptions.load(force: true)
} label: {
Label("Refresh", systemImage: "arrow.clockwise")
.labelStyle(.iconOnly)
.imageScale(.small)
.font(.caption)
}
#endif
}
#if os(tvOS)
.padding(.bottom, 15)
.padding(.top, 15)
#endif
}
@ViewBuilder func toggleWatchedButton(_ channel: Channel) -> some View {
if feed.canMarkChannelAsWatched(channel.id) {
markChannelAsWatchedButton(channel)
} else {
markChannelAsUnwatchedButton(channel)
}
}
func markChannelAsWatchedButton(_ channel: Channel) -> some View {
Button {
feed.markChannelAsWatched(channel.id)
} label: {
Label("Mark channel feed as watched", systemImage: "checkmark.circle.fill")
}
.disabled(!feed.canMarkAllFeedAsWatched)
}
func markChannelAsUnwatchedButton(_ channel: Channel) -> some View {
Button {
feed.markChannelAsUnwatched(channel.id)
} label: {
Label("Mark channel feed as unwatched", systemImage: "checkmark.circle")
}
}
}
struct ChannelsView_Previews: PreviewProvider {
static var previews: some View {
NavigationView {
ChannelsView()
}
}
}