2021-12-21 17:13:40 +01:00
|
|
|
import React, { useState } from 'react';
|
|
|
|
import { useTranslation } from 'react-i18next';
|
2021-12-21 20:13:55 +01:00
|
|
|
import { FabButton } from '../../base/fab-button';
|
|
|
|
import { FabModal } from '../../base/fab-modal';
|
|
|
|
import { Price } from '../../../models/price';
|
|
|
|
import PriceAPI from '../../../api/price';
|
2021-12-21 17:13:40 +01:00
|
|
|
|
|
|
|
interface DeleteExtendedPriceProps {
|
|
|
|
onSuccess: (message: string) => void,
|
|
|
|
onError: (message: string) => void,
|
|
|
|
price: Price,
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This component shows a button.
|
|
|
|
* When clicked, we show a modal dialog to ask the user for confirmation about the deletion of the provided extended price.
|
|
|
|
*/
|
|
|
|
export const DeleteExtendedPrice: React.FC<DeleteExtendedPriceProps> = ({ onSuccess, onError, price }) => {
|
|
|
|
const { t } = useTranslation('admin');
|
|
|
|
|
|
|
|
const [deletionModal, setDeletionModal] = useState<boolean>(false);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Opens/closes the deletion modal
|
|
|
|
*/
|
|
|
|
const toggleDeletionModal = (): void => {
|
|
|
|
setDeletionModal(!deletionModal);
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The deletion has been confirmed by the user.
|
|
|
|
* Call the API to trigger the deletion of the temporary set extended price
|
|
|
|
*/
|
|
|
|
const onDeleteConfirmed = (): void => {
|
|
|
|
PriceAPI.destroy(price.id).then(() => {
|
|
|
|
onSuccess(t('app.admin.delete_extendedPrice.extendedPrice_deleted'));
|
|
|
|
}).catch((error) => {
|
|
|
|
onError(t('app.admin.delete_extendedPrice.unable_to_delete') + error);
|
|
|
|
});
|
|
|
|
toggleDeletionModal();
|
|
|
|
};
|
|
|
|
|
|
|
|
return (
|
2021-12-22 17:25:02 +01:00
|
|
|
<div className="delete-group">
|
|
|
|
<FabButton type='button' className="delete-group-button" icon={<i className="fa fa-trash" />} onClick={toggleDeletionModal} />
|
2021-12-21 17:13:40 +01:00
|
|
|
<FabModal title={t('app.admin.delete_extendedPrice.delete_extendedPrice')}
|
|
|
|
isOpen={deletionModal}
|
|
|
|
toggleModal={toggleDeletionModal}
|
|
|
|
closeButton={true}
|
|
|
|
confirmButton={t('app.admin.delete_extendedPrice.confirm_delete')}
|
|
|
|
onConfirm={onDeleteConfirmed}>
|
|
|
|
<span>{t('app.admin.delete_extendedPrice.delete_confirmation')}</span>
|
|
|
|
</FabModal>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
};
|