edv-product-card
Version:
Este es un paquete de pruebas de despliegue en NPM
50 lines (37 loc) • 1.27 kB
text/typescript
import { useEffect, useRef, useState } from "react"
import { Product, onChangeArgs, InitialValues } from '../interfaces';
interface useProductArgs{
product: Product;
onChange?: (args: onChangeArgs) => void;
value?: number;
initialValues?: InitialValues;
}
export const useProduct = ({ product, onChange, value = 0, initialValues } : useProductArgs) => {
const [counter, setCounter] = useState<number>(initialValues?.count || value);
const isMounted = useRef(false);
const increaseBy = (value:number) => {
let newValue = Math.max(counter + value, 0);
if(initialValues?.maxCount){
newValue = Math.min(newValue, initialValues.maxCount)
}
setCounter(newValue);
onChange && onChange({count: newValue, product});
}
const reset = () => {
setCounter(initialValues?.count || value)
}
useEffect(() => {
if(!isMounted.current) return;
setCounter(initialValues?.count || value);
}, [value])
useEffect(() => {
isMounted.current = true;
}, [])
return{
counter,
isMaxCountReached: !!initialValues?.maxCount && initialValues.maxCount === counter,
maxCount: initialValues?.maxCount,
increaseBy,
reset
}
}