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

26 lines
947 B
Vue

<template>
<ContextMenuBase ref="base" extra-class="playlist-item-menu">
<li :data-testid="`playlist-context-menu-edit-${playlist.id}`" @click="editPlaylist">
{{ playlist.is_smart ? 'Edit' : 'Rename' }}
</li>
<li :data-testid="`playlist-context-menu-delete-${playlist.id}`" @click="deletePlaylist">Delete</li>
</ContextMenuBase>
</template>
<script lang="ts" setup>
import { Ref, toRef } from 'vue'
import { eventBus } from '@/utils'
import { useContextMenu } from '@/composables'
const { context, base, ContextMenuBase, open, trigger } = useContextMenu()
const playlist = toRef(context, 'playlist') as Ref<Playlist>
const editPlaylist = () => trigger(() => eventBus.emit(
playlist.value.is_smart ? 'MODAL_SHOW_EDIT_SMART_PLAYLIST_FORM' : 'MODAL_SHOW_EDIT_PLAYLIST_FORM',
playlist.value
))
const deletePlaylist = () => trigger(() => eventBus.emit('PLAYLIST_DELETE', playlist.value))
defineExpose({ open })
</script>