mirror of
https://gitlab.com/RemixDev/deemix-webui.git
synced 2025-01-24 07:11:43 +00:00
117 lines
2.7 KiB
JavaScript
117 lines
2.7 KiB
JavaScript
import $ from 'jquery'
|
|
|
|
/* ===== Globals ====== */
|
|
// Object is needed for vue proxy
|
|
window.vol = {
|
|
preview_max_volume: 100
|
|
}
|
|
|
|
/* ===== Locals ===== */
|
|
let preview_track = document.getElementById('preview-track')
|
|
let preview_stopped = true
|
|
|
|
// init stuff
|
|
function init() {
|
|
preview_track.volume = 1
|
|
|
|
// start playing when track loaded
|
|
preview_track.addEventListener('canplay', function() {
|
|
preview_track.play()
|
|
preview_stopped = false
|
|
$(preview_track).animate({ volume: vol.preview_max_volume / 100 }, 500)
|
|
})
|
|
|
|
// auto fadeout when at the end of the song
|
|
preview_track.addEventListener('timeupdate', function() {
|
|
if (preview_track.currentTime > preview_track.duration - 1) {
|
|
$(preview_track).animate({ volume: 0 }, 800)
|
|
preview_stopped = true
|
|
$('a[playing] > .preview_controls').css({ opacity: 0 })
|
|
$('*').removeAttr('playing')
|
|
$('.preview_controls').text('play_arrow')
|
|
$('.preview_playlist_controls').text('play_arrow')
|
|
}
|
|
})
|
|
}
|
|
|
|
// on modal closing
|
|
function stopStackedTabsPreview() {
|
|
if (
|
|
$('.preview_playlist_controls').filter(function() {
|
|
return $(this).attr('playing')
|
|
}).length > 0
|
|
) {
|
|
$(preview_track).animate({ volume: 0 }, 800)
|
|
preview_stopped = true
|
|
$('.preview_playlist_controls').removeAttr('playing')
|
|
$('.preview_playlist_controls').text('play_arrow')
|
|
}
|
|
}
|
|
|
|
// on hover event
|
|
function previewMouseEnter(e) {
|
|
$(e.currentTarget).css({ opacity: 1 })
|
|
}
|
|
|
|
function previewMouseLeave(event) {
|
|
const { currentTarget: obj } = event
|
|
|
|
if (
|
|
($(obj)
|
|
.parent()
|
|
.attr('playing') &&
|
|
preview_stopped) ||
|
|
!$(obj)
|
|
.parent()
|
|
.attr('playing')
|
|
) {
|
|
$(obj).css({ opacity: 0 }, 200)
|
|
}
|
|
}
|
|
|
|
// on click event
|
|
function playPausePreview(e) {
|
|
e.preventDefault()
|
|
|
|
const { currentTarget: obj } = event
|
|
|
|
var $icon = obj.tagName == 'I' ? $(obj) : $(obj).children('i')
|
|
|
|
if ($(obj).attr('playing')) {
|
|
if (preview_track.paused) {
|
|
preview_track.play()
|
|
preview_stopped = false
|
|
$icon.text('pause')
|
|
$(preview_track).animate({ volume: vol.preview_max_volume / 100 }, 500)
|
|
} else {
|
|
preview_stopped = true
|
|
$icon.text('play_arrow')
|
|
$(preview_track).animate({ volume: 0 }, 250, 'swing', () => {
|
|
preview_track.pause()
|
|
})
|
|
}
|
|
} else {
|
|
$('*').removeAttr('playing')
|
|
$(obj).attr('playing', true)
|
|
$('.preview_controls').text('play_arrow')
|
|
$('.preview_playlist_controls').text('play_arrow')
|
|
$('.preview_controls').css({ opacity: 0 })
|
|
$icon.text('pause')
|
|
$icon.css({ opacity: 1 })
|
|
preview_stopped = false
|
|
$(preview_track).animate({ volume: 0 }, 250, 'swing', () => {
|
|
preview_track.pause()
|
|
$('#preview-track_source').prop('src', $(obj).data('preview'))
|
|
preview_track.load()
|
|
})
|
|
}
|
|
}
|
|
|
|
export default {
|
|
init,
|
|
stopStackedTabsPreview,
|
|
previewMouseEnter,
|
|
previewMouseLeave,
|
|
playPausePreview
|
|
}
|