2015-03-25 20:09:04 -07:00
/ * *
* Copyright ( c ) 2015 - present , Facebook , Inc .
* All rights reserved .
*
* This source code is licensed under the BSD - style license found in the
* LICENSE file in the root directory of this source tree . An additional grant
* of patent rights can be found in the PATENTS file in the same directory .
*
* @ providesModule LinkingIOS
* @ flow
* /
'use strict' ;
2016-01-26 14:34:00 -08:00
var Linking = require ( 'Linking' ) ;
2015-03-25 20:09:04 -07:00
var RCTLinkingManager = require ( 'NativeModules' ) . LinkingManager ;
2016-03-02 04:27:13 -08:00
var invariant = require ( 'fbjs/lib/invariant' ) ;
2015-03-25 20:09:04 -07:00
2016-02-02 09:24:30 -08:00
var _initialURL = RCTLinkingManager && RCTLinkingManager . initialURL ;
2015-03-25 20:09:04 -07:00
2015-03-30 20:12:32 -07:00
/ * *
2016-01-26 14:34:00 -08:00
* NOTE : ` LinkingIOS ` is being deprecated . Use ` Linking ` instead .
*
2015-11-12 12:35:44 -08:00
* ` LinkingIOS ` gives you a general interface to interact with both incoming
2015-03-30 20:12:32 -07:00
* and outgoing app links .
*
* # # # Basic Usage
*
* # # # # Handling deep links
*
2015-09-01 08:21:35 -07:00
* If your app was launched from an external url registered to your app you can
2015-03-30 20:12:32 -07:00
* access and handle it from any component you want with
*
* ` ` `
* componentDidMount ( ) {
* var url = LinkingIOS . popInitialURL ( ) ;
* }
* ` ` `
*
* In case you also want to listen to incoming app links during your app ' s
* execution you ' ll need to add the following lines to you ` *AppDelegate.m ` :
*
* ` ` `
2015-12-04 08:05:11 -08:00
* - ( BOOL ) application : ( UIApplication * ) application openURL : ( NSURL * ) url
* sourceApplication : ( NSString * ) sourceApplication annotation : ( id ) annotation
* {
* return [ RCTLinkingManager application : application openURL : url
* sourceApplication : sourceApplication annotation : annotation ] ;
2015-03-30 20:12:32 -07:00
* }
2015-12-04 08:05:11 -08:00
*
* // Only if your app is using [Universal Links](https://developer.apple.com/library/prerelease/ios/documentation/General/Conceptual/AppSearch/UniversalLinks.html).
* - ( BOOL ) application : ( UIApplication * ) application continueUserActivity : ( NSUserActivity * ) userActivity
* restorationHandler : ( void ( ^ ) ( NSArray * _Nullable ) ) restorationHandler
* {
* return [ RCTLinkingManager application : application
* continueUserActivity : userActivity
* restorationHandler : restorationHandler ] ;
* }
*
2015-03-30 20:12:32 -07:00
* ` ` `
*
* And then on your React component you ' ll be able to listen to the events on
* ` LinkingIOS ` as follows
*
* ` ` `
* componentDidMount ( ) {
* LinkingIOS . addEventListener ( 'url' , this . _handleOpenURL ) ;
* } ,
* componentWillUnmount ( ) {
* LinkingIOS . removeEventListener ( 'url' , this . _handleOpenURL ) ;
* } ,
* _handleOpenURL ( event ) {
* console . log ( event . url ) ;
* }
* ` ` `
*
* # # # # Triggering App links
*
2015-11-12 12:35:44 -08:00
* To trigger an app link ( browser , email or custom schemas ) , call
2015-03-30 20:12:32 -07:00
*
* ` ` `
* LinkingIOS . openURL ( url )
* ` ` `
*
2015-12-04 08:05:11 -08:00
* If you want to check if any installed app can handle a given URL beforehand , call
2015-03-30 20:12:32 -07:00
* ` ` `
* LinkingIOS . canOpenURL ( url , ( supported ) => {
* if ( ! supported ) {
* AlertIOS . alert ( 'Can\'t handle url: ' + url ) ;
* } else {
* LinkingIOS . openURL ( url ) ;
* }
* } ) ;
* ` ` `
* /
2015-03-25 20:09:04 -07:00
class LinkingIOS {
2015-03-30 20:12:32 -07:00
/ * *
* Add a handler to LinkingIOS changes by listening to the ` url ` event type
* and providing the handler
2016-01-26 14:34:00 -08:00
*
* @ deprecated
2015-03-30 20:12:32 -07:00
* /
static addEventListener ( type : string , handler : Function ) {
2016-01-26 14:34:00 -08:00
console . warn ( '"LinkingIOS.addEventListener" is deprecated. Use "Linking.addEventListener" instead.' ) ;
Linking . addEventListener ( type , handler ) ;
2015-03-25 20:09:04 -07:00
}
2015-03-30 20:12:32 -07:00
/ * *
* Remove a handler by passing the ` url ` event type and the handler
2016-01-26 14:34:00 -08:00
*
* @ deprecated
2015-03-30 20:12:32 -07:00
* /
static removeEventListener ( type : string , handler : Function ) {
2016-01-26 14:34:00 -08:00
console . warn ( '"LinkingIOS.removeEventListener" is deprecated. Use "Linking.removeEventListener" instead.' ) ;
Linking . removeEventListener ( type , handler ) ;
2015-03-25 20:09:04 -07:00
}
2015-03-30 20:12:32 -07:00
/ * *
* Try to open the given ` url ` with any of the installed apps .
2016-01-26 14:34:00 -08:00
*
* @ deprecated
2015-03-30 20:12:32 -07:00
* /
static openURL ( url : string ) {
2016-01-26 14:34:00 -08:00
console . warn ( '"LinkingIOS.openURL" is deprecated. Use the promise based "Linking.openURL" instead.' ) ;
Linking . openURL ( url ) ;
2015-03-25 20:09:04 -07:00
}
2015-03-30 20:12:32 -07:00
/ * *
2015-11-12 12:35:44 -08:00
* Determine whether or not an installed app can handle a given URL .
2015-03-30 20:12:32 -07:00
* The callback function will be called with ` bool supported ` as the only argument
2015-10-12 08:03:02 -07:00
*
2015-12-04 08:05:11 -08:00
* NOTE : As of iOS 9 , your app needs to provide the ` LSApplicationQueriesSchemes ` key
2015-10-12 08:03:02 -07:00
* inside ` Info.plist ` .
2016-01-26 14:34:00 -08:00
*
* @ deprecated
2015-03-30 20:12:32 -07:00
* /
static canOpenURL ( url : string , callback : Function ) {
2016-01-26 14:34:00 -08:00
console . warn ( '"LinkingIOS.canOpenURL" is deprecated. Use the promise based "Linking.canOpenURL" instead.' ) ;
2015-03-25 20:09:04 -07:00
invariant (
typeof callback === 'function' ,
'A valid callback function is required'
) ;
2016-01-26 14:34:00 -08:00
Linking . canOpenURL ( url ) . then ( callback ) ;
2015-03-25 20:09:04 -07:00
}
2015-03-30 20:12:32 -07:00
/ * *
* If the app launch was triggered by an app link , it will pop the link url ,
* otherwise it will return ` null `
2016-01-26 14:34:00 -08:00
*
* @ deprecated
2015-03-30 20:12:32 -07:00
* /
static popInitialURL ( ) : ? string {
2016-01-26 14:34:00 -08:00
console . warn ( '"LinkingIOS.popInitialURL" is deprecated. Use the promise based "Linking.getInitialURL" instead.' ) ;
2015-03-25 20:09:04 -07:00
var initialURL = _initialURL ;
_initialURL = null ;
return initialURL ;
}
}
module . exports = LinkingIOS ;