index.js 3.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
  2. const require_runtime = require('../../_virtual/_rolldown/runtime.js');
  3. const require_types = require('../../utils/types.js');
  4. const require_runtime$1 = require('../../utils/vue/props/runtime.js');
  5. let vue = require("vue");
  6. let _vue_shared = require("@vue/shared");
  7. let _vueuse_core = require("@vueuse/core");
  8. //#region ../../packages/hooks/use-model-toggle/index.ts
  9. const _prop = require_runtime$1.buildProp({
  10. type: require_runtime$1.definePropType(Boolean),
  11. default: null
  12. });
  13. const _event = require_runtime$1.buildProp({ type: require_runtime$1.definePropType(Function) });
  14. const createModelToggleComposable = (name) => {
  15. const updateEventKey = `update:${name}`;
  16. const updateEventKeyRaw = `onUpdate:${name}`;
  17. const useModelToggleEmits = [updateEventKey];
  18. const useModelToggleProps = {
  19. [name]: _prop,
  20. [updateEventKeyRaw]: _event
  21. };
  22. const useModelToggle = ({ indicator, toggleReason, shouldHideWhenRouteChanges, shouldProceed, onShow, onHide }) => {
  23. const instance = (0, vue.getCurrentInstance)();
  24. const { emit } = instance;
  25. const props = instance.props;
  26. const hasUpdateHandler = (0, vue.computed)(() => (0, _vue_shared.isFunction)(props[updateEventKeyRaw]));
  27. const isModelBindingAbsent = (0, vue.computed)(() => props[name] === null);
  28. const doShow = (event) => {
  29. if (indicator.value === true) return;
  30. indicator.value = true;
  31. if (toggleReason) toggleReason.value = event;
  32. if ((0, _vue_shared.isFunction)(onShow)) onShow(event);
  33. };
  34. const doHide = (event) => {
  35. if (indicator.value === false) return;
  36. indicator.value = false;
  37. if (toggleReason) toggleReason.value = event;
  38. if ((0, _vue_shared.isFunction)(onHide)) onHide(event);
  39. };
  40. const show = (event) => {
  41. if (props.disabled === true || (0, _vue_shared.isFunction)(shouldProceed) && !shouldProceed()) return;
  42. const shouldEmit = hasUpdateHandler.value && _vueuse_core.isClient;
  43. if (shouldEmit) emit(updateEventKey, true);
  44. if (isModelBindingAbsent.value || !shouldEmit) doShow(event);
  45. };
  46. const hide = (event) => {
  47. if (props.disabled === true || !_vueuse_core.isClient) return;
  48. const shouldEmit = hasUpdateHandler.value && _vueuse_core.isClient;
  49. if (shouldEmit) emit(updateEventKey, false);
  50. if (isModelBindingAbsent.value || !shouldEmit) doHide(event);
  51. };
  52. const onChange = (val) => {
  53. if (!require_types.isBoolean(val)) return;
  54. if (props.disabled && val) {
  55. if (hasUpdateHandler.value) emit(updateEventKey, false);
  56. } else if (indicator.value !== val) if (val) doShow();
  57. else doHide();
  58. };
  59. const toggle = () => {
  60. if (indicator.value) hide();
  61. else show();
  62. };
  63. (0, vue.watch)(() => props[name], onChange);
  64. if (shouldHideWhenRouteChanges && instance.appContext.config.globalProperties.$route !== void 0) (0, vue.watch)(() => ({ ...instance.proxy.$route }), () => {
  65. if (shouldHideWhenRouteChanges.value && indicator.value) hide();
  66. });
  67. (0, vue.onMounted)(() => {
  68. onChange(props[name]);
  69. });
  70. return {
  71. hide,
  72. show,
  73. toggle,
  74. hasUpdateHandler
  75. };
  76. };
  77. return {
  78. useModelToggle,
  79. useModelToggleProps,
  80. useModelToggleEmits
  81. };
  82. };
  83. const { useModelToggle, useModelToggleProps, useModelToggleEmits } = createModelToggleComposable("modelValue");
  84. //#endregion
  85. exports.createModelToggleComposable = createModelToggleComposable;
  86. exports.useModelToggle = useModelToggle;
  87. exports.useModelToggleEmits = useModelToggleEmits;
  88. exports.useModelToggleProps = useModelToggleProps;
  89. //# sourceMappingURL=index.js.map