2015-03-16 13:57:43 -07:00
|
|
|
/**
|
2015-03-23 13:35:08 -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.
|
2015-03-16 13:57:43 -07:00
|
|
|
*
|
|
|
|
* @providesModule NetInfo
|
|
|
|
* @flow
|
|
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
var NativeModules = require('NativeModules');
|
|
|
|
var RCTDeviceEventEmitter = require('RCTDeviceEventEmitter');
|
2015-03-17 22:22:03 -07:00
|
|
|
var RCTReachability = NativeModules.Reachability;
|
2015-03-16 13:57:43 -07:00
|
|
|
|
|
|
|
var DEVICE_REACHABILITY_EVENT = 'reachabilityDidChange';
|
|
|
|
|
|
|
|
type ChangeEventName = $Enum<{
|
|
|
|
change: string;
|
|
|
|
}>;
|
|
|
|
|
2015-03-25 14:55:35 -07:00
|
|
|
type ReachabilityStateIOS = $Enum<{
|
|
|
|
cell: string;
|
|
|
|
none: string;
|
|
|
|
unknown: string;
|
|
|
|
wifi: string;
|
|
|
|
}>;
|
|
|
|
|
2015-03-16 13:57:43 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* NetInfo exposes info about online/offline status
|
|
|
|
*
|
2015-03-25 14:55:35 -07:00
|
|
|
* ### reachabilityIOS
|
2015-03-16 13:57:43 -07:00
|
|
|
*
|
|
|
|
* Asyncronously determine if the device is online and on a cellular network.
|
|
|
|
*
|
2015-03-25 14:55:35 -07:00
|
|
|
* - `none` - device is offline
|
|
|
|
* - `wifi` - device is online and connected via wifi, or is the iOS simulator
|
|
|
|
* - `cell` - device is connected via Edge, 3G, WiMax, or LTE
|
|
|
|
* - `unknown` - error case and the network status is unknown
|
2015-03-16 13:57:43 -07:00
|
|
|
*
|
|
|
|
* ```
|
|
|
|
* NetInfo.reachabilityIOS.fetch().done((reach) => {
|
|
|
|
* console.log('Initial: ' + reach);
|
|
|
|
* });
|
|
|
|
* function handleFirstReachabilityChange(reach) {
|
|
|
|
* console.log('First change: ' + reach);
|
|
|
|
* NetInfo.reachabilityIOS.removeEventListener(
|
|
|
|
* 'change',
|
|
|
|
* handleFirstReachabilityChange
|
|
|
|
* );
|
|
|
|
* }
|
|
|
|
* NetInfo.reachabilityIOS.addEventListener(
|
|
|
|
* 'change',
|
|
|
|
* handleFirstReachabilityChange
|
|
|
|
* );
|
|
|
|
* ```
|
2015-03-25 14:55:35 -07:00
|
|
|
*
|
|
|
|
* ### isConnected
|
|
|
|
*
|
|
|
|
* Available on all platforms. Asyncronously fetch a boolean to determine
|
|
|
|
* internet connectivity.
|
|
|
|
*
|
|
|
|
* ```
|
|
|
|
* NetInfo.isConnected.fetch().done((isConnected) => {
|
|
|
|
* console.log('First, is ' + (isConnected ? 'online' : 'offline'));
|
|
|
|
* });
|
|
|
|
* function handleFirstConnectivityChange(isConnected) {
|
|
|
|
* console.log('Then, is ' + (isConnected ? 'online' : 'offline'));
|
|
|
|
* NetInfo.isConnected.removeEventListener(
|
|
|
|
* 'change',
|
|
|
|
* handleFirstConnectivityChange
|
|
|
|
* );
|
|
|
|
* }
|
|
|
|
* NetInfo.isConnected.addEventListener(
|
|
|
|
* 'change',
|
|
|
|
* handleFirstConnectivityChange
|
|
|
|
* );
|
|
|
|
* ```
|
2015-03-16 13:57:43 -07:00
|
|
|
*/
|
|
|
|
|
|
|
|
var NetInfo = {};
|
|
|
|
|
2015-03-17 03:08:46 -07:00
|
|
|
if (RCTReachability) {
|
2015-03-25 14:55:35 -07:00
|
|
|
|
|
|
|
// RCTReachability is exposed, so this is an iOS-like environment and we will
|
|
|
|
// expose reachabilityIOS
|
|
|
|
|
2015-03-16 13:57:43 -07:00
|
|
|
var _reachabilitySubscriptions = {};
|
|
|
|
|
|
|
|
NetInfo.reachabilityIOS = {
|
|
|
|
addEventListener: function (
|
|
|
|
eventName: ChangeEventName,
|
|
|
|
handler: Function
|
|
|
|
): void {
|
|
|
|
_reachabilitySubscriptions[handler] = RCTDeviceEventEmitter.addListener(
|
|
|
|
DEVICE_REACHABILITY_EVENT,
|
|
|
|
(appStateData) => {
|
|
|
|
handler(appStateData.network_reachability);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
},
|
|
|
|
|
|
|
|
removeEventListener: function(
|
|
|
|
eventName: ChangeEventName,
|
|
|
|
handler: Function
|
|
|
|
): void {
|
|
|
|
if (!_reachabilitySubscriptions[handler]) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
_reachabilitySubscriptions[handler].remove();
|
|
|
|
_reachabilitySubscriptions[handler] = null;
|
|
|
|
},
|
|
|
|
|
|
|
|
fetch: function(): Promise {
|
|
|
|
return new Promise((resolve, reject) => {
|
2015-03-17 03:08:46 -07:00
|
|
|
RCTReachability.getCurrentReachability(
|
2015-03-25 14:55:35 -07:00
|
|
|
function(resp) {
|
2015-03-16 13:57:43 -07:00
|
|
|
resolve(resp.network_reachability);
|
|
|
|
},
|
|
|
|
reject
|
|
|
|
);
|
|
|
|
});
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
var _isConnectedSubscriptions = {};
|
2015-03-25 14:55:35 -07:00
|
|
|
|
|
|
|
var _iosReachabilityIsConnected = function(
|
|
|
|
reachability: ReachabilityStateIOS
|
|
|
|
): bool {
|
|
|
|
return reachability !== 'none' &&
|
|
|
|
reachability !== 'unknown';
|
|
|
|
};
|
|
|
|
|
2015-03-16 13:57:43 -07:00
|
|
|
NetInfo.isConnected = {
|
|
|
|
addEventListener: function (
|
|
|
|
eventName: ChangeEventName,
|
|
|
|
handler: Function
|
|
|
|
): void {
|
|
|
|
_isConnectedSubscriptions[handler] = (reachability) => {
|
2015-03-25 14:55:35 -07:00
|
|
|
handler(_iosReachabilityIsConnected(reachability));
|
2015-03-16 13:57:43 -07:00
|
|
|
};
|
2015-03-25 14:55:35 -07:00
|
|
|
NetInfo.reachabilityIOS.addEventListener(
|
|
|
|
eventName,
|
|
|
|
_isConnectedSubscriptions[handler]
|
|
|
|
);
|
2015-03-16 13:57:43 -07:00
|
|
|
},
|
|
|
|
|
|
|
|
removeEventListener: function(
|
|
|
|
eventName: ChangeEventName,
|
|
|
|
handler: Function
|
|
|
|
): void {
|
2015-03-25 14:55:35 -07:00
|
|
|
NetInfo.reachabilityIOS.removeEventListener(
|
|
|
|
eventName,
|
|
|
|
_isConnectedSubscriptions[handler]
|
|
|
|
);
|
2015-03-16 13:57:43 -07:00
|
|
|
},
|
|
|
|
|
|
|
|
fetch: function(): Promise {
|
|
|
|
return NetInfo.reachabilityIOS.fetch().then(
|
2015-03-25 14:55:35 -07:00
|
|
|
(reachability) => _iosReachabilityIsConnected(reachability)
|
2015-03-16 13:57:43 -07:00
|
|
|
);
|
|
|
|
},
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = NetInfo;
|