AddToCart.tsx 1.08 KB
Newer Older
mayi's avatar
mayi committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38
import * as React from 'react';
import { Component ,useContext} from 'react';
import {appSetStateContext} from '../AppState'
import {Robotprops} from './robots'
export const withAddToCart =(ChildComponent:React.ComponentType<Robotprops>)=>{
    return (props)=>{
        const setState = useContext(appSetStateContext);
        const addToCart = (id,name) => {
          if (setState) {
            setState((state) => {
              return {
                ...state,
                shoppingCart: {
                  items: [...state.shoppingCart.items, { id, name }],
                },
              };
            });
          }
        };
        return <ChildComponent {...props} addToCart={addToCart}/>
    }
}
export const useAddToCart =() =>{
    const setState = useContext(appSetStateContext);
    const addToCart = (id,name) => {
      if (setState) {
        setState((state) => {
          return {
            ...state,
            shoppingCart: {
              items: [...state.shoppingCart.items, { id, name }],
            },
          };
        });
      }
    };
    return addToCart;
}