/* eslint-disable react/no-danger */ import React from 'react'; import PropTypes from 'prop-types'; import { useTranslation } from 'react-i18next'; import AdminBasicSecurityContainer from '~/client/services/AdminBasicSecurityContainer'; import AdminGeneralSecurityContainer from '~/client/services/AdminGeneralSecurityContainer'; import { toastSuccess, toastError } from '~/client/util/apiNotification'; import { withUnstatedContainers } from '../../UnstatedUtils'; class BasicSecurityManagementContents extends React.Component { constructor(props) { super(props); this.onClickSubmit = this.onClickSubmit.bind(this); } async onClickSubmit() { const { t, adminBasicSecurityContainer, adminGeneralSecurityContainer } = this.props; try { await adminBasicSecurityContainer.updateBasicSetting(); await adminGeneralSecurityContainer.retrieveSetupStratedies(); toastSuccess(t('security_setting.Basic.updated_basic')); } catch (err) { toastError(err); } } render() { const { t, adminGeneralSecurityContainer, adminBasicSecurityContainer } = this.props; const { isBasicEnabled } = adminGeneralSecurityContainer.state; return ( { t('security_setting.Basic.name') } {adminBasicSecurityContainer.state.retrieveError != null && ( {t('Error occurred')} : {adminBasicSecurityContainer.state.retrieveError} )} { adminGeneralSecurityContainer.switchIsBasicEnabled() }} /> { t('security_setting.Basic.enable_basic') } { t('security_setting.Basic.desc_2')} {(!adminGeneralSecurityContainer.state.setupStrategies.includes('basic') && isBasicEnabled) && {t('security_setting.setup_is_not_yet_complete')}} {isBasicEnabled && ( { adminBasicSecurityContainer.switchIsSameUsernameTreatedAsIdenticalUser() }} /> {t('Update')} )} ); } } BasicSecurityManagementContents.propTypes = { t: PropTypes.func.isRequired, // i18next adminGeneralSecurityContainer: PropTypes.instanceOf(AdminGeneralSecurityContainer).isRequired, adminBasicSecurityContainer: PropTypes.instanceOf(AdminBasicSecurityContainer).isRequired, }; const BasicSecurityManagementContentsWrapperFC = (props) => { const { t } = useTranslation(); return ; }; const BasicSecurityManagementContentsWrapper = withUnstatedContainers(BasicSecurityManagementContentsWrapperFC, [ AdminGeneralSecurityContainer, AdminBasicSecurityContainer, ]); export default BasicSecurityManagementContentsWrapper;
{t('Error occurred')} : {adminBasicSecurityContainer.state.retrieveError}
{ t('security_setting.Basic.desc_2')}