index.js 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. 'use strict';
  2. Object.defineProperty(exports, '__esModule', { value: true });
  3. var vue = require('vue');
  4. var shared = require('@vue/shared');
  5. var core = require('@vueuse/core');
  6. require('../../utils/index.js');
  7. var runtime = require('../../utils/vue/props/runtime.js');
  8. const _prop = runtime.buildProp({
  9. type: runtime.definePropType(Boolean),
  10. default: null
  11. });
  12. const _event = runtime.buildProp({
  13. type: runtime.definePropType(Function)
  14. });
  15. const createModelToggleComposable = (name) => {
  16. const updateEventKey = `update:${name}`;
  17. const updateEventKeyRaw = `onUpdate:${name}`;
  18. const useModelToggleEmits2 = [updateEventKey];
  19. const useModelToggleProps2 = {
  20. [name]: _prop,
  21. [updateEventKeyRaw]: _event
  22. };
  23. const useModelToggle2 = ({
  24. indicator,
  25. toggleReason,
  26. shouldHideWhenRouteChanges,
  27. shouldProceed,
  28. onShow,
  29. onHide
  30. }) => {
  31. const instance = vue.getCurrentInstance();
  32. const { emit } = instance;
  33. const props = instance.props;
  34. const hasUpdateHandler = vue.computed(() => shared.isFunction(props[updateEventKeyRaw]));
  35. const isModelBindingAbsent = vue.computed(() => props[name] === null);
  36. const doShow = (event) => {
  37. if (indicator.value === true) {
  38. return;
  39. }
  40. indicator.value = true;
  41. if (toggleReason) {
  42. toggleReason.value = event;
  43. }
  44. if (shared.isFunction(onShow)) {
  45. onShow(event);
  46. }
  47. };
  48. const doHide = (event) => {
  49. if (indicator.value === false) {
  50. return;
  51. }
  52. indicator.value = false;
  53. if (toggleReason) {
  54. toggleReason.value = event;
  55. }
  56. if (shared.isFunction(onHide)) {
  57. onHide(event);
  58. }
  59. };
  60. const show = (event) => {
  61. if (props.disabled === true || shared.isFunction(shouldProceed) && !shouldProceed())
  62. return;
  63. const shouldEmit = hasUpdateHandler.value && core.isClient;
  64. if (shouldEmit) {
  65. emit(updateEventKey, true);
  66. }
  67. if (isModelBindingAbsent.value || !shouldEmit) {
  68. doShow(event);
  69. }
  70. };
  71. const hide = (event) => {
  72. if (props.disabled === true || !core.isClient)
  73. return;
  74. const shouldEmit = hasUpdateHandler.value && core.isClient;
  75. if (shouldEmit) {
  76. emit(updateEventKey, false);
  77. }
  78. if (isModelBindingAbsent.value || !shouldEmit) {
  79. doHide(event);
  80. }
  81. };
  82. const onChange = (val) => {
  83. if (!core.isBoolean(val))
  84. return;
  85. if (props.disabled && val) {
  86. if (hasUpdateHandler.value) {
  87. emit(updateEventKey, false);
  88. }
  89. } else if (indicator.value !== val) {
  90. if (val) {
  91. doShow();
  92. } else {
  93. doHide();
  94. }
  95. }
  96. };
  97. const toggle = () => {
  98. if (indicator.value) {
  99. hide();
  100. } else {
  101. show();
  102. }
  103. };
  104. vue.watch(() => props[name], onChange);
  105. if (shouldHideWhenRouteChanges && instance.appContext.config.globalProperties.$route !== void 0) {
  106. vue.watch(() => ({
  107. ...instance.proxy.$route
  108. }), () => {
  109. if (shouldHideWhenRouteChanges.value && indicator.value) {
  110. hide();
  111. }
  112. });
  113. }
  114. vue.onMounted(() => {
  115. onChange(props[name]);
  116. });
  117. return {
  118. hide,
  119. show,
  120. toggle,
  121. hasUpdateHandler
  122. };
  123. };
  124. return {
  125. useModelToggle: useModelToggle2,
  126. useModelToggleProps: useModelToggleProps2,
  127. useModelToggleEmits: useModelToggleEmits2
  128. };
  129. };
  130. const { useModelToggle, useModelToggleProps, useModelToggleEmits } = createModelToggleComposable("modelValue");
  131. exports.createModelToggleComposable = createModelToggleComposable;
  132. exports.useModelToggle = useModelToggle;
  133. exports.useModelToggleEmits = useModelToggleEmits;
  134. exports.useModelToggleProps = useModelToggleProps;
  135. //# sourceMappingURL=index.js.map