144 lines
4.4 KiB
JavaScript
144 lines
4.4 KiB
JavaScript
/**
|
|
* 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 IntentAndroid
|
|
*/
|
|
'use strict';
|
|
|
|
var IntentAndroidModule = require('NativeModules').IntentAndroid;
|
|
var invariant = require('invariant');
|
|
|
|
/**
|
|
* `IntentAndroid` gives you a general interface to handle external links.
|
|
*
|
|
* ### Basic Usage
|
|
*
|
|
* #### Handling deep links
|
|
*
|
|
* If your app was launched from an external url registered to your app you can
|
|
* access and handle it from any component you want with
|
|
*
|
|
* ```
|
|
* componentDidMount() {
|
|
* var url = IntentAndroid.getInitialURL(url => {
|
|
* if (url) {
|
|
* console.log('Initial url is: ' + url);
|
|
* }
|
|
* });
|
|
* }
|
|
* ```
|
|
*
|
|
* Example to add support for deep linking inside your React Native app.
|
|
* More Info: [Enabling Deep Links for App Content - Add Intent Filters for Your Deep Links](http://developer.android.com/training/app-indexing/deep-linking.html#adding-filters).
|
|
*
|
|
* Edit in `android/app/src/main/AndroidManifest.xml`
|
|
*
|
|
* ```
|
|
* <intent-filter>
|
|
* <action android:name="android.intent.action.VIEW" />
|
|
* <category android:name="android.intent.category.DEFAULT" />
|
|
* <category android:name="android.intent.category.BROWSABLE" />
|
|
*
|
|
* <!-- Accepts URIs that begin with "http://www.facebook.com/react -->
|
|
* <data android:scheme="http"
|
|
* android:host="www.facebook.com"
|
|
* android:pathPrefix="/react" />
|
|
* <!-- note that the leading "/" is required for pathPrefix-->
|
|
*
|
|
* <!-- Accepts URIs that begin with "facebook://react -->
|
|
* <!-- <data android:scheme="facebook" android:host="react" /> -->
|
|
* </intent-filter>
|
|
* ```
|
|
*
|
|
* #### Opening external links
|
|
*
|
|
* To start the corresponding activity for a link (web URL, email, contact etc.), call
|
|
*
|
|
* ```
|
|
* IntentAndroid.openURL(url)
|
|
* ```
|
|
*
|
|
* If you want to check if any installed app can handle a given URL beforehand you can call
|
|
* ```
|
|
* IntentAndroid.canOpenURL(url, (supported) => {
|
|
* if (!supported) {
|
|
* console.log('Can\'t handle url: ' + url);
|
|
* } else {
|
|
* IntentAndroid.openURL(url);
|
|
* }
|
|
* });
|
|
* ```
|
|
*/
|
|
class IntentAndroid {
|
|
|
|
/**
|
|
* Starts a corresponding external activity for the given URL.
|
|
*
|
|
* For example, if the URL is "https://www.facebook.com", the system browser will be opened,
|
|
* or the "choose application" dialog will be shown.
|
|
*
|
|
* You can use other URLs, like a location (e.g. "geo:37.484847,-122.148386"), a contact,
|
|
* or any other URL that can be opened with {@code Intent.ACTION_VIEW}.
|
|
*
|
|
* NOTE: This method will fail if the system doesn't know how to open the specified URL.
|
|
* If you're passing in a non-http(s) URL, it's best to check {@code canOpenURL} first.
|
|
*
|
|
* NOTE: For web URLs, the protocol ("http://", "https://") must be set accordingly!
|
|
*/
|
|
static openURL(url: string) {
|
|
this._validateURL(url);
|
|
IntentAndroidModule.openURL(url);
|
|
}
|
|
|
|
/**
|
|
* Determine whether or not an installed app can handle a given URL.
|
|
*
|
|
* You can use other URLs, like a location (e.g. "geo:37.484847,-122.148386"), a contact,
|
|
* or any other URL that can be opened with {@code Intent.ACTION_VIEW}.
|
|
*
|
|
* NOTE: For web URLs, the protocol ("http://", "https://") must be set accordingly!
|
|
*
|
|
* @param URL the URL to open
|
|
*/
|
|
static canOpenURL(url: string, callback: Function) {
|
|
this._validateURL(url);
|
|
invariant(
|
|
typeof callback === 'function',
|
|
'A valid callback function is required'
|
|
);
|
|
IntentAndroidModule.canOpenURL(url, callback);
|
|
}
|
|
|
|
/**
|
|
* If the app launch was triggered by an app link with {@code Intent.ACTION_VIEW},
|
|
* it will give the link url, otherwise it will give `null`
|
|
*
|
|
* Refer http://developer.android.com/training/app-indexing/deep-linking.html#handling-intents
|
|
*/
|
|
static getInitialURL(callback: Function) {
|
|
invariant(
|
|
typeof callback === 'function',
|
|
'A valid callback function is required'
|
|
);
|
|
IntentAndroidModule.getInitialURL(callback);
|
|
}
|
|
|
|
static _validateURL(url: string) {
|
|
invariant(
|
|
typeof url === 'string',
|
|
'Invalid URL: should be a string. Was: ' + url
|
|
);
|
|
invariant(
|
|
url,
|
|
'Invalid URL: cannot be empty'
|
|
);
|
|
}
|
|
}
|
|
|
|
module.exports = IntentAndroid;
|