aboutsummaryrefslogtreecommitdiff
path: root/templates/core/screenshots.html
blob: f48d888e78b5537c28153aac4f215feea138720c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
{% extends "_layouts/base.html" %}
{% load static %}
{% load i18n %}

{% block head %}
<link type="text/css" rel="stylesheet" href="{% static 'css/core/screenshots.css' %}" />
{% endblock head %}

{% block content %}
<div class="scr-room">
    <div class="scr-monitor" id="scr-monitor">
        <img class="scr-img" id="scr-img" alt="" />
        <div class="scr-noise" id="scr-noise">{% trans "no signal" %}</div>
    </div>
</div>
<div class="scr-hint" id="scr-hint">{% trans "press ← or → to change picture" %}</div>

<div class="scr-zoom" id="scr-zoom">
    <img class="scr-zoom-img" id="scr-zoom-img" alt="" />
</div>

<script id="scr-data" type="application/json">[{% for s in shots %}{"id":"{{ s.id }}","url":"{{ s.url }}"}{% if not forloop.last %},{% endif %}{% endfor %}]</script>

<script>
(function() {
    var shots = JSON.parse(document.getElementById('scr-data').textContent || '[]');
    var img = document.getElementById('scr-img');
    var noise = document.getElementById('scr-noise');
    var hint = document.getElementById('scr-hint');
    var zoom = document.getElementById('scr-zoom');
    var zoomImg = document.getElementById('scr-zoom-img');
    var monitor = document.getElementById('scr-monitor');

    if (!shots.length) {
        img.style.display = 'none';
        noise.style.display = 'flex';
        hint.style.display = 'none';
        return;
    }

    var idx = 0;
    var cache = {};
    var AHEAD = 4;

    function preload(i) {
        if (i < 0 || i >= shots.length || cache[i]) return;
        var im = new Image();
        im.src = shots[i].url;
        cache[i] = im;
    }

    function show(i) {
        idx = (i + shots.length) % shots.length;
        img.src = shots[idx].url;
        for (var j = 1; j <= AHEAD; j++) preload(idx + j);
        preload(idx - 1);
        hint.textContent = (idx + 1) + ' / ' + shots.length + ' — {% trans "press ← or → to change picture" %}';
    }

    function navigate(dir) {
        show(idx + dir);
        if (zoom.classList.contains('is-open')) zoomImg.src = shots[idx].url;
    }

    function openZoom() {
        zoomImg.src = shots[idx].url;
        zoom.classList.add('is-open');
        document.body.style.overflow = 'hidden';
    }

    function closeZoom() {
        zoom.classList.remove('is-open');
        document.body.style.overflow = '';
    }

    monitor.addEventListener('click', openZoom);
    zoom.addEventListener('click', closeZoom);

    document.addEventListener('keydown', function(e) {
        if (e.key === 'Escape' && zoom.classList.contains('is-open')) { closeZoom(); return; }
        if (e.key === 'ArrowLeft') { e.preventDefault(); navigate(-1); }
        else if (e.key === 'ArrowRight') { e.preventDefault(); navigate(1); }
    });

    show(0);
})();
</script>
{% endblock content %}