Remove comments, and move post-request actions to the main queue

This commit is contained in:
Angelo Stavrow 2020-08-01 13:09:33 -04:00
parent 42cfe2380a
commit 619ddc6ea2
No known key found for this signature in database
GPG Key ID: 1A49C7064E060EEE
1 changed files with 7 additions and 17 deletions

View File

@ -57,36 +57,26 @@ final class WebFeedInspectorViewController: NSViewController, Inspector {
// MARK: Actions
@IBAction func isNotifyAboutNewArticlesChanged(_ sender: Any) {
guard let settings = userNotificationSettings else {
// Something went wront fetching the user notification settings,
// so toggle the checkbox back to its original state and return.
isNotifyAboutNewArticlesCheckBox.setNextState()
return
}
if settings.authorizationStatus == .denied {
// Notifications are not authorized, so toggle the checkbox back
// to its original state...
isNotifyAboutNewArticlesCheckBox.setNextState()
// ...then alert the user to the issue...
showNotificationsDeniedError()
} else if settings.authorizationStatus == .authorized {
// Notifications are authorized, so set the feed's isNotifyAboutNewArticles
// property to match the state of isNotifyAboutNewArticlesCheckbox.
feed?.isNotifyAboutNewArticles = (isNotifyAboutNewArticlesCheckBox?.state ?? .off) == .on ? true : false
} else {
// We're not sure what the status may be but we've /probably/ not requested
// permission to send notifications, so do that:
UNUserNotificationCenter.current().requestAuthorization(options: [.badge, .sound, .alert]) { (granted, error) in
self.updateNotificationSettings()
if granted {
// We've been given permission, so set the feed's isNotifyAboutNewArticles
// property to match the state of isNotifyAboutNewArticlesCheckbox and then
// register for remote notifications.
self.feed?.isNotifyAboutNewArticles = (self.isNotifyAboutNewArticlesCheckBox?.state ?? .off) == .on ? true : false
NSApplication.shared.registerForRemoteNotifications()
DispatchQueue.main.async {
self.feed?.isNotifyAboutNewArticles = (self.isNotifyAboutNewArticlesCheckBox?.state ?? .off) == .on ? true : false
NSApplication.shared.registerForRemoteNotifications()
}
} else {
// We weren't given permission, so toggle the checkbox back to its
// original state.
self.isNotifyAboutNewArticlesCheckBox.setNextState()
DispatchQueue.main.async {
self.isNotifyAboutNewArticlesCheckBox.setNextState()
}
}
}
}