]> git.immae.eu Git - github/wallabag/wallabag.git/blob - src/Wallabag/CoreBundle/Resources/views/themes/material/Entry/entry.html.twig
e89aea3a7c28dd6ee5f5e1a028d5499e7a3c575e
[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|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 class="waves-effect" href="{{ path('homepage') }}">
16 <i class="mdi-action-exit-to-app"></i>
17 </a>
18 </li>
19 </ul>
20 <ul class="right">
21 <li>
22 <a class="waves-effect" title="{{ 'entry.view.left_menu.set_as_read'|trans }}" href="{{ path('archive_entry', { 'id': entry.id }) }}" id="markAsRead">
23 <i class="{% if entry.isArchived == 0 %}mdi-action-done{% else %}mdi-content-redo{% endif %} small"></i>
24 </a>
25 </li>
26 <li>
27 <a class="waves-effect" title="{{ 'entry.view.left_menu.set_as_favorite'|trans }}" href="{{ path('star_entry', { 'id': entry.id }) }}" id="setFav">
28 <i class="{% if entry.isStarred == 0 %}mdi-action-favorite-outline{% else %}mdi-action-favorite{% endif %} small"></i>
29 </a>
30 </li>
31 <li>
32 <a href="#" data-activates="slide-out" class="button-collapse right">
33 <i class="mdi-navigation-menu"></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="mdi-action-exit-to-app small"></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" href="{{ entry.url|e }}">
50 <i class="mdi-content-link small"></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 hide-on-med-and-down">
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="mdi-action-autorenew small"></i>
59 <span>{{ 'entry.view.left_menu.re_fetch_content'|trans }}</span>
60 </a>
61 <div class="collapsible-body"></div>
62 </li>
63
64 <li class="bold hide-on-med-and-down">
65 <a class="waves-effect collapsible-header" title="{{ 'entry.view.left_menu.set_as_read'|trans }}" href="{{ path('archive_entry', { 'id': entry.id }) }}" id="markAsRead">
66 <i class="{% if entry.isArchived == 0 %}mdi-action-done{% else %}mdi-content-redo{% endif %} small"></i>
67 <span>{% if entry.isArchived == 0 %}{{ 'entry.view.left_menu.set_as_read'|trans }}{% else %}{{ 'entry.view.left_menu.set_as_unread'|trans }}{% endif %}</span>
68 </a>
69 <div class="collapsible-body"></div>
70 </li>
71
72 <li class="bold hide-on-med-and-down">
73 <a class="waves-effect collapsible-header" title="{{ 'entry.view.left_menu.set_as_favorite'|trans }}" href="{{ path('star_entry', { 'id': entry.id }) }}" id="setFav">
74 <i class="{% if entry.isStarred == 0 %}mdi-action-favorite-outline{% else %}mdi-action-favorite{% endif %} small"></i>
75 <span>{{ 'entry.view.left_menu.set_as_favorite'|trans }}</span>
76 </a>
77 <div class="collapsible-body"></div>
78 </li>
79 <li class="bold border-bottom hide-on-med-and-down">
80 <a class="waves-effect collapsible-header" title="{{ 'entry.view.left_menu.delete'|trans }}" href="{{ path('delete_entry', { 'id': entry.id }) }}">
81 <i class="mdi-action-delete small"></i>
82 <span>{{ 'entry.view.left_menu.delete'|trans }}</span>
83 </a>
84 <div class="collapsible-body"></div>
85 </li>
86
87 <li class="bold border-bottom hide-on-med-and-down">
88 <a class="waves-effect collapsible-header" id="nav-btn-add-tag">
89 <i class="mdi-action-label-outline small"></i>
90 <span>{{ 'entry.view.left_menu.add_a_tag'|trans }}</span>
91 </a>
92 <div class="collapsible-body"></div>
93 </li>
94
95 <li class="bold">
96 <a class="waves-effect collapsible-header">
97 <i class="mdi-social-share small"></i>
98 <span>{{ 'entry.view.left_menu.share_content'|trans }}</span>
99 </a>
100 <div class="collapsible-body">
101 <ul>
102 {% if craue_setting('share_twitter') %}
103 <li>
104 <a href="https://twitter.com/home?status={{entry.title|url_encode}}%20{{ entry.url|url_encode }}%20via%20@wallabagapp" target="_blank" class="tool twitter icon icon-twitter" title="twitter">
105 <span>twitter</span>
106 </a>
107 </li>
108 {% endif %}
109 {% if craue_setting('share_shaarli') %}
110 <li>
111 <a href="{{ craue_setting('shaarli_url') }}/index.php?post={{ entry.url|url_encode }}&amp;title={{ entry.title|url_encode }}" target="_blank" class="tool shaarli" title="shaarli">
112 <span>shaarli</span>
113 </a>
114 </li>
115 {% endif %}
116 {% if craue_setting('share_diaspora') %}
117 <li>
118 <a href="{{ craue_setting('diaspora_url') }}/bookmarklet?url={{ entry.url|url_encode }}&title={{ entry.title|url_encode }}&notes=&v=1&noui=1&jump=doclose" target="_blank" class="tool diaspora icon-image icon-image--diaspora" title="diaspora}">
119 <span>diaspora*</span>
120 </a>
121 </li>
122 {% endif %}
123 {% if craue_setting('carrot') %}
124 <li>
125 <a href="https://secure.carrot.org/GiveAndGetBack.do?url={{ entry.url|url_encode }}&title={{ entry.title|url_encode }}" class="tool carrot icon-image icon-image--carrot" target="_blank" title="carrot">
126 <span>Carrot</span>
127 </a>
128 </li>
129 {% endif %}
130 {% if craue_setting('share_mail') %}
131 <li>
132 <a href="mailto:?subject={{ entry.title|url_encode }}&amp;body={{ entry.url|url_encode }}%20via%20@wallabagapp" class="tool email icon icon-mail" title="{{ 'entry.view.left_menu.share_email_label'|trans }}">
133 <span>{{ 'entry.view.left_menu.share_email_label'|trans }}</span>
134 </a>
135 </li>
136 {% endif %}
137 </ul>
138 </div>
139 </li>
140
141 {% if craue_setting('show_printlink') %}
142 <li class="bold border-bottom hide-on-med-and-down">
143 <a class="waves-effect collapsible-header" title="{{ 'entry.view.left_menu.print'|trans }}" href="javascript: window.print();">
144 <i class="mdi-action-print small"></i>
145 <span>{{ 'entry.view.left_menu.print'|trans }}</span>
146 </a>
147 <div class="collapsible-body"></div>
148 </li>
149 {% endif %}
150
151
152 <li class="bold">
153 <a class="waves-effect collapsible-header">
154 <i class="mdi-file-file-download small"></i>
155 <span>{{ 'entry.view.left_menu.download'|trans }}</span>
156 </a>
157 <div class="collapsible-body">
158 <ul>
159 {% if craue_setting('export_epub') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'epub' }) }}" title="Generate ePub file">EPUB</a></li>{% endif %}
160 {% if craue_setting('export_mobi') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'mobi' }) }}" title="Generate Mobi file">MOBI</a></li>{% endif %}
161 {% if craue_setting('export_pdf') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'pdf' }) }}" title="Generate PDF file">PDF</a></li>{% endif %}
162 {% if craue_setting('export_csv') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'csv' }) }}" title="Generate CSV file">CSV</a></li>{% endif %}
163 {% if craue_setting('export_json') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'json' }) }}" title="Generate JSON file">JSON</a></li>{% endif %}
164 {% if craue_setting('export_txt') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'txt' }) }}" title="Generate TXT file">TXT</a></li>{% endif %}
165 {% if craue_setting('export_xml') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'xml' }) }}" title="Generate XML file">XML</a></li>{% endif %}
166 </ul>
167 </div>
168 </li>
169
170 <li class="bold hide-on-large-only">
171 <a class="waves-effect collapsible-header" title="{{ 'entry.view.left_menu.delete'|trans }}" href="{{ path('delete_entry', { 'id': entry.id }) }}">
172 <i class="mdi-action-delete small"></i>
173 <span>{{ 'entry.view.left_menu.delete'|trans }}</span>
174 </a>
175 <div class="collapsible-body"></div>
176 </li>
177
178 <li class="bold">
179 <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 }}">
180 <i class="mdi-alert-error small"></i>
181 <span>{{ 'entry.view.left_menu.problem.label'|trans }}</span>
182 </a>
183 <div class="collapsible-body"></div>
184 </li>
185
186 </ul>
187
188 {% endblock %}
189
190 {% block content %}
191 <div id="article">
192 <header class="mbm">
193 <h1>{{ entry.title|raw }} <a href="{{ path('edit', { 'id': entry.id }) }}" title="{{ 'entry.view.edit_title'|trans }}">✎</a></h1>
194 </header>
195 <aside>
196 <a href="{{ entry.url|e }}" target="_blank" title="{{ 'entry.view.original_article'|trans }} : {{ entry.title|e }}" class="tool link mdi-content-link"> <span>{{ entry.domainName|removeWww }}</span></a>
197 <span class="tool link mdi-communication-comment"> {{ 'entry.view.annotations_on_the_entry'|transchoice(entry.annotations | length) }}</span>
198 <div id="list">
199 {% for tag in entry.tags %}
200 <div class="chip">
201 {{ tag.label }} <a href="{{ path('remove_tag', { 'entry': entry.id, 'tag': tag.id }) }}"><i class="mdi-action-delete"></i></a>
202 </div>
203 {% endfor %}
204 </div>
205
206 <div class="input-field nav-panel-add-tag" style="display: none">
207 {{ render(controller( "WallabagCoreBundle:Tag:addTagForm", { 'id': entry.id } )) }}
208 </div>
209
210 {% if entry.previewPicture is not null %}
211 <div><img class="preview" src="{{ entry.previewPicture }}" alt="{{ entry.title|raw }}" /></div>
212 {% endif %}
213
214 </aside>
215 <article>
216 {{ entry.content | raw }}
217 </article>
218 </div>
219
220 <script type="text/javascript">
221
222 var app = new annotator.App();
223 app.include(annotator.ui.main, {
224 element: document.querySelector('article')
225 });
226 app.include(annotator.storage.http, {
227 prefix: '',
228 urls: {
229 create: '{{ path('annotations_post_annotation', { 'entry': entry.id }) }}',
230 update: '{{ path('annotations_put_annotation', { 'annotation': 'idAnnotation' }) }}',
231 destroy: '{{ path('annotations_delete_annotation', { 'annotation': 'idAnnotation' }) }}',
232 search: '{{ path('annotations_get_annotations', { 'entry': entry.id }) }}'
233 }
234 });
235 app
236 .start()
237 .then(function () {
238 app.annotations.load({entry: {{ entry.id }}});
239 });
240 </script>
241
242 {% endblock %}
243
244 {% block footer %}
245 {% endblock %}