import React, { useCallback, useEffect } from 'react'; import { useTranslation } from 'next-i18next'; import Link from 'next/link'; import { useForm } from 'react-hook-form'; import AdminGeneralSecurityContainer from '~/client/services/AdminGeneralSecurityContainer'; import AdminLocalSecurityContainer from '~/client/services/AdminLocalSecurityContainer'; import { toastSuccess, toastError } from '~/client/util/toastr'; import { useIsMailerSetup } from '~/stores-universal/context'; import { withUnstatedContainers } from '../../UnstatedUtils'; type Props = { adminGeneralSecurityContainer: AdminGeneralSecurityContainer; adminLocalSecurityContainer: AdminLocalSecurityContainer; }; const LocalSecuritySettingContents = (props: Props): JSX.Element => { const { adminGeneralSecurityContainer, adminLocalSecurityContainer, } = props; const { t } = useTranslation('admin'); const { data: isMailerSetup = false } = useIsMailerSetup(); const { register, handleSubmit, reset } = useForm(); const { registrationMode, isPasswordResetEnabled, isEmailAuthenticationEnabled } = adminLocalSecurityContainer.state; const { isLocalEnabled } = adminGeneralSecurityContainer.state; useEffect(() => { reset({ registrationWhitelist: adminLocalSecurityContainer.state.registrationWhitelist.join('\n'), }); }, [reset, adminLocalSecurityContainer.state.registrationWhitelist]); const onSubmit = useCallback(async(data) => { try { await adminLocalSecurityContainer.changeRegistrationWhitelist(data.registrationWhitelist); await adminLocalSecurityContainer.updateLocalSecuritySetting(); await adminGeneralSecurityContainer.retrieveSetupStratedies(); toastSuccess(t('security_settings.updated_general_security_setting')); } catch (err) { toastError(err); } }, [t, adminGeneralSecurityContainer, adminLocalSecurityContainer]); return ( <> {adminLocalSecurityContainer.state.retrieveError != null && (
{t('Error occurred')} : {adminLocalSecurityContainer.state.retrieveError}