koel/resources/assets/js/components/playlist/PlaylistFolderContextMenu.vue

66 lines
2.2 KiB
Vue
Raw Normal View History

<template>
2024-05-08 09:11:32 +00:00
<ContextMenu ref="base">
<template v-if="folder">
<template v-if="playable">
<li @click="play">Play All</li>
<li @click="shuffle">Shuffle All</li>
2022-12-02 16:17:37 +00:00
<li class="separator" />
</template>
<li @click="createPlaylist">New Playlist</li>
<li @click="createSmartPlaylist">New Smart Playlist</li>
2022-12-02 16:17:37 +00:00
<li class="separator" />
<li @click="rename">Rename</li>
<li @click="destroy">Delete</li>
</template>
2024-05-08 09:11:32 +00:00
</ContextMenu>
</template>
<script lang="ts" setup>
import { computed, ref } from 'vue'
2022-11-18 18:44:20 +00:00
import { eventBus } from '@/utils'
import { playlistStore, songStore } from '@/stores'
import { playbackService } from '@/services'
import { useContextMenu, useMessageToaster, useRouter } from '@/composables'
2024-05-08 09:11:32 +00:00
const { base, ContextMenu, open, trigger } = useContextMenu()
const { go } = useRouter()
const { toastWarning } = useMessageToaster()
const folder = ref<PlaylistFolder>()
const playlistsInFolder = computed(() => folder.value ? playlistStore.byFolder(folder.value) : [])
const playable = computed(() => playlistsInFolder.value.length > 0)
const play = () => trigger(async () => {
const songs = await songStore.fetchForPlaylistFolder(folder.value!)
if (songs.length) {
playbackService.queueAndPlay(songs)
go('queue')
} else {
toastWarning('No songs available.')
}
})
const shuffle = () => trigger(async () => {
const songs = await songStore.fetchForPlaylistFolder(folder.value!)
if (songs.length) {
playbackService.queueAndPlay(songs, true)
go('queue')
} else {
toastWarning('No songs available.')
}
})
2022-12-02 16:17:37 +00:00
const createPlaylist = () => trigger(() => eventBus.emit('MODAL_SHOW_CREATE_PLAYLIST_FORM', folder.value!))
const createSmartPlaylist = () => trigger(() => eventBus.emit('MODAL_SHOW_CREATE_SMART_PLAYLIST_FORM', folder.value!))
const rename = () => trigger(() => eventBus.emit('MODAL_SHOW_EDIT_PLAYLIST_FOLDER_FORM', folder.value!))
const destroy = () => trigger(() => eventBus.emit('PLAYLIST_FOLDER_DELETE', folder.value!))
2024-01-24 22:39:47 +00:00
eventBus.on('PLAYLIST_FOLDER_CONTEXT_MENU_REQUESTED', async ({ pageX, pageY }, _folder) => {
folder.value = _folder
2024-01-24 22:39:47 +00:00
await open(pageY, pageX)
})
</script>