@dialpad/dialtone
Version:
Dialpad's Dialtone design system monorepo
1 lines • 42.9 kB
Source Map (JSON)
{"version":3,"file":"popover.cjs","names":[],"sources":["../../../components/popover/popover.vue"],"sourcesContent":["<!-- eslint-disable vuejs-accessibility/mouse-events-have-key-events -->\n<template>\n <div>\n <Teleport\n v-if=\"modal && isOpen\"\n to=\"body\"\n >\n <div\n class=\"d-modal--transparent\"\n aria-hidden=\"false\"\n @click.prevent.stop\n />\n </Teleport>\n <component\n :is=\"elementType\"\n ref=\"popover\"\n :class=\"['d-popover', { 'd-popover__anchor--opened': isOpen }]\"\n data-qa=\"dt-popover-container\"\n >\n <!-- eslint-disable-next-line vuejs-accessibility/no-static-element-interactions -->\n <div\n :id=\"!ariaLabelledby && labelledBy\"\n ref=\"anchor\"\n :data-qa=\"$attrs['data-qa'] ? `${$attrs['data-qa']}-anchor` : 'dt-popover-anchor'\"\n :tabindex=\"openOnContext ? 0 : undefined\"\n @click.capture=\"defaultToggleOpen\"\n @contextmenu=\"onContext\"\n @keydown.up.prevent=\"onArrowKeyPress\"\n @keydown.down.prevent=\"onArrowKeyPress\"\n @keydown.escape.capture=\"closePopover\"\n @keydown.enter=\"$emit('keydown', $event)\"\n @keydown.space=\"$emit('keydown', $event)\"\n @mouseenter=\"onMouseEnter\"\n @mouseleave=\"onMouseLeave\"\n >\n <!-- @slot Anchor element that activates the popover. Usually a button. -->\n <slot\n name=\"anchor\"\n :attrs=\"{\n 'aria-expanded': isOpen.toString(),\n 'aria-controls': id,\n 'aria-haspopup': role,\n }\"\n />\n </div>\n <dt-lazy-show\n :id=\"id\"\n ref=\"content\"\n :role=\"role\"\n :data-qa=\"$attrs['data-qa'] ? `${$attrs['data-qa']}__dialog` : 'dt-popover'\"\n :aria-hidden=\"`${!isOpen}`\"\n :aria-labelledby=\"labelledBy\"\n :aria-label=\"ariaLabel\"\n :aria-modal=\"`${!modal}`\"\n :transition=\"transition\"\n :show=\"isOpen\"\n :appear=\"toAppear\"\n :class=\"['d-popover__dialog', { 'd-popover__dialog--modal': modal }, dialogClass]\"\n :style=\"{\n 'max-height': calculatedMaxHeight,\n 'max-width': maxWidth,\n }\"\n :css=\"$attrs.css\"\n :tabindex=\"contentTabindex\"\n v-on=\"popoverListeners\"\n @mouseenter=\"onMouseEnterAnchor\"\n @mouseleave=\"onMouseLeaveAnchor\"\n >\n <popover-header-footer\n v-if=\"hasSlotContent($slots.headerContent) || showCloseButton\"\n ref=\"popover__header\"\n :class=\"POPOVER_HEADER_FOOTER_PADDING_CLASSES[padding]\"\n :content-class=\"headerClass\"\n type=\"header\"\n :show-close-button=\"showCloseButton\"\n @close=\"closePopover\"\n >\n <template #content>\n <!-- @slot Slot for popover header content -->\n <slot\n name=\"headerContent\"\n :close=\"closePopover\"\n />\n </template>\n </popover-header-footer>\n <div\n ref=\"popover__content\"\n :data-qa=\"$attrs['data-qa'] ? `${$attrs['data-qa']}-content` : 'dt-popover-content'\"\n :class=\"[\n 'd-popover__content',\n POPOVER_PADDING_CLASSES[padding],\n contentClass,\n ]\"\n >\n <!-- @slot Slot for the content that is displayed in the popover when it is open. -->\n <slot\n name=\"content\"\n :close=\"closePopover\"\n />\n </div>\n <popover-header-footer\n v-if=\"hasSlotContent($slots.footerContent)\"\n ref=\"popover__footer\"\n type=\"footer\"\n :class=\"POPOVER_HEADER_FOOTER_PADDING_CLASSES[padding]\"\n :content-class=\"footerClass\"\n >\n <template #content>\n <!-- @slot Slot for the footer content. -->\n <slot\n name=\"footerContent\"\n :close=\"closePopover\"\n />\n </template>\n </popover-header-footer>\n <sr-only-close-button\n v-if=\"!showCloseButton\"\n @close=\"closePopover\"\n />\n </dt-lazy-show>\n </component>\n </div>\n</template>\n\n<script>\n/* eslint-disable max-lines */\nimport {\n POPOVER_APPEND_TO_VALUES,\n POPOVER_CONTENT_WIDTHS,\n POPOVER_HEADER_FOOTER_PADDING_CLASSES,\n POPOVER_INITIAL_FOCUS_STRINGS,\n POPOVER_PADDING_CLASSES,\n POPOVER_ROLES,\n POPOVER_STICKY_VALUES,\n} from './popover_constants';\nimport { getUniqueString, hasSlotContent, isOutOfViewPort, warnIfUnmounted, disableRootScrolling, enableRootScrolling, returnFirstEl } from '@/common/utils';\nimport { DtLazyShow } from '@/components/lazy_show';\nimport ModalMixin from '@/common/mixins/modal';\nimport { createTippyPopover, getPopperOptions } from './tippy_utils';\nimport PopoverHeaderFooter from './popover_header_footer.vue';\nimport SrOnlyCloseButton from '@/common/sr_only_close_button.vue';\n\n/**\n * A Popover displays a content overlay when its anchor element is activated.\n * @see https://dialtone.dialpad.com/components/popover.html\n */\nexport default {\n compatConfig: { MODE: 3 },\n name: 'DtPopover',\n\n /********************\n * CHILD COMPONENTS *\n ********************/\n components: {\n SrOnlyCloseButton,\n DtLazyShow,\n PopoverHeaderFooter,\n },\n\n mixins: [ModalMixin],\n\n props: {\n /**\n * Controls whether the popover is shown. Leaving this null will have the popover trigger on click by default.\n * If you set this value, the default trigger behavior will be disabled, and you can control it as you need.\n * Supports v-model\n * @values null, true, false\n */\n open: {\n type: Boolean,\n default: null,\n },\n\n /**\n * Opens the popover on right click (context menu). If you set this value to `true`,\n * the default trigger behavior will be disabled.\n * @values true, false\n */\n openOnContext: {\n type: Boolean,\n default: false,\n },\n\n /**\n * Element type (tag name) of the root element of the component.\n */\n elementType: {\n type: String,\n default: 'div',\n },\n\n /**\n * Named transition when the content display is toggled.\n * @see DtLazyShow\n */\n transition: {\n type: String,\n default: 'fade',\n },\n\n /**\n * ARIA role for the content of the popover. Defaults to \"dialog\".\n * <a class=\"d-link\" href=\"https://www.w3.org/TR/wai-aria/#aria-haspopup\" target=\"_blank\">aria-haspopup</a>\n */\n role: {\n type: String,\n default: 'dialog',\n validator: (role) => {\n return POPOVER_ROLES.includes(role);\n },\n },\n\n /**\n * ID of the element that serves as the label for the popover content.\n * Defaults to the \"anchor\" element; this exists to provide a different\n * ID of the label element if, for example, the anchor slot contains\n * other items that do not serve as a label. You should provide this\n * or ariaLabel, but not both.\n */\n ariaLabelledby: {\n type: String,\n default: null,\n },\n\n /**\n * Descriptive label for the popover content. You should provide this\n * or ariaLabelledby, but not both.\n */\n ariaLabel: {\n type: String,\n default: null,\n },\n\n /**\n * Padding size class for the popover content.\n * @values none, small, medium, large\n */\n padding: {\n type: String,\n default: 'large',\n validator: (padding) => {\n return Object.keys(POPOVER_PADDING_CLASSES).some((item) => item === padding);\n },\n },\n\n /**\n * Additional class name for the content wrapper element.\n */\n contentClass: {\n type: [String, Array, Object],\n default: '',\n },\n\n /**\n * Width configuration for the popover content. When its value is 'anchor',\n * the popover content will have the same width as the anchor.\n * @values null, anchor\n */\n contentWidth: {\n type: String,\n default: '',\n validator: contentWidth => POPOVER_CONTENT_WIDTHS.includes(contentWidth),\n },\n\n /**\n * Whether to apply transition on initial render in the content lazy show component.\n */\n contentAppear: {\n type: Boolean,\n default: null,\n },\n\n /**\n * Tabindex value for the content. Passing null, no tabindex attribute will be set.\n */\n contentTabindex: {\n type: Number || null,\n default: -1,\n },\n\n /**\n * External anchor id to use in those cases the anchor can't be provided via the slot.\n * For instance, using the combobox's input as the anchor for the popover.\n * @deprecated Use externalAnchorElement instead for Shadow DOM compatibility.\n */\n externalAnchor: {\n type: String,\n default: '',\n },\n\n /**\n * External anchor element reference. Use this instead of externalAnchor when\n * the anchor may be inside a Shadow DOM, as querySelector cannot pierce shadow boundaries.\n */\n externalAnchorElement: {\n type: HTMLElement,\n default: null,\n },\n\n /**\n * The id of the tooltip\n */\n id: {\n type: String,\n default () { return getUniqueString(); },\n },\n\n /**\n * Displaces the content box from its anchor element\n * by the specified number of pixels.\n * <a\n * class=\"d-link\"\n * href=\"https://atomiks.github.io/tippyjs/v6/all-props/#offset\"\n * target=\"_blank\"\n * >\n * Tippy.js docs\n * </a>\n */\n offset: {\n type: Array,\n default: () => [0, 4],\n },\n\n /**\n * Determines if the popover hides upon clicking the\n * anchor or outside the content box.\n * @values true, false\n */\n hideOnClick: {\n type: Boolean,\n default: true,\n },\n\n /**\n * Determines modal state. If enabled popover has a modal overlay\n * preventing interaction with elements below it, but it is invisible.\n * @values true, false\n */\n modal: {\n type: Boolean,\n default: true,\n },\n\n /**\n * If the popover does not fit in the direction described by \"placement\",\n * it will attempt to change its direction to the \"fallbackPlacements\".\n * <a\n * class=\"d-link\"\n * href=\"https://popper.js.org/docs/v2/modifiers/flip/#fallbackplacements\"\n * target=\"_blank\"\n * >\n * Popper.js docs\n * </a>\n * */\n fallbackPlacements: {\n type: Array,\n default: () => {\n return ['auto'];\n },\n },\n\n /**\n * The direction the popover displays relative to the anchor.\n * <a\n * class=\"d-link\"\n * href=\"https://atomiks.github.io/tippyjs/v6/all-props/#placement\"\n * target=\"_blank\"\n * >\n * Tippy.js docs\n * </a>\n * @values top, top-start, top-end,\n * right, right-start, right-end,\n * left, left-start, left-end,\n * bottom, bottom-start, bottom-end,\n * auto, auto-start, auto-end\n */\n placement: {\n type: String,\n default: 'bottom-end',\n },\n\n /**\n * If set to false the dialog will display over top of the anchor when there is insufficient space.\n * If set to true it will never move from its position relative to the anchor and will clip instead.\n * <a\n * class=\"d-link\"\n * href=\"https://popper.js.org/docs/v2/modifiers/prevent-overflow/#tether\"\n * target=\"_blank\"\n * >\n * Popper.js docs\n * </a>\n * @values true, false\n */\n tether: {\n type: Boolean,\n default: true,\n },\n\n /**\n * If the popover sticks to the anchor. This is usually not needed, but can be needed\n * if the reference element's position is animating, or to automatically update the popover\n * position in those cases the DOM layout changes the reference element's position.\n * `true` enables it, `reference` only checks the \"reference\" rect for changes and `popper` only\n * checks the \"popper\" rect for changes.\n * <a\n * class=\"d-link\"\n * href=\"https://atomiks.github.io/tippyjs/v6/all-props/#sticky\"\n * target=\"_blank\"\n * >\n * Tippy.js docs\n * </a>\n * @values true, false, reference, popper\n */\n sticky: {\n type: [Boolean, String],\n default: false,\n validator: (sticky) => {\n return POPOVER_STICKY_VALUES.includes(sticky);\n },\n },\n\n /**\n * Determines maximum height for the popover before overflow.\n * Possible units rem|px|em\n */\n maxHeight: {\n type: String,\n default: '',\n },\n\n /**\n * Determines maximum width for the popover before overflow.\n * Possible units rem|px|%|em\n */\n maxWidth: {\n type: String,\n default: '',\n },\n\n /**\n * Determines visibility for close button\n * @values true, false\n */\n showCloseButton: {\n type: Boolean,\n default: false,\n },\n\n /**\n * Additional class name for the header content wrapper element.\n */\n headerClass: {\n type: [String, Array, Object],\n default: '',\n },\n\n /**\n * Additional class name for the footer content wrapper element.\n */\n footerClass: {\n type: [String, Array, Object],\n default: '',\n },\n\n /**\n * Additional class name for the dialog element.\n */\n dialogClass: {\n type: [String, Array, Object],\n default: '',\n },\n\n /**\n * The element that is focused when the popover is opened. This can be an\n * HTMLElement within the popover, a string starting with '#' which will\n * find the element by ID. 'first' which will automatically focus\n * the first element, or 'dialog' which will focus the dialog window itself.\n * If the dialog is modal this prop cannot be 'none'.\n * @values none, dialog, first\n */\n initialFocusElement: {\n type: [String, HTMLElement],\n default: 'first',\n validator: initialFocusElement => {\n return POPOVER_INITIAL_FOCUS_STRINGS.includes(initialFocusElement) ||\n (initialFocusElement instanceof HTMLElement) ||\n initialFocusElement.startsWith('#');\n },\n },\n\n /**\n * If the popover should open pressing up or down arrow key on the anchor element.\n * This can be set when not passing open prop.\n * @values true, false\n */\n openWithArrowKeys: {\n type: Boolean,\n default: false,\n },\n\n /**\n * Sets the element to which the popover is going to append to.\n * 'body' will append to the nearest body (supports shadow DOM).\n * 'root' will try append to the iFrame's parent body if it is contained in an iFrame\n * and has permissions to access it, else, it'd default to 'parent'.\n * @values 'body', 'parent', 'root', HTMLElement\n */\n appendTo: {\n type: [HTMLElement, String],\n default: 'body',\n validator: appendTo => {\n return POPOVER_APPEND_TO_VALUES.includes(appendTo) ||\n (appendTo instanceof HTMLElement);\n },\n },\n },\n\n emits: [\n /**\n * Native keydown event\n *\n * @event keydown\n * @type {KeyboardEvent}\n */\n 'keydown',\n\n /**\n * Event fired to sync the open prop with the parent component\n * @event update:open\n */\n 'update:open',\n\n /**\n * Emitted when popover is shown or hidden\n *\n * @event opened\n * @type {Boolean | Array}\n */\n 'opened',\n\n /**\n * Emitted when the mouse enters the popover\n *\n * @event mouseenter-popover\n */\n 'mouseenter-popover',\n\n /**\n * Emitted when the mouse leaves the popover\n *\n * @event mouseleave-popover\n */\n 'mouseleave-popover',\n\n /**\n * Emitted when the mouse enters the popover anchor\n *\n * @event mouseenter-popover-anchor\n */\n 'mouseenter-popover-anchor',\n\n /**\n * Emitted when the mouse leaves the popover anchor\n *\n * @event mouseleave-popover-anchor\n */\n 'mouseleave-popover-anchor',\n ],\n\n data () {\n return {\n POPOVER_PADDING_CLASSES,\n POPOVER_HEADER_FOOTER_PADDING_CLASSES,\n intersectionObserver: null,\n mutationObserver: null,\n isOutsideViewport: false,\n isOpen: false,\n toAppear: false,\n anchorEl: null,\n popoverContentEl: null,\n hasSlotContent,\n };\n },\n\n computed: {\n popoverListeners () {\n return {\n keydown: event => {\n this.onKeydown(event);\n },\n\n 'after-leave': () => {\n this.onLeaveTransitionComplete();\n },\n\n 'after-enter': () => {\n this.onEnterTransitionComplete();\n },\n };\n },\n\n calculatedMaxHeight () {\n if (this.isOutsideViewport && this.modal) {\n return `calc(100vh - var(--dt-space-300))`;\n }\n return this.maxHeight;\n },\n\n labelledBy () {\n // aria-labelledby should be set only if aria-labelledby is passed as a prop, or if\n // there is no aria-label and the labelledby should point to the anchor.\n return this.ariaLabelledby || (!this.ariaLabel && getUniqueString('DtPopover__anchor'));\n },\n },\n\n watch: {\n $props: {\n immediate: true,\n deep: true,\n handler () {\n this.validateProps();\n },\n },\n\n modal (modal) {\n this.tip?.setProps({\n zIndex: modal ? 650 : this.calculateAnchorZindex(),\n });\n },\n\n offset (offset) {\n this.tip?.setProps({\n offset,\n });\n },\n\n sticky (sticky) {\n this.tip?.setProps({\n sticky,\n });\n },\n\n fallbackPlacements () {\n this.tip?.setProps({\n popperOptions: this.popperOptions(),\n });\n },\n\n tether () {\n this.tip?.setProps({\n popperOptions: this.popperOptions(),\n });\n },\n\n externalAnchorElement () {\n this.updateAnchorEl();\n },\n\n placement (placement) {\n this.tip?.setProps({\n placement,\n });\n },\n\n open: {\n handler: function (open) {\n if (open !== null) {\n this.isOpen = open;\n }\n if (open === true) {\n this.toAppear = true;\n }\n },\n\n immediate: true,\n },\n\n contentAppear: {\n handler: function (contentAppear) {\n if (contentAppear !== null) {\n this.toAppear = contentAppear;\n }\n },\n },\n\n isOpen (isOpen, isPrev) {\n if (isOpen) {\n this.initTippyInstance();\n this.tip?.show();\n } else if (!isOpen && isPrev !== isOpen) {\n this.removeEventListeners();\n this.tip?.hide();\n }\n },\n },\n\n mounted () {\n warnIfUnmounted(returnFirstEl(this.$el), this.$options.name);\n\n this.popoverContentEl = returnFirstEl(this.$refs.content?.$el);\n this.updateAnchorEl();\n\n this.mutationObserver = new MutationObserver(this.updateAnchorEl);\n this.mutationObserver.observe(this.$refs.anchor, {childList: true});\n\n // rootMargin here must be greater than the margin of the height we are setting in calculatedMaxHeight which\n // currently is var(--dt-space-300) (4px). If not the intersectionObserver will continually trigger in an infinite\n // loop.\n // threshold 1.0 makes this trigger every time the dialog \"touches\" the edge of the viewport.\n this.intersectionObserver = new IntersectionObserver(this.hasIntersectedViewport);\n this.intersectionObserver.observe(this.popoverContentEl);\n },\n\n beforeUnmount () {\n this._isUnmounting = true;\n // Cancel any in-progress CSS transitions so transitionend cannot fire\n // after this component is torn down and call into dead lifecycle methods.\n if (this.popoverContentEl) {\n this.popoverContentEl.style.transition = 'none';\n }\n this.tip?.destroy();\n this.intersectionObserver?.disconnect();\n this.mutationObserver?.disconnect();\n this.removeReferences();\n this.removeEventListeners();\n },\n\n /******************\n * METHODS *\n ******************/\n methods: {\n\n hasIntersectedViewport (entries) {\n const dialog = entries?.[0]?.target;\n if (!dialog) return;\n const isOut = isOutOfViewPort(dialog);\n this.isOutsideViewport = isOut.bottom || isOut.top;\n },\n\n updateAnchorEl () {\n const externalAnchorEl = this.externalAnchorElement ||\n (this.externalAnchor\n ? this.$refs.anchor.getRootNode().querySelector(`#${this.externalAnchor}`)\n : null);\n const anchorEl = externalAnchorEl ?? this.$refs.anchor.children[0];\n if (anchorEl === this.anchorEl) {\n return;\n }\n this.anchorEl = anchorEl;\n\n this.tip?.destroy();\n delete this.tip;\n\n if (!this.anchorEl) {\n console.warn('No anchor found for popover');\n return;\n }\n\n if (this.isOpen) {\n this.initTippyInstance();\n this.tip?.show();\n }\n },\n\n popperOptions () {\n return getPopperOptions({\n fallbackPlacements: this.fallbackPlacements,\n tether: this.tether,\n hasHideModifierEnabled: true,\n });\n },\n\n validateProps () {\n if (this.modal && this.initialFocusElement === 'none') {\n console.error('If the popover is modal you must set the ' +\n 'initialFocusElement prop. Possible values: \"dialog\", \"first\", HTMLElement');\n }\n },\n\n calculateAnchorZindex () {\n // if a modal is currently active render at modal-element z-index, otherwise at popover z-index\n if (returnFirstEl(this.$el).getRootNode()\n .querySelector('.d-modal[aria-hidden=\"false\"], .d-modal--transparent[aria-hidden=\"false\"]') ||\n // Special case because we don't have any dialtone drawer component yet. Render at 650 when\n // anchor of popover is within a drawer.\n this.anchorEl?.closest('.d-zi-drawer')) {\n return 650;\n } else {\n return 300;\n }\n },\n\n defaultToggleOpen (e) {\n if (this.openOnContext) { return; }\n\n // Only use default toggle behaviour if the user has not set the open prop.\n // Check that the anchor element specifically was clicked.\n if (this.open === null || this.open === undefined) {\n if ((!this.anchorEl?.contains(e.target) && !this.anchorEl?.isEqualNode(e.target)) || this.anchorEl?.disabled) {\n return;\n }\n\n this.toggleOpen();\n }\n },\n\n async onContext (event) {\n if (!this.openOnContext) { return; }\n\n event.preventDefault();\n\n this.isOpen = true;\n await this.$nextTick();\n this.tip?.setProps({\n placement: 'right-start',\n getReferenceClientRect: () => ({\n width: 0,\n height: 0,\n top: event.clientY,\n bottom: event.clientY,\n left: event.clientX,\n right: event.clientX,\n }),\n });\n },\n\n toggleOpen () {\n this.isOpen = !this.isOpen;\n },\n\n onArrowKeyPress (e) {\n if (this.open !== null) { return; }\n if (this.openWithArrowKeys && this.anchorEl?.contains(e.target)) {\n if (!this.isOpen) {\n this.isOpen = true;\n }\n }\n\n this.$emit('keydown', e);\n },\n\n addEventListeners () {\n window.addEventListener('dt-popover-close', this.closePopover);\n // align popover content width when contentWidth is 'anchor'\n if (this.contentWidth === 'anchor') {\n window.addEventListener('resize', this.onResize);\n }\n },\n\n removeEventListeners () {\n window.removeEventListener('dt-popover-close', this.closePopover);\n if (this.contentWidth === 'anchor') {\n window.removeEventListener('resize', this.onResize);\n }\n },\n\n closePopover () {\n this.isOpen = false;\n },\n\n /*\n * Prevents scrolling outside of the currently opened modal popover by:\n * - when anchor is not within another popover: setting the body to overflow: hidden\n * - when anchor is within another popover: set the popover dialog container to it's non-modal z-index\n * since it is no longer the active modal. This puts it underneath the overlay and prevents scrolling.\n **/\n preventScrolling () {\n if (this.modal) {\n const element = this.anchorEl?.closest('body, .tippy-box');\n if (!element) return;\n if (element.tagName?.toLowerCase() === 'body') {\n disableRootScrolling(this.anchorEl.getRootNode().host);\n this.tip?.setProps({ offset: this.offset });\n } else {\n element.classList.add('d-zi-popover');\n }\n }\n },\n\n /*\n * Resets the prevent scrolling properties set in preventScrolling() back to normal.\n **/\n enableScrolling () {\n const element = this.anchorEl?.closest('body, .tippy-box');\n if (!element) return;\n if (element.tagName?.toLowerCase() === 'body') {\n enableRootScrolling(this.anchorEl.getRootNode().host);\n this.tip?.setProps({ offset: this.offset });\n } else {\n element.classList.remove('d-zi-popover');\n }\n },\n\n removeReferences () {\n this.anchorEl = null;\n this.popoverContentEl = null;\n this.tip = null;\n },\n\n async onShow () {\n if (this.contentWidth === 'anchor') {\n await this.setPopoverContentAnchorWidth();\n }\n\n if (this.contentWidth === null) {\n this.popoverContentEl.style.width = 'auto';\n }\n\n this.addEventListeners();\n },\n\n async onLeaveTransitionComplete () {\n if (this._isUnmounting) return;\n if (this.modal) {\n await this.focusFirstElement(this.$refs.anchor);\n if (this._isUnmounting) return;\n // await next tick in case the user wants to change focus themselves.\n await this.$nextTick();\n if (this._isUnmounting) return;\n this.enableScrolling();\n }\n if (this._isUnmounting) return;\n this.tip?.unmount();\n this.$emit('opened', false);\n if (this.open !== null) {\n this.$emit('update:open', false);\n }\n },\n\n async onEnterTransitionComplete () {\n if (this._isUnmounting) return;\n this.focusInitialElement();\n // await next tick in case the user wants to change focus themselves.\n await this.$nextTick();\n if (this._isUnmounting) return;\n this.preventScrolling();\n this.$emit('opened', true, this.$refs.popover__content);\n if (this.open !== null) {\n this.$emit('update:open', true);\n }\n },\n\n focusInitialElement () {\n if (this.initialFocusElement === 'dialog') {\n returnFirstEl(this.$refs.content?.$el)?.focus();\n }\n // find by ID\n if (this.initialFocusElement.startsWith('#')) {\n this.focusInitialElementById();\n }\n if (this.initialFocusElement === 'first') {\n this.focusFirstElementIfNeeded(this.$refs.popover__content);\n }\n if (this.initialFocusElement instanceof HTMLElement) {\n this.initialFocusElement.focus();\n }\n },\n\n focusInitialElementById () {\n const result = returnFirstEl(this.$refs.content?.$el)?.querySelector(this.initialFocusElement);\n if (result) {\n result.focus();\n } else {\n console.warn('Could not find the element specified in dt-popover prop \"initialFocusElement\". ' +\n 'Defaulting to focusing the dialog.');\n returnFirstEl(this.$refs.content?.$el)?.focus();\n }\n },\n\n onResize () {\n this.closePopover();\n },\n\n onClickOutside () {\n if (!this.hideOnClick) return;\n // If a popover is opened inside of this one, do not hide on click out\n const innerModals = this.popoverContentEl?.querySelector('.d-popover__anchor--opened');\n if (!innerModals) {\n this.closePopover();\n }\n },\n\n onKeydown (e) {\n if (e.key === 'Tab') {\n if (this.modal) {\n this.focusTrappedTabPress(e, this.popoverContentEl);\n }\n }\n if (e.key === 'Escape') {\n this.closePopover();\n }\n\n this.$emit('keydown', e);\n },\n\n async setPopoverContentAnchorWidth () {\n await this.$nextTick();\n this.popoverContentEl.style.width = `${this.anchorEl?.clientWidth}px`;\n },\n\n focusFirstElementIfNeeded (domEl) {\n const focusableElements = this._getFocusableElements(domEl, true);\n if (focusableElements.length !== 0) {\n this.focusFirstElement(domEl);\n } else if (this.showCloseButton) {\n this.$refs.popover__header?.focusCloseButton();\n } else {\n // if there are no focusable elements at all focus the dialog itself\n returnFirstEl(this.$refs.content?.$el).focus();\n }\n },\n\n /**\n * Return's the anchor ClientRect object relative to the window.\n * Refer to: https://atomiks.github.io/tippyjs/v6/all-props/#getreferenceclientrect for more information\n * @param error\n */\n getReferenceClientRect (error) {\n const anchorReferenceRect = this.anchorEl?.getBoundingClientRect();\n\n if (this.appendTo !== 'root' || error) return anchorReferenceRect;\n\n const anchorOwnerDocument = this.anchorEl?.ownerDocument;\n const anchorParentWindow = anchorOwnerDocument?.defaultView || anchorOwnerDocument?.parentWindow;\n const anchorIframe = anchorParentWindow?.frameElement;\n\n if (!anchorIframe) return anchorReferenceRect;\n\n const iframeReferenceRect = anchorIframe.getBoundingClientRect();\n\n return {\n width: anchorReferenceRect?.width,\n height: anchorReferenceRect?.height,\n top: iframeReferenceRect?.top + anchorReferenceRect?.top,\n left: iframeReferenceRect?.left + anchorReferenceRect?.left,\n right: iframeReferenceRect?.right + anchorReferenceRect?.right,\n bottom: iframeReferenceRect?.bottom + anchorReferenceRect?.bottom,\n };\n },\n\n initTippyInstance () {\n let internalAppendTo = null;\n let iFrameError = false;\n\n switch (this.appendTo) {\n case 'body':\n internalAppendTo = this.anchorEl?.getRootNode()?.querySelector('body');\n break;\n\n case 'root':\n // Try to attach the popover to root document, fallback to parent is fail\n try {\n internalAppendTo = window.parent.document.body;\n } catch (err) {\n console.error('Could not attach the popover to iframe parent window: ', err);\n internalAppendTo = 'parent';\n iFrameError = true;\n }\n break;\n\n default:\n internalAppendTo = this.appendTo;\n break;\n }\n\n this.tip?.destroy();\n\n this.tip = createTippyPopover(this.anchorEl, {\n popperOptions: this.popperOptions(),\n contentElement: this.popoverContentEl,\n placement: this.placement,\n offset: this.offset,\n sticky: this.sticky,\n appendTo: internalAppendTo,\n interactive: true,\n trigger: 'manual',\n getReferenceClientRect: () => this.getReferenceClientRect(iFrameError),\n // We have to manage hideOnClick functionality manually to handle\n // popover within popover situations.\n hideOnClick: false,\n zIndex: this.modal ? 650 : this.calculateAnchorZindex(),\n onClickOutside: this.onClickOutside,\n onShow: this.onShow,\n });\n },\n\n onMouseEnter () {\n this.$emit('mouseenter-popover');\n },\n\n onMouseLeave () {\n this.$emit('mouseleave-popover');\n },\n\n onMouseEnterAnchor () {\n this.$emit('mouseenter-popover-anchor');\n },\n\n onMouseLeaveAnchor () {\n this.$emit('mouseleave-popover-anchor');\n },\n },\n};\n</script>\n"],"mappings":"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"}