CustomizeLayoutSetting.jsx 3.1 KB

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