hermium 0.1.9 → 0.2.0

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 (209) hide show
  1. package/README.md +56 -0
  2. package/bin/hermium.mjs +185 -164
  3. package/dist/api.mjs +3513 -0
  4. package/dist/public/assets/css/index-Dfs9RUU9.css +1 -0
  5. package/dist/public/assets/css/styles-B8p6jk5Z.css +1 -0
  6. package/dist/public/assets/js/ChatInputBlock-Bw7AL70H.js +1 -0
  7. package/dist/public/assets/js/MarkdownMessage-8d7Y6VL-.js +1 -0
  8. package/dist/public/assets/js/base-ui-BvQbAt_1.js +1 -0
  9. package/dist/public/assets/js/chat._sessionId-BG6lVraH.js +1 -0
  10. package/dist/public/assets/js/chat.index-D2zdMPTT.js +1 -0
  11. package/dist/public/assets/js/index-C0AK45FU.js +60 -0
  12. package/dist/public/assets/js/index-Cx5En4FK.js +1 -0
  13. package/dist/public/assets/js/memory-CeSRdTkW.js +3 -0
  14. package/dist/public/assets/js/router-8uDKazL-.js +1 -0
  15. package/dist/public/assets/js/settings-Bc3Y5zXO.js +1 -0
  16. package/dist/public/assets/js/skills-DZv7sA_5.js +1 -0
  17. package/dist/public/assets/js/theme-CPkdkpaj.js +1 -0
  18. package/dist/public/assets/js/usage-DXQsT9_b.js +1 -0
  19. package/dist/public/assets/woff2/geist-cyrillic-ext-wght-normal-DjL33-gN.woff2 +0 -0
  20. package/dist/public/assets/woff2/geist-cyrillic-wght-normal-BEAKL7Jp.woff2 +0 -0
  21. package/dist/public/assets/woff2/geist-latin-ext-wght-normal-DC-KSUi6.woff2 +0 -0
  22. package/dist/public/assets/woff2/geist-latin-wght-normal-BgDaEnEv.woff2 +0 -0
  23. package/dist/public/assets/woff2/geist-vietnamese-wght-normal-6IgcOCM7.woff2 +0 -0
  24. package/dist/public/favicon.ico +0 -0
  25. package/dist/public/logo.png +0 -0
  26. package/package.json +1 -1
  27. package/dist/public/assets/IconAlertCircle-BHkmI3j7.js +0 -1
  28. package/dist/public/assets/IconAlertTriangle-wCJudlVg.js +0 -1
  29. package/dist/public/assets/IconCheck-CFuEh_p7.js +0 -1
  30. package/dist/public/assets/IconLoader2-BIx3OuF9.js +0 -1
  31. package/dist/public/assets/IconRefresh-Dgm93w3T.js +0 -1
  32. package/dist/public/assets/geist-cyrillic-wght-normal-CHSlOQsW.woff2 +0 -0
  33. package/dist/public/assets/geist-latin-ext-wght-normal-DMtmJ5ZE.woff2 +0 -0
  34. package/dist/public/assets/geist-latin-wght-normal-Dm3htQBi.woff2 +0 -0
  35. package/dist/public/assets/index-Bbz3abmO.js +0 -14
  36. package/dist/public/assets/index-CWUaRwcE.js +0 -1
  37. package/dist/public/assets/index-CinLq3cd.js +0 -1
  38. package/dist/public/assets/index-CrQs9n6q.js +0 -29
  39. package/dist/public/assets/index-CtacpN3I.js +0 -1
  40. package/dist/public/assets/index-DY7aE-9s.js +0 -2
  41. package/dist/public/assets/index-DkYGodJj.js +0 -94
  42. package/dist/public/assets/index-DvDLadUx.js +0 -1
  43. package/dist/public/assets/index-U6RcWedt.js +0 -1
  44. package/dist/public/assets/index-_6iFZ0fh.js +0 -1
  45. package/dist/public/assets/index-enFS26SU.js +0 -1
  46. package/dist/public/assets/input-eNcwlDHp.js +0 -1
  47. package/dist/public/assets/inter-cyrillic-ext-wght-normal-BOeWTOD4.woff2 +0 -0
  48. package/dist/public/assets/inter-cyrillic-wght-normal-DqGufNeO.woff2 +0 -0
  49. package/dist/public/assets/inter-greek-ext-wght-normal-DlzME5K_.woff2 +0 -0
  50. package/dist/public/assets/inter-greek-wght-normal-CkhJZR-_.woff2 +0 -0
  51. package/dist/public/assets/inter-latin-ext-wght-normal-DO1Apj_S.woff2 +0 -0
  52. package/dist/public/assets/inter-latin-wght-normal-Dx4kXJAl.woff2 +0 -0
  53. package/dist/public/assets/inter-vietnamese-wght-normal-CBcvBZtf.woff2 +0 -0
  54. package/dist/public/assets/queries-iHRgZzw2.js +0 -1
  55. package/dist/public/assets/styles-KcflDlA_.css +0 -1
  56. package/dist/public/assets/switch-B1DcZLwL.js +0 -1
  57. package/dist/public/assets/syntax-highlighter-DWPF-A_h.js +0 -6
  58. package/dist/public/assets/textarea-Di_syYTS.js +0 -1
  59. package/dist/public/favicon.png +0 -0
  60. package/dist/public/nous-logo.png +0 -0
  61. package/dist/server/index.mjs +0 -244
  62. package/dist/web-server/__23tanstack-start-plugin-adapters-Cwee5PKy.mjs +0 -6
  63. package/dist/web-server/_chunks/ssr-renderer.mjs +0 -22
  64. package/dist/web-server/_libs/babel__runtime.mjs +0 -237
  65. package/dist/web-server/_libs/bail.mjs +0 -8
  66. package/dist/web-server/_libs/base-ui__react.mjs +0 -9554
  67. package/dist/web-server/_libs/base-ui__utils.mjs +0 -1101
  68. package/dist/web-server/_libs/ccount.mjs +0 -16
  69. package/dist/web-server/_libs/character-entities-legacy.mjs +0 -111
  70. package/dist/web-server/_libs/character-entities.mjs +0 -2130
  71. package/dist/web-server/_libs/character-reference-invalid.mjs +0 -33
  72. package/dist/web-server/_libs/class-variance-authority.mjs +0 -44
  73. package/dist/web-server/_libs/clsx.mjs +0 -16
  74. package/dist/web-server/_libs/comma-separated-tokens.mjs +0 -31
  75. package/dist/web-server/_libs/cookie-es.mjs +0 -44
  76. package/dist/web-server/_libs/croner.mjs +0 -1
  77. package/dist/web-server/_libs/crossws.mjs +0 -1
  78. package/dist/web-server/_libs/decode-named-character-reference+[...].mjs +0 -8
  79. package/dist/web-server/_libs/devlop.mjs +0 -8
  80. package/dist/web-server/_libs/escape-string-regexp.mjs +0 -9
  81. package/dist/web-server/_libs/estree-util-is-identifier-name.mjs +0 -11
  82. package/dist/web-server/_libs/extend.mjs +0 -97
  83. package/dist/web-server/_libs/fault.mjs +0 -1
  84. package/dist/web-server/_libs/floating-ui__core.mjs +0 -663
  85. package/dist/web-server/_libs/floating-ui__dom.mjs +0 -624
  86. package/dist/web-server/_libs/floating-ui__react-dom.mjs +0 -279
  87. package/dist/web-server/_libs/floating-ui__utils.mjs +0 -322
  88. package/dist/web-server/_libs/format.mjs +0 -1
  89. package/dist/web-server/_libs/h3.mjs +0 -408
  90. package/dist/web-server/_libs/hast-util-parse-selector.mjs +0 -39
  91. package/dist/web-server/_libs/hast-util-to-jsx-runtime.mjs +0 -388
  92. package/dist/web-server/_libs/hast-util-whitespace.mjs +0 -10
  93. package/dist/web-server/_libs/hastscript.mjs +0 -200
  94. package/dist/web-server/_libs/highlight.js.mjs +0 -1
  95. package/dist/web-server/_libs/hookable.mjs +0 -1
  96. package/dist/web-server/_libs/html-url-attributes.mjs +0 -26
  97. package/dist/web-server/_libs/inline-style-parser.mjs +0 -142
  98. package/dist/web-server/_libs/is-alphabetical.mjs +0 -7
  99. package/dist/web-server/_libs/is-alphanumerical.mjs +0 -8
  100. package/dist/web-server/_libs/is-decimal.mjs +0 -7
  101. package/dist/web-server/_libs/is-hexadecimal.mjs +0 -7
  102. package/dist/web-server/_libs/is-plain-obj.mjs +0 -10
  103. package/dist/web-server/_libs/isbot.mjs +0 -21
  104. package/dist/web-server/_libs/longest-streak.mjs +0 -25
  105. package/dist/web-server/_libs/lowlight.mjs +0 -1
  106. package/dist/web-server/_libs/markdown-table.mjs +0 -142
  107. package/dist/web-server/_libs/mdast-util-find-and-replace.mjs +0 -109
  108. package/dist/web-server/_libs/mdast-util-from-markdown.mjs +0 -717
  109. package/dist/web-server/_libs/mdast-util-gfm-autolink-literal+[...].mjs +0 -156
  110. package/dist/web-server/_libs/mdast-util-gfm-footnote.mjs +0 -117
  111. package/dist/web-server/_libs/mdast-util-gfm-strikethrough.mjs +0 -54
  112. package/dist/web-server/_libs/mdast-util-gfm-table.mjs +0 -157
  113. package/dist/web-server/_libs/mdast-util-gfm-task-list-item.mjs +0 -77
  114. package/dist/web-server/_libs/mdast-util-gfm.mjs +0 -29
  115. package/dist/web-server/_libs/mdast-util-phrasing.mjs +0 -30
  116. package/dist/web-server/_libs/mdast-util-to-hast.mjs +0 -710
  117. package/dist/web-server/_libs/mdast-util-to-markdown.mjs +0 -798
  118. package/dist/web-server/_libs/mdast-util-to-string.mjs +0 -38
  119. package/dist/web-server/_libs/micromark-core-commonmark.mjs +0 -2259
  120. package/dist/web-server/_libs/micromark-extension-gfm-autolink-literal+[...].mjs +0 -344
  121. package/dist/web-server/_libs/micromark-extension-gfm-footnote+[...].mjs +0 -279
  122. package/dist/web-server/_libs/micromark-extension-gfm-strikethrough+[...].mjs +0 -98
  123. package/dist/web-server/_libs/micromark-extension-gfm-table.mjs +0 -491
  124. package/dist/web-server/_libs/micromark-extension-gfm-tagfilter+[...].mjs +0 -1
  125. package/dist/web-server/_libs/micromark-extension-gfm-task-list-item+[...].mjs +0 -77
  126. package/dist/web-server/_libs/micromark-extension-gfm.mjs +0 -18
  127. package/dist/web-server/_libs/micromark-factory-destination.mjs +0 -94
  128. package/dist/web-server/_libs/micromark-factory-label.mjs +0 -63
  129. package/dist/web-server/_libs/micromark-factory-space.mjs +0 -24
  130. package/dist/web-server/_libs/micromark-factory-title.mjs +0 -65
  131. package/dist/web-server/_libs/micromark-factory-whitespace.mjs +0 -22
  132. package/dist/web-server/_libs/micromark-util-character.mjs +0 -44
  133. package/dist/web-server/_libs/micromark-util-chunked.mjs +0 -36
  134. package/dist/web-server/_libs/micromark-util-classify-character+[...].mjs +0 -12
  135. package/dist/web-server/_libs/micromark-util-combine-extensions+[...].mjs +0 -41
  136. package/dist/web-server/_libs/micromark-util-decode-numeric-character-reference+[...].mjs +0 -19
  137. package/dist/web-server/_libs/micromark-util-decode-string.mjs +0 -21
  138. package/dist/web-server/_libs/micromark-util-encode.mjs +0 -1
  139. package/dist/web-server/_libs/micromark-util-html-tag-name.mjs +0 -69
  140. package/dist/web-server/_libs/micromark-util-normalize-identifier+[...].mjs +0 -6
  141. package/dist/web-server/_libs/micromark-util-resolve-all.mjs +0 -15
  142. package/dist/web-server/_libs/micromark-util-sanitize-uri.mjs +0 -41
  143. package/dist/web-server/_libs/micromark-util-subtokenize.mjs +0 -346
  144. package/dist/web-server/_libs/micromark.mjs +0 -906
  145. package/dist/web-server/_libs/ocache.mjs +0 -1
  146. package/dist/web-server/_libs/ohash.mjs +0 -1
  147. package/dist/web-server/_libs/parse-entities.mjs +0 -245
  148. package/dist/web-server/_libs/property-information.mjs +0 -1210
  149. package/dist/web-server/_libs/react-dom.mjs +0 -10779
  150. package/dist/web-server/_libs/react-markdown.mjs +0 -147
  151. package/dist/web-server/_libs/react-syntax-highlighter.mjs +0 -941
  152. package/dist/web-server/_libs/react.mjs +0 -513
  153. package/dist/web-server/_libs/refractor.mjs +0 -2425
  154. package/dist/web-server/_libs/remark-gfm.mjs +0 -20
  155. package/dist/web-server/_libs/remark-parse.mjs +0 -19
  156. package/dist/web-server/_libs/remark-rehype.mjs +0 -21
  157. package/dist/web-server/_libs/reselect.mjs +0 -1
  158. package/dist/web-server/_libs/rou3.mjs +0 -8
  159. package/dist/web-server/_libs/seroval-plugins.mjs +0 -58
  160. package/dist/web-server/_libs/seroval.mjs +0 -1775
  161. package/dist/web-server/_libs/space-separated-tokens.mjs +0 -11
  162. package/dist/web-server/_libs/srvx.mjs +0 -781
  163. package/dist/web-server/_libs/style-to-js.mjs +0 -72
  164. package/dist/web-server/_libs/style-to-object.mjs +0 -38
  165. package/dist/web-server/_libs/tabler__icons-react.mjs +0 -230
  166. package/dist/web-server/_libs/tanstack__history.mjs +0 -204
  167. package/dist/web-server/_libs/tanstack__query-core.mjs +0 -2552
  168. package/dist/web-server/_libs/tanstack__react-query.mjs +0 -190
  169. package/dist/web-server/_libs/tanstack__react-router.mjs +0 -1120
  170. package/dist/web-server/_libs/tanstack__react-store.mjs +0 -2
  171. package/dist/web-server/_libs/tanstack__router-core.mjs +0 -4288
  172. package/dist/web-server/_libs/tanstack__store.mjs +0 -1
  173. package/dist/web-server/_libs/trim-lines.mjs +0 -41
  174. package/dist/web-server/_libs/trough.mjs +0 -85
  175. package/dist/web-server/_libs/ufo.mjs +0 -54
  176. package/dist/web-server/_libs/unctx.mjs +0 -1
  177. package/dist/web-server/_libs/ungap__structured-clone.mjs +0 -224
  178. package/dist/web-server/_libs/unified.mjs +0 -661
  179. package/dist/web-server/_libs/unist-util-is.mjs +0 -100
  180. package/dist/web-server/_libs/unist-util-position.mjs +0 -27
  181. package/dist/web-server/_libs/unist-util-stringify-position.mjs +0 -27
  182. package/dist/web-server/_libs/unist-util-visit-parents.mjs +0 -83
  183. package/dist/web-server/_libs/unist-util-visit.mjs +0 -24
  184. package/dist/web-server/_libs/unstorage.mjs +0 -1
  185. package/dist/web-server/_libs/use-sync-external-store.mjs +0 -139
  186. package/dist/web-server/_libs/vfile-message.mjs +0 -138
  187. package/dist/web-server/_libs/vfile.mjs +0 -467
  188. package/dist/web-server/_libs/zod.mjs +0 -3915
  189. package/dist/web-server/_libs/zustand.mjs +0 -343
  190. package/dist/web-server/_libs/zwitch.mjs +0 -1
  191. package/dist/web-server/_ssr/index-0n2Z3BPQ.mjs +0 -369
  192. package/dist/web-server/_ssr/index-6itDALOw.mjs +0 -339
  193. package/dist/web-server/_ssr/index-BIRTrOmp.mjs +0 -449
  194. package/dist/web-server/_ssr/index-BPzfADac.mjs +0 -66
  195. package/dist/web-server/_ssr/index-BQE3bF14.mjs +0 -1870
  196. package/dist/web-server/_ssr/index-C5HpvlUP.mjs +0 -190
  197. package/dist/web-server/_ssr/index-C_ZxnypN.mjs +0 -213
  198. package/dist/web-server/_ssr/index-Ca8JFH8f.mjs +0 -612
  199. package/dist/web-server/_ssr/index-DNVESZiA.mjs +0 -513
  200. package/dist/web-server/_ssr/index.mjs +0 -1558
  201. package/dist/web-server/_ssr/input-CqXjTRQg.mjs +0 -20
  202. package/dist/web-server/_ssr/queries-3H_19mUt.mjs +0 -16
  203. package/dist/web-server/_ssr/router-sbsNus0Y.mjs +0 -2093
  204. package/dist/web-server/_ssr/start-HYkvq4Ni.mjs +0 -4
  205. package/dist/web-server/_ssr/switch-usf2F1UM.mjs +0 -33
  206. package/dist/web-server/_ssr/syntax-highlighter-5vezNTce.mjs +0 -62
  207. package/dist/web-server/_ssr/textarea-DfRheWY0.mjs +0 -18
  208. package/dist/web-server/_tanstack-start-manifest_v-DqW-pKEH.mjs +0 -4
  209. package/dist/web-server/index.mjs +0 -597
@@ -1,663 +0,0 @@
1
- import { m as evaluate, s as getSide, t as getSideAxis, u as getOppositePlacement, v as getExpandedPlacements, w as getOppositeAxisPlacements, x as getAlignmentSides, p as getAlignment, y as min, z as max, o as getAlignmentAxis, n as getPaddingObject, A as rectToClientRect, B as sides, q as getAxisLength, r as clamp, C as getOppositeAxis } from "./floating-ui__utils.mjs";
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
- async function detectOverflow(state, options) {
58
- var _await$platform$isEle;
59
- if (options === void 0) {
60
- options = {};
61
- }
62
- const {
63
- x,
64
- y,
65
- platform,
66
- rects,
67
- elements,
68
- strategy
69
- } = state;
70
- const {
71
- boundary = "clippingAncestors",
72
- rootBoundary = "viewport",
73
- elementContext = "floating",
74
- altBoundary = false,
75
- padding = 0
76
- } = evaluate(options, state);
77
- const paddingObject = getPaddingObject(padding);
78
- const altContext = elementContext === "floating" ? "reference" : "floating";
79
- const element = elements[altBoundary ? altContext : elementContext];
80
- const clippingClientRect = rectToClientRect(await platform.getClippingRect({
81
- 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)),
82
- boundary,
83
- rootBoundary,
84
- strategy
85
- }));
86
- const rect = elementContext === "floating" ? {
87
- x,
88
- y,
89
- width: rects.floating.width,
90
- height: rects.floating.height
91
- } : rects.reference;
92
- const offsetParent = await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(elements.floating));
93
- const offsetScale = await (platform.isElement == null ? void 0 : platform.isElement(offsetParent)) ? await (platform.getScale == null ? void 0 : platform.getScale(offsetParent)) || {
94
- x: 1,
95
- y: 1
96
- } : {
97
- x: 1,
98
- y: 1
99
- };
100
- const elementClientRect = rectToClientRect(platform.convertOffsetParentRelativeRectToViewportRelativeRect ? await platform.convertOffsetParentRelativeRectToViewportRelativeRect({
101
- elements,
102
- rect,
103
- offsetParent,
104
- strategy
105
- }) : rect);
106
- return {
107
- top: (clippingClientRect.top - elementClientRect.top + paddingObject.top) / offsetScale.y,
108
- bottom: (elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom) / offsetScale.y,
109
- left: (clippingClientRect.left - elementClientRect.left + paddingObject.left) / offsetScale.x,
110
- right: (elementClientRect.right - clippingClientRect.right + paddingObject.right) / offsetScale.x
111
- };
112
- }
113
- const MAX_RESET_COUNT = 50;
114
- const computePosition = async (reference, floating, config) => {
115
- const {
116
- placement = "bottom",
117
- strategy = "absolute",
118
- middleware = [],
119
- platform
120
- } = config;
121
- const platformWithDetectOverflow = platform.detectOverflow ? platform : {
122
- ...platform,
123
- detectOverflow
124
- };
125
- const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(floating));
126
- let rects = await platform.getElementRects({
127
- reference,
128
- floating,
129
- strategy
130
- });
131
- let {
132
- x,
133
- y
134
- } = computeCoordsFromPlacement(rects, placement, rtl);
135
- let statefulPlacement = placement;
136
- let resetCount = 0;
137
- const middlewareData = {};
138
- for (let i = 0; i < middleware.length; i++) {
139
- const currentMiddleware = middleware[i];
140
- if (!currentMiddleware) {
141
- continue;
142
- }
143
- const {
144
- name,
145
- fn
146
- } = currentMiddleware;
147
- const {
148
- x: nextX,
149
- y: nextY,
150
- data,
151
- reset
152
- } = await fn({
153
- x,
154
- y,
155
- initialPlacement: placement,
156
- placement: statefulPlacement,
157
- strategy,
158
- middlewareData,
159
- rects,
160
- platform: platformWithDetectOverflow,
161
- elements: {
162
- reference,
163
- floating
164
- }
165
- });
166
- x = nextX != null ? nextX : x;
167
- y = nextY != null ? nextY : y;
168
- middlewareData[name] = {
169
- ...middlewareData[name],
170
- ...data
171
- };
172
- if (reset && resetCount < MAX_RESET_COUNT) {
173
- resetCount++;
174
- if (typeof reset === "object") {
175
- if (reset.placement) {
176
- statefulPlacement = reset.placement;
177
- }
178
- if (reset.rects) {
179
- rects = reset.rects === true ? await platform.getElementRects({
180
- reference,
181
- floating,
182
- strategy
183
- }) : reset.rects;
184
- }
185
- ({
186
- x,
187
- y
188
- } = computeCoordsFromPlacement(rects, statefulPlacement, rtl));
189
- }
190
- i = -1;
191
- }
192
- }
193
- return {
194
- x,
195
- y,
196
- placement: statefulPlacement,
197
- strategy,
198
- middlewareData
199
- };
200
- };
201
- const flip = function(options) {
202
- if (options === void 0) {
203
- options = {};
204
- }
205
- return {
206
- name: "flip",
207
- options,
208
- async fn(state) {
209
- var _middlewareData$arrow, _middlewareData$flip;
210
- const {
211
- placement,
212
- middlewareData,
213
- rects,
214
- initialPlacement,
215
- platform,
216
- elements
217
- } = state;
218
- const {
219
- mainAxis: checkMainAxis = true,
220
- crossAxis: checkCrossAxis = true,
221
- fallbackPlacements: specifiedFallbackPlacements,
222
- fallbackStrategy = "bestFit",
223
- fallbackAxisSideDirection = "none",
224
- flipAlignment = true,
225
- ...detectOverflowOptions
226
- } = evaluate(options, state);
227
- if ((_middlewareData$arrow = middlewareData.arrow) != null && _middlewareData$arrow.alignmentOffset) {
228
- return {};
229
- }
230
- const side = getSide(placement);
231
- const initialSideAxis = getSideAxis(initialPlacement);
232
- const isBasePlacement = getSide(initialPlacement) === initialPlacement;
233
- const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));
234
- const fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipAlignment ? [getOppositePlacement(initialPlacement)] : getExpandedPlacements(initialPlacement));
235
- const hasFallbackAxisSideDirection = fallbackAxisSideDirection !== "none";
236
- if (!specifiedFallbackPlacements && hasFallbackAxisSideDirection) {
237
- fallbackPlacements.push(...getOppositeAxisPlacements(initialPlacement, flipAlignment, fallbackAxisSideDirection, rtl));
238
- }
239
- const placements = [initialPlacement, ...fallbackPlacements];
240
- const overflow = await platform.detectOverflow(state, detectOverflowOptions);
241
- const overflows = [];
242
- let overflowsData = ((_middlewareData$flip = middlewareData.flip) == null ? void 0 : _middlewareData$flip.overflows) || [];
243
- if (checkMainAxis) {
244
- overflows.push(overflow[side]);
245
- }
246
- if (checkCrossAxis) {
247
- const sides2 = getAlignmentSides(placement, rects, rtl);
248
- overflows.push(overflow[sides2[0]], overflow[sides2[1]]);
249
- }
250
- overflowsData = [...overflowsData, {
251
- placement,
252
- overflows
253
- }];
254
- if (!overflows.every((side2) => side2 <= 0)) {
255
- var _middlewareData$flip2, _overflowsData$filter;
256
- const nextIndex = (((_middlewareData$flip2 = middlewareData.flip) == null ? void 0 : _middlewareData$flip2.index) || 0) + 1;
257
- const nextPlacement = placements[nextIndex];
258
- if (nextPlacement) {
259
- const ignoreCrossAxisOverflow = checkCrossAxis === "alignment" ? initialSideAxis !== getSideAxis(nextPlacement) : false;
260
- if (!ignoreCrossAxisOverflow || // We leave the current main axis only if every placement on that axis
261
- // overflows the main axis.
262
- overflowsData.every((d) => getSideAxis(d.placement) === initialSideAxis ? d.overflows[0] > 0 : true)) {
263
- return {
264
- data: {
265
- index: nextIndex,
266
- overflows: overflowsData
267
- },
268
- reset: {
269
- placement: nextPlacement
270
- }
271
- };
272
- }
273
- }
274
- 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;
275
- if (!resetPlacement) {
276
- switch (fallbackStrategy) {
277
- case "bestFit": {
278
- var _overflowsData$filter2;
279
- const placement2 = (_overflowsData$filter2 = overflowsData.filter((d) => {
280
- if (hasFallbackAxisSideDirection) {
281
- const currentSideAxis = getSideAxis(d.placement);
282
- return currentSideAxis === initialSideAxis || // Create a bias to the `y` side axis due to horizontal
283
- // reading directions favoring greater width.
284
- currentSideAxis === "y";
285
- }
286
- return true;
287
- }).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];
288
- if (placement2) {
289
- resetPlacement = placement2;
290
- }
291
- break;
292
- }
293
- case "initialPlacement":
294
- resetPlacement = initialPlacement;
295
- break;
296
- }
297
- }
298
- if (placement !== resetPlacement) {
299
- return {
300
- reset: {
301
- placement: resetPlacement
302
- }
303
- };
304
- }
305
- }
306
- return {};
307
- }
308
- };
309
- };
310
- function getSideOffsets(overflow, rect) {
311
- return {
312
- top: overflow.top - rect.height,
313
- right: overflow.right - rect.width,
314
- bottom: overflow.bottom - rect.height,
315
- left: overflow.left - rect.width
316
- };
317
- }
318
- function isAnySideFullyClipped(overflow) {
319
- return sides.some((side) => overflow[side] >= 0);
320
- }
321
- const hide = function(options) {
322
- if (options === void 0) {
323
- options = {};
324
- }
325
- return {
326
- name: "hide",
327
- options,
328
- async fn(state) {
329
- const {
330
- rects,
331
- platform
332
- } = state;
333
- const {
334
- strategy = "referenceHidden",
335
- ...detectOverflowOptions
336
- } = evaluate(options, state);
337
- switch (strategy) {
338
- case "referenceHidden": {
339
- const overflow = await platform.detectOverflow(state, {
340
- ...detectOverflowOptions,
341
- elementContext: "reference"
342
- });
343
- const offsets = getSideOffsets(overflow, rects.reference);
344
- return {
345
- data: {
346
- referenceHiddenOffsets: offsets,
347
- referenceHidden: isAnySideFullyClipped(offsets)
348
- }
349
- };
350
- }
351
- case "escaped": {
352
- const overflow = await platform.detectOverflow(state, {
353
- ...detectOverflowOptions,
354
- altBoundary: true
355
- });
356
- const offsets = getSideOffsets(overflow, rects.floating);
357
- return {
358
- data: {
359
- escapedOffsets: offsets,
360
- escaped: isAnySideFullyClipped(offsets)
361
- }
362
- };
363
- }
364
- default: {
365
- return {};
366
- }
367
- }
368
- }
369
- };
370
- };
371
- const originSides = /* @__PURE__ */ new Set(["left", "top"]);
372
- async function convertValueToCoords(state, options) {
373
- const {
374
- placement,
375
- platform,
376
- elements
377
- } = state;
378
- const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));
379
- const side = getSide(placement);
380
- const alignment = getAlignment(placement);
381
- const isVertical = getSideAxis(placement) === "y";
382
- const mainAxisMulti = originSides.has(side) ? -1 : 1;
383
- const crossAxisMulti = rtl && isVertical ? -1 : 1;
384
- const rawValue = evaluate(options, state);
385
- let {
386
- mainAxis,
387
- crossAxis,
388
- alignmentAxis
389
- } = typeof rawValue === "number" ? {
390
- mainAxis: rawValue,
391
- crossAxis: 0,
392
- alignmentAxis: null
393
- } : {
394
- mainAxis: rawValue.mainAxis || 0,
395
- crossAxis: rawValue.crossAxis || 0,
396
- alignmentAxis: rawValue.alignmentAxis
397
- };
398
- if (alignment && typeof alignmentAxis === "number") {
399
- crossAxis = alignment === "end" ? alignmentAxis * -1 : alignmentAxis;
400
- }
401
- return isVertical ? {
402
- x: crossAxis * crossAxisMulti,
403
- y: mainAxis * mainAxisMulti
404
- } : {
405
- x: mainAxis * mainAxisMulti,
406
- y: crossAxis * crossAxisMulti
407
- };
408
- }
409
- const offset = function(options) {
410
- if (options === void 0) {
411
- options = 0;
412
- }
413
- return {
414
- name: "offset",
415
- options,
416
- async fn(state) {
417
- var _middlewareData$offse, _middlewareData$arrow;
418
- const {
419
- x,
420
- y,
421
- placement,
422
- middlewareData
423
- } = state;
424
- const diffCoords = await convertValueToCoords(state, options);
425
- if (placement === ((_middlewareData$offse = middlewareData.offset) == null ? void 0 : _middlewareData$offse.placement) && (_middlewareData$arrow = middlewareData.arrow) != null && _middlewareData$arrow.alignmentOffset) {
426
- return {};
427
- }
428
- return {
429
- x: x + diffCoords.x,
430
- y: y + diffCoords.y,
431
- data: {
432
- ...diffCoords,
433
- placement
434
- }
435
- };
436
- }
437
- };
438
- };
439
- const shift = function(options) {
440
- if (options === void 0) {
441
- options = {};
442
- }
443
- return {
444
- name: "shift",
445
- options,
446
- async fn(state) {
447
- const {
448
- x,
449
- y,
450
- placement,
451
- platform
452
- } = state;
453
- const {
454
- mainAxis: checkMainAxis = true,
455
- crossAxis: checkCrossAxis = false,
456
- limiter = {
457
- fn: (_ref) => {
458
- let {
459
- x: x2,
460
- y: y2
461
- } = _ref;
462
- return {
463
- x: x2,
464
- y: y2
465
- };
466
- }
467
- },
468
- ...detectOverflowOptions
469
- } = evaluate(options, state);
470
- const coords = {
471
- x,
472
- y
473
- };
474
- const overflow = await platform.detectOverflow(state, detectOverflowOptions);
475
- const crossAxis = getSideAxis(getSide(placement));
476
- const mainAxis = getOppositeAxis(crossAxis);
477
- let mainAxisCoord = coords[mainAxis];
478
- let crossAxisCoord = coords[crossAxis];
479
- if (checkMainAxis) {
480
- const minSide = mainAxis === "y" ? "top" : "left";
481
- const maxSide = mainAxis === "y" ? "bottom" : "right";
482
- const min2 = mainAxisCoord + overflow[minSide];
483
- const max2 = mainAxisCoord - overflow[maxSide];
484
- mainAxisCoord = clamp(min2, mainAxisCoord, max2);
485
- }
486
- if (checkCrossAxis) {
487
- const minSide = crossAxis === "y" ? "top" : "left";
488
- const maxSide = crossAxis === "y" ? "bottom" : "right";
489
- const min2 = crossAxisCoord + overflow[minSide];
490
- const max2 = crossAxisCoord - overflow[maxSide];
491
- crossAxisCoord = clamp(min2, crossAxisCoord, max2);
492
- }
493
- const limitedCoords = limiter.fn({
494
- ...state,
495
- [mainAxis]: mainAxisCoord,
496
- [crossAxis]: crossAxisCoord
497
- });
498
- return {
499
- ...limitedCoords,
500
- data: {
501
- x: limitedCoords.x - x,
502
- y: limitedCoords.y - y,
503
- enabled: {
504
- [mainAxis]: checkMainAxis,
505
- [crossAxis]: checkCrossAxis
506
- }
507
- }
508
- };
509
- }
510
- };
511
- };
512
- const limitShift = function(options) {
513
- if (options === void 0) {
514
- options = {};
515
- }
516
- return {
517
- options,
518
- fn(state) {
519
- const {
520
- x,
521
- y,
522
- placement,
523
- rects,
524
- middlewareData
525
- } = state;
526
- const {
527
- offset: offset2 = 0,
528
- mainAxis: checkMainAxis = true,
529
- crossAxis: checkCrossAxis = true
530
- } = evaluate(options, state);
531
- const coords = {
532
- x,
533
- y
534
- };
535
- const crossAxis = getSideAxis(placement);
536
- const mainAxis = getOppositeAxis(crossAxis);
537
- let mainAxisCoord = coords[mainAxis];
538
- let crossAxisCoord = coords[crossAxis];
539
- const rawOffset = evaluate(offset2, state);
540
- const computedOffset = typeof rawOffset === "number" ? {
541
- mainAxis: rawOffset,
542
- crossAxis: 0
543
- } : {
544
- mainAxis: 0,
545
- crossAxis: 0,
546
- ...rawOffset
547
- };
548
- if (checkMainAxis) {
549
- const len = mainAxis === "y" ? "height" : "width";
550
- const limitMin = rects.reference[mainAxis] - rects.floating[len] + computedOffset.mainAxis;
551
- const limitMax = rects.reference[mainAxis] + rects.reference[len] - computedOffset.mainAxis;
552
- if (mainAxisCoord < limitMin) {
553
- mainAxisCoord = limitMin;
554
- } else if (mainAxisCoord > limitMax) {
555
- mainAxisCoord = limitMax;
556
- }
557
- }
558
- if (checkCrossAxis) {
559
- var _middlewareData$offse, _middlewareData$offse2;
560
- const len = mainAxis === "y" ? "width" : "height";
561
- const isOriginSide = originSides.has(getSide(placement));
562
- 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);
563
- 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);
564
- if (crossAxisCoord < limitMin) {
565
- crossAxisCoord = limitMin;
566
- } else if (crossAxisCoord > limitMax) {
567
- crossAxisCoord = limitMax;
568
- }
569
- }
570
- return {
571
- [mainAxis]: mainAxisCoord,
572
- [crossAxis]: crossAxisCoord
573
- };
574
- }
575
- };
576
- };
577
- const size = function(options) {
578
- if (options === void 0) {
579
- options = {};
580
- }
581
- return {
582
- name: "size",
583
- options,
584
- async fn(state) {
585
- var _state$middlewareData, _state$middlewareData2;
586
- const {
587
- placement,
588
- rects,
589
- platform,
590
- elements
591
- } = state;
592
- const {
593
- apply = () => {
594
- },
595
- ...detectOverflowOptions
596
- } = evaluate(options, state);
597
- const overflow = await platform.detectOverflow(state, detectOverflowOptions);
598
- const side = getSide(placement);
599
- const alignment = getAlignment(placement);
600
- const isYAxis = getSideAxis(placement) === "y";
601
- const {
602
- width,
603
- height
604
- } = rects.floating;
605
- let heightSide;
606
- let widthSide;
607
- if (side === "top" || side === "bottom") {
608
- heightSide = side;
609
- widthSide = alignment === (await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating)) ? "start" : "end") ? "left" : "right";
610
- } else {
611
- widthSide = side;
612
- heightSide = alignment === "end" ? "top" : "bottom";
613
- }
614
- const maximumClippingHeight = height - overflow.top - overflow.bottom;
615
- const maximumClippingWidth = width - overflow.left - overflow.right;
616
- const overflowAvailableHeight = min(height - overflow[heightSide], maximumClippingHeight);
617
- const overflowAvailableWidth = min(width - overflow[widthSide], maximumClippingWidth);
618
- const noShift = !state.middlewareData.shift;
619
- let availableHeight = overflowAvailableHeight;
620
- let availableWidth = overflowAvailableWidth;
621
- if ((_state$middlewareData = state.middlewareData.shift) != null && _state$middlewareData.enabled.x) {
622
- availableWidth = maximumClippingWidth;
623
- }
624
- if ((_state$middlewareData2 = state.middlewareData.shift) != null && _state$middlewareData2.enabled.y) {
625
- availableHeight = maximumClippingHeight;
626
- }
627
- if (noShift && !alignment) {
628
- const xMin = max(overflow.left, 0);
629
- const xMax = max(overflow.right, 0);
630
- const yMin = max(overflow.top, 0);
631
- const yMax = max(overflow.bottom, 0);
632
- if (isYAxis) {
633
- availableWidth = width - 2 * (xMin !== 0 || xMax !== 0 ? xMin + xMax : max(overflow.left, overflow.right));
634
- } else {
635
- availableHeight = height - 2 * (yMin !== 0 || yMax !== 0 ? yMin + yMax : max(overflow.top, overflow.bottom));
636
- }
637
- }
638
- await apply({
639
- ...state,
640
- availableWidth,
641
- availableHeight
642
- });
643
- const nextDimensions = await platform.getDimensions(elements.floating);
644
- if (width !== nextDimensions.width || height !== nextDimensions.height) {
645
- return {
646
- reset: {
647
- rects: true
648
- }
649
- };
650
- }
651
- return {};
652
- }
653
- };
654
- };
655
- export {
656
- shift as a,
657
- computePosition as c,
658
- flip as f,
659
- hide as h,
660
- limitShift as l,
661
- offset as o,
662
- size as s
663
- };