ffplayout/frontend/components/VideoPlayer.vue
2024-09-24 10:49:37 +02:00

78 lines
1.5 KiB
Vue

<template>
<div>
<div v-if="options.sources">
<video
:id="reference"
class="video-js vjs-default-skin vjs-big-play-centered vjs-16-9"
width="1024"
height="576"
/>
</div>
</div>
</template>
<script setup lang="ts">
import videojs from 'video.js'
import 'video.js/dist/video-js.css'
const configStore = useConfig()
const player = ref()
const props = defineProps({
options: {
type: Object,
required: true,
},
reference: {
type: String,
required: true,
},
})
onMounted(() => {
const volume = localStorage.getItem('volume')
player.value = videojs(props.reference, props.options, function onPlayerReady() {
// console.log('onPlayerReady', this);
})
if (volume !== null) {
player.value.volume(volume)
}
player.value.on('volumechange', () => {
localStorage.setItem('volume', player.value.volume())
})
player.value.on('error', () => {
setTimeout(() => {
configStore.showPlayer = false
nextTick(() => {
configStore.showPlayer = true
})
}, 2000)
})
})
onBeforeUnmount(() => {
if (player.value) {
player.value.dispose()
}
})
</script>
<style>
.video-js .vjs-volume-panel.vjs-volume-panel-horizontal {
width: 10em;
}
.video-js .vjs-volume-panel .vjs-volume-control.vjs-volume-horizontal {
width: 5em;
height: 3em;
margin-right: 0;
opacity: 1;
}
</style>