Projekt

Obecné

Profil

Stáhnout (7.89 KB) Statistiky
| Větev: | Revize:
1
{% extends 'base.html.twig' %}
2
  
3
{% block title %}Heatmap.ZČU{% endblock %}
4
{% block stylesheets %}
5
  <link rel="stylesheet" href="{{ asset('css/leaflet.css') }}">
6
  <link rel="stylesheet" href="{{ asset('css/bootstrap.min.css') }}">
7
  <link rel="stylesheet" href="{{ asset('css/style.css') }}">
8
  <link rel="stylesheet" href="{{ asset('css/bootstrap-datepicker3.css') }}">
9
{% endblock %}
10

    
11
{% block body %}
12

    
13
  <header class="map">
14
    <nav class="navbar navbar-expand-lg ml-auto">
15
      <a href="{{ path('home') }}" class="navbar-brand">
16
        <h1>Heatmap.ZČU</h1>
17
      </a>
18

    
19
      <button type="button" class="navbar-toggler" data-toggle="collapse" data-target="#navigation" aria-controls="navigation" aria-expanded="false" aria-label="Toggle navigation">
20
        <span class="navbar-toggler-icon"></span>
21
      </button>
22

    
23
      <div class="collapse navbar-collapse ml-auto" id="navigation">
24
        {{ form_start(form, {'action': path('heatmap'), 'method': 'GET'}) }}
25
          <ul class="navbar-nav">
26
            <li class="nav-item">
27
              {{ form_label(form.date, 'Vyberte datum', {
28
                label_attr: {class: 'font-weight-bold'}
29
              }) }}
30
              {{ form_widget(form.date,
31
                {
32
                  'type' : 'text',
33
                  'id' : 'date',
34
                  'attr' : {
35
                    'class' : 'form-control',
36
                    'maxlength' : '10',
37
                    'placeholder' : 'YYYY-MM-DD',
38
                    'autocomplete' : 'off',
39
                    'onChange' : 'checkDataSetsAvailability("' ~ path('available') ~ '")'
40
                  }
41
                })
42
              }}
43
            </li>
44
            <li class="nav-item">
45
              <label class="font-weight-bold">Vyberte čas</label>
46
              <div class="dropdown">
47
                <button type="button" class="btn dropdown-toggle" id="dropdownMenuButtonTime" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
48
                  {{ current_time }}
49
                </button>
50
                <div id="dataset-dropdown-time" class="dropdown-menu" aria-labelledby="dropdownMenuButtonTime">
51
                  {% for oneTime in form.time.children %}
52
                  <label class="dropdown-item custom-dropdown-item">
53
                    {{ form_widget(oneTime, {attr: {class: 'd-none'}}) }}
54
                    {{ form_label(oneTime, null) }}
55
                  </label>
56
                  {% endfor %}
57
                </div>
58
              </div>
59
            </li>
60
            <li class="nav-item">
61
              <div class="dropdown">
62
                <button type="button" class="btn dropdown-toggle font-weight-bold" id="dropdownMenuButtonDataset" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
63
                  Vyberte datovou sadu
64
                </button>
65
                <div id="dataset-dropdown" class="dropdown-menu" aria-labelledby="dropdownMenuButtonDataset">
66
                  {% for oneDataset in form.type.children %}
67
                  <div class="dropdown-item custom-dropdown-item">
68
                    <div class="custom-control custom-checkbox custom-checkbox-{{oneDataset.vars.value}}">
69
                      {{ form_widget(oneDataset, {
70
                        attr: {
71
                          'class': "custom-control-input custom-control-input-#{oneDataset.vars.value}",
72
                          'data-dataset-display-name': "#{oneDataset.vars.label}"
73
                          }
74
                      }) }}
75
                      {{ form_label(oneDataset, null, {
76
                        'label_attr': {'class': 'custom-control-label'}
77
                      }) }}
78
                    </div>
79
                  </div>
80
                  {% endfor %}
81
                </div>
82
              </div>
83
            </li>
84
            <li class="nav-item">
85
              {{ form_widget(form.submit,
86
                {
87
                  'name' : '',
88
                  'label' : '',
89
                  'type' : 'submit',
90
                  'id' : 'submit-btn',
91
                  'attr' : {
92
                    'class': 'btn btn-secondary'
93
                  }
94
                })
95
              }}
96
            </li>
97
          </ul>
98
        {{ form_end(form) }}
99
      </div>
100
    </nav>
101
  </header>
102

    
103
  <div class="map-locations">
104
    <a class="menu" data-toggle="collapse" href="#mapLocations" role="button" aria-expanded="false" aria-controls="mapLocations">
105
      <span class="desktop">Prohlédněte si jednotlivé oblasti</span>
106
      <span class="mobile">Jednotlivé oblasti</span>
107
      <div class="circle"></div>
108
    </a>
109
    <div class="locations collapse" id="mapLocations">
110
      {% include 'heatmap-locations.html.twig' %}
111
    </div>
112
  </div>
113

    
114
  <div class="player">
115
    <div class="prev" onclick="previous()"></div>
116
    <div class="play" id="play-pause" onclick="changeAnimationState()"></div>
117
    <div class="next" onclick="next()"></div>
118

    
119
    <div class="datetime">
120
    
121
    {% if form.vars.value.date %}
122
      <div class="date" id="player-date" onclick="openDatepicker()">{{ form.vars.value.date|date('j. n. Y') }}</div>
123
    {% endif %}
124

    
125
    <div class="timeline">
126
      <div class="time hour-0" id="timeline">0:00</div>
127

    
128
      <div class="hour"></div>
129
      <div class="hour"></div>
130
      <div class="hour"></div>
131
      <div class="hour"></div>
132
      <div class="hour"></div>
133
      <div class="hour"></div>
134
      <div class="hour"></div>
135
      <div class="hour"></div>
136
      <div class="hour"></div>
137
      <div class="hour"></div>
138
      <div class="hour"></div>
139
      <div class="hour"></div>
140
      <div class="hour"></div>
141
      <div class="hour"></div>
142
      <div class="hour"></div>
143
      <div class="hour"></div>
144
      <div class="hour"></div>
145
      <div class="hour"></div>
146
      <div class="hour"></div>
147
      <div class="hour"></div>
148
      <div class="hour"></div>
149
      <div class="hour"></div>
150
      <div class="hour"></div>
151
      <div class="hour"></div>
152
      <div class="end-dot"></div>
153
    </div>
154
    </div>
155
  </div>
156

    
157
  <div id="heatmap"></div>
158
  
159
{% endblock %}
160

    
161
{% block javascripts %}
162

    
163
    <script src="{{ asset('js/vendor/jquery-3.4.1.min.js') }}"></script>
164
    <script src="{{ asset('js/vendor/bootstrap.min.js') }}"></script>
165
    <script src="{{ asset('js/vendor/bootstrap-datepicker.min.js') }}"></script>
166
    <script src="{{ asset('js/vendor/bootstrap-datepicker.cs.min.js') }}" charset="UTF-8"></script>
167
    <script src="{{ asset('js/vendor/leaflet.js') }}"></script>
168
    <script src="{{ asset('js/vendor/leaflet-heat.js') }}"></script>
169
    <script src="{{ asset('js/zcu-heatmap.js') }}"></script>
170
    <script>
171
        initDatepicker("{{ path('dates') }}");
172
        initLocationsMenu();
173
        initMap();        
174
        $(document).ready(function() {
175
          onDocumentReady();
176
          checkDataSetsAvailability("{{ path('available') }}")
177
          {% if submitted %}
178
          loadCurrentTimeHeatmap("{{ path('opendata') }}", "{{ path('positions') }}");
179
          {% endif %}
180
        });
181
        $(window).resize(function() {
182
          initLocationsMenu();
183
        });
184
  </script>
185

    
186
{% endblock %}
187

    
188
{% block style %}
189
  <style>
190
    {% for key, item in dataset_colors %}
191
      .custom-control-input-{{key}}:focus~.custom-control-label::before {
192
        border-color: {{item}} !important;
193
        box-shadow: 0 0 0 0.2rem rgba(192,192,192, 0.4) !important;
194
      }
195

    
196
      .custom-control-input-{{key}}:checked~.custom-control-label::before {
197
        border-color: {{item}} !important;
198
        background-color: {{item}} !important;
199
      }
200

    
201
      .custom-control-input-{{key}}:focus:not(:checked)~.custom-control-label::before {
202
        border-color: {{item}} !important;
203
      }
204

    
205
      .custom-control-input-{{key}}:not(:disabled):active~.custom-control-label::before {
206
        background-color: {{item}} !important;
207
        border-color: {{item}} !important;
208
      }
209

    
210
      .popup-{{key}} > .leaflet-popup-content-wrapper, .popup-{{key}} .leaflet-popup-tip {
211
        background-color: {{item}} !important;
212
      }
213
    {% endfor %}
214
  </style>
215
{% endblock %}
(3-3/4)