140 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			140 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
'use strict';
 | 
						|
 | 
						|
Object.defineProperty(exports, '__esModule', { value: true });
 | 
						|
 | 
						|
var vue = require('vue');
 | 
						|
var runtime = require('../../utils/vue/props/runtime.js');
 | 
						|
var types = require('../../utils/types.js');
 | 
						|
var shared = require('@vue/shared');
 | 
						|
var core = require('@vueuse/core');
 | 
						|
 | 
						|
const _prop = runtime.buildProp({
 | 
						|
  type: runtime.definePropType(Boolean),
 | 
						|
  default: null
 | 
						|
});
 | 
						|
const _event = runtime.buildProp({
 | 
						|
  type: runtime.definePropType(Function)
 | 
						|
});
 | 
						|
const createModelToggleComposable = (name) => {
 | 
						|
  const updateEventKey = `update:${name}`;
 | 
						|
  const updateEventKeyRaw = `onUpdate:${name}`;
 | 
						|
  const useModelToggleEmits2 = [updateEventKey];
 | 
						|
  const useModelToggleProps2 = {
 | 
						|
    [name]: _prop,
 | 
						|
    [updateEventKeyRaw]: _event
 | 
						|
  };
 | 
						|
  const useModelToggle2 = ({
 | 
						|
    indicator,
 | 
						|
    toggleReason,
 | 
						|
    shouldHideWhenRouteChanges,
 | 
						|
    shouldProceed,
 | 
						|
    onShow,
 | 
						|
    onHide
 | 
						|
  }) => {
 | 
						|
    const instance = vue.getCurrentInstance();
 | 
						|
    const { emit } = instance;
 | 
						|
    const props = instance.props;
 | 
						|
    const hasUpdateHandler = vue.computed(() => shared.isFunction(props[updateEventKeyRaw]));
 | 
						|
    const isModelBindingAbsent = vue.computed(() => props[name] === null);
 | 
						|
    const doShow = (event) => {
 | 
						|
      if (indicator.value === true) {
 | 
						|
        return;
 | 
						|
      }
 | 
						|
      indicator.value = true;
 | 
						|
      if (toggleReason) {
 | 
						|
        toggleReason.value = event;
 | 
						|
      }
 | 
						|
      if (shared.isFunction(onShow)) {
 | 
						|
        onShow(event);
 | 
						|
      }
 | 
						|
    };
 | 
						|
    const doHide = (event) => {
 | 
						|
      if (indicator.value === false) {
 | 
						|
        return;
 | 
						|
      }
 | 
						|
      indicator.value = false;
 | 
						|
      if (toggleReason) {
 | 
						|
        toggleReason.value = event;
 | 
						|
      }
 | 
						|
      if (shared.isFunction(onHide)) {
 | 
						|
        onHide(event);
 | 
						|
      }
 | 
						|
    };
 | 
						|
    const show = (event) => {
 | 
						|
      if (props.disabled === true || shared.isFunction(shouldProceed) && !shouldProceed())
 | 
						|
        return;
 | 
						|
      const shouldEmit = hasUpdateHandler.value && core.isClient;
 | 
						|
      if (shouldEmit) {
 | 
						|
        emit(updateEventKey, true);
 | 
						|
      }
 | 
						|
      if (isModelBindingAbsent.value || !shouldEmit) {
 | 
						|
        doShow(event);
 | 
						|
      }
 | 
						|
    };
 | 
						|
    const hide = (event) => {
 | 
						|
      if (props.disabled === true || !core.isClient)
 | 
						|
        return;
 | 
						|
      const shouldEmit = hasUpdateHandler.value && core.isClient;
 | 
						|
      if (shouldEmit) {
 | 
						|
        emit(updateEventKey, false);
 | 
						|
      }
 | 
						|
      if (isModelBindingAbsent.value || !shouldEmit) {
 | 
						|
        doHide(event);
 | 
						|
      }
 | 
						|
    };
 | 
						|
    const onChange = (val) => {
 | 
						|
      if (!types.isBoolean(val))
 | 
						|
        return;
 | 
						|
      if (props.disabled && val) {
 | 
						|
        if (hasUpdateHandler.value) {
 | 
						|
          emit(updateEventKey, false);
 | 
						|
        }
 | 
						|
      } else if (indicator.value !== val) {
 | 
						|
        if (val) {
 | 
						|
          doShow();
 | 
						|
        } else {
 | 
						|
          doHide();
 | 
						|
        }
 | 
						|
      }
 | 
						|
    };
 | 
						|
    const toggle = () => {
 | 
						|
      if (indicator.value) {
 | 
						|
        hide();
 | 
						|
      } else {
 | 
						|
        show();
 | 
						|
      }
 | 
						|
    };
 | 
						|
    vue.watch(() => props[name], onChange);
 | 
						|
    if (shouldHideWhenRouteChanges && instance.appContext.config.globalProperties.$route !== void 0) {
 | 
						|
      vue.watch(() => ({
 | 
						|
        ...instance.proxy.$route
 | 
						|
      }), () => {
 | 
						|
        if (shouldHideWhenRouteChanges.value && indicator.value) {
 | 
						|
          hide();
 | 
						|
        }
 | 
						|
      });
 | 
						|
    }
 | 
						|
    vue.onMounted(() => {
 | 
						|
      onChange(props[name]);
 | 
						|
    });
 | 
						|
    return {
 | 
						|
      hide,
 | 
						|
      show,
 | 
						|
      toggle,
 | 
						|
      hasUpdateHandler
 | 
						|
    };
 | 
						|
  };
 | 
						|
  return {
 | 
						|
    useModelToggle: useModelToggle2,
 | 
						|
    useModelToggleProps: useModelToggleProps2,
 | 
						|
    useModelToggleEmits: useModelToggleEmits2
 | 
						|
  };
 | 
						|
};
 | 
						|
const { useModelToggle, useModelToggleProps, useModelToggleEmits } = createModelToggleComposable("modelValue");
 | 
						|
 | 
						|
exports.createModelToggleComposable = createModelToggleComposable;
 | 
						|
exports.useModelToggle = useModelToggle;
 | 
						|
exports.useModelToggleEmits = useModelToggleEmits;
 | 
						|
exports.useModelToggleProps = useModelToggleProps;
 | 
						|
//# sourceMappingURL=index.js.map
 |