import React from 'react';
import PropTypes from 'prop-types';
import { useTranslation } from 'react-i18next';
import {
Modal,
ModalHeader,
ModalBody,
ModalFooter,
} from 'reactstrap';
import AppContainer from '~/client/services/AppContainer';
import PersonalContainer from '~/client/services/PersonalContainer';
import { toastSuccess, toastError } from '~/client/util/apiNotification';
import { withUnstatedContainers } from '../UnstatedUtils';
class DisassociateModal extends React.Component {
constructor(props) {
super(props);
this.onClickDisassociateBtn = this.onClickDisassociateBtn.bind(this);
}
async onClickDisassociateBtn() {
const { t, personalContainer } = this.props;
const { providerType, accountId } = this.props.accountForDisassociate;
try {
await personalContainer.disassociateLdapAccount({ providerType, accountId });
this.props.onClose();
toastSuccess(t('security_setting.updated_general_security_setting'));
}
catch (err) {
toastError(err);
}
try {
await personalContainer.retrieveExternalAccounts();
}
catch (err) {
toastError(err);
}
}
render() {
const { t, accountForDisassociate } = this.props;
const { providerType, accountId } = accountForDisassociate;
return (
{t('personal_settings.disassociate_external_account')}
{/* eslint-disable-next-line react/no-danger */}
);
}
}
DisassociateModal.propTypes = {
t: PropTypes.func.isRequired, // i18next
appContainer: PropTypes.instanceOf(AppContainer).isRequired,
personalContainer: PropTypes.instanceOf(PersonalContainer).isRequired,
isOpen: PropTypes.bool.isRequired,
onClose: PropTypes.func.isRequired,
accountForDisassociate: PropTypes.object.isRequired,
};
const DisassociateModalWrapperFC = (props) => {
const { t } = useTranslation();
return ;
};
/**
* Wrapper component for using unstated
*/
const DisassociateModalWrapper = withUnstatedContainers(DisassociateModalWrapperFC, [AppContainer, PersonalContainer]);
export default DisassociateModalWrapper;