mirror of
https://github.com/koel/koel
synced 2024-12-30 06:23:05 +00:00
26 lines
912 B
Vue
26 lines
912 B
Vue
<template>
|
|
<ContextMenuBase ref="base" extra-class="playlist-item-menu">
|
|
<li :data-testid="`playlist-context-menu-edit-${playlist.id}`" @click="editPlaylist">Edit</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 emit = defineEmits(['edit'])
|
|
|
|
const editPlaylist = () => trigger(() => playlist.value.is_smart
|
|
? eventBus.emit('MODAL_SHOW_EDIT_SMART_PLAYLIST_FORM', playlist.value)
|
|
: emit('edit')
|
|
)
|
|
|
|
const deletePlaylist = () => trigger(() => eventBus.emit('PLAYLIST_DELETE', playlist.value))
|
|
|
|
defineExpose({ open })
|
|
</script>
|