22106b473f28ba43a8db961654c6467f39a6c7c2
[wolnelektury.git] / src / catalogue / templates / catalogue / book_text.html
1 {% extends "base.html" %}
2
3
4 {% load i18n l10n %}
5 {% load catalogue_tags %}
6 {% load chunks %}
7 {% load thumbnail %}
8 {% load static %}
9 {% load annoy %}
10
11
12 {% block title %}{{ book.pretty_title }}{% endblock %}
13
14
15 {% block extrahead %}
16   <link rel="stylesheet" href="https://unpkg.com/leaflet@1.7.1/dist/leaflet.css"
17         integrity="sha512-xodZBNTC5n17Xt2atTPuE1HxjVMSvLVW9ocqUKLsCC5CXdbqCmblAshOMAS6/keqq/sMZMZ19scR4PsZChSR7A=="
18         crossorigin=""/>
19   <script src="https://unpkg.com/leaflet@1.7.1/dist/leaflet.js"
20           integrity="sha512-XQoYMqMTK8LvdxXYG3nZ448hOEQiglfqkJs1NOQV44cWnUrBc8PkAOcXy20w0vlaXaVUearIOBhiXZ5V3ynxwA=="
21           crossorigin=""></script>
22 {% endblock %}
23
24
25 {% block menu %}
26   <li>
27     <a href="{{ book.get_absolute_url }}" id="menu-book" data-box="book-short">
28       <span class="label">{% trans "Kliknij, by pobrać" %}:</span>
29       <img src="{% if book.cover_clean %}{% thumbnail book.cover_clean '240x332' as thumb %}{{ thumb.url }}{% empty %}{{ book.cover_clean.url }}{% endthumbnail %}{% endif %}"
30            width="120" height="166"
31            alt="{{ book.pretty_title }}"
32            title="{{ book.pretty_title }}">
33     </a>
34   </li>
35
36   {% if book.other_versions.exists %}
37     <li id="menu-other">
38       <a href="#" data-box="other">
39         <span class="label">{% trans "Inne wersje" %}</span>
40       </a>
41     </li>
42   {% endif %}
43
44   {% if extra_info.logo_mono %}
45     {% thumbnail extra_info.logo_mono '200x200' as th %}
46     <img src="{{ th.url }}" style="width: 100px; padding: 10px;"
47          alt="{{ extra_info.logo_alt|default:'Sponsor' }}"
48     >
49   {% endthumbnail %}
50   {% endif %}
51
52
53
54 {% endblock menu %}
55
56
57
58 {% block breadcrumb-right %}
59   <div class="l-text_toolbar" id="menu">
60     <a href="#info" data-box="info">
61       <img src="{% static '2022/images/about.svg' %}" alt="{% trans "Informacje" %}">
62     </a>
63
64     <a href="#" data-box="settings" style="display: none;">
65       <img src="{% static '2022/images/settings.svg' %}" alt="{% trans "Ustawienia" %}">
66     </a>
67
68     <a href="#wltoc" data-box="wltoc" style="display: none;">
69       <img src="{% static '2022/images/toc.svg' %}" alt="{% trans "Spis treści" %}">
70     </a>
71
72
73
74
75     <div id="info" class="box">
76       {% book_info book %}
77     </div>
78
79
80     <div id="settings" class="box">
81       <a href="#" class="settings-switch" id="settings-line-numbers"
82          data-setting="always-hide-line-numbers"><span>{% trans "Numeracja" %}</span></a>
83       <a href="#" class="settings-switch" id="settings-themes"
84          data-setting="always-hide-themes"><span>{% trans "Motywy" %}</span></a>
85       <a href="#" class="settings-switch" id="settings-annotations"
86          data-setting="no-annotations"><span>{% trans "Przypisy" %}</span></a>
87       <a href="#" class="settings-switch" id="settings-references"
88          data-setting="no-references"><span>{% trans "Pinezki" %}</span></a>
89     </div>
90
91
92     <div id="wltoc" class="box">
93       {% if book.parent %}
94         {% for b in book.ancestors %}
95           {% if forloop.counter > 1 %}
96             <li>
97           {% endif %}
98           <a href="{% if b.html_file %}{% url 'book_text' b.slug %}{% else %}{{ b.get_absolute_url }}{% endif %}">{{ b.title }}</a>
99           <ol>
100         {% endfor %}
101         {% for b in book.get_siblings %}
102           <li>
103             {% if b == book %}
104               <strong>{{ b.title }}</strong>
105               <div id="heretoc"></div>
106             {% else %}
107               <a href="{% url 'book_text' b.get_first_text.slug %}">{{ b.title }}</a>
108             {% endif %}
109           </li>
110         {% endfor %}
111
112         {% for b in book.ancestor.all %}
113           </ol>
114           {% if not forloop.counter.last %}
115             </li>
116           {% endif %}
117         {% endfor %}
118       {% else %}
119         <strong>{{ book.title }}</strong>
120         <div id="heretoc"></div>
121         <ol>
122           {% for c in book.get_children %}
123             <li><a href="{% url 'book_text' c.get_first_text.slug %}">{{ c.title }}</a></li>
124           {% endfor %}
125         </ol>
126       {% endif %}
127     </div>
128
129   </div>
130 {% endblock %}
131
132
133
134
135 {% block main %}
136   <div id="global-progress" class="l-container" data-t="{{ book.get_time }}">
137     <div class="bar">
138       <span class="piece" style="flex-grow: 100;">
139         <span class="filled"></span>
140       </span>
141     </div>
142     <div class="progress-text">
143       Szacowany czas do końca: <span class="progress-text-value">-</span>
144     </div>
145   </div>
146
147   <header class="l-text_header">
148     <img class="l-text_header_cover" src="{% if book.cover_clean %}{{ book.cover_clean.url }}{% endif %}" alt="{{ book.pretty_title }}">
149
150     <div class="l-text_header__content">
151       <p class="l-text_header_author">{% for author in book.authors %}<a href="{{ author.get_absolute_url }}">{{ author.name }}</a>{% if not forloop.last %}, {% endif %}{% endfor %}
152       </p>
153       <h1 class="l-text_header_title"><a href="{{ book.get_absolute_url }}">{{ book.title }}</a></h1>
154       {% if book.translators.exists %}
155         <p class="l-header__translators">
156           {% for translator in book.translators.all %}
157             {% if forloop.first and translator.name != 'tłumacz nieznany' %}
158               {% trans "tłum." %}
159             {% endif %}
160             <a href="{{ translator.get_absolute_url }}">
161               {{ translator }}</a>{% if not forloop.last %}, {% endif %}
162           {% endfor %}
163         </p>
164       {% endif %}
165       <div style="margin-top:1em;">
166         {% content_warning book %}
167       </div>
168
169       {#% annoy_banner 'book-start' %#}
170
171       <div id="book-text-buttons">
172       </div>
173
174     </div>
175   </header>
176
177
178   <article id="main-text" {% if book.has_sync_file %}class="has-sync"{% endif %}>
179     {% with next=book.get_next_text prev=book.get_prev_text %}
180       {% if next %}
181         <a class="text_next-book" href="{% url 'book_text' next.slug %}">{{ next.title }}&nbsp;&rarr;</a>
182       {% endif %}
183       {% if prev %}
184         <a class="text_prev-book" href="{% url 'book_text' prev.slug %}">&larr;&nbsp;{{ prev.title }}</a>
185       {% endif %}
186       <div class="main-text-body">
187         {{ book_text|safe }}
188       </div>
189
190       <div class="l-checkout__box" style="margin: 2em 0;">
191         {% include 'club/donation_step1_form.html' with form=donation_form %}
192       </div>
193     {% endwith %}
194
195
196
197
198
199
200     <article id="other-text">
201       <a class="other-text-close" href="#">{% trans "Zamknij" %}</a>
202       <div id="other-text-waiter">{% trans "Proszę czekać..." %}</div>
203       <div id="other-text-body" style="display: none;"></div>
204     </article>
205
206     <div id="reference-box">
207       <div id="reference-map"></div>
208       <a id="reference-close" href="#">x</a>
209       <div id="reference-images">
210       </div>
211       <a id="reference-link" target="_blank"></a>
212     </div>
213
214     <div id="annotation-box"
215          data-default-leftoffset="40"
216     >
217       <div id="annotation">
218         <div id="annotation-content"></div>
219         <a id="footnote-link">Czytaj w przypisie dolnym</a>
220       </div>
221       <div class="pointer pointer-bottom"></div>
222       <div class="pointer pointer-top"></div>
223     </div>
224
225     <div id="qbox" class="qbox"
226          data-default-leftoffset="105"
227          data-attach-bottom="true"
228     >
229       <div class="content">
230         <a class="qbox-t-link" href="" title="Skopiuj link"><img src="{% static '2022/images/tool-link.svg' %}" alt="Skopiuj link"></a>
231         <a class="qbox-t-copy" href="" title="Skopiuj cytat"><img src="{% static '2022/images/tool-copy.svg' %}" alt="Skopiuj cytat"></a>
232         {% if request.user.is_authenticated %}
233           <a class="qbox-t-quote" href="" title="Zapisz cytat"><img src="{% static '2022/images/tool-quote.svg' %}" alt="Zapisz cytat"></a>
234         {% endif %}
235       </div>
236       <div class="pointer pointer-bottom"></div>
237       <div class="pointer pointer-top"></div>
238     </div>
239
240     <div id="zakladka" class="zakladka">
241       <div class="icon">
242         <img style="height: 30px;" class="icon-empty" src="{% static '2022/images/zakladka.svg' %}" alt="Zakładka">
243         <img class="icon-exists" src="{% static '2022/images/zakladka-full.svg' %}" alt="Istniejąca zakładka">
244         <img class="icon-note" src="{% static '2022/images/zakladka-note.svg' %}" alt="Notka">
245       </div>
246       <div id="zakladka-box">
247         <div class="content">
248           {% if request.user.is_authenticated %}
249             <div class="zakladka-tool zakladka-tool_zakladka_delete">
250               Usuń zakładkę
251             </div>
252             <div class="zakladka-tool zakladka-tool_zakladka">
253               Dodaj zakładkę
254             </div>
255             <div class="zakladka-tool zakladka-tool_sluchaj">
256               Słuchaj od tego miejsca
257             </div>
258             <div class="zakladka-tool_notka_text">
259               <textarea placeholder="Notatka"></textarea>
260               <svg height="16" width="16" xmlns="http://www.w3.org/2000/svg" id="notka-save">
261                 <circle r="7" cx="8" cy="8" fill="none" stroke="black" stroke-width="2px" stroke-dasharray="1,1" />
262               </svg>
263               <img src="{% static '2022/images/notka-saved.svg' %}" id="notka-saved">
264             </div>
265
266           {% else %}
267             <div class="zakladka-tool zakladka-tool_login">
268               <a href="{% url 'login' %}?next={{ request.path }}">
269                 Zaloguj się </a>
270               /
271               <a href="{% url 'register' %}?next={{ request.path }}"> Załóż konto
272               </a>
273           {% endif %}
274
275             </div>
276
277             <div class="pointer pointer-bottom"></div>
278             <div class="pointer pointer-top"></div>
279         </div>
280       </div>
281
282
283       {% if book.other_versions.exists %}
284         <div class="box" id="other">
285           <h2>{% trans "Inne wersje utworu" %}</h2>
286           <a class="other-text-close" href="#">{% trans "Zamknij drugą wersję" %}</a>
287           <ul>
288             {% spaceless %}
289               {% for other_version in book.other_versions %}
290                 <li>
291                   <a class="display-other"
292                      data-other="{{ other_version.html_url }}"
293                      href="{% url 'book_text' other_version.slug %}">
294                     {{ other_version.mini_box_nolink }}
295                   </a>
296                 </li>
297               {% endfor %}
298             {% endspaceless %}
299           </ul>
300         </div>
301       {% endif %}
302
303       <div id="annoy-stubs">
304         {% annoy_banners 'book-text-intermission' %}
305
306         {% for insert in inserts %}
307           {% include 'annoy/dynamic_insert.html' %}
308         {% endfor %}
309       </div>
310
311   </article>
312
313
314
315   {% if book.has_sync_file %}
316     <div id="player-bar">
317       {% include 'catalogue/snippets/jplayer_reader.html' %}
318     </div>
319     <script type="application/json" id="smil">
320      {{ book.get_sync|safe }}
321     </script>
322   {% endif %}
323
324
325   <div id="marker">
326
327   </div>
328
329   {% localize off %}
330   <script type="application/json" id="interesting-references">
331    {
332        {% for ref in book.references %}
333        {% if ref.entity.is_interesting %}
334        "{{ ref.entity.uri }}": {
335            {% if ref.entity.lat and ref.entity.lon %}
336            "location": [{{ ref.entity.lat }}, {{ ref.entity.lon }}],
337            {% endif %}
338            "images": {{ ref.entity.images|safe }},
339            "label": "{{ ref.entity.label }}",
340            "description": "{{ ref.entity.description }}",
341            "wikipedia_link": "{{ ref.entity.wikipedia_link }}"
342        },
343        {% endif %}
344        {% endfor %}
345        "": null
346    }
347   </script>
348
349   {% endlocalize %}
350
351 {% endblock main %}