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/editable-price.tsx

57 lines
1.8 KiB
TypeScript
Raw Normal View History

import React, { useState } from 'react';
import { IFablab } from '../../models/fablab';
import { FabInput } from '../base/fab-input';
import { FabButton } from '../base/fab-button';
import { Price } from '../../models/price';
declare var Fablab: IFablab;
interface EditablePriceProps {
price: Price,
onSave: (price: Price) => void,
}
/**
* Display the given price.
* When the user clics on the price, switch to the edition mode to allow him modifying the price.
*/
export const EditablePrice: React.FC<EditablePriceProps> = ({ price, onSave }) => {
const [edit, setEdit] = useState<boolean>(false);
2021-06-22 17:56:13 +02:00
const [tempPrice, setTempPrice] = useState<string>(`${price.amount}`);
/**
* Return the formatted localized amount for the price (eg. 20.5 => "20,50 €")
*/
const formatPrice = (): string => {
return new Intl.NumberFormat(Fablab.intl_locale, { style: 'currency', currency: Fablab.intl_currency }).format(price.amount);
}
/**
* Saves the new price
*/
const handleValidateEdit = (): void => {
const newPrice: Price = Object.assign({}, price);
2021-06-22 17:56:13 +02:00
newPrice.amount = parseFloat(tempPrice);
onSave(newPrice);
2021-06-22 17:56:13 +02:00
toggleEdit();
}
/**
* Enable or disable the edit mode
*/
2021-06-22 17:56:13 +02:00
const toggleEdit = (): void => {
setEdit(!edit);
}
return (
<span className="editable-price">
{!edit && <span className="display-price" onClick={toggleEdit}>{formatPrice()}</span>}
{edit && <span>
2021-06-22 17:56:13 +02:00
<FabInput id="price" type="number" step={0.01} defaultValue={price.amount} addOn={Fablab.intl_currency} onChange={setTempPrice} required/>
<FabButton icon={<i className="fas fa-check" />} className="approve-button" onClick={handleValidateEdit} />
<FabButton icon={<i className="fas fa-times" />} className="cancel-button" onClick={toggleEdit} />
</span>}
</span>
);
}