2022-12-31 13:18:27 +00:00
|
|
|
{% extends 'base.html' %}
|
2023-02-19 15:18:14 +00:00
|
|
|
{% load static %}
|
2023-11-17 20:06:57 +00:00
|
|
|
{% block title %}
|
|
|
|
{{ title }}
|
|
|
|
{% endblock title %}
|
2022-12-31 13:18:27 +00:00
|
|
|
{% block content %}
|
2023-11-17 20:06:57 +00:00
|
|
|
{% if dataset.count >= 1 %}
|
|
|
|
<div class="mx-auto text-center my-4">
|
|
|
|
<a id="last-session-start"
|
2024-01-10 14:12:45 +00:00
|
|
|
href="{% url 'start_session_same_as_last' last.id %}"
|
|
|
|
hx-get="{% url 'start_session_same_as_last' last.id %}"
|
|
|
|
hx-swap="afterbegin"
|
|
|
|
hx-target=".responsive-table tbody"
|
|
|
|
onClick="document.querySelector('#last-session-start').classList.add('invisible')"
|
|
|
|
class="{% if last.timestamp_end == null %}invisible{% endif %}">
|
2023-11-17 20:06:57 +00:00
|
|
|
{% include 'components/button_start.html' with text=last.purchase title="Start session of last played game" only %}
|
|
|
|
</a>
|
|
|
|
</div>
|
|
|
|
{% endif %}
|
|
|
|
{% if dataset.count != 0 %}
|
|
|
|
<table class="responsive-table">
|
|
|
|
<thead>
|
|
|
|
<tr>
|
|
|
|
<th class="px-2 sm:px-4 md:px-6 md:py-2">Name</th>
|
|
|
|
<th class="hidden sm:table-cell px-2 sm:px-4 md:px-6 md:py-2">Start</th>
|
|
|
|
<th class="hidden lg:table-cell px-2 sm:px-4 md:px-6 md:py-2">End</th>
|
|
|
|
<th class="px-2 sm:px-4 md:px-6 md:py-2">Duration</th>
|
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
<tbody>
|
2024-01-10 14:12:45 +00:00
|
|
|
{% for session in dataset %}
|
|
|
|
{% partialdef session-row inline=True %}
|
|
|
|
<tr>
|
|
|
|
<td class="px-2 sm:px-4 md:px-6 md:py-2 purchase-name truncate max-w-20char md:max-w-40char">
|
|
|
|
<a class="underline decoration-slate-500 sm:decoration-2"
|
|
|
|
href="{% url 'view_game' session.purchase.edition.game.id %}">
|
|
|
|
{{ session.purchase.edition }}
|
|
|
|
</a>
|
|
|
|
</td>
|
|
|
|
<td class="px-2 sm:px-4 md:px-6 md:py-2 font-mono hidden sm:table-cell">
|
|
|
|
{{ session.timestamp_start | date:"d/m/Y H:i" }}
|
|
|
|
</td>
|
|
|
|
<td class="px-2 sm:px-4 md:px-6 md:py-2 font-mono hidden lg:table-cell">
|
2024-01-10 14:53:15 +00:00
|
|
|
{% if not session.timestamp_end %}
|
2024-01-10 14:12:45 +00:00
|
|
|
<a href="{% url 'update_session' session.id %}"
|
|
|
|
hx-get="{% url 'update_session' session.id %}"
|
|
|
|
hx-target="closest tr"
|
|
|
|
hx-swap="outerHTML"
|
|
|
|
hx-indicator="#indicator"
|
|
|
|
onClick="document.querySelector('#last-session-start').classList.remove('invisible')">
|
|
|
|
<span class="text-yellow-300">Finish now?</span>
|
|
|
|
</a>
|
|
|
|
{% elif session.duration_manual %}
|
|
|
|
--
|
|
|
|
{% else %}
|
|
|
|
{{ session.timestamp_end | date:"d/m/Y H:i" }}
|
|
|
|
{% endif %}
|
|
|
|
</td>
|
|
|
|
<td class="px-2 sm:px-4 md:px-6 md:py-2 font-mono">{{ session.duration_formatted }}</td>
|
|
|
|
</tr>
|
|
|
|
{% endpartialdef %}
|
2023-11-17 20:06:57 +00:00
|
|
|
{% endfor %}
|
|
|
|
</tbody>
|
|
|
|
</table>
|
|
|
|
{% else %}
|
|
|
|
<div class="mx-auto text-center text-slate-300 text-xl">No sessions found.</div>
|
|
|
|
{% endif %}
|
2023-09-17 11:28:15 +00:00
|
|
|
{% endblock content %}
|