| 1234567891011121314151617181920212223242526272829303132333435363738394041424344 | 
							- import { ref, h, Teleport, onUnmounted } from 'vue';
 
- import { NOOP } from '@vue/shared';
 
- import { isClient } from '@vueuse/core';
 
- import '../../utils/index.mjs';
 
- import { createGlobalNode, removeGlobalNode } from '../../utils/vue/global-node.mjs';
 
- const useTeleport = (contentRenderer, appendToBody) => {
 
-   const isTeleportVisible = ref(false);
 
-   if (!isClient) {
 
-     return {
 
-       isTeleportVisible,
 
-       showTeleport: NOOP,
 
-       hideTeleport: NOOP,
 
-       renderTeleport: NOOP
 
-     };
 
-   }
 
-   let $el = null;
 
-   const showTeleport = () => {
 
-     isTeleportVisible.value = true;
 
-     if ($el !== null)
 
-       return;
 
-     $el = createGlobalNode();
 
-   };
 
-   const hideTeleport = () => {
 
-     isTeleportVisible.value = false;
 
-     if ($el !== null) {
 
-       removeGlobalNode($el);
 
-       $el = null;
 
-     }
 
-   };
 
-   const renderTeleport = () => {
 
-     return appendToBody.value !== true ? contentRenderer() : isTeleportVisible.value ? [h(Teleport, { to: $el }, contentRenderer())] : void 0;
 
-   };
 
-   onUnmounted(hideTeleport);
 
-   return {
 
-     isTeleportVisible,
 
-     showTeleport,
 
-     hideTeleport,
 
-     renderTeleport
 
-   };
 
- };
 
- export { useTeleport };
 
- //# sourceMappingURL=index.mjs.map
 
 
  |