wf4/app/components/Spoiler.vue
webfussel a86b89dc98 add: extract plain faq
Add Schema Org for FAQ
2025-06-11 08:54:32 +02:00

25 lines
No EOL
565 B
Vue

<template>
<details class="Spoiler" :open="open">
<summary @click="toggle"><Icon class="icon" :name="icon" mode="svg" />{{ title }}</summary>
<div>
<slot />
</div>
</details>
</template>
<script setup lang="ts">
type Props = {
title: string
answer ?: string
}
const { title, answer = '' } = defineProps<Props>()
const open = ref(false)
const toggle = (event : MouseEvent) => {
event.preventDefault()
open.value = !open.value
}
const icon = computed(() => open.value ? 'ph:minus-circle-duotone' : 'ph:plus-circle-duotone')
</script>