koel/resources/assets/js/components/main-wrapper/extra/youtube.vue
2017-03-28 18:25:24 +08:00

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>