import {
  CheckNetworkStatusPayloadType,
  NetworkActionType,
} from '../state/ducks/network';
import { getSocketStatus } from '../shims/socketStatus';

type NetworkActions = {
  checkNetworkStatus: (x: CheckNetworkStatusPayloadType) => NetworkActionType;
  closeConnectingGracePeriod: () => NetworkActionType;
};

const REFRESH_INTERVAL = 5000;

export function initializeNetworkObserver(
  networkActions: NetworkActions
): void {
  const { log } = window;
  log.info(`Initializing network observer every ${REFRESH_INTERVAL}ms`);

  const refresh = () => {
    networkActions.checkNetworkStatus({
      isOnline: navigator.onLine,
      socketStatus: getSocketStatus(),
    });
  };

  window.addEventListener('online', refresh);
  window.addEventListener('offline', refresh);
  window.setInterval(refresh, REFRESH_INTERVAL);
  window.setTimeout(() => {
    networkActions.closeConnectingGracePeriod();
  }, REFRESH_INTERVAL);
}