Search.js 7.93 KB
Newer Older
1
import React, { useState, useEffect } from 'react';
Kim, Chaerin's avatar
Kim, Chaerin committed
2
import { Link, Redirect } from 'react-router-dom';
Kim, Chaerin's avatar
?    
Kim, Chaerin committed
3
4
import ohuh from '../ohuh-sm.PNG';
import Place from '../Components/Place';
baesangjune's avatar
baesangjune committed
5
import { Container, Form, Row, Col, Card, Image, InputGroup, FormControl, Button } from 'react-bootstrap';
Kim, Chaerin's avatar
?    
Kim, Chaerin committed
6
import Paginations from '../Components/Paginations';
baesangjune's avatar
.    
baesangjune committed
7
import axios from 'axios';
Kim, Chaerin's avatar
Kim, Chaerin committed
8
import queryString from 'query-string'
Kim, Chaerin's avatar
Kim, Chaerin committed
9
10

function Search(props) {
11
    const endPage = 10;
Kim, Chaerin's avatar
Kim, Chaerin committed
12
    const [state, setState] = useState(false);
13
    const [index, setIndex] = useState(1);
14
    const [showSet, setShowSet] = useState([false, false, false, false]);
Kim, Chaerin's avatar
Kim, Chaerin committed
15
    const [search, setSearch] = useState(queryString.parse(props.location.search).keyword);
16
    const [mobile, setMobile] = useState();
baesangjune's avatar
baesangjune committed
17
18
    // const [place, setPlace] = useState([{ name: "", category: "", address: "" }])
    // const [imgUrl, setImgUrl] = useState([])
baesangjune's avatar
.    
baesangjune committed
19
    const [association, setAssociation] = useState([])
baesangjune's avatar
baesangjune committed
20
    const [pagePlace, setPagePlace] = useState([])
baesangjune's avatar
baesangjune committed
21

baesangjune's avatar
하하    
baesangjune committed
22
    // console.log("search###############", search)
baesangjune's avatar
baesangjune committed
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
    // const getPlace = () => {
    //     axios.get(`/api/search/places?keyword=${search}`)
    //         .then(res => {
    //             console.log("places=", res.data)
    //             // setPlace(res.data)
    //         })
    //         .catch(err => {
    //             console.log('search.places 에러 발생', err)
    //         })
    // }

    // const getImg = () => {
    //     axios.get(`/api/search/imges?keyword=${search}`)
    //         .then(res => {
    //             console.log("images=", res.data)
    //             // setImgUrl(res.data)
    //         })
    //         .catch(err => {
    //             console.log('search.images 에러 발생', err)
    //         })
    // }
baesangjune's avatar
.    
baesangjune committed
44

baesangjune's avatar
하하    
baesangjune committed
45

baesangjune's avatar
.    
baesangjune committed
46

baesangjune's avatar
baesangjune committed
47
    const getAssociation = () => {
Kim, Chaerin's avatar
Kim, Chaerin committed
48
        axios.get(`/api/search/association?keyword=${search}`)
baesangjune's avatar
baesangjune committed
49
50
51
52
53
54
55
            .then(res => {
                console.log("Associations = ", res.data)
                setAssociation(res.data)
            })
            .catch(err => {
                console.log("search.associations 에러 발생", err)
            })
baesangjune's avatar
.    
baesangjune committed
56
57
    }

baesangjune's avatar
.    
baesangjune committed
58

59
60

    useEffect(() => {
baesangjune's avatar
baesangjune committed
61
62
        // getPlace()
        // getImg()
baesangjune's avatar
.    
baesangjune committed
63
        getAssociation()
64
65
66
67
68
        if (window.innerWidth < 960) {
            setMobile(true)
        } else {
            setMobile(false)
        }
baesangjune's avatar
.    
baesangjune committed
69

baesangjune's avatar
baesangjune committed
70
71
72
73
74
75
76
77
78
79
80
81
    }, []);

    useEffect(() => {
        // getImg()
        // getAssociation()
        setPagePlace(paginate(association, index, association.length))
    }, [association])

    useEffect(() => {
        // getPlace()
        // getImg()
        getAssociation()
Kim, Chaerin's avatar
.    
Kim, Chaerin committed
82
83
84
85
86
        if (state) {
            props.history.push('/search?keyword=' + search)
            setState(false)
            console.log("search야", search)
        }
baesangjune's avatar
baesangjune committed
87
88

    }, [state])
baesangjune's avatar
.    
baesangjune committed
89
90


91
    const places = [{
92
        name: "한라산",
93
        address: "제주 서귀포시 토평동 산15-1",
baesangjune's avatar
.    
baesangjune committed
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
        img: "https://upload.wikimedia.org/wikipedia/commons/thumb/e/eb/KOCIS_Halla_Mountain_in_Jeju-do_%286387785543%29.jpg/269px-KOCIS_Halla_Mountain_in_Jeju-do_%286387785543%29.jpg?size=200x200",
    }, {
        name: "성산일출봉(sungsan)",
        address: "제주 서귀포시 성산읍 성산리 1",
        img: "https://www.jeju.go.kr/pub/site/geopark/images/sub/sub03/02%EC%A7%80%EC%A7%88%EB%A7%88%EC%9D%84%EC%9D%B4%EC%95%BC%EA%B8%B0/%EC%A7%80%EC%A7%88%EB%A7%88%EC%9D%84/%EC%A7%80%EC%A7%88%EB%A7%88%EC%9D%84_%EC%84%B1%EC%82%B0%EC%9D%BC%EC%B6%9C%EB%B4%89/1412402261.jpg?400/400",
    }, {
        name: "해녀의 집(haenyeo)",
        address: "제주 서귀포시 성산읍 한도로 141-13지번오조리 3 오조해녀의집",
        img: "https://mblogthumb-phinf.pstatic.net/MjAxNjExMTdfMTc0/MDAxNDc5MzU3ODU0ODQy.KZYXCjzsXT3rCsE4HXBfxyCg2buvluBvN_7NxVp7BSwg.loJc89d8JjGXdNCn-4yMd7aMWPjfrZn21TI9Hyzemkog.JPEG.icocam11/20161010_100205.jpg?type=w800",
    }, {
        name: "오설록 티 뮤지엄(osulloc)",
        address: "제주 서귀포시 안덕면 신화역사로 15 오설록지번서광리 1235-1 오설록",
        img: "https://cdnweb01.wikitree.co.kr/webdata/editor/202007/01/img_20200701143323_2ced7627.webp",
    }, {
        name: "오설록 티 뮤지엄(osulloc)",
        address: "제주 서귀포시 안덕면 신화역사로 15 오설록지번서광리 1235-1 오설록",
        img: "https://upload.wikimedia.org/wikipedia/commons/thumb/e/eb/KOCIS_Halla_Mountain_in_Jeju-do_%286387785543%29.jpg/269px-KOCIS_Halla_Mountain_in_Jeju-do_%286387785543%29.jpg",
111
112
    }]

Kim, Chaerin's avatar
Kim, Chaerin committed
113
    if (state !== false) {
Kim, Chaerin's avatar
.    
Kim, Chaerin committed
114
115
116
117
118
119
120
121
        // console.log(queryString.parse(props.location.search))
        //  = {keyword:search}
        // return <Redirect to={{
        //     pathname: `/search?keyword=${search}`,
        //     state: { id: search },
        // }} />;
        // history.pushState(null, null, "?"+queryParams.toString());
        // return <Redirect to={`/search?keyword=${search}`} />;
122
    }
Kim, Chaerin's avatar
Kim, Chaerin committed
123

124
125
126
127
128
    const handlePage = (num) => {
        setIndex(num);
    }


Kim, Chaerin's avatar
Kim, Chaerin committed
129
130
131
    const handleChange = (e) => {
        setSearch(e.target.value);
    }
Kim, Chaerin's avatar
Kim, Chaerin committed
132

Kim, Chaerin's avatar
Kim, Chaerin committed
133
    const handleSubmit = (e) => {
baesangjune's avatar
baesangjune committed
134
        e.preventDefault()
Kim, Chaerin's avatar
Kim, Chaerin committed
135
        setState(true);
Kim, Chaerin's avatar
Kim, Chaerin committed
136
    }
137

Kim, Chaerin's avatar
Kim, Chaerin committed
138
    function paginate(items, pageNumber, itemNumber) {
139
        const page = [];
Kim, Chaerin's avatar
Kim, Chaerin committed
140
141
        const startIndex = (pageNumber - 1) * itemNumber
        for (var i = 0; i < itemNumber; i++) {
142
143
144
145
146
            page.push(items[(startIndex + i)])
        }
        return page
    }

baesangjune's avatar
baesangjune committed
147
148


baesangjune's avatar
.    
baesangjune committed
149
150

    let time = new Date()
151

Kim, Chaerin's avatar
Kim, Chaerin committed
152
    return (
153
154
155
156
        <Container >
            <Link to="/" className="d-flex justify-content-center"><Image src={ohuh} /></Link>
            <Row className="mb-2" className="d-flex justify-content-center">
                <Form style={{ width: "90vw" }} onSubmit={handleSubmit}>
157
158
159
160
161
162
163
164
165
166
167
168
                    <InputGroup size="lg">
                        <FormControl
                            placeholder="검색어를 입력하세요."
                            value={search}
                            aria-label="Large"
                            aria-describedby="inputGroup-sizing-sm"
                            onChange={handleChange}
                        />
                        <InputGroup.Append>
                            <Button type="submit" variant="outline-secondary" >검색</Button>
                        </InputGroup.Append>
                    </InputGroup>
169
                </Form>
Kim, Chaerin's avatar
Kim, Chaerin committed
170
            </Row>
baesangjune's avatar
baesangjune committed
171
            {time.toLocaleString()}
172
173
174
            <Row className="d-flex flex-wrap">
                {pagePlace.map((place, index) => {
                    return (
175
176
177
178
179
180
                        <Col key={index} md={6} >
                            <Card align="center" border="info" style={{ margin: "3%" }}>
                                <Card.Title style={{ margin: "3%", fontSize: '200%', fontWeight: 'bold' }} >{place.name}</Card.Title>
                                <Card.Img variant="top" style={{ padding: "5%", width: "100%", height: "340px" }} src={place.img} />
                                <Card.Body >
                                    <Card.Text style={{ overflow: 'auto', fontSize: '25px', width: '100%', height: "80px" }} >
181
                                        {place.address} </Card.Text>
182
183
184
185
186
                                    <Button variant="primary" onClick={() => {
                                        const showArr = [false, false, false, false]
                                        showArr[index] = true
                                        setShowSet(showArr)
                                    }}>{place.name} 자세히 살펴보기</Button>
baesangjune's avatar
baesangjune committed
187
                                    <Place place={place} index={index} show={showSet[index]} onHide={() => setShowSet([false, false, false, false])} />
188
189
190
                                </Card.Body>
                            </Card>
                        </Col>
191
192
193
                    )
                })}
            </Row>
194
            <Row className="mt-2 d-flex justify-content-center">
195
                <Paginations index={index} endPage={endPage} handlePage={handlePage}></Paginations>
196
            </Row>
Kim, Chaerin's avatar
Kim, Chaerin committed
197
198
199
200
        </Container>
    );
}

201
export default Search;