/*
This file is part of GNU Taler
(C) 2021-2023 Taler Systems S.A.
GNU Taler is free software; you can redistribute it and/or modify it under the
terms of the GNU General Public License as published by the Free Software
Foundation; either version 3, or (at your option) any later version.
GNU Taler is distributed in the hope that it will be useful, but WITHOUT ANY
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with
GNU Taler; see the file COPYING. If not, see
*/
/**
*
* @author Sebastian Javier Marchano (sebasjm)
*/
import { useTranslationContext } from "@gnu-taler/web-util/lib/index.browser";
import { Fragment, h } from "preact";
import { useLayoutEffect, useState } from "preact/hooks";
import { MerchantBackend, Timestamp } from "../../declaration.js";
import { FormErrors, FormProvider } from "./FormProvider.js";
import { InputDate } from "./InputDate.js";
import { InputGroup } from "./InputGroup.js";
import { InputLocation } from "./InputLocation.js";
import { InputNumber } from "./InputNumber.js";
import { InputProps, useField } from "./useField.js";
export interface Props extends InputProps {
alreadyExist?: boolean;
}
type Entity = Stock;
export interface Stock {
current: number;
lost: number;
sold: number;
address?: MerchantBackend.Location;
nextRestock?: Timestamp;
}
interface StockDelta {
incoming: number;
lost: number;
}
export function InputStock({
name,
tooltip,
label,
alreadyExist,
}: Props) {
const { error, value, onChange } = useField(name);
const [errors, setErrors] = useState>({});
const [formValue, valueHandler] = useState>(value);
const [addedStock, setAddedStock] = useState({
incoming: 0,
lost: 0,
});
const { i18n } = useTranslationContext();
useLayoutEffect(() => {
if (!formValue) {
onChange(undefined as any);
} else {
onChange({
...formValue,
current: (formValue?.current || 0) + addedStock.incoming,
lost: (formValue?.lost || 0) + addedStock.lost,
} as any);
}
}, [formValue, addedStock]);
if (!formValue) {
return (
{!alreadyExist ? (
) : (
)}
);
}
const currentStock =
(formValue.current || 0) - (formValue.lost || 0) - (formValue.sold || 0);
const stockAddedErrors: FormErrors = {
lost:
currentStock + addedStock.incoming < addedStock.lost
? i18n.str`lost cannot be greater than current and incoming (max ${
currentStock + addedStock.incoming
})`
: undefined,
};
// const stockUpdateDescription = stockAddedErrors.lost ? '' : (
// !!addedStock.incoming || !!addedStock.lost ?
// i18n.str`current stock will change from ${currentStock} to ${currentStock + addedStock.incoming - addedStock.lost}` :
// i18n.str`current stock will stay at ${currentStock}`
// )
return (