@yselimcan/ui 0.0.1 → 0.0.3

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 (267) hide show
  1. package/dist/index.d.ts +231 -1
  2. package/dist/index.js +100 -15331
  3. package/dist/index10.js +137 -0
  4. package/dist/index100.js +7 -0
  5. package/dist/index101.js +69 -0
  6. package/dist/index102.js +11 -0
  7. package/dist/index103.js +16 -0
  8. package/dist/index104.js +6 -0
  9. package/dist/index105.js +6 -0
  10. package/dist/index106.js +8 -0
  11. package/dist/index107.js +10 -0
  12. package/dist/index108.js +90 -0
  13. package/dist/index109.js +15 -0
  14. package/dist/index11.js +21 -0
  15. package/dist/index110.js +65 -0
  16. package/dist/index111.js +40 -0
  17. package/dist/index112.js +16 -0
  18. package/dist/index113.js +35 -0
  19. package/dist/index114.js +21 -0
  20. package/dist/index115.js +8 -0
  21. package/dist/index116.js +6 -0
  22. package/dist/index117.js +7 -0
  23. package/dist/index118.js +14 -0
  24. package/dist/index119.js +21 -0
  25. package/dist/index12.js +20 -0
  26. package/dist/index120.js +15 -0
  27. package/dist/index121.js +299 -0
  28. package/dist/index122.js +7 -0
  29. package/dist/index123.js +41 -0
  30. package/dist/index124.js +128 -0
  31. package/dist/index125.js +23 -0
  32. package/dist/index126.js +79 -0
  33. package/dist/index127.js +67 -0
  34. package/dist/index128.js +48 -0
  35. package/dist/index129.js +32 -0
  36. package/dist/index13.js +206 -0
  37. package/dist/index130.js +14 -0
  38. package/dist/index131.js +69 -0
  39. package/dist/index132.js +56 -0
  40. package/dist/index133.js +15 -0
  41. package/dist/index134.js +15 -0
  42. package/dist/index135.js +15 -0
  43. package/dist/index136.js +43 -0
  44. package/dist/index137.js +14 -0
  45. package/dist/index138.js +11 -0
  46. package/dist/index139.js +8 -0
  47. package/dist/index14.js +24 -0
  48. package/dist/index140.js +90 -0
  49. package/dist/index141.js +14 -0
  50. package/dist/index142.js +266 -0
  51. package/dist/index143.js +82 -0
  52. package/dist/index144.js +14 -0
  53. package/dist/index145.js +59 -0
  54. package/dist/index146.js +14 -0
  55. package/dist/index147.js +14 -0
  56. package/dist/index148.js +33 -0
  57. package/dist/index149.js +21 -0
  58. package/dist/index15.js +19 -0
  59. package/dist/index150.js +69 -0
  60. package/dist/index151.js +107 -0
  61. package/dist/index152.js +11 -0
  62. package/dist/index153.js +11 -0
  63. package/dist/index154.js +25 -0
  64. package/dist/index155.js +106 -0
  65. package/dist/index156.js +10 -0
  66. package/dist/index157.js +35 -0
  67. package/dist/index158.js +233 -0
  68. package/dist/index159.js +77 -0
  69. package/dist/index16.js +8 -0
  70. package/dist/index160.js +286 -0
  71. package/dist/index161.js +56 -0
  72. package/dist/index162.js +6 -0
  73. package/dist/index163.js +17 -0
  74. package/dist/index164.js +18 -0
  75. package/dist/index165.js +31 -0
  76. package/dist/index166.js +10 -0
  77. package/dist/index167.js +25 -0
  78. package/dist/index168.js +27 -0
  79. package/dist/index169.js +163 -0
  80. package/dist/index17.js +46 -0
  81. package/dist/index170.js +116 -0
  82. package/dist/index171.js +78 -0
  83. package/dist/index172.js +67 -0
  84. package/dist/index173.js +72 -0
  85. package/dist/index174.js +16 -0
  86. package/dist/index175.js +8 -0
  87. package/dist/index176.js +20 -0
  88. package/dist/index177.js +24 -0
  89. package/dist/index178.js +61 -0
  90. package/dist/index179.js +20 -0
  91. package/dist/index18.js +41 -0
  92. package/dist/index180.js +30 -0
  93. package/dist/index181.js +45 -0
  94. package/dist/index182.js +24 -0
  95. package/dist/index183.js +51 -0
  96. package/dist/index184.js +54 -0
  97. package/dist/index185.js +20 -0
  98. package/dist/index186.js +14 -0
  99. package/dist/index187.js +38 -0
  100. package/dist/index188.js +18 -0
  101. package/dist/index189.js +82 -0
  102. package/dist/index19.js +80 -0
  103. package/dist/index190.js +26 -0
  104. package/dist/index191.js +6 -0
  105. package/dist/index192.js +14 -0
  106. package/dist/index193.js +13 -0
  107. package/dist/index194.js +43 -0
  108. package/dist/index195.js +7 -0
  109. package/dist/index196.js +12 -0
  110. package/dist/index197.js +14 -0
  111. package/dist/index198.js +120 -0
  112. package/dist/index199.js +14 -0
  113. package/dist/index20.js +25 -0
  114. package/dist/index200.js +8 -0
  115. package/dist/index201.js +50 -0
  116. package/dist/index202.js +202 -0
  117. package/dist/index203.js +50 -0
  118. package/dist/index204.js +22 -0
  119. package/dist/index205.js +29 -0
  120. package/dist/index206.js +6 -0
  121. package/dist/index207.js +24 -0
  122. package/dist/index208.js +130 -0
  123. package/dist/index209.js +47 -0
  124. package/dist/index21.js +40 -0
  125. package/dist/index210.js +20 -0
  126. package/dist/index211.js +7 -0
  127. package/dist/index212.js +183 -0
  128. package/dist/index213.js +78 -0
  129. package/dist/index214.js +401 -0
  130. package/dist/index215.js +9 -0
  131. package/dist/index216.js +7 -0
  132. package/dist/index217.js +19 -0
  133. package/dist/index218.js +17 -0
  134. package/dist/index219.js +35 -0
  135. package/dist/index22.js +31 -0
  136. package/dist/index220.js +41 -0
  137. package/dist/index221.js +59 -0
  138. package/dist/index222.js +30 -0
  139. package/dist/index223.js +10 -0
  140. package/dist/index224.js +15 -0
  141. package/dist/index225.js +14 -0
  142. package/dist/index226.js +14 -0
  143. package/dist/index227.js +24 -0
  144. package/dist/index228.js +14 -0
  145. package/dist/index229.js +10 -0
  146. package/dist/index23.js +25 -0
  147. package/dist/index230.js +45 -0
  148. package/dist/index231.js +599 -0
  149. package/dist/index232.js +14 -0
  150. package/dist/index233.js +6 -0
  151. package/dist/index234.js +12 -0
  152. package/dist/index235.js +14 -0
  153. package/dist/index236.js +17 -0
  154. package/dist/index237.js +211 -0
  155. package/dist/index238.js +6 -0
  156. package/dist/index239.js +16 -0
  157. package/dist/index24.js +56 -0
  158. package/dist/index240.js +50 -0
  159. package/dist/index241.js +6 -0
  160. package/dist/index242.js +15 -0
  161. package/dist/index243.js +60 -0
  162. package/dist/index244.js +32 -0
  163. package/dist/index245.js +16 -0
  164. package/dist/index246.js +11 -0
  165. package/dist/index247.js +209 -0
  166. package/dist/index248.js +23 -0
  167. package/dist/index249.js +8 -0
  168. package/dist/index25.js +35 -0
  169. package/dist/index250.js +324 -0
  170. package/dist/index251.js +5 -0
  171. package/dist/index252.js +5 -0
  172. package/dist/index253.js +489 -0
  173. package/dist/index254.js +10 -0
  174. package/dist/index255.js +4 -0
  175. package/dist/index256.js +46 -0
  176. package/dist/index257.js +58 -0
  177. package/dist/index258.js +10 -0
  178. package/dist/index259.js +4 -0
  179. package/dist/index26.js +7 -0
  180. package/dist/index260.js +57 -0
  181. package/dist/index261.js +58 -0
  182. package/dist/index262.js +4 -0
  183. package/dist/index263.js +4 -0
  184. package/dist/index264.js +4 -0
  185. package/dist/index265.js +4 -0
  186. package/dist/index27.js +82 -0
  187. package/dist/index28.js +32 -0
  188. package/dist/index29.js +6 -0
  189. package/dist/index3.js +181 -0
  190. package/dist/index30.js +9 -0
  191. package/dist/index31.js +6 -0
  192. package/dist/index32.js +23 -0
  193. package/dist/index33.js +207 -0
  194. package/dist/index34.js +25 -0
  195. package/dist/index35.js +102 -0
  196. package/dist/index36.js +69 -0
  197. package/dist/index37.js +66 -0
  198. package/dist/index38.js +113 -0
  199. package/dist/index39.js +53 -0
  200. package/dist/index4.js +47 -0
  201. package/dist/index40.js +35 -0
  202. package/dist/index41.js +28 -0
  203. package/dist/index42.js +18 -0
  204. package/dist/index43.js +27 -0
  205. package/dist/index44.js +25 -0
  206. package/dist/index45.js +36 -0
  207. package/dist/index46.js +78 -0
  208. package/dist/index47.js +65 -0
  209. package/dist/index48.js +128 -0
  210. package/dist/index49.js +19 -0
  211. package/dist/index5.js +52 -0
  212. package/dist/index50.js +86 -0
  213. package/dist/index51.js +6 -0
  214. package/dist/index52.js +268 -0
  215. package/dist/index53.js +25 -0
  216. package/dist/index54.js +207 -0
  217. package/dist/index55.js +146 -0
  218. package/dist/index56.js +88 -0
  219. package/dist/index57.js +29 -0
  220. package/dist/index58.js +30 -0
  221. package/dist/index59.js +48 -0
  222. package/dist/index6.js +93 -0
  223. package/dist/index60.js +79 -0
  224. package/dist/index61.js +45 -0
  225. package/dist/index62.js +46 -0
  226. package/dist/index63.js +76 -0
  227. package/dist/index64.js +45 -0
  228. package/dist/index65.js +22 -0
  229. package/dist/index66.js +101 -0
  230. package/dist/index67.js +14 -0
  231. package/dist/index68.js +6 -0
  232. package/dist/index69.js +321 -0
  233. package/dist/index7.js +294 -0
  234. package/dist/index70.js +24 -0
  235. package/dist/index71.js +143 -0
  236. package/dist/index72.js +200 -0
  237. package/dist/index73.js +43 -0
  238. package/dist/index74.js +29 -0
  239. package/dist/index75.js +148 -0
  240. package/dist/index76.js +32 -0
  241. package/dist/index77.js +53 -0
  242. package/dist/index78.js +28 -0
  243. package/dist/index79.js +15 -0
  244. package/dist/index8.js +264 -0
  245. package/dist/index80.js +15 -0
  246. package/dist/index81.js +135 -0
  247. package/dist/index82.js +31 -0
  248. package/dist/index83.js +35 -0
  249. package/dist/index84.js +17 -0
  250. package/dist/index85.js +2765 -0
  251. package/dist/index86.js +57 -0
  252. package/dist/index87.js +14 -0
  253. package/dist/index88.js +98 -0
  254. package/dist/index89.js +92 -0
  255. package/dist/index9.js +197 -0
  256. package/dist/index90.js +21 -0
  257. package/dist/index91.js +18 -0
  258. package/dist/index92.js +35 -0
  259. package/dist/index93.js +14 -0
  260. package/dist/index94.js +136 -0
  261. package/dist/index95.js +30 -0
  262. package/dist/index96.js +11 -0
  263. package/dist/index97.js +7 -0
  264. package/dist/index98.js +15 -0
  265. package/dist/index99.js +25 -0
  266. package/dist/styles.css +1 -1
  267. package/package.json +3 -2
@@ -0,0 +1,14 @@
1
+ import n from "./index100.js";
2
+ import * as o from "react";
3
+ const t = /* @__PURE__ */ o.createContext(void 0);
4
+ process.env.NODE_ENV !== "production" && (t.displayName = "MenuPortalContext");
5
+ function s() {
6
+ const e = o.useContext(t);
7
+ if (e === void 0)
8
+ throw new Error(process.env.NODE_ENV !== "production" ? "Base UI: <Menu.Portal> is missing." : n(32));
9
+ return e;
10
+ }
11
+ export {
12
+ t as MenuPortalContext,
13
+ s as useMenuPortalContext
14
+ };
@@ -0,0 +1,266 @@
1
+ "use client";
2
+ import * as a from "react";
3
+ import { getSide as L, getSideAxis as Ee, getAlignment as Me } from "./index208.js";
4
+ import { ownerDocument as qe } from "./index162.js";
5
+ import { useIsoLayoutEffect as q } from "./index97.js";
6
+ import { useValueAsRef as G } from "./index176.js";
7
+ import { useStableCallback as Ge } from "./index95.js";
8
+ import { useDirection as Je } from "./index153.js";
9
+ import { arrow as Ke } from "./index209.js";
10
+ import { hide as Ne } from "./index210.js";
11
+ import { DEFAULT_SIDES as Qe } from "./index211.js";
12
+ import { flip as Ze, offset as et, size as tt, shift as nt, limitShift as ot } from "./index212.js";
13
+ import { useFloating as it } from "./index213.js";
14
+ import { autoUpdate as $e } from "./index214.js";
15
+ function ke(l, f, u) {
16
+ const n = l === "inline-start" || l === "inline-end";
17
+ return {
18
+ top: "top",
19
+ right: n ? u ? "inline-start" : "inline-end" : "right",
20
+ bottom: "bottom",
21
+ left: n ? u ? "inline-end" : "inline-start" : "left"
22
+ }[f];
23
+ }
24
+ function ve(l, f, u) {
25
+ const {
26
+ rects: n,
27
+ placement: s
28
+ } = l;
29
+ return {
30
+ side: ke(f, L(s), u),
31
+ align: Me(s) || "center",
32
+ anchor: {
33
+ width: n.reference.width,
34
+ height: n.reference.height
35
+ },
36
+ positioner: {
37
+ width: n.floating.width,
38
+ height: n.floating.height
39
+ }
40
+ };
41
+ }
42
+ function wt(l) {
43
+ const {
44
+ // Public parameters
45
+ anchor: f,
46
+ positionMethod: u = "absolute",
47
+ side: n = "bottom",
48
+ sideOffset: s = 0,
49
+ align: b = "center",
50
+ alignOffset: H = 0,
51
+ collisionBoundary: J,
52
+ collisionPadding: Ce = 5,
53
+ sticky: T = !1,
54
+ arrowPadding: K = 5,
55
+ disableAnchorTracking: z = !1,
56
+ // Private parameters
57
+ keepMounted: B = !1,
58
+ floatingRootContext: $,
59
+ mounted: r,
60
+ collisionAvoidance: V,
61
+ shiftCrossAxis: w = !1,
62
+ nodeId: Fe,
63
+ adaptiveOrigin: I,
64
+ lazyFlip: N = !1,
65
+ externalTree: Le
66
+ } = l, [Q, Z] = a.useState(null);
67
+ !r && Q !== null && Z(null);
68
+ const A = V.side || "flip", S = V.align || "flip", He = V.fallbackAxisSide || "end", ee = typeof f == "function" ? f : void 0, Te = Ge(ee), te = ee ? Te : f, v = G(f), p = Je() === "rtl", ne = Q || {
69
+ top: "top",
70
+ right: "right",
71
+ bottom: "bottom",
72
+ left: "left",
73
+ "inline-end": p ? "left" : "right",
74
+ "inline-start": p ? "right" : "left"
75
+ }[n], ze = b === "center" ? ne : `${ne}-${b}`;
76
+ let e = Ce;
77
+ const d = 1, oe = n === "bottom" ? d : 0, ie = n === "top" ? d : 0, re = n === "right" ? d : 0, se = n === "left" ? d : 0;
78
+ typeof e == "number" ? e = {
79
+ top: e + oe,
80
+ right: e + se,
81
+ bottom: e + ie,
82
+ left: e + re
83
+ } : e && (e = {
84
+ top: (e.top || 0) + oe,
85
+ right: (e.right || 0) + se,
86
+ bottom: (e.bottom || 0) + ie,
87
+ left: (e.left || 0) + re
88
+ });
89
+ const D = {
90
+ boundary: J === "clipping-ancestors" ? "clippingAncestors" : J,
91
+ padding: e
92
+ }, m = a.useRef(null), U = G(s), Y = G(H), M = [et((t) => {
93
+ const o = ve(t, n, p), c = typeof U.current == "function" ? U.current(o) : U.current, i = typeof Y.current == "function" ? Y.current(o) : Y.current;
94
+ return {
95
+ mainAxis: c,
96
+ crossAxis: i,
97
+ alignmentAxis: i
98
+ };
99
+ }, [typeof s != "function" ? s : 0, typeof H != "function" ? H : 0, p, n])], ce = S === "none" && A !== "shift", le = !ce && (T || w || A === "shift"), ae = A === "none" ? null : Ze({
100
+ ...D,
101
+ // Ensure the popup flips if it's been limited by its --available-height and it resizes.
102
+ // Since the size() padding is smaller than the flip() padding, flip() will take precedence.
103
+ padding: {
104
+ top: e.top + d,
105
+ right: e.right + d,
106
+ bottom: e.bottom + d,
107
+ left: e.left + d
108
+ },
109
+ mainAxis: !w && A === "flip",
110
+ crossAxis: S === "flip" ? "alignment" : !1,
111
+ fallbackAxisSideDirection: He
112
+ }), fe = ce ? null : nt((t) => {
113
+ const o = qe(t.elements.floating).documentElement;
114
+ return {
115
+ ...D,
116
+ // Use the Layout Viewport to avoid shifting around when pinch-zooming
117
+ // for context menus.
118
+ rootBoundary: w ? {
119
+ x: 0,
120
+ y: 0,
121
+ width: o.clientWidth,
122
+ height: o.clientHeight
123
+ } : void 0,
124
+ mainAxis: S !== "none",
125
+ crossAxis: le,
126
+ limiter: T || w ? void 0 : ot((c) => {
127
+ if (!m.current)
128
+ return {};
129
+ const {
130
+ width: i,
131
+ height: x
132
+ } = m.current.getBoundingClientRect(), y = Ee(L(c.placement)), F = y === "y" ? i : x, j = y === "y" ? e.left + e.right : e.top + e.bottom;
133
+ return {
134
+ offset: F / 2 + j / 2
135
+ };
136
+ })
137
+ };
138
+ }, [D, T, w, e, S]);
139
+ A === "shift" || S === "shift" || b === "center" ? M.push(fe, ae) : M.push(ae, fe), M.push(tt({
140
+ ...D,
141
+ apply({
142
+ elements: {
143
+ floating: t
144
+ },
145
+ rects: {
146
+ reference: o
147
+ },
148
+ availableWidth: c,
149
+ availableHeight: i
150
+ }) {
151
+ Object.entries({
152
+ "--available-width": `${c}px`,
153
+ "--available-height": `${i}px`,
154
+ "--anchor-width": `${o.width}px`,
155
+ "--anchor-height": `${o.height}px`
156
+ }).forEach(([x, y]) => {
157
+ t.style.setProperty(x, y);
158
+ });
159
+ }
160
+ }), Ke(() => ({
161
+ // `transform-origin` calculations rely on an element existing. If the arrow hasn't been set,
162
+ // we'll create a fake element.
163
+ element: m.current || document.createElement("div"),
164
+ padding: K,
165
+ offsetParent: "floating"
166
+ }), [K]), {
167
+ name: "transformOrigin",
168
+ fn(t) {
169
+ const {
170
+ elements: o,
171
+ middlewareData: c,
172
+ placement: i,
173
+ rects: x,
174
+ y
175
+ } = t, F = L(i), j = Ee(F), Oe = m.current, Be = c.arrow?.x || 0, Ve = c.arrow?.y || 0, Ie = Oe?.clientWidth || 0, Ue = Oe?.clientHeight || 0, _ = Be + Ie / 2, Pe = Ve + Ue / 2, Ye = Math.abs(c.shift?.y || 0), We = x.reference.height / 2, E = typeof s == "function" ? s(ve(t, n, p)) : s, Xe = Ye > E, je = {
176
+ top: `${_}px calc(100% + ${E}px)`,
177
+ bottom: `${_}px ${-E}px`,
178
+ left: `calc(100% + ${E}px) ${Pe}px`,
179
+ right: `${-E}px ${Pe}px`
180
+ }[F], _e = `${_}px ${x.reference.y + We - y}px`;
181
+ return o.floating.style.setProperty("--transform-origin", le && j === "y" && Xe ? _e : je), {};
182
+ }
183
+ }, Ne, I), q(() => {
184
+ !r && $ && $.update({
185
+ referenceElement: null,
186
+ floatingElement: null,
187
+ domReferenceElement: null
188
+ });
189
+ }, [r, $]);
190
+ const W = a.useMemo(() => ({
191
+ elementResize: !z && typeof ResizeObserver < "u",
192
+ layoutShift: !z && typeof IntersectionObserver < "u"
193
+ }), [z]), {
194
+ refs: h,
195
+ elements: R,
196
+ x: de,
197
+ y: ue,
198
+ middlewareData: g,
199
+ update: k,
200
+ placement: pe,
201
+ context: me,
202
+ isPositioned: O,
203
+ floatingStyles: he
204
+ } = it({
205
+ rootContext: $,
206
+ placement: ze,
207
+ middleware: M,
208
+ strategy: u,
209
+ whileElementsMounted: B ? void 0 : (...t) => $e(...t, W),
210
+ nodeId: Fe,
211
+ externalTree: Le
212
+ }), {
213
+ sideX: ge,
214
+ sideY: xe
215
+ } = g.adaptiveOrigin || Qe, X = O ? u : "fixed", ye = a.useMemo(() => I ? {
216
+ position: X,
217
+ [ge]: de,
218
+ [xe]: ue
219
+ } : {
220
+ position: X,
221
+ ...he
222
+ }, [I, X, ge, de, xe, ue, he]), C = a.useRef(null);
223
+ q(() => {
224
+ if (!r)
225
+ return;
226
+ const t = v.current, o = typeof t == "function" ? t() : t, i = (De(o) ? o.current : o) || null || null;
227
+ i !== C.current && (h.setPositionReference(i), C.current = i);
228
+ }, [r, h, te, v]), a.useEffect(() => {
229
+ if (!r)
230
+ return;
231
+ const t = v.current;
232
+ typeof t != "function" && De(t) && t.current !== C.current && (h.setPositionReference(t.current), C.current = t.current);
233
+ }, [r, h, te, v]), a.useEffect(() => {
234
+ if (B && r && R.domReference && R.floating)
235
+ return $e(R.domReference, R.floating, k, W);
236
+ }, [B, r, R, k, W]);
237
+ const P = L(pe), be = ke(n, P, p), we = Me(pe) || "center", Ae = !!g.hide?.referenceHidden;
238
+ q(() => {
239
+ N && r && O && Z(P);
240
+ }, [N, r, O, P]);
241
+ const Se = a.useMemo(() => ({
242
+ position: "absolute",
243
+ top: g.arrow?.y,
244
+ left: g.arrow?.x
245
+ }), [g.arrow]), Re = g.arrow?.centerOffset !== 0;
246
+ return a.useMemo(() => ({
247
+ positionerStyles: ye,
248
+ arrowStyles: Se,
249
+ arrowRef: m,
250
+ arrowUncentered: Re,
251
+ side: be,
252
+ align: we,
253
+ physicalSide: P,
254
+ anchorHidden: Ae,
255
+ refs: h,
256
+ context: me,
257
+ isPositioned: O,
258
+ update: k
259
+ }), [ye, Se, m, Re, be, we, P, Ae, h, me, O, k]);
260
+ }
261
+ function De(l) {
262
+ return l != null && "current" in l;
263
+ }
264
+ export {
265
+ wt as useAnchorPositioning
266
+ };
@@ -0,0 +1,82 @@
1
+ "use client";
2
+ import * as a from "react";
3
+ import { useRefWithInit as T } from "./index107.js";
4
+ import { useStableCallback as m } from "./index95.js";
5
+ import { useIsoLayoutEffect as f } from "./index97.js";
6
+ import { CompositeListContext as D } from "./index207.js";
7
+ import { jsx as L } from "react/jsx-runtime";
8
+ function k(h) {
9
+ const {
10
+ children: N,
11
+ elementsRef: t,
12
+ labelsRef: o,
13
+ onMapChange: _
14
+ } = h, C = m(_), O = a.useRef(0), d = T(R).current, i = T(P).current, [p, M] = a.useState(0), c = a.useRef(p), E = m((e, u) => {
15
+ i.set(e, u ?? null), c.current += 1, M(c.current);
16
+ }), I = m((e) => {
17
+ i.delete(e), c.current += 1, M(c.current);
18
+ }), r = a.useMemo(() => {
19
+ const e = /* @__PURE__ */ new Map();
20
+ return Array.from(i.keys()).filter((n) => n.isConnected).sort(S).forEach((n, l) => {
21
+ const s = i.get(n) ?? {};
22
+ e.set(n, {
23
+ ...s,
24
+ index: l
25
+ });
26
+ }), e;
27
+ }, [i, p]);
28
+ f(() => {
29
+ if (typeof MutationObserver != "function" || r.size === 0)
30
+ return;
31
+ const e = new MutationObserver((u) => {
32
+ const n = /* @__PURE__ */ new Set(), l = (s) => n.has(s) ? n.delete(s) : n.add(s);
33
+ u.forEach((s) => {
34
+ s.removedNodes.forEach(l), s.addedNodes.forEach(l);
35
+ }), n.size === 0 && (c.current += 1, M(c.current));
36
+ });
37
+ return r.forEach((u, n) => {
38
+ n.parentElement && e.observe(n.parentElement, {
39
+ childList: !0
40
+ });
41
+ }), () => {
42
+ e.disconnect();
43
+ };
44
+ }, [r]), f(() => {
45
+ c.current === p && (t.current.length !== r.size && (t.current.length = r.size), o && o.current.length !== r.size && (o.current.length = r.size), O.current = r.size), C(r);
46
+ }, [C, r, t, o, p]), f(() => () => {
47
+ t.current = [];
48
+ }, [t]), f(() => () => {
49
+ o && (o.current = []);
50
+ }, [o]);
51
+ const g = m((e) => (d.add(e), () => {
52
+ d.delete(e);
53
+ }));
54
+ f(() => {
55
+ d.forEach((e) => e(r));
56
+ }, [d, r]);
57
+ const b = a.useMemo(() => ({
58
+ register: E,
59
+ unregister: I,
60
+ subscribeMapChange: g,
61
+ elementsRef: t,
62
+ labelsRef: o,
63
+ nextIndexRef: O
64
+ }), [E, I, g, t, o, O]);
65
+ return /* @__PURE__ */ L(D.Provider, {
66
+ value: b,
67
+ children: N
68
+ });
69
+ }
70
+ function P() {
71
+ return /* @__PURE__ */ new Map();
72
+ }
73
+ function R() {
74
+ return /* @__PURE__ */ new Set();
75
+ }
76
+ function S(h, N) {
77
+ const t = h.compareDocumentPosition(N);
78
+ return t & Node.DOCUMENT_POSITION_FOLLOWING || t & Node.DOCUMENT_POSITION_CONTAINED_BY ? -1 : t & Node.DOCUMENT_POSITION_PRECEDING || t & Node.DOCUMENT_POSITION_CONTAINS ? 1 : 0;
79
+ }
80
+ export {
81
+ k as CompositeList
82
+ };
@@ -0,0 +1,14 @@
1
+ import r from "./index100.js";
2
+ import * as e from "react";
3
+ const o = /* @__PURE__ */ e.createContext(void 0);
4
+ process.env.NODE_ENV !== "production" && (o.displayName = "ContextMenuRootContext");
5
+ function u(n = !0) {
6
+ const t = e.useContext(o);
7
+ if (t === void 0 && !n)
8
+ throw new Error(process.env.NODE_ENV !== "production" ? "Base UI: ContextMenuRootContext is missing. ContextMenu parts must be placed within <ContextMenu.Root>." : r(25));
9
+ return t;
10
+ }
11
+ export {
12
+ o as ContextMenuRootContext,
13
+ u as useContextMenuRootContext
14
+ };
@@ -0,0 +1,59 @@
1
+ "use client";
2
+ import * as r from "react";
3
+ import { useId as a } from "./index149.js";
4
+ import { useIsoLayoutEffect as l } from "./index97.js";
5
+ import { useRefWithInit as f } from "./index107.js";
6
+ import { FloatingTreeStore as m } from "./index163.js";
7
+ import { jsx as d } from "react/jsx-runtime";
8
+ const i = /* @__PURE__ */ r.createContext(null);
9
+ process.env.NODE_ENV !== "production" && (i.displayName = "FloatingNodeContext");
10
+ const s = /* @__PURE__ */ r.createContext(null);
11
+ process.env.NODE_ENV !== "production" && (s.displayName = "FloatingTreeContext");
12
+ const u = () => r.useContext(i)?.id || null, p = (o) => {
13
+ const e = r.useContext(s);
14
+ return o ?? e;
15
+ };
16
+ function v(o) {
17
+ const e = a(), t = p(o), n = u();
18
+ return l(() => {
19
+ if (!e)
20
+ return;
21
+ const c = {
22
+ id: e,
23
+ parentId: n
24
+ };
25
+ return t?.addNode(c), () => {
26
+ t?.removeNode(c);
27
+ };
28
+ }, [t, e, n]), e;
29
+ }
30
+ function I(o) {
31
+ const {
32
+ children: e,
33
+ id: t
34
+ } = o, n = u();
35
+ return /* @__PURE__ */ d(i.Provider, {
36
+ value: r.useMemo(() => ({
37
+ id: t,
38
+ parentId: n
39
+ }), [t, n]),
40
+ children: e
41
+ });
42
+ }
43
+ function T(o) {
44
+ const {
45
+ children: e,
46
+ externalTree: t
47
+ } = o, n = f(() => t ?? new m()).current;
48
+ return /* @__PURE__ */ d(s.Provider, {
49
+ value: n,
50
+ children: e
51
+ });
52
+ }
53
+ export {
54
+ I as FloatingNode,
55
+ T as FloatingTree,
56
+ v as useFloatingNodeId,
57
+ u as useFloatingParentNodeId,
58
+ p as useFloatingTree
59
+ };
@@ -0,0 +1,14 @@
1
+ import n from "./index100.js";
2
+ import * as e from "react";
3
+ const t = /* @__PURE__ */ e.createContext(void 0);
4
+ process.env.NODE_ENV !== "production" && (t.displayName = "MenuRadioGroupContext");
5
+ function i() {
6
+ const o = e.useContext(t);
7
+ if (o === void 0)
8
+ throw new Error(process.env.NODE_ENV !== "production" ? "Base UI: MenuRadioGroupContext is missing. MenuRadioGroup parts must be placed within <Menu.RadioGroup>." : n(34));
9
+ return o;
10
+ }
11
+ export {
12
+ t as MenuRadioGroupContext,
13
+ i as useMenuRadioGroupContext
14
+ };
@@ -0,0 +1,14 @@
1
+ import n from "./index100.js";
2
+ import * as t from "react";
3
+ const o = /* @__PURE__ */ t.createContext(void 0);
4
+ process.env.NODE_ENV !== "production" && (o.displayName = "MenuRadioItemContext");
5
+ function r() {
6
+ const e = t.useContext(o);
7
+ if (e === void 0)
8
+ throw new Error(process.env.NODE_ENV !== "production" ? "Base UI: MenuRadioItemContext is missing. MenuRadioItem parts must be placed within <Menu.RadioItem>." : n(35));
9
+ return e;
10
+ }
11
+ export {
12
+ o as MenuRadioItemContext,
13
+ r as useMenuRadioItemContext
14
+ };
@@ -0,0 +1,33 @@
1
+ "use client";
2
+ import { useRefWithInit as c } from "./index107.js";
3
+ import { useOnMount as u } from "./index215.js";
4
+ const t = 0;
5
+ class e {
6
+ static create() {
7
+ return new e();
8
+ }
9
+ currentId = t;
10
+ /**
11
+ * Executes `fn` after `delay`, clearing any previously scheduled call.
12
+ */
13
+ start(s, i) {
14
+ this.clear(), this.currentId = setTimeout(() => {
15
+ this.currentId = t, i();
16
+ }, s);
17
+ }
18
+ isStarted() {
19
+ return this.currentId !== t;
20
+ }
21
+ clear = () => {
22
+ this.currentId !== t && (clearTimeout(this.currentId), this.currentId = t);
23
+ };
24
+ disposeEffect = () => this.clear;
25
+ }
26
+ function a() {
27
+ const r = c(e.create).current;
28
+ return u(r.disposeEffect), r;
29
+ }
30
+ export {
31
+ e as Timeout,
32
+ a as useTimeout
33
+ };
@@ -0,0 +1,21 @@
1
+ "use client";
2
+ import * as n from "react";
3
+ import { SafeReact as l } from "./index216.js";
4
+ let o = 0;
5
+ function f(u, t = "mui") {
6
+ const [e, a] = n.useState(u), c = u || e;
7
+ return n.useEffect(() => {
8
+ e == null && (o += 1, a(`${t}-${o}`));
9
+ }, [e, t]), c;
10
+ }
11
+ const s = l.useId;
12
+ function I(u, t) {
13
+ if (s !== void 0) {
14
+ const e = s();
15
+ return u ?? (t ? `${t}-${e}` : e);
16
+ }
17
+ return f(u, t);
18
+ }
19
+ export {
20
+ I as useId
21
+ };
@@ -0,0 +1,19 @@
1
+ import { jsx as e } from "react/jsx-runtime";
2
+ import "react";
3
+ import { cn as t } from "./index16.js";
4
+ function o({ className: i, ...r }) {
5
+ return /* @__PURE__ */ e(
6
+ "textarea",
7
+ {
8
+ "data-slot": "textarea",
9
+ className: t(
10
+ "border-input dark:bg-input/30 focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive dark:aria-invalid:border-destructive/50 disabled:bg-input/50 dark:disabled:bg-input/80 rounded-lg border bg-transparent px-2.5 py-2 text-base transition-colors focus-visible:ring-[3px] aria-invalid:ring-[3px] md:text-sm placeholder:text-muted-foreground flex field-sizing-content min-h-16 w-full outline-none disabled:cursor-not-allowed disabled:opacity-50",
11
+ i
12
+ ),
13
+ ...r
14
+ }
15
+ );
16
+ }
17
+ export {
18
+ o as Textarea
19
+ };
@@ -0,0 +1,69 @@
1
+ "use client";
2
+ import { useRefWithInit as u } from "./index107.js";
3
+ import { useOnMount as h } from "./index215.js";
4
+ const s = null;
5
+ let l = globalThis.requestAnimationFrame;
6
+ class o {
7
+ /* This implementation uses an array as a backing data-structure for frame callbacks.
8
+ * It allows `O(1)` callback cancelling by inserting a `null` in the array, though it
9
+ * never calls the native `cancelAnimationFrame` if there are no frames left. This can
10
+ * be much more efficient if there is a call pattern that alterns as
11
+ * "request-cancel-request-cancel-…".
12
+ * But in the case of "request-request-…-cancel-cancel-…", it leaves the final animation
13
+ * frame to run anyway. We turn that frame into a `O(1)` no-op via `callbacksCount`. */
14
+ callbacks = [];
15
+ callbacksCount = 0;
16
+ nextId = 1;
17
+ startId = 1;
18
+ isScheduled = !1;
19
+ tick = (t) => {
20
+ this.isScheduled = !1;
21
+ const e = this.callbacks, i = this.callbacksCount;
22
+ if (this.callbacks = [], this.callbacksCount = 0, this.startId = this.nextId, i > 0)
23
+ for (let r = 0; r < e.length; r += 1)
24
+ e[r]?.(t);
25
+ };
26
+ request(t) {
27
+ const e = this.nextId;
28
+ this.nextId += 1, this.callbacks.push(t), this.callbacksCount += 1;
29
+ const i = process.env.NODE_ENV === "test" && l !== requestAnimationFrame && (l = requestAnimationFrame, !0);
30
+ return (!this.isScheduled || i) && (requestAnimationFrame(this.tick), this.isScheduled = !0), e;
31
+ }
32
+ cancel(t) {
33
+ const e = t - this.startId;
34
+ e < 0 || e >= this.callbacks.length || (this.callbacks[e] = null, this.callbacksCount -= 1);
35
+ }
36
+ }
37
+ const c = new o();
38
+ class a {
39
+ static create() {
40
+ return new a();
41
+ }
42
+ static request(t) {
43
+ return c.request(t);
44
+ }
45
+ static cancel(t) {
46
+ return c.cancel(t);
47
+ }
48
+ currentId = s;
49
+ /**
50
+ * Executes `fn` after `delay`, clearing any previously scheduled call.
51
+ */
52
+ request(t) {
53
+ this.cancel(), this.currentId = c.request(() => {
54
+ this.currentId = s, t();
55
+ });
56
+ }
57
+ cancel = () => {
58
+ this.currentId !== s && (c.cancel(this.currentId), this.currentId = s);
59
+ };
60
+ disposeEffect = () => this.cancel;
61
+ }
62
+ function k() {
63
+ const n = u(a.create).current;
64
+ return h(n.disposeEffect), n;
65
+ }
66
+ export {
67
+ a as AnimationFrame,
68
+ k as useAnimationFrame
69
+ };