Attendance/templates/homeroom.html

272 lines
16 KiB
HTML
Raw Normal View History

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
2021-09-24 22:31:36 -07:00
<title>Homeroom 班級 {{homeroomCode[0]}}{{homeroomCode[1]}}) - Attendance 點名</title>
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.1.1/dist/css/bootstrap.min.css" rel="stylesheet"
integrity="sha384-F3w7mX95PdgyTmZZMECAngseQB83DfGTowi0iMjiWaeVhAn4FJkqJByhZMI3AhiU" crossorigin="anonymous">
<link rel="stylesheet" href="/static/allpages.css">
2021-09-12 02:39:09 -07:00
<link rel="stylesheet" href="/static/homeroom.css">
2021-09-18 04:26:06 -07:00
<link rel="shortcut icon" type="image/x-icon" href="/static/favicon.ico" />
<!-- Global site tag (gtag.js) - Google Analytics -->
<script async src="https://www.googletagmanager.com/gtag/js?id=G-H6D61RSBHR"></script>
2021-10-19 07:30:49 -07:00
<script src="/static/gtag.js"></script>
</head>
<body>
2021-09-26 06:37:34 -07:00
<div class="showTime"><span id="showTime"></span></div>
<div class="container">
2021-09-18 04:26:06 -07:00
<h1 class="margin-top">Homeroom View | 班級主頁</h1>
<h2 class="margin-top">{{homeroomCode[0]}}{{homeroomCode[1]}}</h2>
<h2>[{{currDate}}]</h2>
<a href="/logout"><button class="btn btn-primary logout margin-top">Logout 登出</button></a>
2021-10-03 07:33:53 -07:00
<a href="/select"><button class="btn btn-primary margin-top logout">Choose Subuser 選擇其他帳號</button></a>
2021-10-15 05:32:24 -07:00
<select name="date" id="date" class="form-select logout" onchange="chgDate();">
{% for date in range(dateKeys|length) %}
{% if dateKeys[date] == currDate %}
{% if date-2 >= 0 %}<option value="{{dateKeys[date-2]}}">{{dateKeys[date-2]}}</option>{% endif %}
{% if date-1 >= 0 %}<option value="{{dateKeys[date-1]}}">{{dateKeys[date-1]}}</option>{% endif %}
<option value="{{dateKeys[date]}}" selected="selected">{{dateKeys[date]}} ★</option>
{% for i in range(1,5) %}
{% if date+i < dateKeys|length %}<option value="{{dateKeys[date+i]}}">{{dateKeys[date+i]}}</option>{%endif%}
{% endfor %}
{% endif %}
{% endfor %}
2021-10-15 05:32:24 -07:00
</select>
<form action="/manage/homeroom_confirm" id="homeroom_confirm" method="post">
<input type="hidden" name="date" value="{{currDate}}">
2021-09-12 02:39:09 -07:00
<input type="hidden" name="homeroom" value="{{homeroomCode[0]}}^{{homeroomCode[1]}}">
<input type="hidden" id="hrCfrm-sign" name="signatureData" value="">
<input type="hidden" id="hrCfrm-notes" name="notes" value="">
</form>
<div class="col">
<div class="sticky-top" style="background-color:white;">
<div class="row title">
2021-09-18 04:26:06 -07:00
<div class="col">班級</div>
<div class="col">座號</div>
<div class="col">姓名</div>
<div class="col">英文姓名</div>
{% for i in periods %}
<div class="col" {% if currPeriod==i %} style="background-color: #ffdf81;" {% endif %}>{{i}}</div>
{% endfor %}
</div>
<div class="row title">
<div class="col"></div>
<div class="col"></div>
<div class="col"></div>
<div class="col"></div>
{% for i in periods %}
<div class="col" {% if currPeriod==i %} style="background-color: #ffdf81;" {% endif %}>
{{absData[currDate][i]['name']}}</div>
{% endfor %}
</div>
<div class="row title">
<div class="col"></div>
<div class="col"></div>
<div class="col"></div>
<div class="col"></div>
{% for i in periods %}
<div class="col" {% if currPeriod==i %} style="background-color: #ffdf81;" {% endif %}>
{{absData[currDate][i]['teacher']}}</div>
{% endfor %}
</div>
</div>
2021-09-12 02:39:09 -07:00
{% for i in homeroomData %}
<div class="row">
<div class="col">{{homeroomCode[0]}}{{homeroomCode[1]}}</div>
<div class="col">{{i}}</div>
2021-09-12 02:39:09 -07:00
<div class="col">{{ homeroomData[i]['name'] }}</div>
<div class="col">{{ homeroomData[i]['eng_name'] }}</div>
{% for j in periods %}
2021-10-15 05:29:53 -07:00
<div class="col view-{{j}}" {% if currPeriod==j %} style="background-color: #ffdf81;" {% endif %}>
2021-09-12 06:59:31 -07:00
{% if 'signature' in absData[currDate][j] %}
{% if i in absData[currDate][j] %}
{% if absData[currDate][j][i] == 1 %}
2021-10-15 05:29:53 -07:00
<p class="highlightAbs n-2 view-n-{{i}}">X</p>
2021-09-12 06:59:31 -07:00
{% else %}
2021-10-15 05:29:53 -07:00
<p class="highlightAbs n-3 view-n-{{i}}">𝜑</p>
{% endif %}
{% else %}
2021-09-12 06:59:31 -07:00
{% if absData[currDate][j]['name'] != 'GP' %}
2021-10-15 05:29:53 -07:00
<p class="highlightAbs n-1 view-n-{{i}}">V</p>
2021-09-12 06:59:31 -07:00
{% else %}
{% if (homeroomData[i]['GP_Class'][absData[currDate][j]['teacher']] in
absData[currDate][j]['signature'])%}
2021-10-15 05:29:53 -07:00
<p class="highlightAbs n-1 view-n-{{i}}">V</p>
2021-09-12 06:59:31 -07:00
{% else %}
2021-10-15 05:29:53 -07:00
<p class="highlightAbs n-2 view-n-{{i}}"></p>
2021-09-12 06:59:31 -07:00
{% endif %}
{% endif %}
{% endif %}
{% elif absData[currDate][j]['name'] == 'GP' %}
2021-09-12 02:39:09 -07:00
<p class="highlightAbs"></p>
2021-09-12 06:59:31 -07:00
{% else %}
2021-09-12 02:39:09 -07:00
{% if 'confirm' in absData[currDate] %}
<p class="highlightAbs"></p>
{% else %}
<input type="checkbox" class="tobeform 2^{{j}}^{{i}} late" id="late^{{j}}^{{i}}"
onchange="unCheckAbs('{{j}}^{{i}}')">
<input type="checkbox" class="tobeform 1^{{j}}^{{i}} absent" id="absent^{{j}}^{{i}}"
onchange="unCheckLate('{{j}}^{{i}}')">
2021-09-12 02:39:09 -07:00
{% endif %}
<!-- <input type="checkbox" class="tobeform {{j}}^{{i}}"> -->
2021-09-12 06:59:31 -07:00
{% endif %}
2021-09-12 02:39:09 -07:00
</div>
{% endfor %}
</div>
{% endfor %}
2021-09-12 02:39:09 -07:00
<div class="row">
<div class="col"></div>
<div class="col"></div>
<div class="col"></div>
<div class="col"></div>
{% for i in periods %}
2021-10-15 05:29:53 -07:00
<div id="btns-{{i}}" class="col" {% if currPeriod==i %} style="background-color: #ffdf81;" {% endif %}>
{% if (absData[currDate][i]['name'] == 'GP' or 'confirm' in absData[currDate]) %}
<button class="btn btn-danger afterSelButton" disabled="disabled"></button>
{% elif ('signature' in absData[currDate][i]) %}
<button class="btn btn-danger afterSelButton" onclick="edit('{{i|string}}')">Edit
<br>{{absData[currDate][i]['name']}}</button>
2021-09-12 02:39:09 -07:00
{% else %}
<button class="btn btn-primary afterSelButton"
2021-10-15 05:29:53 -07:00
onclick="afterSelAbs('{{i|string}}', 'newSubmit')">Confirm<br>{{absData[currDate][i]['name']}}</button>
2021-09-12 02:39:09 -07:00
{% endif %}
</div>
{% endfor %}
</div>
<form action="/manage/homeroom_abs" id="postHomeroomAbs" hidden="hidden" method="post">
<input type="text" id="HR-date" name="date" value="{{currDate}}">
<input type="text" id="HR-period" name="period" value="">
<input type="text" id="HR-signatureData" name="signatureData" value="">
2021-09-14 02:49:16 -07:00
<input type="text" id="HR-notes" name="notes" value="">
2021-09-12 02:39:09 -07:00
<input type="text" id="HR-homeroom" name="homeroom" value="{{homeroomCode[0]}}^{{homeroomCode[1]}}">
2021-10-15 05:29:53 -07:00
<input type="text" id="HR-type" name="stype" value="">
2021-09-12 02:39:09 -07:00
</form>
{% if 'confirm' in absData[currDate] %}
<button class="btn btn-primary margin-top afterSelButton" onclick="homeroomCfrm()" disabled="disabled">
2021-09-14 07:55:11 -07:00
Homeroom Teacher Already Confirmed | 班導已確認</button>
2021-09-12 02:39:09 -07:00
{% else %}
<button class="btn btn-primary margin-top afterSelButton" onclick="homeroomCfrm()">Homeroom
2021-09-15 04:30:09 -07:00
Teacher Confirm | 班導確認</button>
{% endif %}
2021-10-19 07:30:49 -07:00
<div id="finalCheck" class="modal fade" id="staticBackdrop" data-bs-backdrop="static"
data-bs-keyboard="false" tabindex="-1" aria-labelledby="staticBackdropLabel" aria-hidden="true">
<div class="modal-dialog modal-dialog-centered modal-xl">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="staticBackdropLabel">Please Sign Below 請在下方簽名</h5>
</div>
<div class="modal-body">
<h3>Period: <span id="showSignPeriod"></span></h3>
<h3>Subject: <span id="showSignSubjectName"></h3>
<div class="alert alert-warning margin-top" id="allPresentWarning" role="alert"
hidden="hidden">
<h4 class="alert-heading">請確認是否全班全到Please check if everyone is present!</h4>
</div>
<div class="forSign"><canvas id="signature_pad"></canvas></div>
<h3 class="margin-top">Notes 備註欄</h3>
<input type="textarea" class="form-control" name="notes" id="subjectNotes"
placeholder="Enter Notes 請輸入備註" style="width: 80%; margin-left: 10%;" row="3">
</div>
<div class="modal-footer">
<button class="btn btn-secondary" type="button" onclick="signaturePad.clear()">Clear
Signature 清除簽名</button>
<button type="button" class="btn btn-danger" onclick="location.reload();">Cancel
取消</button>
<button type="button" class="btn btn-primary submitButton" onclick="submitForm()">Submit
提交</button>
</div>
</div>
</div>
2021-09-12 02:39:09 -07:00
</div>
{% for c in range(periods|length + 1) %}
2021-09-14 02:49:16 -07:00
{% if c % 4 == 0 %}
<div class="row signatures">
{% endif %}
<div class="col half">
2021-09-12 02:39:09 -07:00
{% if c == 0 %}
2021-10-05 04:22:23 -07:00
<div class="row needborder">Homeroom Teacher 導師</div>
2021-09-16 06:19:10 -07:00
{% if 'confirm' in absData[currDate] %}
2021-09-12 02:39:09 -07:00
<div class="row"><img src="{{absData[currDate]['confirm']}}" alt=""></div>
<div class="row">備註: {{absData[currDate]['notes']}}</div>
2021-09-12 02:39:09 -07:00
{% else %}
2021-09-16 06:19:10 -07:00
<div class="row"><span style="color:red;">No Signature 導師尚未簽名</span></div>
{% endif %}
{% else %}
2021-09-12 02:39:09 -07:00
{% if absData[currDate][periods[c-1]]['name'] == 'GP' %}
{% if 'signature' in absData[currDate][periods[c-1]] %}
{% for i in absData[currDate][periods[c-1]]['signature'] %}
2021-10-05 04:22:23 -07:00
<div class="row needborder">{{periods[c-1]}}: {{absData[currDate][periods[c-1]]['teacher']}}: {{i}}:
2021-09-16 06:19:10 -07:00
{{absData[currDate][periods[c-1]]['names'][i]}}</div>
2021-10-05 04:22:23 -07:00
<div class="row"><img src="{{absData[currDate][periods[c-1]]['signature'][i]}}" alt="">
{% if loop.index == loop.length %}
<br>備註: {{absData[currDate][periods[c-1]]['notes']}}
{% endif %}
</div>
2021-09-12 02:39:09 -07:00
{% endfor %}
{% else %}
2021-10-05 04:22:23 -07:00
<div class="row needborder">{{periods[c-1]}}: {{absData[currDate][periods[c-1]]['teacher']}}: No
Signature
2021-09-12 02:39:09 -07:00
</div>
<div class="row"></div>
{% endif %}
{% else %}
2021-10-05 04:22:23 -07:00
<div class="row needborder">{{periods[c-1]}}: {{absData[currDate][periods[c-1]]['name']}}:
2021-09-12 02:39:09 -07:00
{{absData[currDate][periods[c-1]]['teacher']}}
</div>
2021-09-14 02:49:16 -07:00
<div class="row"><img src="{{absData[currDate][periods[c-1]]['signature']}}" alt=""><br>備註:
{{absData[currDate][periods[c-1]]['notes']}}</div>
2021-09-12 02:39:09 -07:00
{% endif %}
{% endif %}
</div>
2021-09-14 02:49:16 -07:00
{% if c % 4 == 3 %}
</div>
{% endif %}
{% endfor %}
</div>
</div>
<script src="https://cdn.jsdelivr.net/npm/signature_pad@2.3.2/dist/signature_pad.min.js"></script>
2021-09-12 02:44:27 -07:00
<script type="text/javascript" src="/static/jquery.min.js"></script>
2021-10-19 07:30:49 -07:00
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.1.3/dist/js/bootstrap.bundle.min.js"
integrity="sha384-ka7Sk0Gln4gmtz2MlQnikT1wXgYsOg+OMhuP+IlRH9sENBO0LRn5q+8nbTov4+1p"
crossorigin="anonymous"></script>
<div id="loading" style="text-align:center; width:100%; display:none;"><img src="/static/loading.gif" alt=""
style="height:100%;" />
</div>
2021-09-24 22:31:36 -07:00
{% include 'footer.html' %}
<script>
2021-09-12 06:59:31 -07:00
var periodData = {}
{% for i in periods %}
periodData['{{i}}'] = '{{ absData[currDate][i]['name'] }}'
{% endfor %}
2021-10-15 05:29:53 -07:00
function edit(string) {
$('.view-' + string).each(function (i, obj) {
var num = $(this.firstElementChild).attr('class').split(' ')[2].replace('view-n-', '');
if ($(this.firstElementChild).attr('class').split(' ')[1] == "n-1") {
$(this).html("")
$(this).append("<input type=\"checkbox\" class=\"tobeform 2^" + string + "^" + num + " late\" id=\"late^" + string + "^" + num + "\" onchange=\"unCheckAbs('" + string + "^" + num + "')\">");
$(this).append("\n<input type=\"checkbox\" class=\"tobeform 1^" + string + "^" + num + " absent\" id=\"absent^" + string + "^" + num + "\" onchange=\"unCheckLate('" + string + "^" + num + "')\">");
} else if ($(this.firstElementChild).attr('class').split(' ')[1] == "n-2") {
$(this).html("")
$(this).append("<input type=\"checkbox\" class=\"tobeform 2^" + string + "^" + num + " late\" id=\"late^" + string + "^" + num + "\" onchange=\"unCheckAbs('" + string + "^" + num + "')\">");
$(this).append("\n<input type=\"checkbox\" class=\"tobeform 1^" + string + "^" + num + " absent\" id=\"absent^" + string + "^" + num + "\" onchange=\"unCheckLate('" + string + "^" + num + "')\" checked>");
} else {
$(this).html("")
$(this).append("<input type=\"checkbox\" class=\"tobeform 2^" + string + "^" + num + " late\" id=\"late^" + string + "^" + num + "\" onchange=\"unCheckAbs('" + string + "^" + num + "')\" checked>");
$(this).append("\n<input type=\"checkbox\" class=\"tobeform 1^" + string + "^" + num + " absent\" id=\"absent^" + string + "^" + num + "\" onchange=\"unCheckLate('" + string + "^" + num + "')\" checked>");
}
});
$('#btns-' + string).html("")
$('.afterSelButton').attr('disabled', 'disabled');
$('#btns-' + string).append("<button class=\"btn btn-secondary editSaveButton\" onclick=\"afterSelAbs('" + string + "', 'edit')\">Save</button>");
}
</script>
2021-10-19 07:30:49 -07:00
<script src="/static/pagejs/homeroom.js"></script>
2021-09-18 07:04:31 -07:00
<script src="/static/time.js"></script>
</body>
</html>