vue-devui 1.6.13 → 1.6.15

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (66) hide show
  1. package/auto-complete/index.es.js +20 -39
  2. package/auto-complete/index.umd.js +10 -10
  3. package/breadcrumb/index.es.js +25 -39
  4. package/breadcrumb/index.umd.js +1 -1
  5. package/category-search/index.es.js +27 -41
  6. package/category-search/index.umd.js +13 -13
  7. package/category-search/style.css +1 -1
  8. package/checkbox/index.es.js +20 -39
  9. package/checkbox/index.umd.js +11 -11
  10. package/code-review/index.es.js +20 -39
  11. package/code-review/index.umd.js +17 -17
  12. package/data-grid/index.es.js +27 -41
  13. package/data-grid/index.umd.js +12 -12
  14. package/date-picker-pro/index.es.js +20 -39
  15. package/date-picker-pro/index.umd.js +13 -13
  16. package/dropdown/index.es.js +25 -39
  17. package/dropdown/index.umd.js +1 -1
  18. package/editable-select/index.es.js +20 -39
  19. package/editable-select/index.umd.js +14 -14
  20. package/editor-md/index.es.js +27 -41
  21. package/editor-md/index.umd.js +23 -23
  22. package/form/index.es.js +20 -39
  23. package/form/index.umd.js +12 -12
  24. package/input/index.es.js +20 -39
  25. package/input/index.umd.js +10 -10
  26. package/input-number/index.es.js +20 -39
  27. package/input-number/index.umd.js +18 -18
  28. package/mention/index.es.js +20 -39
  29. package/mention/index.umd.js +18 -18
  30. package/modal/index.es.js +18 -37
  31. package/modal/index.umd.js +2 -2
  32. package/overlay/index.es.js +18 -37
  33. package/overlay/index.umd.js +1 -1
  34. package/package.json +2 -2
  35. package/pagination/index.es.js +27 -41
  36. package/pagination/index.umd.js +13 -13
  37. package/popover/index.es.js +20 -39
  38. package/popover/index.umd.js +14 -14
  39. package/radio/index.es.js +20 -39
  40. package/radio/index.umd.js +17 -17
  41. package/search/index.es.js +20 -39
  42. package/search/index.umd.js +12 -12
  43. package/select/index.es.js +20 -39
  44. package/select/index.umd.js +16 -16
  45. package/splitter/index.es.js +20 -39
  46. package/splitter/index.umd.js +16 -16
  47. package/style.css +1 -1
  48. package/switch/index.es.js +20 -39
  49. package/switch/index.umd.js +12 -12
  50. package/table/index.es.js +27 -41
  51. package/table/index.umd.js +14 -14
  52. package/textarea/index.es.js +20 -39
  53. package/textarea/index.umd.js +15 -15
  54. package/time-picker/index.es.js +20 -39
  55. package/time-picker/index.umd.js +16 -16
  56. package/time-select/index.es.js +20 -39
  57. package/time-select/index.umd.js +10 -10
  58. package/tooltip/index.es.js +20 -39
  59. package/tooltip/index.umd.js +17 -17
  60. package/tree/index.es.js +20 -39
  61. package/tree/index.umd.js +12 -12
  62. package/types/dropdown/src/dropdown-types.d.ts +4 -0
  63. package/types/dropdown/src/dropdown.d.ts +9 -0
  64. package/types/tooltip/src/tooltip.d.ts +1 -1
  65. package/vue-devui.es.js +26 -40
  66. package/vue-devui.umd.js +63 -63
@@ -36,7 +36,7 @@ var __publicField = (obj, key, value) => {
36
36
  import { ref, reactive, defineComponent, watch, provide, toRefs, createVNode, onUnmounted, Transition, mergeProps, unref, nextTick, withModifiers, Comment, Text, h, Fragment, inject, withDirectives, cloneVNode, computed, onMounted, Teleport, createTextVNode, onBeforeUnmount, toRef, onBeforeMount, vShow, resolveComponent, getCurrentInstance, render, resolveDirective } from "vue";
37
37
  import { onClickOutside } from "@vueuse/core";
38
38
  import "clipboard";
39
- import { offset, autoPlacement, arrow, shift, computePosition } from "@floating-ui/dom";
39
+ import { offset, flip, arrow, computePosition } from "@floating-ui/dom";
40
40
  function deepAssign(...objects) {
41
41
  const isObject2 = (obj) => obj && typeof obj === "object";
42
42
  return objects.reduce((prev, from) => {
@@ -4089,7 +4089,7 @@ var lodash = { exports: {} };
4089
4089
  var delay = baseRest(function(func, wait, args) {
4090
4090
  return baseDelay(func, toNumber(wait) || 0, args);
4091
4091
  });
4092
- function flip(func) {
4092
+ function flip2(func) {
4093
4093
  return createWrap(func, WRAP_FLIP_FLAG);
4094
4094
  }
4095
4095
  function memoize(func, resolver) {
@@ -5213,7 +5213,7 @@ var lodash = { exports: {} };
5213
5213
  lodash2.flatten = flatten;
5214
5214
  lodash2.flattenDeep = flattenDeep;
5215
5215
  lodash2.flattenDepth = flattenDepth;
5216
- lodash2.flip = flip;
5216
+ lodash2.flip = flip2;
5217
5217
  lodash2.flow = flow;
5218
5218
  lodash2.flowRight = flowRight;
5219
5219
  lodash2.fromPairs = fromPairs;
@@ -6008,16 +6008,6 @@ const flexibleOverlayProps = {
6008
6008
  default: false
6009
6009
  }
6010
6010
  };
6011
- function getScrollParent(element) {
6012
- const overflowRegex = /(auto|scroll|hidden)/;
6013
- for (let parent = element; parent = parent.parentElement; parent.parentElement !== document.body) {
6014
- const style = window.getComputedStyle(parent);
6015
- if (overflowRegex.test(style.overflow + style.overflowX + style.overflowY)) {
6016
- return parent;
6017
- }
6018
- }
6019
- return window;
6020
- }
6021
6011
  function adjustArrowPosition(isArrowCenter, point, placement, originRect) {
6022
6012
  let { x, y } = point;
6023
6013
  if (!isArrowCenter) {
@@ -6038,9 +6028,9 @@ function adjustArrowPosition(isArrowCenter, point, placement, originRect) {
6038
6028
  return { x, y };
6039
6029
  }
6040
6030
  function useOverlay(props, emit) {
6031
+ const { position, showArrow } = toRefs(props);
6041
6032
  const overlayRef = ref();
6042
6033
  const arrowRef = ref();
6043
- let originParent = null;
6044
6034
  const updateArrowPosition = (arrowEl, placement, point, overlayEl) => {
6045
6035
  const { x, y } = adjustArrowPosition(props.isArrowCenter, point, placement, overlayEl.getBoundingClientRect());
6046
6036
  const staticSide = {
@@ -6061,51 +6051,42 @@ function useOverlay(props, emit) {
6061
6051
  const hostEl = props.origin;
6062
6052
  const overlayEl = unref(overlayRef.value);
6063
6053
  const arrowEl = unref(arrowRef.value);
6064
- const middleware = [
6065
- offset(props.offset),
6066
- autoPlacement({
6067
- alignment: props.align,
6068
- allowedPlacements: props.position
6069
- })
6070
- ];
6071
- props.showArrow && middleware.push(arrow({ element: arrowEl }));
6072
- props.shiftOffset !== void 0 && middleware.push(shift());
6073
- if (!overlayEl) {
6074
- return;
6054
+ const [mainPosition, ...fallbackPosition] = position.value;
6055
+ const middleware = [offset(props.offset)];
6056
+ middleware.push(fallbackPosition.length ? flip({ fallbackPlacements: fallbackPosition }) : flip());
6057
+ if (showArrow.value) {
6058
+ middleware.push(arrow({ element: arrowRef.value }));
6075
6059
  }
6076
6060
  const { x, y, placement, middlewareData } = await computePosition(hostEl, overlayEl, {
6077
6061
  strategy: "fixed",
6062
+ placement: mainPosition,
6078
6063
  middleware
6079
6064
  });
6080
6065
  let applyX = x;
6081
6066
  let applyY = y;
6082
- if (props.shiftOffset !== void 0) {
6083
- const { x: shiftX, y: shiftY } = middlewareData.shift;
6084
- shiftX < 0 && (applyX -= props.shiftOffset);
6085
- shiftX > 0 && (applyX += props.shiftOffset);
6086
- shiftY < 0 && (applyY -= props.shiftOffset);
6087
- shiftY > 0 && (applyY += props.shiftOffset);
6088
- }
6089
6067
  emit("positionChange", placement);
6090
6068
  Object.assign(overlayEl.style, { top: `${applyY}px`, left: `${applyX}px` });
6091
6069
  props.showArrow && updateArrowPosition(arrowEl, placement, middlewareData.arrow, overlayEl);
6092
6070
  };
6071
+ const scrollCallback = (e) => {
6072
+ var _a, _b;
6073
+ const scrollElement = e.target;
6074
+ if (scrollElement == null ? void 0 : scrollElement.contains((_b = (_a = props.origin) == null ? void 0 : _a.$el) != null ? _b : props.origin)) {
6075
+ updatePosition();
6076
+ }
6077
+ };
6093
6078
  watch(() => props.modelValue, () => {
6094
6079
  if (props.modelValue && props.origin) {
6095
- originParent = getScrollParent(props.origin);
6096
6080
  nextTick(updatePosition);
6097
- originParent == null ? void 0 : originParent.addEventListener("scroll", updatePosition);
6098
- originParent !== window && window.addEventListener("scroll", updatePosition);
6081
+ window.addEventListener("scroll", scrollCallback, true);
6099
6082
  window.addEventListener("resize", updatePosition);
6100
6083
  } else {
6101
- originParent == null ? void 0 : originParent.removeEventListener("scroll", updatePosition);
6102
- originParent !== window && window.removeEventListener("scroll", updatePosition);
6084
+ window.removeEventListener("scroll", scrollCallback, true);
6103
6085
  window.removeEventListener("resize", updatePosition);
6104
6086
  }
6105
6087
  });
6106
6088
  onUnmounted(() => {
6107
- originParent == null ? void 0 : originParent.removeEventListener("scroll", updatePosition);
6108
- originParent !== window && window.removeEventListener("scroll", updatePosition);
6089
+ window.removeEventListener("scroll", scrollCallback, true);
6109
6090
  window.removeEventListener("resize", updatePosition);
6110
6091
  });
6111
6092
  return { arrowRef, overlayRef, updatePosition };