This commit is contained in:
53
app/components/organism/compilationList.vue
Normal file
53
app/components/organism/compilationList.vue
Normal file
@@ -0,0 +1,53 @@
|
||||
<template>
|
||||
<div class="flex flex-col-reverse mt-16">
|
||||
<molecule-box v-for="compilation in dataStore.getAllCompilations.slice().reverse()" :key="compilation.id"
|
||||
:compilation="compilation" :BoxState="boxStates[compilation.id]" @click="() => openCompilation(compilation.id)"
|
||||
:class="boxStates[compilation.id]" />
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup lang="ts">
|
||||
import { useDataStore } from '~/store/data'
|
||||
import type { BoxState } from '~~/types/types'
|
||||
import { useRouter } from 'vue-router'
|
||||
|
||||
const dataStore = useDataStore()
|
||||
const router = useRouter()
|
||||
const boxStates = ref<Record<string, BoxState>>({})
|
||||
|
||||
function openCompilation(id: string) {
|
||||
if (boxStates.value[id] === 'list') {
|
||||
for (const key in boxStates.value) {
|
||||
boxStates.value[key] = (key === id) ? 'selected' : 'hide'
|
||||
}
|
||||
window.history.pushState({}, '', '/compilation/' + id)
|
||||
}
|
||||
}
|
||||
|
||||
function closeCompilation(e: KeyboardEvent) {
|
||||
if (e.key === 'Escape') {
|
||||
for (const key in boxStates.value) {
|
||||
boxStates.value[key] = 'list'
|
||||
}
|
||||
}
|
||||
window.history.pushState({}, '', '/')
|
||||
}
|
||||
|
||||
|
||||
onMounted(async () => {
|
||||
const dataStore = await useDataStore()
|
||||
await dataStore.loadData()
|
||||
|
||||
dataStore.getAllCompilations.forEach(c => {
|
||||
if (!(c.id in boxStates.value)) boxStates.value[c.id] = 'hide'
|
||||
})
|
||||
|
||||
window.addEventListener('keydown', closeCompilation)
|
||||
|
||||
setTimeout(() => {
|
||||
dataStore.getAllCompilations.forEach(c => {
|
||||
boxStates.value[c.id] = 'list'
|
||||
})
|
||||
}, 333)
|
||||
})
|
||||
</script>
|
||||
Reference in New Issue
Block a user