bitboss-ui 2.1.7 → 2.1.8

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