lecture.html 3.38 KB
Newer Older
Andreas Valder's avatar
Andreas Valder committed
1
{% from 'macros.html' import player %}
Andreas Valder's avatar
Andreas Valder committed
2
3
{% from 'macros.html' import video_download_btn %}
{% from 'macros.html' import video_embed_btn %}
4
{% from 'macros.html' import vtttime %}
5
6
7
{% from 'macros.html' import moderator_editor %}
{% from 'macros.html' import moderator_delete %}
{% from 'macros.html' import moderator_checkbox %}
Andreas Valder's avatar
Andreas Valder committed
8
{% set page_border = 1 -%}
9

Andreas Valder's avatar
Andreas Valder committed
10
{% extends "base.html" %}
11
{% block title %}- {{ course.title }}: {{ lecture.title}}{% endblock %}
12
13
14
15
16
17
18
{% block header %}
{{ super() }}

	<meta property="og:image" content="{{ config.VIDEOPREFIX }}/{{ lecture['titlefile'] }}" />
	<meta property="og:title" content="{{ course.title }}: {{ lecture.title}}" />
	<meta property="og:description" content="{{ lecture.comment }}" />
{% endblock %}
Andreas Valder's avatar
Andreas Valder committed
19
{% block content %}
20
21
<div class="panel panel-default">
	<div class="panel-heading">
22
		<h1 class="panel-title"><strong><a href="{{url_for('course', handle=course.handle)}}#lecture-{{lecture.id}}">{{ course.title }}</strong></a>: {{ lecture.title}}</h1>
23
	</div>
Andreas Valder's avatar
Andreas Valder committed
24
	<div class="panel-body">
Andreas Valder's avatar
Andreas Valder committed
25
26
		<div class="row" style="padding: 0px;">
			<div class="col-sm-6 col-xs-12" style="padding-bottom: 5px;">
Andreas Valder's avatar
Andreas Valder committed
27
				<a href="{{url_for('course', handle=course.handle)}}#lecture-{{lecture.id}}" class="btn btn-default" >Zur Veranstaltungsseite</a>
Andreas Valder's avatar
Andreas Valder committed
28
29
			</div>
			<div class="col-sm-6 col-xs-12">
Andreas Valder's avatar
Andreas Valder committed
30
				<ul class="list-inline pull-right">
31
					<li><button class="btn btn-default" id="hintnewchapter">Kapitelmarker vorschlagen</button></li>
Andreas Valder's avatar
Andreas Valder committed
32
33
34
					<li>{{ video_embed_btn(lecture.id) }}</li>
					<li class="dropdown">{{ video_download_btn(videos) }}</li>
				</ul>
Andreas Valder's avatar
Andreas Valder committed
35
36
			</div>
		</div>
Andreas Valder's avatar
Andreas Valder committed
37
		<div class="row">
Andreas Valder's avatar
Andreas Valder committed
38
			<div class="col-xs-12" style="padding: 0px">
Andreas Valder's avatar
Andreas Valder committed
39
40
				{{ player(lecture, videos) }}
			</div>
41
42
43
44
45
46
47
48
49
50
51
52
			{% if ismod() %}
				<div class="col-xs-12" style="padding-top: 10px;">
					<p>Kapitel:</p>
					<table class="table table-hover">
					<tr>
						<th>Index</th>
						<th>Start</th>
						<th>Kapitel</th>
						<th>Sichtbar</th>
						<th></th>
					</tr>
					{% for c in chapters|sort(attribute='time') %}
53
					<tr>
54
						<td>{{ loop.index }}</td>
55
						<td><a href="javascript:videojs('videoplayer').currentTime({{c['time']}})">{{ vtttime(c['time']) }}</a></td>
56
57
58
59
60
61
62
63
						<td>{{ moderator_editor(['chapters',c.id,'text'],c['text']) }}</td>
						<td>{{ moderator_checkbox(['chapters',c.id,'visible'], c.visible) }}</td>
						<td>{{ moderator_delete(['chapters',c.id,'deleted']) }}</td>
					</tr>
					{% endfor %}
					</table>
				</div>
			{% endif %}
Andreas Valder's avatar
Andreas Valder committed
64
		</div>
65
66
	</div>
</div>
67
68
69
70
71
72
<script>
$(function() {
	$( "#hintnewchapter" ).popover(
			{
				html:true,
				title:'Kapitelmarkierung vorschlagen',
73
74
75
76
77
				content: function() {
					var zeropad = function (num, places) {
						  var zero = places - num.toString().length + 1;
						    return Array(+(zero > 0 && zero)).join("0") + num;
					};
78
					var timestamp = videojs('videoplayer').currentTime()
79
80
81
					var h = zeropad( Math.trunc(timestamp/3600),2);
					var m = zeropad( Math.trunc((timestamp%3600)/60),2);
					var s = zeropad( Math.trunc(timestamp%60),2);
82
83
84
					var timeasstring = h+':'+m+':'+s;
					return '<form method="post" data-url="{{ url_for('suggest_chapter', lectureid=lecture.id) }}" onSubmit="return moderator.editor.hintchapterclick(this);"><input placeholder="00:00.000" name="time" type="text" value="'+timeasstring+'"><br><input placeholder="Kapitel" name="text" type="texz"><br><input type="submit" value="Vorschlagen"></form>';
				}
85
			})
86

87
88
});
</script>
Andreas Valder's avatar
Andreas Valder committed
89
{% endblock %}