cross_connectivity 2.0.0
cross_connectivity: ^2.0.0 copied to clipboard
A Flutter plugin for handling Connectivity and REAL Connection state in the mobile, web and desktop platforms. Supports iOS, Android, Web, Windows, Linux and macOS.
cross_connectivity #
A Flutter plugin for handling Connectivity and REAL Connection state in the mobile, web and desktop platforms. Supports iOS, Android, Web, Windows, Linux and macOS.
Getting Started #
In order to use this plugin, add dependency in the pubspec.yaml:
cross_connectivity: any
or
cross_connectivity:
git:
url: https://github.com/marchdev-tk/cross_connectivity
Add an import to dart file:
import 'package:cross_connectivity/cross_connectivity.dart';
Samples #
Web sample:
[Web Sample]
Desktop sample:
[Desktop Sample]
Mobile sample:
[Mobile Sample]
Usage #
Functional approach
This plugin provides two streams:
isConnectedthat shows whether the device isREALLYconnected to the network or not.onConnectivityChangedthat it will not let you know about state of theREALnetwork connection. It only shows connectivity state.
Also for one time check could be used following methods:
checkConnection()that is working likeisConnected, but returnsFuture<bool>instread ofStream<bool>.checkConnectivity()that is working likeonConnectivityChanged, but returnsFuture<ConnectivityStatus>instread ofStream<ConnectivityStatus>.
As an addition there are more methods (they are working only on Android/iOS/macOS):
getWifiName()- Obtains the wifi name (SSID) of the connected network.getWifiBSSID()- Obtains the wifi BSSID of the connected network.getWifiIP()- Obtains the IP address of the connected wifi network.
Widget approach
As an alteration to funcitonal approach could be used ConnectivityBuilder widget as follows:
ConnectivityBuilder(
builder: (context, isConnected, status) => Row(
mainAxisSize: MainAxisSize.min,
children: <Widget>[
Icon(
isConnected == true
? Icons.signal_wifi_4_bar
: Icons.signal_wifi_off,
color: isConnected == true ? Colors.green : Colors.red,
),
const SizedBox(width: 8),
Text(
'$status',
style: TextStyle(
color: status != ConnectivityStatus.none
? Colors.green
: Colors.red,
),
),
],
),
)
Feature requests and Bug reports #
Feel free to post a feature requests or report a bug here.