48 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			48 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
'use strict';
 | 
						|
 | 
						|
Object.defineProperty(exports, '__esModule', { value: true });
 | 
						|
 | 
						|
var vue = require('vue');
 | 
						|
var globalNode = require('../../utils/vue/global-node.js');
 | 
						|
var core = require('@vueuse/core');
 | 
						|
var shared = require('@vue/shared');
 | 
						|
 | 
						|
const useTeleport = (contentRenderer, appendToBody) => {
 | 
						|
  const isTeleportVisible = vue.ref(false);
 | 
						|
  if (!core.isClient) {
 | 
						|
    return {
 | 
						|
      isTeleportVisible,
 | 
						|
      showTeleport: shared.NOOP,
 | 
						|
      hideTeleport: shared.NOOP,
 | 
						|
      renderTeleport: shared.NOOP
 | 
						|
    };
 | 
						|
  }
 | 
						|
  let $el = null;
 | 
						|
  const showTeleport = () => {
 | 
						|
    isTeleportVisible.value = true;
 | 
						|
    if ($el !== null)
 | 
						|
      return;
 | 
						|
    $el = globalNode.createGlobalNode();
 | 
						|
  };
 | 
						|
  const hideTeleport = () => {
 | 
						|
    isTeleportVisible.value = false;
 | 
						|
    if ($el !== null) {
 | 
						|
      globalNode.removeGlobalNode($el);
 | 
						|
      $el = null;
 | 
						|
    }
 | 
						|
  };
 | 
						|
  const renderTeleport = () => {
 | 
						|
    return appendToBody.value !== true ? contentRenderer() : isTeleportVisible.value ? [vue.h(vue.Teleport, { to: $el }, contentRenderer())] : void 0;
 | 
						|
  };
 | 
						|
  vue.onUnmounted(hideTeleport);
 | 
						|
  return {
 | 
						|
    isTeleportVisible,
 | 
						|
    showTeleport,
 | 
						|
    hideTeleport,
 | 
						|
    renderTeleport
 | 
						|
  };
 | 
						|
};
 | 
						|
 | 
						|
exports.useTeleport = useTeleport;
 | 
						|
//# sourceMappingURL=index.js.map
 |