dr-prod-card
Version:
Este es un paquete de prueba de despliegue en NPM
52 lines (41 loc) • 1.33 kB
text/typescript
import { Props as ProductCardProps } from '../components/ProductCard';
import { Props as ProductImageProps } from '../components/ProductImage';
import { Props as ProductTitleProps } from '../components/ProductTitle';
import { Props as ProductButtonsProps } from '../components/ProductButtons';
export interface Product {
id: string;
title: string;
img?: string;
}
export interface ProductContextProps {
product: Product;
increaseBy: (value: number) => void;
counter: number;
maxCount?: number;
}
//Para el patron compund component pattern
export interface ProductCardHOCProps {
({ children, product }: ProductCardProps): JSX.Element,
Title: (Props: ProductTitleProps) => JSX.Element,
Image: (Props: ProductImageProps) => JSX.Element,
Buttons: (Props: ProductButtonsProps) => JSX.Element
}
export interface onChangeArgs {
product: Product;
count: number;
}
export interface ProductInCart extends Product { //la interfaz va a contener todo lo que tenga la interface Produc
count: number
}
export interface InitialValues {
count?: number;
maxCount?: number;
}
export interface ProductCardHandlers {
count: number;
isMaxCountReached: boolean;
maxCount?: number;
product: Product;
increaseBy: (value: number) => void;
reset: () => void;
}