CustomizeLayoutSetting.tsx 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. import React, { useCallback, useEffect, useState } from 'react';
  2. import { useTranslation } from 'react-i18next';
  3. import { toastSuccess, toastError } from '~/client/util/apiNotification';
  4. import { apiv3Get, apiv3Put } from '~/client/util/apiv3-client';
  5. import { isDarkMode as isDarkModeByUtil } from '~/client/util/color-scheme';
  6. const isDarkMode = isDarkModeByUtil();
  7. const colorText = isDarkMode ? 'dark' : 'light';
  8. const CustomizeLayoutSetting = (): JSX.Element => {
  9. const { t } = useTranslation();
  10. const [isContainerFluid, setIsContainerFluid] = useState(false);
  11. const [retrieveError, setRetrieveError] = useState();
  12. const retrieveData = useCallback(async() => {
  13. try {
  14. const res = await apiv3Get('/customize-setting/layout');
  15. setIsContainerFluid(res.data.isContainerFluid);
  16. }
  17. catch (err) {
  18. setRetrieveError(err);
  19. toastError(err);
  20. }
  21. }, []);
  22. useEffect(() => {
  23. retrieveData();
  24. }, [retrieveData]);
  25. const onClickSubmit = async() => {
  26. try {
  27. await apiv3Put('/customize-setting/layout', { isContainerFluid });
  28. toastSuccess(t('toaster.update_successed', { target: t('admin:customize_setting.layout') }));
  29. retrieveData();
  30. }
  31. catch (err) {
  32. toastError(err);
  33. }
  34. };
  35. return (
  36. <React.Fragment>
  37. <div className="row">
  38. <div className="col-12">
  39. <h2 className="admin-setting-header">{t('admin:customize_setting.layout')}</h2>
  40. <div className="d-flex justify-content-around mt-5">
  41. <div id="layoutOptions" className="card-deck">
  42. <div
  43. className={`card customize-layout-card ${!isContainerFluid ? 'border-active' : ''}`}
  44. onClick={() => setIsContainerFluid(false)}
  45. role="button"
  46. >
  47. <img src={`/images/customize-settings/default-${colorText}.svg`} />
  48. <div className="card-body text-center">
  49. {t('admin:customize_setting.layout_options.default')}
  50. </div>
  51. </div>
  52. <div
  53. className={`card customize-layout-card ${isContainerFluid ? 'border-active' : ''}`}
  54. onClick={() => setIsContainerFluid(true)}
  55. role="button"
  56. >
  57. <img src={`/images/customize-settings/fluid-${colorText}.svg`} />
  58. <div className="card-body text-center">
  59. {t('admin:customize_setting.layout_options.expanded')}
  60. </div>
  61. </div>
  62. </div>
  63. </div>
  64. <div className="row my-3">
  65. <div className="mx-auto">
  66. <button type="button" className="btn btn-primary" onClick={onClickSubmit} disabled={retrieveError != null}>{ t('Update') }</button>
  67. </div>
  68. </div>
  69. </div>
  70. </div>
  71. </React.Fragment>
  72. );
  73. };
  74. export default CustomizeLayoutSetting;