import React, { Suspense } from 'react';
import { Card, CardBody } from 'reactstrap';
import PropTypes from 'prop-types';
import { withTranslation } from 'react-i18next';
import loggerFactory from '@alias/logger';
import { withUnstatedContainers } from '../../UnstatedUtils';
import { toastError } from '../../../util/apiNotification';
import LineBreakForm from './LineBreakForm';
import PresentationForm from './PresentationForm';
import XssForm from './XssForm';
import AdminMarkDownContainer from '../../../services/AdminMarkDownContainer';
const logger = loggerFactory('growi:MarkDown');
function MarkdownSetting(props) {
return (
)}
>
);
}
function RenderMarkdownSetting(props) {
const { t, adminMarkDownContainer } = props;
if (adminMarkDownContainer.state.isEnabledLinebreaks === adminMarkDownContainer.dummyIsEnabledLinebreaks) {
throw new Promise(async() => {
try {
await adminMarkDownContainer.retrieveMarkdownData();
}
catch (err) {
toastError(err);
adminMarkDownContainer.setState({ retrieveError: err.message });
logger.error(err);
}
});
}
return (
{/* Line Break Setting */}
{t('admin:markdown_setting.lineBreak_header')}
{ t('admin:markdown_setting.lineBreak_desc') }
{/* Presentation Setting */}
{ t('admin:markdown_setting.presentation_header') }
{ t('admin:markdown_setting.presentation_desc') }
{/* XSS Setting */}
{ t('admin:markdown_setting.xss_header') }
{ t('admin:markdown_setting.xss_desc') }
);
}
const RenderMarkdownSettingWrapper = withUnstatedContainers(MarkdownSetting, [AdminMarkDownContainer]);
RenderMarkdownSetting.propTypes = {
t: PropTypes.func.isRequired, // i18next
adminMarkDownContainer: PropTypes.instanceOf(AdminMarkDownContainer).isRequired,
};
export default withTranslation()(RenderMarkdownSettingWrapper);