131 lines
6.8 KiB
Vue
131 lines
6.8 KiB
Vue
<template>
|
|
<div class="deck">
|
|
<draggable
|
|
v-model="tracks"
|
|
item-key="id"
|
|
class="draggable-container"
|
|
@start="drag = true"
|
|
@end="onDragEnd"
|
|
>
|
|
<template #item="{ element: track }">
|
|
<card
|
|
:key="track.id"
|
|
:track="track"
|
|
tabindex="0"
|
|
:is-face-up="track.isFaceUp"
|
|
class="draggable-item"
|
|
@click="flipCard(track)"
|
|
/>
|
|
</template>
|
|
</draggable>
|
|
</div>
|
|
</template>
|
|
|
|
<script setup>
|
|
import { useDataStore } from '~/store/data'
|
|
import draggable from 'vuedraggable'
|
|
|
|
const drag = ref(false)
|
|
const tracks = ref([])
|
|
// Configuration du layout
|
|
definePageMeta({
|
|
layout: 'default'
|
|
})
|
|
|
|
onMounted(async () => {
|
|
const dataStore = useDataStore()
|
|
await dataStore.loadData()
|
|
tracks.value = dataStore.getTracksByboxId('ES2025')
|
|
})
|
|
|
|
function flipCard(track) {
|
|
track.isFaceUp = !track.isFaceUp
|
|
}
|
|
|
|
function onDragEnd() {
|
|
drag.value = false
|
|
// Ici vous pouvez ajouter une logique supplémentaire après le drop si nécessaire
|
|
}
|
|
</script>
|
|
|
|
<style lang="scss" scoped>
|
|
.logo {
|
|
filter: drop-shadow(3px 3px 0 rgb(0 0 0 / 0.7));
|
|
}
|
|
|
|
.deck {
|
|
position: relative;
|
|
height: 80vh;
|
|
|
|
.draggable-container {
|
|
display: flex;
|
|
flex-wrap: wrap;
|
|
gap: 1rem;
|
|
padding: 1rem;
|
|
min-height: 100%;
|
|
}
|
|
|
|
.draggable-item {
|
|
cursor: grab;
|
|
transition: transform 0.2s;
|
|
|
|
&:active {
|
|
cursor: grabbing;
|
|
}
|
|
|
|
&.sortable-ghost {
|
|
opacity: 0.5;
|
|
background: #c8ebfb;
|
|
border-radius: 1rem;
|
|
}
|
|
|
|
&.sortable-drag {
|
|
transform: rotate(2deg);
|
|
box-shadow: 0 10px 20px rgba(0, 0, 0, 0.2);
|
|
}
|
|
}
|
|
|
|
.card {
|
|
z-index: 10;
|
|
position: relative;
|
|
}
|
|
|
|
/* noise tools */
|
|
$size: 130px;
|
|
$scale: 1.05;
|
|
$border-radius: calc($size / 2);
|
|
$grad-position: 100% 0;
|
|
$grad-start: 25%;
|
|
$grad-stop: 65%;
|
|
$duration: 3.5s;
|
|
$noise: url('');
|
|
|
|
@mixin dithered-gradient($position, $start, $stop, $color) {
|
|
background: radial-gradient(circle at $position, transparent $start, $color $stop);
|
|
mask: $noise, radial-gradient(circle at $position, transparent $start, #000 ($stop + 10%));
|
|
}
|
|
|
|
&::before,
|
|
&::after {
|
|
content: '';
|
|
position: absolute;
|
|
top: 0;
|
|
left: 0;
|
|
z-index: 0;
|
|
display: block;
|
|
width: 100%;
|
|
height: 100%;
|
|
}
|
|
|
|
&::before {
|
|
@include dithered-gradient(50%, 30%, 60%, #6cc8ff);
|
|
}
|
|
|
|
&::after {
|
|
mask-image:
|
|
$noise, linear-gradient(45deg, #000 0%, transparent 25%, transparent 75%, #000 100%);
|
|
background: linear-gradient(45deg, #6d6dff 10%, transparent 25%, transparent 75%, #6af789 90%);
|
|
}
|
|
}
|
|
</style>
|