bitboss-ui 2.1.12 → 2.1.14

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 (183) hide show
  1. package/dist/components/BbDropdown/BbDropdown.vue.d.ts +12 -2
  2. package/dist/components/BbPopover/BbPopover.vue.d.ts +12 -2
  3. package/dist/components/BbTooltip/BbTooltip.vue.d.ts +12 -2
  4. package/dist/components/CommonPopover.vue.d.ts +2 -0
  5. package/dist/index.css +1 -1
  6. package/dist/index106.js +7 -7
  7. package/dist/index113.js +1 -1
  8. package/dist/index121.js +11 -11
  9. package/dist/index129.js +1 -1
  10. package/dist/index13.js +1 -1
  11. package/dist/index131.js +3 -3
  12. package/dist/index133.js +1 -1
  13. package/dist/index136.js +1 -1
  14. package/dist/index138.js +1 -1
  15. package/dist/index139.js +2 -2
  16. package/dist/index15.js +8 -8
  17. package/dist/index17.js +3 -3
  18. package/dist/index19.js +8 -8
  19. package/dist/index207.js +2 -2
  20. package/dist/index208.js +2 -2
  21. package/dist/index209.js +86 -5
  22. package/dist/index21.js +16 -16
  23. package/dist/index211.js +29 -5
  24. package/dist/index212.js +17 -5
  25. package/dist/index213.js +51 -5
  26. package/dist/index214.js +15 -5
  27. package/dist/index215.js +3 -2
  28. package/dist/index216.js +12 -2
  29. package/dist/index217.js +16 -2
  30. package/dist/index218.js +33 -12
  31. package/dist/index219.js +4 -11
  32. package/dist/index220.js +13 -20
  33. package/dist/index221.js +11 -66
  34. package/dist/index222.js +22 -0
  35. package/dist/index223.js +197 -13
  36. package/dist/index225.js +68 -0
  37. package/dist/index227.js +13 -2
  38. package/dist/index228.js +114 -4
  39. package/dist/index23.js +15 -15
  40. package/dist/index230.js +2 -86
  41. package/dist/{index226.js → index231.js} +1 -1
  42. package/dist/index232.js +2 -29
  43. package/dist/index233.js +2 -17
  44. package/dist/index234.js +6 -50
  45. package/dist/index235.js +2 -15
  46. package/dist/index236.js +7 -3
  47. package/dist/index237.js +4 -12
  48. package/dist/index238.js +2 -16
  49. package/dist/index239.js +106 -2
  50. package/dist/index241.js +100 -7
  51. package/dist/index243.js +2 -106
  52. package/dist/index244.js +7 -0
  53. package/dist/index245.js +5 -100
  54. package/dist/index246.js +7 -0
  55. package/dist/index247.js +5 -4
  56. package/dist/index248.js +5 -197
  57. package/dist/index249.js +7 -0
  58. package/dist/index25.js +3 -3
  59. package/dist/index250.js +2 -34
  60. package/dist/index252.js +5 -18
  61. package/dist/index253.js +5 -12
  62. package/dist/index254.js +7 -5
  63. package/dist/index255.js +238 -218
  64. package/dist/index256.js +51 -12
  65. package/dist/index257.js +44 -5
  66. package/dist/index258.js +5 -5
  67. package/dist/index259.js +58 -6
  68. package/dist/index260.js +12 -249
  69. package/dist/index261.js +8 -51
  70. package/dist/index262.js +23 -44
  71. package/dist/index263.js +18 -5
  72. package/dist/index264.js +12 -60
  73. package/dist/index265.js +6 -6
  74. package/dist/index266.js +230 -15
  75. package/dist/index267.js +9 -8
  76. package/dist/index268.js +3 -23
  77. package/dist/index269.js +6 -10
  78. package/dist/index27.js +1 -1
  79. package/dist/index270.js +16 -3
  80. package/dist/index271.js +1 -1
  81. package/dist/index273.js +1 -1
  82. package/dist/index275.js +2 -5
  83. package/dist/index276.js +67 -2
  84. package/dist/index277.js +5 -67
  85. package/dist/index278.js +7 -4
  86. package/dist/index279.js +5 -8
  87. package/dist/index280.js +3 -280
  88. package/dist/index281.js +17 -2
  89. package/dist/index282.js +26 -123
  90. package/dist/index283.js +2 -2
  91. package/dist/index284.js +3 -15
  92. package/dist/index285.js +3 -2
  93. package/dist/index287.js +7 -2
  94. package/dist/index288.js +3 -16
  95. package/dist/index289.js +7 -2
  96. package/dist/index29.js +4 -4
  97. package/dist/index290.js +10 -18
  98. package/dist/index291.js +4 -2
  99. package/dist/index292.js +5 -3
  100. package/dist/index293.js +6 -0
  101. package/dist/index294.js +3 -7
  102. package/dist/index295.js +1 -1
  103. package/dist/index296.js +280 -7
  104. package/dist/index297.js +2 -11
  105. package/dist/index298.js +125 -5
  106. package/dist/index299.js +2 -4
  107. package/dist/index300.js +14 -5
  108. package/dist/index301.js +2 -4
  109. package/dist/index302.js +16 -3
  110. package/dist/index303.js +2 -17
  111. package/dist/index304.js +15 -27
  112. package/dist/index305.js +2 -3
  113. package/dist/index306.js +19 -3
  114. package/dist/index307.js +2 -3
  115. package/dist/index308.js +6 -2
  116. package/dist/index309.js +19 -2
  117. package/dist/index31.js +2 -2
  118. package/dist/index310.js +2 -19
  119. package/dist/index311.js +27 -2
  120. package/dist/index312.js +2 -27
  121. package/dist/index313.js +2 -2
  122. package/dist/index314.js +1 -1
  123. package/dist/index315.js +1 -1
  124. package/dist/index316.js +1 -1
  125. package/dist/index317.js +21 -1
  126. package/dist/index319.js +4 -0
  127. package/dist/index320.js +5 -718
  128. package/dist/index321.js +715 -363
  129. package/dist/index322.js +366 -58
  130. package/dist/index323.js +58 -5
  131. package/dist/index324.js +1 -1
  132. package/dist/index325.js +128 -32
  133. package/dist/index326.js +369 -28
  134. package/dist/index327.js +35 -0
  135. package/dist/index328.js +27 -227
  136. package/dist/index33.js +8 -8
  137. package/dist/index330.js +7 -58
  138. package/dist/index331.js +17 -127
  139. package/dist/index332.js +56 -367
  140. package/dist/index333.js +58 -47
  141. package/dist/index334.js +6 -7
  142. package/dist/index335.js +227 -5
  143. package/dist/index336.js +8 -8
  144. package/dist/index337.js +5 -6
  145. package/dist/index338.js +8 -19
  146. package/dist/index339.js +46 -6
  147. package/dist/index340.js +1 -1
  148. package/dist/index341.js +131 -0
  149. package/dist/index343.js +3 -129
  150. package/dist/index344.js +421 -473
  151. package/dist/index345.js +113 -422
  152. package/dist/index346.js +484 -123
  153. package/dist/index35.js +4 -4
  154. package/dist/index37.js +209 -200
  155. package/dist/index39.js +8 -8
  156. package/dist/index41.js +2 -2
  157. package/dist/index43.js +8 -8
  158. package/dist/index45.js +8 -8
  159. package/dist/index47.js +2 -2
  160. package/dist/index49.js +2 -2
  161. package/dist/index53.js +1 -1
  162. package/dist/index55.js +1 -1
  163. package/dist/index57.js +2 -2
  164. package/dist/index61.js +3 -3
  165. package/dist/index67.js +1 -1
  166. package/dist/index79.js +4 -4
  167. package/dist/index81.js +1 -1
  168. package/dist/index83.js +2 -2
  169. package/dist/index85.js +1 -1
  170. package/dist/index90.js +3 -3
  171. package/dist/index92.js +1 -1
  172. package/dist/index94.js +3 -3
  173. package/dist/index96.js +1 -1
  174. package/package.json +2 -2
  175. package/dist/index210.js +0 -7
  176. package/dist/index224.js +0 -115
  177. package/dist/index229.js +0 -4
  178. package/dist/index240.js +0 -4
  179. package/dist/index242.js +0 -9
  180. package/dist/index286.js +0 -18
  181. package/dist/index318.js +0 -24
  182. package/dist/index329.js +0 -60
  183. package/dist/index342.js +0 -5
package/dist/index344.js CHANGED
@@ -1,490 +1,438 @@
1
- import { debounce as M, memo as d, notUndefined as m, approxEqual as y } from "./index347.js";
2
- const b = (r) => {
3
- const { offsetWidth: h, offsetHeight: t } = r;
4
- return { width: h, height: t };
5
- }, z = (r) => r, w = (r) => {
6
- const h = Math.max(r.startIndex - r.overscan, 0), t = Math.min(r.endIndex + r.overscan, r.count - 1), s = [];
7
- for (let e = h; e <= t; e++)
8
- s.push(e);
9
- return s;
10
- }, _ = (r, h) => {
11
- const t = r.scrollElement;
12
- if (!t)
13
- return;
14
- const s = r.targetWindow;
15
- if (!s)
16
- return;
17
- const e = (n) => {
18
- const { width: o, height: a } = n;
19
- h({ width: Math.round(o), height: Math.round(a) });
20
- };
21
- if (e(b(t)), !s.ResizeObserver)
22
- return () => {
23
- };
24
- const i = new s.ResizeObserver((n) => {
25
- const o = () => {
26
- const a = n[0];
27
- if (a != null && a.borderBoxSize) {
28
- const c = a.borderBoxSize[0];
29
- if (c) {
30
- e({ width: c.inlineSize, height: c.blockSize });
31
- return;
32
- }
1
+ import { evaluate as F, getSide as M, getSideAxis as j, getOppositePlacement as Q, getExpandedPlacements as U, getOppositeAxisPlacements as Z, getAlignmentSides as ee, clamp as Y, getPaddingObject as G, rectToClientRect as _, getAlignment as X, getOppositeAxis as te, sides as ne, getAlignmentAxis as J, getAxisLength as K, min as z } from "./index345.js";
2
+ function I(t, e, f) {
3
+ let {
4
+ reference: s,
5
+ floating: a
6
+ } = t;
7
+ const n = j(e), o = J(e), c = K(o), u = M(e), g = n === "y", d = s.x + s.width / 2 - a.width / 2, r = s.y + s.height / 2 - a.height / 2, m = s[c] / 2 - a[c] / 2;
8
+ let i;
9
+ switch (u) {
10
+ case "top":
11
+ i = {
12
+ x: d,
13
+ y: s.y - a.height
14
+ };
15
+ break;
16
+ case "bottom":
17
+ i = {
18
+ x: d,
19
+ y: s.y + s.height
20
+ };
21
+ break;
22
+ case "right":
23
+ i = {
24
+ x: s.x + s.width,
25
+ y: r
26
+ };
27
+ break;
28
+ case "left":
29
+ i = {
30
+ x: s.x - a.width,
31
+ y: r
32
+ };
33
+ break;
34
+ default:
35
+ i = {
36
+ x: s.x,
37
+ y: s.y
38
+ };
39
+ }
40
+ switch (X(e)) {
41
+ case "start":
42
+ i[o] -= m * (f && g ? -1 : 1);
43
+ break;
44
+ case "end":
45
+ i[o] += m * (f && g ? -1 : 1);
46
+ break;
47
+ }
48
+ return i;
49
+ }
50
+ const oe = async (t, e, f) => {
51
+ const {
52
+ placement: s = "bottom",
53
+ strategy: a = "absolute",
54
+ middleware: n = [],
55
+ platform: o
56
+ } = f, c = n.filter(Boolean), u = await (o.isRTL == null ? void 0 : o.isRTL(e));
57
+ let g = await o.getElementRects({
58
+ reference: t,
59
+ floating: e,
60
+ strategy: a
61
+ }), {
62
+ x: d,
63
+ y: r
64
+ } = I(g, s, u), m = s, i = {}, l = 0;
65
+ for (let w = 0; w < c.length; w++) {
66
+ const {
67
+ name: x,
68
+ fn: h
69
+ } = c[w], {
70
+ x: y,
71
+ y: v,
72
+ data: b,
73
+ reset: p
74
+ } = await h({
75
+ x: d,
76
+ y: r,
77
+ initialPlacement: s,
78
+ placement: m,
79
+ strategy: a,
80
+ middlewareData: i,
81
+ rects: g,
82
+ platform: o,
83
+ elements: {
84
+ reference: t,
85
+ floating: e
33
86
  }
34
- e(b(t));
35
- };
36
- r.options.useAnimationFrameWithResizeObserver ? requestAnimationFrame(o) : o();
37
- });
38
- return i.observe(t, { box: "border-box" }), () => {
39
- i.unobserve(t);
40
- };
41
- }, x = {
42
- passive: !0
43
- }, E = typeof window > "u" ? !0 : "onscrollend" in window, A = (r, h) => {
44
- const t = r.scrollElement;
45
- if (!t)
46
- return;
47
- const s = r.targetWindow;
48
- if (!s)
49
- return;
50
- let e = 0;
51
- const i = r.options.useScrollendEvent && E ? () => {
52
- } : M(
53
- s,
54
- () => {
55
- h(e, !1);
56
- },
57
- r.options.isScrollingResetDelay
58
- ), n = (l) => () => {
59
- const { horizontal: f, isRtl: u } = r.options;
60
- e = f ? t.scrollLeft * (u && -1 || 1) : t.scrollTop, i(), h(e, l);
61
- }, o = n(!0), a = n(!1);
62
- a(), t.addEventListener("scroll", o, x);
63
- const c = r.options.useScrollendEvent && E;
64
- return c && t.addEventListener("scrollend", a, x), () => {
65
- t.removeEventListener("scroll", o), c && t.removeEventListener("scrollend", a);
66
- };
67
- }, C = (r, h, t) => {
68
- if (h != null && h.borderBoxSize) {
69
- const s = h.borderBoxSize[0];
70
- if (s)
71
- return Math.round(
72
- s[t.options.horizontal ? "inlineSize" : "blockSize"]
73
- );
87
+ });
88
+ d = y ?? d, r = v ?? r, i = {
89
+ ...i,
90
+ [x]: {
91
+ ...i[x],
92
+ ...b
93
+ }
94
+ }, p && l <= 50 && (l++, typeof p == "object" && (p.placement && (m = p.placement), p.rects && (g = p.rects === !0 ? await o.getElementRects({
95
+ reference: t,
96
+ floating: e,
97
+ strategy: a
98
+ }) : p.rects), {
99
+ x: d,
100
+ y: r
101
+ } = I(g, m, u)), w = -1);
74
102
  }
75
- return r[t.options.horizontal ? "offsetWidth" : "offsetHeight"];
76
- }, D = (r, {
77
- adjustments: h = 0,
78
- behavior: t
79
- }, s) => {
80
- var e, i;
81
- const n = r + h;
82
- (i = (e = s.scrollElement) == null ? void 0 : e.scrollTo) == null || i.call(e, {
83
- [s.options.horizontal ? "left" : "top"]: n,
84
- behavior: t
85
- });
103
+ return {
104
+ x: d,
105
+ y: r,
106
+ placement: m,
107
+ strategy: a,
108
+ middlewareData: i
109
+ };
86
110
  };
87
- class N {
88
- constructor(h) {
89
- this.unsubs = [], this.scrollElement = null, this.targetWindow = null, this.isScrolling = !1, this.scrollToIndexTimeoutId = null, this.measurementsCache = [], this.itemSizeCache = /* @__PURE__ */ new Map(), this.pendingMeasuredCacheIndexes = [], this.scrollRect = null, this.scrollOffset = null, this.scrollDirection = null, this.scrollAdjustments = 0, this.elementsCache = /* @__PURE__ */ new Map(), this.observer = /* @__PURE__ */ (() => {
90
- let t = null;
91
- const s = () => t || (!this.targetWindow || !this.targetWindow.ResizeObserver ? null : t = new this.targetWindow.ResizeObserver((e) => {
92
- e.forEach((i) => {
93
- const n = () => {
94
- this._measureElement(i.target, i);
95
- };
96
- this.options.useAnimationFrameWithResizeObserver ? requestAnimationFrame(n) : n();
97
- });
98
- }));
99
- return {
100
- disconnect: () => {
101
- var e;
102
- (e = s()) == null || e.disconnect(), t = null;
103
- },
104
- observe: (e) => {
105
- var i;
106
- return (i = s()) == null ? void 0 : i.observe(e, { box: "border-box" });
107
- },
108
- unobserve: (e) => {
109
- var i;
110
- return (i = s()) == null ? void 0 : i.unobserve(e);
111
+ async function $(t, e) {
112
+ var f;
113
+ e === void 0 && (e = {});
114
+ const {
115
+ x: s,
116
+ y: a,
117
+ platform: n,
118
+ rects: o,
119
+ elements: c,
120
+ strategy: u
121
+ } = t, {
122
+ boundary: g = "clippingAncestors",
123
+ rootBoundary: d = "viewport",
124
+ elementContext: r = "floating",
125
+ altBoundary: m = !1,
126
+ padding: i = 0
127
+ } = F(e, t), l = G(i), x = c[m ? r === "floating" ? "reference" : "floating" : r], h = _(await n.getClippingRect({
128
+ element: (f = await (n.isElement == null ? void 0 : n.isElement(x))) == null || f ? x : x.contextElement || await (n.getDocumentElement == null ? void 0 : n.getDocumentElement(c.floating)),
129
+ boundary: g,
130
+ rootBoundary: d,
131
+ strategy: u
132
+ })), y = r === "floating" ? {
133
+ x: s,
134
+ y: a,
135
+ width: o.floating.width,
136
+ height: o.floating.height
137
+ } : o.reference, v = await (n.getOffsetParent == null ? void 0 : n.getOffsetParent(c.floating)), b = await (n.isElement == null ? void 0 : n.isElement(v)) ? await (n.getScale == null ? void 0 : n.getScale(v)) || {
138
+ x: 1,
139
+ y: 1
140
+ } : {
141
+ x: 1,
142
+ y: 1
143
+ }, p = _(n.convertOffsetParentRelativeRectToViewportRelativeRect ? await n.convertOffsetParentRelativeRectToViewportRelativeRect({
144
+ elements: c,
145
+ rect: y,
146
+ offsetParent: v,
147
+ strategy: u
148
+ }) : y);
149
+ return {
150
+ top: (h.top - p.top + l.top) / b.y,
151
+ bottom: (p.bottom - h.bottom + l.bottom) / b.y,
152
+ left: (h.left - p.left + l.left) / b.x,
153
+ right: (p.right - h.right + l.right) / b.x
154
+ };
155
+ }
156
+ const ae = (t) => ({
157
+ name: "arrow",
158
+ options: t,
159
+ async fn(e) {
160
+ const {
161
+ x: f,
162
+ y: s,
163
+ placement: a,
164
+ rects: n,
165
+ platform: o,
166
+ elements: c,
167
+ middlewareData: u
168
+ } = e, {
169
+ element: g,
170
+ padding: d = 0
171
+ } = F(t, e) || {};
172
+ if (g == null)
173
+ return {};
174
+ const r = G(d), m = {
175
+ x: f,
176
+ y: s
177
+ }, i = J(a), l = K(i), w = await o.getDimensions(g), x = i === "y", h = x ? "top" : "left", y = x ? "bottom" : "right", v = x ? "clientHeight" : "clientWidth", b = n.reference[l] + n.reference[i] - m[i] - n.floating[l], p = m[i] - n.reference[i], T = await (o.getOffsetParent == null ? void 0 : o.getOffsetParent(g));
178
+ let S = T ? T[v] : 0;
179
+ (!S || !await (o.isElement == null ? void 0 : o.isElement(T))) && (S = c.floating[v] || n.floating[l]);
180
+ const V = b / 2 - p / 2, D = S / 2 - w[l] / 2 - 1, R = z(r[h], D), B = z(r[y], D), E = R, H = S - w[l] - B, A = S / 2 - w[l] / 2 + V, L = Y(E, A, H), O = !u.arrow && X(a) != null && A !== L && n.reference[l] / 2 - (A < E ? R : B) - w[l] / 2 < 0, P = O ? A < E ? A - E : A - H : 0;
181
+ return {
182
+ [i]: m[i] + P,
183
+ data: {
184
+ [i]: L,
185
+ centerOffset: A - L - P,
186
+ ...O && {
187
+ alignmentOffset: P
111
188
  }
112
- };
113
- })(), this.range = null, this.setOptions = (t) => {
114
- Object.entries(t).forEach(([s, e]) => {
115
- typeof e > "u" && delete t[s];
116
- }), this.options = {
117
- debug: !1,
118
- initialOffset: 0,
119
- overscan: 1,
120
- paddingStart: 0,
121
- paddingEnd: 0,
122
- scrollPaddingStart: 0,
123
- scrollPaddingEnd: 0,
124
- horizontal: !1,
125
- getItemKey: z,
126
- rangeExtractor: w,
127
- onChange: () => {
128
- },
129
- measureElement: C,
130
- initialRect: { width: 0, height: 0 },
131
- scrollMargin: 0,
132
- gap: 0,
133
- indexAttribute: "data-index",
134
- initialMeasurementsCache: [],
135
- lanes: 1,
136
- isScrollingResetDelay: 150,
137
- enabled: !0,
138
- isRtl: !1,
139
- useScrollendEvent: !1,
140
- useAnimationFrameWithResizeObserver: !1,
141
- ...t
142
- };
143
- }, this.notify = (t) => {
144
- var s, e;
145
- (e = (s = this.options).onChange) == null || e.call(s, this, t);
146
- }, this.maybeNotify = d(
147
- () => (this.calculateRange(), [
148
- this.isScrolling,
149
- this.range ? this.range.startIndex : null,
150
- this.range ? this.range.endIndex : null
151
- ]),
152
- (t) => {
153
- this.notify(t);
154
189
  },
155
- {
156
- key: process.env.NODE_ENV !== "production" && "maybeNotify",
157
- debug: () => this.options.debug,
158
- initialDeps: [
159
- this.isScrolling,
160
- this.range ? this.range.startIndex : null,
161
- this.range ? this.range.endIndex : null
162
- ]
163
- }
164
- ), this.cleanup = () => {
165
- this.unsubs.filter(Boolean).forEach((t) => t()), this.unsubs = [], this.observer.disconnect(), this.scrollElement = null, this.targetWindow = null;
166
- }, this._didMount = () => () => {
167
- this.cleanup();
168
- }, this._willUpdate = () => {
169
- var t;
170
- const s = this.options.enabled ? this.options.getScrollElement() : null;
171
- if (this.scrollElement !== s) {
172
- if (this.cleanup(), !s) {
173
- this.maybeNotify();
174
- return;
175
- }
176
- this.scrollElement = s, this.scrollElement && "ownerDocument" in this.scrollElement ? this.targetWindow = this.scrollElement.ownerDocument.defaultView : this.targetWindow = ((t = this.scrollElement) == null ? void 0 : t.window) ?? null, this.elementsCache.forEach((e) => {
177
- this.observer.observe(e);
178
- }), this._scrollToOffset(this.getScrollOffset(), {
179
- adjustments: void 0,
180
- behavior: void 0
181
- }), this.unsubs.push(
182
- this.options.observeElementRect(this, (e) => {
183
- this.scrollRect = e, this.maybeNotify();
184
- })
185
- ), this.unsubs.push(
186
- this.options.observeElementOffset(this, (e, i) => {
187
- this.scrollAdjustments = 0, this.scrollDirection = i ? this.getScrollOffset() < e ? "forward" : "backward" : null, this.scrollOffset = e, this.isScrolling = i, this.maybeNotify();
188
- })
189
- );
190
- }
191
- }, this.getSize = () => this.options.enabled ? (this.scrollRect = this.scrollRect ?? this.options.initialRect, this.scrollRect[this.options.horizontal ? "width" : "height"]) : (this.scrollRect = null, 0), this.getScrollOffset = () => this.options.enabled ? (this.scrollOffset = this.scrollOffset ?? (typeof this.options.initialOffset == "function" ? this.options.initialOffset() : this.options.initialOffset), this.scrollOffset) : (this.scrollOffset = null, 0), this.getFurthestMeasurement = (t, s) => {
192
- const e = /* @__PURE__ */ new Map(), i = /* @__PURE__ */ new Map();
193
- for (let n = s - 1; n >= 0; n--) {
194
- const o = t[n];
195
- if (e.has(o.lane))
196
- continue;
197
- const a = i.get(
198
- o.lane
199
- );
200
- if (a == null || o.end > a.end ? i.set(o.lane, o) : o.end < a.end && e.set(o.lane, !0), e.size === this.options.lanes)
201
- break;
190
+ reset: O
191
+ };
192
+ }
193
+ }), ce = function(t) {
194
+ return t === void 0 && (t = {}), {
195
+ name: "flip",
196
+ options: t,
197
+ async fn(e) {
198
+ var f, s;
199
+ const {
200
+ placement: a,
201
+ middlewareData: n,
202
+ rects: o,
203
+ initialPlacement: c,
204
+ platform: u,
205
+ elements: g
206
+ } = e, {
207
+ mainAxis: d = !0,
208
+ crossAxis: r = !0,
209
+ fallbackPlacements: m,
210
+ fallbackStrategy: i = "bestFit",
211
+ fallbackAxisSideDirection: l = "none",
212
+ flipAlignment: w = !0,
213
+ ...x
214
+ } = F(t, e);
215
+ if ((f = n.arrow) != null && f.alignmentOffset)
216
+ return {};
217
+ const h = M(a), y = j(c), v = M(c) === c, b = await (u.isRTL == null ? void 0 : u.isRTL(g.floating)), p = m || (v || !w ? [Q(c)] : U(c)), T = l !== "none";
218
+ !m && T && p.push(...Z(c, w, l, b));
219
+ const S = [c, ...p], V = await $(e, x), D = [];
220
+ let R = ((s = n.flip) == null ? void 0 : s.overflows) || [];
221
+ if (d && D.push(V[h]), r) {
222
+ const A = ee(a, o, b);
223
+ D.push(V[A[0]], V[A[1]]);
202
224
  }
203
- return i.size === this.options.lanes ? Array.from(i.values()).sort((n, o) => n.end === o.end ? n.index - o.index : n.end - o.end)[0] : void 0;
204
- }, this.getMeasurementOptions = d(
205
- () => [
206
- this.options.count,
207
- this.options.paddingStart,
208
- this.options.scrollMargin,
209
- this.options.getItemKey,
210
- this.options.enabled
211
- ],
212
- (t, s, e, i, n) => (this.pendingMeasuredCacheIndexes = [], {
213
- count: t,
214
- paddingStart: s,
215
- scrollMargin: e,
216
- getItemKey: i,
217
- enabled: n
218
- }),
219
- {
220
- key: !1
225
+ if (R = [...R, {
226
+ placement: a,
227
+ overflows: D
228
+ }], !D.every((A) => A <= 0)) {
229
+ var B, E;
230
+ const A = (((B = n.flip) == null ? void 0 : B.index) || 0) + 1, L = S[A];
231
+ if (L)
232
+ return {
233
+ data: {
234
+ index: A,
235
+ overflows: R
236
+ },
237
+ reset: {
238
+ placement: L
239
+ }
240
+ };
241
+ let O = (E = R.filter((P) => P.overflows[0] <= 0).sort((P, k) => P.overflows[1] - k.overflows[1])[0]) == null ? void 0 : E.placement;
242
+ if (!O)
243
+ switch (i) {
244
+ case "bestFit": {
245
+ var H;
246
+ const P = (H = R.filter((k) => {
247
+ if (T) {
248
+ const C = j(k.placement);
249
+ return C === y || // Create a bias to the `y` side axis due to horizontal
250
+ // reading directions favoring greater width.
251
+ C === "y";
252
+ }
253
+ return !0;
254
+ }).map((k) => [k.placement, k.overflows.filter((C) => C > 0).reduce((C, N) => C + N, 0)]).sort((k, C) => k[1] - C[1])[0]) == null ? void 0 : H[0];
255
+ P && (O = P);
256
+ break;
257
+ }
258
+ case "initialPlacement":
259
+ O = c;
260
+ break;
261
+ }
262
+ if (a !== O)
263
+ return {
264
+ reset: {
265
+ placement: O
266
+ }
267
+ };
221
268
  }
222
- ), this.getMeasurements = d(
223
- () => [this.getMeasurementOptions(), this.itemSizeCache],
224
- ({ count: t, paddingStart: s, scrollMargin: e, getItemKey: i, enabled: n }, o) => {
225
- if (!n)
226
- return this.measurementsCache = [], this.itemSizeCache.clear(), [];
227
- this.measurementsCache.length === 0 && (this.measurementsCache = this.options.initialMeasurementsCache, this.measurementsCache.forEach((l) => {
228
- this.itemSizeCache.set(l.key, l.size);
229
- }));
230
- const a = this.pendingMeasuredCacheIndexes.length > 0 ? Math.min(...this.pendingMeasuredCacheIndexes) : 0;
231
- this.pendingMeasuredCacheIndexes = [];
232
- const c = this.measurementsCache.slice(0, a);
233
- for (let l = a; l < t; l++) {
234
- const f = i(l), u = this.options.lanes === 1 ? c[l - 1] : this.getFurthestMeasurement(c, l), g = u ? u.end + this.options.gap : s + e, p = o.get(f), v = typeof p == "number" ? p : this.options.estimateSize(l), O = g + v, I = u ? u.lane : l % this.options.lanes;
235
- c[l] = {
236
- index: l,
237
- start: g,
238
- size: v,
239
- end: O,
240
- key: f,
241
- lane: I
269
+ return {};
270
+ }
271
+ };
272
+ };
273
+ function W(t, e) {
274
+ return {
275
+ top: t.top - e.height,
276
+ right: t.right - e.width,
277
+ bottom: t.bottom - e.height,
278
+ left: t.left - e.width
279
+ };
280
+ }
281
+ function q(t) {
282
+ return ne.some((e) => t[e] >= 0);
283
+ }
284
+ const le = function(t) {
285
+ return t === void 0 && (t = {}), {
286
+ name: "hide",
287
+ options: t,
288
+ async fn(e) {
289
+ const {
290
+ rects: f
291
+ } = e, {
292
+ strategy: s = "referenceHidden",
293
+ ...a
294
+ } = F(t, e);
295
+ switch (s) {
296
+ case "referenceHidden": {
297
+ const n = await $(e, {
298
+ ...a,
299
+ elementContext: "reference"
300
+ }), o = W(n, f.reference);
301
+ return {
302
+ data: {
303
+ referenceHiddenOffsets: o,
304
+ referenceHidden: q(o)
305
+ }
242
306
  };
243
307
  }
244
- return this.measurementsCache = c, c;
245
- },
246
- {
247
- key: process.env.NODE_ENV !== "production" && "getMeasurements",
248
- debug: () => this.options.debug
249
- }
250
- ), this.calculateRange = d(
251
- () => [
252
- this.getMeasurements(),
253
- this.getSize(),
254
- this.getScrollOffset(),
255
- this.options.lanes
256
- ],
257
- (t, s, e, i) => this.range = t.length > 0 && s > 0 ? T({
258
- measurements: t,
259
- outerSize: s,
260
- scrollOffset: e,
261
- lanes: i
262
- }) : null,
263
- {
264
- key: process.env.NODE_ENV !== "production" && "calculateRange",
265
- debug: () => this.options.debug
266
- }
267
- ), this.getVirtualIndexes = d(
268
- () => {
269
- let t = null, s = null;
270
- const e = this.calculateRange();
271
- return e && (t = e.startIndex, s = e.endIndex), this.maybeNotify.updateDeps([this.isScrolling, t, s]), [
272
- this.options.rangeExtractor,
273
- this.options.overscan,
274
- this.options.count,
275
- t,
276
- s
277
- ];
278
- },
279
- (t, s, e, i, n) => i === null || n === null ? [] : t({
280
- startIndex: i,
281
- endIndex: n,
282
- overscan: s,
283
- count: e
284
- }),
285
- {
286
- key: process.env.NODE_ENV !== "production" && "getVirtualIndexes",
287
- debug: () => this.options.debug
288
- }
289
- ), this.indexFromElement = (t) => {
290
- const s = this.options.indexAttribute, e = t.getAttribute(s);
291
- return e ? parseInt(e, 10) : (console.warn(
292
- `Missing attribute name '${s}={index}' on measured element.`
293
- ), -1);
294
- }, this._measureElement = (t, s) => {
295
- const e = this.indexFromElement(t), i = this.measurementsCache[e];
296
- if (!i)
297
- return;
298
- const n = i.key, o = this.elementsCache.get(n);
299
- o !== t && (o && this.observer.unobserve(o), this.observer.observe(t), this.elementsCache.set(n, t)), t.isConnected && this.resizeItem(e, this.options.measureElement(t, s, this));
300
- }, this.resizeItem = (t, s) => {
301
- const e = this.measurementsCache[t];
302
- if (!e)
303
- return;
304
- const i = this.itemSizeCache.get(e.key) ?? e.size, n = s - i;
305
- n !== 0 && ((this.shouldAdjustScrollPositionOnItemSizeChange !== void 0 ? this.shouldAdjustScrollPositionOnItemSizeChange(e, n, this) : e.start < this.getScrollOffset() + this.scrollAdjustments) && (process.env.NODE_ENV !== "production" && this.options.debug && console.info("correction", n), this._scrollToOffset(this.getScrollOffset(), {
306
- adjustments: this.scrollAdjustments += n,
307
- behavior: void 0
308
- })), this.pendingMeasuredCacheIndexes.push(e.index), this.itemSizeCache = new Map(this.itemSizeCache.set(e.key, s)), this.notify(!1));
309
- }, this.measureElement = (t) => {
310
- if (!t) {
311
- this.elementsCache.forEach((s, e) => {
312
- s.isConnected || (this.observer.unobserve(s), this.elementsCache.delete(e));
313
- });
314
- return;
308
+ case "escaped": {
309
+ const n = await $(e, {
310
+ ...a,
311
+ altBoundary: !0
312
+ }), o = W(n, f.floating);
313
+ return {
314
+ data: {
315
+ escapedOffsets: o,
316
+ escaped: q(o)
317
+ }
318
+ };
319
+ }
320
+ default:
321
+ return {};
315
322
  }
316
- this._measureElement(t, void 0);
317
- }, this.getVirtualItems = d(
318
- () => [this.getVirtualIndexes(), this.getMeasurements()],
319
- (t, s) => {
320
- const e = [];
321
- for (let i = 0, n = t.length; i < n; i++) {
322
- const o = t[i], a = s[o];
323
- e.push(a);
323
+ }
324
+ };
325
+ };
326
+ async function ie(t, e) {
327
+ const {
328
+ placement: f,
329
+ platform: s,
330
+ elements: a
331
+ } = t, n = await (s.isRTL == null ? void 0 : s.isRTL(a.floating)), o = M(f), c = X(f), u = j(f) === "y", g = ["left", "top"].includes(o) ? -1 : 1, d = n && u ? -1 : 1, r = F(e, t);
332
+ let {
333
+ mainAxis: m,
334
+ crossAxis: i,
335
+ alignmentAxis: l
336
+ } = typeof r == "number" ? {
337
+ mainAxis: r,
338
+ crossAxis: 0,
339
+ alignmentAxis: null
340
+ } : {
341
+ mainAxis: 0,
342
+ crossAxis: 0,
343
+ alignmentAxis: null,
344
+ ...r
345
+ };
346
+ return c && typeof l == "number" && (i = c === "end" ? l * -1 : l), u ? {
347
+ x: i * d,
348
+ y: m * g
349
+ } : {
350
+ x: m * g,
351
+ y: i * d
352
+ };
353
+ }
354
+ const re = function(t) {
355
+ return t === void 0 && (t = 0), {
356
+ name: "offset",
357
+ options: t,
358
+ async fn(e) {
359
+ var f, s;
360
+ const {
361
+ x: a,
362
+ y: n,
363
+ placement: o,
364
+ middlewareData: c
365
+ } = e, u = await ie(e, t);
366
+ return o === ((f = c.offset) == null ? void 0 : f.placement) && (s = c.arrow) != null && s.alignmentOffset ? {} : {
367
+ x: a + u.x,
368
+ y: n + u.y,
369
+ data: {
370
+ ...u,
371
+ placement: o
324
372
  }
325
- return e;
326
- },
327
- {
328
- key: process.env.NODE_ENV !== "production" && "getVirtualItems",
329
- debug: () => this.options.debug
373
+ };
374
+ }
375
+ };
376
+ }, fe = function(t) {
377
+ return t === void 0 && (t = {}), {
378
+ name: "shift",
379
+ options: t,
380
+ async fn(e) {
381
+ const {
382
+ x: f,
383
+ y: s,
384
+ placement: a
385
+ } = e, {
386
+ mainAxis: n = !0,
387
+ crossAxis: o = !1,
388
+ limiter: c = {
389
+ fn: (x) => {
390
+ let {
391
+ x: h,
392
+ y
393
+ } = x;
394
+ return {
395
+ x: h,
396
+ y
397
+ };
398
+ }
399
+ },
400
+ ...u
401
+ } = F(t, e), g = {
402
+ x: f,
403
+ y: s
404
+ }, d = await $(e, u), r = j(M(a)), m = te(r);
405
+ let i = g[m], l = g[r];
406
+ if (n) {
407
+ const x = m === "y" ? "top" : "left", h = m === "y" ? "bottom" : "right", y = i + d[x], v = i - d[h];
408
+ i = Y(y, i, v);
330
409
  }
331
- ), this.getVirtualItemForOffset = (t) => {
332
- const s = this.getMeasurements();
333
- if (s.length !== 0)
334
- return m(
335
- s[S(
336
- 0,
337
- s.length - 1,
338
- (e) => m(s[e]).start,
339
- t
340
- )]
341
- );
342
- }, this.getOffsetForAlignment = (t, s, e = 0) => {
343
- const i = this.getSize(), n = this.getScrollOffset();
344
- s === "auto" && (s = t >= n + i ? "end" : "start"), s === "center" ? t += (e - i) / 2 : s === "end" && (t -= i);
345
- const o = this.getTotalSize() - i;
346
- return Math.max(Math.min(o, t), 0);
347
- }, this.getOffsetForIndex = (t, s = "auto") => {
348
- t = Math.max(0, Math.min(t, this.options.count - 1));
349
- const e = this.measurementsCache[t];
350
- if (!e)
351
- return;
352
- const i = this.getSize(), n = this.getScrollOffset();
353
- if (s === "auto")
354
- if (e.end >= n + i - this.options.scrollPaddingEnd)
355
- s = "end";
356
- else if (e.start <= n + this.options.scrollPaddingStart)
357
- s = "start";
358
- else
359
- return [n, s];
360
- const o = s === "end" ? e.end + this.options.scrollPaddingEnd : e.start - this.options.scrollPaddingStart;
361
- return [
362
- this.getOffsetForAlignment(o, s, e.size),
363
- s
364
- ];
365
- }, this.isDynamicMode = () => this.elementsCache.size > 0, this.cancelScrollToIndex = () => {
366
- this.scrollToIndexTimeoutId !== null && this.targetWindow && (this.targetWindow.clearTimeout(this.scrollToIndexTimeoutId), this.scrollToIndexTimeoutId = null);
367
- }, this.scrollToOffset = (t, { align: s = "start", behavior: e } = {}) => {
368
- this.cancelScrollToIndex(), e === "smooth" && this.isDynamicMode() && console.warn(
369
- "The `smooth` scroll behavior is not fully supported with dynamic size."
370
- ), this._scrollToOffset(this.getOffsetForAlignment(t, s), {
371
- adjustments: void 0,
372
- behavior: e
373
- });
374
- }, this.scrollToIndex = (t, { align: s = "auto", behavior: e } = {}) => {
375
- t = Math.max(0, Math.min(t, this.options.count - 1)), this.cancelScrollToIndex(), e === "smooth" && this.isDynamicMode() && console.warn(
376
- "The `smooth` scroll behavior is not fully supported with dynamic size."
377
- );
378
- const i = this.getOffsetForIndex(t, s);
379
- if (!i) return;
380
- const [n, o] = i;
381
- this._scrollToOffset(n, { adjustments: void 0, behavior: e }), e !== "smooth" && this.isDynamicMode() && this.targetWindow && (this.scrollToIndexTimeoutId = this.targetWindow.setTimeout(() => {
382
- if (this.scrollToIndexTimeoutId = null, this.elementsCache.has(
383
- this.options.getItemKey(t)
384
- )) {
385
- const [c] = m(
386
- this.getOffsetForIndex(t, o)
387
- ), l = this.getScrollOffset();
388
- y(c, l) || this.scrollToIndex(t, { align: o, behavior: e });
389
- } else
390
- this.scrollToIndex(t, { align: o, behavior: e });
391
- }));
392
- }, this.scrollBy = (t, { behavior: s } = {}) => {
393
- this.cancelScrollToIndex(), s === "smooth" && this.isDynamicMode() && console.warn(
394
- "The `smooth` scroll behavior is not fully supported with dynamic size."
395
- ), this._scrollToOffset(this.getScrollOffset() + t, {
396
- adjustments: void 0,
397
- behavior: s
410
+ if (o) {
411
+ const x = r === "y" ? "top" : "left", h = r === "y" ? "bottom" : "right", y = l + d[x], v = l - d[h];
412
+ l = Y(y, l, v);
413
+ }
414
+ const w = c.fn({
415
+ ...e,
416
+ [m]: i,
417
+ [r]: l
398
418
  });
399
- }, this.getTotalSize = () => {
400
- var t;
401
- const s = this.getMeasurements();
402
- let e;
403
- if (s.length === 0)
404
- e = this.options.paddingStart;
405
- else if (this.options.lanes === 1)
406
- e = ((t = s[s.length - 1]) == null ? void 0 : t.end) ?? 0;
407
- else {
408
- const i = Array(this.options.lanes).fill(null);
409
- let n = s.length - 1;
410
- for (; n >= 0 && i.some((o) => o === null); ) {
411
- const o = s[n];
412
- i[o.lane] === null && (i[o.lane] = o.end), n--;
419
+ return {
420
+ ...w,
421
+ data: {
422
+ x: w.x - f,
423
+ y: w.y - s
413
424
  }
414
- e = Math.max(...i.filter((o) => o !== null));
415
- }
416
- return Math.max(
417
- e - this.options.scrollMargin + this.options.paddingEnd,
418
- 0
419
- );
420
- }, this._scrollToOffset = (t, {
421
- adjustments: s,
422
- behavior: e
423
- }) => {
424
- this.options.scrollToFn(t, { behavior: e, adjustments: s }, this);
425
- }, this.measure = () => {
426
- this.itemSizeCache = /* @__PURE__ */ new Map(), this.notify(!1);
427
- }, this.setOptions(h);
428
- }
429
- }
430
- const S = (r, h, t, s) => {
431
- for (; r <= h; ) {
432
- const e = (r + h) / 2 | 0, i = t(e);
433
- if (i < s)
434
- r = e + 1;
435
- else if (i > s)
436
- h = e - 1;
437
- else
438
- return e;
439
- }
440
- return r > 0 ? r - 1 : 0;
441
- };
442
- function T({
443
- measurements: r,
444
- outerSize: h,
445
- scrollOffset: t,
446
- lanes: s
447
- }) {
448
- const e = r.length - 1, i = (a) => r[a].start;
449
- if (r.length <= s)
450
- return {
451
- startIndex: 0,
452
- endIndex: e
453
- };
454
- let n = S(
455
- 0,
456
- e,
457
- i,
458
- t
459
- ), o = n;
460
- if (s === 1)
461
- for (; o < e && r[o].end < t + h; )
462
- o++;
463
- else if (s > 1) {
464
- const a = Array(s).fill(0);
465
- for (; o < e && a.some((l) => l < t + h); ) {
466
- const l = r[o];
467
- a[l.lane] = l.end, o++;
468
- }
469
- const c = Array(s).fill(t + h);
470
- for (; n >= 0 && c.some((l) => l >= t); ) {
471
- const l = r[n];
472
- c[l.lane] = l.start, n--;
425
+ };
473
426
  }
474
- n = Math.max(0, n - n % s), o = Math.min(e, o + (s - 1 - o % s));
475
- }
476
- return { startIndex: n, endIndex: o };
477
- }
427
+ };
428
+ };
478
429
  export {
479
- N as Virtualizer,
480
- y as approxEqual,
481
- M as debounce,
482
- z as defaultKeyExtractor,
483
- w as defaultRangeExtractor,
484
- D as elementScroll,
485
- C as measureElement,
486
- d as memo,
487
- m as notUndefined,
488
- A as observeElementOffset,
489
- _ as observeElementRect
430
+ ae as arrow,
431
+ oe as computePosition,
432
+ $ as detectOverflow,
433
+ ce as flip,
434
+ le as hide,
435
+ re as offset,
436
+ _ as rectToClientRect,
437
+ fe as shift
490
438
  };