Payment.js 14 KB
Newer Older
Jiwon Yoon's avatar
Jiwon Yoon committed
1
import axios from 'axios';
Kim, Subin's avatar
Kim, Subin committed
2
import React, { useState, useEffect, useRef } from 'react';
Jiwon Yoon's avatar
Jiwon Yoon committed
3
import DaumPostcode from "react-daum-postcode";
Jiwon Yoon's avatar
Jiwon Yoon committed
4
import { Container, Card, Row, Col, Button, Form, FormGroup } from 'react-bootstrap';
5
import { Redirect, Link, useHistory } from 'react-router-dom';
Jiwon Yoon's avatar
Jiwon Yoon committed
6
7
8
import PaymentCard from '../Components/PaymentCard';
import { isAuthenticated } from '../utils/auth';
import catchErrors from '../utils/catchErrors';
Kim, Subin's avatar
Kim, Subin committed
9

Jiwon Yoon's avatar
Jiwon Yoon committed
10
function Payment({ match, location }) {
Kim, Subin's avatar
Kim, Subin committed
11

Jiwon Yoon's avatar
Jiwon Yoon committed
12
    const [cart, setCart] = useState([])
13
    const [order, setOrder] = useState({ products: [] })
Jiwon Yoon's avatar
Jiwon Yoon committed
14
15
    const [userData, setUserData] = useState({})
    const [error, setError] = useState()
16
    const [paymentWay, setPaymentWay] = useState([])
Jiwon Yoon's avatar
Jiwon Yoon committed
17
    const [post, setPost] = useState([])
Jiwon Yoon's avatar
Jiwon Yoon committed
18
19
    const [redirect, setRedirect] = useState(null)
    const [address, setAddress] = useState("")
Jiwon Yoon's avatar
Jiwon Yoon committed
20
    const [finalPrice, setFinalPrice] = useState(0)
Jiwon Yoon's avatar
Jiwon Yoon committed
21
    const [completeState, setCompleteState] = useState(false)
Jiwon Yoon's avatar
Jiwon Yoon committed
22
    const user = isAuthenticated()
23
    let history = useHistory();
Jiwon Yoon's avatar
?    
Jiwon Yoon committed
24
    const preCart = []
Jiwon Yoon's avatar
Jiwon Yoon committed
25
26
27

    useEffect(() => {
        getUser()
Jiwon Yoon's avatar
Jiwon Yoon committed
28
29
30
31
        getCart()
    }, [user])

    useEffect(() => {
Jiwon Yoon's avatar
Jiwon Yoon committed
32
33
34
35
36
        let price = 0
        cart.map((el) => {
            price = Number(el.count) * Number(el.productId.price) + price
        })
        setFinalPrice(price)
Jiwon Yoon's avatar
Jiwon Yoon committed
37
    }, [cart])
Jiwon Yoon's avatar
Jiwon Yoon committed
38
39

    async function getUser() {
40
41
        const name = localStorage.getItem('name')
        const tel = localStorage.getItem('tel')
Jiwon Yoon's avatar
Jiwon Yoon committed
42
        const email = localStorage.getItem('email')
43
        setUserData({ name: name, tel: tel, email: email })
Jiwon Yoon's avatar
Jiwon Yoon committed
44
45
    }

Jiwon Yoon's avatar
Jiwon Yoon committed
46
47
    async function getCart() {
        try {
48
            setError('')
Jiwon Yoon's avatar
Jiwon Yoon committed
49
50
            const response = await axios.get(`/api/cart/showcart/${user}`)
            console.log(response.data)
51
52
            const preCart = response.data.filter((el) => el.checked === true)
            if (preCart.length) {
Jiwon Yoon's avatar
?    
Jiwon Yoon committed
53
                setCart(preCart)
54
                setOrder({ products: preCart })
Jiwon Yoon's avatar
?    
Jiwon Yoon committed
55
            } else {
56
57
                alert("주문하실 상품이 없습니다.")
                history.push("/home")
Jiwon Yoon's avatar
?    
Jiwon Yoon committed
58
            }
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
        } catch (error) {
            catchErrors(error, setError)
        }
    }

    async function deleteOrder(e) {
        try {
            setError('')
            const response = await axios.post('/api/cart/deletecart', {
                userId: user,
                cartId: e.target.name
            })
            console.log(response.data)
            const preCart = response.data.products.filter((el) => el.checked === true)
            setCart(preCart)
74
            setOrder({ products: preCart })
Jiwon Yoon's avatar
Jiwon Yoon committed
75
76
77
78
79
        } catch (error) {
            catchErrors(error, setError)
        }
    }

Jiwon Yoon's avatar
Jiwon Yoon committed
80
81
    function handleReceiverInfo(e) {
        const { name, value } = e.target
Jiwon Yoon's avatar
Jiwon Yoon committed
82
83
        console.log(name, value)
        setOrder({ ...order, receiverInfo: { ...order.receiverInfo, [name]: value } })
Jiwon Yoon's avatar
Jiwon Yoon committed
84
    }
Jiwon Yoon's avatar
Jiwon Yoon committed
85
86
87
88
89
90
91
92

    function postClick() {
        if (post.length !== 0) {
            setPost([])
        }
        else {
            setPost(
                <div>
Jiwon Yoon's avatar
Jiwon Yoon committed
93
                    <DaumPostcode style={postCodeStyle} onComplete={handleComplete} autoClose={true} />
Jiwon Yoon's avatar
Jiwon Yoon committed
94
95
96
97
98
99
100
101
                </div>
            )
        }

    }
    const handleComplete = (data) => {
        let fullAddress = data.address;
        let extraAddress = "";
Jiwon Yoon's avatar
Jiwon Yoon committed
102
        console.log(data)
Jiwon Yoon's avatar
Jiwon Yoon committed
103
104
105
        if (data.addressType === "R") {
            if (data.bname !== "") {
                extraAddress += data.bname;
Jiwon Yoon's avatar
Jiwon Yoon committed
106
                console.log(extraAddress)
Jiwon Yoon's avatar
Jiwon Yoon committed
107
108
109
110
111
112
113
            }
            if (data.buildingName !== "") {
                extraAddress +=
                    extraAddress !== "" ? `, ${data.buildingName}` : data.buildingName;
            }
            fullAddress += extraAddress !== "" ? ` (${extraAddress})` : "";
        }
Jiwon Yoon's avatar
Jiwon Yoon committed
114
        setAddress({ full: fullAddress, code: data.zonecode });
Jiwon Yoon's avatar
Jiwon Yoon committed
115
        setOrder({ ...order, receiverInfo: { ...order.receiverInfo, address: fullAddress, postalCode: data.zonecode } })
Jiwon Yoon's avatar
Jiwon Yoon committed
116
117
118
        console.log(fullAddress);
    }

Jiwon Yoon's avatar
Jiwon Yoon committed
119
    const postCodeStyle = {
Jiwon Yoon's avatar
Jiwon Yoon committed
120
        // display: "block",
Jiwon Yoon's avatar
Jiwon Yoon committed
121
122
123
124
        position: "absolute",
        width: "400px",
        height: "500px",
        padding: "7px",
Jiwon Yoon's avatar
Jiwon Yoon committed
125
        zIndex: "1000"
Jiwon Yoon's avatar
Jiwon Yoon committed
126
    };
127
128
129

    function handleClick() {
        if (paymentWay.length !== 0) {
Jiwon Yoon's avatar
Jiwon Yoon committed
130
            setCompleteState(false)
131
132
133
134
            setPaymentWay([])
        }
        else {
            const a = (
135
136
                <Row className="justify-content-md-center">
                    <Col md={6} className="border m-5 p-5">
Jiwon Yoon's avatar
Jiwon Yoon committed
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
                        <Form>
                            <Form.Group controlId="exampleForm.ControlSelect1">
                                <Form.Label>입금은행</Form.Label>
                                <Form.Control as="select" placeholder="입금은행을 선택하세요.">
                                    <option>농협 / 352-0559-2528-83 / 김수빈</option>
                                    <option>우리은행 / 0000-000-000000 / 이재연</option>
                                    <option>국민은행 / 111111-11-111111 / 윤대기</option>
                                </Form.Control>
                            </Form.Group>
                            <Form.Group controlId="formName">
                                <Form.Label>입금자</Form.Label>
                                <Form.Control type="email" placeholder="윤지원" />
                            </Form.Group>
                            <Form.Group controlId="formDay">
                                <Form.Label>입금예정일</Form.Label>
                                <Form.Control type="date" />
                            </Form.Group>
                        </Form>
155
                    </Col>
Jiwon Yoon's avatar
Jiwon Yoon committed
156

157
                </Row>)
158
            setPaymentWay(a)
Jiwon Yoon's avatar
Jiwon Yoon committed
159
            setCompleteState(true)
160
161
162
        }
    }

Jiwon Yoon's avatar
Jiwon Yoon committed
163
    async function kakaopay() {
Jiwon Yoon's avatar
Jiwon Yoon committed
164
        let itemNames = ""
165
166
        if (cart.length > 1) {
            itemNames = cart[0].productId.pro_name + '' + String(cart.length - 1) + ''
Jiwon Yoon's avatar
Jiwon Yoon committed
167
168
169
        } else {
            itemNames = cart[0].productId.pro_name
        }
170
171
172
173
174
175
176
177
178
179
180
181
182
183
        const response = await fetch('/api/kakaopay/test/single', {
            method: "POST",
            headers: {
                'Content-type': 'application/json'
            },
            body: JSON.stringify({
                cid: 'TC0ONETIME',
                partner_order_id: 'partner_order_id',
                partner_user_id: user,
                item_name: itemNames,
                quantity: cart.length,
                total_amount: finalPrice + 2500,
                vat_amount: 200,
                tax_free_amount: 0,
184
185
186
                approval_url: 'http://localhost:3000/paymentcompleted',
                fail_url: 'http://localhost:3000/shoppingcart',
                cancel_url: 'http://localhost:3000/shoppingcart',
Jiwon Yoon's avatar
Jiwon Yoon committed
187
            })
188
        })
Jiwon Yoon's avatar
Jiwon Yoon committed
189
        const data = await response.json()
190
        if (data) {
Jiwon Yoon's avatar
Jiwon Yoon committed
191
192
            setCompleteState(true)
        }
Jiwon Yoon's avatar
Jiwon Yoon committed
193
194
195
        window.location.href = data.redirect_url
        // setRedirect(data.redirect_url)
    }
196

Jiwon Yoon's avatar
Jiwon Yoon committed
197
    async function paymentCompleted() {
Jiwon Yoon's avatar
Jiwon Yoon committed
198
        console.log(order)
199
200
201
202
        const cartIds = []
        order.products.map((el) => {
            cartIds.push(el._id)
        })
Jiwon Yoon's avatar
Jiwon Yoon committed
203
        try {
204
            setError('')
Jiwon Yoon's avatar
Jiwon Yoon committed
205
            const response = await axios.post(`/api/order/addorder`, {
Jiwon Yoon's avatar
Jiwon Yoon committed
206
                userId: user,
Jiwon Yoon's avatar
Jiwon Yoon committed
207
                ...order,
Jiwon Yoon's avatar
Jiwon Yoon committed
208
                total: finalPrice + 2500
Jiwon Yoon's avatar
Jiwon Yoon committed
209
            })
210
211
212
213
214
215
216
            const response2 = await axios.post(`/api/cart/deletecart2`, {
                userId: user,
                cartId: cartIds
            })
            const response3 = await axios.post(`/api/product/pluspurchase`, {
                products: order.products
            })
Jiwon Yoon's avatar
Jiwon Yoon committed
217
            console.log(response.data)
218
219
            console.log(response2.data)
            console.log(response3.data)
220
            alert("주문이 완료되었습니다.")
221
            history.push('/paymentcompleted')
Jiwon Yoon's avatar
Jiwon Yoon committed
222
223
        } catch (error) {
            catchErrors(error, setError)
224
            alert("주문에 실패하셨습니다. 다시 확인해주세요.")
225
226
        }
    }
Jiwon Yoon's avatar
Jiwon Yoon committed
227

Kim, Subin's avatar
Kim, Subin committed
228
229
    return (
        <div>
230
            {/* {console.log(completeState)} */}
231
            <Container>
Jiwon Yoon's avatar
Jiwon Yoon committed
232
                <h3 className="my-5 font-weight-bold text-center">주문/결제</h3>
233
                <div>
Jiwon Yoon's avatar
Jiwon Yoon committed
234
                    <h5 className="font-weight-bold py-3 border-top border-bottom text-center" style={{ background: '#F7F3F3' }}>주문자 정보</h5>
235
236
237
238
239
                    <Row className="justify-content-md-center">
                        <Col md={4}>
                            <Form>
                                <Form.Group controlId="formBasicName">
                                    <Form.Label>이름</Form.Label>
Jiwon Yoon's avatar
Jiwon Yoon committed
240
                                    <Form.Control type="text" value={userData.name} readOnly />
241
242
243
                                </Form.Group>
                                <Form.Group controlId="formBasicTel">
                                    <Form.Label>휴대전화</Form.Label>
Jiwon Yoon's avatar
Jiwon Yoon committed
244
245
246
247
                                    <Form.Control type="tel" value={userData.tel} readOnly />
                                </Form.Group>
                                <Form.Group controlId="formBasicEmail">
                                    <Form.Label>이메일</Form.Label>
Jiwon Yoon's avatar
Jiwon Yoon committed
248
                                    <Form.Control type="email" value={userData.email} readOnly />
249
250
251
252
                                </Form.Group>
                            </Form>
                        </Col>
                    </Row>
253
254
255
                </div>

                <div>
Jiwon Yoon's avatar
Jiwon Yoon committed
256
257
258
259
260
261
                    <h5 className="font-weight-bold py-3 border-top border-bottom text-center" style={{ background: '#F7F3F3' }}>받는사람 정보</h5>
                    <Row className="justify-content-center">
                        <Col md={8}>
                            <Form>
                                <Form.Group>
                                    <Form.Label>이름</Form.Label>
Jiwon Yoon's avatar
Jiwon Yoon committed
262
263
264
265
266
                                    <Form.Control type="text" name="name" onChange={handleReceiverInfo}></Form.Control>
                                </Form.Group>
                                <Form.Group>
                                    <Form.Label>휴대전화</Form.Label>
                                    <Form.Control type="text" name="tel" onChange={handleReceiverInfo}></Form.Control>
Jiwon Yoon's avatar
Jiwon Yoon committed
267
268
269
270
271
                                </Form.Group>
                                <Form.Group controlId="formBasicAdd">
                                    <Form.Label>주소</Form.Label>
                                    <Form.Row>
                                        <Col xs={4} sm={4}>
Jiwon Yoon's avatar
Jiwon Yoon committed
272
                                            <Form.Control type="text" name="postalCode" id="add" onChange={handleReceiverInfo} value={address.code} disabled={(address.code == null) ? false : true} placeholder="우편번호" required ></Form.Control>
Jiwon Yoon's avatar
Jiwon Yoon committed
273
274
275
276
277
278
279
280
                                        </Col>
                                        <Col >
                                            <Button style={{ background: '#91877F', borderColor: '#91877F' }} className="mx-1" onClick={postClick}>우편번호</Button>
                                            {post}
                                        </Col>
                                    </Form.Row>
                                    <Form.Row>
                                        <Col>
Jiwon Yoon's avatar
Jiwon Yoon committed
281
282
                                            <Form.Control type="text" name="address" id="add1" onChange={handleReceiverInfo} value={address.full} disabled={(address.code == null) ? false : true} placeholder="주소" required></Form.Control>
                                            <Form.Control type="text" name="address2" id="add2" onChange={handleReceiverInfo} placeholder="상세주소" required></Form.Control>
Jiwon Yoon's avatar
Jiwon Yoon committed
283
284
285
286
287
                                            <Form.Control.Feedback type="invalid" > 상세 주소를 입력하세요. </Form.Control.Feedback>
                                        </Col>
                                    </Form.Row>
                                </Form.Group>
                            </Form>
Jiwon Yoon's avatar
Jiwon Yoon committed
288
289
                        </Col>
                    </Row>
290
291
292
                </div>

                <div>
Jiwon Yoon's avatar
Jiwon Yoon committed
293
                    <h5 className="font-weight-bold py-3 border-top border-bottom text-center" style={{ background: '#F7F3F3' }}>주문상품정보</h5>
294
                    <PaymentCard cart={cart} deleteOrder={deleteOrder} />
295
296
                </div>

Jiwon Yoon's avatar
Jiwon Yoon committed
297
                <div className="p-5 m-3" style={{ background: '#F7F3F3' }}>
298
299
300
                    <ul className="pl-0" style={{ listStyle: 'none' }}>
                        <li>
                            <span className="text-secondary"> 상품금액</span>
Jiwon Yoon's avatar
Jiwon Yoon committed
301
                            <span className="text-secondary float-right">{finalPrice}</span>
302
303
304
                        </li>
                        <li>
                            <span className="text-secondary">배송비</span>
Jiwon Yoon's avatar
Jiwon Yoon committed
305
                            <span className="text-secondary float-right">2500</span>
306
307
308
                        </li>
                    </ul>
                    <div className="my-1 pt-2 border-top font-weight-bold">
Jiwon Yoon's avatar
Jiwon Yoon committed
309
                        결제금액<span className="float-right">{finalPrice + 2500}</span>
310
311
312
313
                    </div>
                </div>

                <div>
Jiwon Yoon's avatar
Jiwon Yoon committed
314
                    <h5 className="font-weight-bold py-3 border-top border-bottom text-center" style={{ background: '#F7F3F3' }}>결제수단</h5>
315
                    <div className="text-center m-3">
Jiwon Yoon's avatar
Jiwon Yoon committed
316
                        <Button variant="success" className="align-top" onClick={handleClick} >무통장입금</Button>
317
                        <input type="image" alt="카카오페이결제" src="icon/payment_icon_yellow_small.png" onClick={kakaopay} />
318
319
                    </div>
                    {paymentWay}
Jiwon Yoon's avatar
Jiwon Yoon committed
320
321
                </div>
                <div className="text-center">
322
                    <Button type="button" onClick={paymentCompleted} disabled={!completeState} className="px-5" style={{ background: "#91877F", borderColor: '#91877F' }} block>결제완료</Button>
323
324
                </div>
            </Container>
Kim, Subin's avatar
Kim, Subin committed
325
326
327
328
329
        </div>
    )
}

export default Payment