Открытие настроек уведомлений приложения в приложении настроек

В случае, если пользователь может случайно отказаться от получения уведомлений и хочет включить уведомления позже, как я могу использовать NSURL, чтобы открыть приложение настроек IOS на странице уведомлений моего приложения, где они могут выбрать Разрешить уведомления?

6 ответов

Я обнаружил, что ответ на этот вопрос (хотя и полезный) слишком логичен. Вот простая и простая реализация Swift 5, если кто-то еще наткнется на этот вопрос:

if let bundleIdentifier = Bundle.main.bundleIdentifier, let appSettings = URL(string: UIApplication.openSettingsURLString + bundleIdentifier) {
    if UIApplication.shared.canOpenURL(appSettings) {
        UIApplication.shared.open(appSettings)
    }
}

Для Swift 3 используйте UIApplicationOpenSettingsURLString перейти к настройкам для вашего приложения, где оно показывает статус уведомлений и "Сотовые данные"

let settingsButton = NSLocalizedString("Settings", comment: "")
let cancelButton = NSLocalizedString("Cancel", comment: "")
let message = NSLocalizedString("Your need to give a permission from notification settings.", comment: "")
let goToSettingsAlert = UIAlertController(title: "", message: message, preferredStyle: UIAlertControllerStyle.alert)

goToSettingsAlert.addAction(UIAlertAction(title: settingsButton, style: .destructive, handler: { (action: UIAlertAction) in
    DispatchQueue.main.async {
        guard let settingsUrl = URL(string: UIApplicationOpenSettingsURLString) else {
            return
        }

        if UIApplication.shared.canOpenURL(settingsUrl) {
            if #available(iOS 10.0, *) {
                UIApplication.shared.open(settingsUrl, completionHandler: { (success) in
                    print("Settings opened: \(success)") // Prints true
                })
            } else {
                UIApplication.shared.openURL(settingsUrl as URL)
            } 
        }
    }
}))

logoutUserAlert.addAction(UIAlertAction(title: cancelButton, style: .cancel, handler: nil))

Swift 5:

      if let url = URL(string: UIApplication.openSettingsURLString) {
    UIApplication.shared.open(url)
}

Это должно обеспечить вас для всех версий iOS, включая iOS 15 и iOS 16.

      extension UIApplication {
  private static let notificationSettingsURLString: String? = {
    if #available(iOS 16, *) {
      return UIApplication.openNotificationSettingsURLString
    }

    if #available(iOS 15.4, *) {
      return UIApplicationOpenNotificationSettingsURLString
    }

    if #available(iOS 8.0, *) {
      // just opens settings
      return UIApplication.openSettingsURLString
    }

    // lol bruh
    return nil
  }()

  private static let appNotificationSettingsURL = URL(
    string: notificationSettingsURLString ?? ""
  )

  func openAppNotificationSettings() -> Bool {
    guard
      let url = UIApplication.appNotificationSettingsURL,
      self.canOpen(url) else { return false }
    return self.open(url)
  }
}

Использование:

      Button {
  let opened = UIApplication.shared.openAppNotificationSettings()
  if !opened {
    print("lol fail")
  }
} label: {
  Text("Notifications")
}

Начиная с iOS 15.4 мы можем напрямую ссылаться на экран настроек уведомлений, используяUIApplicationOpenNotificationSettingsURLString:

https://developer.apple.com/documentation/uikit/uiapplicationopennotificationsettingsurlstring?language=objc

Чтобы открыть уведомления часть настроек используйте эту

UIApplication.shared.open(URL(string:"App-Prefs:root=NOTIFICATIONS_ID")!, options: [:], completionHandler: nil)
Другие вопросы по тегам