-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathCart.js
More file actions
94 lines (79 loc) · 2.58 KB
/
Cart.js
File metadata and controls
94 lines (79 loc) · 2.58 KB
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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
import {Fragment, useContext, useState} from 'react';
import Modal from '../UI/Modal';
import CartItem from './CartItem';
import classes from './Cart.module.css';
import CartContext from '../../store/cart-context';
import Checkout from "./Checkout";
const Cart = (props) => {
const [isCheckout,setIsCheckout] = useState(false)
const [isSubmitting,setIsSubmitting] =useState(false)
const [didSubmit,setDidSubmit] =useState(false)
const cartCtx = useContext(CartContext);
const totalAmount = `$${cartCtx.totalAmount.toFixed(2)}`;
const hasItems = cartCtx.items.length > 0;
const cartItemRemoveHandler = (id) => {
cartCtx.removeItem(id);
};
const cartItemAddHandler = (item) => {
cartCtx.addItem(item);
};
const orderHandler =()=>{
setIsCheckout(true)
}
const submitOrderHandler =async (userData) => {
setIsSubmitting(true)
await fetch('https://react-tasks-731ef-default-rtdb.firebaseio.com/orders.json', {
method: "POST",
body: JSON.stringify({
user: userData,
orderedItems: cartCtx.items
})
})
setIsSubmitting(false)
setDidSubmit(true)
cartCtx.clearCart()
}
const cartItems = (
<ul className={classes['cart-items']}>
{cartCtx.items.map((item) => (
<CartItem
key={item.id}
name={item.name}
amount={item.amount}
price={item.price}
onRemove={cartItemRemoveHandler.bind(null, item.id)}
onAdd={cartItemAddHandler.bind(null, item)}
/>
))}
</ul>
);
const modelActions = (<div className={classes.actions}>
<button className={classes['button--alt']} onClick={props.onClose}>
Close
</button>
{hasItems && <button className={classes.button} onClick={orderHandler}>Order</button>}
</div>)
const cartModelContent = (<Fragment> {cartItems}
<div className={classes.total}>
<span>Total Amount</span>
<span>{totalAmount}</span>
</div>
{isCheckout && <Checkout onConfirm ={submitOrderHandler} onCancel={props.onClose}/>}
{!isCheckout && modelActions}</Fragment>)
const isSubmittingModelContent =<p>Sending order data...</p>
const didSumbitModelContent =(<Fragment><p>Successfully sent the order !</p>
<div className={classes.actions}>
<button className={classes.button} onClick={props.onClose}>
Close
</button>
</div>
</Fragment>)
return (
<Modal onClose={props.onClose}>
{!isSubmitting && !didSubmit &&cartModelContent}
{isSubmitting &&isSubmittingModelContent}
{!isSubmitting && didSubmit && didSumbitModelContent}
</Modal>
);
};
export default Cart;