{"version":3,"sources":["webpack:///./node_modules/@esri/calcite-components/dist/components/tooltip.js","webpack:///./node_modules/@esri/calcite-components/dist/components/calcite-tooltip.js"],"names":["CSS","manager","this","registeredElements","WeakMap","hoverTimeouts","registeredElementCount","queryTooltip","composedPath","registeredElement","find","pathEl","has","get","keyDownHandler","event","key","activeTooltipEl","clearHoverTimeout","toggleTooltip","mouseEnterShow","hoverEvent","mouseLeaveHide","clickHandler","clickedTooltip","closeOnClick","focusShow","focusEvent","blurHide","hoverToggle","tooltip","value","delete","closeExistingTooltip","referenceEl","set","addListeners","removeListeners","document","addEventListener","capture","removeEventListener","window","clearTimeout","open","timeoutId","setTimeout","type","includes","hoverTooltip","activeTooltipHover","focusTooltip","Tooltip","super","__registerHost","__attachShadow","offsetDistance","offsetSkidding","overlayPositioning","placement","guid","hasLoaded","setUpReferenceElement","warn","removeReferences","effectiveReferenceElement","getReferenceElement","el","referenceElement","console","tagName","addReferences","getId","id","setAttribute","registerElement","removeAttribute","unregisterElement","reposition","delayed","arrowEl","floatingEl","includeArrow","label","displayed","hidden","role","class","animation","animationActive","ref","defineCustomElement","customElements","forEach","define","CalciteTooltip"],"mappings":"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","file":"53.3dc48d3118e08b991bb1.js","sourcesContent":["/*!\n * All material copyright ESRI, All Rights Reserved, unless otherwise specified.\n * See https://github.com/Esri/calcite-components/blob/master/LICENSE.md for details.\n * v1.0.0-beta.97\n */\nimport { proxyCustomElement, HTMLElement, h, Host } from '@stencil/core/internal/client/index.js';\nimport { g as guid } from './guid.js';\nimport { b as defaultOffsetDistance, c as connectFloatingUI, u as updateAfterClose, a as disconnectFloatingUI, r as reposition, F as FloatingCSS } from './floating-ui.js';\nimport { i as isPrimaryPointerButton, q as queryElementRoots, t as toAriaBoolean } from './dom.js';\n\nconst CSS = {\n container: \"container\",\n arrow: \"arrow\"\n};\nconst TOOLTIP_DELAY_MS = 500;\nconst ARIA_DESCRIBED_BY = \"aria-describedby\";\n\nclass TooltipManager {\n constructor() {\n // --------------------------------------------------------------------------\n //\n // Private Properties\n //\n // --------------------------------------------------------------------------\n this.registeredElements = new WeakMap();\n this.hoverTimeouts = new WeakMap();\n this.registeredElementCount = 0;\n // --------------------------------------------------------------------------\n //\n // Private Methods\n //\n // --------------------------------------------------------------------------\n this.queryTooltip = (composedPath) => {\n const { registeredElements } = this;\n const registeredElement = composedPath.find((pathEl) => registeredElements.has(pathEl));\n return registeredElements.get(registeredElement);\n };\n this.keyDownHandler = (event) => {\n if (event.key === \"Escape\") {\n const { activeTooltipEl } = this;\n if (activeTooltipEl) {\n this.clearHoverTimeout(activeTooltipEl);\n this.toggleTooltip(activeTooltipEl, false);\n }\n }\n };\n this.mouseEnterShow = (event) => {\n this.hoverEvent(event, true);\n };\n this.mouseLeaveHide = (event) => {\n this.hoverEvent(event, false);\n };\n this.clickHandler = (event) => {\n if (!isPrimaryPointerButton(event)) {\n return;\n }\n const clickedTooltip = this.queryTooltip(event.composedPath());\n this.clickedTooltip = clickedTooltip;\n if (clickedTooltip === null || clickedTooltip === void 0 ? void 0 : clickedTooltip.closeOnClick) {\n this.toggleTooltip(clickedTooltip, false);\n this.clearHoverTimeout(clickedTooltip);\n }\n };\n this.focusShow = (event) => {\n this.focusEvent(event, true);\n };\n this.blurHide = (event) => {\n this.focusEvent(event, false);\n };\n this.hoverToggle = (tooltip, value) => {\n const { hoverTimeouts } = this;\n hoverTimeouts.delete(tooltip);\n if (value) {\n this.closeExistingTooltip();\n }\n this.toggleTooltip(tooltip, value);\n };\n }\n // --------------------------------------------------------------------------\n //\n // Public Methods\n //\n // --------------------------------------------------------------------------\n registerElement(referenceEl, tooltip) {\n this.registeredElementCount++;\n this.registeredElements.set(referenceEl, tooltip);\n if (this.registeredElementCount === 1) {\n this.addListeners();\n }\n }\n unregisterElement(referenceEl) {\n if (this.registeredElements.delete(referenceEl)) {\n this.registeredElementCount--;\n }\n if (this.registeredElementCount === 0) {\n this.removeListeners();\n }\n }\n addListeners() {\n document.addEventListener(\"keydown\", this.keyDownHandler);\n document.addEventListener(\"pointerover\", this.mouseEnterShow, { capture: true });\n document.addEventListener(\"pointerout\", this.mouseLeaveHide, { capture: true });\n document.addEventListener(\"pointerdown\", this.clickHandler, { capture: true });\n document.addEventListener(\"focusin\", this.focusShow, { capture: true });\n document.addEventListener(\"focusout\", this.blurHide, { capture: true });\n }\n removeListeners() {\n document.removeEventListener(\"keydown\", this.keyDownHandler);\n document.removeEventListener(\"pointerover\", this.mouseEnterShow, { capture: true });\n document.removeEventListener(\"pointerout\", this.mouseLeaveHide, { capture: true });\n document.removeEventListener(\"pointerdown\", this.clickHandler, { capture: true });\n document.removeEventListener(\"focusin\", this.focusShow, { capture: true });\n document.removeEventListener(\"focusout\", this.blurHide, { capture: true });\n }\n clearHoverTimeout(tooltip) {\n const { hoverTimeouts } = this;\n if (hoverTimeouts.has(tooltip)) {\n window.clearTimeout(hoverTimeouts.get(tooltip));\n hoverTimeouts.delete(tooltip);\n }\n }\n closeExistingTooltip() {\n const { activeTooltipEl } = this;\n if (activeTooltipEl) {\n this.toggleTooltip(activeTooltipEl, false);\n }\n }\n focusTooltip(tooltip, value) {\n this.closeExistingTooltip();\n if (value) {\n this.clearHoverTimeout(tooltip);\n }\n this.toggleTooltip(tooltip, value);\n }\n toggleTooltip(tooltip, value) {\n tooltip.open = value;\n if (value) {\n this.activeTooltipEl = tooltip;\n }\n }\n hoverTooltip(tooltip, value) {\n this.clearHoverTimeout(tooltip);\n const { hoverTimeouts } = this;\n const timeoutId = window.setTimeout(() => this.hoverToggle(tooltip, value), TOOLTIP_DELAY_MS );\n hoverTimeouts.set(tooltip, timeoutId);\n }\n activeTooltipHover(event) {\n const { activeTooltipEl, hoverTimeouts } = this;\n const { type } = event;\n if (!activeTooltipEl) {\n return;\n }\n if (type === \"pointerover\" && event.composedPath().includes(activeTooltipEl)) {\n this.clearHoverTimeout(activeTooltipEl);\n }\n else if (type === \"pointerout\" && !hoverTimeouts.has(activeTooltipEl)) {\n this.hoverTooltip(activeTooltipEl, false);\n }\n }\n hoverEvent(event, value) {\n const tooltip = this.queryTooltip(event.composedPath());\n this.activeTooltipHover(event);\n if (!tooltip) {\n return;\n }\n this.hoverTooltip(tooltip, value);\n }\n focusEvent(event, value) {\n const tooltip = this.queryTooltip(event.composedPath());\n if (!tooltip || tooltip === this.clickedTooltip) {\n this.clickedTooltip = null;\n return;\n }\n this.focusTooltip(tooltip, value);\n }\n}\n\nconst tooltipCss = \"@keyframes in{0%{opacity:0}100%{opacity:1}}@keyframes in-down{0%{opacity:0;transform:translate3D(0, -5px, 0)}100%{opacity:1;transform:translate3D(0, 0, 0)}}@keyframes in-up{0%{opacity:0;transform:translate3D(0, 5px, 0)}100%{opacity:1;transform:translate3D(0, 0, 0)}}@keyframes in-scale{0%{opacity:0;transform:scale3D(0.95, 0.95, 1)}100%{opacity:1;transform:scale3D(1, 1, 1)}}:root{--calcite-animation-timing:calc(150ms * var(--calcite-internal-duration-factor));--calcite-internal-duration-factor:var(--calcite-duration-factor, 1);--calcite-internal-animation-timing-fast:calc(100ms * var(--calcite-internal-duration-factor));--calcite-internal-animation-timing-medium:calc(200ms * var(--calcite-internal-duration-factor));--calcite-internal-animation-timing-slow:calc(300ms * var(--calcite-internal-duration-factor))}.calcite-animate{opacity:0;animation-fill-mode:both;animation-duration:var(--calcite-animation-timing)}.calcite-animate__in{animation-name:in}.calcite-animate__in-down{animation-name:in-down}.calcite-animate__in-up{animation-name:in-up}.calcite-animate__in-scale{animation-name:in-scale}@media (prefers-reduced-motion: reduce){:root{--calcite-internal-duration-factor:0.01}}:root{--calcite-floating-ui-transition:var(--calcite-animation-timing)}:host([hidden]){display:none}:host{display:block;position:absolute;z-index:999}.calcite-floating-ui-anim{position:relative;transition:var(--calcite-floating-ui-transition);visibility:hidden;transition-property:transform, visibility, opacity;opacity:0;box-shadow:0 0 16px 0 rgba(0, 0, 0, 0.16);z-index:1;border-radius:0.25rem}:host([data-placement^=bottom]) .calcite-floating-ui-anim{transform:translateY(-5px)}:host([data-placement^=top]) .calcite-floating-ui-anim{transform:translateY(5px)}:host([data-placement^=left]) .calcite-floating-ui-anim{transform:translateX(5px)}:host([data-placement^=right]) .calcite-floating-ui-anim{transform:translateX(-5px)}:host([data-placement]) .calcite-floating-ui-anim--active{opacity:1;visibility:visible;transform:translate(0)}:host([calcite-hydrated-hidden]){visibility:hidden !important;pointer-events:none}.arrow,.arrow::before{position:absolute;inline-size:8px;block-size:8px;z-index:-1}.arrow::before{content:\\\"\\\";--tw-shadow:0 4px 8px -1px rgba(0, 0, 0, 0.08), 0 2px 4px -1px rgba(0, 0, 0, 0.04);--tw-shadow-colored:0 4px 8px -1px var(--tw-shadow-color), 0 2px 4px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);transform:rotate(45deg);background:var(--calcite-ui-foreground-1)}:host([data-placement^=top]) .arrow{inset-block-end:-4px}:host([data-placement^=bottom]) .arrow{inset-block-start:-4px}:host([data-placement^=left]) .arrow{direction:ltr;inset-inline-end:-4px}:host([data-placement^=right]) .arrow{direction:ltr;inset-inline-start:-4px}.container{position:relative;overflow:hidden;border-radius:0.25rem;background-color:var(--calcite-ui-foreground-1);padding-block:0.75rem;padding-inline:1rem;font-size:var(--calcite-font-size--2);line-height:1.375;font-weight:var(--calcite-font-weight-medium);color:var(--calcite-ui-text-1);max-inline-size:20rem;max-block-size:20rem;text-align:start}.calcite-floating-ui-anim{border-radius:0.25rem;border-width:1px;border-style:solid;border-color:var(--calcite-ui-border-3);background-color:var(--calcite-ui-foreground-1)}.arrow::before{outline:1px solid var(--calcite-ui-border-3)}\";\n\nconst manager = new TooltipManager();\nconst Tooltip = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {\n constructor() {\n super();\n this.__registerHost();\n this.__attachShadow();\n // --------------------------------------------------------------------------\n //\n // Properties\n //\n // --------------------------------------------------------------------------\n /** Closes the component when the `referenceElement` is clicked. */\n this.closeOnClick = false;\n /**\n * Offset the position of the component away from the `referenceElement`.\n *\n * @default 6\n */\n this.offsetDistance = defaultOffsetDistance;\n /**\n * Offset the position of the component along the `referenceElement`.\n */\n this.offsetSkidding = 0;\n /**\n * When `true`, the component is open.\n */\n this.open = false;\n /**\n * Determines the type of positioning to use for the overlaid content.\n *\n * Using `\"absolute\"` will work for most cases. The component will be positioned inside of overflowing parent containers and will affect the container's layout.\n *\n * The `\"fixed\"` value should be used to escape an overflowing parent container, or when the reference element's `position` CSS property is `\"fixed\"`.\n *\n */\n this.overlayPositioning = \"absolute\";\n /**\n * Determines where the component will be positioned relative to the `referenceElement`.\n *\n * @see [LogicalPlacement](https://github.com/Esri/calcite-components/blob/master/src/utils/floating-ui.ts#L25)\n */\n this.placement = \"auto\";\n this.guid = `calcite-tooltip-${guid()}`;\n this.hasLoaded = false;\n // --------------------------------------------------------------------------\n //\n // Private Methods\n //\n // --------------------------------------------------------------------------\n this.setUpReferenceElement = (warn = true) => {\n this.removeReferences();\n this.effectiveReferenceElement = this.getReferenceElement();\n connectFloatingUI(this, this.effectiveReferenceElement, this.el);\n const { el, referenceElement, effectiveReferenceElement } = this;\n if (warn && referenceElement && !effectiveReferenceElement) {\n console.warn(`${el.tagName}: reference-element id \"${referenceElement}\" was not found.`, {\n el\n });\n }\n this.addReferences();\n };\n this.getId = () => {\n return this.el.id || this.guid;\n };\n this.addReferences = () => {\n const { effectiveReferenceElement } = this;\n if (!effectiveReferenceElement) {\n return;\n }\n const id = this.getId();\n if (\"setAttribute\" in effectiveReferenceElement) {\n effectiveReferenceElement.setAttribute(ARIA_DESCRIBED_BY, id);\n }\n manager.registerElement(effectiveReferenceElement, this.el);\n };\n this.removeReferences = () => {\n const { effectiveReferenceElement } = this;\n if (!effectiveReferenceElement) {\n return;\n }\n if (\"removeAttribute\" in effectiveReferenceElement) {\n effectiveReferenceElement.removeAttribute(ARIA_DESCRIBED_BY);\n }\n manager.unregisterElement(effectiveReferenceElement);\n };\n }\n offsetDistanceOffsetHandler() {\n this.reposition(true);\n }\n offsetSkiddingHandler() {\n this.reposition(true);\n }\n openHandler(value) {\n if (value) {\n this.reposition(true);\n }\n else {\n updateAfterClose(this.el);\n }\n }\n overlayPositioningHandler() {\n this.reposition(true);\n }\n placementHandler() {\n this.reposition(true);\n }\n referenceElementHandler() {\n this.setUpReferenceElement();\n }\n // --------------------------------------------------------------------------\n //\n // Lifecycle\n //\n // --------------------------------------------------------------------------\n connectedCallback() {\n this.setUpReferenceElement(this.hasLoaded);\n }\n componentDidLoad() {\n if (this.referenceElement && !this.effectiveReferenceElement) {\n this.setUpReferenceElement();\n }\n this.reposition(true);\n this.hasLoaded = true;\n }\n disconnectedCallback() {\n this.removeReferences();\n disconnectFloatingUI(this, this.effectiveReferenceElement, this.el);\n }\n // --------------------------------------------------------------------------\n //\n // Public Methods\n //\n // --------------------------------------------------------------------------\n /**\n * Updates the position of the component.\n *\n * @param delayed\n */\n async reposition(delayed = false) {\n const { el, effectiveReferenceElement, placement, overlayPositioning, offsetDistance, offsetSkidding, arrowEl } = this;\n return reposition(this, {\n floatingEl: el,\n referenceEl: effectiveReferenceElement,\n overlayPositioning,\n placement,\n offsetDistance,\n offsetSkidding,\n includeArrow: true,\n arrowEl,\n type: \"tooltip\"\n }, delayed);\n }\n getReferenceElement() {\n const { referenceElement, el } = this;\n return ((typeof referenceElement === \"string\"\n ? queryElementRoots(el, { id: referenceElement })\n : referenceElement) || null);\n }\n // --------------------------------------------------------------------------\n //\n // Render Methods\n //\n // --------------------------------------------------------------------------\n render() {\n const { effectiveReferenceElement, label, open } = this;\n const displayed = effectiveReferenceElement && open;\n const hidden = !displayed;\n return (h(Host, { \"aria-hidden\": toAriaBoolean(hidden), \"aria-label\": label, \"aria-live\": \"polite\", \"calcite-hydrated-hidden\": hidden, id: this.getId(), role: \"tooltip\" }, h(\"div\", { class: {\n [FloatingCSS.animation]: true,\n [FloatingCSS.animationActive]: displayed\n } }, h(\"div\", { class: CSS.arrow, ref: (arrowEl) => (this.arrowEl = arrowEl) }), h(\"div\", { class: CSS.container }, h(\"slot\", null)))));\n }\n get el() { return this; }\n static get watchers() { return {\n \"offsetDistance\": [\"offsetDistanceOffsetHandler\"],\n \"offsetSkidding\": [\"offsetSkiddingHandler\"],\n \"open\": [\"openHandler\"],\n \"overlayPositioning\": [\"overlayPositioningHandler\"],\n \"placement\": [\"placementHandler\"],\n \"referenceElement\": [\"referenceElementHandler\"]\n }; }\n static get style() { return tooltipCss; }\n}, [1, \"calcite-tooltip\", {\n \"closeOnClick\": [516, \"close-on-click\"],\n \"label\": [1],\n \"offsetDistance\": [514, \"offset-distance\"],\n \"offsetSkidding\": [514, \"offset-skidding\"],\n \"open\": [516],\n \"overlayPositioning\": [513, \"overlay-positioning\"],\n \"placement\": [513],\n \"referenceElement\": [1, \"reference-element\"],\n \"effectiveReferenceElement\": [32],\n \"reposition\": [64]\n }]);\nfunction defineCustomElement() {\n if (typeof customElements === \"undefined\") {\n return;\n }\n const components = [\"calcite-tooltip\"];\n components.forEach(tagName => { switch (tagName) {\n case \"calcite-tooltip\":\n if (!customElements.get(tagName)) {\n customElements.define(tagName, Tooltip);\n }\n break;\n } });\n}\ndefineCustomElement();\n\nexport { Tooltip as T, defineCustomElement as d };\n","/*!\n * All material copyright ESRI, All Rights Reserved, unless otherwise specified.\n * See https://github.com/Esri/calcite-components/blob/master/LICENSE.md for details.\n * v1.0.0-beta.97\n */\nimport { T as Tooltip, d as defineCustomElement$1 } from './tooltip.js';\n\nconst CalciteTooltip = Tooltip;\nconst defineCustomElement = defineCustomElement$1;\n\nexport { CalciteTooltip, defineCustomElement };\n"],"sourceRoot":""}