mirror of
https://github.com/status-im/react-native.git
synced 2025-01-16 04:24:15 +00:00
Use promises in 'NetInfo'
Reviewed By: svcscm Differential Revision: D2938010 fb-gh-sync-id: 4a24ce680b37e49759f3325987b4b440eb033b94 shipit-source-id: 4a24ce680b37e49759f3325987b4b440eb033b94
This commit is contained in:
parent
ecb1643fee
commit
14ec6f011e
Examples/UIExplorer
Libraries
ReactAndroid/src/main/java/com/facebook/react/modules/netinfo
@ -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() {
|
||||||
|
@ -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");
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
@ -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'`);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -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() {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user