CustomizeHeaderSetting.tsx 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. import React, { useCallback } from 'react';
  2. import { useTranslation } from 'react-i18next';
  3. import { Card, CardBody } from 'reactstrap';
  4. import AdminCustomizeContainer from '~/client/services/AdminCustomizeContainer';
  5. import { toastSuccess, toastError } from '~/client/util/apiNotification';
  6. import { withUnstatedContainers } from '../../UnstatedUtils';
  7. import AdminUpdateButtonRow from '../Common/AdminUpdateButtonRow';
  8. import CustomHeaderEditor from '../CustomHeaderEditor';
  9. type Props = {
  10. adminCustomizeContainer: AdminCustomizeContainer
  11. }
  12. const CustomizeHeaderSetting = (props: Props): JSX.Element => {
  13. const { adminCustomizeContainer } = props;
  14. const { t } = useTranslation();
  15. const onClickSubmit = useCallback(async() => {
  16. try {
  17. await adminCustomizeContainer.updateCustomizeHeader();
  18. toastSuccess(t('toaster.update_successed', { target: t('admin:customize_setting.custom_header') }));
  19. }
  20. catch (err) {
  21. toastError(err);
  22. }
  23. }, [t, adminCustomizeContainer]);
  24. return (
  25. <React.Fragment>
  26. <div className="row">
  27. <div className="col-12">
  28. <h2 className="admin-setting-header">{t('admin:customize_setting.custom_header')}</h2>
  29. <Card className="card well my-3">
  30. <CardBody className="px-0 py-2">
  31. <span
  32. // eslint-disable-next-line react/no-danger
  33. dangerouslySetInnerHTML={{ __html: t('admin:customize_setting.custom_header_detail') }}
  34. />
  35. </CardBody>
  36. </Card>
  37. <div className="form-text text-muted">
  38. { t('Example') }:
  39. <pre className="hljs">
  40. {/* eslint-disable-next-line react/no-unescaped-entities */}
  41. <code className="text-wrap">&lt;script src="https://cdn.jsdelivr.net/gh/highlightjs/cdn-release@9.13.0/build/languages/yaml.min.js"
  42. defer&gt;&lt;/script&gt;
  43. </code>
  44. </pre>
  45. </div>
  46. <div className="form-group">
  47. <CustomHeaderEditor
  48. value={adminCustomizeContainer.state.currentCustomizeHeader || ''}
  49. onChange={(inputValue) => { adminCustomizeContainer.changeCustomizeHeader(inputValue) }}
  50. />
  51. <p className="form-text text-muted text-right">
  52. <i className="fa fa-fw fa-keyboard-o" aria-hidden="true"></i>
  53. {t('admin:customize_setting.ctrl_space')}
  54. </p>
  55. </div>
  56. <AdminUpdateButtonRow onClick={onClickSubmit} disabled={adminCustomizeContainer.state.retrieveError != null} />
  57. </div>
  58. </div>
  59. </React.Fragment>
  60. );
  61. };
  62. const CustomizeHeaderSettingWrapper = withUnstatedContainers(CustomizeHeaderSetting, [AdminCustomizeContainer]);
  63. export default CustomizeHeaderSettingWrapper;