mirror of
https://github.com/koel/koel
synced 2025-01-25 02:35:08 +00:00
93 lines
1.9 KiB
Vue
93 lines
1.9 KiB
Vue
<template>
|
|
<div id="youtube-extra-wrapper">
|
|
<template v-if="videos && videos.length">
|
|
<a class="video" v-for="video in videos" :href="'https://youtu.be/' + video.id.videoId"
|
|
@click.prevent="playYouTube(video.id.videoId)">
|
|
<div class="thumb">
|
|
<img :src="video.snippet.thumbnails.default.url" width="90">
|
|
</div>
|
|
<div class="meta">
|
|
<h3 class="title">{{ video.snippet.title }}</h3>
|
|
<p class="desc">{{ video.snippet.description }}</p>
|
|
</div>
|
|
</a>
|
|
<button @click="loadMore" v-if="!loading" class="more btn-blue">Load More</button>
|
|
</template>
|
|
<p class="nope" v-else>Play a song to retrieve related YouTube videos.</p>
|
|
<p class="nope" v-show="loading">Loading…</p>
|
|
</div>
|
|
</template>
|
|
|
|
<script>
|
|
import { youtube as youtubeService } from '../../../services'
|
|
|
|
export default {
|
|
name: 'main-wrapper--extra--youtube',
|
|
props: ['song'],
|
|
|
|
data () {
|
|
return {
|
|
loading: false,
|
|
videos: []
|
|
}
|
|
},
|
|
|
|
watch: {
|
|
song (val) {
|
|
this.videos = val.youtube ? val.youtube.items : []
|
|
}
|
|
},
|
|
|
|
methods: {
|
|
playYouTube (id) {
|
|
youtubeService.play(id)
|
|
},
|
|
|
|
/**
|
|
* Load more videos.
|
|
*/
|
|
loadMore () {
|
|
this.loading = true
|
|
youtubeService.searchVideosRelatedToSong(this.song).then(() => {
|
|
this.videos = this.song.youtube.items
|
|
this.loading = false
|
|
})
|
|
}
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style lang="scss" scoped>
|
|
#youtube-extra-wrapper {
|
|
overflow-x: hidden;
|
|
|
|
.video {
|
|
display: flex;
|
|
padding: 12px 0;
|
|
border-bottom: 1px solid #333;
|
|
|
|
.thumb {
|
|
margin-right: 10px;
|
|
}
|
|
|
|
.title {
|
|
font-size: 1.1rem;
|
|
margin-bottom: .4rem;
|
|
}
|
|
|
|
.desc {
|
|
font-size: .9rem;
|
|
}
|
|
|
|
&:hover {
|
|
.title {
|
|
color: #fff;
|
|
}
|
|
}
|
|
|
|
&:last-of-type {
|
|
margin-bottom: 16px;
|
|
}
|
|
}
|
|
}
|
|
</style>
|