hermium 0.1.10 → 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 (212) 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-BW147gsG.js +0 -1
  28. package/dist/public/assets/IconAlertTriangle-DCoTLVSd.js +0 -1
  29. package/dist/public/assets/IconCheck-DAO7Fpl9.js +0 -1
  30. package/dist/public/assets/IconCode-BqfTl5wU.js +0 -1
  31. package/dist/public/assets/IconLoader2-B_pehSXN.js +0 -1
  32. package/dist/public/assets/IconRefresh-BbMGoMV8.js +0 -1
  33. package/dist/public/assets/geist-cyrillic-wght-normal-CHSlOQsW.woff2 +0 -0
  34. package/dist/public/assets/geist-latin-ext-wght-normal-DMtmJ5ZE.woff2 +0 -0
  35. package/dist/public/assets/geist-latin-wght-normal-Dm3htQBi.woff2 +0 -0
  36. package/dist/public/assets/index-BL9a2Xg9.js +0 -1
  37. package/dist/public/assets/index-BSwXjgjr.js +0 -1
  38. package/dist/public/assets/index-BWl8tn18.js +0 -1
  39. package/dist/public/assets/index-CQh8SXb2.js +0 -94
  40. package/dist/public/assets/index-Cxd-kSUY.js +0 -1
  41. package/dist/public/assets/index-DA5SH--7.js +0 -2
  42. package/dist/public/assets/index-DCHbvtBS.js +0 -1
  43. package/dist/public/assets/index-DCYXJZEe.js +0 -1
  44. package/dist/public/assets/index-DFDfp0ca.js +0 -1
  45. package/dist/public/assets/index-GuAAqSCJ.js +0 -14
  46. package/dist/public/assets/index-WIDirTHx.js +0 -29
  47. package/dist/public/assets/index-X3XZcAzy.js +0 -1
  48. package/dist/public/assets/input-7TQEEJq6.js +0 -1
  49. package/dist/public/assets/inter-cyrillic-ext-wght-normal-BOeWTOD4.woff2 +0 -0
  50. package/dist/public/assets/inter-cyrillic-wght-normal-DqGufNeO.woff2 +0 -0
  51. package/dist/public/assets/inter-greek-ext-wght-normal-DlzME5K_.woff2 +0 -0
  52. package/dist/public/assets/inter-greek-wght-normal-CkhJZR-_.woff2 +0 -0
  53. package/dist/public/assets/inter-latin-ext-wght-normal-DO1Apj_S.woff2 +0 -0
  54. package/dist/public/assets/inter-latin-wght-normal-Dx4kXJAl.woff2 +0 -0
  55. package/dist/public/assets/inter-vietnamese-wght-normal-CBcvBZtf.woff2 +0 -0
  56. package/dist/public/assets/models-BlUb1eaf.js +0 -1
  57. package/dist/public/assets/styles-PHtUFHUr.css +0 -1
  58. package/dist/public/assets/switch-B_iYUUM3.js +0 -1
  59. package/dist/public/assets/syntax-highlighter-DcBYfnEK.js +0 -6
  60. package/dist/public/assets/textarea-Dm4aaRqS.js +0 -1
  61. package/dist/public/favicon.png +0 -0
  62. package/dist/public/nous-logo.png +0 -0
  63. package/dist/server/index.mjs +0 -244
  64. package/dist/web-server/__23tanstack-start-plugin-adapters-Cwee5PKy.mjs +0 -6
  65. package/dist/web-server/_chunks/ssr-renderer.mjs +0 -22
  66. package/dist/web-server/_libs/babel__runtime.mjs +0 -237
  67. package/dist/web-server/_libs/bail.mjs +0 -8
  68. package/dist/web-server/_libs/base-ui__react.mjs +0 -9554
  69. package/dist/web-server/_libs/base-ui__utils.mjs +0 -1101
  70. package/dist/web-server/_libs/ccount.mjs +0 -16
  71. package/dist/web-server/_libs/character-entities-legacy.mjs +0 -111
  72. package/dist/web-server/_libs/character-entities.mjs +0 -2130
  73. package/dist/web-server/_libs/character-reference-invalid.mjs +0 -33
  74. package/dist/web-server/_libs/class-variance-authority.mjs +0 -44
  75. package/dist/web-server/_libs/clsx.mjs +0 -16
  76. package/dist/web-server/_libs/comma-separated-tokens.mjs +0 -31
  77. package/dist/web-server/_libs/cookie-es.mjs +0 -44
  78. package/dist/web-server/_libs/croner.mjs +0 -1
  79. package/dist/web-server/_libs/crossws.mjs +0 -1
  80. package/dist/web-server/_libs/decode-named-character-reference+[...].mjs +0 -8
  81. package/dist/web-server/_libs/devlop.mjs +0 -8
  82. package/dist/web-server/_libs/escape-string-regexp.mjs +0 -9
  83. package/dist/web-server/_libs/estree-util-is-identifier-name.mjs +0 -11
  84. package/dist/web-server/_libs/extend.mjs +0 -97
  85. package/dist/web-server/_libs/fault.mjs +0 -1
  86. package/dist/web-server/_libs/floating-ui__core.mjs +0 -663
  87. package/dist/web-server/_libs/floating-ui__dom.mjs +0 -624
  88. package/dist/web-server/_libs/floating-ui__react-dom.mjs +0 -279
  89. package/dist/web-server/_libs/floating-ui__utils.mjs +0 -322
  90. package/dist/web-server/_libs/format.mjs +0 -1
  91. package/dist/web-server/_libs/h3.mjs +0 -408
  92. package/dist/web-server/_libs/hast-util-parse-selector.mjs +0 -39
  93. package/dist/web-server/_libs/hast-util-to-jsx-runtime.mjs +0 -388
  94. package/dist/web-server/_libs/hast-util-whitespace.mjs +0 -10
  95. package/dist/web-server/_libs/hastscript.mjs +0 -200
  96. package/dist/web-server/_libs/highlight.js.mjs +0 -1
  97. package/dist/web-server/_libs/hookable.mjs +0 -1
  98. package/dist/web-server/_libs/html-url-attributes.mjs +0 -26
  99. package/dist/web-server/_libs/inline-style-parser.mjs +0 -142
  100. package/dist/web-server/_libs/is-alphabetical.mjs +0 -7
  101. package/dist/web-server/_libs/is-alphanumerical.mjs +0 -8
  102. package/dist/web-server/_libs/is-decimal.mjs +0 -7
  103. package/dist/web-server/_libs/is-hexadecimal.mjs +0 -7
  104. package/dist/web-server/_libs/is-plain-obj.mjs +0 -10
  105. package/dist/web-server/_libs/isbot.mjs +0 -21
  106. package/dist/web-server/_libs/longest-streak.mjs +0 -25
  107. package/dist/web-server/_libs/lowlight.mjs +0 -1
  108. package/dist/web-server/_libs/markdown-table.mjs +0 -142
  109. package/dist/web-server/_libs/mdast-util-find-and-replace.mjs +0 -109
  110. package/dist/web-server/_libs/mdast-util-from-markdown.mjs +0 -717
  111. package/dist/web-server/_libs/mdast-util-gfm-autolink-literal+[...].mjs +0 -156
  112. package/dist/web-server/_libs/mdast-util-gfm-footnote.mjs +0 -117
  113. package/dist/web-server/_libs/mdast-util-gfm-strikethrough.mjs +0 -54
  114. package/dist/web-server/_libs/mdast-util-gfm-table.mjs +0 -157
  115. package/dist/web-server/_libs/mdast-util-gfm-task-list-item.mjs +0 -77
  116. package/dist/web-server/_libs/mdast-util-gfm.mjs +0 -29
  117. package/dist/web-server/_libs/mdast-util-phrasing.mjs +0 -30
  118. package/dist/web-server/_libs/mdast-util-to-hast.mjs +0 -710
  119. package/dist/web-server/_libs/mdast-util-to-markdown.mjs +0 -798
  120. package/dist/web-server/_libs/mdast-util-to-string.mjs +0 -38
  121. package/dist/web-server/_libs/micromark-core-commonmark.mjs +0 -2259
  122. package/dist/web-server/_libs/micromark-extension-gfm-autolink-literal+[...].mjs +0 -344
  123. package/dist/web-server/_libs/micromark-extension-gfm-footnote+[...].mjs +0 -279
  124. package/dist/web-server/_libs/micromark-extension-gfm-strikethrough+[...].mjs +0 -98
  125. package/dist/web-server/_libs/micromark-extension-gfm-table.mjs +0 -491
  126. package/dist/web-server/_libs/micromark-extension-gfm-tagfilter+[...].mjs +0 -1
  127. package/dist/web-server/_libs/micromark-extension-gfm-task-list-item+[...].mjs +0 -77
  128. package/dist/web-server/_libs/micromark-extension-gfm.mjs +0 -18
  129. package/dist/web-server/_libs/micromark-factory-destination.mjs +0 -94
  130. package/dist/web-server/_libs/micromark-factory-label.mjs +0 -63
  131. package/dist/web-server/_libs/micromark-factory-space.mjs +0 -24
  132. package/dist/web-server/_libs/micromark-factory-title.mjs +0 -65
  133. package/dist/web-server/_libs/micromark-factory-whitespace.mjs +0 -22
  134. package/dist/web-server/_libs/micromark-util-character.mjs +0 -44
  135. package/dist/web-server/_libs/micromark-util-chunked.mjs +0 -36
  136. package/dist/web-server/_libs/micromark-util-classify-character+[...].mjs +0 -12
  137. package/dist/web-server/_libs/micromark-util-combine-extensions+[...].mjs +0 -41
  138. package/dist/web-server/_libs/micromark-util-decode-numeric-character-reference+[...].mjs +0 -19
  139. package/dist/web-server/_libs/micromark-util-decode-string.mjs +0 -21
  140. package/dist/web-server/_libs/micromark-util-encode.mjs +0 -1
  141. package/dist/web-server/_libs/micromark-util-html-tag-name.mjs +0 -69
  142. package/dist/web-server/_libs/micromark-util-normalize-identifier+[...].mjs +0 -6
  143. package/dist/web-server/_libs/micromark-util-resolve-all.mjs +0 -15
  144. package/dist/web-server/_libs/micromark-util-sanitize-uri.mjs +0 -41
  145. package/dist/web-server/_libs/micromark-util-subtokenize.mjs +0 -346
  146. package/dist/web-server/_libs/micromark.mjs +0 -906
  147. package/dist/web-server/_libs/ocache.mjs +0 -1
  148. package/dist/web-server/_libs/ohash.mjs +0 -1
  149. package/dist/web-server/_libs/parse-entities.mjs +0 -245
  150. package/dist/web-server/_libs/property-information.mjs +0 -1210
  151. package/dist/web-server/_libs/react-dom.mjs +0 -10779
  152. package/dist/web-server/_libs/react-markdown.mjs +0 -147
  153. package/dist/web-server/_libs/react-syntax-highlighter.mjs +0 -941
  154. package/dist/web-server/_libs/react.mjs +0 -513
  155. package/dist/web-server/_libs/refractor.mjs +0 -2425
  156. package/dist/web-server/_libs/remark-gfm.mjs +0 -20
  157. package/dist/web-server/_libs/remark-parse.mjs +0 -19
  158. package/dist/web-server/_libs/remark-rehype.mjs +0 -21
  159. package/dist/web-server/_libs/reselect.mjs +0 -1
  160. package/dist/web-server/_libs/rou3.mjs +0 -8
  161. package/dist/web-server/_libs/seroval-plugins.mjs +0 -58
  162. package/dist/web-server/_libs/seroval.mjs +0 -1775
  163. package/dist/web-server/_libs/space-separated-tokens.mjs +0 -11
  164. package/dist/web-server/_libs/srvx.mjs +0 -781
  165. package/dist/web-server/_libs/style-to-js.mjs +0 -72
  166. package/dist/web-server/_libs/style-to-object.mjs +0 -38
  167. package/dist/web-server/_libs/tabler__icons-react.mjs +0 -233
  168. package/dist/web-server/_libs/tanstack__history.mjs +0 -204
  169. package/dist/web-server/_libs/tanstack__query-core.mjs +0 -2552
  170. package/dist/web-server/_libs/tanstack__react-query.mjs +0 -190
  171. package/dist/web-server/_libs/tanstack__react-router.mjs +0 -1120
  172. package/dist/web-server/_libs/tanstack__react-store.mjs +0 -2
  173. package/dist/web-server/_libs/tanstack__router-core.mjs +0 -4288
  174. package/dist/web-server/_libs/tanstack__store.mjs +0 -1
  175. package/dist/web-server/_libs/trim-lines.mjs +0 -41
  176. package/dist/web-server/_libs/trough.mjs +0 -85
  177. package/dist/web-server/_libs/ufo.mjs +0 -54
  178. package/dist/web-server/_libs/unctx.mjs +0 -1
  179. package/dist/web-server/_libs/ungap__structured-clone.mjs +0 -224
  180. package/dist/web-server/_libs/unified.mjs +0 -661
  181. package/dist/web-server/_libs/unist-util-is.mjs +0 -100
  182. package/dist/web-server/_libs/unist-util-position.mjs +0 -27
  183. package/dist/web-server/_libs/unist-util-stringify-position.mjs +0 -27
  184. package/dist/web-server/_libs/unist-util-visit-parents.mjs +0 -83
  185. package/dist/web-server/_libs/unist-util-visit.mjs +0 -24
  186. package/dist/web-server/_libs/unstorage.mjs +0 -1
  187. package/dist/web-server/_libs/use-sync-external-store.mjs +0 -139
  188. package/dist/web-server/_libs/vfile-message.mjs +0 -138
  189. package/dist/web-server/_libs/vfile.mjs +0 -467
  190. package/dist/web-server/_libs/zod.mjs +0 -3915
  191. package/dist/web-server/_libs/zustand.mjs +0 -343
  192. package/dist/web-server/_libs/zwitch.mjs +0 -1
  193. package/dist/web-server/_ssr/index--Bo2_ipW.mjs +0 -277
  194. package/dist/web-server/_ssr/index-BEvygh5x.mjs +0 -612
  195. package/dist/web-server/_ssr/index-BFaKxYfN.mjs +0 -40
  196. package/dist/web-server/_ssr/index-BdrMzRTd.mjs +0 -513
  197. package/dist/web-server/_ssr/index-CoDfv1vI.mjs +0 -66
  198. package/dist/web-server/_ssr/index-Cwp8Gyl1.mjs +0 -1812
  199. package/dist/web-server/_ssr/index-DQsfKYjV.mjs +0 -449
  200. package/dist/web-server/_ssr/index-Dbs9k8Ea.mjs +0 -251
  201. package/dist/web-server/_ssr/index-Dk93oyZD.mjs +0 -213
  202. package/dist/web-server/_ssr/index-KNJ7huw_.mjs +0 -369
  203. package/dist/web-server/_ssr/index.mjs +0 -1558
  204. package/dist/web-server/_ssr/input-BV1DMASc.mjs +0 -20
  205. package/dist/web-server/_ssr/models-MzrvbL2i.mjs +0 -43
  206. package/dist/web-server/_ssr/router-CS6Zq3md.mjs +0 -2134
  207. package/dist/web-server/_ssr/start-HYkvq4Ni.mjs +0 -4
  208. package/dist/web-server/_ssr/switch-Bd-Sg0HG.mjs +0 -33
  209. package/dist/web-server/_ssr/syntax-highlighter-5vezNTce.mjs +0 -62
  210. package/dist/web-server/_ssr/textarea-CB4kQp9w.mjs +0 -18
  211. package/dist/web-server/_tanstack-start-manifest_v-m5lY48LR.mjs +0 -4
  212. package/dist/web-server/index.mjs +0 -611
@@ -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
- };