UNPKG

react-jlm-product-card

Version:

This is a test package to deploy in NPM

57 lines (44 loc) 1.35 kB
//* libraries import { useEffect, useRef, useState } from "react"; //* interfaces import { onChangeArgs, Product, InitialValues } from "../interfaces/interfaces"; interface useProductArgs { product: Product; onChange?: (args: onChangeArgs) => void; value?: number; initialValues?: InitialValues; } export const useProduct = ({ onChange, product, value = 0, initialValues, }: useProductArgs) => { const [counter, setCounter] = useState<number>(initialValues?.count || value); const isMounted = useRef(false); useEffect(() => { if (!isMounted.current) return; setCounter(value); }, [value]); useEffect(() => { isMounted.current = true; }, []); const increaseBy = (value: number): void => { // if prev + value is < 0 then set counter to 0 let newValue = Math.max(counter + value, 0); if (initialValues?.maxCount) { newValue = Math.min(newValue, initialValues?.maxCount); } setCounter(newValue); onChange && onChange({ count: newValue, product: product }); }; const reset = () => setCounter(initialValues?.count || value); return { counter, isMaxCountReached: !!initialValues?.count && initialValues.maxCount === counter, maxCount: initialValues?.maxCount, increaseBy, reset, }; };