<script setup lang="ts">
import { TemplateProvider, useTemplate } from 'vue-use-template'
// Support Ref, Reactive, Computed
const props = reactive({
title: 'Hello World!'
})
const { show, hide } = useTemplate({
component: defineAsyncComponent(() => import('./DialogConfirm.vue')),
props,
emits: {
onConfirm: () => {
alert('Confirm!')
hide()
},
onCancel: () => hide(),
},
slots: {
default: defineTemplate({
component: () => h('p', 'This is a dialog content.'),
}),
},
})
</script>
<template>
<TemplateProvider>
<div>App</div>
<!-- or -->
<RouterView />
<!-- or -->
<NuxtPage />
</TemplateProvider>
</template>
<script setup lang="ts">
defineProps<{
title: string
}>()
const emit = defineEmits<{
(e: 'confirm'): void
(e: 'cancel'): void
}>()
</script>
<template>
<dialog open>
<h1>{{ title }}</h1>
<slot />
<button @click="emit('confirm')">
Confirm
</button>
<button @click="emit('cancel')">
Cancel
</button>
</dialog>
</template>