PaymentCompletePage.js 3.16 KB
Newer Older
1
2
3
4
import axios from 'axios'
import { useAuth } from '../context/auth_context'
import { useEffect, useState } from 'react'
import catchErrors from '../utils/catchErrors'
한규민's avatar
한규민 committed
5
import reservationApi from '../apis/reservation.api'
6
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
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
            const response = await axios.get(`/api/auth/guestinfo/${user.id}`);
            // const response2 = await reservationApi.save({
            //     userType: "guest",
            //     user: user.id,
            //     ...paymentData,
            //     timetableId: 1
            // })
            // if (response.data) {
            //     const responseEmail = await axios.post('/api/email/send', {
            //         reservationData: [...response2.data],
            //         userData: { ...response.data },
            //         cinema: "Butter Studio 조치원",
            //         title: "더 수어사이드 스쿼드",
            //         theater: "1",
            //         time: "2021/07/21 10:00"
            //     })
            //     console.log(responseEmail.data)
            // }
            console.log(response.data)
47
48
49
50
51
        } catch (error) {
            catchErrors(error, setError)
        }
    }

Jiwon Yoon's avatar
Jiwon Yoon committed
52
    async function saveUserReservation() {
53
54
55
56
        try {
            const response = await axios.post(`/api/auth/getuserinfo`, {
                id: user.id
            })
Jiwon Yoon's avatar
Jiwon Yoon committed
57

Jiwon Yoon's avatar
Jiwon Yoon committed
58
59
60
61
62
63
64
65
            // if (response.data) {
            //     const responseEmail = await axios.post('/api/email/send', {
            //         ...response2.data,
            //         ...response.data,

            //     })
            //     console.log(responseEmail.data)
            // }
66
67
68
69
70
        } catch (error) {
            catchErrors(error, setError)
        }
    }

Jiwon Yoon's avatar
Jiwon Yoon committed
71
72
    async function approveKakaopay(tid) {
        try {
Jiwon Yoon's avatar
Jiwon Yoon committed
73
74
75
76
77
78
79
80
81
82
            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
83
84
85
86
87
        } catch (error) {
            catchErrors(error, setError)
        }
    }

88
89
90
91
92
93
94
95
96
97
98
99
    return (
        <div className="text-center">
            <h3>예매가 정상적으로 완료되었습니다.</h3>
            <button>홈으로</button>
            {
                user.role === "member" ? <button>마이페이지</button> : <></>
            }
        </div>
    )
}

export default PaymentCompletePage