add to cart

This commit is contained in:
Tyrel Souza 2022-09-26 13:18:59 -04:00
parent 6915852524
commit 135e4a9a1d
No known key found for this signature in database
GPG Key ID: F3614B02ACBE438E
4 changed files with 77 additions and 11 deletions

View File

@ -1,8 +1,19 @@
import { useContext } from "react"
import classes from "./MealItem.module.css"
import MealItemForm from "./MealItemForm"
import CartContext from "../../../store/cart-context"
function MealItem(props) {
const price = `$${props.price.toFixed(2)}`
const cartContext = useContext(CartContext)
const price = `$${props.price.toFixed(2)}`
const addItemToCartHandler = (amount) => {
cartContext.addItem({
id: props.id,
name: props.name,
amount: amount,
price: props.price,
})
}
return (
<li className={classes.meal}>
<div>
@ -11,7 +22,10 @@ function MealItem(props) {
<div className={classes.price}>{price}</div>
</div>
<div>
<MealItemForm id={props.id}/>
<MealItemForm
id={props.id}
onAddToCart={addItemToCartHandler}
/>
</div>
</li>
)

View File

@ -1,13 +1,35 @@
import { useRef, useState } from "react"
import classes from "./MealItemForm.module.css"
import Input from "../../UI/Input"
function MealItemForm(props) {
const [amountIsValid, setAmountIsValid] = useState(true)
const amountInputRef = useRef()
const submitHandler = (event) => {
event.preventDefault()
const enteredAmount = amountInputRef.current.value
const enteredAmountNumber = +enteredAmount
if (
enteredAmount.trim().length === 0 ||
enteredAmountNumber < 1 ||
enteredAmountNumber > 5
) {
setAmountIsValid(false)
return
}
props.onAddToCart(enteredAmountNumber)
}
return (
<form className={classes.form}>
<form className={classes.form} onSubmit={submitHandler}>
<Input
ref={amountInputRef}
label="Amount"
input={{
id: "amount_" + props.id ,
id: "amount_" + props.id,
type: "number",
min: "1",
max: "5",
@ -16,6 +38,7 @@ function MealItemForm(props) {
}}
/>
<button>+ Add</button>
{!amountIsValid && <p>Please enter a valid amount (1-5)</p>}
</form>
)
}

View File

@ -1,11 +1,12 @@
import React from "react"
import classes from "./Input.module.css"
function Input(props) {
const Input = React.forwardRef((props, ref) => {
return (
<div className={classes.input}>
<label htmlFor={props.input.id}>{props.label}</label>
<input {...props.input} />
<input ref={ref} {...props.input} />
</div>
)
}
})
export default Input

View File

@ -1,12 +1,40 @@
import { useReducer } from "react"
import CartContext from "./cart-context"
const defaultCartState = {
items: [],
totalAmount: 0,
}
const cartReducer = (state, action) => {
if (action.type === "ADD") {
const updatedItems = state.items.concat(action.item)
const updatedTotalAmount =
state.totalAmount + action.item.price * action.item.amount
return {
items: updatedItems,
totalAmount: updatedTotalAmount,
}
}
return defaultCartState
}
const CartProvider = (props) => {
const addItemToCartHandler = (item) => {}
const removeItemToCartHandler = (id) => {}
const [cartState, dispatchCartAction] = useReducer(
cartReducer,
defaultCartState
)
const addItemToCartHandler = (item) => {
dispatchCartAction({ type: "ADD", item })
}
const removeItemToCartHandler = (id) => {
dispatchCartAction({ type: "REMOVE", id })
}
const cartContext = {
items: [],
totalAmount: 0,
items: cartState.items,
totalAmount: cartState.totalAmount,
addItem: addItemToCartHandler,
removeItem: removeItemToCartHandler,
}