UNPKG

edv-product-card

Version:

Este es un paquete de pruebas de despliegue en NPM

50 lines (37 loc) 1.27 kB
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 } }