koel/resources/assets/js/components/artist/ArtistContextMenu.vue

54 lines
1.7 KiB
Vue
Raw Normal View History

2022-04-15 14:24:30 +00:00
<template>
2024-05-08 09:11:32 +00:00
<ContextMenu ref="base" data-testid="artist-context-menu" extra-class="artist-menu">
2022-04-15 14:24:30 +00:00
<template v-if="artist">
<li @click="play">Play All</li>
<li @click="shuffle">Shuffle All</li>
2022-04-15 14:24:30 +00:00
<template v-if="isStandardArtist">
2022-12-02 16:17:37 +00:00
<li class="separator" />
<li @click="viewArtistDetails">Go to Artist</li>
2022-04-15 14:24:30 +00:00
</template>
<template v-if="isStandardArtist && allowDownload">
2022-12-02 16:17:37 +00:00
<li class="separator" />
<li @click="download">Download</li>
2022-04-15 14:24:30 +00:00
</template>
</template>
2024-05-08 09:11:32 +00:00
</ContextMenu>
2022-04-15 14:24:30 +00:00
</template>
2022-04-15 17:00:08 +00:00
<script lang="ts" setup>
import { computed, ref, toRef } from 'vue'
2022-06-10 10:47:46 +00:00
import { artistStore, commonStore, songStore } from '@/stores'
2022-04-24 08:50:45 +00:00
import { downloadService, playbackService } from '@/services'
2022-11-18 18:44:20 +00:00
import { useContextMenu, useRouter } from '@/composables'
import { eventBus } from '@/utils'
2022-04-15 14:24:30 +00:00
2022-11-18 18:44:20 +00:00
const { go } = useRouter()
2024-05-08 09:11:32 +00:00
const { base, ContextMenu, open, trigger } = useContextMenu()
2022-04-15 14:24:30 +00:00
const artist = ref<Artist>()
2024-01-04 11:35:36 +00:00
const allowDownload = toRef(commonStore.state, 'allows_download')
2022-04-15 14:24:30 +00:00
2022-04-15 17:00:08 +00:00
const isStandardArtist = computed(() =>
!artistStore.isUnknown(artist.value!)
&& !artistStore.isVarious(artist.value!)
2022-04-15 17:00:08 +00:00
)
2022-04-15 14:24:30 +00:00
const play = () => trigger(async () => {
2022-10-21 20:06:43 +00:00
playbackService.queueAndPlay(await songStore.fetchForArtist(artist.value!))
2022-11-18 18:44:20 +00:00
go('queue')
})
2022-04-15 14:24:30 +00:00
const shuffle = () => trigger(async () => {
2022-10-21 20:06:43 +00:00
playbackService.queueAndPlay(await songStore.fetchForArtist(artist.value!), true)
2022-11-18 18:44:20 +00:00
go('queue')
})
2022-04-15 14:24:30 +00:00
2022-11-18 18:44:20 +00:00
const viewArtistDetails = () => trigger(() => go(`artist/${artist.value!.id}`))
const download = () => trigger(() => downloadService.fromArtist(artist.value!))
2022-04-15 14:24:30 +00:00
2024-01-24 22:39:47 +00:00
eventBus.on('ARTIST_CONTEXT_MENU_REQUESTED', async ({ pageX, pageY }, _artist) => {
artist.value = _artist
2024-01-24 22:39:47 +00:00
await open(pageY, pageX)
})
2022-04-15 14:24:30 +00:00
</script>