PaymentCompletePage.js 3.16 KB
Newer Older
1
import { useEffect, useState } from 'react'
Jiwon Yoon's avatar
Jiwon Yoon committed
2
3
import axios from 'axios'
import moment from 'moment';
Kim, Subin's avatar
Kim, Subin committed
4
import { useAuth } from '../context/auth_context'
5
import catchErrors from '../utils/catchErrors'
한규민's avatar
한규민 committed
6
import reservationApi from '../apis/reservation.api'
7
8
9
10

const PaymentCompletePage = () => {
    const { user } = useAuth()
    const [error, setError] = useState()
Jiwon Yoon's avatar
Jiwon Yoon committed
11
12
    const [success, setSuccess] = useState(false)
    const [paymentData, setPaymentData] = useState()
Jiwon Yoon's avatar
Jiwon Yoon committed
13

14
    useEffect(() => {
Jiwon Yoon's avatar
Jiwon Yoon committed
15
        if (user.id > 0) {
Jiwon Yoon's avatar
Jiwon Yoon committed
16
17
            const tid = localStorage.getItem('tid')
            approveKakaopay(tid)
Jiwon Yoon's avatar
Jiwon Yoon committed
18
19
20
21
22
            if (user.role === "member") {
                saveUserReservation()
            } else {
                saveGuestReservation()
            }
23
24
25
        }
    }, [user])

Jiwon Yoon's avatar
Jiwon Yoon committed
26
    async function saveGuestReservation() {
27
        try {
Jiwon Yoon's avatar
Jiwon Yoon committed
28
            const response = await axios.get(`/api/auth/guestinfo/${user.id}`);
Jiwon Yoon's avatar
Jiwon Yoon committed
29
            const response2 = await reservationApi.findOneReservation()
Jiwon Yoon's avatar
Jiwon Yoon committed
30
31
32
33
34
35
36
37
38
39
40
41
            console.log("예매내역=====", response2)
            if (response.data || response2) {
                const responseEmail = await axios.post('/api/email/send', {
                    reservationData: response2.map(el => { return { "row": el.row, "col": el.col } }),
                    userData: { ...response.data },
                    cinema: "Butter Studio 조치원",
                    title: response2[0].title,
                    theater: response2[0].theater.theaterName,
                    time: response2[0].timetable.date.split('T')[0] + ' ' + moment(response2[0].timetable.start_time).format('HH:mm')
                })
                console.log(responseEmail.data)
            }
42
43
44
45
46
        } catch (error) {
            catchErrors(error, setError)
        }
    }

Jiwon Yoon's avatar
Jiwon Yoon committed
47
    async function saveUserReservation() {
48
49
50
51
        try {
            const response = await axios.post(`/api/auth/getuserinfo`, {
                id: user.id
            })
Jiwon Yoon's avatar
Jiwon Yoon committed
52

Jiwon Yoon's avatar
Jiwon Yoon committed
53
54
55
56
57
58
59
60
            // if (response.data) {
            //     const responseEmail = await axios.post('/api/email/send', {
            //         ...response2.data,
            //         ...response.data,

            //     })
            //     console.log(responseEmail.data)
            // }
61
62
63
64
65
        } catch (error) {
            catchErrors(error, setError)
        }
    }

Jiwon Yoon's avatar
Jiwon Yoon committed
66
67
    async function approveKakaopay(tid) {
        try {
Jiwon Yoon's avatar
Jiwon Yoon committed
68
69
70
71
72
73
74
75
76
77
            const urlParams = new URLSearchParams(window.location.search);
            const pg_token = urlParams.get('pg_token');
            const response = await axios.post(`/api/kakaopay/success`, {
                'tid': tid,
                cid: 'TC0ONETIME',
                partner_order_id: 'butter_studio',
                partner_user_id: '000000' + user.id,
                pg_token: pg_token
            })
            setPaymentData(response.data)
Jiwon Yoon's avatar
Jiwon Yoon committed
78
79
80
81
82
        } catch (error) {
            catchErrors(error, setError)
        }
    }

83
84
85
86
    return (
        <div className="text-center">
            <h3>예매가 정상적으로 완료되었습니다.</h3>
            <button>홈으로</button>
Kim, Subin's avatar
Kim, Subin committed
87
            {user.role === "member" ? <button>마이페이지</button> : <></>}
88
89
90
91
92
        </div>
    )
}

export default PaymentCompletePage