1

im not getting anything on userActivity.title , it turns nil at appdelegate. check below, this used to work in ios9 , that i can remember. i need to get the Title set in attributeSet.title , but it is always nil.

Code to index my item

    let attributeSet = CSSearchableItemAttributeSet(itemContentType: kUTTypeText as String)
    attributeSet.title = "ALFRESCO" //restnombre //project[0]
    attributeSet.contentDescription = "\(tipocomida)"

    let item = CSSearchableItem(uniqueIdentifier: "\(restid)", domainIdentifier: "com.cgcompany.restaurants", attributeSet: attributeSet)
    CSSearchableIndex.default().indexSearchableItems([item]) { (error: Error?) -> Void in
        if let error = error {
            print("Indexing error: \(error.localizedDescription)")
        } else {
            print("Search item successfully indexed!")
        }
    }

Code in app delegate

 func application(_ application: UIApplication, continue userActivity: NSUserActivity, restorationHandler: @escaping ([Any]?) -> Void) -> Bool {
      //  if #available(iOS 9.0, *) {

            print("CALLING CONTINUE USER ACT")

        if userActivity.activityType == CSSearchableItemActionType {
                print("ACT TYPE IS CSSEARCHABLEITEM")

      var title = "NOTITLE"
            if (userActivity.title) != nil {
                title = userActivity.title!
            }


                if let uniqueIdentifier = userActivity.userInfo?[CSSearchableItemActivityIdentifier] as? String {
                 print ("Calling FROM SPOTLIGHTSEARCH")


                    let rootViewController = self.window!.rootViewController as! UINavigationController
                    let mainStoryboard: UIStoryboard = UIStoryboard(name: "Main", bundle: nil)

                    let restaurantdetail = mainStoryboard.instantiateViewController(withIdentifier: "restaurant_detail2") as! VCviendorest
                    let detailurl = "http://www.urltoget.com/iphone/\(uniqueIdentifier)/fromiOSSearch.html"

                    restaurantdetail.IDREST = uniqueIdentifier
                    restaurantdetail.NOMBRERESTAURANT = "\(title)" //userActivity.title!

                    restaurantdetail.DETAILURL = detailurl
                    rootViewController.pushViewController(restaurantdetail, animated: true)

                }
            }
     //   } else {
            // Fallback on earlier versions
       // }

        return true
    }
lorenzo gonzalez
  • 1,894
  • 4
  • 14
  • 18

1 Answers1

2

I had the same problem as yours when my app run on iOS 10 device (on XCode 7.1), after couple tests, I need to combine the NSUserActivity with CSSearchableItemAttributeSet, and stop using CSSearchableItem and indexSearchableItems method of CSSearchableIndex. Here's the code:

// Config the attributeSet
let attributeSet = CSSearchableItemAttributeSet(itemContentType: kUTTypeText as String)
attributeSet.title = "ALFRESCO" //restnombre //project[0]
attributeSet.contentDescription = "\(tipocomida)"
attributeSet.identifier = "\(restid)"

if #available(iOS 10, *) {
    // Init user activity combining with the attribute set
    let bundleId = NSBundle.mainBundle().bundleIdentifier ?? ""
    let activity = NSUserActivity(activityType: "\(bundleId).spotlight")
    activity.userInfo = [CSSearchableItemActivityIdentifier: attributeSet.identifier!]
    activity.title = attributeSet.title
    activity.eligibleForHandoff = false
    activity.eligibleForSearch = true
    activity.eligibleForPublicIndexing = true
    activity.contentAttributeSet = attributeSet
    activity.becomeCurrent()
} else {
    // continue using CSSearchableItem with your old code
    // let item = CSSearchableItem(...
}

On your app delegate, you need to update the check to:

let activityType = (NSBundle.mainBundle().bundleIdentifier ?? "") + ".spotlight"
if userActivity.activityType == CSSearchableItemActionType || userActivity.activityType == activityType {
    // here for your code
}
bubuxu
  • 2,187
  • 18
  • 23