Merge remote-tracking branch 'refs/remotes/tryggvib/532-exif-creation-date'
[mediagoblin.git] / mediagoblin / templates / mediagoblin / user_pages / media.html
1 {#
2 # GNU MediaGoblin -- federated, autonomous media hosting
3 # Copyright (C) 2011, 2012 MediaGoblin contributors. See AUTHORS.
4 #
5 # This program is free software: you can redistribute it and/or modify
6 # it under the terms of the GNU Affero General Public License as published by
7 # the Free Software Foundation, either version 3 of the License, or
8 # (at your option) any later version.
9 #
10 # This program is distributed in the hope that it will be useful,
11 # but WITHOUT ANY WARRANTY; without even the implied warranty of
12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 # GNU Affero General Public License for more details.
14 #
15 # You should have received a copy of the GNU Affero General Public License
16 # along with this program. If not, see <http://www.gnu.org/licenses/>.
17 #}
18 {%- extends "mediagoblin/base.html" %}
19
20 {% import "/mediagoblin/utils/wtforms.html" as wtforms_util %}
21 {% from "mediagoblin/utils/pagination.html" import render_pagination %}
22
23 {% block title %}{{ media.title }} &mdash; {{ super() }}{% endblock %}
24
25 {% block mediagoblin_head %}
26 <!--[if lte IE 8]><link rel="stylesheet"
27 href="{{ request.staticdirect('/extlib/leaflet/leaflet.ie.css') }}" /><![endif]-->
28 <script type="text/javascript"
29 src="{{ request.staticdirect('/js/comment_show.js') }}"></script>
30 <script type="text/javascript"
31 src="{{ request.staticdirect('/js/keyboard_navigation.js') }}"></script>
32
33 {% template_hook("media_head") %}
34 {% endblock mediagoblin_head %}
35
36 {% block mediagoblin_content %}
37 <p class="context">
38 {%- trans user_url=request.urlgen(
39 'mediagoblin.user_pages.user_home',
40 user=media.get_uploader.username),
41 username=media.get_uploader.username -%}
42 ❖ Browsing media by <a href="{{user_url}}">{{username}}</a>
43 {%- endtrans -%}
44 </p>
45 {% include "mediagoblin/utils/prev_next.html" %}
46 <div class="media_pane">
47 <div class="media_image_container">
48 {% block mediagoblin_media %}
49 {% set display_media = request.app.public_store.file_url(
50 media.get_display_media()[1]) %}
51 {# if there's a medium file size, that means the medium size
52 # isn't the original... so link to the original!
53 #}
54 {% if media.media_files.has_key('medium') %}
55 <a href="{{ request.app.public_store.file_url(
56 media.media_files['original']) }}">
57 <img class="media_image"
58 src="{{ display_media }}"
59 alt="{% trans media_title=media.title -%}
60 Image for {{ media_title }}{% endtrans %}" />
61 </a>
62 {% else %}
63 <img class="media_image"
64 src="{{ display_media }}"
65 alt="{% trans media_title=media.title -%}
66 Image for {{ media_title }}{% endtrans %}" />
67 {% endif %}
68 {% endblock %}
69 </div>
70 <h2 class="media_title">
71 {{ media.title }}
72 </h2>
73 {% if request.user and
74 (media.uploader == request.user.id or
75 request.user.is_admin) %}
76 {% set edit_url = request.urlgen('mediagoblin.edit.edit_media',
77 user= media.get_uploader.username,
78 media_id=media.id) %}
79 <a class="button_action" href="{{ edit_url }}">{% trans %}Edit{% endtrans %}</a>
80 {% set delete_url = request.urlgen('mediagoblin.user_pages.media_confirm_delete',
81 user= media.get_uploader.username,
82 media_id=media.id) %}
83 <a class="button_action" href="{{ delete_url }}">{% trans %}Delete{% endtrans %}</a>
84 {% endif %}
85 {% autoescape False %}
86 <p>{{ media.description_html }}</p>
87 {% endautoescape %}
88 {% if comments %}
89 <a
90 {% if not request.user %}
91 href="{{ request.urlgen('mediagoblin.auth.login') }}"
92 {% endif %}
93 {% if app_config['allow_comments'] %}
94 class="button_action" id="button_addcomment" title="Add a comment">
95 {% trans %}Add a comment{% endtrans %}
96 {% endif %}
97 </a>
98 {% if request.user %}
99 <form action="{{ request.urlgen('mediagoblin.user_pages.media_post_comment',
100 user= media.get_uploader.username,
101 media_id=media.id) }}" method="POST" id="form_comment">
102 {{ wtforms_util.render_divs(comment_form) }}
103 <div class="form_submit_buttons">
104 <input type="submit" value="{% trans %}Add this comment{% endtrans %}" class="button_action" />
105 {{ csrf_token }}
106 </div>
107 </form>
108 {% endif %}
109 <ul style="list-style:none">
110 {% for comment in comments %}
111 {% set comment_author = comment.get_author %}
112 <li id="comment-{{ comment.id }}"
113 {%- if pagination.active_id == comment.id %}
114 class="comment_wrapper comment_active">
115 <a name="comment" id="comment"></a>
116 {%- else %}
117 class="comment_wrapper">
118 {%- endif %}
119 <div class="comment_author">
120 <img src="{{ request.staticdirect('/images/icon_comment.png') }}" />
121 <a href="{{ request.urlgen('mediagoblin.user_pages.user_home',
122 user=comment_author.username) }}"
123 class="comment_authorlink">
124 {{- comment_author.username -}}
125 </a>
126 <a href="{{ request.urlgen('mediagoblin.user_pages.media_home.view_comment',
127 comment=comment.id,
128 user=media.get_uploader.username,
129 media=media.slug_or_id) }}#comment"
130 class="comment_whenlink">
131 <span title='{{- comment.created.strftime("%I:%M%p %Y-%m-%d") -}}'>
132 {%- trans formatted_time=timesince(comment.created) -%}
133 {{ formatted_time }} ago
134 {%- endtrans -%}
135 </span></a>:
136 </div>
137 <div class="comment_content">
138 {% autoescape False -%}
139 {{ comment.content_html }}
140 {%- endautoescape %}
141 </div>
142 </li>
143 {% endfor %}
144 </ul>
145 {{ render_pagination(request, pagination,
146 media.url_for_self(request.urlgen)) }}
147 {% endif %}
148 </div>
149 <div class="media_sidebar">
150 <h3>Added</h3>
151 <p><span title="{{ media.created.strftime("%I:%M%p %Y-%m-%d") }}">
152 {%- trans formatted_time=timesince(media.created) -%}
153 {{ formatted_time }} ago
154 {%- endtrans -%}
155 </span></p>
156
157 {% if app_config['original_date_visible'] %}
158 {% set original_date = media.media_data.get_original_date() %}
159 {% if original_date -%}
160 {% trans date=original_date.strftime("%Y-%m-%d") -%}
161 <h3>Created on</h3>
162 <p>{{ date }}</p>
163 {%- endtrans %}
164 {%- endif %}
165 {% endif %}
166
167 {% if media.tags %}
168 {% include "mediagoblin/utils/tags.html" %}
169 {% endif %}
170
171 {% include "mediagoblin/utils/collections.html" %}
172
173 {% include "mediagoblin/utils/license.html" %}
174
175 {% include "mediagoblin/utils/exif.html" %}
176
177 {%- if media.attachment_files|count %}
178 <h3>{% trans %}Attachments{% endtrans %}</h3>
179 <ul>
180 {%- for attachment in media.attachment_files %}
181 <li>
182 <a href="{{ request.app.public_store.file_url(attachment.filepath) }}">
183 {{- attachment.name -}}
184 </a>
185 </li>
186 {%- endfor %}
187 </ul>
188 {%- endif %}
189 {%- if app_config['allow_attachments']
190 and request.user
191 and (media.uploader == request.user.id
192 or request.user.is_admin) %}
193 {%- if not media.attachment_files|count %}
194 <h3>{% trans %}Attachments{% endtrans %}</h3>
195 {%- endif %}
196 <p>
197 <a href="{{ request.urlgen('mediagoblin.edit.attachments',
198 user=media.get_uploader.username,
199 media_id=media.id) }}">
200 {%- trans %}Add attachment{% endtrans -%}
201 </a>
202 </p>
203 {%- endif %}
204
205 {% template_hook("media_sideinfo") %}
206
207 {% block mediagoblin_sidebar %}
208 {% endblock %}
209
210 </div>
211 <div class="clear"></div>
212 {% endblock %}