12345678910111213141516171819202122232425262728293031323334353637 |
- // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- import { computed, shallowRef } from 'vue'
- import type { CommonPopoverInstance } from './types.ts'
- import type { ShallowRef, Ref } from 'vue'
- export const usePopover = (
- popoverRef?: Ref<CommonPopoverInstance | undefined>,
- ) => {
- const popover: ShallowRef<CommonPopoverInstance | undefined> =
- popoverRef || shallowRef()
- const popoverTarget: ShallowRef<HTMLDivElement | undefined> = shallowRef()
- const isOpen = computed(() => popover.value?.isOpen)
- const open = () => {
- popover.value?.openPopover()
- }
- const close = () => {
- popover.value?.closePopover()
- }
- const toggle = (isInteractive = false) => {
- popover.value?.togglePopover(isInteractive)
- }
- return {
- popover,
- popoverTarget,
- open,
- close,
- toggle,
- isOpen,
- }
- }
|