setupConnectivityListner method

dynamic setupConnectivityListner({
  1. CustomNoInternetWrapper? offlineWidget,
  2. GlobalKey<NavigatorState>? navigatorKey,
  3. NoConnectivityStyle? connectivityStyle = NoConnectivityStyle.SNACKBAR,
  4. Widget? noInternetText,
})

Initialize the connectivity wtacher with custom parameters

Implementation

setupConnectivityListner(
    {CustomNoInternetWrapper? offlineWidget,
    GlobalKey<NavigatorState>? navigatorKey,
    NoConnectivityStyle? connectivityStyle = NoConnectivityStyle.SNACKBAR,
    Widget? noInternetText}) async {
  if (navigatorKey != null) {
    _contextKey = navigatorKey;
  }
  _userWidget = offlineWidget;
  _connectivityStyle = connectivityStyle;
  customNoInternetText = noInternetText;
  if (_connectivityStyle == NoConnectivityStyle.CUSTOM &&
      _userWidget == null) {
    throw ("widgetForNoInternet is missing");
  }

  checker.onStatusChange.listen((status) {
    if (_connectivityStyle == NoConnectivityStyle.CUSTOM &&
        (_contextKey.currentState?.overlay) != null) {
      _overlayState = (_contextKey.currentState!.overlay);
    }

    switch (status) {
      /// ConnectedState
      case InternetConnectionStatus.connected:
        try {
          _removeNoInternet();
          connectivityController.sink
              .add(ConnectivityWatcherStatus.connected);
        } catch (e) {}
        print('You are Connected to the internet.');
        break;

      /// DisconnectedState
      case InternetConnectionStatus.disconnected:
        connectivityController.sink
            .add(ConnectivityWatcherStatus.disconnected);
        showNoInternet();
        print('You are disconnected from the internet.');
        break;
    }
  });
}