]>
Commit | Line | Data |
---|---|---|
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="material-icons">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="material-icons small">{% if entry.isArchived == 0 %}done{% else %}redo{% endif %}</i> | |
24 | </a> | |
25 | </li> | |
26 | <li> | |
27 | <a class="waves-effect" title="{{ 'entry.view.left_menu.set_as_starred'|trans }}" href="{{ path('star_entry', { 'id': entry.id }) }}" id="setFav"> | |
28 | <i class="material-icons small">{% if entry.isStarred == 0 %}star_outline{% else %}star{% endif %}</i> | |
29 | </a> | |
30 | </li> | |
31 | <li> | |
32 | <a href="#" data-activates="slide-out" class="button-collapse right"> | |
33 | <i class="material-icons">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="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" href="{{ entry.url|e }}"> | |
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 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="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" 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" 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 hide-on-med-and-down"> | |
85 | <a class="waves-effect collapsible-header" 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 hide-on-med-and-down"> | |
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" class="public icon-link" title="{{ 'entry.view.left_menu.public_link'|trans }}"> | |
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 }) }}" class="tool public" title="{{ 'entry.view.left_menu.delete_public_link'|trans }}"> | |
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|url_encode}}%20{{ entry.url|url_encode }}%20via%20@wallabagapp" target="_blank" class="tool twitter icon 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 }}&title={{ entry.title|url_encode }}" target="_blank" class="tool shaarli" title="shaarli"> | |
129 | <span>shaarli</span> | |
130 | </a> | |
131 | </li> | |
132 | {% endif %} | |
133 | {% if craue_setting('share_diaspora') %} | |
134 | <li> | |
135 | <a href="{{ craue_setting('diaspora_url') }}/bookmarklet?url={{ entry.url|url_encode }}&title={{ entry.title|url_encode }}¬es=&v=1&noui=1&jump=doclose" target="_blank" class="tool diaspora icon-image icon-image--diaspora" title="diaspora}"> | |
136 | <span>diaspora*</span> | |
137 | </a> | |
138 | </li> | |
139 | {% endif %} | |
140 | {% if craue_setting('carrot') %} | |
141 | <li> | |
142 | <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"> | |
143 | <span>Carrot</span> | |
144 | </a> | |
145 | </li> | |
146 | {% endif %} | |
147 | {% if craue_setting('share_mail') %} | |
148 | <li> | |
149 | <a href="mailto:?subject={{ entry.title|url_encode }}&body={{ entry.url|url_encode }}%20via%20@wallabagapp" title="{{ 'entry.view.left_menu.share_email_label'|trans }}"> | |
150 | <i class="material-icons">email</i> | |
151 | <span>{{ 'entry.view.left_menu.share_email_label'|trans }}</span> | |
152 | </a> | |
153 | </li> | |
154 | {% endif %} | |
155 | </ul> | |
156 | </div> | |
157 | </li> | |
158 | ||
159 | {% if craue_setting('show_printlink') %} | |
160 | <li class="bold border-bottom hide-on-med-and-down"> | |
161 | <a class="waves-effect collapsible-header" title="{{ 'entry.view.left_menu.print'|trans }}" href="javascript: window.print();"> | |
162 | <i class="material-icons small">print</i> | |
163 | <span>{{ 'entry.view.left_menu.print'|trans }}</span> | |
164 | </a> | |
165 | <div class="collapsible-body"></div> | |
166 | </li> | |
167 | {% endif %} | |
168 | ||
169 | <li class="bold"> | |
170 | <a class="waves-effect collapsible-header"> | |
171 | <i class="material-icons small">file_download</i> | |
172 | <span>{{ 'entry.view.left_menu.download'|trans }}</span> | |
173 | </a> | |
174 | <div class="collapsible-body"> | |
175 | <ul> | |
176 | {% if craue_setting('export_epub') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'epub' }) }}" title="Generate ePub file">EPUB</a></li>{% endif %} | |
177 | {% if craue_setting('export_mobi') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'mobi' }) }}" title="Generate Mobi file">MOBI</a></li>{% endif %} | |
178 | {% if craue_setting('export_pdf') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'pdf' }) }}" title="Generate PDF file">PDF</a></li>{% endif %} | |
179 | {% if craue_setting('export_csv') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'csv' }) }}" title="Generate CSV file">CSV</a></li>{% endif %} | |
180 | {% if craue_setting('export_json') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'json' }) }}" title="Generate JSON file">JSON</a></li>{% endif %} | |
181 | {% if craue_setting('export_txt') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'txt' }) }}" title="Generate TXT file">TXT</a></li>{% endif %} | |
182 | {% if craue_setting('export_xml') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'xml' }) }}" title="Generate XML file">XML</a></li>{% endif %} | |
183 | </ul> | |
184 | </div> | |
185 | </li> | |
186 | ||
187 | <li class="bold hide-on-large-only"> | |
188 | <a class="waves-effect collapsible-header" title="{{ 'entry.view.left_menu.delete'|trans }}" href="{{ path('delete_entry', { 'id': entry.id }) }}"> | |
189 | <i class="material-icons small">delete</i> | |
190 | <span>{{ 'entry.view.left_menu.delete'|trans }}</span> | |
191 | </a> | |
192 | <div class="collapsible-body"></div> | |
193 | </li> | |
194 | ||
195 | <li class="bold"> | |
196 | <a class="waves-effect collapsible-header" href="mailto:hello@wallabag.org?subject=Wrong%20display%20in%20wallabag&body={{ entry.url|url_encode }}" title="{{ 'entry.view.left_menu.problem.description'|trans }}"> | |
197 | <i class="material-icons small">error</i> | |
198 | <span>{{ 'entry.view.left_menu.problem.label'|trans }}</span> | |
199 | </a> | |
200 | <div class="collapsible-body"></div> | |
201 | </li> | |
202 | ||
203 | </ul> | |
204 | ||
205 | {% endblock %} | |
206 | ||
207 | {% block content %} | |
208 | <div id="article"> | |
209 | <header class="mbm"> | |
210 | <h1>{{ entry.title|raw }} <a href="{{ path('edit', { 'id': entry.id }) }}" title="{{ 'entry.view.edit_title'|trans }}">✎</a></h1> | |
211 | </header> | |
212 | <aside> | |
213 | {% set readingTime = entry.readingTime / app.user.config.readingSpeed %} | |
214 | <span class="mdi-action-query-builder"></span> | |
215 | <span class="link"> | |
216 | {% if readingTime > 0 %} | |
217 | {{ 'entry.list.reading_time_minutes_short'|trans({'%readingTime%': readingTime|round}) }} | |
218 | {% else %} | |
219 | {{ 'entry.list.reading_time_less_one_minute_short'|trans|raw }} | |
220 | {% endif %} | |
221 | </span> | |
222 | <span class="mdi-action-today" title="{{ 'entry.view.created_at'|trans }}"> </span> <span class="link">{{ entry.createdAt|date('Y-m-d') }}</span> | |
223 | <a href="{{ entry.url|e }}" target="_blank" title="{{ 'entry.view.original_article'|trans }} : {{ entry.title|e }}" class="tool"> | |
224 | <i class="material-icons link">link</i> <span class="link">{{ entry.domainName|removeWww }}</span></a> | |
225 | <span class="tool"><i class="material-icons link">comment</i> <span class="link">{{ 'entry.view.annotations_on_the_entry'|transchoice(entry.annotations | length) }}</span> | |
226 | <div id="list"> | |
227 | {% for tag in entry.tags %} | |
228 | <div class="chip"> | |
229 | {{ tag.label }} <a href="{{ path('remove_tag', { 'entry': entry.id, 'tag': tag.id }) }}"><i class="material-icons">delete</i></a> | |
230 | </div> | |
231 | {% endfor %} | |
232 | </div> | |
233 | ||
234 | <div class="input-field nav-panel-add-tag" style="display: none"> | |
235 | {{ render(controller( "WallabagCoreBundle:Tag:addTagForm", { 'id': entry.id } )) }} | |
236 | </div> | |
237 | ||
238 | {% if entry.previewPicture is not null %} | |
239 | <div><img class="preview" src="{{ entry.previewPicture }}" alt="{{ entry.title|raw }}" /></div> | |
240 | {% endif %} | |
241 | ||
242 | </aside> | |
243 | <article> | |
244 | {{ entry.content | raw }} | |
245 | </article> | |
246 | </div> | |
247 | ||
248 | <script id="annotationroutes" type="application/json"> | |
249 | { | |
250 | "prefix": "", | |
251 | "urls": { | |
252 | "create": "{{ path('annotations_post_annotation', { 'entry': entry.id }) }}", | |
253 | "update": "{{ path('annotations_put_annotation', { 'annotation': 'idAnnotation' }) }}", | |
254 | "destroy": "{{ path('annotations_delete_annotation', { 'annotation': 'idAnnotation' }) }}", | |
255 | "search": "{{ path('annotations_get_annotations', { 'entry': entry.id }) }}" | |
256 | }, | |
257 | "entryId": "{{ entry.id }}" | |
258 | }</script> | |
259 | ||
260 | {% endblock %} | |
261 | ||
262 | {% block footer %} | |
263 | {% endblock %} |