macros.html 17.2 KB
Newer Older
1
2
3
4
5
6
{% macro livelabel(live=None, nowlive=None) %}
{% if live or nowlive %}
<span class="label {% if nowlive %}label-danger{% else %}label-default{% endif %}">Live</span>
{% endif %}
{% endmacro %}

7
{% macro preview(lecture) %}
Andreas Valder's avatar
Andreas Valder committed
8
<li class="list-group-item">
9
	<a href="{{url_for('lecture', course=lecture.course.handle, id=lecture['id'])}}" title="{{ lecture.course.title }}" style="color: #000">
10
11
		<div class="hidden-xs">
			<div class="row">
12
				<img class="col-xs-4" style="max-height: 120px; height: auto; width:170px" src="{{ config.VIDEOPREFIX }}/thumbnail/l_{{ lecture['id'] }}.jpg" alt="Vorschaubild">
13
				<div class="col-xs-4">
14
					<span><strong>{{ lecture.course.short }}</strong> {{livelabel(0, lecture.livehandle)}}{% if ismod() %} <i>({{lecture.course_id}})</i>{% endif %}</span><br>
15
					<span>{% if ismod() %}ID: {{lecture.id}}{% endif %}</span><br>
16
					<span>{{ lecture['time']|fulldate }}</span>
17
18
19
20
21
					{% if lecture['speaker'] %}
						<div class="small">Gehalten von {{ lecture['speaker']|safe }} </div>
					{% endif %}
				</div>
				<div class="col-xs-4">
22
					<div>{{ lecture['title']|fixnl|safe }}</div>
23
24
25
26
27
28
				</div>
			</div>
		</div>
		<div class="visible-xs">
			<ul class="list-unstyled">
				<li>
29
					<img style="width: 100%;" src="{{ config.VIDEOPREFIX }}/thumbnail/l_{{ lecture['id'] }}.jpg" alt="Vorschaubild">
30
31
				</li>
				<li>
32
					<strong>{{ lecture.course.title }}</strong>
33
					{{livelabel(0, lecture.livehandle)}}
34
				</li>
35
				<li>{{ lecture['time']|fulldate }}</li>
36
				{% if lecture['speaker'] %}
37
38
39
				<li>
					<span class="small">Gehalten von {{ lecture['speaker']|safe }} </span>
				</li>
40
				{% endif %}
41
				<li>
42
					{{ lecture['title']|fixnl|safe }}
43
44
				</li>
			</ul>
Andreas Valder's avatar
Andreas Valder committed
45
46
		</div>
	</a>
Andreas Valder's avatar
Andreas Valder committed
47
48
</li>

Andreas Valder's avatar
Andreas Valder committed
49
50
{% endmacro %}

51
52
53
54
55
56
{% macro player(lecture, videos, msgs=[], autoplay=True, seek=None) %}
{% if seek == None %}
	{% set mfrag = "" %}
{% else %}
	{% set mfrag = "#t="+seek %}
{% endif %}
57
<video id="videoplayer" style="width: 100%" class="video-js vjs-default-skin vjs-big-play-centered" width="640" height="320" controls data-wasnotplayed="1" data-setup='{ "language":"de", "plugins" : {"hotkeys": {"seekStep": 15, "enableVolumeScroll": false, "alwaysCaptureHotkeys": true}, "videoJsResolutionSwitcher": { "ui": true, "default": "720p", "dynamicLabel": false } }, "customControlsOnMobile": true, "playbackRates": [0.5, 0.75, 1, 1.25, 1.5, 1.75, 2, 2.25, 2.5, 2.75, 3, 3.25, 3.5, 3.75, 4] }'>
58
	{% for v in videos|sort(attribute='formats.player_prio', reverse=True) %}
59
	<source type="{{ v.formats.mimetype }}" src="{{ config.VIDEOPREFIX }}/{{ v.path }}{{mfrag}}" data-label="{{ v.formats.description }}" data-res="{{v.formats.resolution}}" data-aspect="{{v.formats.aspect}}" data-player_prio="{{v.formats.player_prio}}"/>
Andreas Valder's avatar
Andreas Valder committed
60
	{% endfor %}
61
	<track srclang="de" kind="chapters" src="{{ url_for('chapters',lectureid=lecture.id) }}" />
Andreas Valder's avatar
Andreas Valder committed
62
</video>
Andreas Valder's avatar
Andreas Valder committed
63
<script>
Jan Philipp Hafer's avatar
Jan Philipp Hafer committed
64
$(function() {
Andreas Valder's avatar
Andreas Valder committed
65
66
67
68
69
70
	$('#videoplayer').addClass("vjs-fluid");
	$('#videoplayer').css("width");
	videojs("videoplayer").ready(function() {
		//resume
		var progress_key = "progress_{{ lecture.id }}";
		var seconds_played;
Andreas Valder's avatar
Andreas Valder committed
71
		if (localStorage) {
Andreas Valder's avatar
Andreas Valder committed
72
73
74
75
			seconds_played = localStorage.getItem(progress_key);
			if (!seconds_played) {
				seconds_played = 0;
			} else {
76
			{% if seek == None %}
Andreas Valder's avatar
Andreas Valder committed
77
				videojs('videoplayer').currentTime(seconds_played);
78
			{% endif %}
Andreas Valder's avatar
Andreas Valder committed
79
80
			}
		}
Andreas Valder's avatar
Andreas Valder committed
81
82
83
84
85
86
87
88
		videojs("videoplayer").on("timeupdate", function() {
			if (localStorage) {
				var player_cur_Time = Math.round(videojs("videoplayer").currentTime());
				if(Math.abs(player_cur_Time - seconds_played) >= 10) {
					seconds_played = player_cur_Time;
					localStorage.setItem( progress_key , seconds_played)
				}
			}
Andreas Valder's avatar
Andreas Valder committed
89

Andreas Valder's avatar
Andreas Valder committed
90
		});
Andreas Valder's avatar
Andreas Valder committed
91

Andreas Valder's avatar
Andreas Valder committed
92
93
94
95
96
97
98
		//autoplay
		var playerplay = function() {
			if ($('#videoplayer').data("wasnotplayed") == 1) {
				videojs('videoplayer').play();
				$('#videoplayer').data("wasnotplayed","0");
			}
		};
Julian Rother's avatar
Julian Rother committed
99
		{% if autoplay %}
Andreas Valder's avatar
Andreas Valder committed
100
101
102
		$(window).focus(playerplay);
		if (document.hasFocus()) {
			playerplay();
Jan Philipp Hafer's avatar
Jan Philipp Hafer committed
103
		}
Julian Rother's avatar
Julian Rother committed
104
		{% endif %}
Andreas Valder's avatar
Andreas Valder committed
105
106
107
108
109
110
111
112
113
114
115
116
		// errors as modal dialog
		videojs("videoplayer").on("error", function() {
			var modals = [];
			//display errors
			{% for msg in msgs %}
				var m = videojs("videoplayer").createModal('',{"uncloseable": true });
				modals.push(m);
				m.contentEl().innerHTML='<div class="hidden-print alert alert-danger" role="alert">{{ msg|safe }}</div>';
				
			{% endfor %}
			videojs("videoplayer").on('play', function() {
				for (var i=0; i < modals.length; i++) {
Andreas Valder's avatar
Andreas Valder committed
117
					//modals[i].close();
Andreas Valder's avatar
Andreas Valder committed
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
				}
			});
		});
		//markers
		$.ajax({method: "GET", url: "{{url_for('chapters',lectureid=lecture.id, json=1)}}", dataType: "json",
			success: function (data) {
				videojs("videoplayer").markers({
					markerStyle: {
						'width':'5px',
						'border-radius': '40%',
						'background-color': 'black'
					},
					markerTip:{
						display: true,
						text: function(marker) {
							return marker.text;
						}
					},
					markers: data});
			}});
Andreas Valder's avatar
Andreas Valder committed
138
139

	});
Jan Philipp Hafer's avatar
Jan Philipp Hafer committed
140
});
Andreas Valder's avatar
Andreas Valder committed
141
</script>
Andreas Valder's avatar
Andreas Valder committed
142
{% endmacro %}
143
144

{% macro course_list_item(course,show_semester=False) %}
145
<li class="list-group-item list-group-item-condensed {% if (not course.visible) or (not course.listed) %}list-group-item-danger{% endif %}">
146
	<div class="row">
Andreas Valder's avatar
Andreas Valder committed
147
			{% if show_semester %}
148
				<span class="col-xs-2 col-md-1">
149
					{{ course.semester|semester }}
Andreas Valder's avatar
Andreas Valder committed
150
				</span>
151
				<span class="col-xs-10 col-md-6">
Andreas Valder's avatar
Andreas Valder committed
152
			{% else %}
153
				<span class="col-xs-12 col-md-7">
Andreas Valder's avatar
Andreas Valder committed
154
			{% endif %}
155
				<a href="{{url_for('course', handle=course.handle)}}">
156
					{{ course.title }}{% if ismod() %}<i> ({{course.id}})</i>{% endif %}
157
				</a>
158
			</span>
159
			<span class="col-xs-8 col-md-3">
Andreas Valder's avatar
Andreas Valder committed
160
161
				{{ course.organizer }}
			</span>
162
			<span class="col-xs-4 col-md-2">
Andreas Valder's avatar
Andreas Valder committed
163
164
				{{ course.subject }}
			</span>
165
166
167
	</div>
</li>
{% endmacro %}
Andreas Valder's avatar
Andreas Valder committed
168

169
{% macro video_download_btn(videos) %}
170
{% if not ismod() %}
171
<span class="btn btn-default dropdown-toggle{% if not videos|selectattr('downloadable')|list and not ismod() %} disabled{% endif %}" type="button" data-toggle="dropdown">Download <span class="caret"></span></span>
172
<ul class="dropdown-menu">
173
174
	{% for v in videos|sort(attribute='formats.prio', reverse=True) if (v.downloadable or ismod() ) %}
	<li><a href="{{ config.VIDEOPREFIX }}/{{v.path}}">{{v.formats.description}} ({{v.file_size|filesizeformat(true)}})</a></li>
175
176
	{% endfor %}
</ul>
177
178
{% endif %}
{% if not ismod() %}
179
	<noscript> 
180
{% endif %}
181
<ul class="pull-right list-unstyled" style="margin-left:10px;">
182
183
{% for v in videos|sort(attribute='formats.prio', reverse=True) if (v.downloadable or ismod() ) %}
	<li>{{moderator_delete(['videos',v.id,'deleted'])}} {{ moderator_checkbox(['videos',v.id,'visible'], v.visible) }} <a href="{{ config.VIDEOPREFIX }}/{{v.path}}">{{v.formats.description}} ({{v.file_size|filesizeformat(true)}})</a></li>
184
185
{% endfor %}
</ul>
186
{% if not ismod() %}
187
	</noscript> 
188
{% endif %}
189
190
{% endmacro %}

191
{%macro video_embed_btn(lectureid, course=None) %}
Andreas Valder's avatar
Andreas Valder committed
192
193
194
195
<a class="btn btn-default" id="embedcodebtn" data-container="body" data-toggle="popover" data-placement="bottom">
	<span>Einbetten</span>
</a>
<script>
196
{% set embedcode = '<iframe width="700" height="394" src="'+url_for('embed', course=course, id=lectureid, _external=True)+'" frameborder="0" allowfullscreen="true"></iframe>' %}
Andreas Valder's avatar
Andreas Valder committed
197
198
199
200
201
202
203
204
205
206
$('#embedcodebtn').popover(
		{
			html:true,
			title:'Einbettcode',
			content:'<span><input type="text" onclick="this.select()" value="{{embedcode}}"></span>'
		}
		)
</script>
{% endmacro %}

207
{% macro lecture_list_item(lecture,videos,global_permissions,chapters=[]) %}
208
<li class="list-group-item{% if lecture.norecording %} text-muted{% endif %}" id="lecture-{{lecture.id}}">
Andreas Valder's avatar
Andreas Valder committed
209
	<div class="row">
210
		{% if ismod() or (videos|length > 0) %}
211
212
213
214
215
			<div style="background-image: url('{{ config.VIDEOPREFIX }}/thumbnail/l_{{lecture.id}}.jpg')" class="col-sm-2 col-xs-12 thumbnailimg">
			{% if not videos|length is equalto 0 %}
				<a href="{{url_for('lecture', course=lecture.course.handle, id=lecture.id)}}">
					<span class="glyphicon glyphicon-play-circle playpreviewbtn"></span>
				</a>
216
			{% endif %}
217
218
219
220
			</div>
			<ul class="list-unstyled col-sm-3 col-xs-12">
				<li>{{ moderator_editor(['lectures',lecture.id,'title'], lecture.title) }}{{livelabel((lecture.live and lecture.time > datetime.now()-timedelta(days=1)), videos|selectattr("livehandle")|list|length)}}</li>
				{% if lecture.speaker or ismod() %}<li>Gehalten von {{ moderator_editor(['lectures',lecture.id,'speaker'], lecture.speaker) }}</li>{% endif %}
221
				{% if ismod() %}
222
				<li>{{ moderator_editor(['lectures',lecture.id,'time'], lecture.time) }} </li>
223
				<li>Dauer: {{ moderator_editor(['lectures',lecture.id,'duration'], lecture.duration) }} min</li>
224
				<li>ID: <a href="{{url_for('course',handle=lecture.course.handle)}}#lecture-{{lecture.id}}">{{lecture.id}}</a></li>
225
226
				{% else %}
				<li>{{ lecture.time|fulldate }}</li>
227
228
229
230
				{% endif %}
			</ul>
			<ul class="list-unstyled col-sm-3 col-xs-12">
				<li>{{ moderator_editor(['lectures',lecture.id,'comment'], lecture.comment) }}</li>
231
232
233
				{% for chapter in chapters %}
				<li><span class="glyphicon glyphicon-play"></span> <a href="{{url_for('lecture', course=lecture.course.handle, id=lecture.id, t=chapter.time)}}">{{chapter.text}}</a></li>
				{% endfor %}
234
				{% if ismod() %}
235
236
237
				<li>{{ moderator_editor(['lectures',lecture.id,'internal'], lecture.internal) }}</li>
				<li>Sichtbar: {{ moderator_checkbox(['lectures',lecture.id,'visible'], lecture.visible) }}</li>
				<li>Livestream geplant: {{ moderator_checkbox(['lectures',lecture.id,'live'], lecture.live) }}</li>
238
				<li>Wird nicht aufgenommen: {{ moderator_checkbox(['lectures',lecture.id,'norecording'], lecture.norecording) }}</li>
239
240
241
				<li>Hörsaal: {{ moderator_editor(['lectures',lecture.id,'place'], lecture.place) }} </li>
				{% endif %}
			</ul>
242
243
244
245
246
247
248
249
250
251
252
253
254
			<ul class="col-sm-4 col-xs-12 list-unstyled">
				<li>
					<ul class="list-inline">
						<li class="dropdown">
							{{ video_download_btn(videos) }}
						</li>
						<li class="pull-right">
							{{ moderator_permissioneditor('lecture', lecture.id, lecture.perm, global_permissions) }}
						</li>
						<li class="pull-right">
							{{ moderator_delete(['lectures',lecture.id,'deleted']) }}
						</li>
					</ul>
255
				</li>
256
				{% if ismod() %}
257
				<li class="pull-right">
Andreas Valder's avatar
Andreas Valder committed
258
					<p>Abrufe: <span data-lectureid="{{ lecture.id }}" data-lecturedate="{{ lecture.time }}" class="viewcounter">loading...</span></p>
259
				</li>
260
				{% endif %}
261
262
263
264
265
266
267
268
			</ul>
		{% else %}
			<div class="col-sm-2 col-xs-12">
			</div>
			<ul class="list-unstyled col-sm-3 col-xs-12">
				<li>{{ moderator_editor(['lectures',lecture.id,'title'], lecture.title) }}{{livelabel((lecture.live and lecture.time > datetime.now()-timedelta(days=1)), videos|selectattr("livehandle")|list|length)}}</li>
			</ul>
			<ul class="list-unstyled col-sm-3 col-xs-12">
269
				{% if ismod() %}
270
				<li>{{ moderator_editor(['lectures',lecture.id,'time'], lecture.time) }} </li>
271
272
273
				{% else %}
				<li>{{ lecture.time|fulldate }}</li>
				{% endif %}
274
275
276
277
278
			</ul>
			<ul class="list-inline col-sm-4 col-xs-12">
				<li>{{ moderator_editor(['lectures',lecture.id,'comment'], lecture.comment) }}</li>
			</ul>
		{% endif %}
Andreas Valder's avatar
Andreas Valder committed
279
280
281
	</div>
</li>
{% endmacro %}
282

283
{% macro moderator_editor (path,value,reload=false) %}
284
	{% if ismod() %}
285
	<span class="moderator_editor" data-path="{{path|join('.')}}" data-reload="{{ reload|int }}" >
286
		<a class="moderator_editor_sign btn btn-default" title="{{path|join('.')}}{{ path|join('.')|getfielddescription }}" data-toggle="tooltip" tabindex="0" style="padding: 3px; margin-right: 5px;">
287
288
			<span class="glyphicon glyphicon-pencil"></span>
		</a>
289
		<span class="moderator_editor_value">{{ value|fixnl|safe }}</span>
290
	</span>
291
	{% else %}
292
		{{value|fixnl|safe}}
293
	{% endif %}
294
295
{% endmacro %}

296
{% macro moderator_checkbox (path,value) %}
297
	{% if ismod() %}
298
	<input title="{{path|join('.')}}{{ path|join('.')|getfielddescription }}" data-toggle="tooltip" type="checkbox" data-path="{{path|join('.')}}" {% if value %} checked {% endif %} onchange="moderator.editor.changeboxclick(this)"/>
299
300
	{% endif %}
{% endmacro %}
301

302
{% macro moderator_delete (path) %}
303
	{% if ismod() %}
304
	<button class="btn btn-default" style="background-color: red;" data-path="{{path|join('.')}}" onclick="moderator.editor.deletebtnclick(this)" >
Andreas Valder's avatar
Andreas Valder committed
305
306
307
308
309
		<span class="glyphicon glyphicon-trash"></span>
	</button>
	{% endif %}
{% endmacro %}

310
311
312
{% macro moderator_permissioneditor(type,id,perm,global_permissions) %}
	{% set tmp = global_permissions.extend(perm) %}
	{% set permdescription = perm|permdescr %}
313
314
315
316
317
	{% set permlogos = '' %}

	{% if permdescription[0] == 'public' %}
		{% set permlogos = '<span class="fa fa-globe" aria-hidden="true"></span>' %}
	{% endif %}
Julian Rother's avatar
Julian Rother committed
318
319
320
	{% if permdescription[0] == 'none' %}
		{% set permlogos = '<span class="fa fa-ban" aria-hidden="true"></span>' %}
	{% endif %}
321
322
323
324
	{% if permdescription[0] == 'password' %}
		{% set permlogos = '<span class="fa fa-lock" aria-hidden="true"></span>' %}
	{% endif %}
	{% if permdescription[0] == 'l2p' %}
325
		{% set permlogos = '<span class="fa" aria-hidden="true" style="width: 12px; height: 14px; background-size: cover; background-image: url(\'/static/l2p-logo.gif\');"></span>' %}
326
327
	{% endif %}
	{% if permdescription[0] == 'rwth' %}
328
		{% set permlogos = '<span class="fa" aria-hidden="true" style="width: 25px; height: 20px; background-size: cover; background-image: url(\'/static/rwth.png\');"></span>' %}
329
	{% endif %}
330
	{% if permdescription[0] == 'fsmpi' %}
331
		{% set permlogos = '<span class="fa" aria-hidden="true" style="width: 25px; height: 20px; background-size: cover; background-image: url(\'/static/fsmpi.png\');"></span>' %}
332
	{% endif %}
333
334

	{% if ismod() %}
335
		<button class="btn btn-default" data-toggle="modal" data-target="#editperm" data-type="{{ type }}" data-id="{{ id }}">
336
			{{ permlogos|safe }}
337
		</button>
Andreas Valder's avatar
Andreas Valder committed
338
	{% else %}
Andreas Valder's avatar
Andreas Valder committed
339
		<span title="{{permdescription[1]}}">
340
			{{ permlogos|safe }}
Andreas Valder's avatar
Andreas Valder committed
341
		</span>
342
	{% endif %}
Andreas Valder's avatar
Andreas Valder committed
343
	
344
{% endmacro %}
Andreas Valder's avatar
Andreas Valder committed
345
346

{% macro vtttime(time) %}{{ '%02d:%02d:%02d.000'|format( time//3600, (time//60)%60, time%60) }}{% endmacro %}
347

Julian Rother's avatar
Julian Rother committed
348
{% macro stats_viewsperday(id, req, title, type="scatter", param=None, maxtraces=7) %}
349
350
351
<script>
	$.ajax({
		method: "GET",
Julian Rother's avatar
Julian Rother committed
352
		url: "{{url_for('stats_viewsperday', req=req, param=param)}}",
353
354
355
356
		dataType: "json",
		error: moderator.api.handleapierror,
		success: function (data) {
			var traces = [];
Julian Rother's avatar
Julian Rother committed
357
358
359
360
361
			for (var i = 0; i < data.views.length; i++) {
				if (data.views[i].name == 'total' && data.views.length > 2)
					traces.push({"x": data.times, "y": data.views[i].vals, "type": "{{type}}", "name": "gesamt", line: {"color": "black", "width": 2}});
				else
					traces.push({"x": data.times, "y": data.views[i].vals, "type": "{{type}}", "name": data.views[i].name, line: {"width": 1}});
362
			}
Julian Rother's avatar
Julian Rother committed
363
364
365
366
367
368
369
370
371
372
373
374
			traces.sort(function (a, b) {
				amax = 0;
				bmax = 0;
				for (var i = 0; i < a.y.length; i++)
					amax = Math.max(amax, a.y[i]);
				for (var i = 0; i < b.y.length; i++)
					bmax = Math.max(bmax, b.y[i]);
				return bmax-amax;
			});
			for (var i = 0; i < traces.length; i++)
				if (i > {{maxtraces}})
					traces[i].visible = "legendonly";
375
376
377
378
379
380
381
382
383
			var layout = {
				"title": "{{title}}",
				"showlegend": (traces.length != 1)
			};
			Plotly.newPlot("{{id}}", traces, layout, { "modeBarButtonsToRemove": ['sendDataToCloud','hoverCompareCartesian'], "displaylogo": false});
		}
	});
</script>
{% endmacro %}
Julian Rother's avatar
Julian Rother committed
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415

{% macro featured_content(item) %} {# This macro is used in a panel div after the panel header #}
	{% if item.type == 'image' %}
		<!-- Putting image tag here makes it borderless. This should be replaced by a bootstrap-compatible solution. -->
		<img src="{{item.param}}" style="width: 100%;"/>
		{% if ismod() %}
		<p>{{moderator_editor(('featured',item.id,'param'), item.param)}}</p>
		{% endif %}
		{% if item.text or ismod() %}
			<div class="panel-body">{{ moderator_editor(('featured',item.id,'text'), item.text) }}</div>
		{% endif %}
	{% elif item.type == 'courses' %}
		{% if item.text or ismod() %}
			<div class="panel-body">{{ moderator_editor(('featured',item.id,'text'), item.text) }}</div>
		{% endif %}
		<ul class="courses-list list-group">
		{% for i in item.courses %}
			{{ course_list_item(i) }}
		{% endfor %}
		</ul>
		<div class="panel-footer">
		{% if ismod() %}
			<ul class="list-inline">	
			<li><div class="dropdown">
				{% set params = {'semester': 'Semester', 'title': 'Veranstaltung', 'organizer': 'Dozent', 'subject': 'Kategorie'} %}
				<button class="btn btn-default dropdown-toggle" type="button" data-toggle="dropdown">{{params[item.param]}}: <span class="caret"></span></button>
				<ul class="dropdown-menu">
					{% for key, name in params.items() %}
					<li><a href="{{url_for('edit', **{'featured.'+item.id|string+'.param': key, 'ref': request.url})}}">{{name}}</a></li>
					{% endfor %}
				</ul>
			</div></li>
416
			<li>{{ moderator_editor(('featured',item.id,'param2'), item.param2, reload=True) }}</li>
Julian Rother's avatar
Julian Rother committed
417
418
419
420
			</ul>
		{% endif %}
		Die vollständige Liste findest du <a href="{{ url_for('courses') }}">hier</a>.
		</div>
Julian Rother's avatar
Julian Rother committed
421
422
423
424
425
426
427
	{% elif item.type == 'video' %}
		<div class="panel-body">
			<div>{{ moderator_editor(('featured',item.id,'text'), item.text) }}</div>
			{% if item.videos %}
			{{ player(item.lecture, item.videos, autoplay=False)}}
			{% endif %}
			{% if ismod() %}
428
			<div>ID des Videos: {{ moderator_editor(('featured',item.id,'param'), item.param, reload=True) }}</div>
Julian Rother's avatar
Julian Rother committed
429
430
431
			{% endif %}
			<div>{{ moderator_editor(('featured',item.id,'param2'), item.param2) }}</div>
		</div>
Julian Rother's avatar
Julian Rother committed
432
433
434
435
436
437
	{% else %}
		{% if item.text or ismod() %}
			<div class="panel-body">{{ moderator_editor(('featured',item.id,'text'), item.text) }}</div>
		{% endif %}
	{% endif %}
{% endmacro %}