@epilot/volt-ui 1.1.7-alpha.1 → 1.1.7

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 (217) hide show
  1. package/dist/index.cjs.js +51 -0
  2. package/dist/index.es.js +11823 -137
  3. package/dist/preflight.css +1 -241
  4. package/dist/style.css +1 -7393
  5. package/package.json +4 -1
  6. package/dist/components/button/index.d.ts +0 -1
  7. package/dist/index.es.js.map +0 -1
  8. package/dist/index.es10.js +0 -35
  9. package/dist/index.es10.js.map +0 -1
  10. package/dist/index.es100.js +0 -14
  11. package/dist/index.es100.js.map +0 -1
  12. package/dist/index.es101.js +0 -20
  13. package/dist/index.es101.js.map +0 -1
  14. package/dist/index.es102.js +0 -103
  15. package/dist/index.es102.js.map +0 -1
  16. package/dist/index.es103.js +0 -12
  17. package/dist/index.es103.js.map +0 -1
  18. package/dist/index.es104.js +0 -30
  19. package/dist/index.es104.js.map +0 -1
  20. package/dist/index.es105.js +0 -38
  21. package/dist/index.es105.js.map +0 -1
  22. package/dist/index.es106.js +0 -17
  23. package/dist/index.es106.js.map +0 -1
  24. package/dist/index.es107.js +0 -49
  25. package/dist/index.es107.js.map +0 -1
  26. package/dist/index.es108.js +0 -10
  27. package/dist/index.es108.js.map +0 -1
  28. package/dist/index.es11.js +0 -318
  29. package/dist/index.es11.js.map +0 -1
  30. package/dist/index.es12.js +0 -274
  31. package/dist/index.es12.js.map +0 -1
  32. package/dist/index.es13.js +0 -38
  33. package/dist/index.es13.js.map +0 -1
  34. package/dist/index.es14.js +0 -48
  35. package/dist/index.es14.js.map +0 -1
  36. package/dist/index.es15.js +0 -67
  37. package/dist/index.es15.js.map +0 -1
  38. package/dist/index.es16.js +0 -120
  39. package/dist/index.es16.js.map +0 -1
  40. package/dist/index.es17.js +0 -27
  41. package/dist/index.es17.js.map +0 -1
  42. package/dist/index.es18.js +0 -51
  43. package/dist/index.es18.js.map +0 -1
  44. package/dist/index.es19.js +0 -168
  45. package/dist/index.es19.js.map +0 -1
  46. package/dist/index.es20.js +0 -55
  47. package/dist/index.es20.js.map +0 -1
  48. package/dist/index.es21.js +0 -61
  49. package/dist/index.es21.js.map +0 -1
  50. package/dist/index.es22.js +0 -86
  51. package/dist/index.es22.js.map +0 -1
  52. package/dist/index.es23.js +0 -195
  53. package/dist/index.es23.js.map +0 -1
  54. package/dist/index.es24.js +0 -105
  55. package/dist/index.es24.js.map +0 -1
  56. package/dist/index.es25.js +0 -146
  57. package/dist/index.es25.js.map +0 -1
  58. package/dist/index.es26.js +0 -92
  59. package/dist/index.es26.js.map +0 -1
  60. package/dist/index.es27.js +0 -80
  61. package/dist/index.es27.js.map +0 -1
  62. package/dist/index.es28.js +0 -94
  63. package/dist/index.es28.js.map +0 -1
  64. package/dist/index.es29.js +0 -82
  65. package/dist/index.es29.js.map +0 -1
  66. package/dist/index.es30.js +0 -1087
  67. package/dist/index.es30.js.map +0 -1
  68. package/dist/index.es31.js +0 -18
  69. package/dist/index.es31.js.map +0 -1
  70. package/dist/index.es32.js +0 -3015
  71. package/dist/index.es32.js.map +0 -1
  72. package/dist/index.es33.js +0 -107
  73. package/dist/index.es33.js.map +0 -1
  74. package/dist/index.es34.js +0 -46
  75. package/dist/index.es34.js.map +0 -1
  76. package/dist/index.es35.js +0 -151
  77. package/dist/index.es35.js.map +0 -1
  78. package/dist/index.es36.js +0 -1200
  79. package/dist/index.es36.js.map +0 -1
  80. package/dist/index.es37.js +0 -27
  81. package/dist/index.es37.js.map +0 -1
  82. package/dist/index.es38.js +0 -493
  83. package/dist/index.es38.js.map +0 -1
  84. package/dist/index.es39.js +0 -156
  85. package/dist/index.es39.js.map +0 -1
  86. package/dist/index.es4.js +0 -9
  87. package/dist/index.es4.js.map +0 -1
  88. package/dist/index.es40.js +0 -31
  89. package/dist/index.es40.js.map +0 -1
  90. package/dist/index.es41.js +0 -314
  91. package/dist/index.es41.js.map +0 -1
  92. package/dist/index.es42.js +0 -343
  93. package/dist/index.es42.js.map +0 -1
  94. package/dist/index.es43.js +0 -280
  95. package/dist/index.es43.js.map +0 -1
  96. package/dist/index.es44.js +0 -289
  97. package/dist/index.es44.js.map +0 -1
  98. package/dist/index.es45.js +0 -319
  99. package/dist/index.es45.js.map +0 -1
  100. package/dist/index.es46.js +0 -167
  101. package/dist/index.es46.js.map +0 -1
  102. package/dist/index.es47.js +0 -195
  103. package/dist/index.es47.js.map +0 -1
  104. package/dist/index.es48.js +0 -40
  105. package/dist/index.es48.js.map +0 -1
  106. package/dist/index.es49.js +0 -40
  107. package/dist/index.es49.js.map +0 -1
  108. package/dist/index.es5.js +0 -57
  109. package/dist/index.es5.js.map +0 -1
  110. package/dist/index.es50.js +0 -12
  111. package/dist/index.es50.js.map +0 -1
  112. package/dist/index.es51.js +0 -82
  113. package/dist/index.es51.js.map +0 -1
  114. package/dist/index.es52.js +0 -72
  115. package/dist/index.es52.js.map +0 -1
  116. package/dist/index.es53.js +0 -15
  117. package/dist/index.es53.js.map +0 -1
  118. package/dist/index.es54.js +0 -40
  119. package/dist/index.es54.js.map +0 -1
  120. package/dist/index.es55.js +0 -44
  121. package/dist/index.es55.js.map +0 -1
  122. package/dist/index.es56.js +0 -71
  123. package/dist/index.es56.js.map +0 -1
  124. package/dist/index.es57.js +0 -152
  125. package/dist/index.es57.js.map +0 -1
  126. package/dist/index.es58.js +0 -15
  127. package/dist/index.es58.js.map +0 -1
  128. package/dist/index.es59.js +0 -11
  129. package/dist/index.es59.js.map +0 -1
  130. package/dist/index.es6.js +0 -77
  131. package/dist/index.es6.js.map +0 -1
  132. package/dist/index.es60.js +0 -130
  133. package/dist/index.es60.js.map +0 -1
  134. package/dist/index.es61.js +0 -213
  135. package/dist/index.es61.js.map +0 -1
  136. package/dist/index.es62.js +0 -294
  137. package/dist/index.es62.js.map +0 -1
  138. package/dist/index.es63.js +0 -16
  139. package/dist/index.es63.js.map +0 -1
  140. package/dist/index.es64.js +0 -37
  141. package/dist/index.es64.js.map +0 -1
  142. package/dist/index.es65.js +0 -228
  143. package/dist/index.es65.js.map +0 -1
  144. package/dist/index.es66.js +0 -209
  145. package/dist/index.es66.js.map +0 -1
  146. package/dist/index.es67.js +0 -19
  147. package/dist/index.es67.js.map +0 -1
  148. package/dist/index.es68.js +0 -30
  149. package/dist/index.es68.js.map +0 -1
  150. package/dist/index.es69.js +0 -12
  151. package/dist/index.es69.js.map +0 -1
  152. package/dist/index.es7.js +0 -200
  153. package/dist/index.es7.js.map +0 -1
  154. package/dist/index.es70.js +0 -123
  155. package/dist/index.es70.js.map +0 -1
  156. package/dist/index.es71.js +0 -90
  157. package/dist/index.es71.js.map +0 -1
  158. package/dist/index.es72.js +0 -7
  159. package/dist/index.es72.js.map +0 -1
  160. package/dist/index.es73.js +0 -90
  161. package/dist/index.es73.js.map +0 -1
  162. package/dist/index.es74.js +0 -15
  163. package/dist/index.es74.js.map +0 -1
  164. package/dist/index.es75.js +0 -7
  165. package/dist/index.es75.js.map +0 -1
  166. package/dist/index.es76.js +0 -40
  167. package/dist/index.es76.js.map +0 -1
  168. package/dist/index.es77.js +0 -90
  169. package/dist/index.es77.js.map +0 -1
  170. package/dist/index.es78.js +0 -313
  171. package/dist/index.es78.js.map +0 -1
  172. package/dist/index.es79.js +0 -16
  173. package/dist/index.es79.js.map +0 -1
  174. package/dist/index.es8.js +0 -47
  175. package/dist/index.es8.js.map +0 -1
  176. package/dist/index.es80.js +0 -90
  177. package/dist/index.es80.js.map +0 -1
  178. package/dist/index.es81.js +0 -18
  179. package/dist/index.es81.js.map +0 -1
  180. package/dist/index.es82.js +0 -298
  181. package/dist/index.es82.js.map +0 -1
  182. package/dist/index.es83.js +0 -26
  183. package/dist/index.es83.js.map +0 -1
  184. package/dist/index.es84.js +0 -626
  185. package/dist/index.es84.js.map +0 -1
  186. package/dist/index.es85.js +0 -19
  187. package/dist/index.es85.js.map +0 -1
  188. package/dist/index.es86.js +0 -40
  189. package/dist/index.es86.js.map +0 -1
  190. package/dist/index.es87.js +0 -40
  191. package/dist/index.es87.js.map +0 -1
  192. package/dist/index.es88.js +0 -39
  193. package/dist/index.es88.js.map +0 -1
  194. package/dist/index.es89.js +0 -8
  195. package/dist/index.es89.js.map +0 -1
  196. package/dist/index.es9.js +0 -37
  197. package/dist/index.es9.js.map +0 -1
  198. package/dist/index.es90.js +0 -722
  199. package/dist/index.es90.js.map +0 -1
  200. package/dist/index.es91.js +0 -155
  201. package/dist/index.es91.js.map +0 -1
  202. package/dist/index.es92.js +0 -174
  203. package/dist/index.es92.js.map +0 -1
  204. package/dist/index.es93.js +0 -11
  205. package/dist/index.es93.js.map +0 -1
  206. package/dist/index.es94.js +0 -6
  207. package/dist/index.es94.js.map +0 -1
  208. package/dist/index.es95.js +0 -36
  209. package/dist/index.es95.js.map +0 -1
  210. package/dist/index.es96.js +0 -175
  211. package/dist/index.es96.js.map +0 -1
  212. package/dist/index.es97.js +0 -22
  213. package/dist/index.es97.js.map +0 -1
  214. package/dist/index.es98.js +0 -89
  215. package/dist/index.es98.js.map +0 -1
  216. package/dist/index.es99.js +0 -48
  217. package/dist/index.es99.js.map +0 -1
@@ -1,722 +0,0 @@
1
- import { evaluate, getSideAxis, getSide, clamp, getOppositePlacement, getExpandedPlacements, getOppositeAxisPlacements, getAlignmentSides, getAlignment, min, max, getPaddingObject, rectToClientRect, getOppositeAxis, getAlignmentAxis, sides, getAxisLength } from "./index.es91.js";
2
- function computeCoordsFromPlacement(_ref, placement, rtl) {
3
- let {
4
- reference,
5
- floating
6
- } = _ref;
7
- const sideAxis = getSideAxis(placement);
8
- const alignmentAxis = getAlignmentAxis(placement);
9
- const alignLength = getAxisLength(alignmentAxis);
10
- const side = getSide(placement);
11
- const isVertical = sideAxis === "y";
12
- const commonX = reference.x + reference.width / 2 - floating.width / 2;
13
- const commonY = reference.y + reference.height / 2 - floating.height / 2;
14
- const commonAlign = reference[alignLength] / 2 - floating[alignLength] / 2;
15
- let coords;
16
- switch (side) {
17
- case "top":
18
- coords = {
19
- x: commonX,
20
- y: reference.y - floating.height
21
- };
22
- break;
23
- case "bottom":
24
- coords = {
25
- x: commonX,
26
- y: reference.y + reference.height
27
- };
28
- break;
29
- case "right":
30
- coords = {
31
- x: reference.x + reference.width,
32
- y: commonY
33
- };
34
- break;
35
- case "left":
36
- coords = {
37
- x: reference.x - floating.width,
38
- y: commonY
39
- };
40
- break;
41
- default:
42
- coords = {
43
- x: reference.x,
44
- y: reference.y
45
- };
46
- }
47
- switch (getAlignment(placement)) {
48
- case "start":
49
- coords[alignmentAxis] -= commonAlign * (rtl && isVertical ? -1 : 1);
50
- break;
51
- case "end":
52
- coords[alignmentAxis] += commonAlign * (rtl && isVertical ? -1 : 1);
53
- break;
54
- }
55
- return coords;
56
- }
57
- const computePosition = async (reference, floating, config) => {
58
- const {
59
- placement = "bottom",
60
- strategy = "absolute",
61
- middleware = [],
62
- platform
63
- } = config;
64
- const validMiddleware = middleware.filter(Boolean);
65
- const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(floating));
66
- let rects = await platform.getElementRects({
67
- reference,
68
- floating,
69
- strategy
70
- });
71
- let {
72
- x,
73
- y
74
- } = computeCoordsFromPlacement(rects, placement, rtl);
75
- let statefulPlacement = placement;
76
- let middlewareData = {};
77
- let resetCount = 0;
78
- for (let i = 0; i < validMiddleware.length; i++) {
79
- const {
80
- name,
81
- fn
82
- } = validMiddleware[i];
83
- const {
84
- x: nextX,
85
- y: nextY,
86
- data,
87
- reset
88
- } = await fn({
89
- x,
90
- y,
91
- initialPlacement: placement,
92
- placement: statefulPlacement,
93
- strategy,
94
- middlewareData,
95
- rects,
96
- platform,
97
- elements: {
98
- reference,
99
- floating
100
- }
101
- });
102
- x = nextX != null ? nextX : x;
103
- y = nextY != null ? nextY : y;
104
- middlewareData = {
105
- ...middlewareData,
106
- [name]: {
107
- ...middlewareData[name],
108
- ...data
109
- }
110
- };
111
- if (reset && resetCount <= 50) {
112
- resetCount++;
113
- if (typeof reset === "object") {
114
- if (reset.placement) {
115
- statefulPlacement = reset.placement;
116
- }
117
- if (reset.rects) {
118
- rects = reset.rects === true ? await platform.getElementRects({
119
- reference,
120
- floating,
121
- strategy
122
- }) : reset.rects;
123
- }
124
- ({
125
- x,
126
- y
127
- } = computeCoordsFromPlacement(rects, statefulPlacement, rtl));
128
- }
129
- i = -1;
130
- }
131
- }
132
- return {
133
- x,
134
- y,
135
- placement: statefulPlacement,
136
- strategy,
137
- middlewareData
138
- };
139
- };
140
- async function detectOverflow(state, options) {
141
- var _await$platform$isEle;
142
- if (options === void 0) {
143
- options = {};
144
- }
145
- const {
146
- x,
147
- y,
148
- platform,
149
- rects,
150
- elements,
151
- strategy
152
- } = state;
153
- const {
154
- boundary = "clippingAncestors",
155
- rootBoundary = "viewport",
156
- elementContext = "floating",
157
- altBoundary = false,
158
- padding = 0
159
- } = evaluate(options, state);
160
- const paddingObject = getPaddingObject(padding);
161
- const altContext = elementContext === "floating" ? "reference" : "floating";
162
- const element = elements[altBoundary ? altContext : elementContext];
163
- const clippingClientRect = rectToClientRect(await platform.getClippingRect({
164
- element: ((_await$platform$isEle = await (platform.isElement == null ? void 0 : platform.isElement(element))) != null ? _await$platform$isEle : true) ? element : element.contextElement || await (platform.getDocumentElement == null ? void 0 : platform.getDocumentElement(elements.floating)),
165
- boundary,
166
- rootBoundary,
167
- strategy
168
- }));
169
- const rect = elementContext === "floating" ? {
170
- x,
171
- y,
172
- width: rects.floating.width,
173
- height: rects.floating.height
174
- } : rects.reference;
175
- const offsetParent = await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(elements.floating));
176
- const offsetScale = await (platform.isElement == null ? void 0 : platform.isElement(offsetParent)) ? await (platform.getScale == null ? void 0 : platform.getScale(offsetParent)) || {
177
- x: 1,
178
- y: 1
179
- } : {
180
- x: 1,
181
- y: 1
182
- };
183
- const elementClientRect = rectToClientRect(platform.convertOffsetParentRelativeRectToViewportRelativeRect ? await platform.convertOffsetParentRelativeRectToViewportRelativeRect({
184
- elements,
185
- rect,
186
- offsetParent,
187
- strategy
188
- }) : rect);
189
- return {
190
- top: (clippingClientRect.top - elementClientRect.top + paddingObject.top) / offsetScale.y,
191
- bottom: (elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom) / offsetScale.y,
192
- left: (clippingClientRect.left - elementClientRect.left + paddingObject.left) / offsetScale.x,
193
- right: (elementClientRect.right - clippingClientRect.right + paddingObject.right) / offsetScale.x
194
- };
195
- }
196
- const arrow = (options) => ({
197
- name: "arrow",
198
- options,
199
- async fn(state) {
200
- const {
201
- x,
202
- y,
203
- placement,
204
- rects,
205
- platform,
206
- elements,
207
- middlewareData
208
- } = state;
209
- const {
210
- element,
211
- padding = 0
212
- } = evaluate(options, state) || {};
213
- if (element == null) {
214
- return {};
215
- }
216
- const paddingObject = getPaddingObject(padding);
217
- const coords = {
218
- x,
219
- y
220
- };
221
- const axis = getAlignmentAxis(placement);
222
- const length = getAxisLength(axis);
223
- const arrowDimensions = await platform.getDimensions(element);
224
- const isYAxis = axis === "y";
225
- const minProp = isYAxis ? "top" : "left";
226
- const maxProp = isYAxis ? "bottom" : "right";
227
- const clientProp = isYAxis ? "clientHeight" : "clientWidth";
228
- const endDiff = rects.reference[length] + rects.reference[axis] - coords[axis] - rects.floating[length];
229
- const startDiff = coords[axis] - rects.reference[axis];
230
- const arrowOffsetParent = await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(element));
231
- let clientSize = arrowOffsetParent ? arrowOffsetParent[clientProp] : 0;
232
- if (!clientSize || !await (platform.isElement == null ? void 0 : platform.isElement(arrowOffsetParent))) {
233
- clientSize = elements.floating[clientProp] || rects.floating[length];
234
- }
235
- const centerToReference = endDiff / 2 - startDiff / 2;
236
- const largestPossiblePadding = clientSize / 2 - arrowDimensions[length] / 2 - 1;
237
- const minPadding = min(paddingObject[minProp], largestPossiblePadding);
238
- const maxPadding = min(paddingObject[maxProp], largestPossiblePadding);
239
- const min$1 = minPadding;
240
- const max2 = clientSize - arrowDimensions[length] - maxPadding;
241
- const center = clientSize / 2 - arrowDimensions[length] / 2 + centerToReference;
242
- const offset2 = clamp(min$1, center, max2);
243
- const shouldAddOffset = !middlewareData.arrow && getAlignment(placement) != null && center !== offset2 && rects.reference[length] / 2 - (center < min$1 ? minPadding : maxPadding) - arrowDimensions[length] / 2 < 0;
244
- const alignmentOffset = shouldAddOffset ? center < min$1 ? center - min$1 : center - max2 : 0;
245
- return {
246
- [axis]: coords[axis] + alignmentOffset,
247
- data: {
248
- [axis]: offset2,
249
- centerOffset: center - offset2 - alignmentOffset,
250
- ...shouldAddOffset && {
251
- alignmentOffset
252
- }
253
- },
254
- reset: shouldAddOffset
255
- };
256
- }
257
- });
258
- const flip = function(options) {
259
- if (options === void 0) {
260
- options = {};
261
- }
262
- return {
263
- name: "flip",
264
- options,
265
- async fn(state) {
266
- var _middlewareData$arrow, _middlewareData$flip;
267
- const {
268
- placement,
269
- middlewareData,
270
- rects,
271
- initialPlacement,
272
- platform,
273
- elements
274
- } = state;
275
- const {
276
- mainAxis: checkMainAxis = true,
277
- crossAxis: checkCrossAxis = true,
278
- fallbackPlacements: specifiedFallbackPlacements,
279
- fallbackStrategy = "bestFit",
280
- fallbackAxisSideDirection = "none",
281
- flipAlignment = true,
282
- ...detectOverflowOptions
283
- } = evaluate(options, state);
284
- if ((_middlewareData$arrow = middlewareData.arrow) != null && _middlewareData$arrow.alignmentOffset) {
285
- return {};
286
- }
287
- const side = getSide(placement);
288
- const initialSideAxis = getSideAxis(initialPlacement);
289
- const isBasePlacement = getSide(initialPlacement) === initialPlacement;
290
- const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));
291
- const fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipAlignment ? [getOppositePlacement(initialPlacement)] : getExpandedPlacements(initialPlacement));
292
- const hasFallbackAxisSideDirection = fallbackAxisSideDirection !== "none";
293
- if (!specifiedFallbackPlacements && hasFallbackAxisSideDirection) {
294
- fallbackPlacements.push(...getOppositeAxisPlacements(initialPlacement, flipAlignment, fallbackAxisSideDirection, rtl));
295
- }
296
- const placements = [initialPlacement, ...fallbackPlacements];
297
- const overflow = await detectOverflow(state, detectOverflowOptions);
298
- const overflows = [];
299
- let overflowsData = ((_middlewareData$flip = middlewareData.flip) == null ? void 0 : _middlewareData$flip.overflows) || [];
300
- if (checkMainAxis) {
301
- overflows.push(overflow[side]);
302
- }
303
- if (checkCrossAxis) {
304
- const sides2 = getAlignmentSides(placement, rects, rtl);
305
- overflows.push(overflow[sides2[0]], overflow[sides2[1]]);
306
- }
307
- overflowsData = [...overflowsData, {
308
- placement,
309
- overflows
310
- }];
311
- if (!overflows.every((side2) => side2 <= 0)) {
312
- var _middlewareData$flip2, _overflowsData$filter;
313
- const nextIndex = (((_middlewareData$flip2 = middlewareData.flip) == null ? void 0 : _middlewareData$flip2.index) || 0) + 1;
314
- const nextPlacement = placements[nextIndex];
315
- if (nextPlacement) {
316
- const ignoreCrossAxisOverflow = checkCrossAxis === "alignment" ? initialSideAxis !== getSideAxis(nextPlacement) : false;
317
- if (!ignoreCrossAxisOverflow || // We leave the current main axis only if every placement on that axis
318
- // overflows the main axis.
319
- overflowsData.every((d) => getSideAxis(d.placement) === initialSideAxis ? d.overflows[0] > 0 : true)) {
320
- return {
321
- data: {
322
- index: nextIndex,
323
- overflows: overflowsData
324
- },
325
- reset: {
326
- placement: nextPlacement
327
- }
328
- };
329
- }
330
- }
331
- let resetPlacement = (_overflowsData$filter = overflowsData.filter((d) => d.overflows[0] <= 0).sort((a, b) => a.overflows[1] - b.overflows[1])[0]) == null ? void 0 : _overflowsData$filter.placement;
332
- if (!resetPlacement) {
333
- switch (fallbackStrategy) {
334
- case "bestFit": {
335
- var _overflowsData$filter2;
336
- const placement2 = (_overflowsData$filter2 = overflowsData.filter((d) => {
337
- if (hasFallbackAxisSideDirection) {
338
- const currentSideAxis = getSideAxis(d.placement);
339
- return currentSideAxis === initialSideAxis || // Create a bias to the `y` side axis due to horizontal
340
- // reading directions favoring greater width.
341
- currentSideAxis === "y";
342
- }
343
- return true;
344
- }).map((d) => [d.placement, d.overflows.filter((overflow2) => overflow2 > 0).reduce((acc, overflow2) => acc + overflow2, 0)]).sort((a, b) => a[1] - b[1])[0]) == null ? void 0 : _overflowsData$filter2[0];
345
- if (placement2) {
346
- resetPlacement = placement2;
347
- }
348
- break;
349
- }
350
- case "initialPlacement":
351
- resetPlacement = initialPlacement;
352
- break;
353
- }
354
- }
355
- if (placement !== resetPlacement) {
356
- return {
357
- reset: {
358
- placement: resetPlacement
359
- }
360
- };
361
- }
362
- }
363
- return {};
364
- }
365
- };
366
- };
367
- function getSideOffsets(overflow, rect) {
368
- return {
369
- top: overflow.top - rect.height,
370
- right: overflow.right - rect.width,
371
- bottom: overflow.bottom - rect.height,
372
- left: overflow.left - rect.width
373
- };
374
- }
375
- function isAnySideFullyClipped(overflow) {
376
- return sides.some((side) => overflow[side] >= 0);
377
- }
378
- const hide = function(options) {
379
- if (options === void 0) {
380
- options = {};
381
- }
382
- return {
383
- name: "hide",
384
- options,
385
- async fn(state) {
386
- const {
387
- rects
388
- } = state;
389
- const {
390
- strategy = "referenceHidden",
391
- ...detectOverflowOptions
392
- } = evaluate(options, state);
393
- switch (strategy) {
394
- case "referenceHidden": {
395
- const overflow = await detectOverflow(state, {
396
- ...detectOverflowOptions,
397
- elementContext: "reference"
398
- });
399
- const offsets = getSideOffsets(overflow, rects.reference);
400
- return {
401
- data: {
402
- referenceHiddenOffsets: offsets,
403
- referenceHidden: isAnySideFullyClipped(offsets)
404
- }
405
- };
406
- }
407
- case "escaped": {
408
- const overflow = await detectOverflow(state, {
409
- ...detectOverflowOptions,
410
- altBoundary: true
411
- });
412
- const offsets = getSideOffsets(overflow, rects.floating);
413
- return {
414
- data: {
415
- escapedOffsets: offsets,
416
- escaped: isAnySideFullyClipped(offsets)
417
- }
418
- };
419
- }
420
- default: {
421
- return {};
422
- }
423
- }
424
- }
425
- };
426
- };
427
- const originSides = /* @__PURE__ */ new Set(["left", "top"]);
428
- async function convertValueToCoords(state, options) {
429
- const {
430
- placement,
431
- platform,
432
- elements
433
- } = state;
434
- const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));
435
- const side = getSide(placement);
436
- const alignment = getAlignment(placement);
437
- const isVertical = getSideAxis(placement) === "y";
438
- const mainAxisMulti = originSides.has(side) ? -1 : 1;
439
- const crossAxisMulti = rtl && isVertical ? -1 : 1;
440
- const rawValue = evaluate(options, state);
441
- let {
442
- mainAxis,
443
- crossAxis,
444
- alignmentAxis
445
- } = typeof rawValue === "number" ? {
446
- mainAxis: rawValue,
447
- crossAxis: 0,
448
- alignmentAxis: null
449
- } : {
450
- mainAxis: rawValue.mainAxis || 0,
451
- crossAxis: rawValue.crossAxis || 0,
452
- alignmentAxis: rawValue.alignmentAxis
453
- };
454
- if (alignment && typeof alignmentAxis === "number") {
455
- crossAxis = alignment === "end" ? alignmentAxis * -1 : alignmentAxis;
456
- }
457
- return isVertical ? {
458
- x: crossAxis * crossAxisMulti,
459
- y: mainAxis * mainAxisMulti
460
- } : {
461
- x: mainAxis * mainAxisMulti,
462
- y: crossAxis * crossAxisMulti
463
- };
464
- }
465
- const offset = function(options) {
466
- if (options === void 0) {
467
- options = 0;
468
- }
469
- return {
470
- name: "offset",
471
- options,
472
- async fn(state) {
473
- var _middlewareData$offse, _middlewareData$arrow;
474
- const {
475
- x,
476
- y,
477
- placement,
478
- middlewareData
479
- } = state;
480
- const diffCoords = await convertValueToCoords(state, options);
481
- if (placement === ((_middlewareData$offse = middlewareData.offset) == null ? void 0 : _middlewareData$offse.placement) && (_middlewareData$arrow = middlewareData.arrow) != null && _middlewareData$arrow.alignmentOffset) {
482
- return {};
483
- }
484
- return {
485
- x: x + diffCoords.x,
486
- y: y + diffCoords.y,
487
- data: {
488
- ...diffCoords,
489
- placement
490
- }
491
- };
492
- }
493
- };
494
- };
495
- const shift = function(options) {
496
- if (options === void 0) {
497
- options = {};
498
- }
499
- return {
500
- name: "shift",
501
- options,
502
- async fn(state) {
503
- const {
504
- x,
505
- y,
506
- placement
507
- } = state;
508
- const {
509
- mainAxis: checkMainAxis = true,
510
- crossAxis: checkCrossAxis = false,
511
- limiter = {
512
- fn: (_ref) => {
513
- let {
514
- x: x2,
515
- y: y2
516
- } = _ref;
517
- return {
518
- x: x2,
519
- y: y2
520
- };
521
- }
522
- },
523
- ...detectOverflowOptions
524
- } = evaluate(options, state);
525
- const coords = {
526
- x,
527
- y
528
- };
529
- const overflow = await detectOverflow(state, detectOverflowOptions);
530
- const crossAxis = getSideAxis(getSide(placement));
531
- const mainAxis = getOppositeAxis(crossAxis);
532
- let mainAxisCoord = coords[mainAxis];
533
- let crossAxisCoord = coords[crossAxis];
534
- if (checkMainAxis) {
535
- const minSide = mainAxis === "y" ? "top" : "left";
536
- const maxSide = mainAxis === "y" ? "bottom" : "right";
537
- const min2 = mainAxisCoord + overflow[minSide];
538
- const max2 = mainAxisCoord - overflow[maxSide];
539
- mainAxisCoord = clamp(min2, mainAxisCoord, max2);
540
- }
541
- if (checkCrossAxis) {
542
- const minSide = crossAxis === "y" ? "top" : "left";
543
- const maxSide = crossAxis === "y" ? "bottom" : "right";
544
- const min2 = crossAxisCoord + overflow[minSide];
545
- const max2 = crossAxisCoord - overflow[maxSide];
546
- crossAxisCoord = clamp(min2, crossAxisCoord, max2);
547
- }
548
- const limitedCoords = limiter.fn({
549
- ...state,
550
- [mainAxis]: mainAxisCoord,
551
- [crossAxis]: crossAxisCoord
552
- });
553
- return {
554
- ...limitedCoords,
555
- data: {
556
- x: limitedCoords.x - x,
557
- y: limitedCoords.y - y,
558
- enabled: {
559
- [mainAxis]: checkMainAxis,
560
- [crossAxis]: checkCrossAxis
561
- }
562
- }
563
- };
564
- }
565
- };
566
- };
567
- const limitShift = function(options) {
568
- if (options === void 0) {
569
- options = {};
570
- }
571
- return {
572
- options,
573
- fn(state) {
574
- const {
575
- x,
576
- y,
577
- placement,
578
- rects,
579
- middlewareData
580
- } = state;
581
- const {
582
- offset: offset2 = 0,
583
- mainAxis: checkMainAxis = true,
584
- crossAxis: checkCrossAxis = true
585
- } = evaluate(options, state);
586
- const coords = {
587
- x,
588
- y
589
- };
590
- const crossAxis = getSideAxis(placement);
591
- const mainAxis = getOppositeAxis(crossAxis);
592
- let mainAxisCoord = coords[mainAxis];
593
- let crossAxisCoord = coords[crossAxis];
594
- const rawOffset = evaluate(offset2, state);
595
- const computedOffset = typeof rawOffset === "number" ? {
596
- mainAxis: rawOffset,
597
- crossAxis: 0
598
- } : {
599
- mainAxis: 0,
600
- crossAxis: 0,
601
- ...rawOffset
602
- };
603
- if (checkMainAxis) {
604
- const len = mainAxis === "y" ? "height" : "width";
605
- const limitMin = rects.reference[mainAxis] - rects.floating[len] + computedOffset.mainAxis;
606
- const limitMax = rects.reference[mainAxis] + rects.reference[len] - computedOffset.mainAxis;
607
- if (mainAxisCoord < limitMin) {
608
- mainAxisCoord = limitMin;
609
- } else if (mainAxisCoord > limitMax) {
610
- mainAxisCoord = limitMax;
611
- }
612
- }
613
- if (checkCrossAxis) {
614
- var _middlewareData$offse, _middlewareData$offse2;
615
- const len = mainAxis === "y" ? "width" : "height";
616
- const isOriginSide = originSides.has(getSide(placement));
617
- const limitMin = rects.reference[crossAxis] - rects.floating[len] + (isOriginSide ? ((_middlewareData$offse = middlewareData.offset) == null ? void 0 : _middlewareData$offse[crossAxis]) || 0 : 0) + (isOriginSide ? 0 : computedOffset.crossAxis);
618
- const limitMax = rects.reference[crossAxis] + rects.reference[len] + (isOriginSide ? 0 : ((_middlewareData$offse2 = middlewareData.offset) == null ? void 0 : _middlewareData$offse2[crossAxis]) || 0) - (isOriginSide ? computedOffset.crossAxis : 0);
619
- if (crossAxisCoord < limitMin) {
620
- crossAxisCoord = limitMin;
621
- } else if (crossAxisCoord > limitMax) {
622
- crossAxisCoord = limitMax;
623
- }
624
- }
625
- return {
626
- [mainAxis]: mainAxisCoord,
627
- [crossAxis]: crossAxisCoord
628
- };
629
- }
630
- };
631
- };
632
- const size = function(options) {
633
- if (options === void 0) {
634
- options = {};
635
- }
636
- return {
637
- name: "size",
638
- options,
639
- async fn(state) {
640
- var _state$middlewareData, _state$middlewareData2;
641
- const {
642
- placement,
643
- rects,
644
- platform,
645
- elements
646
- } = state;
647
- const {
648
- apply = () => {
649
- },
650
- ...detectOverflowOptions
651
- } = evaluate(options, state);
652
- const overflow = await detectOverflow(state, detectOverflowOptions);
653
- const side = getSide(placement);
654
- const alignment = getAlignment(placement);
655
- const isYAxis = getSideAxis(placement) === "y";
656
- const {
657
- width,
658
- height
659
- } = rects.floating;
660
- let heightSide;
661
- let widthSide;
662
- if (side === "top" || side === "bottom") {
663
- heightSide = side;
664
- widthSide = alignment === (await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating)) ? "start" : "end") ? "left" : "right";
665
- } else {
666
- widthSide = side;
667
- heightSide = alignment === "end" ? "top" : "bottom";
668
- }
669
- const maximumClippingHeight = height - overflow.top - overflow.bottom;
670
- const maximumClippingWidth = width - overflow.left - overflow.right;
671
- const overflowAvailableHeight = min(height - overflow[heightSide], maximumClippingHeight);
672
- const overflowAvailableWidth = min(width - overflow[widthSide], maximumClippingWidth);
673
- const noShift = !state.middlewareData.shift;
674
- let availableHeight = overflowAvailableHeight;
675
- let availableWidth = overflowAvailableWidth;
676
- if ((_state$middlewareData = state.middlewareData.shift) != null && _state$middlewareData.enabled.x) {
677
- availableWidth = maximumClippingWidth;
678
- }
679
- if ((_state$middlewareData2 = state.middlewareData.shift) != null && _state$middlewareData2.enabled.y) {
680
- availableHeight = maximumClippingHeight;
681
- }
682
- if (noShift && !alignment) {
683
- const xMin = max(overflow.left, 0);
684
- const xMax = max(overflow.right, 0);
685
- const yMin = max(overflow.top, 0);
686
- const yMax = max(overflow.bottom, 0);
687
- if (isYAxis) {
688
- availableWidth = width - 2 * (xMin !== 0 || xMax !== 0 ? xMin + xMax : max(overflow.left, overflow.right));
689
- } else {
690
- availableHeight = height - 2 * (yMin !== 0 || yMax !== 0 ? yMin + yMax : max(overflow.top, overflow.bottom));
691
- }
692
- }
693
- await apply({
694
- ...state,
695
- availableWidth,
696
- availableHeight
697
- });
698
- const nextDimensions = await platform.getDimensions(elements.floating);
699
- if (width !== nextDimensions.width || height !== nextDimensions.height) {
700
- return {
701
- reset: {
702
- rects: true
703
- }
704
- };
705
- }
706
- return {};
707
- }
708
- };
709
- };
710
- export {
711
- arrow,
712
- computePosition,
713
- detectOverflow,
714
- flip,
715
- hide,
716
- limitShift,
717
- offset,
718
- rectToClientRect,
719
- shift,
720
- size
721
- };
722
- //# sourceMappingURL=index.es90.js.map