react-jlm-product-card
Version:
This is a test package to deploy in NPM
57 lines (44 loc) • 1.35 kB
text/typescript
//* 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,
};
};