IntentHandler class:
import Intents
class IntentHandler: INExtension, INStartWorkoutIntentHandling {
public func handle(startWorkout intent: INStartWorkoutIntent, completion: @escaping (INStartWorkoutIntentResponse) -> Void) {
let userActivity = NSUserActivity(activityType: NSStringFromClass(INStartWorkoutIntent.self))
let response = INStartWorkoutIntentResponse(code: .continueInApp, userActivity: userActivity)
completion(response)
}
//MARK: - INStartWorkoutIntentHandling
func confirm(startWorkout intent: INStartWorkoutIntent, completion: @escaping (INStartWorkoutIntentResponse) -> Void) {
completion(INStartWorkoutIntentResponse(code: .continueInApp, userActivity: nil))
}
}
Apple documentation says:
Siri opens the app, but I need to display UI from IntentUI. How to do this?
In other words: How to prepare to display response, load intents UI extension, prepare interface and display it in code?
IntentViewController class:
import IntentsUI
class IntentViewController: UIViewController, INUIHostedViewControlling {
//MARK: - INUIHostedViewControlling
func configure(with interaction: INInteraction!, context: INUIHostedViewContext, completion: ((CGSize) -> Void)!) {
if let completion = completion {
completion(self.desiredSize)
}
}
var desiredSize: CGSize {
return self.extensionContext!.hostedViewMaximumAllowedSize
}
}
Base on this tutorial it is possible indeed.
Although Apple says here:
I think it is quite impossible, because response responsible for open UI is not prepared for this:
Please look at
INSendMessageIntentResponseCode
forINSentMessageIntentHandling
:and
INStartWorkoutIntentResponse
forINStartWorkoutIntentHandling
:For the second one, there is only
.continueInApp
, and this is exactly what happens here, opposite to the first one where exists:.success
and.inProgress