import React from 'react';
import { Button } from 'reactstrap';
import { useTranslation } from 'react-i18next';
import { pushAlert } from './common/alert-service';
if ('serviceWorker' in navigator) {
  let isThisTriggerUpgrade = false;
  const upgradeSuccessLocalStorageKey = 'TIMELINE_UPGRADE_SUCCESS';
  if (window.localStorage.getItem(upgradeSuccessLocalStorageKey)) {
    pushAlert({
      message: {
        type: 'i18n',
        key: 'serviceWorker.upgradeSuccess',
      },
      type: 'success',
    });
    window.localStorage.removeItem(upgradeSuccessLocalStorageKey);
  }
  void import('workbox-window').then(({ Workbox, messageSW }) => {
    const wb = new Workbox('/sw.js');
    let registration: ServiceWorkerRegistration | undefined;
    // externalactivated is not usable but I still use its name.
    wb.addEventListener('controlling', () => {
      const upgradeReload = (): void => {
        window.localStorage.setItem(upgradeSuccessLocalStorageKey, 'true');
        window.location.reload();
      };
      if (isThisTriggerUpgrade) {
        upgradeReload();
      } else {
        const Message: React.FC = () => {
          const { t } = useTranslation();
          return (
            <>
              {t('serviceWorker.externalActivatedPrompt')}
              
            >
          );
        };
        pushAlert({
          message: Message,
          dismissTime: 'never',
          type: 'warning',
        });
      }
    });
    wb.addEventListener('activated', (event) => {
      if (!event.isUpdate) {
        pushAlert({
          message: {
            type: 'i18n',
            key: 'serviceWorker.availableOffline',
          },
          type: 'success',
        });
      }
    });
    const showSkipWaitingPrompt = (): void => {
      const upgrade = (): void => {
        isThisTriggerUpgrade = true;
        if (registration && registration.waiting) {
          // Send a message to the waiting service worker,
          // instructing it to activate.
          // Note: for this to work, you have to add a message
          // listener in your service worker. See below.
          void messageSW(registration.waiting, { type: 'SKIP_WAITING' });
        }
      };
      const UpgradeMessage: React.FC = () => {
        const { t } = useTranslation();
        return (
          <>
            {t('serviceWorker.upgradePrompt')}
            
          >
        );
      };
      pushAlert({
        message: UpgradeMessage,
        dismissTime: 'never',
        type: 'success',
      });
    };
    // Add an event listener to detect when the registered
    // service worker has installed but is waiting to activate.
    wb.addEventListener('waiting', showSkipWaitingPrompt);
    wb.addEventListener('externalwaiting', showSkipWaitingPrompt);
    void wb.register().then((reg) => {
      registration = reg;
    });
  });
}