Показать детальный вид контроллера после поиска прожектора - PullRequest
0 голосов
/ 04 марта 2019

В недавнем проекте я реализовал поиск в центре внимания, и все работает отлично (я использовал UINavigationController).Теперь я перерабатываю поиск в центре внимания для другого проекта, который не содержит UINavigationController, а только два UIViewController.Также в этом случае все работает нормально, кроме перенаправления на контроллер подробного просмотра, когда конкретный элемент нажимается в поиске прожектора.Я обнаружил, что проблема в этом методе, и это потому, что я не использую UINavigationController.Итак, мой вопрос, как я могу изменить этот код для работы только с двумя моими UIViewController?

func application(_ application: UIApplication, continue userActivity: NSUserActivity, restorationHandler: @escaping ([Any]?) -> Swift.Void) -> Bool {

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

    if let actID = userActivity.userInfo!["kCSSearchableItemActivityIdentifier"] as? String {
        let ricette = DataManager.shared.arra.filter { $0.id.uuidString == actID }
        if let ricetta = ricette.first {
            debugPrint("Abbiamo la ricetta grazie all'ID")

            if let listController = navController.topViewController as? ListController {

                if let posizione = DataManager.shared.arra.index(of: ricetta) {
                    listController.showDetailFromSpotlightSearch(posizione)
                }

            } else if let ricettaController = navController.visibleViewController as? RicettaController {
                ricettaController.ricetta = ricetta
                ricettaController.aggiornaInterfaccia()
            }

        } else { debugPrint("errore ID") }
    } else { debugPrint("errore ID") }

    return true
}

1 Ответ

0 голосов
/ 01 апреля 2019

Вы должны использовать это два расширения для определения topViewController и visibleViewController:

extension UIApplication {
class func getVisibleViewController(_ rootViewController: UIViewController? = UIApplication.shared.keyWindow?.rootViewController) -> UIViewController? {
    if let presentedViewController = rootViewController?.presentedViewController {
        return getVisibleViewController(presentedViewController)
    }

    return rootViewController
}}

extension UIApplication {
class func topViewController(controller: UIViewController? = UIApplication.shared.keyWindow?.rootViewController) -> UIViewController? {
    if let presented = controller?.presentedViewController {
        return topViewController(controller: presented)
    }
    return controller
}}
...