/* eslint-disable react/no-danger */ import React from 'react'; import PropTypes from 'prop-types'; import { withTranslation } from 'react-i18next'; import { withUnstatedContainers } from '../../UnstatedUtils'; import { toastSuccess, toastError } from '../../../util/apiNotification'; import AppContainer from '../../../services/AppContainer'; import AdminGeneralSecurityContainer from '../../../services/AdminGeneralSecurityContainer'; import AdminLocalSecurityContainer from '../../../services/AdminLocalSecurityContainer'; class LocalSecuritySettingContents extends React.Component { constructor(props) { super(props); this.onClickSubmit = this.onClickSubmit.bind(this); } async onClickSubmit() { const { t, adminGeneralSecurityContainer, adminLocalSecurityContainer } = this.props; try { await adminLocalSecurityContainer.updateLocalSecuritySetting(); await adminGeneralSecurityContainer.retrieveSetupStratedies(); toastSuccess(t('security_setting.updated_general_security_setting')); } catch (err) { toastError(err); } } render() { const { t, adminGeneralSecurityContainer, adminLocalSecurityContainer } = this.props; const { registrationMode } = adminLocalSecurityContainer.state; const { isLocalEnabled } = adminGeneralSecurityContainer.state; return ( {adminLocalSecurityContainer.state.retrieveError != null && (

{t('Error occurred')} : {adminLocalSecurityContainer.state.retrieveError}

)}

{t('security_setting.Local.name')}

{adminLocalSecurityContainer.state.useOnlyEnvVars && (

)}

adminGeneralSecurityContainer.switchIsLocalEnabled()} disabled={adminLocalSecurityContainer.state.useOnlyEnvVars} />
{!adminGeneralSecurityContainer.state.setupStrategies.includes('local') && isLocalEnabled && (
{t('security_setting.setup_is_not_yet_complete')}
)}
{isLocalEnabled && (

{t('security_setting.configuration')}

{t('Register limitation')}

{t('security_setting.Register limitation desc')}