2017-09-12 19 views
0

私は自分のアプリでfirebase通知を作成します。そしてそれは成功した働きです。しかし、私は通知データが "Second"と等しい場合、私のアプリでSecondViewControllerを開いて開きたいと思います。どのようにできるのか?私はuserInfoを使用しますが、私はそれをしませんでした。Firebase Notification Swift 3 SecondViewController

Firebase Notification Special Data: { "view" : "Second" } 

これは私の完全なappdelegateコードです。ありがとうございました。私は自分の英語を残念に思っています。このコードを追加userNotificationCenter内部
のuserinfoから

import UIKit 
import Firebase 
import UserNotifications 

@UIApplicationMain 
class AppDelegate: UIResponder, UIApplicationDelegate { 

    var window: UIWindow? 
    static var shared: AppDelegate { return UIApplication.shared.delegate as! AppDelegate } 

    func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool { 
     FirebaseApp.configure() 
     application.registerForRemoteNotifications() 
     requestNotificationAuthorization(application: application) 
     if let userInfo = launchOptions?[UIApplicationLaunchOptionsKey.remoteNotification] as? NSDictionary { 

      NSLog("[RemoteNotification] applicationState: \(applicationStateString) didFinishLaunchingWithOptions for iOS9: \(userInfo)") 
      //TODO: Handle background notification 
     } 
     return true 
    } 

    var applicationStateString: String { 
     if UIApplication.shared.applicationState == .active { 
      return "active" 
     } else if UIApplication.shared.applicationState == .background { 
      return "background" 
     }else { 
      return "inactive" 
     } 
    } 

    func requestNotificationAuthorization(application: UIApplication) { 
     if #available(iOS 10.0, *) { 
      UNUserNotificationCenter.current().delegate = self 
      let authOptions: UNAuthorizationOptions = [.alert, .badge, .sound] 
      UNUserNotificationCenter.current().requestAuthorization(options: authOptions, completionHandler: {_, _ in }) 
     } else { 
      let settings: UIUserNotificationSettings = UIUserNotificationSettings(types: [.alert, .badge, .sound], categories: nil) 
      application.registerUserNotificationSettings(settings) 
     } 
    } 
} 

@available(iOS 10, *) 
extension AppDelegate : UNUserNotificationCenterDelegate { 
    // iOS10+, called when presenting notification in foreground 
    func userNotificationCenter(_ center: UNUserNotificationCenter, willPresent notification: UNNotification, withCompletionHandler completionHandler: @escaping (UNNotificationPresentationOptions) -> Void) { 
     let userInfo = notification.request.content.userInfo 
     NSLog("[UserNotificationCenter] applicationState: \(applicationStateString) willPresentNotification: \(userInfo)") 
     //TODO: Handle foreground notification 
     completionHandler([.alert]) 
    } 

    // iOS10+, called when received response (default open, dismiss or custom action) for a notification 
    func userNotificationCenter(_ center: UNUserNotificationCenter, didReceive response: UNNotificationResponse, withCompletionHandler completionHandler: @escaping() -> Void) { 
     let userInfo = response.notification.request.content.userInfo 
     NSLog("[UserNotificationCenter] applicationState: \(applicationStateString) didReceiveResponse: \(userInfo)") 
     //TODO: Handle background notification 
     completionHandler() 
    } 
} 

extension AppDelegate : MessagingDelegate { 
    func messaging(_ messaging: Messaging, didRefreshRegistrationToken fcmToken: String) { 
     NSLog("[RemoteNotification] didRefreshRegistrationToken: \(fcmToken)") 
    } 

    // iOS9, called when presenting notification in foreground 
    func application(_ application: UIApplication, didReceiveRemoteNotification userInfo: [AnyHashable : Any]) { 

     NSLog("[RemoteNotification] applicationState: \(applicationStateString) didReceiveRemoteNotification for iOS9: \(userInfo)") 
     if UIApplication.shared.applicationState == .active { 
      //TODO: Handle foreground notification 
     } else { 
      //TODO: Handle background notification 
     } 
    } 
} 
+0

あなただけ表示したい場合は...そう...それrootViewController作るあなたのナビゲーションコントローラでそれを押してください。ウィンドウのオブジェクトを直接使用することができます。 Othewriseはあなたの初期ビューコントローラのデータを使ってローカルNSNotificationを投稿します – Naresh

+0

ありがとうございました。サンプルコードを書くことができますか? –

+0

https://stackoverflow.com/questions/24049020/nsnotificationcenter-addobserver-in-swift および https://stackoverflow.com/questions/30956476/swift-instantiating-a-navigation-controller-without-storyboards-in -app-delegat – Naresh

答えて

0

通知データ...

let str:String = (userInfo["gcm.notification.imType"] as? String)! 

    switch str { 
    case "FIRST": 

     let rootViewController = self.window!.rootViewController as! UINavigationController 

      let storyboard = UIStoryboard(name: "Main", bundle: nil) 
      let firstViewController = storyboard.instantiateViewController(withIdentifier: "FIRSTID") as! MessagesTableViewController 

      rootViewController.pushViewController(firstViewController, animated: true) 

     case "SECOND": 

     let rootViewController = self.window!.rootViewController as! UINavigationController 

     let storyboard = UIStoryboard(name: "Main", bundle: nil) 
     let secondViewController = storyboard.instantiateViewController(withIdentifier: "SECONDID") as! SecondViewController 

     rootViewController.pushViewController(secondViewController, animated: true) 
default: 
    print("Type is something else") 

} 
関連する問題