mirror of
https://github.com/koel/koel
synced 2025-01-01 23:38:43 +00:00
29 lines
1.1 KiB
Vue
29 lines
1.1 KiB
Vue
<template>
|
|
<ContextMenuBase ref="base" extra-class="playlist-menu">
|
|
<li data-testid="playlist-context-menu-create-simple" @click="onItemClicked('new-playlist')">New Playlist</li>
|
|
<li data-testid="playlist-context-menu-create-smart" @click="onItemClicked('new-smart-playlist')">
|
|
New Smart Playlist
|
|
</li>
|
|
<li data-testid="playlist-context-menu-create-folder" @click="onItemClicked('new-folder')">New Folder</li>
|
|
</ContextMenuBase>
|
|
</template>
|
|
|
|
<script lang="ts" setup>
|
|
import { useContextMenu } from '@/composables'
|
|
import { eventBus } from '@/utils'
|
|
import { EventName } from '@/config'
|
|
|
|
const { base, ContextMenuBase, open, trigger } = useContextMenu()
|
|
|
|
const emit = defineEmits(['itemClicked'])
|
|
|
|
const actionToEventMap: Record<string, EventName> = {
|
|
'new-playlist': 'MODAL_SHOW_CREATE_PLAYLIST_FORM',
|
|
'new-smart-playlist': 'MODAL_SHOW_CREATE_SMART_PLAYLIST_FORM',
|
|
'new-folder': 'MODAL_SHOW_CREATE_PLAYLIST_FOLDER_FORM'
|
|
}
|
|
|
|
const onItemClicked = (key: keyof typeof actionToEventMap) => trigger(() => eventBus.emit(actionToEventMap[key]))
|
|
|
|
defineExpose({ open })
|
|
</script>
|