Files
flowbite-vue/src/components/Accordion/AccordionPanel.vue
2022-12-13 18:20:44 +04:00

35 lines
842 B
Vue

<template>
<div :data-panel-id="panelId" ref="panel">
<slot v-if="accordionId"></slot>
</div>
</template>
<script lang="ts" setup>
import { computed, onMounted, ref } from 'vue'
import { useAccordionState } from '@/components/Accordion/composables/useAccordionState'
import { nanoid } from 'nanoid'
const { accordionsStates } = useAccordionState()
const panelId = nanoid()
const panel = ref()
const accordionId = computed(() => {
if (panel.value) return panel.value.parentElement.dataset.accordionId
return null
})
const accordionState = computed(() => {
return accordionsStates[accordionId.value]
})
onMounted(() => {
const panelsCount = Object.keys(accordionState?.value?.panels)?.length
accordionState.value.panels[panelId] = {
id: panelId,
order: panelsCount,
isVisible: !panelsCount,
}
})
</script>