1
0
mirror of https://github.com/LaCasemate/fab-manager.git synced 2025-01-10 00:46:15 +01:00
fab-manager/app/frontend/src/javascript/components/pricing/spaces/edit-extended-price.tsx

66 lines
2.1 KiB
TypeScript
Raw Normal View History

2021-12-21 17:13:40 +01:00
import React, { useState } from 'react';
2021-12-21 20:13:55 +01:00
import { FabModal } from '../../base/fab-modal';
2021-12-21 17:13:40 +01:00
import { ExtendedPriceForm } from './extended-price-form';
2021-12-21 20:13:55 +01:00
import { Price } from '../../../models/price';
import PriceAPI from '../../../api/price';
2021-12-21 17:13:40 +01:00
import { useTranslation } from 'react-i18next';
2021-12-21 20:13:55 +01:00
import { FabButton } from '../../base/fab-button';
2021-12-21 17:13:40 +01:00
interface EditExtendedPriceProps {
price: Price,
onSuccess: (message: string) => void,
onError: (message: string) => void
}
/**
* This component shows a button.
* When clicked, we show a modal dialog handing the process of creating a new extended price
*/
export const EditExtendedPrice: React.FC<EditExtendedPriceProps> = ({ price, onSuccess, onError }) => {
const { t } = useTranslation('admin');
const [isOpen, setIsOpen] = useState<boolean>(false);
const [extendedPriceData, setExtendedPriceData] = useState<Price>(price);
/**
* Open/closes the "edit extended price" modal dialog
*/
const toggleModal = (): void => {
setIsOpen(!isOpen);
};
/**
* When the user clicks on the edition button open te edition modal
*/
const handleRequestEdit = (): void => {
toggleModal();
};
/**
* Callback triggered when the user has validated the changes of the extended price
*/
const handleUpdate = (price: Price): void => {
PriceAPI.update(price)
.then(() => {
onSuccess(t('app.admin.edit_extendedPrice.extendedPrice_successfully_updated'));
setExtendedPriceData(price);
toggleModal();
})
.catch(error => onError(error));
};
return (
2021-12-22 17:25:02 +01:00
<div className="edit-group">
<FabButton type='button' icon={<i className="fas fa-edit" />} onClick={handleRequestEdit} />
2021-12-21 17:13:40 +01:00
<FabModal isOpen={isOpen}
toggleModal={toggleModal}
title={t('app.admin.edit_extendedPrice.edit_extendedPrice')}
closeButton
confirmButton={t('app.admin.edit_extendedPrice.confirm_changes')}
2021-12-22 17:25:02 +01:00
onConfirmSendFormId="edit-group">
{extendedPriceData && <ExtendedPriceForm formId="edit-group" onSubmit={handleUpdate} price={extendedPriceData} />}
2021-12-21 17:13:40 +01:00
</FabModal>
</div>
);
};