CustomizeLayoutSetting.jsx 3.1 KB

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