MovieChart.js 2.38 KB
Newer Older
Jiwon Yoon's avatar
Jiwon Yoon committed
1
import React, { useState, useEffect } from 'react'
Jiwon Yoon's avatar
Jiwon Yoon committed
2
import axios from 'axios'
Jiwon Yoon's avatar
Jiwon Yoon committed
3
import {baseUrl} from '../../utils/baseUrl.js'
Jiwon Yoon's avatar
Jiwon Yoon committed
4
import { Link } from 'react-router-dom';
Jiwon Yoon's avatar
Jiwon Yoon committed
5
import styles from "./movieChart.module.scss"
Jiwon Yoon's avatar
Jiwon Yoon committed
6

Jiwon Yoon's avatar
Jiwon Yoon committed
7
const MovieChart = () => {
Jiwon Yoon's avatar
Jiwon Yoon committed
8
9
10
11
12
13
    const [TMDB_TopRated_Data, setTMDB_TopRated_Data] = useState()
    useEffect(() => {
        getTMDB_TopRated()
    }, [])

    async function getTMDB_TopRated() {
Jiwon Yoon's avatar
Jiwon Yoon committed
14
        const category = "popular"
Jiwon Yoon's avatar
Jiwon Yoon committed
15
        try {
Jiwon Yoon's avatar
Jiwon Yoon committed
16
            const response = await axios.get(`${baseUrl}/api/movie/showmovie/${category}`)
Jiwon Yoon's avatar
Jiwon Yoon committed
17
            console.log(response.data)
Jiwon Yoon's avatar
Jiwon Yoon committed
18
            setTMDB_TopRated_Data([...response.data])
Jiwon Yoon's avatar
Jiwon Yoon committed
19
20
        } catch (error) {

Jiwon Yoon's avatar
Jiwon Yoon committed
21
        }
Jiwon Yoon's avatar
Jiwon Yoon committed
22
    }
Jiwon Yoon's avatar
Jiwon Yoon committed
23
24
    return (
        <div class="row row-cols-1 row-cols-md-4 g-4">
Jiwon Yoon's avatar
Jiwon Yoon committed
25
26
            {console.log(TMDB_TopRated_Data)}
            {TMDB_TopRated_Data
Jiwon Yoon's avatar
Jiwon Yoon committed
27
                ?
Jiwon Yoon's avatar
Jiwon Yoon committed
28
                TMDB_TopRated_Data.map(movie => (
Jiwon Yoon's avatar
Jiwon Yoon committed
29
                    <div className="card h-100" style={{ backgroundColor: "black" }}>
Jiwon Yoon's avatar
Jiwon Yoon committed
30
31
                        <Link to={{
                            pathname: `/movie/${movie.id}`,
Jiwon Yoon's avatar
Jiwon Yoon committed
32
                            state: {...movie}
Jiwon Yoon's avatar
Jiwon Yoon committed
33
                        }} className={`${styles.layer}`} >
Jiwon Yoon's avatar
Jiwon Yoon committed
34
                            <img src={`https://image.tmdb.org/t/p/original${movie.poster_path}`} className={`card-img-top rounded ${styles.poster}`} alt="Movie Poster" />
Jiwon Yoon's avatar
Jiwon Yoon committed
35
36
                            <div className={`${styles.description}`}>{movie.overview}</div>
                        </Link>
Jiwon Yoon's avatar
Jiwon Yoon committed
37
                        <div className="card-body text-light">
Jiwon Yoon's avatar
Jiwon Yoon committed
38
                            <marquee onmouseover="this.stop()" className={`h2 card-title text-center ${styles.title}`}>{movie.title}</marquee>
Jiwon Yoon's avatar
Jiwon Yoon committed
39
                            <p className="card-text text-center">예매율: {movie.ticket_sales}0% | {movie.runtime}</p>
Jiwon Yoon's avatar
Jiwon Yoon committed
40
41
                            <p className="card-text text-center"><small className="text-muted">{movie.release_date} 개봉</small></p>
                        </div>
Jiwon Yoon's avatar
Jiwon Yoon committed
42
43
44
45
46
47
                        <Link to={{
                            pathname:`/ticket`,
                            state: {movieId:movie.id}
                        }}>
                            <button className="btn btn-warning">예매하기</button>
                        </Link>
Jiwon Yoon's avatar
Jiwon Yoon committed
48
49
50
51
52
53
54
55
56
                    </div>
                ))
                : <div>영화정보를 로딩할  없습니다.</div>
            }
        </div>
    )
}

export default MovieChart