koel/resources/assets/js/components/shared/song-item.vue
2016-01-31 23:59:06 +08:00

148 lines
3.9 KiB
Vue

<template>
<tr
@dblclick.prevent="playRightAwayyyyyyy"
class="song-item"
:class="{ selected: selected, playing: playbackState === 'playing' || playbackState === 'paused' }"
>
<td class="title">{{ song.title }}</td>
<td class="artist">{{ song.album.artist.name }}</td>
<td class="album">{{ song.album.name }}</td>
<td class="time">{{ song.fmtLength }}</td>
<td class="play" @click.stop="doPlayback">
<i class="fa fa-pause-circle" v-show="playbackState === 'playing'"></i>
<i class="fa fa-play-circle" v-else></i>
</td>
</tr>
</template>
<script>
import playback from '../../services/playback';
import queueStore from '../../stores/queue';
export default {
props: ['song'],
data() {
return {
playbackState: 'stopped',
selected: false,
};
},
methods: {
/**
* Play the song right away.
*/
playRightAwayyyyyyy() {
if (!queueStore.contains(this.song)) {
queueStore.queueAfterCurrent(this.song);
}
Vue.nextTick(() => playback.play(this.song));
},
/**
* Take the right playback action based on the current playback state.
*/
doPlayback() {
switch (this.playbackState) {
case 'playing':
playback.pause();
break;
case 'paused':
playback.resume();
break;
default:
this.playRightAwayyyyyyy();
break;
}
},
/**
* Toggle the "selected" state of the current component.
*/
toggleSelectedState() {
this.selected = !this.selected;
},
/**
* Select the current component (apply a CSS class on its DOM).
*/
select() {
this.selected = true;
},
/**
* Deselect the current component.
*/
deselect() {
this.selected = false;
}
},
events: {
// Listen to playback events and set playback state.
'song:played': function (song) {
this.playbackState = this.song === song ? 'playing' : 'stopped';
},
'song:stopped': function () {
this.playbackState = 'stopped';
},
'song:paused': function (song) {
if (this.song === song) {
this.playbackState = 'paused';
}
},
},
/**
* When the component is (re)attached into the DOM, we check if its song is current and set its playback state.
*/
attached() {
if (this.song === queueStore.current()) {
this.playbackState = 'playing';
}
},
};
</script>
<style lang="sass">
@import "resources/assets/sass/partials/_vars.scss";
@import "resources/assets/sass/partials/_mixins.scss";
.song-item {
border-bottom: 1px solid $color2ndBgr;
html.no-touchevents &:hover {
background: rgba(255, 255, 255, .05);
}
.time {
color: $color2ndText;
}
.title {
min-width: 192px;
}
.play {
max-width: 32px;
opacity: .5;
i {
font-size: 150%;
}
}
&.selected {
background-color: rgba(255, 255, 255, .08);
}
&.playing {
color: $colorHighlight;
}
}
</style>