aboutsummaryrefslogtreecommitdiff
path: root/viewer/src/components/item_handlers/LdVideoViewer.vue
diff options
context:
space:
mode:
Diffstat (limited to 'viewer/src/components/item_handlers/LdVideoViewer.vue')
-rw-r--r--viewer/src/components/item_handlers/LdVideoViewer.vue54
1 files changed, 54 insertions, 0 deletions
diff --git a/viewer/src/components/item_handlers/LdVideoViewer.vue b/viewer/src/components/item_handlers/LdVideoViewer.vue
new file mode 100644
index 0000000..67203a5
--- /dev/null
+++ b/viewer/src/components/item_handlers/LdVideoViewer.vue
@@ -0,0 +1,54 @@
1<!--
2-- ldgallery - A static generator which turns a collection of tagged
3-- pictures into a searchable web gallery.
4--
5-- Copyright (C) 2020 Pacien TRAN-GIRARD
6--
7-- This program is free software: you can redistribute it and/or modify
8-- it under the terms of the GNU Affero General Public License as
9-- published by the Free Software Foundation, either version 3 of the
10-- License, or (at your option) any later version.
11--
12-- This program is distributed in the hope that it will be useful,
13-- but WITHOUT ANY WARRANTY; without even the implied warranty of
14-- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15-- GNU Affero General Public License for more details.
16--
17-- You should have received a copy of the GNU Affero General Public License
18-- along with this program. If not, see <https://www.gnu.org/licenses/>.
19-->
20
21<template>
22 <!-- intermediate container necessary to eliminate the scrollbar -->
23 <div class="fill no-scroll">
24 <video
25 class="fill"
26 :src="itemResourceUrl"
27 :poster="thumbnailResourceUrl"
28 preload="auto"
29 controls
30 >
31 <ld-download :item="item" />
32 </video>
33 </div>
34</template>
35
36<script lang="ts">
37import { Component, Prop, Vue } from "vue-property-decorator";
38
39@Component
40export default class LdVideoViewer extends Vue {
41 @Prop({ required: true }) readonly item!: Gallery.Video;
42
43 get itemResourceUrl(): string {
44 return this.$galleryStore.resourceRoot + this.item.properties.resource;
45 }
46
47 get thumbnailResourceUrl(): string {
48 return this.item.thumbnail ? this.$galleryStore.resourceRoot + this.item.thumbnail.resource : "";
49 }
50}
51</script>
52
53<style lang="scss" module>
54</style>