blob: 5d6cb8c611f9d4296739bb83496f21bbb1ab65d0 [file] [log] [blame]
// Copyright 2019 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef IOS_CHROME_APP_INTENTS_OPENINCHROMEINTENT_H_
#define IOS_CHROME_APP_INTENTS_OPENINCHROMEINTENT_H_
//
// OpenInChromeIntent.h
//
// This file was automatically generated and should not be edited.
//
#if __has_include(<Intents/Intents.h>)
#import <Intents/Intents.h>
NS_ASSUME_NONNULL_BEGIN
API_AVAILABLE(ios(12.0), watchos(5.0))
API_UNAVAILABLE(macos, tvos) @interface OpenInChromeIntent : INIntent
@property(readwrite, copy, nullable, nonatomic) NSURL* url;
@end
@class OpenInChromeIntentResponse;
/*!
@abstract Protocol to declare support for handling a OpenInChromeIntent. By
implementing this protocol, a class can provide logic for resolving, confirming
and handling the intent.
@discussion The minimum requirement for an implementing class is that it should
be able to handle the intent. The confirmation method is optional. The handling
method is always called last, after confirming the intent.
*/
API_AVAILABLE(ios(12.0), watchos(5.0))
API_UNAVAILABLE(macos, tvos) @protocol OpenInChromeIntentHandling<NSObject>
@required
/*!
@abstract Handling method - Execute the task represented by the
OpenInChromeIntent that's passed in
@discussion Called to actually execute the intent. The app must return a
response for this intent.
@param intent The input intent
@param completion The response handling block takes a
OpenInChromeIntentResponse containing the details of the result of having
executed the intent
@see OpenInChromeIntentResponse
*/
- (void)handleOpenInChrome:(OpenInChromeIntent*)intent
completion:
(void (^)(OpenInChromeIntentResponse* response))completion
NS_SWIFT_NAME(handle(intent:completion:));
/*!
@abstract Resolution methods - Determine if this intent is ready for the next
step (confirmation)
@discussion Called to make sure the app extension is capable of handling this
intent in its current form. This method is for validating if the intent needs
any further fleshing out.
@param intent The input intent
@param completion The response block contains an INIntentResolutionResult for
the parameter being resolved
@see INIntentResolutionResult
*/
- (void)resolveUrlForOpenInChrome:(OpenInChromeIntent *)intent
withCompletion:(void (^)(INURLResolutionResult *resolutionResult))completion
NS_SWIFT_NAME(resolveUrl(for:with:)) API_AVAILABLE(ios(13.0), watchos(6.0));
@optional
/*!
@abstract Confirmation method - Validate that this intent is ready for the next
step (i.e. handling)
@discussion Called prior to asking the app to handle the intent. The app should
return a response object that contains additional information about the intent,
which may be relevant for the system to show the user prior to handling. If
unimplemented, the system will assume the intent is valid, and will assume
there is no additional information relevant to this intent.
@param intent The input intent
@param completion The response block contains a OpenInChromeIntentResponse
containing additional details about the intent that may be relevant for the
system to show the user prior to handling.
@see OpenInChromeIntentResponse
*/
- (void)confirmOpenInChrome:(OpenInChromeIntent*)intent
completion:
(void (^)(OpenInChromeIntentResponse* response))completion
NS_SWIFT_NAME(confirm(intent:completion:));
@end
/*!
@abstract Constants indicating the state of the response.
*/
typedef NS_ENUM(NSInteger, OpenInChromeIntentResponseCode) {
OpenInChromeIntentResponseCodeUnspecified = 0,
OpenInChromeIntentResponseCodeReady,
OpenInChromeIntentResponseCodeContinueInApp,
OpenInChromeIntentResponseCodeInProgress,
OpenInChromeIntentResponseCodeSuccess,
OpenInChromeIntentResponseCodeFailure,
OpenInChromeIntentResponseCodeFailureRequiringAppLaunch
} API_AVAILABLE(ios(12.0), watchos(5.0)) API_UNAVAILABLE(macos, tvos);
API_AVAILABLE(ios(12.0), watchos(5.0))
API_UNAVAILABLE(macos, tvos)
@interface OpenInChromeIntentResponse : INIntentResponse
- (instancetype)init NS_UNAVAILABLE;
/*!
@abstract Initializes the response object with the specified code and user
activity object.
@discussion The app extension has the option of capturing its private state as
an NSUserActivity and returning it as the 'currentActivity'. If the app is
launched, an NSUserActivity will be passed in with the private state. The
NSUserActivity may also be used to query the app's UI extension (if provided)
for a view controller representing the current intent handling state. In the
case of app launch, the NSUserActivity will have its activityType set to the
name of the intent. This intent object will also be available in the
NSUserActivity.interaction property.
@param code The response code indicating your success or failure in confirming
or handling the intent.
@param userActivity The user activity object to use when launching your app.
Provide an object if you want to add information that is specific to your app.
If you specify nil, the system automatically creates a user activity object for
you, sets its type to the class name of the intent being handled, and fills it
with an INInteraction object containing the intent and your response.
*/
- (instancetype)initWithCode:(OpenInChromeIntentResponseCode)code
userActivity:(nullable NSUserActivity*)userActivity
NS_DESIGNATED_INITIALIZER;
/*!
@abstract The response code indicating your success or failure in confirming or
handling the intent.
*/
@property(readonly, NS_NONATOMIC_IOSONLY) OpenInChromeIntentResponseCode code;
@end
NS_ASSUME_NONNULL_END
#endif
#endif // IOS_CHROME_APP_INTENTS_OPENINCHROMEINTENT_H_