Files
Grinch-AP/WebHostLib/templates/tracker.html

168 lines
8.2 KiB
HTML
Raw Normal View History

{% extends 'layout.html' %}
{% block head %}
2020-06-21 15:42:26 +02:00
<title>Multiworld Tracker for Room {{ room.id }}</title>
2020-06-30 07:32:05 +02:00
<link rel="stylesheet" type="text/css" href="{{ static_autoversion("static.css") }}"/>
<script src="{{ static_autoversion("jquery.scrollsync.js") }}"></script>
2020-07-19 20:52:04 +02:00
<link rel="stylesheet" type="text/css" href="https://cdn.datatables.net/v/bs4-4.1.1/jq-3.3.1/dt-1.10.21/datatables.min.css"/>
<script type="text/javascript" src="https://cdn.datatables.net/v/bs4-4.1.1/jq-3.3.1/dt-1.10.21/datatables.min.js"></script>
<script>
window.onload = () => {
let tables = $(".table").DataTable({
"paging": false,
"ordering": true,
"info": false,
2020-06-30 07:32:05 +02:00
"dom": "t",
"scrollY": "39vh",
"scrollCollapse": true,
});
2020-06-24 18:22:18 +02:00
$('#searchbox').keyup(function () {
tables.search($(this).val()).draw();
2020-06-24 18:22:18 +02:00
});
function update() {
var target = $("<div></div>");
2020-06-27 18:17:36 +02:00
target.load("/tracker/{{ room.tracker }}", function (response, status) {
2020-06-24 18:22:18 +02:00
if (status === "success") {
target.find(".table").each(function (i, new_table) {
var new_trs = $(new_table).find("tbody>tr");
var old_table = tables.eq(i);
2020-06-30 07:32:05 +02:00
var topscroll = $(old_table.settings()[0].nScrollBody).scrollTop();
var leftscroll = $(old_table.settings()[0].nScrollBody).scrollLeft();
2020-06-24 18:22:18 +02:00
old_table.clear();
old_table.rows.add(new_trs).draw();
2020-06-30 07:32:05 +02:00
$(old_table.settings()[0].nScrollBody).scrollTop(topscroll);
$(old_table.settings()[0].nScrollBody).scrollLeft(leftscroll);
2020-06-24 18:22:18 +02:00
});
} else {
console.log("Failed to connect to Server, in order to update Table Data.");
console.log(response);
}
})
}
setInterval(update, 30000);
2020-06-30 07:32:05 +02:00
$(".dataTables_scrollBody").scrollsync({
y_sync: true,
x_sync: true
})
$(window).resize(function () {
tables.draw();
});
setTimeout(
tables.draw, {# this fixes the top header misalignment, for some reason #}
500
);
}
</script>
2020-06-30 07:32:05 +02:00
{% endblock %}
{% block body %}
<input id="searchbox" class="form-control" type="text" placeholder="Search" />
2020-06-30 07:32:05 +02:00
<div>
{% for team, players in inventory.items() %}
<table class="table table-striped table-bordered table-hover table-sm">
<thead class="thead-dark">
<tr>
<th>#</th>
<th>Name</th>
{% for name in tracking_names %}
{% if name in icons %}
<th style="text-align: center">
<img class="alttp-sprite" src="{{ icons[name] }}" alt="{{ name|e }}">
</th>
{% else %}
<th>{{ name|e }}</th>
{% endif %}
{% endfor %}
</tr>
</thead>
<tbody>
{% for player, items in players.items() %}
<tr>
<td class="table-info">{{ loop.index }}</td>
{% if (team, loop.index) in video %}
<td class="table-info">
<a target="_blank" href="https://www.twitch.tv/{{ video[(team, loop.index)][1] }}">
{{ player_names[(team, loop.index)] }}
▶️</a></td>
{% else %}
<td class="table-info">{{ player_names[(team, loop.index)] }}</td>
{% endif %}
{% for id in tracking_ids %}
{% if items[id] %}
<td style="text-align: center" class="table-success">
{% if id in multi_items %}{{ items[id] }}{% else %}✔️{% endif %}</td>
{% else %}
<td></td>
{% endif %}
{% endfor %}
</tr>
{% endfor %}
</tbody>
</table>
{% endfor %}
2020-06-22 00:58:18 +02:00
{% for team, players in checks_done.items() %}
<table class="table table-striped table-bordered table-hover table-sm">
<thead class="thead-dark">
<tr>
<th rowspan="2">#</th>
<th rowspan="2">Name</th>
{% for area in ordered_areas %}
{% set colspan = (3 if area in key_locations else 1) %}
{% if area in icons %}
<th colspan="{{ colspan }}" style="text-align: center"><img class="alttp-sprite"
src="{{ icons[area] }}"
alt="{{ area }}"></th>
2020-06-22 00:58:18 +02:00
{% else %}
<th colspan="{{ colspan }}">{{ area }}</th>
2020-06-22 00:58:18 +02:00
{% endif %}
{% endfor %}
<th rowspan="2">Last Activity</th>
</tr>
2020-06-23 02:50:07 +02:00
<tr>
{% for area in ordered_areas %}
<th style="text-align: center"><img class="alttp-sprite" src="{{ icons["Chest"] }}" alt="Checks">
</th>
2020-06-24 16:06:19 +02:00
{% if area in key_locations %}
<th style="text-align: center"><img class="alttp-sprite"
src="{{ icons["Small Key"] }}" alt="Small Key"></th>
<th style="text-align: center"><img class="alttp-sprite"
src="{{ icons["Big Key"] }}" alt="Big Key"></th>
2020-06-24 16:06:19 +02:00
{% endif %}
2020-06-23 02:50:07 +02:00
{% endfor %}
</tr>
</thead>
<tbody>
{% for player, checks in players.items() %}
<tr>
<td class="table-info">{{ loop.index }}</td>
<td class="table-info">{{ player_names[(team, loop.index)]|e }}</td>
{% for area in ordered_areas %}
{% set checks_done = checks[area] %}
{% set checks_total = checks_in_area[area] %}
{% if checks_done == checks_total %}
<td style="text-align: center" class="table-success">
{{ checks_done }}/{{ checks_total }}</td>
{% else %}
<td style="text-align: center">{{ checks_done }}/{{ checks_total }}</td>
{% endif %}
{% if area in key_locations %}
<td>{{ inventory[team][player][small_key_ids[area]] }}</td>
<td>{% if inventory[team][player][big_key_ids[area]] %}✔️{% endif %}</td>
{% endif %}
{% endfor %}
{% if activity_timers[(team, player)] %}
<td class="table-info">{{ activity_timers[(team, player)] | render_timedelta }}</td>
{% else %}
<td class="table-warning">None</td>{% endif %}
</tr>
{% endfor %}
</tbody>
</table>
{% endfor %}
2020-06-30 07:32:05 +02:00
</div>
{% endblock %}