| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464 | <!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <title>{{ title }}</title>    <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">    <!-- 新 Bootstrap4 核心 CSS 文件 -->    <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css">    <!-- jQuery文件。务必在bootstrap.min.js 之前引入 -->    <script src="https://code.jquery.com/jquery-3.3.1.slim.min.js"></script>    <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.3/umd/popper.min.js"></script>    <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/js/bootstrap.min.js"></script>    <!--可用來建立使用者小圖示-->    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css">        <script language="JavaScript">        var set_dryImport_number = 2;           // prompt("請輸入乾燥 入料儲豆槽 數量:")        var set_dryTank_number = 12;            // prompt("請輸入乾燥 桶槽 數量:")        var set_dryExport_number = 2;          // prompt("請輸入乾燥 出料儲豆槽 數量:")        console.log("get number: " + set_dryImport_number + "-" + set_dryTank_number + "-" + set_dryExport_number);        // 儲存乾燥貨櫃所有桶槽、入料儲豆槽、出料儲豆槽        var dry_import_list = [];        var dry_tank_list = [];        var dry_export_list = [];        // 桶槽對應值        var dry_tank_data_list = [];        var dry_import_data_list = [];        var dry_export_data_list = [];               var html = '';        var dry_export_data = [];        var data = '{{dtr[0]}}';        console.log("data: " + data);                $(function(){            // 網頁 title            $("#coffee_title_pc").text("桶槽關係建立");            $("#coffee_title_phone").text("桶槽關係建立");            console.log("dry_import_list: " + dry_import_list);            console.log("dry_tank_list: " + dry_tank_list);            console.log("dry_export_list: " + dry_export_list);            console.log("dry_tank_data_list: " + dry_tank_data_list);            console.log("dry_import_data_list: " + dry_import_data_list);            console.log("dry_export_data_list: " + dry_export_data_list);            // 從 入料桶槽出料 取得 桶槽值 D1, 轉換成下拉式選單選項            html = '';            for (let dil = 0; dil < dry_import_list.length; dil++) {                html += '<option value="' + dry_import_list[dil] + '">' + dry_import_list[dil] + '</option>';            }            for (let dtl = 0; dtl < dry_tank_list.length; dtl++) {                html += '<option value="' + dry_tank_list[dtl] + '">' + dry_tank_list[dtl] + '</option>';            }            for (let del = 0; del < dry_export_list.length; del++) {                html += '<option value="' + dry_export_list[del] + '">' + dry_export_list[del] + '</option>';            }            // 賦值到下拉式選單中 - 入料 + 出料            for (let dil = 0; dil < dry_import_list.length; dil++) {                var divbox = document.getElementById(dry_import_list[dil] + '_import');                divbox.insertAdjacentHTML('beforeend', html);                var divbox = document.getElementById(dry_import_list[dil] + '_export');                divbox.insertAdjacentHTML('beforeend', html);            }            for (let dtl = 0; dtl < dry_tank_list.length; dtl++) {                var divbox = document.getElementById(dry_tank_list[dtl] + '_import');                divbox.insertAdjacentHTML('beforeend', html);                var divbox = document.getElementById(dry_tank_list[dtl] + '_export');                divbox.insertAdjacentHTML('beforeend', html);            }            for (let del = 0; del < dry_export_list.length; del++) {                var divbox = document.getElementById(dry_export_list[del] + '_import');                divbox.insertAdjacentHTML('beforeend', html);                var divbox = document.getElementById(dry_export_list[del] + '_export');                divbox.insertAdjacentHTML('beforeend', html);            }            var divbox = document.getElementById('new_import');            divbox.insertAdjacentHTML('beforeend', html);            var divbox = document.getElementById('new_export');            divbox.insertAdjacentHTML('beforeend', html);            // DB 取值後顯示                // // 儲存乾燥貨櫃所有桶槽、入料儲豆槽、出料儲豆槽                // var dry_import_list = [];                // var dry_tank_list = [];                // var dry_export_list = [];                // // 桶槽對應值                // var dry_tank_data_list = [];                // var dry_import_data_list = [];                // var dry_export_data_list = [];            for (let i = 0; i < dry_tank_data_list.length; i++) {                if (dry_tank_data_list.includes(dry_import_data_list[i])) {                    $("#" + dry_tank_data_list[i] + "_import").val(dry_import_data_list[i]);                } else {                    $("#" + dry_tank_data_list[i] + "_import").val('-');                }                                if (dry_tank_data_list.includes(dry_export_data_list[i])) {                    $("#" + dry_tank_data_list[i] + "_export").val(dry_export_data_list[i]);                } else {                    $("#" + dry_tank_data_list[i] + "_export").val('-');                }                // $("#" + dry_tank_data_list[i] + "_export").val(dry_export_data_list[i]);                // if (dry_tank_data_list.includes(dry_import_data_list[i])) {                //     console.log("tttest " + dry_import_data_list[i]);                //     $("#" + dry_tank_data_list[i] + "_import").val(dry_import_data_list[i]);                //     $("#" + dry_tank_data_list[i] + "_export").val(dry_export_data_list[i]);                // } else {                //     console.log("else tttest " + dry_import_data_list[i]);                //     $("#" + dry_tank_data_list[i] + "_import").val('-');                //     $("#" + dry_tank_data_list[i] + "_export").val('-');                // }            }                                    // var html = '<table border="5" style="border: 3px lightgray solid; text-align: center; margin-left: auto; margin-right: auto; width: 500px;">' +             //             '<tr>' +             //             '<th>桶槽名稱</th>' +             //             '<th>桶槽類別</th>' +             //             '<th>桶槽入料</th>' +             //             '<th>桶槽出料</th>' +             //             '</tr>';            // // 增加入料儲豆槽 設定表格            // for (let di = 1; di <= set_dryImport_number; di++) {            //     html +='<tr>' +             //             '<td>DI' + di + '</td>' +             //             '<td></td>' +              //             '<td></td>' +              //             '<td></td>' +             //             '</tr>';            // }            // // 增加桶槽 設定表格            // for (let dt = 1; dt <= set_dryTank_number; dt++) {            //     html +='<tr>' +             //             '<td>D' + dt + '</td>' +             //             '<td></td>' +              //             '<td></td>' +              //             '<td></td>' +             //             '</tr>';            // }            // // 增加出料儲豆槽 設定表格            // for (let de = 1; de <= set_dryExport_number; de++) {            //     html +='<tr>' +             //             '<td>DO' + de + '</td>' +             //             '<td></td>' +              //             '<td></td>' +              //             '<td></td>' +             //             '</tr>';            // }            // html += '<tr>' +             //         '<td colspan="5">[修改確認]</td>' +             //         '</table>';            // var divbox = document.getElementById('set_table');            // divbox.insertAdjacentHTML('beforeend', html);        });           </script>    <style>        .input-cond-delete {            background: #E43030;            border: 1px solid #CFCFCF;            box-sizing: border-box;            border-radius: 5px;            margin-left: 5px;            width: 86px;            height: 33px;            font-size: 16px;            text-align: center;            line-height: 16px;            color: #FFFFFF;        }        .input-cond-add {            background: #008CBA;            border: 1px solid #CFCFCF;            box-sizing: border-box;            border-radius: 5px;            margin-left: 5px;            width: 80px;            height: 33px;            font-size: 16px;            text-align: center;            line-height: 16px;            color: #FFFFFF;        }        .r5_position {            position: absolute;            top: 160px;            left: 310px;            width: 40px;            height: 150px;            border-style: solid;            border-color: aqua;        }        .div_relay_css {            position: absolute;             border-style: solid;             border-color: aqua;             text-align: center;            font-size: 12px;        }        /* header */        /* 文字輸入框 */        .input-text {            height: 25px;            width: 40px;            text-align: center;            margin-left: 2px;            margin-right: 5px;        }        /* 致動器狀態表格置中 */        .label_ActuatorStatus {            margin: auto;        }        /* 致動器 ON 樣式 */        .input-button-on {            color: #008CBA;            border: 2px rgb(182, 181, 181) solid;            background-color: whitesmoke;            padding: 1px 3px;            width: 45px;        }        /* 致動器 OFF 樣式 */        .input-button-off {            color: #707070;            border: 2px rgb(192, 192, 192) solid;            background-color: whitesmoke;            padding: 1px 3px;            width: 45px;        }        /* 輸入按鈕 */        .input-button {            font-size: 14px;            color: #008CBA;            border: 2px rgb(182, 181, 181) solid;            background-color: whitesmoke;            padding: 1px 3px;        }        /* 大表格樣式 */        .table-all {            font-size:18px;             border:2px #cccccc solid;             margin-left: 10px;             margin-right: 10px;             width: 98%;        }        /* footer */        .footer{            height: 40px;            box-sizing: border-box;            /* 設定footer絕對位置在底部 */            position: absolute;            bottom: 0px;            width: 100%;            background-color: #eee;            text-align: center;        }        html, body {            height: 100%;            /* margin: 0; */            position: relative;        }        #wrapper {            /* 設定高度最小為100%, 如果內容區塊很多, 可以長大 */            min-height: 100%;            /* 位置設為relative, 作為footer區塊位置的參考 */            position: relative;        }    </style></head><body style="font-size: 18px;">    <div id="wrapper" style="height: fit-content; text-align: center; margin-left: auto; margin-right: auto;">        <div id="coffee_header">            <!-- 匯入共同使用的 header.html 內容 -->            {% include 'header.html' %}        </div>        <!-- <div id="set_table">        </div> -->        <table border="5" style="border: 3px lightgray solid; text-align: center; margin-left: auto; margin-right: auto; width: 700px;">            <tr>                <th>桶槽名稱</th>                <th>桶槽類別</th>                <th>入料</th>                <th>出料</th>                <th></th>            </tr>                {% for i in dtr %}                <script>                    dry_tank_data_list.push('{{ i.tank_id }}');                    if ('{{ i.tank_id }}'.substring(0, 2) === 'DO') {                        dry_export_list.push('{{ i.tank_id }}');                    } else if ('{{ i.tank_id }}'.substring(0, 2) === 'DI') {                        dry_import_list.push('{{ i.tank_id }}');                    } else {                        dry_tank_list.push('{{ i.tank_id }}');                    }                </script>                <tr>                    <td>                        {{ i.tank_id }}                    </td>                    <td>                        <select id="{{ i.tank_id }}_type" onchange="" class="select-input">                            <option value="mix" selected>混合槽</option>                            <option value="clean_tank">清洗桶槽</option>                            <option value="reclaimedwater_tank">中水桶</option>                            <option value="colorselect_tank">色選機</option>                            <option value="peel_tank">脫皮機</option>                            <option value="ferment_in">發酵入料</option>                            <option value="ferment_tank">發酵桶槽</option>                            <option value="ferment_out">發酵出料</option>                            <option value="dry_in">乾燥入料</option>                            <option value="dry_tank">乾燥桶槽</option>                            <option value="dry_out">乾燥出料</option>                        </select>                    </td>                    <script>                        var tank_type_data = '{{i.tank_type}}';                        $("#{{ i.tank_id }}_type").val(tank_type_data);                    </script>                    <td>                        <select id="{{ i.tank_id }}_import" onchange="" class="select-input">                            <option value="-">-</option>                        </select>                    </td>                    <script>                        dry_import_data_list.push('{{ i.tank_import }}');                    </script>                                        <td>                        <select id="{{ i.tank_id }}_export" onchange="" class="select-input">                            <option value="-">-</option>                        </select>                    </td>                    <script>                        dry_export_data_list.push('{{ i.tank_export }}');                    </script>                    <td>                        <input type="button" id="{{ i.tank_id }}_del" value="刪除 {{ i.tank_id }}" onclick="relation_del('{{ i.tank_id }}')" class="input-cond-delete">                        <script>                            function relation_del(tankID) {                                var confirm_relation_del = confirm("是否要移除 " + tankID + " ?\n確認後即刪除該項關聯")                                if (!confirm_relation_del) {                                    alert("已取消動作");                                } else {                                    const SQL_delete = 'DELETE FROM `dry_tank_relation` WHERE `tank_id` = "' + tankID + '"';                                    // console.log("sql_data: " + sql_data);                                    var sql_data = { "sql": SQL_delete };                                    console.log("sql_data: ", sql_data)                                    $.get('/sql_get', sql_data, function (res) {                                        if (res['response'] == '') {                                            alert("OK");                                        } else {                                            alert(res['response']);                                        }                                    }, 'json');                                    // TRUNCATE TABLE `dry_tank_relation`;                                }                            }                        </script>                    </td>                </tr>                {% endfor %}                <tr>                    <td>                        <input type="text" id="new_tank_id" style="width: 120px;">                    </td>                    <td>                        <select id="new_type" onchange="" class="select-input">                            <option value="mix" selected>混合槽</option>                            <option value="clean_tank">清洗桶槽</option>                            <option value="reclaimedwater_tank">中水桶</option>                            <option value="colorselect_tank">色選機</option>                            <option value="peel_tank">脫皮機</option>                            <option value="ferment_in">發酵入料</option>                            <option value="ferment_tank">發酵桶槽</option>                            <option value="ferment_out">發酵出料</option>                            <option value="dry_in">乾燥入料</option>                            <option value="dry_tank">乾燥桶槽</option>                            <option value="dry_out">乾燥出料</option>                        </select>                    </td>                    <td>                        <select id="new_import" onchange="" class="select-input">                            <option value="-">-</option>                        </select>                    </td>                    <td>                        <select id="new_export" onchange="" class="select-input">                            <option value="-">-</option>                        </select>                    </td>                    <td>                        <input type="button" id="new_insert" value="新增" onclick="relation_ins()" class="input-cond-add">                        <script>                            function relation_ins() {                                const new_insert_tid = $('#new_tank_id').val();                                const new_insert_type = $("#new_type").val();                                const new_insert_import = $("#new_import").val();                                const new_insert_export = $("#new_export").val();                                // console.log("new_insert_tid: " + new_insert_tid);                                // console.log("new_insert_type: " + new_insert_type);                                // console.log("new_insert_import: " + new_insert_import);                                // console.log("new_insert_export: " + new_insert_export);                                const SQL_delete = 'INSERT INTO `dry_tank_relation`(`tank_id`, `tank_type`, `tank_import`, `tank_export`, `datetime`) ' +                                                     'VALUES ("' + new_insert_tid +                                                     '","' + new_insert_type +                                                     '","' + new_insert_import +                                                     '","' + new_insert_export +                                                     '", current_timestamp())';                                console.log("SQL_delete: " + SQL_delete);                                var sql_data = { "sql": SQL_delete };                                $.get('/sql_get', sql_data, function (res) {                                    if (res['response'] == '') {                                        alert("OK");                                    } else {                                        alert(res['response']);                                    }                                }, 'json');                            }                        </script>                    </td>                </tr>                <script>                                    </script>                <tr>                    <td colspan="5">                        [確認]                    </td>                </tr>        </table>                <div id="coffee_footer">            <!-- 匯入共同使用的 footer.html 內容 -->            {% include 'footer.html' %}            <br>            <br>        </div>    </div></body></html>
 |