SwiftUI Views monitor notifs via .task & for await

This commit is contained in:
Stuart Breckenridge
2023-03-11 19:01:17 +08:00
parent 9f4332f74f
commit 15db283ec1
5 changed files with 38 additions and 26 deletions

View File

@@ -50,8 +50,10 @@ struct AddExtensionListView: View {
}
}
}
.onReceive(NotificationCenter.default.publisher(for: .ActiveExtensionPointsDidChange)) { _ in
dismiss()
.task {
for await _ in NotificationCenter.default.notifications(named: .ActiveExtensionPointsDidChange) {
await MainActor.run(body: { dismiss() })
}
}
}

View File

@@ -32,8 +32,10 @@ struct EnableExtensionPointView: View {
.navigationTitle(extensionPoint.title)
.navigationBarTitleDisplayMode(.inline)
.dismissOnExternalContextLaunch()
.onReceive(NotificationCenter.default.publisher(for: .ActiveExtensionPointsDidChange)) { _ in
dismiss()
.task {
for await _ in NotificationCenter.default.notifications(named: .ActiveExtensionPointsDidChange) {
await MainActor.run { dismiss() }
}
}
.edgesIgnoringSafeArea(.bottom)
}

View File

@@ -51,8 +51,10 @@ struct ExtensionsManagementView: View {
} message: {
Text("This action cannot be undone.", comment: "Alert message: confirmation that deactivation of extension cannot be undone.")
}
.onReceive(NotificationCenter.default.publisher(for: .ActiveExtensionPointsDidChange)) { _ in
availableExtensionPointTypes = ExtensionPointManager.shared.availableExtensionPointTypes.sorted(by: { $0.title < $1.title })
.task {
for await _ in NotificationCenter.default.notifications(named: .ActiveExtensionPointsDidChange) {
await MainActor.run { availableExtensionPointTypes = ExtensionPointManager.shared.availableExtensionPointTypes.sorted(by: { $0.title < $1.title }) }
}
}
}

View File

@@ -101,15 +101,13 @@ struct SettingsView: View {
}
.task {
UNUserNotificationCenter.current().getNotificationSettings { settings in
DispatchQueue.main.async {
self.viewModel.notificationPermissions = settings.authorizationStatus
}
Task { await MainActor.run { self.viewModel.notificationPermissions = settings.authorizationStatus }}
}
}
.onReceive(NotificationCenter.default.publisher(for: UIScene.willEnterForegroundNotification)) { _ in
UNUserNotificationCenter.current().getNotificationSettings { settings in
DispatchQueue.main.async {
self.viewModel.notificationPermissions = settings.authorizationStatus
.task {
for await _ in NotificationCenter.default.notifications(named: UIScene.willEnterForegroundNotification) {
UNUserNotificationCenter.current().getNotificationSettings { settings in
Task { await MainActor.run { self.viewModel.notificationPermissions = settings.authorizationStatus }}
}
}
}

View File

@@ -28,24 +28,32 @@ struct NewArticleNotificationsView: View, Logging {
}
.tint(Color(uiColor: AppAssets.primaryAccentColor))
.onReceive(NotificationCenter.default.publisher(for: .FaviconDidBecomeAvailable)) { notification in
guard let faviconURLString = notification.userInfo?["faviconURL"] as? String,
let faviconHost = URL(string: faviconURLString)?.host else {
return
}
activeAccounts.forEach { account in
for feed in Array(account.flattenedWebFeeds()) {
if let feedURLHost = URL(string: feed.url)?.host {
if faviconHost == feedURLHost {
feed.objectWillChange.send()
.task {
for await notification in NotificationCenter.default.notifications(named: .FaviconDidBecomeAvailable) {
await MainActor.run {
guard let faviconURLString = notification.userInfo?["faviconURL"] as? String,
let faviconHost = URL(string: faviconURLString)?.host else {
return
}
activeAccounts.forEach { account in
for feed in Array(account.flattenedWebFeeds()) {
if let feedURLHost = URL(string: feed.url)?.host {
if faviconHost == feedURLHost {
feed.objectWillChange.send()
}
}
}
}
}
}
}
.onReceive(NotificationCenter.default.publisher(for: .WebFeedIconDidBecomeAvailable)) { notification in
guard let webFeed = notification.userInfo?[UserInfoKey.webFeed] as? WebFeed else { return }
webFeed.objectWillChange.send()
.task {
for await notification in NotificationCenter.default.notifications(named: .WebFeedIconDidBecomeAvailable) {
await MainActor.run {
guard let webFeed = notification.userInfo?[UserInfoKey.webFeed] as? WebFeed else { return }
webFeed.objectWillChange.send()
}
}
}
}