]> git.immae.eu Git - github/wallabag/wallabag.git/blob - src/Wallabag/CoreBundle/Resources/views/themes/material/Entry/entry.html.twig
Fixed sandwich menu position in entry view (material theme)
[github/wallabag/wallabag.git] / src / Wallabag / CoreBundle / Resources / views / themes / material / Entry / entry.html.twig
1 {% extends "WallabagCoreBundle::layout.html.twig" %}
2
3 {% block title %}{{ entry.title|striptags|raw }} ({{ entry.domainName|removeWww }}){% endblock %}
4
5 {% block body_class %}entry{% endblock %}
6
7 {% block menu %}
8 <div class="progress">
9 <div class="determinate"></div>
10 </div>
11 <nav class="hide-on-large-only">
12 <div class="nav-wrapper cyan darken-1">
13 <ul>
14 <li>
15 <a href="#" data-activates="slide-out" class="button-collapse">
16 <i class="material-icons">menu</i>
17 </a>
18 </li>
19 <li>
20 <a class="waves-effect" href="{{ path('homepage') }}">
21 <i class="material-icons">exit_to_app</i>
22 </a>
23 </li>
24 </ul>
25 <ul class="right">
26 <li>
27 <a class="waves-effect" title="{{ 'entry.view.left_menu.set_as_read'|trans }}" href="{{ path('archive_entry', { 'id': entry.id }) }}" id="markAsRead">
28 <i class="material-icons small">{% if entry.isArchived == 0 %}done{% else %}redo{% endif %}</i>
29 </a>
30 </li>
31 <li>
32 <a class="waves-effect" title="{{ 'entry.view.left_menu.set_as_starred'|trans }}" href="{{ path('star_entry', { 'id': entry.id }) }}" id="setFav">
33 <i class="material-icons small">{% if entry.isStarred == 0 %}star_outline{% else %}star{% endif %}</i>
34 </a>
35 </li>
36 </ul>
37 </div>
38 </nav>
39 <ul id="slide-out" class="collapsible side-nav fixed reader-mode" data-collapsible="accordion">
40 <li class="bold border-bottom hide-on-med-and-down">
41 <a class="waves-effect collapsible-header" href="{{ path('homepage') }}">
42 <i class="material-icons small">exit_to_app</i>
43 <span>{{ 'entry.view.left_menu.back_to_homepage'|trans }}</span>
44 </a>
45 <div class="collapsible-body"></div>
46 </li>
47
48 <li class="bold border-bottom hide-on-med-and-down">
49 <a class="waves-effect collapsible-header original" href="{{ entry.url|e }}" target="_blank">
50 <i class="material-icons small">link</i>
51 <span>{{ 'entry.view.left_menu.view_original_article'|trans }}</span>
52 </a>
53 <div class="collapsible-body"></div>
54 </li>
55
56 <li class="bold">
57 <a class="waves-effect collapsible-header" title="{{ 'entry.view.left_menu.re_fetch_content'|trans }}" href="{{ path('reload_entry', { 'id': entry.id }) }}" id="reload">
58 <i class="material-icons small">autorenew</i>
59 <span>{{ 'entry.view.left_menu.re_fetch_content'|trans }}</span>
60 </a>
61 <div class="collapsible-body"></div>
62 </li>
63
64 {% set markAsReadLabel = 'entry.view.left_menu.set_as_unread' %}
65 {% if entry.isArchived == 0 %}
66 {% set markAsReadLabel = 'entry.view.left_menu.set_as_read' %}
67 {% endif %}
68
69 <li class="bold hide-on-med-and-down">
70 <a class="waves-effect collapsible-header markasread" title="{{ markAsReadLabel|trans }}" href="{{ path('archive_entry', { 'id': entry.id }) }}" id="markAsRead">
71 <i class="material-icons small">{% if entry.isArchived == 0 %}done{% else %}redo{% endif %}</i>
72 <span>{{ markAsReadLabel|trans }}</span>
73 </a>
74 <div class="collapsible-body"></div>
75 </li>
76
77 <li class="bold hide-on-med-and-down">
78 <a class="waves-effect collapsible-header favorite" title="{{ 'entry.view.left_menu.set_as_starred'|trans }}" href="{{ path('star_entry', { 'id': entry.id }) }}" id="setFav">
79 <i class="material-icons spall">{% if entry.isStarred == 0 %}star_outline{% else %}star{% endif %}</i>
80 <span>{{ 'entry.view.left_menu.set_as_starred'|trans }}</span>
81 </a>
82 <div class="collapsible-body"></div>
83 </li>
84 <li class="bold border-bottom">
85 <a class="waves-effect collapsible-header delete" title="{{ 'entry.view.left_menu.delete'|trans }}" href="{{ path('delete_entry', { 'id': entry.id }) }}">
86 <i class="material-icons small">delete</i>
87 <span>{{ 'entry.view.left_menu.delete'|trans }}</span>
88 </a>
89 <div class="collapsible-body"></div>
90 </li>
91
92 <li class="bold border-bottom">
93 <a class="waves-effect collapsible-header" id="nav-btn-add-tag">
94 <i class="material-icons small">label_outline</i>
95 <span>{{ 'entry.view.left_menu.add_a_tag'|trans }}</span>
96 </a>
97 <div class="collapsible-body"></div>
98 </li>
99
100 <li class="bold">
101 <a class="waves-effect collapsible-header">
102 <i class="material-icons small">share</i>
103 <span>{{ 'entry.view.left_menu.share_content'|trans }}</span>
104 </a>
105 <div class="collapsible-body">
106 <ul>
107 {% if craue_setting('share_public') %}
108 <li>
109 <a href="{{ path('share', {'id': entry.id }) }}" target="_blank" title="{{ 'entry.view.left_menu.public_link'|trans }}" class="tool icon-eye">
110 <span>{{ 'entry.view.left_menu.public_link'|trans }}</span>
111 </a>
112 </li>
113 <li>
114 <a href="{{ path('delete_share', {'id': entry.id }) }}" title="{{ 'entry.view.left_menu.delete_public_link'|trans }}" class="tool icon-no-eye">
115 <span>{{ 'entry.view.left_menu.delete_public_link'|trans }}</span>
116 </a>
117 </li>
118 {% endif %}
119 {% if craue_setting('share_twitter') %}
120 <li>
121 <a href="https://twitter.com/home?status={{entry.title|striptags|url_encode}}%20{{ entry.url|url_encode }}%20via%20@wallabagapp" target="_blank" class="tool icon-twitter" title="twitter">
122 <span>twitter</span>
123 </a>
124 </li>
125 {% endif %}
126 {% if craue_setting('share_shaarli') %}
127 <li>
128 <a href="{{ craue_setting('shaarli_url') }}/index.php?post={{ entry.url|url_encode }}&amp;title={{ entry.title|striptags|url_encode }}&amp;tags={{ entry.tags|join(',')|striptags|url_encode }}" target="_blank">
129 <i class="tool icon-image icon-image--shaarli" title="shaarli"></i>
130 <span>shaarli</span>
131 </a>
132 </li>
133 {% endif %}
134 {% if craue_setting('share_scuttle') %}
135 <li>
136 <a href="{{ craue_setting('scuttle_url') }}/bookmarks.php?action=add&amp;address={{ entry.url|url_encode }}&amp;title={{ entry.title|striptags|url_encode }}&amp;tags={{ entry.tags|join(',')|striptags|url_encode }}" target="_blank">
137 <i class="tool icon-image icon-image--scuttle" title="scuttle"></i>
138 <span>scuttle</span>
139 </a>
140 </li>
141 {% endif %}
142 {% if craue_setting('share_diaspora') %}
143 <li>
144 <a href="{{ craue_setting('diaspora_url') }}/bookmarklet?url={{ entry.url|url_encode }}&amp;title={{ entry.title|striptags|url_encode }}&amp;notes=&amp;v=1&amp;noui=1&amp;jump=doclose" target="_blank">
145 <i class="tool icon-image icon-image--diaspora" title="diaspora"></i>
146 <span>diaspora*</span>
147 </a>
148 </li>
149 {% endif %}
150 {% if craue_setting('share_unmark') %}
151 <li>
152 <a href="{{ craue_setting('unmark_url') }}/mark/add?url={{ entry.url|url_encode }}&amp;title={{entry.title|striptags|url_encode}}&amp;v=6" target="_blank">
153 <i class="tool icon-image icon-image--unmark" title="unmark"></i>
154 <span>unmark.it</span>
155 </a>
156 </li>
157 {% endif %}
158 {% if craue_setting('carrot') %}
159 <li>
160 <a href="https://secure.carrot.org/GiveAndGetBack.do?url={{ entry.url|url_encode }}&amp;title={{ entry.title|striptags|url_encode }}" target="_blank" title="carrot">
161 <i class="tool icon-image icon-image--carrot"></i>
162 <span>Carrot</span>
163 </a>
164 </li>
165 {% endif %}
166 {% if craue_setting('share_mail') %}
167 <li>
168 <a href="mailto:?subject={{ entry.title|striptags|url_encode }}&amp;body={{ entry.url|url_encode }}%20via%20@wallabagapp" title="{{ 'entry.view.left_menu.share_email_label'|trans }}" class="tool email icon icon-mail">
169 <span>{{ 'entry.view.left_menu.share_email_label'|trans }}</span>
170 </a>
171 </li>
172 {% endif %}
173 </ul>
174 </div>
175 </li>
176
177 {% if craue_setting('show_printlink') %}
178 <li class="bold border-bottom hide-on-med-and-down">
179 <a class="waves-effect collapsible-header" title="{{ 'entry.view.left_menu.print'|trans }}" href="javascript: window.print();">
180 <i class="material-icons small">print</i>
181 <span>{{ 'entry.view.left_menu.print'|trans }}</span>
182 </a>
183 <div class="collapsible-body"></div>
184 </li>
185 {% endif %}
186
187 <li class="bold">
188 <a class="waves-effect collapsible-header">
189 <i class="material-icons small">file_download</i>
190 <span>{{ 'entry.view.left_menu.download'|trans }}</span>
191 </a>
192 <div class="collapsible-body">
193 <ul>
194 {% if craue_setting('export_epub') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'epub' }) }}" title="Generate ePub file">EPUB</a></li>{% endif %}
195 {% if craue_setting('export_mobi') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'mobi' }) }}" title="Generate Mobi file">MOBI</a></li>{% endif %}
196 {% if craue_setting('export_pdf') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'pdf' }) }}" title="Generate PDF file">PDF</a></li>{% endif %}
197 {% if craue_setting('export_csv') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'csv' }) }}" title="Generate CSV file">CSV</a></li>{% endif %}
198 {% if craue_setting('export_json') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'json' }) }}" title="Generate JSON file">JSON</a></li>{% endif %}
199 {% if craue_setting('export_txt') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'txt' }) }}" title="Generate TXT file">TXT</a></li>{% endif %}
200 {% if craue_setting('export_xml') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'xml' }) }}" title="Generate XML file">XML</a></li>{% endif %}
201 </ul>
202 </div>
203 </li>
204
205 <li class="bold">
206 <a class="waves-effect collapsible-header" href="mailto:hello@wallabag.org?subject=Wrong%20display%20in%20wallabag&amp;body={{ entry.url|url_encode }}" title="{{ 'entry.view.left_menu.problem.description'|trans }}">
207 <i class="material-icons small">error</i>
208 <span>{{ 'entry.view.left_menu.problem.label'|trans }}</span>
209 </a>
210 <div class="collapsible-body"></div>
211 </li>
212
213 </ul>
214
215 {% endblock %}
216
217 {% block content %}
218 <div id="article">
219 <header class="mbm">
220 <h1>{{ entry.title|striptags|raw }} <a href="{{ path('edit', { 'id': entry.id }) }}" title="{{ 'entry.view.edit_title'|trans }}">✎</a></h1>
221 </header>
222 <aside>
223 <ul class="tools">
224 <li>
225 {% include "@WallabagCore/themes/material/Entry/_reading_time.html.twig" with {'entry': entry} only %}
226 </li>
227 <li>
228 <i class="material-icons" title="{{ 'entry.view.created_at'|trans }}">today</i>
229 {{ entry.createdAt|date('Y-m-d H:i') }}
230 </li>
231 {% if entry.publishedAt is not null %}
232 <li>
233 <i class="material-icons" title="{{ 'entry.view.published_at'|trans }}">create</i>
234 {{ entry.publishedAt|date('Y-m-d H:i') }}
235 </li>
236 {% endif %}
237 {% if entry.publishedBy is not empty %}
238 <li>
239 <i class="material-icons" title="{{ 'entry.view.published_by'|trans }}">person</i>
240 {% for author in entry.publishedBy %}
241 {{ author }}{% if not loop.last %}, {% endif %}
242 {% endfor %}
243 </li>
244 {% endif %}
245 <li>
246 <i class="material-icons link">link</i>
247 <a href="{{ entry.url|e }}" target="_blank" title="{{ 'entry.view.original_article'|trans }} : {{ entry.title|striptags }}" class="tool">
248 {{ entry.domainName|removeWww }}
249 </a>
250 </li>
251 <li>
252 <i class="material-icons link">comment</i>
253 {{ 'entry.view.annotations_on_the_entry'|transchoice(entry.annotations | length) }}
254 </li>
255 <li id="list">
256 {% for tag in entry.tags %}
257 <div class="chip">
258 <a href="{{ path('tag_entries', {'slug': tag.slug}) }}">{{ tag.label }}</a> <a href="{{ path('remove_tag', { 'entry': entry.id, 'tag': tag.id }) }}"><i class="material-icons">delete</i></a>
259 </div>
260 {% endfor %}
261 </li>
262 </ul>
263
264 <div class="input-field nav-panel-add-tag" style="display: none">
265 {{ render(controller( "WallabagCoreBundle:Tag:addTagForm", { 'id': entry.id } )) }}
266 </div>
267
268 {% if entry.previewPicture is not null %}
269 <div><img class="preview" src="{{ entry.previewPicture }}" alt="{{ entry.title|striptags|e('html_attr') }}" /></div>
270 {% endif %}
271
272 </aside>
273 <article>
274 {{ entry.content | raw }}
275 </article>
276
277 <div class="fixed-action-btn horizontal click-to-toggle hide-on-large-only">
278 <a class="btn-floating btn-large">
279 <i class="material-icons">menu</i>
280 </a>
281 <ul>
282 <li><a class="btn-floating" href="{{ path('archive_entry', { 'id': entry.id }) }}"><i class="material-icons">done</i></a></li>
283 <li><a class="btn-floating" href="{{ path('star_entry', { 'id': entry.id }) }}"><i class="material-icons">star_outline</i></a></li>
284 <li><a class="btn-floating" href="{{ path('delete_entry', { 'id': entry.id }) }}"><i class="material-icons">delete</i></a></li>
285 </ul>
286 </div>
287 </div>
288
289 <script id="annotationroutes" type="application/json">
290 {
291 "prefix": "",
292 "urls": {
293 "create": "{{ path('annotations_post_annotation', { 'entry': entry.id }) }}",
294 "update": "{{ path('annotations_put_annotation', { 'annotation': 'idAnnotation' }) }}",
295 "destroy": "{{ path('annotations_delete_annotation', { 'annotation': 'idAnnotation' }) }}",
296 "search": "{{ path('annotations_get_annotations', { 'entry': entry.id }) }}"
297 },
298 "entryId": "{{ entry.id }}"
299 }</script>
300
301 {% endblock %}
302
303 {% block footer %}
304 {% endblock %}