vm-product-card
Version:
Este es un paquete de pruebas de desplieque en NPM
48 lines (40 loc) • 1.21 kB
text/typescript
import { ButtonProps } from "../components/ProductButtons";
import { Props as ProductCardProps } from "../components/ProductCard";
import { Props as ImageProps } from "../components/ProductImage";
import { ProductTitleProps } from "../components/ProductTitle";
export interface Product {
id: string;
title: string;
img?: string;
}
export interface ProductContextProps {
count: number;
increaseBy: (value: number) => void;
product: Product;
maxCount?: number
}
export interface ProductCardHOCProps {
({ children, product }: ProductCardProps): JSX.Element;
Title: ({ title, className }: ProductTitleProps) => JSX.Element;
Image: ({ img, className }: ImageProps) => JSX.Element;
Buttons: ({ className }: ButtonProps) => JSX.Element;
}
export interface onChangeArgs {
product: Product,
count: number
}
export interface ProductInCart extends Product {
count: number;
}
export interface InitialValues {
count?: number
maxCount?: number
}
export interface ProductCartHandlers {
count: number;
isMaxCountReaced?: boolean;
maxCount?: number;
product: Product;
increaseBy: (value: number) => void;
reset: () => void
}