mirror of
https://github.com/ArthurDanjou/ui.git
synced 2026-01-14 20:19:34 +01:00
27 lines
715 B
TypeScript
27 lines
715 B
TypeScript
import { ref, onMounted, watchEffect } from 'vue'
|
|
import { createPopper } from '@popperjs/core'
|
|
|
|
export function usePopper (options: object) {
|
|
const reference = ref(null)
|
|
const popper = ref(null)
|
|
|
|
onMounted(() => {
|
|
watchEffect((onInvalidate) => {
|
|
if (!popper.value) { return }
|
|
if (!reference.value) { return }
|
|
|
|
const popperEl = popper.value.el || popper.value
|
|
const referenceEl = reference.value.el || reference.value
|
|
|
|
if (!(referenceEl instanceof HTMLElement)) { return }
|
|
if (!(popperEl instanceof HTMLElement)) { return }
|
|
|
|
const { destroy } = createPopper(referenceEl, popperEl, options)
|
|
|
|
onInvalidate(destroy)
|
|
})
|
|
})
|
|
|
|
return [reference, popper]
|
|
}
|