웹개발 종합반 7주차 (3.7)

신예진·2022년 2월 28일
0

(앞으로 해야할 것)
1. select에 따라 해당하는 오름 카드들만 나오게
2. 코멘트 달기
3. 웹페이지 배포
4. 지도 만들기
5. 코멘트 꾸며주기
6. 카드 리스트 이름 순으로 정렬해주기

1) app.py

from flask import Flask, render_template, request, jsonify
import requests
app = Flask(__name__)

from pymongo import MongoClient
import certifi
ca = certifi.where()
client = MongoClient('mongodb+srv://test:sparta@cluster0.4n13d.mongodb.net/Cluster0?retryWrites=true&w=majority', tlsCAFile=ca)
db = client.dbsparta

headers = {'User-Agent' : 'Mozilla/5.0 (Windows NT 10.0; Win64; x64)AppleWebKit/537.36 (KHTML, like Gecko) Chrome/73.0.3683.86 Safari/537.36'}
data = requests.get('https://gis.jeju.go.kr/rest/JejuOleumVRImg/getOleumRDetailList',headers=headers)

d = data.json()
oleums = d["resultSummary"]

@app.route('/')
def home():
    return render_template('index.html')

@app.route("/oleums", methods=["POST"])
def jejuoleum_post():
    for oleum in oleums:
        name = oleum['oleumKname']
        address = oleum['oleumAddr']
        altitude = oleum['oleumAltitu']
        x = oleum['x']
        y = oleum['y']
        explan = oleum['explan']
        img = oleum['imgPath']
        doc = {
            'name': name,
            'address': address,
            'altitude': altitude,
            'x': x,
            'y': y,
            'explan': explan,
            'img': img
        }
        db.oleums.insert_one(doc)

@app.route("/oleums", methods=["GET"])
def jejuoleum_get():
    oleum_list = list(db.oleums.find({}, {'_id': False}))
    print(oleum_list[0])
    return jsonify({'oleums': oleum_list})

@app.route("/comment", methods=["POST"])
def comment_post():
    comname_receive = request.form['comname_give']
    star_receive = request.form['star_give']
    comment_receive = request.form['comment_give']

    doc = {
        'comname' : comname_receive,
        'star' : star_receive,
        'comment' : comment_receive
    }

    db.comment.insert_one(doc)
    return jsonify({'msg': '저장 완료!'})
@app.route("/commentlist", methods=["POST"])
def comment_get():
    comname_receive = request.form['comname_give']
    comment_list = list(db.comment.find({'comname':comname_receive}, {'_id': False}))
    print(comment_list)
    return jsonify({'comments': comment_list})

if __name__ == '__main__':
    app.run('0.0.0.0', port=5000, debug=True)
  1. index.html

    <meta property="og:title" content="제주 오름 지도🏔"/>
    <meta property="og:description" content="제주의 오름들을 구경하세요"/>
    <meta property="og:image" content="http://www.ibulgyo.com/news/photo/201506/141816_88579_3155.jpg"/>
    
    <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.0.2/dist/css/bootstrap.min.css" rel="stylesheet"
          integrity="sha384-EVSTQN3/azprG1Anm3QDgpJLIm9Nao0Yz1ztcQTwFspd3yD65VohhpuuCOmLASjC" crossorigin="anonymous">
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
    <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.0.2/dist/js/bootstrap.bundle.min.js"
            integrity="sha384-MrcW6ZMFYlzcLA8Nl+NtUVF0sA7MsXsP1UyJoMp4YLEuNSfAP+JcXn/tWtIaxVXM"
            crossorigin="anonymous"></script>
    
    <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.0.0/jquery.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery-modal/0.9.1/jquery.modal.min.js"></script>
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/jquery-modal/0.9.1/jquery.modal.min.css"/>
    
    <link href="https://fonts.googleapis.com/css2?family=Gowun+Batang&display=swap" rel="stylesheet">
    
    <title>제주 오름 지도</title>
    
    <style>
    * {
        font-family: 'Gowun Batang', serif;
    }
    
    .mytitle {
        width: 100%;
        height: 250px;
    
        background-image: linear-gradient(0deg, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5)), url('');
        background-position: center;
        background-size: cover;
    
        color: white;
    
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
    }
    .myselect {
        margin : 30px;
    
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
    
        border : 1px solid white;
        box-shadow : 0px 0px 2px 0px darkgray;
    }
    .mycomment {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
    }
    .mycomment > .btn {
        margin: 20px 10px 10px 10px;
    }
    .mybtns {
        margin : 10px 10px 10px 160px;
        }
    
    </style>
    <script>
        $(document).ready(function () {
            set_temp()
            save_oleum()
            show_oleum()
            close_box()
        });
    
        function set_temp() {
            $.ajax({
                type: "GET",
                url: "http://spartacodingclub.shop/sparta_api/weather/jeju",
                data: {},
                success: function (response) {
                    $('#temp').text(response['temp'])
                }
            })
        }
    
        function save_oleum(){
            $.ajax({
                type : 'POST',
                url: '/oluems',
                data: {},
                success: function (response) {
                    window.location.reload()
                }
            })
        }
    
        function show_oleum(){
            $.ajax({
                type : 'GET',
                url : '/oleums',
                data : {},
                success : function (response) {
                    let rows = response['oleums']
                    for (let i = 0; i < rows.length; i++) {
                        let name = rows[i]['name']
                        let address = rows[i]['address']
                        let altitude = rows[i]['altitude']
                        let x = rows[i]['x']
                        let y = rows[i]['y']
                        let explan = rows[i]['explan']
                        let img = rows[i]['img']
    
                        let temp_html = `<div class="card" style="width: 18rem;">
                                            <img src="${img}" class="card-img-top" alt="...">
                                            <div class="card-body">
                                                <h5 class="card-title">${name}</h5>
                                                <p class="card-text">${address}</p>
                                                <p class="card-text">${explan}</p>
                                            </div>
                                        </div>
                                        `
                        $.ajax({
                            type: 'POST',
                            url: '/commentlist',
                            data: {comname_give: name},
                            success: function (response) {
                                let rows = response['comments']
                                for (let i = 0; i < rows.length; i++) {
                                    let comname = rows[i]['comname']
                                    let star = rows[i]['star']
                                    let comment = rows[i]['comment']
                                    let star_image = '⭐'.repeat(star)
                                    temp_html = temp_html + `<div class="card" style="width: 18rem;">
                                                            <div class="card-body">
                                                            <p class="card-text">${star_image}</p>
                                                            <p class="card-text">${comment}</p></div>`
                                }
    
                                if (x < 126.431492) {
                                    $('#west-box').append(temp_html)
                                    $('#west-box').hide()
                                } else if (x > 126.672505) {
                                    $('#east-box').append(temp_html)
                                    $('#east-box').hide()
                                } else {
                                    $('#middle-box').append(temp_html)
                                    $('#middle-box').hide()
                                }
                            }
                        })
    
                    }
                }
            })
        }
    
        function OnSelect(){
            var gubun = document.getElementById("floatingSelect").options[document.getElementById("floatingSelect").selectedIndex].value;
    
            if (gubun ==1){
                $('#east-box').hide()
                $('#middle-box').hide()
                $('#west-box').show();
            }else if (gubun ==2){
                $('#east-box').hide()
                $('#west-box').hide()
                $('#middle-box').show();
            }else if (gubun ==3){
                $('#west-box').hide()
                $('#middle-box').hide()
                $('#east-box').show()
            }else{
                $('#west-box').hide()
                $('#middle-box').hide()
                $('#east-box').hide()
            }
        }
    
        function open_box() {
            $('#comment-box').show()
        }
        function close_box() {
            $('#comment-box').hide()
        }
    
        function posting() {
            let comname = $('#comname').val()
            let star = $('#star').val()
            let comment = $('#comment').val()
    
            $.ajax({
                type: 'POST',
                url: '/comment',
                data: {comname_give: comname, star_give: star, comment_give: comment},
                success: function (response) {
                    alert(response['msg'])
                    window.location.reload()
                }
            })
        }
    </script>
</head>

<body>
<div class="mytitle">
    <h1>제주 오름 지도</h1>
    <p>제주의 기온 : <span id="temp">00.0</span></p>
</div>
<div class="mycomment">
    <a href="#" class="btn btn-success" onclick="open_box()">당신의 경험을 공유하세요</a>

    <div id="comment-box">
        <div class="form-floating mb-3">
            <input id="comname" type="email" class="form-control" placeholder="name@example.com">
            <label>오름 이름</label>
        </div>
        <div class="input-group mb-3">
            <label class="input-group-text" for="inputGroupSelect01">난이도</label>
            <select class="form-select" id="star">
                <option selected>-- 선택하기 --</option>
                <option value="1"></option>
                <option value="2">⭐⭐</option>
                <option value="3">⭐⭐⭐</option>
                <option value="4">⭐⭐⭐⭐</option>
                <option value="5">⭐⭐⭐⭐⭐</option>
            </select>
        </div>
        <div class="form-floating">
            <textarea id="comment" class="form-control" placeholder="Leave a comment here"></textarea>
            <label for="floatingTextarea2">코멘트</label>
        </div>
        <div class="mybtns">
            <button onclick="posting()" type="button" class="btn btn-outline-success">완료</button>
            <button onclick="close_box()" type="button" class="btn btn-outline-secondary">닫기</button>
        </div>
    </div>
</div>
<div class="myselect">
    <select class="form-select" id="floatingSelect" aria-label="Floating label select example" onchange="OnSelect();">
        <option selected>-- 원하는 지역을 선택하세요 --</option>
        <option value="1">서부</option>
        <option value="2">중부</option>
        <option value="3">동부</option>
    </select>
</div>
<div class="mycards">
    <div class="row row-cols-1 row-cols-md-4 g-4" id="west-box">
    </div>
    <div class="row row-cols-1 row-cols-md-4 g-4" id="middle-box">
    </div>
    <div class="row row-cols-1 row-cols-md-4 g-4" id="east-box">
    </div>
</div>
</body>
</html>

3) 현재 페이지 상태

0개의 댓글