koel/resources/assets/js/components/main-wrapper/extra/youtube.vue
2016-07-30 23:32:17 +08:00

94 lines
1.9 KiB
Vue

<template>
<div id="youtube-wrapper">
<template v-if="videos && videos.length">
<a class="video" v-for="video in videos" href="#" @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 retreive related YouTube videos.</p>
<p class="nope" v-show="loading">Loading</p>
</div>
</template>
<script>
import { event } from '../../../utils';
import { youtube as youtubeService } from '../../../services';
export default {
name: 'main-wrapper--extra--youtube',
// We explicitly use 'youtube' as a prop here to force reactivity.
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, () => {
this.videos = this.song.youtube.items;
this.loading = false;
});
},
},
};
</script>
<style lang="sass" scoped>
#youtube-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>