osmg-product-card
Version:
This is a testing package for a npm deploy
48 lines (37 loc) • 1.21 kB
text/typescript
import { useEffect, useState, useRef } from 'react';
import { InitialValues, onChangeArgs, Product } 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);
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( value )
}, [value])
useEffect(() => {
isMounted.current = true;
}, [])
return {
counter,
isMaxCountReached: !!initialValues?.count && initialValues.maxCount === counter,
maxCount: initialValues?.maxCount,
reset,
increaseBy,
};
};