]> git.immae.eu Git - github/wallabag/wallabag.git/blame - src/Wallabag/CoreBundle/Resources/views/themes/material/Entry/entry.html.twig
Fixed possible JS injection via the title edition
[github/wallabag/wallabag.git] / src / Wallabag / CoreBundle / Resources / views / themes / material / Entry / entry.html.twig
CommitLineData
53e12188
AD
1{% extends "WallabagCoreBundle::layout.html.twig" %}
2
3d995079 3{% block title %}{{ entry.title|e|raw }} ({{ entry.domainName|removeWww }}){% endblock %}
53e12188 4
0d42217e
JB
5{% block body_class %}entry{% endblock %}
6
53e12188 7{% block menu %}
fcb3faf1
AD
8 <div class="progress">
9 <div class="determinate"></div>
10 </div>
b17874a7
AD
11 <nav class="hide-on-large-only">
12 <div class="nav-wrapper cyan darken-1">
13 <ul>
14 <li>
fad31615 15 <a class="waves-effect" href="{{ path('homepage') }}">
5ecdfcd0 16 <i class="material-icons">exit_to_app</i>
b17874a7
AD
17 </a>
18 </li>
19 </ul>
20 <ul class="right">
21 <li>
0d42217e 22 <a class="waves-effect" title="{{ 'entry.view.left_menu.set_as_read'|trans }}" href="{{ path('archive_entry', { 'id': entry.id }) }}" id="markAsRead">
91826e3c 23 <i class="material-icons small">{% if entry.isArchived == 0 %}done{% else %}redo{% endif %}</i>
b17874a7
AD
24 </a>
25 </li>
26 <li>
519ba0b5 27 <a class="waves-effect" title="{{ 'entry.view.left_menu.set_as_starred'|trans }}" href="{{ path('star_entry', { 'id': entry.id }) }}" id="setFav">
79efca1e 28 <i class="material-icons small">{% if entry.isStarred == 0 %}star_outline{% else %}star{% endif %}</i>
b17874a7
AD
29 </a>
30 </li>
31 <li>
32 <a href="#" data-activates="slide-out" class="button-collapse right">
91826e3c 33 <i class="material-icons">menu</i>
b17874a7
AD
34 </a>
35 </li>
36 </ul>
37 </div>
38 </nav>
9948d899 39 <ul id="slide-out" class="collapsible side-nav fixed reader-mode" data-collapsible="accordion">
b17874a7 40 <li class="bold border-bottom hide-on-med-and-down">
fad31615 41 <a class="waves-effect collapsible-header" href="{{ path('homepage') }}">
5ecdfcd0 42 <i class="material-icons small">exit_to_app</i>
0d42217e 43 <span>{{ 'entry.view.left_menu.back_to_homepage'|trans }}</span>
53e12188
AD
44 </a>
45 <div class="collapsible-body"></div>
46 </li>
47
9cc6bd87
NL
48 <li class="bold border-bottom hide-on-med-and-down">
49 <a class="waves-effect collapsible-header" href="{{ entry.url|e }}">
46d78f87 50 <i class="material-icons small">link</i>
0d42217e 51 <span>{{ 'entry.view.left_menu.view_original_article'|trans }}</span>
9cc6bd87
NL
52 </a>
53 <div class="collapsible-body"></div>
54 </li>
55
831b02aa 56 <li class="bold hide-on-med-and-down">
0d42217e 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">
5ecdfcd0 58 <i class="material-icons small">autorenew</i>
0d42217e 59 <span>{{ 'entry.view.left_menu.re_fetch_content'|trans }}</span>
831b02aa
JB
60 </a>
61 <div class="collapsible-body"></div>
62 </li>
63
458beef0
NL
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
b17874a7 69 <li class="bold hide-on-med-and-down">
458beef0 70 <a class="waves-effect collapsible-header" title="{{ markAsReadLabel|trans }}" href="{{ path('archive_entry', { 'id': entry.id }) }}" id="markAsRead">
5ecdfcd0 71 <i class="material-icons small">{% if entry.isArchived == 0 %}done{% else %}redo{% endif %}</i>
458beef0 72 <span>{{ markAsReadLabel|trans }}</span>
53e12188
AD
73 </a>
74 <div class="collapsible-body"></div>
75 </li>
76
b17874a7 77 <li class="bold hide-on-med-and-down">
519ba0b5 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">
79efca1e 79 <i class="material-icons spall">{% if entry.isStarred == 0 %}star_outline{% else %}star{% endif %}</i>
519ba0b5 80 <span>{{ 'entry.view.left_menu.set_as_starred'|trans }}</span>
53e12188
AD
81 </a>
82 <div class="collapsible-body"></div>
83 </li>
b17874a7 84 <li class="bold border-bottom hide-on-med-and-down">
0d42217e 85 <a class="waves-effect collapsible-header" title="{{ 'entry.view.left_menu.delete'|trans }}" href="{{ path('delete_entry', { 'id': entry.id }) }}">
5ecdfcd0 86 <i class="material-icons small">delete</i>
0d42217e 87 <span>{{ 'entry.view.left_menu.delete'|trans }}</span>
53e12188
AD
88 </a>
89 <div class="collapsible-body"></div>
90 </li>
91
a754db33
NL
92 <li class="bold border-bottom hide-on-med-and-down">
93 <a class="waves-effect collapsible-header" id="nav-btn-add-tag">
5ecdfcd0 94 <i class="material-icons small">label_outline</i>
0d42217e 95 <span>{{ 'entry.view.left_menu.add_a_tag'|trans }}</span>
a754db33
NL
96 </a>
97 <div class="collapsible-body"></div>
98 </li>
99
53e12188
AD
100 <li class="bold">
101 <a class="waves-effect collapsible-header">
5ecdfcd0 102 <i class="material-icons small">share</i>
0d42217e 103 <span>{{ 'entry.view.left_menu.share_content'|trans }}</span>
53e12188
AD
104 </a>
105 <div class="collapsible-body">
106 <ul>
d0545b6b 107 {% if craue_setting('share_public') %}
f3d0cb91 108 <li>
0c7f1ba7 109 <a href="{{ path('share', {'id': entry.id }) }}" target="_blank" title="{{ 'entry.view.left_menu.public_link'|trans }}" class="tool icon-eye">
3377c938 110 <span>{{ 'entry.view.left_menu.public_link'|trans }}</span>
f3d0cb91
NL
111 </a>
112 </li>
f1be7af4 113 <li>
0c7f1ba7 114 <a href="{{ path('delete_share', {'id': entry.id }) }}" title="{{ 'entry.view.left_menu.delete_public_link'|trans }}" class="tool icon-no-eye">
f1be7af4
NL
115 <span>{{ 'entry.view.left_menu.delete_public_link'|trans }}</span>
116 </a>
117 </li>
f3d0cb91 118 {% endif %}
daa2b7e7
JB
119 {% if craue_setting('share_twitter') %}
120 <li>
0c7f1ba7 121 <a href="https://twitter.com/home?status={{entry.title|url_encode}}%20{{ entry.url|url_encode }}%20via%20@wallabagapp" target="_blank" class="tool icon-twitter" title="twitter">
daa2b7e7
JB
122 <span>twitter</span>
123 </a>
124 </li>
125 {% endif %}
126 {% if craue_setting('share_shaarli') %}
127 <li>
f733d8aa
TC
128 <a href="{{ craue_setting('shaarli_url') }}/index.php?post={{ entry.url|url_encode }}&amp;title={{ entry.title|url_encode }}" target="_blank">
129 <i class="tool icon-image icon-image--shaarli" title="shaarli"></i>
46d78f87 130 <span>shaarli</span>
daa2b7e7
JB
131 </a>
132 </li>
133 {% endif %}
134 {% if craue_setting('share_diaspora') %}
135 <li>
f733d8aa
TC
136 <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">
137 <i class="tool icon-image icon-image--diaspora" title="diaspora"></i>
46d78f87 138 <span>diaspora*</span>
daa2b7e7
JB
139 </a>
140 </li>
141 {% endif %}
142 {% if craue_setting('carrot') %}
143 <li>
f733d8aa
TC
144 <a href="https://secure.carrot.org/GiveAndGetBack.do?url={{ entry.url|url_encode }}&title={{ entry.title|url_encode }}" target="_blank" title="carrot">
145 <i class="tool icon-image icon-image--carrot"></i>
46d78f87 146 <span>Carrot</span>
daa2b7e7
JB
147 </a>
148 </li>
149 {% endif %}
150 {% if craue_setting('share_mail') %}
151 <li>
0c7f1ba7 152 <a href="mailto:?subject={{ entry.title|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">
0d42217e 153 <span>{{ 'entry.view.left_menu.share_email_label'|trans }}</span>
daa2b7e7
JB
154 </a>
155 </li>
156 {% endif %}
53e12188
AD
157 </ul>
158 </div>
159 </li>
160
cb48a569
NL
161 {% if craue_setting('show_printlink') %}
162 <li class="bold border-bottom hide-on-med-and-down">
163 <a class="waves-effect collapsible-header" title="{{ 'entry.view.left_menu.print'|trans }}" href="javascript: window.print();">
5ecdfcd0 164 <i class="material-icons small">print</i>
cb48a569
NL
165 <span>{{ 'entry.view.left_menu.print'|trans }}</span>
166 </a>
167 <div class="collapsible-body"></div>
168 </li>
169 {% endif %}
170
53e12188
AD
171 <li class="bold">
172 <a class="waves-effect collapsible-header">
5ecdfcd0 173 <i class="material-icons small">file_download</i>
0d42217e 174 <span>{{ 'entry.view.left_menu.download'|trans }}</span>
53e12188
AD
175 </a>
176 <div class="collapsible-body">
177 <ul>
63e40f2d
JB
178 {% if craue_setting('export_epub') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'epub' }) }}" title="Generate ePub file">EPUB</a></li>{% endif %}
179 {% if craue_setting('export_mobi') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'mobi' }) }}" title="Generate Mobi file">MOBI</a></li>{% endif %}
180 {% if craue_setting('export_pdf') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'pdf' }) }}" title="Generate PDF file">PDF</a></li>{% endif %}
181 {% if craue_setting('export_csv') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'csv' }) }}" title="Generate CSV file">CSV</a></li>{% endif %}
182 {% if craue_setting('export_json') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'json' }) }}" title="Generate JSON file">JSON</a></li>{% endif %}
6c08fb68 183 {% if craue_setting('export_txt') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'txt' }) }}" title="Generate TXT file">TXT</a></li>{% endif %}
63e40f2d 184 {% if craue_setting('export_xml') %}<li><a href="{{ path('export_entry', { 'id': entry.id, 'format': 'xml' }) }}" title="Generate XML file">XML</a></li>{% endif %}
53e12188
AD
185 </ul>
186 </div>
187 </li>
188
b17874a7 189 <li class="bold hide-on-large-only">
0d42217e 190 <a class="waves-effect collapsible-header" title="{{ 'entry.view.left_menu.delete'|trans }}" href="{{ path('delete_entry', { 'id': entry.id }) }}">
5ecdfcd0 191 <i class="material-icons small">delete</i>
0d42217e 192 <span>{{ 'entry.view.left_menu.delete'|trans }}</span>
b17874a7
AD
193 </a>
194 <div class="collapsible-body"></div>
195 </li>
196
53e12188 197 <li class="bold">
0d42217e 198 <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 }}">
5ecdfcd0 199 <i class="material-icons small">error</i>
0d42217e 200 <span>{{ 'entry.view.left_menu.problem.label'|trans }}</span>
53e12188
AD
201 </a>
202 <div class="collapsible-body"></div>
203 </li>
204
205 </ul>
206
53e12188
AD
207{% endblock %}
208
209{% block content %}
210 <div id="article">
211 <header class="mbm">
3d995079 212 <h1>{{ entry.title|e|raw }} <a href="{{ path('edit', { 'id': entry.id }) }}" title="{{ 'entry.view.edit_title'|trans }}">✎</a></h1>
53e12188 213 </header>
a754db33 214 <aside>
34aa06a9
TC
215 <ul class="tools">
216 <li>
217 {% set readingTime = entry.readingTime / app.user.config.readingSpeed %}
218 <i class="material-icons">timer</i>
219 {% if readingTime > 0 %}
220 {{ 'entry.list.reading_time_minutes_short'|trans({'%readingTime%': readingTime|round}) }}
221 {% else %}
222 {{ 'entry.list.reading_time_less_one_minute_short'|trans|raw }}
223 {% endif %}
224 </li>
225 <li>
226 <i class="material-icons" title="{{ 'entry.view.created_at'|trans }}">today</i>
227 {{ entry.createdAt|date('Y-m-d') }}
228 </li>
229 <li>
230 <i class="material-icons link">link</i>
231 <a href="{{ entry.url|e }}" target="_blank" title="{{ 'entry.view.original_article'|trans }} : {{ entry.title|e }}" class="tool">
232 {{ entry.domainName|removeWww }}
233 </a>
234 </li>
235 <li>
236 <i class="material-icons link">comment</i>
237 {{ 'entry.view.annotations_on_the_entry'|transchoice(entry.annotations | length) }}
238 </li>
239 <li id="list">
240 {% for tag in entry.tags %}
241 <div class="chip">
242 <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>
243 </div>
244 {% endfor %}
245 </li>
246 </ul>
a754db33
NL
247
248 <div class="input-field nav-panel-add-tag" style="display: none">
249 {{ render(controller( "WallabagCoreBundle:Tag:addTagForm", { 'id': entry.id } )) }}
250 </div>
251
c6cbe75b
NL
252 {% if entry.previewPicture is not null %}
253 <div><img class="preview" src="{{ entry.previewPicture }}" alt="{{ entry.title|raw }}" /></div>
254 {% endif %}
255
53e12188
AD
256 </aside>
257 <article>
258 {{ entry.content | raw }}
259 </article>
260 </div>
2b6e65a5 261
5ecdfcd0
TC
262<script id="annotationroutes" type="application/json">
263{
264 "prefix": "",
265 "urls": {
266 "create": "{{ path('annotations_post_annotation', { 'entry': entry.id }) }}",
267 "update": "{{ path('annotations_put_annotation', { 'annotation': 'idAnnotation' }) }}",
268 "destroy": "{{ path('annotations_delete_annotation', { 'annotation': 'idAnnotation' }) }}",
269 "search": "{{ path('annotations_get_annotations', { 'entry': entry.id }) }}"
270 },
271 "entryId": "{{ entry.id }}"
272}</script>
2b6e65a5 273
53e12188
AD
274{% endblock %}
275
276{% block footer %}
c2257428 277{% endblock %}