koel/resources/assets/js/components/ui/album-artist/AlbumOrArtistCard.vue

94 lines
2.2 KiB
Vue
Raw Normal View History

<template>
<article
:class="layout"
2024-05-19 05:49:42 +00:00
class="relative group flex max-w-full md:max-w-[256px] border p-5 rounded-lg flex-col gap-5 transition border-color duration-200"
2024-04-23 21:01:27 +00:00
data-testid="artist-album-card"
draggable="true"
tabindex="0"
@dblclick="onDblClick"
@dragstart="onDragStart"
@contextmenu.prevent="onContextMenu"
>
2024-05-19 05:49:42 +00:00
<slot name="thumbnail">
<Thumbnail v-if="!isPodcast" :entity="entity" />
2024-05-19 05:49:42 +00:00
</slot>
2024-04-04 22:20:42 +00:00
<footer class="flex flex-1 flex-col gap-1.5 overflow-hidden">
<div class="name flex flex-col gap-2 whitespace-nowrap">
2022-12-02 16:17:37 +00:00
<slot name="name" />
</div>
2024-04-04 22:20:42 +00:00
<p class="meta text-[0.9rem] flex gap-1.5 opacity-70 hover:opacity-100">
2022-12-02 16:17:37 +00:00
<slot name="meta" />
</p>
</footer>
</article>
</template>
<script lang="ts" setup>
2024-04-29 19:50:03 +00:00
import Thumbnail from '@/components/ui/album-artist/AlbumOrArtistThumbnail.vue'
2024-05-19 05:49:42 +00:00
import { computed, toRefs } from 'vue'
2024-04-04 22:20:42 +00:00
2024-05-19 05:49:42 +00:00
const props = withDefaults(defineProps<{ layout?: ArtistAlbumCardLayout, entity: Artist | Album | Podcast }>(), {
layout: 'full',
2024-04-04 22:20:42 +00:00
})
const emit = defineEmits<{
(e: 'dblclick'): void
(e: 'dragstart', event: DragEvent): void
(e: 'contextmenu', event: MouseEvent): void
}>()
const isPodcast = computed(() => props.entity.type === 'podcasts')
const { layout } = toRefs(props)
const onDblClick = () => emit('dblclick')
const onDragStart = (e: DragEvent) => emit('dragstart', e)
const onContextMenu = (e: MouseEvent) => emit('contextmenu', e)
</script>
2024-04-04 20:13:35 +00:00
<style lang="postcss" scoped>
2024-04-04 22:20:42 +00:00
article {
@apply bg-k-bg-secondary border border-k-border hover:border-white/15;
2024-05-19 05:49:42 +00:00
&.full {
:deep(.play-icon) {
@apply scale-[3];
}
}
.name {
2022-10-27 17:06:49 +00:00
&:deep(a) {
2024-04-04 22:20:42 +00:00
@apply overflow-hidden text-ellipsis text-k-text-primary;
2022-10-27 17:06:49 +00:00
2024-05-19 05:49:42 +00:00
&:is(:hover, :active, :focus) {
@apply text-k-accent;
}
2022-10-27 17:06:49 +00:00
}
}
&:focus,
&:focus-within {
2024-04-04 22:20:42 +00:00
@apply ring-1 ring-k-accent;
}
&.compact {
2024-04-04 22:20:42 +00:00
@apply flex-row gap-4 max-w-full p-3 rounded-md items-center;
2024-04-29 19:50:03 +00:00
.thumbnail {
2024-04-04 22:20:42 +00:00
@apply w-[80px] rounded-md;
}
}
.meta {
2022-10-27 17:06:49 +00:00
:deep(a) {
& + a {
&::before {
2024-04-04 22:20:42 +00:00
@apply mr-0.5 content-['•'] text-k-text-secondary;
}
}
}
}
}
</style>