Use promises in 'NetInfo'

Reviewed By: svcscm

Differential Revision: D2938010

fb-gh-sync-id: 4a24ce680b37e49759f3325987b4b440eb033b94
shipit-source-id: 4a24ce680b37e49759f3325987b4b440eb033b94
This commit is contained in:
Satyajit Sahoo 2016-02-15 13:33:28 -08:00 committed by facebook-github-bot-9
parent ecb1643fee
commit 14ec6f011e
5 changed files with 39 additions and 41 deletions

View File

@ -134,8 +134,8 @@ const IsConnectionExpensive = React.createClass({
}; };
}, },
_checkIfExpensive() { _checkIfExpensive() {
NetInfo.isConnectionExpensive( NetInfo.isConnectionExpensive().then(
(isConnectionExpensive) => { this.setState({isConnectionExpensive}); } isConnectionExpensive => { this.setState({isConnectionExpensive}); }
); );
}, },
render() { render() {

View File

@ -16,6 +16,7 @@ const NativeModules = require('NativeModules');
const Platform = require('Platform'); const Platform = require('Platform');
const RCTDeviceEventEmitter = require('RCTDeviceEventEmitter'); const RCTDeviceEventEmitter = require('RCTDeviceEventEmitter');
const RCTNetInfo = NativeModules.NetInfo; const RCTNetInfo = NativeModules.NetInfo;
const deprecatedCallback = require('deprecatedCallback');
const DEVICE_CONNECTIVITY_EVENT = 'networkStatusDidChange'; const DEVICE_CONNECTIVITY_EVENT = 'networkStatusDidChange';
@ -135,8 +136,12 @@ const _isConnectedSubscriptions = new Map();
* monetary costs, data limitations or battery/performance issues. * monetary costs, data limitations or battery/performance issues.
* *
* ``` * ```
* NetInfo.isConnectionExpensive((isConnectionExpensive) => { * NetInfo.isConnectionExpensive()
* .then(isConnectionExpensive => {
* console.log('Connection is ' + (isConnectionExpensive ? 'Expensive' : 'Not Expensive')); * console.log('Connection is ' + (isConnectionExpensive ? 'Expensive' : 'Not Expensive'));
* })
* .catch(error => {
* console.error(error);
* }); * });
* ``` * ```
* *
@ -146,7 +151,7 @@ const _isConnectedSubscriptions = new Map();
* internet connectivity. * internet connectivity.
* *
* ``` * ```
* NetInfo.isConnected.fetch().done((isConnected) => { * NetInfo.isConnected.fetch().then(isConnected => {
* console.log('First, is ' + (isConnected ? 'online' : 'offline')); * console.log('First, is ' + (isConnected ? 'online' : 'offline'));
* }); * });
* function handleFirstConnectivityChange(isConnected) { * function handleFirstConnectivityChange(isConnected) {
@ -192,14 +197,7 @@ const NetInfo = {
}, },
fetch(): Promise { fetch(): Promise {
return new Promise((resolve, reject) => { return RCTNetInfo.getCurrentConnectivity().then(resp => resp.network_info);
RCTNetInfo.getCurrentConnectivity(
function(resp) {
resolve(resp.network_info);
},
reject
);
});
}, },
isConnected: { isConnected: {
@ -239,15 +237,13 @@ const NetInfo = {
}, },
}, },
isConnectionExpensive(callback: (metered: ?boolean, error?: string) => void): void { isConnectionExpensive(): Promise {
if (Platform.OS === 'android') { return deprecatedCallback(
RCTNetInfo.isConnectionMetered((_isMetered) => { Platform.OS === 'android' ? RCTNetInfo.isConnectionMetered() : Promise.reject(new Error('Currently not supported on iOS')),
callback(_isMetered); Array.prototype.slice.call(arguments),
}); 'single-callback-value-first',
} else { 'NetInfo.isConnectionMetered(callback) is deprecated. Use the returned Promise instead.'
// TODO t9296080 consider polyfill and more features later on );
callback(null, "Unsupported");
}
}, },
}; };

View File

@ -87,10 +87,10 @@ static void RCTReachabilityCallback(__unused SCNetworkReachabilityRef target, SC
#pragma mark - Public API #pragma mark - Public API
// TODO: remove error callback - not needed except by Subscribable interface // TODO: remove error callback - not needed except by Subscribable interface
RCT_EXPORT_METHOD(getCurrentConnectivity:(RCTResponseSenderBlock)getSuccess RCT_EXPORT_METHOD(getCurrentConnectivity:(RCTPromiseResolveBlock)resolve
withErrorCallback:(__unused RCTResponseSenderBlock)getError) reject:(__unused RCTPromiseRejectBlock)reject)
{ {
getSuccess(@[@{@"network_info": _status}]); resolve(@[@{@"network_info": _status}]);
} }
@end @end

View File

@ -19,7 +19,7 @@ module.exports = function(promise: Promise, callbacks: Array<Function>, type: st
return promise; return promise;
} }
let success, error; let success, error, callback;
console.warn(warning); console.warn(warning);
@ -36,13 +36,19 @@ module.exports = function(promise: Promise, callbacks: Array<Function>, type: st
res => success(res), res => success(res),
err => error(err) err => error(err)
); );
case 'node': // handles func(callback) case 'single-callback-value-first': // handles func(callback(value, err))
const [ callback ] = callbacks; [ callback ] = callbacks;
return promise.then(
res => callback(res),
err => callback(null, err)
);
case 'node': // handles func(callback(err, value))
[ callback ] = callbacks;
return promise.then( return promise.then(
res => callback(null, res), res => callback(null, res),
err => callback(err) err => callback(err)
); );
default: default:
throw new Error(`Type of callbacks not specified. Must be one of 'success-first', 'error-first', or 'node'`); throw new Error(`Type of callbacks not specified. Must be one of 'success-first', 'error-first', 'single-callback-value-first', or 'node'`);
} }
}; };

View File

@ -17,15 +17,13 @@ import android.net.ConnectivityManager;
import android.net.NetworkInfo; import android.net.NetworkInfo;
import android.support.v4.net.ConnectivityManagerCompat; import android.support.v4.net.ConnectivityManagerCompat;
import com.facebook.common.logging.FLog;
import com.facebook.react.bridge.Callback;
import com.facebook.react.bridge.LifecycleEventListener; import com.facebook.react.bridge.LifecycleEventListener;
import com.facebook.react.bridge.Promise;
import com.facebook.react.bridge.ReactApplicationContext; import com.facebook.react.bridge.ReactApplicationContext;
import com.facebook.react.bridge.ReactContextBaseJavaModule; import com.facebook.react.bridge.ReactContextBaseJavaModule;
import com.facebook.react.bridge.ReactMethod; import com.facebook.react.bridge.ReactMethod;
import com.facebook.react.bridge.WritableMap; import com.facebook.react.bridge.WritableMap;
import com.facebook.react.bridge.WritableNativeMap; import com.facebook.react.bridge.WritableNativeMap;
import com.facebook.react.common.ReactConstants;
import static com.facebook.react.modules.core.DeviceEventManagerModule.RCTDeviceEventEmitter; import static com.facebook.react.modules.core.DeviceEventManagerModule.RCTDeviceEventEmitter;
@ -41,6 +39,8 @@ public class NetInfoModule extends ReactContextBaseJavaModule
"To use NetInfo on Android, add the following to your AndroidManifest.xml:\n" + "To use NetInfo on Android, add the following to your AndroidManifest.xml:\n" +
"<uses-permission android:name=\"android.permission.ACCESS_NETWORK_STATE\" />"; "<uses-permission android:name=\"android.permission.ACCESS_NETWORK_STATE\" />";
private static final String ERROR_MISSING_PERMISSION = "E_MISSING_PERMISSION";
private final ConnectivityManager mConnectivityManager; private final ConnectivityManager mConnectivityManager;
private final ConnectivityManagerCompat mConnectivityManagerCompat; private final ConnectivityManagerCompat mConnectivityManagerCompat;
private final ConnectivityBroadcastReceiver mConnectivityBroadcastReceiver; private final ConnectivityBroadcastReceiver mConnectivityBroadcastReceiver;
@ -81,25 +81,21 @@ public class NetInfoModule extends ReactContextBaseJavaModule
} }
@ReactMethod @ReactMethod
public void getCurrentConnectivity(Callback successCallback, Callback errorCallback) { public void getCurrentConnectivity(Promise promise) {
if (mNoNetworkPermission) { if (mNoNetworkPermission) {
if (errorCallback == null) { promise.reject(ERROR_MISSING_PERMISSION, MISSING_PERMISSION_MESSAGE, null);
FLog.e(ReactConstants.TAG, MISSING_PERMISSION_MESSAGE);
return;
}
errorCallback.invoke(MISSING_PERMISSION_MESSAGE);
return; return;
} }
successCallback.invoke(createConnectivityEventMap()); promise.resolve(createConnectivityEventMap());
} }
@ReactMethod @ReactMethod
public void isConnectionMetered(Callback successCallback) { public void isConnectionMetered(Promise promise) {
if (mNoNetworkPermission) { if (mNoNetworkPermission) {
FLog.e(ReactConstants.TAG, MISSING_PERMISSION_MESSAGE); promise.reject(ERROR_MISSING_PERMISSION, MISSING_PERMISSION_MESSAGE, null);
return; return;
} }
successCallback.invoke(mConnectivityManagerCompat.isActiveNetworkMetered(mConnectivityManager)); promise.resolve(ConnectivityManagerCompat.isActiveNetworkMetered(mConnectivityManager));
} }
private void registerReceiver() { private void registerReceiver() {