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

163 lines
5.5 KiB
Swift
Raw Permalink Normal View History

2021-07-12 02:22:49 +05:30
import Defaults
import SwiftUI
struct AppTabNavigation: View {
2021-10-23 04:34:03 +05:30
@EnvironmentObject<AccountsModel> private var accounts
2021-09-25 13:48:22 +05:30
@EnvironmentObject<NavigationModel> private var navigation
2021-10-23 04:34:03 +05:30
@EnvironmentObject<PlayerModel> private var player
2021-09-25 17:47:58 +05:30
@EnvironmentObject<RecentsModel> private var recents
2021-10-23 04:34:03 +05:30
@EnvironmentObject<SearchModel> private var search
2021-09-19 16:36:54 +05:30
2021-11-08 02:21:22 +05:30
@Default(.tabNavigationSection) private var tabNavigationSection
2021-07-12 02:22:49 +05:30
var body: some View {
2021-09-29 04:31:49 +05:30
TabView(selection: navigation.tabSelectionBinding) {
2021-07-12 02:22:49 +05:30
NavigationView {
2021-11-02 03:26:18 +05:30
LazyView(FavoritesView())
2021-09-25 13:48:22 +05:30
.toolbar { toolbarContent }
2021-07-12 02:22:49 +05:30
}
.tabItem {
2021-11-02 03:26:18 +05:30
Label("Favorites", systemImage: "heart")
.accessibility(label: Text("Favorites"))
2021-07-12 02:22:49 +05:30
}
2021-11-02 03:26:18 +05:30
.tag(TabSelection.favorites)
2021-07-12 02:22:49 +05:30
2021-11-08 02:21:22 +05:30
if subscriptionsVisible {
2021-10-23 04:34:03 +05:30
NavigationView {
LazyView(SubscriptionsView())
.toolbar { toolbarContent }
}
.tabItem {
Label("Subscriptions", systemImage: "star.circle.fill")
.accessibility(label: Text("Subscriptions"))
}
.tag(TabSelection.subscriptions)
2021-07-12 02:22:49 +05:30
}
2021-09-19 02:06:42 +05:30
2021-11-08 02:21:22 +05:30
if subscriptionsVisible {
if accounts.app.supportsPopular {
if tabNavigationSection == .popular {
popularNavigationView
} else {
trendingNavigationView
}
2021-11-28 20:07:55 +05:30
} else {
trendingNavigationView
2021-10-23 04:34:03 +05:30
}
2021-11-08 02:21:22 +05:30
} else {
if accounts.app.supportsPopular {
popularNavigationView
2021-10-23 04:34:03 +05:30
}
2021-11-08 02:21:22 +05:30
trendingNavigationView
2021-07-12 02:22:49 +05:30
}
2021-10-23 04:34:03 +05:30
if accounts.app.supportsUserPlaylists {
NavigationView {
LazyView(PlaylistsView())
.toolbar { toolbarContent }
}
.tabItem {
Label("Playlists", systemImage: "list.and.film")
.accessibility(label: Text("Playlists"))
}
.tag(TabSelection.playlists)
2021-07-12 02:22:49 +05:30
}
NavigationView {
2021-11-28 20:07:55 +05:30
LazyView(SearchView())
2021-07-12 02:22:49 +05:30
}
.tabItem {
Label("Search", systemImage: "magnifyingglass")
.accessibility(label: Text("Search"))
}
.tag(TabSelection.search)
}
2021-12-01 04:28:46 +05:30
.id(accounts.current?.id ?? "")
2021-09-19 18:12:47 +05:30
.environment(\.navigationStyle, .tab)
2021-12-01 04:28:46 +05:30
.background(
EmptyView().sheet(isPresented: $navigation.presentingChannel, onDismiss: {
if let channel = recents.presentedChannel {
recents.close(RecentItem(from: channel))
}
}) {
if let channel = recents.presentedChannel {
NavigationView {
ChannelVideosView(channel: channel)
.environment(\.inChannelView, true)
.environment(\.inNavigationView, true)
.background(playerNavigationLink)
}
2021-10-23 04:34:03 +05:30
}
}
2021-12-01 04:28:46 +05:30
)
.background(
EmptyView().sheet(isPresented: $navigation.presentingPlaylist, onDismiss: {
if let playlist = recents.presentedPlaylist {
recents.close(RecentItem(from: playlist))
}
}) {
if let playlist = recents.presentedPlaylist {
NavigationView {
ChannelPlaylistView(playlist: playlist)
.environment(\.inNavigationView, true)
.background(playerNavigationLink)
}
}
}
2021-12-01 04:28:46 +05:30
)
}
2021-09-25 13:48:22 +05:30
2021-11-08 02:21:22 +05:30
private var subscriptionsVisible: Bool {
accounts.app.supportsSubscriptions && !(accounts.current?.anonymous ?? true)
}
private var popularNavigationView: some View {
NavigationView {
LazyView(PopularView())
.toolbar { toolbarContent }
}
.tabItem {
2021-11-28 20:07:55 +05:30
Label("Popular", systemImage: "arrow.up.right.circle")
2021-11-08 02:21:22 +05:30
.accessibility(label: Text("Popular"))
}
.tag(TabSelection.popular)
}
private var trendingNavigationView: some View {
NavigationView {
LazyView(TrendingView())
.toolbar { toolbarContent }
}
.tabItem {
2021-11-28 20:07:55 +05:30
Label("Trending", systemImage: "chart.bar")
2021-11-08 02:21:22 +05:30
.accessibility(label: Text("Trending"))
}
.tag(TabSelection.trending)
}
2021-10-23 04:34:03 +05:30
private var playerNavigationLink: some View {
NavigationLink(isActive: $player.playerNavigationLinkActive, destination: {
VideoPlayerView()
.environment(\.inNavigationView, true)
}) {
EmptyView()
}
}
2021-09-25 13:48:22 +05:30
var toolbarContent: some ToolbarContent {
#if os(iOS)
Group {
ToolbarItemGroup(placement: .navigationBarLeading) {
Button(action: { navigation.presentingSettings = true }) {
Image(systemName: "gearshape.2")
}
}
ToolbarItemGroup(placement: .navigationBarTrailing) {
AccountsMenuView()
}
}
#endif
}
2021-07-12 02:22:49 +05:30
}