MaintenanceMode.tsx 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. import React, { FC, useState, useCallback } from 'react';
  2. import { useTranslation } from 'next-i18next';
  3. import { toastSuccess, toastError } from '~/client/util/toastr';
  4. import { useIsMaintenanceMode } from '~/stores/maintenanceMode';
  5. import loggerFactory from '~/utils/logger';
  6. import { ConfirmModal } from './ConfirmModal';
  7. const logger = loggerFactory('growi:maintenanceMode');
  8. export const MaintenanceMode: FC = () => {
  9. const { t } = useTranslation();
  10. const {
  11. data: isMaintenanceMode, start: startMaintenanceMode, end: endMaintenanceMode,
  12. } = useIsMaintenanceMode();
  13. const [isModalOpen, setModalOpen] = useState<boolean>(false);
  14. const openModal = useCallback(() => { setModalOpen(true) }, []);
  15. const closeModal = useCallback(() => { setModalOpen(false) }, []);
  16. const onConfirmHandler = useCallback(async() => {
  17. closeModal();
  18. try {
  19. if (isMaintenanceMode) {
  20. endMaintenanceMode();
  21. }
  22. else {
  23. startMaintenanceMode();
  24. }
  25. }
  26. catch (err) {
  27. toastError(isMaintenanceMode ? t('admin:maintenance_mode.failed_to_end_maintenance_mode') : t('admin:maintenance_mode.failed_to_start_maintenance_mode'));
  28. }
  29. // eslint-disable-next-line max-len
  30. toastSuccess(isMaintenanceMode ? t('admin:maintenance_mode.successfully_ended_maintenance_mode') : t('admin:maintenance_mode.successfully_started_maintenance_mode'));
  31. }, [isMaintenanceMode, closeModal, startMaintenanceMode, endMaintenanceMode, t]);
  32. return (
  33. <div className="mb-5">
  34. <ConfirmModal
  35. isModalOpen={isModalOpen}
  36. warningMessage={isMaintenanceMode ? t('admin:maintenance_mode.warning_message_to_end') : t('admin:maintenance_mode.warning_message_to_start')}
  37. // eslint-disable-next-line max-len
  38. supplymentaryMessage={isMaintenanceMode ? null : t('admin:maintenance_mode.supplymentary_message_to_start')}
  39. confirmButtonTitle={isMaintenanceMode ? t('admin:maintenance_mode.end_maintenance_mode') : t('admin:maintenance_mode.start_maintenance_mode')}
  40. onConfirm={onConfirmHandler}
  41. onCancel={() => closeModal()}
  42. />
  43. <p className="card custom-card">
  44. {t('admin:maintenance_mode.description')}
  45. <br />
  46. <br />
  47. <span className="text-warning">
  48. <span className="material-symbols-outlined">error</span>
  49. {t('admin:maintenance_mode.supplymentary_message_to_start')}
  50. </span>
  51. </p>
  52. <div className="row my-3">
  53. <div className="mx-auto">
  54. <button type="button" className="btn btn-success" onClick={() => openModal()}>
  55. {isMaintenanceMode ? t('admin:maintenance_mode.end_maintenance_mode') : t('admin:maintenance_mode.start_maintenance_mode')}
  56. </button>
  57. </div>
  58. </div>
  59. </div>
  60. );
  61. };