2015-12-13 04:42:28 +00:00
|
|
|
<template>
|
2016-02-08 12:21:24 +00:00
|
|
|
<tr
|
2015-12-13 04:42:28 +00:00
|
|
|
class="song-item"
|
2016-06-25 05:24:55 +00:00
|
|
|
draggable="true"
|
|
|
|
:data-song-id="song.id"
|
|
|
|
key="id"
|
|
|
|
@click="$parent.rowClick(song.id, $event)"
|
|
|
|
@dblclick.prevent="playRightAwayyyyyyy"
|
|
|
|
@dragstart="$parent.dragStart(song.id, $event)"
|
|
|
|
@dragleave="$parent.removeDroppableState($event)"
|
|
|
|
@dragover.prevent="$parent.allowDrop(song.id, $event)"
|
|
|
|
@drop.stop.prevent="$parent.handleDrop(song.id, $event)"
|
|
|
|
@contextmenu.prevent="$parent.openContextMenu(song.id, $event)"
|
2016-02-08 12:21:24 +00:00
|
|
|
:class="{ selected: selected, playing: song.playbackState === 'playing' || song.playbackState === 'paused' }"
|
2015-12-13 04:42:28 +00:00
|
|
|
>
|
2016-03-20 14:23:01 +00:00
|
|
|
<td class="track-number">{{ song.track || '' }}</td>
|
2016-02-14 07:18:40 +00:00
|
|
|
<td class="title">{{ song.title }}</td>
|
2016-04-17 15:38:06 +00:00
|
|
|
<td class="artist">{{ song.artist.name }}</td>
|
2016-03-20 14:06:57 +00:00
|
|
|
<td class="album">{{ song.album.name }}</td>
|
2016-06-25 05:24:55 +00:00
|
|
|
<td class="time">{{ song.fmtLength }}</td>
|
2016-01-11 14:06:42 +00:00
|
|
|
<td class="play" @click.stop="doPlayback">
|
2016-06-25 05:24:55 +00:00
|
|
|
<i class="fa fa-pause-circle" v-if="song.playbackState === 'playing'"></i>
|
2016-01-11 14:06:42 +00:00
|
|
|
<i class="fa fa-play-circle" v-else></i>
|
2016-01-07 04:22:02 +00:00
|
|
|
</td>
|
2015-12-13 04:42:28 +00:00
|
|
|
</tr>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
2016-06-25 10:15:57 +00:00
|
|
|
import { playback } from '../../services';
|
|
|
|
import { queueStore } from '../../stores';
|
2015-12-13 04:42:28 +00:00
|
|
|
|
|
|
|
export default {
|
2016-02-14 07:18:40 +00:00
|
|
|
props: ['song'],
|
2015-12-13 04:42:28 +00:00
|
|
|
|
|
|
|
data() {
|
|
|
|
return {
|
2016-01-17 09:59:58 +00:00
|
|
|
selected: false,
|
2015-12-13 04:42:28 +00:00
|
|
|
};
|
|
|
|
},
|
|
|
|
|
|
|
|
methods: {
|
|
|
|
/**
|
2016-01-07 08:11:11 +00:00
|
|
|
* Play the song right away.
|
2015-12-13 04:42:28 +00:00
|
|
|
*/
|
2016-01-31 15:59:06 +00:00
|
|
|
playRightAwayyyyyyy() {
|
2016-01-07 08:11:11 +00:00
|
|
|
if (!queueStore.contains(this.song)) {
|
|
|
|
queueStore.queueAfterCurrent(this.song);
|
|
|
|
}
|
2016-02-08 12:21:24 +00:00
|
|
|
|
|
|
|
playback.play(this.song);
|
2015-12-13 04:42:28 +00:00
|
|
|
},
|
2016-01-06 16:41:59 +00:00
|
|
|
|
2016-01-11 14:06:42 +00:00
|
|
|
/**
|
|
|
|
* Take the right playback action based on the current playback state.
|
|
|
|
*/
|
|
|
|
doPlayback() {
|
2016-02-08 12:21:24 +00:00
|
|
|
switch (this.song.playbackState) {
|
2016-01-11 14:06:42 +00:00
|
|
|
case 'playing':
|
|
|
|
playback.pause();
|
|
|
|
break;
|
|
|
|
case 'paused':
|
|
|
|
playback.resume();
|
|
|
|
break;
|
|
|
|
default:
|
2016-01-31 15:59:06 +00:00
|
|
|
this.playRightAwayyyyyyy();
|
2016-01-11 14:06:42 +00:00
|
|
|
break;
|
|
|
|
}
|
2016-01-06 16:41:59 +00:00
|
|
|
},
|
2016-01-17 09:59:58 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Toggle the "selected" state of the current component.
|
|
|
|
*/
|
|
|
|
toggleSelectedState() {
|
|
|
|
this.selected = !this.selected;
|
|
|
|
},
|
|
|
|
|
2016-01-17 14:08:39 +00:00
|
|
|
/**
|
|
|
|
* Select the current component (apply a CSS class on its DOM).
|
|
|
|
*/
|
2016-01-17 09:59:58 +00:00
|
|
|
select() {
|
2016-03-13 17:00:32 +00:00
|
|
|
this.selected = true;
|
2016-01-17 09:59:58 +00:00
|
|
|
},
|
|
|
|
|
2016-01-17 14:08:39 +00:00
|
|
|
/**
|
|
|
|
* Deselect the current component.
|
|
|
|
*/
|
2016-01-17 09:59:58 +00:00
|
|
|
deselect() {
|
|
|
|
this.selected = false;
|
2016-03-14 17:16:38 +00:00
|
|
|
},
|
2015-12-13 04:42:28 +00:00
|
|
|
},
|
|
|
|
};
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<style lang="sass">
|
2016-03-13 17:00:32 +00:00
|
|
|
@import "../../../sass/partials/_vars.scss";
|
|
|
|
@import "../../../sass/partials/_mixins.scss";
|
2015-12-13 04:42:28 +00:00
|
|
|
|
|
|
|
.song-item {
|
|
|
|
border-bottom: 1px solid $color2ndBgr;
|
|
|
|
|
2016-01-07 04:22:02 +00:00
|
|
|
html.no-touchevents &:hover {
|
2015-12-13 04:42:28 +00:00
|
|
|
background: rgba(255, 255, 255, .05);
|
|
|
|
}
|
|
|
|
|
2016-03-20 14:24:58 +00:00
|
|
|
.time, .track-number {
|
2015-12-13 04:42:28 +00:00
|
|
|
color: $color2ndText;
|
|
|
|
}
|
|
|
|
|
|
|
|
.title {
|
|
|
|
min-width: 192px;
|
|
|
|
}
|
|
|
|
|
2016-01-07 04:22:02 +00:00
|
|
|
.play {
|
2016-01-06 16:41:59 +00:00
|
|
|
max-width: 32px;
|
2016-01-07 04:22:02 +00:00
|
|
|
opacity: .5;
|
|
|
|
|
|
|
|
i {
|
2016-06-02 09:46:01 +00:00
|
|
|
font-size: 1.5rem;
|
2016-01-07 04:22:02 +00:00
|
|
|
}
|
2016-01-06 16:41:59 +00:00
|
|
|
}
|
|
|
|
|
2015-12-13 04:42:28 +00:00
|
|
|
&.selected {
|
|
|
|
background-color: rgba(255, 255, 255, .08);
|
|
|
|
}
|
|
|
|
|
|
|
|
&.playing {
|
|
|
|
color: $colorHighlight;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</style>
|