Files
flowbite-vue/src/components/Accordion/AccordionPanel.vue
2022-12-11 02:08:39 +04:00

32 lines
760 B
Vue

<template>
<div>
<slot name="header"/>
<slot name="content"/>
</div>
</template>
<script lang="ts" setup>
import { computed, inject, onBeforeMount, provide } from 'vue'
import { useAccordionState } from '@/components/Accordion/composables/useAccordionState'
import { nanoid } from 'nanoid'
const { accordionsStates } = useAccordionState()
const panelId = nanoid()
const accordionId: any = inject('accordionId')
provide('panelId', panelId)
const accordionState = computed(() => {
return accordionsStates[accordionId]
})
onBeforeMount(() => {
const panelsCount = Object.keys(accordionState.value.panels).length
accordionState.value.panels[panelId] = {
id: panelId,
order: panelsCount,
isVisible: !panelsCount,
}
})
</script>