Skip to content

Control Vue Component programmatically by using a useTemplate composable

Notifications You must be signed in to change notification settings

hunterliu1003/vue-use-template

Repository files navigation

vue-use-template

Playground

App.vue

<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>

DialogConfirm.vue

<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>