{"version":3,"file":"tooltip.vue.mjs","sources":["../../../../../packages/components/tooltip/src/tooltip.vue"],"sourcesContent":["<template>\n  <el-popper ref=\"popperRef\">\n    <el-tooltip-trigger\n      :disabled=\"disabled\"\n      :trigger=\"trigger\"\n      :virtual-ref=\"virtualRef\"\n      :virtual-triggering=\"virtualTriggering\"\n    >\n      <slot v-if=\"$slots.default\" />\n    </el-tooltip-trigger>\n    <el-tooltip-content\n      :aria-label=\"ariaLabel\"\n      :boundaries-padding=\"boundariesPadding\"\n      :content=\"content\"\n      :disabled=\"disabled\"\n      :effect=\"effect\"\n      :enterable=\"enterable\"\n      :fallback-placements=\"fallbackPlacements\"\n      :hide-after=\"hideAfter\"\n      :gpu-acceleration=\"gpuAcceleration\"\n      :offset=\"offset\"\n      :persistent=\"persistent\"\n      :popper-class=\"popperClass\"\n      :popper-style=\"popperStyle\"\n      :placement=\"placement\"\n      :popper-options=\"popperOptions\"\n      :pure=\"pure\"\n      :raw-content=\"rawContent\"\n      :reference-el=\"referenceEl\"\n      :show-after=\"compatShowAfter\"\n      :strategy=\"strategy\"\n      :teleported=\"teleported\"\n      :transition=\"transition\"\n      :z-index=\"zIndex\"\n      :append-to=\"appendTo\"\n    >\n      <slot name=\"content\">\n        <span v-if=\"rawContent\" v-html=\"content\"></span>\n        <span v-else>{{ content }}</span>\n      </slot>\n      <el-popper-arrow v-if=\"compatShowArrow\" :arrow-offset=\"arrowOffset\" />\n    </el-tooltip-content>\n  </el-popper>\n</template>\n\n<script lang=\"ts\">\nimport {\n  defineComponent,\n  computed,\n  ref,\n  provide,\n  toRef,\n  readonly,\n  unref,\n} from 'vue'\nimport {\n  ElPopper,\n  ElPopperArrow,\n  usePopperArrowProps,\n} from '@element-ultra/components/popper'\n\nimport { debugWarn, isBoolean, isUndefined } from '@element-ultra/utils'\nimport {\n  usePopperContainer,\n  useId,\n  createModelToggleComposable,\n  useDelayedToggle,\n} from '@element-ultra/hooks'\nimport ElTooltipContent from './content.vue'\nimport ElTooltipTrigger from './trigger.vue'\nimport {\n  useTooltipContentProps,\n  useTooltipTriggerProps,\n  useTooltipProps,\n} from './tooltip'\nimport { TOOLTIP_INJECTION_KEY } from './tokens'\n\nconst { useModelToggleProps, useModelToggle, useModelToggleEmits } =\n  createModelToggleComposable('visible' as const)\n\nexport default defineComponent({\n  name: 'ElTooltip',\n  components: {\n    ElPopper,\n    ElPopperArrow,\n    ElTooltipContent,\n    ElTooltipTrigger,\n  },\n  props: {\n    ...useModelToggleProps,\n    ...useTooltipContentProps,\n    ...useTooltipTriggerProps,\n    ...usePopperArrowProps,\n    ...useTooltipProps,\n  },\n  emits: [...useModelToggleEmits, 'before-show', 'before-hide', 'show', 'hide'],\n  setup(props, { emit }) {\n    usePopperContainer()\n    const compatShowAfter = computed(() => {\n      if (!isUndefined(props.openDelay)) {\n        debugWarn(\n          'ElTooltip',\n          'open-delay is about to be deprecated in the next major version, please use `show-after` instead'\n        )\n      }\n      return props.openDelay || (props.showAfter as number)\n    })\n    const compatShowArrow = computed(() => {\n      if (!isUndefined(props.visibleArrow)) {\n        debugWarn(\n          'ElTooltip',\n          '`visible-arrow` is about to be deprecated in the next major version, please use `show-arrow` instead'\n        )\n      }\n      return isBoolean(props.visibleArrow)\n        ? props.visibleArrow\n        : props.showArrow\n    })\n\n    const id = useId()\n    const popperRef = ref<InstanceType<typeof ElPopper> | null>(null)\n\n    const updatePopper = () => {\n      const popperComponent = unref(popperRef)\n      if (popperComponent) {\n        popperComponent.popperInstanceRef?.update()\n      }\n    }\n    const open = ref(false)\n\n    const { show, hide } = useModelToggle({\n      indicator: open,\n    })\n\n    const { onOpen, onClose } = useDelayedToggle({\n      showAfter: compatShowAfter,\n      hideAfter: toRef(props, 'hideAfter'),\n      open: show,\n      close: hide\n    })\n\n    const controlled = computed(() => isBoolean(props.visible))\n\n    provide(TOOLTIP_INJECTION_KEY, {\n      controlled,\n      id,\n      open: readonly(open),\n      trigger: toRef(props, 'trigger'),\n      onOpen,\n      onClose,\n      onToggle: () => {\n        if (unref(open)) {\n          onClose()\n        } else {\n          onOpen()\n        }\n      },\n      onShow: () => {\n        emit('show')\n      },\n      onHide: () => {\n        emit('hide')\n      },\n      onBeforeShow: () => {\n        emit('before-show')\n      },\n      onBeforeHide: () => {\n        emit('before-hide')\n      },\n      updatePopper,\n    })\n\n    return {\n      compatShowAfter,\n      compatShowArrow,\n      popperRef,\n      open,\n      hide,\n      updatePopper,\n      onOpen,\n      onClose,\n    }\n  },\n})\n</script>\n"],"names":["_resolveComponent","_openBlock","_createBlock","_withCtx","_createVNode","_renderSlot","_createCommentVNode","_createElementBlock","_toDisplayString"],"mappings":";;;;;;;;;;+BACEA,iBAyCY,WAAA,CAAA,CAAA;SAxCVC,WAOqB,EAAAC,WAAA;AAAA,IAAA,oBAAA;AAAA,IAAA,EAAA,KAAA,WAAA,EAAA;AAAA,IAAA;AAAA,MAAA,OAAA,EANlBC,QAAU,MAAA;AAAA,QAAAC,YACD,6BAAO,EAAA;AAAA,UAChB,UAAa,IAAA,CAAA,QAAA;AAAA,UACb,SAAA,IAAA,CAAA,OAAA;AAAA,UAAA,eAAA,IAAA,CAAA,UAAA;AAAA,UAE6B,sBAAA,IAAA,CAAA,iBAAA;AAAA,SAAA,EAAA;AAAA,mBAA9BD,QAA8B,MAAA;AAAA,YAAA,IAAA,CAAA,MAAA,CAAA,OAAA,GAAAE,UAAA,CAAA,KAAA,MAAA,EAAA,SAAA,EAAA,EAAA,GAAA,EAAA,CAAA,EAAA,CAAA,GAAAC,kBAAA,CAAA,QAAA,IAAA,CAAA;AAAA;UAEhC,CAAA,EAAA,CAAA;AAAA;AAAA,WACG,CAAY,EAAA,CAAS,YAAA,SAAA,EAAA,aAAA,EAAA,oBAAA,CAAA,CAAA;AAAA,QAAAF,YACrB,6BAAoB,EAAA;AAAA,UACpB,cAAS,IAAA,CAAA,SAAA;AAAA,UACT,sBAAU,IAAQ,CAAA,iBAAA;AAAA,UAClB,SAAQ,IAAA,CAAA,OAAA;AAAA,UACR,UAAS,IAAE,CAAA,QAAA;AAAA,UACX,QAAA,IAAA,CAAA,MAAA;AAAA,UACA,WAAY,IAAA,CAAA,SAAA;AAAA,UACZ,uBAAkB,IAAA,CAAA,kBAAA;AAAA,UAClB,cAAQ,IAAM,CAAA,SAAA;AAAA,UACd,oBAAY,IAAA,CAAA,eAAA;AAAA,UACZ,QAAA,IAAA,CAAA,MAAA;AAAA,UACA,YAAc,IAAA,CAAA,UAAA;AAAA,UACd,gBAAW,IAAA,CAAA,WAAA;AAAA,UACX,gBAAc,IAAE,CAAA,WAAA;AAAA,UAChB,WAAM,IAAI,CAAA,SAAA;AAAA,UACV,kBAAa,IAAA,CAAA,aAAA;AAAA,UACb,MAAA,IAAA,CAAA,IAAA;AAAA,UACA,eAAY,IAAA,CAAA,UAAA;AAAA,UACZ,gBAAU,IAAA,CAAA,WAAA;AAAA,UACV,cAAY,IAAA,CAAA,eAAA;AAAA,UACZ,UAAU,IAAE,CAAA,QAAA;AAAA,UACZ,YAAS,IAAA,CAAA,UAAA;AAAA,UACT,YAAS,IAAE,CAAA,UAAA;AAAA,UAAA,WAAA,IAAA,CAAA,MAAA;AAAA,UAEZ,aAAA,IAAA,CAAA,QAAA;AAAA,SAAA,EAAA;AAAA,mBACcD,QAAU,MAAA;AAAA,YAAAE,WAAA,IAAA,CAAA,MAAA,EAAtB,SAAgD,EAAA,IAAA,MAAA;AAAA,cAAA,IAAA,CAAA,UAAA,IAAAJ,SAAR,EAAA,EAARM,mBAAO,MAAA,EAAA;AAAA,gBAAA,GAAA,EAAA,CAAA;AAAA,gBACvC,WAAA,IAAA,CAAA,OAAA;AAAA,iBAAA,IAAA,EAAA,CAAA,EAAA,UAAA,CAAA,KAEqBN,WAAe,EAAAM,kBAAA;AAAA,gBAAA,MAAA;AAAA,gBAAA,UAAA;AAAA,gBAAAC,eAAA,CAAA,KAAA,OAAA,CAAA;AAAA,gBAAA,CAAA;AAAA;AAAA,eAAA,CAAA;AAAA,aAAA,CAAA;AAAA,YAAG,IAAA,CAAA,eAAA,IAAAP,SAAA,EAAA,EAAAC,YAAc,0BAAW,EAAA;AAAA,cAAA,GAAA,EAAA,CAAA;AAAA;;;;;;;;;;;;;;;;;;"}