mirror of
https://github.com/koel/koel
synced 2025-01-09 19:28:44 +00:00
40 lines
1.1 KiB
Vue
40 lines
1.1 KiB
Vue
<template>
|
|
<a
|
|
:href="url"
|
|
class="flex gap-3 !text-k-text-secondary hover:!text-k-text-primary focus:!text-k-text-primary active:!text-k-text-primary"
|
|
data-testid="youtube-search-result"
|
|
role="button"
|
|
@click.prevent="play"
|
|
>
|
|
<img :alt="video.snippet.title" :src="video.snippet.thumbnails.default.url" class="self-start" width="90">
|
|
<aside class="space-y-1">
|
|
<h3 class="text-lg">{{ unescape(video.snippet.title) }}</h3>
|
|
<p class="text-[0.9rem]">{{ video.snippet.description }}</p>
|
|
</aside>
|
|
</a>
|
|
</template>
|
|
|
|
<script lang="ts" setup>
|
|
import { unescape } from 'lodash'
|
|
import { computed, toRefs } from 'vue'
|
|
import { youTubeService } from '@/services'
|
|
import { useRouter } from '@/composables'
|
|
|
|
const { go } = useRouter()
|
|
|
|
const props = defineProps<{ video: YouTubeVideo }>()
|
|
const { video } = toRefs(props)
|
|
|
|
const url = computed(() => `https://youtu.be/${video.value.id.videoId}`)
|
|
|
|
const play = () => {
|
|
youTubeService.play(video.value)
|
|
go('youtube')
|
|
}
|
|
</script>
|
|
|
|
<style lang="postcss" scoped>
|
|
aside {
|
|
overflow-wrap: anywhere;
|
|
}
|
|
</style>
|