Search.js 10.4 KB
Newer Older
Lee SeoYeon's avatar
merge    
Lee SeoYeon committed
1
import React, { useState, useEffect } from 'react';
baesangjune's avatar
정리.    
baesangjune committed
2
import { Link } from 'react-router-dom';
Lee SeoYeon's avatar
merge    
Lee SeoYeon committed
3
4
import ohuh from '../ohuh-sm.PNG';
import Place from '../Components/Place';
Lee SeoYeon's avatar
0127    
Lee SeoYeon committed
5
import { Container, Form, Row, Col, Card, Image, InputGroup, FormControl, Button, Nav } from 'react-bootstrap';
Lee SeoYeon's avatar
merge    
Lee SeoYeon committed
6
7
8
import Paginations from '../Components/Paginations';
import axios from 'axios';
import queryString from 'query-string'
Lee SeoYeon's avatar
..    
Lee SeoYeon committed
9
import * as Icon from 'react-bootstrap-icons';
Lee SeoYeon's avatar
.    
Lee SeoYeon committed
10
import { isAuthenticated } from '../utils/auth';
Lee SeoYeon's avatar
0127    
Lee SeoYeon committed
11
import catchErrors from '../utils/catchErrors'
Lee SeoYeon's avatar
merge    
Lee SeoYeon committed
12
13

function Search(props) {
baesangjune's avatar
baesangjune committed
14

Lee SeoYeon's avatar
merge    
Lee SeoYeon committed
15
16
17
18
    const [state, setState] = useState(false);
    const [index, setIndex] = useState(1);
    const [showSet, setShowSet] = useState([false, false, false, false]);
    const [search, setSearch] = useState(queryString.parse(props.location.search).keyword);
Lee SeoYeon's avatar
..    
Lee SeoYeon committed
19
    const [bookmark, setBookmark] = useState([false, false, false, false])
Lee SeoYeon's avatar
.    
Lee SeoYeon committed
20
    const user = isAuthenticated()
21
    const [mobile, setMobile] = useState();
baesangjune's avatar
baesangjune committed
22
23
24
    const [association, setAssociation] = useState([{ name: " ", address: " ", img: " " }])
    const [pagePlace, setPagePlace] = useState([{ name: " ", address: " ", img: " " }, { name: " ", address: " ", img: " " }])
    const [endPage, setEndPage] = useState(1)
Lee SeoYeon's avatar
0127    
Lee SeoYeon committed
25
26
27
28
29
30
31
32
33
34
    const [error, setError] = useState('')

    async function getBookmark() {
        try {
            const response = await axios.get(`/api/users/bookmark?ID=${user}`)
            // setBookmark(response.data.bookmark)
        } catch (error) {
            catchErrors(error, setError)
        }
    }
Lee SeoYeon's avatar
merge    
Lee SeoYeon committed
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52

    const getAssociation = () => {
        axios.get(`/api/search/association?keyword=${search}`)
            .then(res => {
                console.log("Associations = ", res.data)
                setAssociation(res.data)
            })
            .catch(err => {
                console.log("search.associations 에러 발생", err)
            })
    }



    useEffect(() => {
        getAssociation()
    }, []);

Lee SeoYeon's avatar
.    
Lee SeoYeon committed
53
    useEffect(() => {
baesangjune's avatar
baesangjune committed
54
55
56
57
58
59
60
        if (association.length < 3) {
            setPagePlace(paginate(association, index, association.length))
        }
        else {
            setPagePlace(paginate(association, index, 4))
        }
        setEndPage(Math.floor((association.length / 4)))
Lee SeoYeon's avatar
.    
Lee SeoYeon committed
61

baesangjune's avatar
baesangjune committed
62
    }, [association, index])
Lee SeoYeon's avatar
merge    
Lee SeoYeon committed
63
64
65
66

    useEffect(() => {
        getAssociation()
        if (state) {
Kim, Chaerin's avatar
.    
Kim, Chaerin committed
67
68
69
70
71
            // window.location.reload()
            // return <Redirect to={{
            //         pathname: `/search?keyword=${search}`,
            //         state: { id: search },
            //     }} />;
Lee SeoYeon's avatar
merge    
Lee SeoYeon committed
72
            props.history.push('/search?keyword=' + search)
Lee SeoYeon's avatar
.    
Lee SeoYeon committed
73
            setState(false)
Kim, Chaerin's avatar
.    
Kim, Chaerin committed
74
            // console.log("search야", search)
75
76
        } window.addEventListener("scroll", infiniteScroll);
        return () => { window.removeEventListener("scroll", infiniteScroll); }
Lee SeoYeon's avatar
.    
Lee SeoYeon committed
77
    }, [state]);
Lee SeoYeon's avatar
merge    
Lee SeoYeon committed
78

79
80
81
82
83
84
85
86
    const infiniteScroll = () => {
        const { documentElement, body } = document;
        const scrollHeight = Math.max(documentElement.scrollHeight, body.scrollHeight);
        const scrollTop = Math.max(documentElement.scrollTop, body.scrollTop);
        const clientHeight = documentElement.clientHeight;
        if (scrollTop + clientHeight >= scrollHeight) {
            // getReview();
            console.log("더불러")
Kim, Chaerin's avatar
.    
Kim, Chaerin committed
87
        }
88
89
        console.log(scrollHeight, scrollTop, clientHeight)
    }
Lee SeoYeon's avatar
merge    
Lee SeoYeon committed
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126


    const places = [{
        name: "한라산",
        address: "제주 서귀포시 토평동 산15-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?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",
    }]

    if (state !== false) {
        // 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}`} />;
    }

    const handlePage = (num) => {
        setIndex(num);
baesangjune's avatar
baesangjune committed
127
128
        console.log("pagenation num", num)
        console.log(index)
Lee SeoYeon's avatar
merge    
Lee SeoYeon committed
129
130
131
132
133
134
135
136
137
    }


    const handleChange = (e) => {
        setSearch(e.target.value);
    }

    const handleSubmit = (e) => {
        e.preventDefault()
baesangjune's avatar
baesangjune committed
138
139
        setState(true)
        setIndex(1)
Lee SeoYeon's avatar
merge    
Lee SeoYeon committed
140
141
142
143
144
145
    }

    function paginate(items, pageNumber, itemNumber) {
        const page = [];
        const startIndex = (pageNumber - 1) * itemNumber
        for (var i = 0; i < itemNumber; i++) {
baesangjune's avatar
baesangjune committed
146

Lee SeoYeon's avatar
merge    
Lee SeoYeon committed
147
148
            page.push(items[(startIndex + i)])
        }
baesangjune's avatar
baesangjune committed
149
        console.log("뿌릴 data22222222222222222", page)
Lee SeoYeon's avatar
merge    
Lee SeoYeon committed
150
151
        return page
    }
baesangjune's avatar
baesangjune committed
152
    //usestate 쓰거나 한번에 useeffect에 넣기
Lee SeoYeon's avatar
merge    
Lee SeoYeon committed
153

Lee SeoYeon's avatar
.    
Lee SeoYeon committed
154
    async function handlebookmark(index) {
Lee SeoYeon's avatar
..    
Lee SeoYeon committed
155
        if (!bookmark[index]) {
Lee SeoYeon's avatar
.    
Lee SeoYeon committed
156
            console.log(pagePlace[index])
Lee SeoYeon's avatar
0127    
Lee SeoYeon committed
157
158
159
160
161
162
163
164
165
166
            try {
                const response = await axios.put(`/api/users/bookmark?ID=${user}&place=${pagePlace[index]._id}`)
                alert(response.data, '북마크가 저장되었습니다.')
                const showArr = bookmark
                showArr[index] = true
                setBookmark(showArr)
                console.log("bookmark=", bookmark) 
            } catch (error) {
                catchErrors(error, setError)
            }
Lee SeoYeon's avatar
..    
Lee SeoYeon committed
167
        } else {
Lee SeoYeon's avatar
0127    
Lee SeoYeon committed
168
169
170
171
172
173
174
175
176
177
            try {
                const response = await axios.delete(`/api/users/bookmark?ID=${user}&place=${pagePlace[index]._id}`)
                alert(response.data, '저장된 북마크가 삭제되었습니다.')
                const showArr = bookmark
                showArr[index] = false
                setBookmark(showArr)
                console.log("bookmark=", bookmark)
            } catch (error) {
                catchErrors(error, setError)
            }
Lee SeoYeon's avatar
..    
Lee SeoYeon committed
178
179
        }
    }
Lee SeoYeon's avatar
merge    
Lee SeoYeon committed
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202


    let time = new Date()

    return (
        <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}>
                    <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>
                </Form>
            </Row>
203
            {/* {time.toLocaleString()} */}
Lee SeoYeon's avatar
merge    
Lee SeoYeon committed
204
            <Row className="d-flex flex-wrap">
baesangjune's avatar
baesangjune committed
205
206

                {console.log("#####################33", pagePlace)}
Lee SeoYeon's avatar
merge    
Lee SeoYeon committed
207
208
209
210
                {pagePlace.map((place, index) => {
                    return (
                        <Col key={index} md={6} >
                            <Card align="center" border="info" style={{ margin: "3%" }}>
Lee SeoYeon's avatar
.    
Lee SeoYeon committed
211
212
213
214
215
216
217
218
219
220

                                <Card.Title className="d-flex justify-content-center" style={{ margin: "3%", fontSize: '200%', fontWeight: 'bold' }} >{place.name}
                                    {user ?
                                        <Button
                                            variant={bookmark[index] ? "primary" : "light"}
                                            onClick={() => handlebookmark(index, place)}>
                                            <Icon.BookmarkStarFill size={35} />
                                            {console.log("bookmark", bookmark)}
                                            {console.log("bookmark[index]", bookmark[index])}</Button> : null}
                                </Card.Title>
Lee SeoYeon's avatar
merge    
Lee SeoYeon committed
221
222
223
224
                                <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" }} >
                                        {place.address} </Card.Text>
Lee SeoYeon's avatar
0127    
Lee SeoYeon committed
225
                                    <Button variant="info" onClick={() => {
Lee SeoYeon's avatar
merge    
Lee SeoYeon committed
226
227
228
229
230
231
232
233
234
235
                                        const showArr = [false, false, false, false]
                                        showArr[index] = true
                                        setShowSet(showArr)
                                    }}>{place.name} 자세히 살펴보기</Button>
                                    <Place place={place} index={index} show={showSet[index]} onHide={() => setShowSet([false, false, false, false])} />
                                </Card.Body>
                            </Card>
                        </Col>
                    )
                })}
baesangjune's avatar
baesangjune committed
236
237


Lee SeoYeon's avatar
merge    
Lee SeoYeon committed
238
239
240
241
            </Row>
            <Row className="mt-2 d-flex justify-content-center">
                <Paginations index={index} endPage={endPage} handlePage={handlePage}></Paginations>
            </Row>
Lee SeoYeon's avatar
.    
Lee SeoYeon committed
242
        </Container >
Lee SeoYeon's avatar
merge    
Lee SeoYeon committed
243
244
245
246
    );
}

export default Search;