mirror of
https://github.com/Dimillian/IceCubesApp.git
synced 2024-12-26 06:54:32 +01:00
1bf4d9e398
* - *WIP* Explore tab: Tap on tab to scroll to top. * - Explore tab: Tap tab to scroll to top. * - Explore: Tap tab again to focus on search bar. - Explore: Set `.defaultMinListRowHeight` so scroll to view doesn't occupy more than 1pt height in grouped style list. - Explore: Add padding to get Explore list view to look the same. * - Explore: Minor adjust to padding. * - Messages: Add tap tab to scroll to top. * - Notifications: Add tap tab to scroll to top. * - Profile: Add tap tab to scroll to top. * Add `ScrollToView` that can be used across all views. * Move scroll-to-top constants to ScrollToView. * Format --------- Co-authored-by: Thomas Ricouard <ricouard77@gmail.com>
105 lines
3.4 KiB
Swift
105 lines
3.4 KiB
Swift
import AppAccount
|
|
import DesignSystem
|
|
import Env
|
|
import Models
|
|
import Network
|
|
import Notifications
|
|
import SwiftUI
|
|
import Timeline
|
|
|
|
@MainActor
|
|
struct NotificationsTab: View {
|
|
@Environment(\.isSecondaryColumn) private var isSecondaryColumn: Bool
|
|
@Environment(\.scenePhase) private var scenePhase
|
|
|
|
@Environment(Theme.self) private var theme
|
|
@Environment(Client.self) private var client
|
|
@Environment(StreamWatcher.self) private var watcher
|
|
@Environment(AppAccountsManager.self) private var appAccount
|
|
@Environment(CurrentAccount.self) private var currentAccount
|
|
@Environment(UserPreferences.self) private var userPreferences
|
|
@Environment(PushNotificationsService.self) private var pushNotificationsService
|
|
@State private var routerPath = RouterPath()
|
|
@State private var scrollToTopSignal: Int = 0
|
|
@Binding var popToRootTab: Tab
|
|
|
|
let lockedType: Models.Notification.NotificationType?
|
|
|
|
var body: some View {
|
|
NavigationStack(path: $routerPath.path) {
|
|
NotificationsListView(lockedType: lockedType, scrollToTopSignal: $scrollToTopSignal)
|
|
.withAppRouter()
|
|
.withSheetDestinations(sheetDestinations: $routerPath.presentedSheet)
|
|
.toolbar {
|
|
if !isSecondaryColumn {
|
|
statusEditorToolbarItem(routerPath: routerPath,
|
|
visibility: userPreferences.postVisibility)
|
|
if UIDevice.current.userInterfaceIdiom != .pad {
|
|
ToolbarItem(placement: .navigationBarLeading) {
|
|
AppAccountsSelectorView(routerPath: routerPath)
|
|
}
|
|
}
|
|
}
|
|
if UIDevice.current.userInterfaceIdiom == .pad {
|
|
if (!isSecondaryColumn && !userPreferences.showiPadSecondaryColumn) || isSecondaryColumn {
|
|
SecondaryColumnToolbarItem()
|
|
}
|
|
}
|
|
}
|
|
.toolbarBackground(theme.primaryBackgroundColor.opacity(0.50), for: .navigationBar)
|
|
.id(client.id)
|
|
}
|
|
.onAppear {
|
|
routerPath.client = client
|
|
if isSecondaryColumn {
|
|
clearNotifications()
|
|
}
|
|
}
|
|
.withSafariRouter()
|
|
.environment(routerPath)
|
|
.onChange(of: $popToRootTab.wrappedValue) { _, newValue in
|
|
if newValue == .notifications {
|
|
if routerPath.path.isEmpty {
|
|
scrollToTopSignal += 1
|
|
} else {
|
|
routerPath.path = []
|
|
}
|
|
}
|
|
}
|
|
.onChange(of: pushNotificationsService.handledNotification) { _, newValue in
|
|
if let newValue, let type = newValue.notification.supportedType {
|
|
DispatchQueue.main.asyncAfter(deadline: .now() + 0.3) {
|
|
switch type {
|
|
case .follow, .follow_request:
|
|
routerPath.navigate(to: .accountDetailWithAccount(account: newValue.notification.account))
|
|
default:
|
|
if let status = newValue.notification.status {
|
|
routerPath.navigate(to: .statusDetailWithStatus(status: status))
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
.onChange(of: scenePhase) { _, newValue in
|
|
switch newValue {
|
|
case .active:
|
|
clearNotifications()
|
|
default:
|
|
break
|
|
}
|
|
}
|
|
.onChange(of: client.id) {
|
|
routerPath.path = []
|
|
}
|
|
}
|
|
|
|
private func clearNotifications() {
|
|
if isSecondaryColumn {
|
|
if let token = appAccount.currentAccount.oauthToken {
|
|
userPreferences.notificationsCount[token] = 0
|
|
}
|
|
watcher.unreadNotificationsCount = 0
|
|
}
|
|
}
|
|
}
|