import React, { useState } from 'react'; import { FabModal } from '../../base/fab-modal'; import { ExtendedPriceForm } from './extended-price-form'; import { Price } from '../../../models/price'; import PriceAPI from '../../../api/price'; import { useTranslation } from 'react-i18next'; import { FabButton } from '../../base/fab-button'; 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 = ({ price, onSuccess, onError }) => { const { t } = useTranslation('admin'); const [isOpen, setIsOpen] = useState(false); const [extendedPriceData, setExtendedPriceData] = useState(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_extended_price.extended_price_successfully_updated')); setExtendedPriceData(price); toggleModal(); }) .catch(error => onError(error)); }; return (
} onClick={handleRequestEdit} /> {extendedPriceData && }
); };