@synnaxlabs/pluto 0.40.0 → 0.41.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 (392) hide show
  1. package/dist/{Center-DoAxDY5V.js → Center-Dr9Np3yZ.js} +4 -4
  2. package/dist/Center-sJghNsrv.cjs +1 -0
  3. package/dist/ContextMenu-DCxj35_j.cjs +1 -0
  4. package/dist/ContextMenu-GUed89mt.js +96 -0
  5. package/dist/DateTime-D6J8sRSH.cjs +1 -0
  6. package/dist/{DateTime-sO15tvDD.js → DateTime-DEbT6v4l.js} +3 -3
  7. package/dist/{Divider-C5m3c4pv.js → Divider-Bpe7zJig.js} +804 -878
  8. package/dist/Divider-CloQr3vQ.cjs +22 -0
  9. package/dist/Dropdown-4Cti-bbQ.js +328 -0
  10. package/dist/Dropdown-C7Im-qW-.cjs +1 -0
  11. package/dist/{Haul-DrdXQaTq.js → Haul-Bw54Yj6J.js} +9 -9
  12. package/dist/{Haul-CoG7Jmz6.cjs → Haul-hv7TLQ7N.cjs} +1 -1
  13. package/dist/Item-9WCCzBv2.js +110 -0
  14. package/dist/Item-piF6rFAm.cjs +1 -0
  15. package/dist/{Keyboard-lwCx7plR.js → Keyboard-634856lT.js} +11 -9
  16. package/dist/Keyboard-CZFi6COK.cjs +1 -0
  17. package/dist/{Link-lleSh5eG.js → Link-BEheZd26.js} +2 -2
  18. package/dist/{Link-BSZ-HrRf.cjs → Link-fkoogssj.cjs} +1 -1
  19. package/dist/Pack-D6Z6WuZl.cjs +1 -0
  20. package/dist/Pack-DhZO_rza.js +48 -0
  21. package/dist/Provider-DNTq46b0.cjs +1 -0
  22. package/dist/Provider-UAXPVomG.js +452 -0
  23. package/dist/Space-BtaH1buB.cjs +1 -0
  24. package/dist/Space-DunsWl06.js +100 -0
  25. package/dist/Text-3PiRcn8q.js +1246 -0
  26. package/dist/Text-BTEov6di.cjs +1 -0
  27. package/dist/Text-CaRMYy3U.js +135 -0
  28. package/dist/Text-DNspRcte.js +36 -0
  29. package/dist/Text-DylGoRKw.cjs +4 -0
  30. package/dist/Text-X_BHez8W.cjs +1 -0
  31. package/dist/Toggle-BKKBcuTj.cjs +1 -0
  32. package/dist/Toggle-CZd8L4GI.js +379 -0
  33. package/dist/{Video-DPIAdJ-g.js → Video-4XQ1qozd.js} +2 -2
  34. package/dist/{Video-BJudMCoc.cjs → Video-BM9uJLaQ.cjs} +1 -1
  35. package/dist/WithIcon-CC-RSx6r.js +93 -0
  36. package/dist/WithIcon-Dn8eAoMj.cjs +1 -0
  37. package/dist/{aggregator-Dd6-VUPG.cjs → aggregator-74jWxDne.cjs} +1 -1
  38. package/dist/{aggregator-Bo5bXe2h.js → aggregator-DMvP8cai.js} +6 -6
  39. package/dist/align.cjs +1 -1
  40. package/dist/align.js +1 -1
  41. package/dist/button.cjs +1 -1
  42. package/dist/button.js +1 -1
  43. package/dist/color.cjs +1 -1
  44. package/dist/color.js +1 -1
  45. package/dist/css-Cj2UCGXB.cjs +1 -0
  46. package/dist/{css-rxwBYwM1.js → css-Dyt-QnKy.js} +467 -462
  47. package/dist/css.cjs +1 -1
  48. package/dist/css.js +2 -2
  49. package/dist/{deep-ChDJVfub.js → deep-Cvb4bVYY.js} +1 -1
  50. package/dist/{deep-BjupBYvk.cjs → deep-ICSlPm58.cjs} +1 -1
  51. package/dist/{dimensions-Bt1NqWz6.js → dimensions-Cc0z-IDd.js} +1 -1
  52. package/dist/dimensions-Djqdrqi0.cjs +1 -0
  53. package/dist/dropdown.cjs +1 -1
  54. package/dist/dropdown.js +1 -1
  55. package/dist/{eraser-BsY8Ilvt.cjs → eraser-9-LOWZvk.cjs} +3 -3
  56. package/dist/{eraser-B8b1ORvV.js → eraser-BjtEI-1I.js} +10 -10
  57. package/dist/ether.cjs +1 -1
  58. package/dist/ether.js +32 -31
  59. package/dist/{external-DhX0dZoF.cjs → external-B-Cao-ae.cjs} +1 -1
  60. package/dist/external-B-UNCzPY.cjs +1 -0
  61. package/dist/external-B18FBGpk.cjs +1 -0
  62. package/dist/{external-DNUUgDyq.js → external-BCUxzSzk.js} +33 -32
  63. package/dist/{external-cFoSk0PK.js → external-BFOrrNde.js} +3 -3
  64. package/dist/external-BG1mV1W8.cjs +1 -0
  65. package/dist/{external-CGxC3uw1.js → external-BIwhkj24.js} +456 -454
  66. package/dist/external-BWeX0nyq.js +399 -0
  67. package/dist/{external-C8i1PCpN.js → external-BY2AjzRx.js} +15 -15
  68. package/dist/external-BbmpRAH3.cjs +1 -0
  69. package/dist/{external-DK_wU08V.js → external-BbrPEGJw.js} +2 -2
  70. package/dist/external-BlUic3Vz.js +29 -0
  71. package/dist/{external-D18IGHXh.js → external-C0ZRdtdj.js} +21 -20
  72. package/dist/{external-GUQ0NMxY.js → external-CH66YjTZ.js} +19 -18
  73. package/dist/{external-Bxg2-RDn.js → external-CVGidiDt.js} +2 -2
  74. package/dist/{external-BmbDPHD3.cjs → external-CnxSp7fm.cjs} +1 -1
  75. package/dist/{external-CSKJSiQJ.cjs → external-D2vS6j9c.cjs} +2 -2
  76. package/dist/external-DHmQqAfL.js +435 -0
  77. package/dist/{external-BtHnb3Sp.js → external-DNF8yEwq.js} +5485 -5443
  78. package/dist/{external-AOOzgEKd.cjs → external-DRGfSFQT.cjs} +1 -1
  79. package/dist/{external-CRbERCqd.cjs → external-DVajt6X6.cjs} +1 -1
  80. package/dist/external-DX4m-5qT.cjs +1 -0
  81. package/dist/external-DlywBW-S.cjs +1 -0
  82. package/dist/{external-CKvBpFrE.cjs → external-kZf9CjYn.cjs} +35 -35
  83. package/dist/{font-BBeEt9tk.js → font-BXKdXsr5.js} +2 -2
  84. package/dist/{font-DshP3AG2.cjs → font-DCE90lco.cjs} +1 -1
  85. package/dist/fontString-BBvH9Ypy.cjs +1 -0
  86. package/dist/fontString-C7Q9Laqk.js +28 -0
  87. package/dist/header.cjs +1 -1
  88. package/dist/header.js +1 -1
  89. package/dist/hooks-BQJQyGWV.js +293 -0
  90. package/dist/hooks-ClXSlga9.cjs +1 -0
  91. package/dist/{state-w46WTrh-.js → index-CSKP1UPN.js} +385 -441
  92. package/dist/index-Ch3utIMa.cjs +15 -0
  93. package/dist/index.cjs +7 -7
  94. package/dist/index.js +8088 -7071
  95. package/dist/input.cjs +1 -1
  96. package/dist/input.js +1 -1
  97. package/dist/jsx-runtime-C5mzlN2N.js +284 -0
  98. package/dist/jsx-runtime-CITbqOLs.cjs +22 -0
  99. package/dist/list.cjs +1 -1
  100. package/dist/list.js +1 -1
  101. package/dist/menu.cjs +1 -1
  102. package/dist/menu.js +1 -1
  103. package/dist/pluto.css +1 -1
  104. package/dist/{provider-BsPH6eua.js → provider-CH0eoGfz.js} +2143 -2085
  105. package/dist/provider-D054LCpB.cjs +53 -0
  106. package/dist/src/aether/main.d.ts +48 -0
  107. package/dist/src/aether/main.d.ts.map +1 -1
  108. package/dist/src/align/Center.d.ts +2 -2
  109. package/dist/src/align/Center.d.ts.map +1 -1
  110. package/dist/src/align/Pack.d.ts +3 -3
  111. package/dist/src/align/Pack.d.ts.map +1 -1
  112. package/dist/src/align/Space.d.ts +25 -10
  113. package/dist/src/align/Space.d.ts.map +1 -1
  114. package/dist/src/align/Stack.d.ts +7 -0
  115. package/dist/src/align/Stack.d.ts.map +1 -0
  116. package/dist/src/align/external.d.ts +1 -0
  117. package/dist/src/align/external.d.ts.map +1 -1
  118. package/dist/src/breadcrumb/Breadcrumb.d.ts +2 -2
  119. package/dist/src/breadcrumb/Breadcrumb.d.ts.map +1 -1
  120. package/dist/src/button/Button.d.ts +2 -4
  121. package/dist/src/button/Button.d.ts.map +1 -1
  122. package/dist/src/button/Icon.d.ts +4 -1
  123. package/dist/src/button/Icon.d.ts.map +1 -1
  124. package/dist/src/button/Toggle.d.ts +0 -1
  125. package/dist/src/button/Toggle.d.ts.map +1 -1
  126. package/dist/src/caret/Animated.d.ts +3 -2
  127. package/dist/src/caret/Animated.d.ts.map +1 -1
  128. package/dist/src/channel/LinePlot.d.ts +1 -1
  129. package/dist/src/channel/LinePlot.d.ts.map +1 -1
  130. package/dist/src/channel/Select.d.ts +3 -3
  131. package/dist/src/channel/Select.d.ts.map +1 -1
  132. package/dist/src/color/Picker.d.ts.map +1 -1
  133. package/dist/src/css/css.d.ts +2 -1
  134. package/dist/src/css/css.d.ts.map +1 -1
  135. package/dist/src/divider/Divider.d.ts +4 -4
  136. package/dist/src/divider/Divider.d.ts.map +1 -1
  137. package/dist/src/dropdown/Dropdown.d.ts +2 -1
  138. package/dist/src/dropdown/Dropdown.d.ts.map +1 -1
  139. package/dist/src/generic/Generic.d.ts +4 -5
  140. package/dist/src/generic/Generic.d.ts.map +1 -1
  141. package/dist/src/hardware/device/Select.d.ts.map +1 -1
  142. package/dist/src/icon/Icon.d.ts.map +1 -1
  143. package/dist/src/input/DateTime.d.ts.map +1 -1
  144. package/dist/src/input/Item.d.ts +1 -1
  145. package/dist/src/input/Item.d.ts.map +1 -1
  146. package/dist/src/input/Text.d.ts +1 -1
  147. package/dist/src/input/Text.d.ts.map +1 -1
  148. package/dist/src/input/types.d.ts +0 -1
  149. package/dist/src/input/types.d.ts.map +1 -1
  150. package/dist/src/list/Column.d.ts +3 -3
  151. package/dist/src/list/Column.d.ts.map +1 -1
  152. package/dist/src/list/Core.d.ts +1 -1
  153. package/dist/src/list/Core.d.ts.map +1 -1
  154. package/dist/src/list/Hover.d.ts +3 -2
  155. package/dist/src/list/Hover.d.ts.map +1 -1
  156. package/dist/src/list/Item.d.ts +1 -1
  157. package/dist/src/list/Item.d.ts.map +1 -1
  158. package/dist/src/main.d.ts.map +1 -1
  159. package/dist/src/menu/ContextMenu.d.ts +5 -3
  160. package/dist/src/menu/ContextMenu.d.ts.map +1 -1
  161. package/dist/src/menu/Item.d.ts.map +1 -1
  162. package/dist/src/menu/Menu.d.ts +3 -2
  163. package/dist/src/menu/Menu.d.ts.map +1 -1
  164. package/dist/src/modal/Modal.d.ts +7 -3
  165. package/dist/src/modal/Modal.d.ts.map +1 -1
  166. package/dist/src/mosaic/Mosaic.d.ts +5 -3
  167. package/dist/src/mosaic/Mosaic.d.ts.map +1 -1
  168. package/dist/src/mosaic/tree.d.ts +4 -3
  169. package/dist/src/mosaic/tree.d.ts.map +1 -1
  170. package/dist/src/mosaic/types.d.ts +6 -6
  171. package/dist/src/nav/Bar.d.ts +2 -1
  172. package/dist/src/nav/Bar.d.ts.map +1 -1
  173. package/dist/src/nav/Drawer.d.ts +3 -2
  174. package/dist/src/nav/Drawer.d.ts.map +1 -1
  175. package/dist/src/notation/Select.d.ts +2 -3
  176. package/dist/src/notation/Select.d.ts.map +1 -1
  177. package/dist/src/notation/index.d.ts +1 -1
  178. package/dist/src/notation/index.d.ts.map +1 -1
  179. package/dist/src/os/Controls/Windows.d.ts +1 -1
  180. package/dist/src/os/Controls/Windows.d.ts.map +1 -1
  181. package/dist/src/os/Controls/types.d.ts +2 -0
  182. package/dist/src/os/Controls/types.d.ts.map +1 -1
  183. package/dist/src/ranger/TimeRangeChip.d.ts +2 -1
  184. package/dist/src/ranger/TimeRangeChip.d.ts.map +1 -1
  185. package/dist/src/resize/Core.d.ts +5 -4
  186. package/dist/src/resize/Core.d.ts.map +1 -1
  187. package/dist/src/resize/Multiple.d.ts.map +1 -1
  188. package/dist/src/resize/Single.d.ts.map +1 -1
  189. package/dist/src/select/Button.d.ts.map +1 -1
  190. package/dist/src/select/List.d.ts.map +1 -1
  191. package/dist/src/select/Multiple.d.ts.map +1 -1
  192. package/dist/src/status/Notification.d.ts.map +1 -1
  193. package/dist/src/status/aether/aggregator.d.ts +8 -8
  194. package/dist/src/status/aether/aggregator.d.ts.map +1 -1
  195. package/dist/src/status/aether/types.d.ts +2 -2
  196. package/dist/src/status/aether/types.d.ts.map +1 -1
  197. package/dist/src/status/colors.d.ts +1 -1
  198. package/dist/src/status/colors.d.ts.map +1 -1
  199. package/dist/src/synnax/aether/provider.d.ts.map +1 -1
  200. package/dist/src/table/aether/Table.d.ts +3 -3
  201. package/dist/src/table/aether/Table.d.ts.map +1 -1
  202. package/dist/src/table/cells/Cells.d.ts +2 -2
  203. package/dist/src/table/cells/Cells.d.ts.map +1 -1
  204. package/dist/src/tabs/Selector.d.ts +5 -2
  205. package/dist/src/tabs/Selector.d.ts.map +1 -1
  206. package/dist/src/tabs/Tabs.d.ts +2 -3
  207. package/dist/src/tabs/Tabs.d.ts.map +1 -1
  208. package/dist/src/tabs/types.d.ts +4 -4
  209. package/dist/src/tag/Tag.d.ts.map +1 -1
  210. package/dist/src/telem/aether/remote.d.ts.map +1 -1
  211. package/dist/src/telem/aether/transformers.d.ts +6 -6
  212. package/dist/src/telem/aether/transformers.d.ts.map +1 -1
  213. package/dist/src/telem/control/aether/chip.d.ts +8 -8
  214. package/dist/src/telem/control/aether/chip.d.ts.map +1 -1
  215. package/dist/src/telem/control/aether/indicator.d.ts +8 -8
  216. package/dist/src/telem/control/aether/indicator.d.ts.map +1 -1
  217. package/dist/src/telem/control/aether/legend.d.ts.map +1 -1
  218. package/dist/src/telem/control/aether/state.d.ts.map +1 -1
  219. package/dist/src/text/Editable.d.ts.map +1 -1
  220. package/dist/src/text/Keyboard.d.ts +1 -1
  221. package/dist/src/text/Keyboard.d.ts.map +1 -1
  222. package/dist/src/text/WithIcon.d.ts +3 -2
  223. package/dist/src/text/WithIcon.d.ts.map +1 -1
  224. package/dist/src/text/core/types.d.ts.map +1 -1
  225. package/dist/src/theming/Provider.d.ts.map +1 -1
  226. package/dist/src/theming/aether/provider.d.ts +650 -530
  227. package/dist/src/theming/aether/provider.d.ts.map +1 -1
  228. package/dist/src/theming/core/fontString.d.ts.map +1 -1
  229. package/dist/src/theming/core/theme.d.ts +229 -187
  230. package/dist/src/theming/core/theme.d.ts.map +1 -1
  231. package/dist/src/theming/css.d.ts +1 -1
  232. package/dist/src/theming/css.d.ts.map +1 -1
  233. package/dist/src/theming/static/generate.d.ts +2 -0
  234. package/dist/src/theming/static/generate.d.ts.map +1 -0
  235. package/dist/src/tooltip/Dialog.d.ts.map +1 -1
  236. package/dist/src/tree/Tree.d.ts +1 -1
  237. package/dist/src/tree/Tree.d.ts.map +1 -1
  238. package/dist/src/tree/core.d.ts +2 -2
  239. package/dist/src/tree/core.d.ts.map +1 -1
  240. package/dist/src/triggers/Provider.d.ts.map +1 -1
  241. package/dist/src/triggers/Text.d.ts.map +1 -1
  242. package/dist/src/triggers/hooks.d.ts +1 -0
  243. package/dist/src/triggers/hooks.d.ts.map +1 -1
  244. package/dist/src/util/component.d.ts +2 -2
  245. package/dist/src/util/component.d.ts.map +1 -1
  246. package/dist/src/viewport/Mask.d.ts.map +1 -1
  247. package/dist/src/viewport/SelectMode.d.ts +2 -1
  248. package/dist/src/viewport/SelectMode.d.ts.map +1 -1
  249. package/dist/src/viewport/use.d.ts +3 -3
  250. package/dist/src/viewport/use.d.ts.map +1 -1
  251. package/dist/src/vis/axis/preciseTimeScale.d.ts +102 -0
  252. package/dist/src/vis/axis/preciseTimeScale.d.ts.map +1 -0
  253. package/dist/src/vis/axis/preciseTimeScale.spec.d.ts +2 -0
  254. package/dist/src/vis/axis/preciseTimeScale.spec.d.ts.map +1 -0
  255. package/dist/src/vis/axis/ticks.d.ts.map +1 -1
  256. package/dist/src/vis/canvas/aether/canvas.d.ts.map +1 -1
  257. package/dist/src/vis/diagram/Diagram.d.ts.map +1 -1
  258. package/dist/src/vis/diagram/aether/Diagram.d.ts +3 -3
  259. package/dist/src/vis/diagram/aether/Diagram.d.ts.map +1 -1
  260. package/dist/src/vis/diagram/aether/types.d.ts +8 -8
  261. package/dist/src/vis/diagram/aether/types.d.ts.map +1 -1
  262. package/dist/src/vis/draw2d/index.d.ts +16 -1
  263. package/dist/src/vis/draw2d/index.d.ts.map +1 -1
  264. package/dist/src/vis/eraser/aether/eraser.d.ts.map +1 -1
  265. package/dist/src/vis/eraser/use.d.ts +2 -2
  266. package/dist/src/vis/eraser/use.d.ts.map +1 -1
  267. package/dist/src/vis/legend/Container.d.ts +6 -6
  268. package/dist/src/vis/legend/Container.d.ts.map +1 -1
  269. package/dist/src/vis/legend/Simple.d.ts +14 -3
  270. package/dist/src/vis/legend/Simple.d.ts.map +1 -1
  271. package/dist/src/vis/line/aether/line.d.ts +4 -1
  272. package/dist/src/vis/line/aether/line.d.ts.map +1 -1
  273. package/dist/src/vis/lineplot/Legend.d.ts.map +1 -1
  274. package/dist/src/vis/lineplot/Line.d.ts +1 -1
  275. package/dist/src/vis/lineplot/Line.d.ts.map +1 -1
  276. package/dist/src/vis/lineplot/LinePlot.d.ts +1 -0
  277. package/dist/src/vis/lineplot/LinePlot.d.ts.map +1 -1
  278. package/dist/src/vis/lineplot/aether/LinePlot.d.ts.map +1 -1
  279. package/dist/src/vis/lineplot/aether/XAxis.d.ts +6 -6
  280. package/dist/src/vis/lineplot/aether/YAxis.d.ts +6 -6
  281. package/dist/src/vis/lineplot/aether/axis.d.ts +3 -3
  282. package/dist/src/vis/lineplot/aether/axis.d.ts.map +1 -1
  283. package/dist/src/vis/lineplot/range/Provider.d.ts.map +1 -1
  284. package/dist/src/vis/lineplot/range/aether/annotation.d.ts +6 -6
  285. package/dist/src/vis/lineplot/range/aether/annotation.d.ts.map +1 -1
  286. package/dist/src/vis/lineplot/range/aether/provider.d.ts.map +1 -1
  287. package/dist/src/vis/lineplot/tooltip/aether/tooltip.d.ts.map +1 -1
  288. package/dist/src/vis/log/Log.d.ts.map +1 -1
  289. package/dist/src/vis/log/aether/Log.d.ts +12 -12
  290. package/dist/src/vis/log/aether/Log.d.ts.map +1 -1
  291. package/dist/src/vis/measure/aether/measure.d.ts.map +1 -1
  292. package/dist/src/vis/rule/Rule.d.ts.map +1 -1
  293. package/dist/src/vis/schematic/Forms.d.ts +7 -1
  294. package/dist/src/vis/schematic/Forms.d.ts.map +1 -1
  295. package/dist/src/vis/schematic/Symbols.d.ts +54 -5
  296. package/dist/src/vis/schematic/Symbols.d.ts.map +1 -1
  297. package/dist/src/vis/schematic/primitives/Primitives.d.ts +41 -1
  298. package/dist/src/vis/schematic/primitives/Primitives.d.ts.map +1 -1
  299. package/dist/src/vis/schematic/registry.d.ts +1 -1
  300. package/dist/src/vis/schematic/registry.d.ts.map +1 -1
  301. package/dist/src/vis/value/Form.d.ts.map +1 -1
  302. package/dist/src/vis/value/aether/value.d.ts +6 -6
  303. package/dist/src/vis/value/aether/value.d.ts.map +1 -1
  304. package/dist/src/vis/value/use.d.ts +2 -2
  305. package/dist/src/vis/value/use.d.ts.map +1 -1
  306. package/dist/state-Bd_8X2jl.cjs +1 -0
  307. package/dist/state-CjGemC7S.js +88 -0
  308. package/dist/tabs.cjs +1 -1
  309. package/dist/tabs.js +1 -1
  310. package/dist/text.cjs +1 -1
  311. package/dist/text.js +2 -2
  312. package/dist/theme.css +1600 -0
  313. package/dist/theming.cjs +1 -1
  314. package/dist/theming.js +2 -2
  315. package/dist/{transformColorsToHex-B2Bui-Wf.cjs → transformColorsToHex-DE7uEs1w.cjs} +1 -1
  316. package/dist/{transformColorsToHex-B6dG2LA6.js → transformColorsToHex-UBrryWh5.js} +1 -1
  317. package/dist/tree.cjs +1 -1
  318. package/dist/tree.js +1 -1
  319. package/dist/triggers.cjs +1 -1
  320. package/dist/triggers.js +1 -1
  321. package/dist/{units-CvIf5nF_.cjs → units-DjoHPrqM.cjs} +1 -1
  322. package/dist/{units-D7qkgH-s.js → units-MBd0L3ff.js} +1 -1
  323. package/dist/useClickOutside-4k9PAT_i.cjs +1 -0
  324. package/dist/{useClickOutside-vpv_GiBw.js → useClickOutside-BYjsXGgb.js} +28 -28
  325. package/dist/{useDebouncedCallback-CVLx7N1s.cjs → useDebouncedCallback-BBsAgC9k.cjs} +1 -1
  326. package/dist/{useDebouncedCallback-DDLuEZa8.js → useDebouncedCallback-Dg4BDGP-.js} +1 -1
  327. package/dist/{useMemoCompare-B-Y9Ft2w.js → useMemoCompare-BEDaTIXL.js} +2 -2
  328. package/dist/useMemoCompare-DORTZbzY.cjs +1 -0
  329. package/dist/useVirtualCursorDragWebKit-BSafZVD_.cjs +1 -0
  330. package/dist/{useVirtualCursorDragWebKit-DFC-XFfl.js → useVirtualCursorDragWebKit-BixysrXI.js} +28 -27
  331. package/dist/{value-C9u1Km9t.js → value-CudL8z5e.js} +1891 -1716
  332. package/dist/value-DT0qJqgQ.cjs +57 -0
  333. package/dist/video.cjs +1 -1
  334. package/dist/video.js +1 -1
  335. package/package.json +22 -20
  336. package/dist/Center-BjxFDxgi.cjs +0 -1
  337. package/dist/ContextMenu-BWGS1vXl.cjs +0 -1
  338. package/dist/ContextMenu-DX6j7Wwi.js +0 -101
  339. package/dist/DateTime-DUuYjZr8.cjs +0 -1
  340. package/dist/Divider-MIbyu5ZH.cjs +0 -31
  341. package/dist/Dropdown-DurKTABg.cjs +0 -1
  342. package/dist/Dropdown-FSmdakic.js +0 -261
  343. package/dist/Item-CZAsnOoO.js +0 -108
  344. package/dist/Item-Dj7cQJ8t.cjs +0 -1
  345. package/dist/Keyboard-D4FRdVej.cjs +0 -1
  346. package/dist/Pack-CzZzxA2R.cjs +0 -1
  347. package/dist/Pack-Dlj4dZzQ.js +0 -46
  348. package/dist/Provider-CvqYCQ-c.js +0 -436
  349. package/dist/Provider-DdzMK2ly.cjs +0 -1
  350. package/dist/Space-DBmhvGQL.js +0 -76
  351. package/dist/Space-NNqCWFbg.cjs +0 -1
  352. package/dist/Text-BBAivtcq.js +0 -124
  353. package/dist/Text-BpgvgYm9.cjs +0 -1
  354. package/dist/Text-D1GKnp9s.cjs +0 -1
  355. package/dist/Text-DKpfyuCy.js +0 -1199
  356. package/dist/Text-Kq93-h4G.cjs +0 -4
  357. package/dist/Text-g6btwQ6E.js +0 -32
  358. package/dist/Toggle-BzORI5sE.cjs +0 -1
  359. package/dist/Toggle-DZMcFiiI.js +0 -356
  360. package/dist/WithIcon-C6COgbZq.js +0 -92
  361. package/dist/WithIcon-CJvuPkSy.cjs +0 -1
  362. package/dist/css-CU7tous7.cjs +0 -1
  363. package/dist/dimensions-IEzi7AOM.cjs +0 -1
  364. package/dist/external-BCMlN9UI.cjs +0 -1
  365. package/dist/external-BJulb-Hm.cjs +0 -1
  366. package/dist/external-BQtPGUNg.cjs +0 -1
  367. package/dist/external-BTGfIw_K.cjs +0 -1
  368. package/dist/external-CqR7Yk0z.js +0 -418
  369. package/dist/external-D3IjVlS7.cjs +0 -1
  370. package/dist/external-DNC1e6Hi.js +0 -343
  371. package/dist/external-Dmr3e50U.js +0 -15
  372. package/dist/external-DrwngojV.cjs +0 -1
  373. package/dist/fontString-CWcKYJNb.cjs +0 -1
  374. package/dist/fontString-DKZUOJ6f.js +0 -12
  375. package/dist/hooks-BKLtEDxx.cjs +0 -1
  376. package/dist/hooks-CwSxEEAh.js +0 -293
  377. package/dist/jsx-runtime-CYK1ROHF.js +0 -445
  378. package/dist/jsx-runtime-UYeBbnYT.cjs +0 -31
  379. package/dist/provider-BaehOXWw.cjs +0 -53
  380. package/dist/src/notation/external.d.ts +0 -3
  381. package/dist/src/notation/external.d.ts.map +0 -1
  382. package/dist/src/notation/notation.d.ts +0 -33
  383. package/dist/src/notation/notation.d.ts.map +0 -1
  384. package/dist/src/notation/notation.spec.d.ts +0 -2
  385. package/dist/src/notation/notation.spec.d.ts.map +0 -1
  386. package/dist/state-BKyv_jWZ.cjs +0 -15
  387. package/dist/useClickOutside-EJHWO4Q9.cjs +0 -1
  388. package/dist/useMemoCompare-ONEAVO05.cjs +0 -1
  389. package/dist/useVirtualCursorDragWebKit-BLtwRQY7.cjs +0 -1
  390. package/dist/value-C_xE_NRc.cjs +0 -57
  391. /package/dist/{Pack-BbwDtaE6.cjs → Stack-BbwDtaE6.cjs} +0 -0
  392. /package/dist/{Pack-D50qN0Vu.js → Stack-D50qN0Vu.js} +0 -0
@@ -0,0 +1,1246 @@
1
+ import { j as x } from "./jsx-runtime-C5mzlN2N.js";
2
+ import { f as $, d as A, y as V, T as oe, c as ze, g as ie } from "./Divider-Bpe7zJig.js";
3
+ import { b as Ae, F as U, a as ke, w as le, C as _e, m as H } from "./index-CSKP1UPN.js";
4
+ import * as L from "react";
5
+ import { useState as k, useCallback as T, use as _, createContext as M, useEffect as R, useMemo as w, useRef as j, memo as je, useContext as ae, useLayoutEffect as ce } from "react";
6
+ import "./Stack-D50qN0Vu.js";
7
+ import { S as q } from "./Space-DunsWl06.js";
8
+ import { C as y, a0 as G } from "./css-Dyt-QnKy.js";
9
+ import { a as Fe, C as Ne } from "./ContextMenu-GUed89mt.js";
10
+ import "./state-CjGemC7S.js";
11
+ import { d as Q } from "./dimensions-Cc0z-IDd.js";
12
+ import { W as ue } from "./WithIcon-CC-RSx6r.js";
13
+ import { c as Ve, C as Le } from "./Provider-UAXPVomG.js";
14
+ import "./provider-CH0eoGfz.js";
15
+ import { u as We } from "./font-BXKdXsr5.js";
16
+ import { flushSync as Be } from "react-dom";
17
+ import { s as J, m as W, a as Pe } from "./hooks-BQJQyGWV.js";
18
+ import { A as $e, o as ee } from "./toArray-Dvn9FA_3.js";
19
+ import { u as Ue } from "./useMemoCompare-BEDaTIXL.js";
20
+ import { a as He, A as Ge, c as qe } from "./aggregator-DMvP8cai.js";
21
+ import { C as Ke } from "./Center-Dr9Np3yZ.js";
22
+ const Xe = ({
23
+ transforms: r = []
24
+ }) => {
25
+ const [l, e] = k(r), t = T(
26
+ (n, i, a = 0) => e((d) => {
27
+ const u = d.filter((h) => h.key !== n);
28
+ return u.push({ key: n, transform: i, priority: a }), u.sort((h, m) => m.priority - h.priority), u;
29
+ }),
30
+ [e]
31
+ ), s = T(
32
+ (n) => e((i) => i.filter((a) => a.key !== n)),
33
+ [t]
34
+ );
35
+ return { transform: T(
36
+ (n) => l.reduce((i, a) => a.transform(i), {
37
+ ...n,
38
+ transformed: !1
39
+ }),
40
+ [l]
41
+ ), setTransform: t, deleteTransform: s };
42
+ }, K = (r) => {
43
+ const l = _(r);
44
+ if (l === null) throw new Error("useRequiredContext: context value is null");
45
+ return l;
46
+ }, de = M({
47
+ transformedData: [],
48
+ sourceData: [],
49
+ transformed: !1
50
+ }), he = M({
51
+ setSourceData: () => {
52
+ },
53
+ getSourceData: () => [],
54
+ getTransformedData: () => [],
55
+ deleteTransform: () => {
56
+ },
57
+ setTransform: () => {
58
+ },
59
+ setEmptyContent: () => {
60
+ },
61
+ getEmptyContent: () => {
62
+ },
63
+ getDefaultEmptyContent: () => {
64
+ },
65
+ getTransformed: () => !1
66
+ }), F = () => K(de), X = () => K(he), es = () => F().transformedData, Ye = () => F().sourceData, fe = () => X().getTransformedData, ts = () => X().setSourceData, Ze = ({
67
+ data: r,
68
+ emptyContent: l,
69
+ children: e
70
+ }) => {
71
+ const { transform: t, setTransform: s, deleteTransform: o } = Xe({}), [n, i, a] = $(() => r ?? []);
72
+ R(() => {
73
+ r != null && i(r);
74
+ }, [r]);
75
+ const d = w(
76
+ () => t({ data: [...n], transformed: !1 }),
77
+ [n, t]
78
+ ), u = A(d), h = A(
79
+ l
80
+ ), [m, p, g] = $(void 0);
81
+ R(() => {
82
+ l != null && p(l);
83
+ }, [l]);
84
+ const c = w(
85
+ () => ({
86
+ setSourceData: i,
87
+ getSourceData: () => a.current,
88
+ getTransformedData: () => u.current.data,
89
+ getTransformed: () => u.current.transformed,
90
+ deleteTransform: o,
91
+ setTransform: s,
92
+ setEmptyContent: p,
93
+ getEmptyContent: () => g.current,
94
+ getDefaultEmptyContent: () => h.current
95
+ }),
96
+ [i, a, u, o, s]
97
+ ), f = w(
98
+ () => ({
99
+ transformed: d.transformed,
100
+ transformedData: d.data,
101
+ sourceData: n,
102
+ emptyContent: m
103
+ }),
104
+ [d, n, m]
105
+ );
106
+ return /* @__PURE__ */ x.jsx(he, { value: c, children: /* @__PURE__ */ x.jsx(de, { value: f, children: e }) });
107
+ }, Qe = ({
108
+ entry: r,
109
+ selected: l,
110
+ hovered: e,
111
+ onSelect: t,
112
+ className: s,
113
+ direction: o = "x",
114
+ draggingOver: n,
115
+ rightAligned: i = !1,
116
+ highlightHovered: a = !1,
117
+ allowSelect: d = !0,
118
+ translate: u,
119
+ style: h,
120
+ sourceIndex: m,
121
+ ...p
122
+ }) => /* @__PURE__ */ x.jsx(
123
+ q,
124
+ {
125
+ id: r.key.toString(),
126
+ direction: o,
127
+ onClick: () => t == null ? void 0 : t(r.key),
128
+ tabIndex: 0,
129
+ className: y(
130
+ s,
131
+ Fe,
132
+ l && Ne,
133
+ d && y.M("selectable"),
134
+ e && y.M("hovered"),
135
+ i && y.M("right-aligned"),
136
+ a && y.M("highlight-hover"),
137
+ y.BE("list", "item"),
138
+ y.selected(l)
139
+ ),
140
+ style: {
141
+ position: u != null ? "absolute" : "relative",
142
+ transform: `translateY(${u}px)`,
143
+ ...h
144
+ },
145
+ ...p
146
+ }
147
+ ), me = M(null), Je = () => K(me), B = "sort", et = ({
148
+ hide: r = !1,
149
+ columns: l,
150
+ children: e,
151
+ level: t = "p",
152
+ weight: s,
153
+ shade: o
154
+ }) => {
155
+ const n = Ye(), { setTransform: i, deleteTransform: a } = X(), d = We("p").toString(), [u, h] = k([null, !1]), [m, p] = k({
156
+ columns: l
157
+ }), g = (c) => {
158
+ const [f, v] = u;
159
+ f === c ? v ? (h([c, !v]), i(B, te(c, !v))) : (h([null, !1]), a(B)) : (h([c, !0]), i(B, te(c, !0)));
160
+ };
161
+ return R(() => {
162
+ p((c) => ({
163
+ columns: nt(
164
+ c.columns.length === 0 ? l : c.columns,
165
+ n,
166
+ d
167
+ )
168
+ }));
169
+ }, [d, n, l]), /* @__PURE__ */ x.jsxs(me, { value: m, children: [
170
+ !r && /* @__PURE__ */ x.jsx(
171
+ q,
172
+ {
173
+ x: !0,
174
+ size: "medium",
175
+ className: y(y.BE("list-col-header", "container"), y.visible(!r)),
176
+ children: m.columns.filter(({ visible: c = !0 }) => c).map(({ key: c, cWidth: f, name: v }) => {
177
+ const [S, E] = u;
178
+ let O;
179
+ const C = n[0];
180
+ return c === S && (O = E ? /* @__PURE__ */ x.jsx(V.Caret.Up, {}) : /* @__PURE__ */ x.jsx(V.Caret.Down, {})), /* @__PURE__ */ x.jsx(
181
+ ue,
182
+ {
183
+ className: y.BE("list-col-header", "item"),
184
+ justify: "spaceBetween",
185
+ level: t,
186
+ weight: s,
187
+ shade: o,
188
+ endIcon: O,
189
+ style: { width: f },
190
+ shrink: !1,
191
+ onClick: () => C != null && c in C && g(c),
192
+ children: v
193
+ },
194
+ c.toString()
195
+ );
196
+ })
197
+ }
198
+ ),
199
+ e
200
+ ] });
201
+ }, tt = ({
202
+ entry: r,
203
+ onSelect: l,
204
+ className: e,
205
+ ...t
206
+ }) => {
207
+ const { columns: s } = Je(), { index: o } = t;
208
+ return /* @__PURE__ */ x.jsx(
209
+ Qe,
210
+ {
211
+ entry: r,
212
+ onSelect: l,
213
+ className: y(
214
+ e,
215
+ y.BE("list-col-item", "container"),
216
+ l != null && y.BEM("list-col-item", "container", "selectable")
217
+ ),
218
+ align: "center",
219
+ size: "medium",
220
+ ...t,
221
+ children: s.filter(({ visible: n = !0 }) => n).map((n) => /* @__PURE__ */ x.jsx(
222
+ st,
223
+ {
224
+ entry: r,
225
+ col: n,
226
+ index: o
227
+ },
228
+ n.key.toString()
229
+ ))
230
+ },
231
+ r.key.toString()
232
+ );
233
+ }, st = ({
234
+ entry: r,
235
+ index: l,
236
+ col: { width: e, ...t }
237
+ }) => {
238
+ const s = {
239
+ width: t.cWidth,
240
+ userSelect: "none",
241
+ padding: "1rem",
242
+ flexShrink: 0
243
+ };
244
+ if (t.render != null) return t.render({ key: t.key, entry: r, style: s, index: l });
245
+ let o;
246
+ return t.stringer != null ? o = t.stringer(r) : o = r[t.key], /* @__PURE__ */ x.jsx(
247
+ oe,
248
+ {
249
+ className: y.BE("list-col-item-value", t.key.toString()),
250
+ level: "p",
251
+ style: s,
252
+ shade: t.shade,
253
+ weight: t.weight,
254
+ children: Ae(o)
255
+ },
256
+ t.key.toString()
257
+ );
258
+ }, nt = (r, l, e, t = 30) => {
259
+ const s = rt(l, r);
260
+ return r.map((o) => {
261
+ if (o.width != null) o.cWidth = o.width;
262
+ else {
263
+ const { width: n } = Q(o.name, e), { width: i } = Q(s[o.key], e);
264
+ o.cWidth = Math.max(n, i) + t;
265
+ }
266
+ return o;
267
+ });
268
+ }, rt = (r, l) => {
269
+ const e = {};
270
+ return r.forEach(
271
+ (t) => l.forEach(({ key: s, stringer: o }) => {
272
+ const n = t[s];
273
+ if (n == null) return;
274
+ const i = o != null ? o(t) : n.toString();
275
+ (!(s in e) || i.length > e[s].length) && (e[s] = i);
276
+ })
277
+ ), e;
278
+ }, te = (r, l) => ({ data: e }) => e.length === 0 ? { data: e, transformed: !1 } : {
279
+ data: [...e].sort(U.newFieldF(r, e[0], !l)),
280
+ transformed: !0
281
+ }, ss = {
282
+ /**
283
+ * The header for a column list.
284
+ *
285
+ * @param columns - The columns to render. See {@link ListColumnT}.
286
+ */
287
+ Header: et,
288
+ /**
289
+ * The item to use for a column list. This should be used as the child render prop
290
+ * in a list render implementation e.g. {@link List.Core.Virtual}.
291
+ *
292
+ * @param props - implements the {@link ItemProps} interface. All these props
293
+ * should be provided by the list render implementation.
294
+ */
295
+ Item: tt,
296
+ /** The default height of a column list item. */
297
+ itemHeight: 5.5 * 6
298
+ };
299
+ function z(r, l, e) {
300
+ let t = e.initialDeps ?? [], s;
301
+ function o() {
302
+ var n, i, a, d;
303
+ let u;
304
+ e.key && ((n = e.debug) != null && n.call(e)) && (u = Date.now());
305
+ const h = r();
306
+ if (!(h.length !== t.length || h.some((g, c) => t[c] !== g)))
307
+ return s;
308
+ t = h;
309
+ let p;
310
+ if (e.key && ((i = e.debug) != null && i.call(e)) && (p = Date.now()), s = l(...h), e.key && ((a = e.debug) != null && a.call(e))) {
311
+ const g = Math.round((Date.now() - u) * 100) / 100, c = Math.round((Date.now() - p) * 100) / 100, f = c / 16, v = (S, E) => {
312
+ for (S = String(S); S.length < E; )
313
+ S = " " + S;
314
+ return S;
315
+ };
316
+ console.info(
317
+ `%c⏱ ${v(c, 5)} /${v(g, 5)} ms`,
318
+ `
319
+ font-size: .6rem;
320
+ font-weight: bold;
321
+ color: hsl(${Math.max(
322
+ 0,
323
+ Math.min(120 - 120 * f, 120)
324
+ )}deg 100% 31%);`,
325
+ e == null ? void 0 : e.key
326
+ );
327
+ }
328
+ return (d = e == null ? void 0 : e.onChange) == null || d.call(e, s), s;
329
+ }
330
+ return o.updateDeps = (n) => {
331
+ t = n;
332
+ }, o;
333
+ }
334
+ function P(r, l) {
335
+ if (r === void 0)
336
+ throw new Error("Unexpected undefined");
337
+ return r;
338
+ }
339
+ const ot = (r, l) => Math.abs(r - l) < 1, it = (r, l, e) => {
340
+ let t;
341
+ return function(...s) {
342
+ r.clearTimeout(t), t = r.setTimeout(() => l.apply(this, s), e);
343
+ };
344
+ }, lt = (r) => r, at = (r) => {
345
+ const l = Math.max(r.startIndex - r.overscan, 0), e = Math.min(r.endIndex + r.overscan, r.count - 1), t = [];
346
+ for (let s = l; s <= e; s++)
347
+ t.push(s);
348
+ return t;
349
+ }, ct = (r, l) => {
350
+ const e = r.scrollElement;
351
+ if (!e)
352
+ return;
353
+ const t = r.targetWindow;
354
+ if (!t)
355
+ return;
356
+ const s = (n) => {
357
+ const { width: i, height: a } = n;
358
+ l({ width: Math.round(i), height: Math.round(a) });
359
+ };
360
+ if (s(e.getBoundingClientRect()), !t.ResizeObserver)
361
+ return () => {
362
+ };
363
+ const o = new t.ResizeObserver((n) => {
364
+ const i = () => {
365
+ const a = n[0];
366
+ if (a != null && a.borderBoxSize) {
367
+ const d = a.borderBoxSize[0];
368
+ if (d) {
369
+ s({ width: d.inlineSize, height: d.blockSize });
370
+ return;
371
+ }
372
+ }
373
+ s(e.getBoundingClientRect());
374
+ };
375
+ r.options.useAnimationFrameWithResizeObserver ? requestAnimationFrame(i) : i();
376
+ });
377
+ return o.observe(e, { box: "border-box" }), () => {
378
+ o.unobserve(e);
379
+ };
380
+ }, se = {
381
+ passive: !0
382
+ }, ne = typeof window > "u" ? !0 : "onscrollend" in window, ut = (r, l) => {
383
+ const e = r.scrollElement;
384
+ if (!e)
385
+ return;
386
+ const t = r.targetWindow;
387
+ if (!t)
388
+ return;
389
+ let s = 0;
390
+ const o = r.options.useScrollendEvent && ne ? () => {
391
+ } : it(
392
+ t,
393
+ () => {
394
+ l(s, !1);
395
+ },
396
+ r.options.isScrollingResetDelay
397
+ ), n = (u) => () => {
398
+ const { horizontal: h, isRtl: m } = r.options;
399
+ s = h ? e.scrollLeft * (m && -1 || 1) : e.scrollTop, o(), l(s, u);
400
+ }, i = n(!0), a = n(!1);
401
+ a(), e.addEventListener("scroll", i, se);
402
+ const d = r.options.useScrollendEvent && ne;
403
+ return d && e.addEventListener("scrollend", a, se), () => {
404
+ e.removeEventListener("scroll", i), d && e.removeEventListener("scrollend", a);
405
+ };
406
+ }, dt = (r, l, e) => {
407
+ if (l != null && l.borderBoxSize) {
408
+ const t = l.borderBoxSize[0];
409
+ if (t)
410
+ return Math.round(
411
+ t[e.options.horizontal ? "inlineSize" : "blockSize"]
412
+ );
413
+ }
414
+ return Math.round(
415
+ r.getBoundingClientRect()[e.options.horizontal ? "width" : "height"]
416
+ );
417
+ }, ht = (r, {
418
+ adjustments: l = 0,
419
+ behavior: e
420
+ }, t) => {
421
+ var s, o;
422
+ const n = r + l;
423
+ (o = (s = t.scrollElement) == null ? void 0 : s.scrollTo) == null || o.call(s, {
424
+ [t.options.horizontal ? "left" : "top"]: n,
425
+ behavior: e
426
+ });
427
+ };
428
+ class ft {
429
+ constructor(l) {
430
+ this.unsubs = [], this.scrollElement = null, this.targetWindow = null, this.isScrolling = !1, this.scrollToIndexTimeoutId = null, this.measurementsCache = [], this.itemSizeCache = /* @__PURE__ */ new Map(), this.pendingMeasuredCacheIndexes = [], this.scrollRect = null, this.scrollOffset = null, this.scrollDirection = null, this.scrollAdjustments = 0, this.elementsCache = /* @__PURE__ */ new Map(), this.observer = /* @__PURE__ */ (() => {
431
+ let e = null;
432
+ const t = () => e || (!this.targetWindow || !this.targetWindow.ResizeObserver ? null : e = new this.targetWindow.ResizeObserver((s) => {
433
+ s.forEach((o) => {
434
+ const n = () => {
435
+ this._measureElement(o.target, o);
436
+ };
437
+ this.options.useAnimationFrameWithResizeObserver ? requestAnimationFrame(n) : n();
438
+ });
439
+ }));
440
+ return {
441
+ disconnect: () => {
442
+ var s;
443
+ (s = t()) == null || s.disconnect(), e = null;
444
+ },
445
+ observe: (s) => {
446
+ var o;
447
+ return (o = t()) == null ? void 0 : o.observe(s, { box: "border-box" });
448
+ },
449
+ unobserve: (s) => {
450
+ var o;
451
+ return (o = t()) == null ? void 0 : o.unobserve(s);
452
+ }
453
+ };
454
+ })(), this.range = null, this.setOptions = (e) => {
455
+ Object.entries(e).forEach(([t, s]) => {
456
+ typeof s > "u" && delete e[t];
457
+ }), this.options = {
458
+ debug: !1,
459
+ initialOffset: 0,
460
+ overscan: 1,
461
+ paddingStart: 0,
462
+ paddingEnd: 0,
463
+ scrollPaddingStart: 0,
464
+ scrollPaddingEnd: 0,
465
+ horizontal: !1,
466
+ getItemKey: lt,
467
+ rangeExtractor: at,
468
+ onChange: () => {
469
+ },
470
+ measureElement: dt,
471
+ initialRect: { width: 0, height: 0 },
472
+ scrollMargin: 0,
473
+ gap: 0,
474
+ indexAttribute: "data-index",
475
+ initialMeasurementsCache: [],
476
+ lanes: 1,
477
+ isScrollingResetDelay: 150,
478
+ enabled: !0,
479
+ isRtl: !1,
480
+ useScrollendEvent: !1,
481
+ useAnimationFrameWithResizeObserver: !1,
482
+ ...e
483
+ };
484
+ }, this.notify = (e) => {
485
+ var t, s;
486
+ (s = (t = this.options).onChange) == null || s.call(t, this, e);
487
+ }, this.maybeNotify = z(
488
+ () => (this.calculateRange(), [
489
+ this.isScrolling,
490
+ this.range ? this.range.startIndex : null,
491
+ this.range ? this.range.endIndex : null
492
+ ]),
493
+ (e) => {
494
+ this.notify(e);
495
+ },
496
+ {
497
+ key: process.env.NODE_ENV !== "production" && "maybeNotify",
498
+ debug: () => this.options.debug,
499
+ initialDeps: [
500
+ this.isScrolling,
501
+ this.range ? this.range.startIndex : null,
502
+ this.range ? this.range.endIndex : null
503
+ ]
504
+ }
505
+ ), this.cleanup = () => {
506
+ this.unsubs.filter(Boolean).forEach((e) => e()), this.unsubs = [], this.observer.disconnect(), this.scrollElement = null, this.targetWindow = null;
507
+ }, this._didMount = () => () => {
508
+ this.cleanup();
509
+ }, this._willUpdate = () => {
510
+ var e;
511
+ const t = this.options.enabled ? this.options.getScrollElement() : null;
512
+ if (this.scrollElement !== t) {
513
+ if (this.cleanup(), !t) {
514
+ this.maybeNotify();
515
+ return;
516
+ }
517
+ this.scrollElement = t, this.scrollElement && "ownerDocument" in this.scrollElement ? this.targetWindow = this.scrollElement.ownerDocument.defaultView : this.targetWindow = ((e = this.scrollElement) == null ? void 0 : e.window) ?? null, this.elementsCache.forEach((s) => {
518
+ this.observer.observe(s);
519
+ }), this._scrollToOffset(this.getScrollOffset(), {
520
+ adjustments: void 0,
521
+ behavior: void 0
522
+ }), this.unsubs.push(
523
+ this.options.observeElementRect(this, (s) => {
524
+ this.scrollRect = s, this.maybeNotify();
525
+ })
526
+ ), this.unsubs.push(
527
+ this.options.observeElementOffset(this, (s, o) => {
528
+ this.scrollAdjustments = 0, this.scrollDirection = o ? this.getScrollOffset() < s ? "forward" : "backward" : null, this.scrollOffset = s, this.isScrolling = o, this.maybeNotify();
529
+ })
530
+ );
531
+ }
532
+ }, this.getSize = () => this.options.enabled ? (this.scrollRect = this.scrollRect ?? this.options.initialRect, this.scrollRect[this.options.horizontal ? "width" : "height"]) : (this.scrollRect = null, 0), this.getScrollOffset = () => this.options.enabled ? (this.scrollOffset = this.scrollOffset ?? (typeof this.options.initialOffset == "function" ? this.options.initialOffset() : this.options.initialOffset), this.scrollOffset) : (this.scrollOffset = null, 0), this.getFurthestMeasurement = (e, t) => {
533
+ const s = /* @__PURE__ */ new Map(), o = /* @__PURE__ */ new Map();
534
+ for (let n = t - 1; n >= 0; n--) {
535
+ const i = e[n];
536
+ if (s.has(i.lane))
537
+ continue;
538
+ const a = o.get(
539
+ i.lane
540
+ );
541
+ if (a == null || i.end > a.end ? o.set(i.lane, i) : i.end < a.end && s.set(i.lane, !0), s.size === this.options.lanes)
542
+ break;
543
+ }
544
+ return o.size === this.options.lanes ? Array.from(o.values()).sort((n, i) => n.end === i.end ? n.index - i.index : n.end - i.end)[0] : void 0;
545
+ }, this.getMeasurementOptions = z(
546
+ () => [
547
+ this.options.count,
548
+ this.options.paddingStart,
549
+ this.options.scrollMargin,
550
+ this.options.getItemKey,
551
+ this.options.enabled
552
+ ],
553
+ (e, t, s, o, n) => (this.pendingMeasuredCacheIndexes = [], {
554
+ count: e,
555
+ paddingStart: t,
556
+ scrollMargin: s,
557
+ getItemKey: o,
558
+ enabled: n
559
+ }),
560
+ {
561
+ key: !1
562
+ }
563
+ ), this.getMeasurements = z(
564
+ () => [this.getMeasurementOptions(), this.itemSizeCache],
565
+ ({ count: e, paddingStart: t, scrollMargin: s, getItemKey: o, enabled: n }, i) => {
566
+ if (!n)
567
+ return this.measurementsCache = [], this.itemSizeCache.clear(), [];
568
+ this.measurementsCache.length === 0 && (this.measurementsCache = this.options.initialMeasurementsCache, this.measurementsCache.forEach((u) => {
569
+ this.itemSizeCache.set(u.key, u.size);
570
+ }));
571
+ const a = this.pendingMeasuredCacheIndexes.length > 0 ? Math.min(...this.pendingMeasuredCacheIndexes) : 0;
572
+ this.pendingMeasuredCacheIndexes = [];
573
+ const d = this.measurementsCache.slice(0, a);
574
+ for (let u = a; u < e; u++) {
575
+ const h = o(u), m = this.options.lanes === 1 ? d[u - 1] : this.getFurthestMeasurement(d, u), p = m ? m.end + this.options.gap : t + s, g = i.get(h), c = typeof g == "number" ? g : this.options.estimateSize(u), f = p + c, v = m ? m.lane : u % this.options.lanes;
576
+ d[u] = {
577
+ index: u,
578
+ start: p,
579
+ size: c,
580
+ end: f,
581
+ key: h,
582
+ lane: v
583
+ };
584
+ }
585
+ return this.measurementsCache = d, d;
586
+ },
587
+ {
588
+ key: process.env.NODE_ENV !== "production" && "getMeasurements",
589
+ debug: () => this.options.debug
590
+ }
591
+ ), this.calculateRange = z(
592
+ () => [
593
+ this.getMeasurements(),
594
+ this.getSize(),
595
+ this.getScrollOffset(),
596
+ this.options.lanes
597
+ ],
598
+ (e, t, s, o) => this.range = e.length > 0 && t > 0 ? mt({
599
+ measurements: e,
600
+ outerSize: t,
601
+ scrollOffset: s,
602
+ lanes: o
603
+ }) : null,
604
+ {
605
+ key: process.env.NODE_ENV !== "production" && "calculateRange",
606
+ debug: () => this.options.debug
607
+ }
608
+ ), this.getVirtualIndexes = z(
609
+ () => {
610
+ let e = null, t = null;
611
+ const s = this.calculateRange();
612
+ return s && (e = s.startIndex, t = s.endIndex), this.maybeNotify.updateDeps([this.isScrolling, e, t]), [
613
+ this.options.rangeExtractor,
614
+ this.options.overscan,
615
+ this.options.count,
616
+ e,
617
+ t
618
+ ];
619
+ },
620
+ (e, t, s, o, n) => o === null || n === null ? [] : e({
621
+ startIndex: o,
622
+ endIndex: n,
623
+ overscan: t,
624
+ count: s
625
+ }),
626
+ {
627
+ key: process.env.NODE_ENV !== "production" && "getVirtualIndexes",
628
+ debug: () => this.options.debug
629
+ }
630
+ ), this.indexFromElement = (e) => {
631
+ const t = this.options.indexAttribute, s = e.getAttribute(t);
632
+ return s ? parseInt(s, 10) : (console.warn(
633
+ `Missing attribute name '${t}={index}' on measured element.`
634
+ ), -1);
635
+ }, this._measureElement = (e, t) => {
636
+ const s = this.indexFromElement(e), o = this.measurementsCache[s];
637
+ if (!o)
638
+ return;
639
+ const n = o.key, i = this.elementsCache.get(n);
640
+ i !== e && (i && this.observer.unobserve(i), this.observer.observe(e), this.elementsCache.set(n, e)), e.isConnected && this.resizeItem(s, this.options.measureElement(e, t, this));
641
+ }, this.resizeItem = (e, t) => {
642
+ const s = this.measurementsCache[e];
643
+ if (!s)
644
+ return;
645
+ const o = this.itemSizeCache.get(s.key) ?? s.size, n = t - o;
646
+ n !== 0 && ((this.shouldAdjustScrollPositionOnItemSizeChange !== void 0 ? this.shouldAdjustScrollPositionOnItemSizeChange(s, n, this) : s.start < this.getScrollOffset() + this.scrollAdjustments) && (process.env.NODE_ENV !== "production" && this.options.debug && console.info("correction", n), this._scrollToOffset(this.getScrollOffset(), {
647
+ adjustments: this.scrollAdjustments += n,
648
+ behavior: void 0
649
+ })), this.pendingMeasuredCacheIndexes.push(s.index), this.itemSizeCache = new Map(this.itemSizeCache.set(s.key, t)), this.notify(!1));
650
+ }, this.measureElement = (e) => {
651
+ if (!e) {
652
+ this.elementsCache.forEach((t, s) => {
653
+ t.isConnected || (this.observer.unobserve(t), this.elementsCache.delete(s));
654
+ });
655
+ return;
656
+ }
657
+ this._measureElement(e, void 0);
658
+ }, this.getVirtualItems = z(
659
+ () => [this.getVirtualIndexes(), this.getMeasurements()],
660
+ (e, t) => {
661
+ const s = [];
662
+ for (let o = 0, n = e.length; o < n; o++) {
663
+ const i = e[o], a = t[i];
664
+ s.push(a);
665
+ }
666
+ return s;
667
+ },
668
+ {
669
+ key: process.env.NODE_ENV !== "production" && "getVirtualItems",
670
+ debug: () => this.options.debug
671
+ }
672
+ ), this.getVirtualItemForOffset = (e) => {
673
+ const t = this.getMeasurements();
674
+ if (t.length !== 0)
675
+ return P(
676
+ t[ge(
677
+ 0,
678
+ t.length - 1,
679
+ (s) => P(t[s]).start,
680
+ e
681
+ )]
682
+ );
683
+ }, this.getOffsetForAlignment = (e, t, s = 0) => {
684
+ const o = this.getSize(), n = this.getScrollOffset();
685
+ t === "auto" && (t = e >= n + o ? "end" : "start"), t === "center" ? e += (s - o) / 2 : t === "end" && (e -= o);
686
+ const i = this.options.horizontal ? "scrollWidth" : "scrollHeight", d = (this.scrollElement ? "document" in this.scrollElement ? this.scrollElement.document.documentElement[i] : this.scrollElement[i] : 0) - o;
687
+ return Math.max(Math.min(d, e), 0);
688
+ }, this.getOffsetForIndex = (e, t = "auto") => {
689
+ e = Math.max(0, Math.min(e, this.options.count - 1));
690
+ const s = this.measurementsCache[e];
691
+ if (!s)
692
+ return;
693
+ const o = this.getSize(), n = this.getScrollOffset();
694
+ if (t === "auto")
695
+ if (s.end >= n + o - this.options.scrollPaddingEnd)
696
+ t = "end";
697
+ else if (s.start <= n + this.options.scrollPaddingStart)
698
+ t = "start";
699
+ else
700
+ return [n, t];
701
+ const i = t === "end" ? s.end + this.options.scrollPaddingEnd : s.start - this.options.scrollPaddingStart;
702
+ return [
703
+ this.getOffsetForAlignment(i, t, s.size),
704
+ t
705
+ ];
706
+ }, this.isDynamicMode = () => this.elementsCache.size > 0, this.cancelScrollToIndex = () => {
707
+ this.scrollToIndexTimeoutId !== null && this.targetWindow && (this.targetWindow.clearTimeout(this.scrollToIndexTimeoutId), this.scrollToIndexTimeoutId = null);
708
+ }, this.scrollToOffset = (e, { align: t = "start", behavior: s } = {}) => {
709
+ this.cancelScrollToIndex(), s === "smooth" && this.isDynamicMode() && console.warn(
710
+ "The `smooth` scroll behavior is not fully supported with dynamic size."
711
+ ), this._scrollToOffset(this.getOffsetForAlignment(e, t), {
712
+ adjustments: void 0,
713
+ behavior: s
714
+ });
715
+ }, this.scrollToIndex = (e, { align: t = "auto", behavior: s } = {}) => {
716
+ e = Math.max(0, Math.min(e, this.options.count - 1)), this.cancelScrollToIndex(), s === "smooth" && this.isDynamicMode() && console.warn(
717
+ "The `smooth` scroll behavior is not fully supported with dynamic size."
718
+ );
719
+ const o = this.getOffsetForIndex(e, t);
720
+ if (!o) return;
721
+ const [n, i] = o;
722
+ this._scrollToOffset(n, { adjustments: void 0, behavior: s }), s !== "smooth" && this.isDynamicMode() && this.targetWindow && (this.scrollToIndexTimeoutId = this.targetWindow.setTimeout(() => {
723
+ if (this.scrollToIndexTimeoutId = null, this.elementsCache.has(
724
+ this.options.getItemKey(e)
725
+ )) {
726
+ const [d] = P(
727
+ this.getOffsetForIndex(e, i)
728
+ );
729
+ ot(d, this.getScrollOffset()) || this.scrollToIndex(e, { align: i, behavior: s });
730
+ } else
731
+ this.scrollToIndex(e, { align: i, behavior: s });
732
+ }));
733
+ }, this.scrollBy = (e, { behavior: t } = {}) => {
734
+ this.cancelScrollToIndex(), t === "smooth" && this.isDynamicMode() && console.warn(
735
+ "The `smooth` scroll behavior is not fully supported with dynamic size."
736
+ ), this._scrollToOffset(this.getScrollOffset() + e, {
737
+ adjustments: void 0,
738
+ behavior: t
739
+ });
740
+ }, this.getTotalSize = () => {
741
+ var e;
742
+ const t = this.getMeasurements();
743
+ let s;
744
+ if (t.length === 0)
745
+ s = this.options.paddingStart;
746
+ else if (this.options.lanes === 1)
747
+ s = ((e = t[t.length - 1]) == null ? void 0 : e.end) ?? 0;
748
+ else {
749
+ const o = Array(this.options.lanes).fill(null);
750
+ let n = t.length - 1;
751
+ for (; n >= 0 && o.some((i) => i === null); ) {
752
+ const i = t[n];
753
+ o[i.lane] === null && (o[i.lane] = i.end), n--;
754
+ }
755
+ s = Math.max(...o.filter((i) => i !== null));
756
+ }
757
+ return Math.max(
758
+ s - this.options.scrollMargin + this.options.paddingEnd,
759
+ 0
760
+ );
761
+ }, this._scrollToOffset = (e, {
762
+ adjustments: t,
763
+ behavior: s
764
+ }) => {
765
+ this.options.scrollToFn(e, { behavior: s, adjustments: t }, this);
766
+ }, this.measure = () => {
767
+ this.itemSizeCache = /* @__PURE__ */ new Map(), this.notify(!1);
768
+ }, this.setOptions(l);
769
+ }
770
+ }
771
+ const ge = (r, l, e, t) => {
772
+ for (; r <= l; ) {
773
+ const s = (r + l) / 2 | 0, o = e(s);
774
+ if (o < t)
775
+ r = s + 1;
776
+ else if (o > t)
777
+ l = s - 1;
778
+ else
779
+ return s;
780
+ }
781
+ return r > 0 ? r - 1 : 0;
782
+ };
783
+ function mt({
784
+ measurements: r,
785
+ outerSize: l,
786
+ scrollOffset: e,
787
+ lanes: t
788
+ }) {
789
+ const s = r.length - 1, o = (a) => r[a].start;
790
+ if (r.length <= t)
791
+ return {
792
+ startIndex: 0,
793
+ endIndex: s
794
+ };
795
+ let n = ge(
796
+ 0,
797
+ s,
798
+ o,
799
+ e
800
+ ), i = n;
801
+ if (t === 1)
802
+ for (; i < s && r[i].end < e + l; )
803
+ i++;
804
+ else if (t > 1) {
805
+ const a = Array(t).fill(0);
806
+ for (; i < s && a.some((u) => u < e + l); ) {
807
+ const u = r[i];
808
+ a[u.lane] = u.end, i++;
809
+ }
810
+ const d = Array(t).fill(e + l);
811
+ for (; n >= 0 && d.some((u) => u >= e); ) {
812
+ const u = r[n];
813
+ d[u.lane] = u.start, n--;
814
+ }
815
+ n = Math.max(0, n - n % t), i = Math.min(s, i + (t - 1 - i % t));
816
+ }
817
+ return { startIndex: n, endIndex: i };
818
+ }
819
+ const re = typeof document < "u" ? L.useLayoutEffect : L.useEffect;
820
+ function gt(r) {
821
+ const l = L.useReducer(() => ({}), {})[1], e = {
822
+ ...r,
823
+ onChange: (s, o) => {
824
+ var n;
825
+ o ? Be(l) : l(), (n = r.onChange) == null || n.call(r, s, o);
826
+ }
827
+ }, [t] = L.useState(
828
+ () => new ft(e)
829
+ );
830
+ return t.setOptions(e), re(() => t._didMount(), []), re(() => t._willUpdate()), t;
831
+ }
832
+ function pt(r) {
833
+ return gt({
834
+ observeElementRect: ct,
835
+ observeElementOffset: ut,
836
+ scrollToFn: ht,
837
+ ...r
838
+ });
839
+ }
840
+ const vt = (r) => r == null ? !0 : Array.isArray(r) || typeof r == "string" ? r.length === 0 : !1, xt = [], Et = [], St = ({
841
+ data: r = xt,
842
+ value: l = Et,
843
+ allowMultiple: e,
844
+ allowNone: t,
845
+ replaceOnSingle: s = !1,
846
+ autoSelectOnNone: o = !1,
847
+ onChange: n
848
+ }) => {
849
+ const i = j(null), a = J({ triggers: [["Shift"]], loose: !0 }), d = J({ triggers: [["Control"]], loose: !0 }), u = A(l), h = A(r), m = T(
850
+ (c, f) => {
851
+ if (u.current = c, c.length === 0 && t !== !1)
852
+ return n(e !== !1 ? [] : null, f);
853
+ if (e !== !1) return n(c, f);
854
+ if (c.length > 0) return n(c[0], f);
855
+ },
856
+ [n, t, e]
857
+ );
858
+ R(() => {
859
+ let c = h.current;
860
+ if (Array.isArray(c) || (c = c()), vt(l) && t === !1 && c.length > 0 && o) {
861
+ const f = c[0];
862
+ i.current = f.key, m([f.key], {
863
+ entries: [f],
864
+ clicked: f.key,
865
+ clickedIndex: 0
866
+ });
867
+ }
868
+ }, [m, h, l, t]);
869
+ const p = T(
870
+ (c) => {
871
+ const f = i.current;
872
+ let v = h.current;
873
+ Array.isArray(v) || (v = v());
874
+ let S = [];
875
+ const E = $e(u.current).filter((C) => C != null);
876
+ if (e === !1) S = E.includes(c) ? [] : [c];
877
+ else if (d.current.held && s)
878
+ E.includes(c) ? S = E.filter((C) => C !== c) : S = [...E, c];
879
+ else if (a.current.held && f !== null) {
880
+ const [C, N] = [
881
+ v.findIndex((I) => I.key === c),
882
+ v.findIndex((I) => I.key === f)
883
+ ].sort((I, D) => I - D), b = v.slice(C, N + 1).map(({ key: I }) => I);
884
+ b.slice(1, b.length - 1).every((I) => E.includes(I)) && E.includes(c) ? S = E.filter((I) => !b.includes(I)) : S = [...E, ...b], i.current = null;
885
+ } else
886
+ i.current = c, s ? S = E.includes(c) && E.length === 1 ? [] : [c] : E.includes(c) ? S = E.filter((C) => C !== c) : S = [...E, c];
887
+ const O = ke.unique(S);
888
+ if (t === !1 && O.length === 0)
889
+ return m(E, {
890
+ entries: v.filter(({ key: C }) => E.includes(C)),
891
+ clicked: c,
892
+ clickedIndex: v.findIndex(({ key: C }) => C === c)
893
+ });
894
+ O.length === 0 && (i.current = null), m(O, {
895
+ entries: v.filter(({ key: C }) => S.includes(C)),
896
+ clicked: c,
897
+ clickedIndex: v.findIndex(({ key: C }) => C === c)
898
+ });
899
+ },
900
+ [u, h, m, e, t]
901
+ ), g = T(
902
+ () => m([], { entries: [], clicked: null, clickedIndex: 0 }),
903
+ [m]
904
+ );
905
+ return { onSelect: p, clear: g };
906
+ }, pe = M({ selected: [] }), ve = M({
907
+ onSelect: () => {
908
+ },
909
+ clear: () => {
910
+ },
911
+ getSelected: () => []
912
+ }), xe = () => ae(pe), yt = () => xe().selected, Y = () => ae(ve), Ee = je(
913
+ ({
914
+ value: r,
915
+ children: l,
916
+ ...e
917
+ }) => {
918
+ const t = fe(), { onSelect: s, clear: o } = St({
919
+ ...e,
920
+ value: r,
921
+ data: t
922
+ }), n = A(r), i = w(
923
+ () => ({ selected: ee(r) }),
924
+ [r]
925
+ ), a = w(
926
+ () => ({ onSelect: s, clear: o, getSelected: () => ee(n.current) }),
927
+ [s, o]
928
+ );
929
+ return /* @__PURE__ */ x.jsx(ve, { value: a, children: /* @__PURE__ */ x.jsx(pe, { value: i, children: l }) });
930
+ }
931
+ );
932
+ Ee.displayName = "List.Selector";
933
+ const ns = Ee, Se = ["ArrowUp"], ye = ["ArrowDown"], Ce = ["Enter"], Ct = [Se, ye, Ce], Ie = M({
934
+ hover: -1,
935
+ setHover: () => {
936
+ }
937
+ }), be = () => _(Ie), rs = ({
938
+ children: r,
939
+ initialHover: l = -1,
940
+ disabled: e = !1,
941
+ onEnter: t
942
+ }) => {
943
+ const s = fe(), { transformedData: o } = F(), { onSelect: n } = Y(), [i, a, d] = $(l), u = j(l);
944
+ R(() => {
945
+ e && (u.current = i), a(e ? -1 : u.current);
946
+ }, [e]), R(() => {
947
+ i >= o.length && a(0);
948
+ }, [o.length]);
949
+ const h = j(null), m = T(
950
+ ({ triggers: g, stage: c }) => {
951
+ if (h.current != null && (clearInterval(h.current), h.current = null), c !== "start" || e) return;
952
+ const f = s();
953
+ if (W(g, [Ce])) {
954
+ if (d.current === -1) return;
955
+ t == null || t(f[d.current].key), n == null || n(f[d.current].key);
956
+ return;
957
+ }
958
+ const v = () => {
959
+ const S = s();
960
+ W(g, [Se], { loose: !0 }) ? a((E) => E <= 0 ? S.length - 1 : E - 1) : W(g, [ye], { loose: !0 }) && a((E) => E >= S.length - 1 ? 0 : E + 1);
961
+ };
962
+ v(), h.current = setTimeout(() => {
963
+ h.current = setInterval(v, 100);
964
+ }, 200);
965
+ },
966
+ [n, e]
967
+ );
968
+ Pe({ triggers: Ct, callback: m, loose: !0 });
969
+ const p = w(
970
+ () => ({ hover: i, setHover: a }),
971
+ [i, a]
972
+ );
973
+ return /* @__PURE__ */ x.jsx(Ie, { value: p, children: r });
974
+ }, Te = M({
975
+ hasMore: !1,
976
+ onFetchMore: () => {
977
+ }
978
+ }), we = M({
979
+ setHasMore: () => {
980
+ },
981
+ setOnFetchMore: () => {
982
+ }
983
+ }), It = () => _(Te), os = () => _(we), bt = ({ children: r }) => {
984
+ const [l, e] = k(!1), [t, s] = ze(
985
+ () => {
986
+ }
987
+ ), o = T(() => {
988
+ var a;
989
+ (a = t.current) == null || a.call(t);
990
+ }, [t]), n = w(
991
+ () => ({ hasMore: l, onFetchMore: o }),
992
+ [l, o]
993
+ ), i = w(
994
+ () => ({
995
+ setHasMore: e,
996
+ setOnFetchMore: (a) => {
997
+ s(() => a);
998
+ }
999
+ }),
1000
+ [e, s]
1001
+ );
1002
+ return /* @__PURE__ */ x.jsx(Te, { value: n, children: /* @__PURE__ */ x.jsx(we, { value: i, children: r }) });
1003
+ }, Tt = (r, l, e) => {
1004
+ var n;
1005
+ const t = r > l ? 1 : -1;
1006
+ let s;
1007
+ const o = r + t * 2;
1008
+ G.contains({ lower: 0, upper: e.children.length }, o) ? s = r + t * 2 : s = r, (n = e.children[s]) == null || n.scrollIntoView({
1009
+ block: "nearest",
1010
+ inline: "nearest",
1011
+ behavior: "smooth"
1012
+ });
1013
+ }, wt = ({
1014
+ itemHeight: r,
1015
+ children: l,
1016
+ overscan: e = 0,
1017
+ className: t,
1018
+ ...s
1019
+ }) => {
1020
+ var N;
1021
+ const { hasMore: o, onFetchMore: n } = It(), { hover: i, setHover: a } = be(), {
1022
+ transformedData: d,
1023
+ emptyContent: u,
1024
+ transformed: h,
1025
+ sourceData: m
1026
+ } = F(), p = yt(), { onSelect: g } = Y(), c = j(null), f = pt({
1027
+ count: d.length,
1028
+ getScrollElement: () => c.current,
1029
+ estimateSize: () => r,
1030
+ overscan: e
1031
+ }), v = ie(d);
1032
+ ce(() => {
1033
+ v == null || v.length === 0 || d.length > 0 && d[0].key !== v[0].key && (f == null || f.scrollToIndex(0), a(0));
1034
+ }, [d]), R(() => {
1035
+ if (c.current == null) return;
1036
+ const b = f.calculateRange();
1037
+ if (b == null) return;
1038
+ const I = G.construct(b.startIndex + 2, b.endIndex - 2);
1039
+ G.contains(I, i) || f.scrollToIndex(i);
1040
+ }, [i, r]);
1041
+ const S = f.getVirtualItems(), E = (N = S.at(-1)) == null ? void 0 : N.index, O = d.length;
1042
+ if (R(() => {
1043
+ E === O - 1 && o && (n == null || n());
1044
+ }, [E, O, o]), r <= 0) throw new Error("itemHeight must be greater than 0");
1045
+ const C = d.length === 0;
1046
+ return /* @__PURE__ */ x.jsx(
1047
+ "div",
1048
+ {
1049
+ ref: c,
1050
+ className: y(
1051
+ t,
1052
+ y.BE("list", "container"),
1053
+ C && y.BM("list", "empty")
1054
+ ),
1055
+ ...s,
1056
+ children: C ? u : /* @__PURE__ */ x.jsx(
1057
+ "div",
1058
+ {
1059
+ className: y.BE("list", "virtualizer"),
1060
+ style: { height: f.getTotalSize() },
1061
+ children: S.map(({ index: b, start: I }) => {
1062
+ const D = d[b];
1063
+ let Z = b;
1064
+ return h && (Z = m.findIndex((De) => De.key === D.key)), l({
1065
+ key: D.key,
1066
+ sourceIndex: Z,
1067
+ index: b,
1068
+ onSelect: g,
1069
+ entry: D,
1070
+ selected: p.includes(D.key),
1071
+ hovered: b === i,
1072
+ translate: I
1073
+ });
1074
+ })
1075
+ }
1076
+ )
1077
+ }
1078
+ );
1079
+ }, Mt = ({
1080
+ itemHeight: r = 50,
1081
+ className: l,
1082
+ children: e,
1083
+ ...t
1084
+ }) => {
1085
+ const {
1086
+ transformedData: s,
1087
+ transformed: o,
1088
+ emptyContent: n,
1089
+ sourceData: i
1090
+ } = F(), { hover: a } = be(), { selected: d } = xe(), { onSelect: u } = Y(), h = j(null), m = ie(a) ?? 0;
1091
+ ce(() => {
1092
+ h.current != null && Tt(a, m, h.current);
1093
+ }, [a, r]);
1094
+ const p = T(
1095
+ (g, c) => {
1096
+ let f = i.findIndex((v) => v.key === g.key);
1097
+ return o && (f = i.findIndex((v) => v.key === g.key)), e({
1098
+ key: g.key,
1099
+ index: c,
1100
+ sourceIndex: f,
1101
+ onSelect: u,
1102
+ entry: g,
1103
+ selected: d.includes(g.key),
1104
+ hovered: c === a
1105
+ });
1106
+ },
1107
+ [e, o, d, a, i]
1108
+ );
1109
+ return /* @__PURE__ */ x.jsx(
1110
+ q,
1111
+ {
1112
+ className: y(l, y.BE("list", "container")),
1113
+ ref: h,
1114
+ size: 0,
1115
+ ...t,
1116
+ children: s.length === 0 ? n : /* @__PURE__ */ x.jsx(x.Fragment, { children: s.map((g, c) => p(g, c)) })
1117
+ }
1118
+ );
1119
+ };
1120
+ Mt.Virtual = wt;
1121
+ const is = ({
1122
+ children: r,
1123
+ data: l,
1124
+ emptyContent: e,
1125
+ omit: t
1126
+ }) => {
1127
+ const s = Ue(
1128
+ () => t != null ? l == null ? void 0 : l.filter((n) => !t.includes(n.key)) : l,
1129
+ ([n, i], [a, d]) => {
1130
+ let u;
1131
+ return n != null && a != null ? u = U.unorderedPrimitiveArrays(n, a) === U.EQUAL : u = n == a, i === d && u;
1132
+ },
1133
+ [t, l]
1134
+ ), o = typeof e == "string" ? /* @__PURE__ */ x.jsx(oe, { level: "p", children: e }) : e;
1135
+ return /* @__PURE__ */ x.jsx(bt, { children: /* @__PURE__ */ x.jsx(Ze, { data: s, emptyContent: o, children: r }) });
1136
+ }, Me = M([]), Oe = M(() => {
1137
+ }), Ot = 0.9, ls = ({ children: r, maxHistory: l = 500 }) => {
1138
+ const [{ path: e }, { statuses: t }, s] = Ve({
1139
+ type: Ge.TYPE,
1140
+ schema: He,
1141
+ initialState: { statuses: [] }
1142
+ });
1143
+ if (t.length > l) {
1144
+ const n = Math.floor(l * Ot);
1145
+ s((i) => ({ ...i, statuses: t.slice(0, n) }));
1146
+ }
1147
+ const o = T(
1148
+ (n) => {
1149
+ const i = { time: H.now(), key: _e.create(), ...n };
1150
+ s((a) => ({ ...a, statuses: [i, ...a.statuses] }));
1151
+ },
1152
+ [s]
1153
+ );
1154
+ return /* @__PURE__ */ x.jsx(Me, { value: t, children: /* @__PURE__ */ x.jsx(Oe, { value: o, children: /* @__PURE__ */ x.jsx(Le, { path: e, children: r }) }) });
1155
+ }, Rt = () => _(Oe), as = () => {
1156
+ const r = Rt();
1157
+ return w(() => qe(r), [r]);
1158
+ }, Dt = le.seconds(7), zt = le.seconds(1), cs = ({
1159
+ expiration: r = Dt,
1160
+ poll: l = zt
1161
+ } = {}) => {
1162
+ const e = _(Me), [t, s] = k(/* @__PURE__ */ new Set()), [o, n] = k(() => H.now());
1163
+ R(() => {
1164
+ const u = setInterval(() => n(H.now()), l.milliseconds);
1165
+ return () => clearInterval(u);
1166
+ }, [l.milliseconds]);
1167
+ const i = w(() => {
1168
+ const u = o.sub(r), m = e.filter(
1169
+ ({ key: p, time: g }) => g.afterEq(u) && !t.has(p)
1170
+ ).reduce((p, g) => {
1171
+ const c = `${g.variant}:${g.message}`;
1172
+ if (!p.has(c))
1173
+ return p.set(c, { ...g, count: 1 }), p;
1174
+ const f = p.get(c);
1175
+ return p.set(c, {
1176
+ ...f,
1177
+ count: f.count + 1,
1178
+ time: g.time.after(f.time) ? g.time : f.time
1179
+ }), p;
1180
+ }, /* @__PURE__ */ new Map());
1181
+ return Array.from(m.values());
1182
+ }, [e, r, t, o]), a = A(e), d = T((u) => {
1183
+ s((h) => {
1184
+ const m = /* @__PURE__ */ new Set(), p = a.current.find(({ key: g }) => g === u);
1185
+ return h.has(u) || m.add(u), p != null && a.current.filter(
1186
+ ({ message: c, variant: f }) => c === p.message && f === p.variant
1187
+ ).forEach((c) => m.add(c.key)), m.size == 0 ? h : /* @__PURE__ */ new Set([...m, ...h]);
1188
+ });
1189
+ }, []);
1190
+ return { statuses: i, silence: d };
1191
+ }, At = {
1192
+ info: "var(--pluto-text-color)",
1193
+ error: "var(--pluto-error-z)",
1194
+ warning: "var(--pluto-warning-m1)",
1195
+ success: "var(--pluto-primary-z)",
1196
+ loading: "var(--pluto-text-color)",
1197
+ disabled: "var(--pluto-gray-l8)",
1198
+ secondary: "var(--pluto-secondary-z)"
1199
+ }, Re = ({
1200
+ variant: r = "info",
1201
+ level: l = "p",
1202
+ hideIcon: e = !1,
1203
+ className: t,
1204
+ ...s
1205
+ }) => {
1206
+ let o;
1207
+ return e || (o = r === "loading" ? /* @__PURE__ */ x.jsx(V.Loading, {}) : /* @__PURE__ */ x.jsx(V.Circle, {})), /* @__PURE__ */ x.jsx(
1208
+ ue,
1209
+ {
1210
+ color: At[r],
1211
+ className: y(t, y.B("status-text")),
1212
+ level: l,
1213
+ startIcon: o,
1214
+ ...s
1215
+ }
1216
+ );
1217
+ }, kt = ({ style: r, ...l }) => /* @__PURE__ */ x.jsx(Ke, { style: r, grow: !0, children: /* @__PURE__ */ x.jsx(Re, { ...l }) }), us = Object.assign(Re, { Centered: kt });
1218
+ export {
1219
+ ls as A,
1220
+ Mt as C,
1221
+ Ze as D,
1222
+ rs as H,
1223
+ Qe as I,
1224
+ is as L,
1225
+ ns as S,
1226
+ us as T,
1227
+ At as V,
1228
+ X as a,
1229
+ os as b,
1230
+ ss as c,
1231
+ F as d,
1232
+ fe as e,
1233
+ be as f,
1234
+ St as g,
1235
+ yt as h,
1236
+ xe as i,
1237
+ ts as j,
1238
+ Ye as k,
1239
+ es as l,
1240
+ Rt as m,
1241
+ as as n,
1242
+ cs as o,
1243
+ Xe as p,
1244
+ vt as s,
1245
+ Y as u
1246
+ };