@sprawlify/primitives 0.0.1

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 (378) hide show
  1. package/dist/anatomy.cjs +3 -0
  2. package/dist/anatomy.d.cts +2 -0
  3. package/dist/anatomy.d.mts +2 -0
  4. package/dist/anatomy.mjs +3 -0
  5. package/dist/aria-hidden-DqYx0f_y.mjs +177 -0
  6. package/dist/aria-hidden-DtLU6hSU.cjs +182 -0
  7. package/dist/aria-hidden.cjs +4 -0
  8. package/dist/aria-hidden.d.cts +16 -0
  9. package/dist/aria-hidden.d.mts +16 -0
  10. package/dist/aria-hidden.mjs +4 -0
  11. package/dist/auto-resize-D3qHtFy1.mjs +114 -0
  12. package/dist/auto-resize-xzlPFDyD.cjs +125 -0
  13. package/dist/auto-resize.cjs +5 -0
  14. package/dist/auto-resize.d.cts +17 -0
  15. package/dist/auto-resize.d.mts +17 -0
  16. package/dist/auto-resize.mjs +4 -0
  17. package/dist/chunk-CbDLau6x.cjs +34 -0
  18. package/dist/collection-8XqaNHs_.mjs +1279 -0
  19. package/dist/collection-DIoIDISa.cjs +1326 -0
  20. package/dist/collection.cjs +11 -0
  21. package/dist/collection.d.cts +5 -0
  22. package/dist/collection.d.mts +5 -0
  23. package/dist/collection.mjs +4 -0
  24. package/dist/color-BkAP1Tkd.d.mts +60 -0
  25. package/dist/color-VKewNv2e.d.cts +60 -0
  26. package/dist/color-utils-Cc5GVXZh.mjs +657 -0
  27. package/dist/color-utils-LER_6Zwu.cjs +680 -0
  28. package/dist/color-utils.cjs +7 -0
  29. package/dist/color-utils.d.cts +19 -0
  30. package/dist/color-utils.d.mts +19 -0
  31. package/dist/color-utils.mjs +4 -0
  32. package/dist/core-30pJjyC2.d.mts +49 -0
  33. package/dist/core-CQFbMdTl.cjs +176 -0
  34. package/dist/core-CefBjbst.d.cts +49 -0
  35. package/dist/core-DCFNMTZF.mjs +129 -0
  36. package/dist/core.cjs +12 -0
  37. package/dist/core.d.cts +3 -0
  38. package/dist/core.d.mts +3 -0
  39. package/dist/core.mjs +5 -0
  40. package/dist/create-anatomy-B3XYc-qG.d.mts +70 -0
  41. package/dist/create-anatomy-BGQ8pv8J.d.cts +70 -0
  42. package/dist/create-anatomy-BbDZbHpC.mjs +39 -0
  43. package/dist/create-anatomy-CDsIFUXg.cjs +45 -0
  44. package/dist/create-props-BnF_vl-E.mjs +5 -0
  45. package/dist/create-props-YKy7JIKj.cjs +11 -0
  46. package/dist/data-url-C3ITPVRX.d.cts +10 -0
  47. package/dist/data-url-DLwZ9M77.d.mts +10 -0
  48. package/dist/date-utils-D2xPHa_I.cjs +738 -0
  49. package/dist/date-utils-wEa1hhpc.mjs +474 -0
  50. package/dist/date-utils.cjs +46 -0
  51. package/dist/date-utils.d.cts +101 -0
  52. package/dist/date-utils.d.mts +2 -0
  53. package/dist/date-utils.mjs +3 -0
  54. package/dist/defineProperty-BoUOT9Ie.cjs +49 -0
  55. package/dist/defineProperty-DrXfyjd4.mjs +43 -0
  56. package/dist/dismissable-CTfKZ4OG.cjs +282 -0
  57. package/dist/dismissable-DDrx0xnH.mjs +271 -0
  58. package/dist/dismissable-layer-C7pZU2wi.d.cts +39 -0
  59. package/dist/dismissable-layer-t_b0fk-p.d.mts +39 -0
  60. package/dist/dismissable.cjs +7 -0
  61. package/dist/dismissable.d.cts +3 -0
  62. package/dist/dismissable.d.mts +3 -0
  63. package/dist/dismissable.mjs +6 -0
  64. package/dist/dom-query-CWZdWUGp.cjs +2141 -0
  65. package/dist/dom-query-DFCRhyj1.mjs +1374 -0
  66. package/dist/dom-query.cjs +130 -0
  67. package/dist/dom-query.d.cts +307 -0
  68. package/dist/dom-query.d.mts +307 -0
  69. package/dist/dom-query.mjs +3 -0
  70. package/dist/file-utils.cjs +220 -0
  71. package/dist/file-utils.d.cts +51 -0
  72. package/dist/file-utils.d.mts +51 -0
  73. package/dist/file-utils.mjs +210 -0
  74. package/dist/focus-trap-D-bypQEJ.mjs +485 -0
  75. package/dist/focus-trap-D4i52S9A.cjs +496 -0
  76. package/dist/focus-trap.cjs +5 -0
  77. package/dist/focus-trap.d.cts +88 -0
  78. package/dist/focus-trap.d.mts +88 -0
  79. package/dist/focus-trap.mjs +4 -0
  80. package/dist/focus-visible-DYTWdWpa.cjs +210 -0
  81. package/dist/focus-visible-irppYatv.mjs +175 -0
  82. package/dist/focus-visible.cjs +9 -0
  83. package/dist/focus-visible.d.cts +31 -0
  84. package/dist/focus-visible.d.mts +31 -0
  85. package/dist/focus-visible.mjs +4 -0
  86. package/dist/functions-BOkTDEFM.d.cts +15 -0
  87. package/dist/functions-IZtWcC8Q.d.mts +15 -0
  88. package/dist/highlight-word.cjs +100 -0
  89. package/dist/highlight-word.d.cts +24 -0
  90. package/dist/highlight-word.d.mts +24 -0
  91. package/dist/highlight-word.mjs +99 -0
  92. package/dist/hotkeys.cjs +758 -0
  93. package/dist/hotkeys.d.cts +130 -0
  94. package/dist/hotkeys.d.mts +130 -0
  95. package/dist/hotkeys.mjs +754 -0
  96. package/dist/i18n-utils.cjs +450 -0
  97. package/dist/i18n-utils.d.cts +61 -0
  98. package/dist/i18n-utils.d.mts +61 -0
  99. package/dist/i18n-utils.mjs +440 -0
  100. package/dist/index-BkzYij2j.d.mts +25 -0
  101. package/dist/index-Bqw3r34-.d.cts +1383 -0
  102. package/dist/index-C0MKXQmE.d.mts +1383 -0
  103. package/dist/index-C9-feK5c.d.cts +25 -0
  104. package/dist/index-CD5FN7kY.d.mts +114 -0
  105. package/dist/index-CJji6wHl.d.cts +15 -0
  106. package/dist/index-CNi5FkPe.d.mts +15 -0
  107. package/dist/index-D96rs8B0.d.mts +115 -0
  108. package/dist/index.cjs +0 -0
  109. package/dist/index.d.cts +1 -0
  110. package/dist/index.d.mts +1 -0
  111. package/dist/index.mjs +1 -0
  112. package/dist/interact-outside-BplxR9cR.mjs +200 -0
  113. package/dist/interact-outside-C8-oFBpB.cjs +205 -0
  114. package/dist/interact-outside.cjs +5 -0
  115. package/dist/interact-outside.d.cts +2 -0
  116. package/dist/interact-outside.d.mts +2 -0
  117. package/dist/interact-outside.mjs +5 -0
  118. package/dist/json-tree-utils.cjs +1512 -0
  119. package/dist/json-tree-utils.d.cts +117 -0
  120. package/dist/json-tree-utils.d.mts +117 -0
  121. package/dist/json-tree-utils.mjs +1463 -0
  122. package/dist/list-collection-BIMJGQjn.d.cts +61 -0
  123. package/dist/list-collection-Db3eixRU.d.mts +61 -0
  124. package/dist/live-region-CcZPGo89.cjs +52 -0
  125. package/dist/live-region-CnPh21WH.mjs +46 -0
  126. package/dist/live-region.cjs +3 -0
  127. package/dist/live-region.d.cts +2 -0
  128. package/dist/live-region.d.mts +2 -0
  129. package/dist/live-region.mjs +3 -0
  130. package/dist/machines/accordion/index.cjs +328 -0
  131. package/dist/machines/accordion/index.d.cts +83 -0
  132. package/dist/machines/accordion/index.d.mts +83 -0
  133. package/dist/machines/accordion/index.mjs +322 -0
  134. package/dist/machines/async-list/index.cjs +311 -0
  135. package/dist/machines/async-list/index.d.cts +89 -0
  136. package/dist/machines/async-list/index.d.mts +89 -0
  137. package/dist/machines/async-list/index.mjs +310 -0
  138. package/dist/machines/avatar/index.cjs +169 -0
  139. package/dist/machines/avatar/index.d.cts +63 -0
  140. package/dist/machines/avatar/index.d.mts +63 -0
  141. package/dist/machines/avatar/index.mjs +165 -0
  142. package/dist/machines/bottom-sheet/index.cjs +676 -0
  143. package/dist/machines/bottom-sheet/index.d.cts +239 -0
  144. package/dist/machines/bottom-sheet/index.d.mts +239 -0
  145. package/dist/machines/bottom-sheet/index.mjs +672 -0
  146. package/dist/machines/carousel/index.cjs +859 -0
  147. package/dist/machines/carousel/index.d.cts +146 -0
  148. package/dist/machines/carousel/index.d.mts +146 -0
  149. package/dist/machines/carousel/index.mjs +851 -0
  150. package/dist/machines/checkbox/index.cjs +316 -0
  151. package/dist/machines/checkbox/index.d.cts +81 -0
  152. package/dist/machines/checkbox/index.d.mts +81 -0
  153. package/dist/machines/checkbox/index.mjs +312 -0
  154. package/dist/machines/clipboard/index.cjs +225 -0
  155. package/dist/machines/clipboard/index.d.cts +68 -0
  156. package/dist/machines/clipboard/index.d.mts +68 -0
  157. package/dist/machines/clipboard/index.mjs +219 -0
  158. package/dist/machines/collapsible/index.cjs +362 -0
  159. package/dist/machines/collapsible/index.d.cts +82 -0
  160. package/dist/machines/collapsible/index.d.mts +82 -0
  161. package/dist/machines/collapsible/index.mjs +358 -0
  162. package/dist/machines/color-picker/index.cjs +1529 -0
  163. package/dist/machines/color-picker/index.d.cts +205 -0
  164. package/dist/machines/color-picker/index.d.mts +205 -0
  165. package/dist/machines/color-picker/index.mjs +1514 -0
  166. package/dist/machines/combobox/index.cjs +1593 -0
  167. package/dist/machines/combobox/index.d.cts +214 -0
  168. package/dist/machines/combobox/index.d.mts +214 -0
  169. package/dist/machines/combobox/index.mjs +1582 -0
  170. package/dist/machines/date-picker/index.cjs +2177 -0
  171. package/dist/machines/date-picker/index.d.cts +350 -0
  172. package/dist/machines/date-picker/index.d.mts +350 -0
  173. package/dist/machines/date-picker/index.mjs +2161 -0
  174. package/dist/machines/dialog/index.cjs +325 -0
  175. package/dist/machines/dialog/index.d.cts +80 -0
  176. package/dist/machines/dialog/index.d.mts +80 -0
  177. package/dist/machines/dialog/index.mjs +321 -0
  178. package/dist/machines/editable/index.cjs +551 -0
  179. package/dist/machines/editable/index.d.cts +114 -0
  180. package/dist/machines/editable/index.d.mts +114 -0
  181. package/dist/machines/editable/index.mjs +547 -0
  182. package/dist/machines/floating-panel/index.cjs +995 -0
  183. package/dist/machines/floating-panel/index.d.cts +147 -0
  184. package/dist/machines/floating-panel/index.d.mts +147 -0
  185. package/dist/machines/floating-panel/index.mjs +988 -0
  186. package/dist/machines/hover-card/index.cjs +383 -0
  187. package/dist/machines/hover-card/index.d.cts +69 -0
  188. package/dist/machines/hover-card/index.d.mts +69 -0
  189. package/dist/machines/hover-card/index.mjs +379 -0
  190. package/dist/machines/image-cropper/index.cjs +1995 -0
  191. package/dist/machines/image-cropper/index.d.cts +182 -0
  192. package/dist/machines/image-cropper/index.d.mts +182 -0
  193. package/dist/machines/image-cropper/index.mjs +1990 -0
  194. package/dist/machines/listbox/index.cjs +794 -0
  195. package/dist/machines/listbox/index.d.cts +168 -0
  196. package/dist/machines/listbox/index.d.mts +168 -0
  197. package/dist/machines/listbox/index.mjs +782 -0
  198. package/dist/machines/marquee/index.cjs +395 -0
  199. package/dist/machines/marquee/index.d.cts +102 -0
  200. package/dist/machines/marquee/index.d.mts +102 -0
  201. package/dist/machines/marquee/index.mjs +391 -0
  202. package/dist/machines/menu/index.cjs +1298 -0
  203. package/dist/machines/menu/index.d.cts +175 -0
  204. package/dist/machines/menu/index.d.mts +175 -0
  205. package/dist/machines/menu/index.mjs +1286 -0
  206. package/dist/machines/navigation-menu/index.cjs +861 -0
  207. package/dist/machines/navigation-menu/index.d.cts +127 -0
  208. package/dist/machines/navigation-menu/index.d.mts +127 -0
  209. package/dist/machines/navigation-menu/index.mjs +857 -0
  210. package/dist/machines/number-input/index.cjs +996 -0
  211. package/dist/machines/number-input/index.d.cts +134 -0
  212. package/dist/machines/number-input/index.d.mts +134 -0
  213. package/dist/machines/number-input/index.mjs +991 -0
  214. package/dist/machines/pagination/index.cjs +419 -0
  215. package/dist/machines/pagination/index.d.cts +139 -0
  216. package/dist/machines/pagination/index.d.mts +139 -0
  217. package/dist/machines/pagination/index.mjs +411 -0
  218. package/dist/machines/password-input/index.cjs +228 -0
  219. package/dist/machines/password-input/index.d.cts +71 -0
  220. package/dist/machines/password-input/index.d.mts +71 -0
  221. package/dist/machines/password-input/index.mjs +224 -0
  222. package/dist/machines/pin-input/index.cjs +523 -0
  223. package/dist/machines/pin-input/index.d.cts +105 -0
  224. package/dist/machines/pin-input/index.d.mts +105 -0
  225. package/dist/machines/pin-input/index.mjs +519 -0
  226. package/dist/machines/popover/index.cjs +430 -0
  227. package/dist/machines/popover/index.d.cts +88 -0
  228. package/dist/machines/popover/index.d.mts +88 -0
  229. package/dist/machines/popover/index.mjs +426 -0
  230. package/dist/machines/presence/index.cjs +192 -0
  231. package/dist/machines/presence/index.d.cts +44 -0
  232. package/dist/machines/presence/index.d.mts +44 -0
  233. package/dist/machines/presence/index.mjs +190 -0
  234. package/dist/machines/progress/index.cjs +288 -0
  235. package/dist/machines/progress/index.d.cts +96 -0
  236. package/dist/machines/progress/index.d.mts +96 -0
  237. package/dist/machines/progress/index.mjs +284 -0
  238. package/dist/machines/qr-code/index.cjs +172 -0
  239. package/dist/machines/qr-code/index.d.cts +70 -0
  240. package/dist/machines/qr-code/index.d.mts +70 -0
  241. package/dist/machines/qr-code/index.mjs +167 -0
  242. package/dist/machines/radio-group/index.cjs +436 -0
  243. package/dist/machines/radio-group/index.d.cts +106 -0
  244. package/dist/machines/radio-group/index.d.mts +106 -0
  245. package/dist/machines/radio-group/index.mjs +430 -0
  246. package/dist/machines/rating-group/index.cjs +405 -0
  247. package/dist/machines/rating-group/index.d.cts +101 -0
  248. package/dist/machines/rating-group/index.d.mts +101 -0
  249. package/dist/machines/rating-group/index.mjs +399 -0
  250. package/dist/machines/scroll-area/index.cjs +857 -0
  251. package/dist/machines/scroll-area/index.d.cts +159 -0
  252. package/dist/machines/scroll-area/index.d.mts +159 -0
  253. package/dist/machines/scroll-area/index.mjs +853 -0
  254. package/dist/machines/select/index.cjs +1165 -0
  255. package/dist/machines/select/index.d.cts +183 -0
  256. package/dist/machines/select/index.d.mts +183 -0
  257. package/dist/machines/select/index.mjs +1154 -0
  258. package/dist/machines/signature-pad/index.cjs +334 -0
  259. package/dist/machines/signature-pad/index.d.cts +108 -0
  260. package/dist/machines/signature-pad/index.d.mts +108 -0
  261. package/dist/machines/signature-pad/index.mjs +328 -0
  262. package/dist/machines/slider/index.cjs +957 -0
  263. package/dist/machines/slider/index.d.cts +149 -0
  264. package/dist/machines/slider/index.d.mts +149 -0
  265. package/dist/machines/slider/index.mjs +949 -0
  266. package/dist/machines/splitter/index.cjs +1112 -0
  267. package/dist/machines/splitter/index.d.cts +155 -0
  268. package/dist/machines/splitter/index.d.mts +155 -0
  269. package/dist/machines/splitter/index.mjs +1103 -0
  270. package/dist/machines/steps/index.cjs +289 -0
  271. package/dist/machines/steps/index.d.cts +97 -0
  272. package/dist/machines/steps/index.d.mts +97 -0
  273. package/dist/machines/steps/index.mjs +285 -0
  274. package/dist/machines/switch/index.cjs +305 -0
  275. package/dist/machines/switch/index.d.cts +80 -0
  276. package/dist/machines/switch/index.d.mts +80 -0
  277. package/dist/machines/switch/index.mjs +301 -0
  278. package/dist/machines/tabs/index.cjs +508 -0
  279. package/dist/machines/tabs/index.d.cts +111 -0
  280. package/dist/machines/tabs/index.d.mts +111 -0
  281. package/dist/machines/tabs/index.mjs +500 -0
  282. package/dist/machines/tags-input/index.cjs +1127 -0
  283. package/dist/machines/tags-input/index.d.cts +179 -0
  284. package/dist/machines/tags-input/index.d.mts +179 -0
  285. package/dist/machines/tags-input/index.mjs +1121 -0
  286. package/dist/machines/timer/index.cjs +329 -0
  287. package/dist/machines/timer/index.d.cts +98 -0
  288. package/dist/machines/timer/index.d.mts +98 -0
  289. package/dist/machines/timer/index.mjs +324 -0
  290. package/dist/machines/toast/index.cjs +1155 -0
  291. package/dist/machines/toast/index.d.cts +195 -0
  292. package/dist/machines/toast/index.d.mts +195 -0
  293. package/dist/machines/toast/index.mjs +1151 -0
  294. package/dist/machines/toggle/index.cjs +103 -0
  295. package/dist/machines/toggle/index.d.cts +46 -0
  296. package/dist/machines/toggle/index.d.mts +46 -0
  297. package/dist/machines/toggle/index.mjs +99 -0
  298. package/dist/machines/toggle-group/index.cjs +328 -0
  299. package/dist/machines/toggle-group/index.d.cts +81 -0
  300. package/dist/machines/toggle-group/index.d.mts +81 -0
  301. package/dist/machines/toggle-group/index.mjs +322 -0
  302. package/dist/machines/tooltip/index.cjs +516 -0
  303. package/dist/machines/tooltip/index.d.cts +71 -0
  304. package/dist/machines/tooltip/index.d.mts +71 -0
  305. package/dist/machines/tooltip/index.mjs +512 -0
  306. package/dist/machines/tour/index.cjs +1108 -0
  307. package/dist/machines/tour/index.d.cts +206 -0
  308. package/dist/machines/tour/index.d.mts +206 -0
  309. package/dist/machines/tour/index.mjs +1101 -0
  310. package/dist/machines/tree-view/index.cjs +1271 -0
  311. package/dist/machines/tree-view/index.d.cts +215 -0
  312. package/dist/machines/tree-view/index.d.mts +215 -0
  313. package/dist/machines/tree-view/index.mjs +1263 -0
  314. package/dist/node-BctU8GXk.d.mts +24 -0
  315. package/dist/node-CSsuPZVZ.d.cts +24 -0
  316. package/dist/popper-BPJeAtcA.mjs +349 -0
  317. package/dist/popper-D0FAW_p7.cjs +373 -0
  318. package/dist/popper.cjs +8 -0
  319. package/dist/popper.d.cts +74 -0
  320. package/dist/popper.d.mts +2 -0
  321. package/dist/popper.mjs +5 -0
  322. package/dist/raf-BnlYUlDi.d.mts +15 -0
  323. package/dist/raf-Cd2FGy0z.d.cts +15 -0
  324. package/dist/rect-utils-0ellN0a_.mjs +854 -0
  325. package/dist/rect-utils-DKLRhP8G.cjs +1147 -0
  326. package/dist/rect-utils.cjs +51 -0
  327. package/dist/rect-utils.d.cts +198 -0
  328. package/dist/rect-utils.d.mts +198 -0
  329. package/dist/rect-utils.mjs +3 -0
  330. package/dist/remove-scroll-Lrfv79X_.mjs +58 -0
  331. package/dist/remove-scroll-Uvzg1L9r.cjs +63 -0
  332. package/dist/remove-scroll.cjs +0 -0
  333. package/dist/remove-scroll.d.cts +1 -0
  334. package/dist/remove-scroll.d.mts +1 -0
  335. package/dist/remove-scroll.mjs +1 -0
  336. package/dist/scroll-snap-CrTmQRzA.mjs +152 -0
  337. package/dist/scroll-snap-zyiZLv7W.cjs +175 -0
  338. package/dist/scroll-snap.cjs +7 -0
  339. package/dist/scroll-snap.d.cts +14 -0
  340. package/dist/scroll-snap.d.mts +14 -0
  341. package/dist/scroll-snap.mjs +4 -0
  342. package/dist/selection-BIhSzkF7.d.mts +50 -0
  343. package/dist/selection-CS1GBp8e.d.cts +50 -0
  344. package/dist/store-BZcXv49B.cjs +305 -0
  345. package/dist/store-DEojWy9H.mjs +263 -0
  346. package/dist/store.cjs +9 -0
  347. package/dist/store.d.cts +26 -0
  348. package/dist/store.d.mts +26 -0
  349. package/dist/store.mjs +3 -0
  350. package/dist/stringify-state.cjs +49 -0
  351. package/dist/stringify-state.d.cts +8 -0
  352. package/dist/stringify-state.d.mts +8 -0
  353. package/dist/stringify-state.mjs +46 -0
  354. package/dist/tree-collection-BwU5WhGQ.d.mts +78 -0
  355. package/dist/tree-collection-DP_eznnI.d.cts +78 -0
  356. package/dist/typeahead-BdNwVP09.d.cts +45 -0
  357. package/dist/typeahead-XN6lZ7G9.d.mts +45 -0
  358. package/dist/types-BivBkYg9.d.cts +57 -0
  359. package/dist/types-Bl_6JtPQ.d.mts +57 -0
  360. package/dist/types-CPUMVt7c.d.mts +54 -0
  361. package/dist/types-CT_W6HWr.d.cts +54 -0
  362. package/dist/types-DDTcG99l.d.mts +201 -0
  363. package/dist/types-DejIu60O.d.cts +201 -0
  364. package/dist/types-DiIdKZ3K.d.cts +45 -0
  365. package/dist/types-GxLIgJib.d.cts +17 -0
  366. package/dist/types.cjs +15 -0
  367. package/dist/types.d.cts +2 -0
  368. package/dist/types.d.mts +2 -0
  369. package/dist/types.mjs +14 -0
  370. package/dist/utils-BZyrxWWR.mjs +525 -0
  371. package/dist/utils-_6frwjgJ.cjs +1040 -0
  372. package/dist/utils.cjs +88 -0
  373. package/dist/utils.d.cts +144 -0
  374. package/dist/utils.d.mts +144 -0
  375. package/dist/utils.mjs +3 -0
  376. package/dist/wait-for-CMjPsqWk.d.cts +10 -0
  377. package/dist/wait-for-D2nkdD4z.d.mts +10 -0
  378. package/package.json +399 -0
@@ -0,0 +1,988 @@
1
+ import { t as createAnatomy } from "../../create-anatomy-BbDZbHpC.mjs";
2
+ import { T as trackPointerMove, U as raf, dt as getEventStep, ft as getEventTarget, ln as isHTMLElement, lt as getEventKey, p as resizeObserverBorderBox, st as addDomEvent, vn as dataAttr, yt as isLeftClick } from "../../dom-query-DFCRhyj1.mjs";
3
+ import { H as toPx, J as match, g as clampValue, n as ensureProps, p as pick, r as invariant, u as createSplitProps } from "../../utils-BZyrxWWR.mjs";
4
+ import { a as createMachine, i as createGuards } from "../../core-DCFNMTZF.mjs";
5
+ import { G as clampPoint, I as addPoints, K as clampSize, R as createRect, T as constrainRect, W as subtractPoints, d as getWindowRect, t as resizeRect, v as getElementRect, x as isSizeEqual, y as isPointEqual } from "../../rect-utils-0ellN0a_.mjs";
6
+ import { a as subscribe, n as proxy } from "../../store-DEojWy9H.mjs";
7
+ import { t as createProps } from "../../create-props-BnF_vl-E.mjs";
8
+
9
+ //#region src/machines/floating-panel/floating-panel.anatomy.ts
10
+ const anatomy = createAnatomy("floating-panel").parts("trigger", "positioner", "content", "header", "body", "title", "resizeTrigger", "dragTrigger", "stageTrigger", "closeTrigger", "control");
11
+ const parts = anatomy.build();
12
+
13
+ //#endregion
14
+ //#region src/machines/floating-panel/floating-panel.dom.ts
15
+ const getTriggerId = (ctx) => ctx.ids?.trigger ?? `floating-panel:${ctx.id}:trigger`;
16
+ const getPositionerId = (ctx) => ctx.ids?.positioner ?? `floating-panel:${ctx.id}:positioner`;
17
+ const getContentId = (ctx) => ctx.ids?.content ?? `floating-panel:${ctx.id}:content`;
18
+ const getTitleId = (ctx) => ctx.ids?.title ?? `floating-panel:${ctx.id}:title`;
19
+ const getHeaderId = (ctx) => ctx.ids?.header ?? `floating-panel:${ctx.id}:header`;
20
+ const getTriggerEl = (ctx) => ctx.getById(getTriggerId(ctx));
21
+ const getPositionerEl = (ctx) => ctx.getById(getPositionerId(ctx));
22
+ const getContentEl = (ctx) => ctx.getById(getContentId(ctx));
23
+ const getHeaderEl = (ctx) => ctx.getById(getHeaderId(ctx));
24
+ const getBoundaryRect = (ctx, boundaryEl, allowOverflow) => {
25
+ let boundaryRect;
26
+ if (isHTMLElement(boundaryEl)) boundaryRect = getElementRect(boundaryEl);
27
+ else boundaryRect = getWindowRect(ctx.getWin());
28
+ if (allowOverflow) boundaryRect = createRect({
29
+ x: -boundaryRect.width,
30
+ y: boundaryRect.minY,
31
+ width: boundaryRect.width * 3,
32
+ height: boundaryRect.height * 2
33
+ });
34
+ return pick(boundaryRect, [
35
+ "x",
36
+ "y",
37
+ "width",
38
+ "height"
39
+ ]);
40
+ };
41
+
42
+ //#endregion
43
+ //#region src/machines/floating-panel/get-resize-axis-style.ts
44
+ function getResizeAxisStyle(axis) {
45
+ switch (axis) {
46
+ case "n": return {
47
+ cursor: "n-resize",
48
+ width: "100%",
49
+ top: 0,
50
+ left: "50%",
51
+ translate: "-50%"
52
+ };
53
+ case "e": return {
54
+ cursor: "e-resize",
55
+ height: "100%",
56
+ right: 0,
57
+ top: "50%",
58
+ translate: "0 -50%"
59
+ };
60
+ case "s": return {
61
+ cursor: "s-resize",
62
+ width: "100%",
63
+ bottom: 0,
64
+ left: "50%",
65
+ translate: "-50%"
66
+ };
67
+ case "w": return {
68
+ cursor: "w-resize",
69
+ height: "100%",
70
+ left: 0,
71
+ top: "50%",
72
+ translate: "0 -50%"
73
+ };
74
+ case "se": return {
75
+ cursor: "se-resize",
76
+ bottom: 0,
77
+ right: 0
78
+ };
79
+ case "sw": return {
80
+ cursor: "sw-resize",
81
+ bottom: 0,
82
+ left: 0
83
+ };
84
+ case "ne": return {
85
+ cursor: "ne-resize",
86
+ top: 0,
87
+ right: 0
88
+ };
89
+ case "nw": return {
90
+ cursor: "nw-resize",
91
+ top: 0,
92
+ left: 0
93
+ };
94
+ default: throw new Error(`Invalid axis: ${axis}`);
95
+ }
96
+ }
97
+
98
+ //#endregion
99
+ //#region src/machines/floating-panel/floating-panel.connect.ts
100
+ const validStages = new Set([
101
+ "minimized",
102
+ "maximized",
103
+ "default"
104
+ ]);
105
+ function connect(service, normalize) {
106
+ const { state, send, scope, prop, computed, context } = service;
107
+ const open = state.hasTag("open");
108
+ const dragging = state.matches("open.dragging");
109
+ const resizing = state.matches("open.resizing");
110
+ const isTopmost = context.get("isTopmost");
111
+ const size = context.get("size");
112
+ const position = context.get("position");
113
+ const isMaximized = computed("isMaximized");
114
+ const isMinimized = computed("isMinimized");
115
+ const isStaged = computed("isStaged");
116
+ const canResize = computed("canResize");
117
+ const canDrag = computed("canDrag");
118
+ return {
119
+ open,
120
+ resizable: prop("resizable"),
121
+ draggable: prop("draggable"),
122
+ setOpen(nextOpen) {
123
+ if (state.hasTag("open") === nextOpen) return;
124
+ send({ type: nextOpen ? "OPEN" : "CLOSE" });
125
+ },
126
+ dragging,
127
+ resizing,
128
+ position,
129
+ size,
130
+ setPosition(position$1) {
131
+ send({
132
+ type: "SET_POSITION",
133
+ position: position$1
134
+ });
135
+ },
136
+ setSize(size$1) {
137
+ send({
138
+ type: "SET_SIZE",
139
+ size: size$1
140
+ });
141
+ },
142
+ minimize() {
143
+ send({ type: "MINIMIZE" });
144
+ },
145
+ maximize() {
146
+ send({ type: "MAXIMIZE" });
147
+ },
148
+ restore() {
149
+ send({ type: "RESTORE" });
150
+ },
151
+ getTriggerProps() {
152
+ return normalize.button({
153
+ ...parts.trigger.attrs,
154
+ dir: prop("dir"),
155
+ type: "button",
156
+ disabled: prop("disabled"),
157
+ id: getTriggerId(scope),
158
+ "data-state": open ? "open" : "closed",
159
+ "data-dragging": dataAttr(dragging),
160
+ "aria-controls": getContentId(scope),
161
+ onClick(event) {
162
+ if (event.defaultPrevented) return;
163
+ if (prop("disabled")) return;
164
+ send({
165
+ type: state.hasTag("open") ? "CLOSE" : "OPEN",
166
+ src: "trigger"
167
+ });
168
+ }
169
+ });
170
+ },
171
+ getPositionerProps() {
172
+ return normalize.element({
173
+ ...parts.positioner.attrs,
174
+ dir: prop("dir"),
175
+ id: getPositionerId(scope),
176
+ style: {
177
+ "--width": toPx(size?.width),
178
+ "--height": toPx(size?.height),
179
+ "--x": toPx(position?.x),
180
+ "--y": toPx(position?.y),
181
+ position: prop("strategy"),
182
+ top: "var(--y)",
183
+ left: "var(--x)"
184
+ }
185
+ });
186
+ },
187
+ getContentProps() {
188
+ return normalize.element({
189
+ ...parts.content.attrs,
190
+ dir: prop("dir"),
191
+ role: "dialog",
192
+ tabIndex: 0,
193
+ hidden: !open,
194
+ id: getContentId(scope),
195
+ "aria-labelledby": getTitleId(scope),
196
+ "data-state": open ? "open" : "closed",
197
+ "data-dragging": dataAttr(dragging),
198
+ "data-topmost": dataAttr(isTopmost),
199
+ "data-behind": dataAttr(!isTopmost),
200
+ "data-minimized": dataAttr(isMinimized),
201
+ "data-maximized": dataAttr(isMaximized),
202
+ "data-staged": dataAttr(isStaged),
203
+ style: {
204
+ width: "var(--width)",
205
+ height: "var(--height)",
206
+ overflow: isMinimized ? "hidden" : void 0
207
+ },
208
+ onFocus() {
209
+ send({ type: "CONTENT_FOCUS" });
210
+ },
211
+ onKeyDown(event) {
212
+ if (event.defaultPrevented) return;
213
+ if (event.currentTarget !== getEventTarget(event)) return;
214
+ const step = getEventStep(event) * prop("gridSize");
215
+ const handler = {
216
+ Escape() {
217
+ if (!isTopmost) return;
218
+ send({ type: "ESCAPE" });
219
+ },
220
+ ArrowLeft() {
221
+ send({
222
+ type: "MOVE",
223
+ direction: "left",
224
+ step
225
+ });
226
+ },
227
+ ArrowRight() {
228
+ send({
229
+ type: "MOVE",
230
+ direction: "right",
231
+ step
232
+ });
233
+ },
234
+ ArrowUp() {
235
+ send({
236
+ type: "MOVE",
237
+ direction: "up",
238
+ step
239
+ });
240
+ },
241
+ ArrowDown() {
242
+ send({
243
+ type: "MOVE",
244
+ direction: "down",
245
+ step
246
+ });
247
+ }
248
+ }[getEventKey(event, { dir: prop("dir") })];
249
+ if (handler) {
250
+ event.preventDefault();
251
+ handler(event);
252
+ }
253
+ }
254
+ });
255
+ },
256
+ getCloseTriggerProps() {
257
+ return normalize.button({
258
+ ...parts.closeTrigger.attrs,
259
+ dir: prop("dir"),
260
+ disabled: prop("disabled"),
261
+ "aria-label": "Close Window",
262
+ type: "button",
263
+ onClick(event) {
264
+ if (event.defaultPrevented) return;
265
+ send({ type: "CLOSE" });
266
+ }
267
+ });
268
+ },
269
+ getStageTriggerProps(props$1) {
270
+ if (!validStages.has(props$1.stage)) throw new Error(`[sprawlify-js] Invalid stage: ${props$1.stage}. Must be one of: ${Array.from(validStages).join(", ")}`);
271
+ const translations = prop("translations");
272
+ const actionProps = match(props$1.stage, {
273
+ minimized: () => ({
274
+ "aria-label": translations.minimize,
275
+ hidden: isStaged
276
+ }),
277
+ maximized: () => ({
278
+ "aria-label": translations.maximize,
279
+ hidden: isStaged
280
+ }),
281
+ default: () => ({
282
+ "aria-label": translations.restore,
283
+ hidden: !isStaged
284
+ })
285
+ });
286
+ return normalize.button({
287
+ ...parts.stageTrigger.attrs,
288
+ dir: prop("dir"),
289
+ disabled: prop("disabled"),
290
+ ...actionProps,
291
+ type: "button",
292
+ onClick(event) {
293
+ if (event.defaultPrevented) return;
294
+ if (!prop("resizable")) return;
295
+ send({ type: match(props$1.stage, {
296
+ minimized: () => "MINIMIZE",
297
+ maximized: () => "MAXIMIZE",
298
+ default: () => "RESTORE"
299
+ }).toUpperCase() });
300
+ }
301
+ });
302
+ },
303
+ getResizeTriggerProps(props$1) {
304
+ return normalize.element({
305
+ ...parts.resizeTrigger.attrs,
306
+ dir: prop("dir"),
307
+ "data-disabled": dataAttr(!canResize),
308
+ "data-axis": props$1.axis,
309
+ onPointerDown(event) {
310
+ if (!canResize) return;
311
+ if (!isLeftClick(event)) return;
312
+ event.currentTarget.setPointerCapture(event.pointerId);
313
+ event.stopPropagation();
314
+ send({
315
+ type: "RESIZE_START",
316
+ axis: props$1.axis,
317
+ position: {
318
+ x: event.clientX,
319
+ y: event.clientY
320
+ }
321
+ });
322
+ },
323
+ onPointerUp(event) {
324
+ if (!canResize) return;
325
+ const node = event.currentTarget;
326
+ if (node.hasPointerCapture(event.pointerId)) node.releasePointerCapture(event.pointerId);
327
+ },
328
+ style: {
329
+ position: "absolute",
330
+ touchAction: "none",
331
+ ...getResizeAxisStyle(props$1.axis)
332
+ }
333
+ });
334
+ },
335
+ getDragTriggerProps() {
336
+ return normalize.element({
337
+ ...parts.dragTrigger.attrs,
338
+ dir: prop("dir"),
339
+ "data-disabled": dataAttr(!canDrag),
340
+ onPointerDown(event) {
341
+ if (!canDrag) return;
342
+ if (!isLeftClick(event)) return;
343
+ const target = getEventTarget(event);
344
+ if (target?.closest("button") || target?.closest("[data-no-drag]")) return;
345
+ event.currentTarget.setPointerCapture(event.pointerId);
346
+ event.stopPropagation();
347
+ send({
348
+ type: "DRAG_START",
349
+ pointerId: event.pointerId,
350
+ position: {
351
+ x: event.clientX,
352
+ y: event.clientY
353
+ }
354
+ });
355
+ },
356
+ onPointerUp(event) {
357
+ if (!canDrag) return;
358
+ const node = event.currentTarget;
359
+ if (node.hasPointerCapture(event.pointerId)) node.releasePointerCapture(event.pointerId);
360
+ },
361
+ onDoubleClick(event) {
362
+ if (event.defaultPrevented) return;
363
+ if (!prop("resizable")) return;
364
+ send({ type: isMaximized ? "RESTORE" : "MAXIMIZE" });
365
+ },
366
+ style: {
367
+ WebkitUserSelect: "none",
368
+ userSelect: "none",
369
+ touchAction: "none",
370
+ cursor: "move"
371
+ }
372
+ });
373
+ },
374
+ getControlProps() {
375
+ return normalize.element({
376
+ ...parts.control.attrs,
377
+ dir: prop("dir"),
378
+ "data-disabled": dataAttr(prop("disabled")),
379
+ "data-stage": context.get("stage"),
380
+ "data-minimized": dataAttr(isMinimized),
381
+ "data-maximized": dataAttr(isMaximized),
382
+ "data-staged": dataAttr(isStaged)
383
+ });
384
+ },
385
+ getTitleProps() {
386
+ return normalize.element({
387
+ ...parts.title.attrs,
388
+ dir: prop("dir"),
389
+ id: getTitleId(scope)
390
+ });
391
+ },
392
+ getHeaderProps() {
393
+ return normalize.element({
394
+ ...parts.header.attrs,
395
+ dir: prop("dir"),
396
+ id: getHeaderId(scope),
397
+ "data-dragging": dataAttr(dragging),
398
+ "data-topmost": dataAttr(isTopmost),
399
+ "data-behind": dataAttr(!isTopmost),
400
+ "data-minimized": dataAttr(isMinimized),
401
+ "data-maximized": dataAttr(isMaximized),
402
+ "data-staged": dataAttr(isStaged)
403
+ });
404
+ },
405
+ getBodyProps() {
406
+ return normalize.element({
407
+ ...parts.body.attrs,
408
+ dir: prop("dir"),
409
+ "data-dragging": dataAttr(dragging),
410
+ "data-minimized": dataAttr(isMinimized),
411
+ "data-maximized": dataAttr(isMaximized),
412
+ "data-staged": dataAttr(isStaged),
413
+ hidden: isMinimized
414
+ });
415
+ }
416
+ };
417
+ }
418
+
419
+ //#endregion
420
+ //#region src/machines/floating-panel/floating-panel.store.ts
421
+ const panelStack = proxy({
422
+ stack: [],
423
+ count() {
424
+ return this.stack.length;
425
+ },
426
+ add(panelId) {
427
+ if (this.stack.includes(panelId)) return;
428
+ this.stack.push(panelId);
429
+ },
430
+ remove(panelId) {
431
+ const index = this.stack.indexOf(panelId);
432
+ if (index < 0) return;
433
+ this.stack.splice(index, 1);
434
+ },
435
+ bringToFront(id) {
436
+ this.remove(id);
437
+ this.add(id);
438
+ },
439
+ isTopmost(id) {
440
+ return this.stack[this.stack.length - 1] === id;
441
+ },
442
+ indexOf(id) {
443
+ return this.stack.indexOf(id);
444
+ }
445
+ });
446
+
447
+ //#endregion
448
+ //#region src/machines/floating-panel/floating-panel.machine.ts
449
+ const { not, and } = createGuards();
450
+ const defaultTranslations = {
451
+ minimize: "Minimize window",
452
+ maximize: "Maximize window",
453
+ restore: "Restore window"
454
+ };
455
+ const machine = createMachine({
456
+ props({ props: props$1 }) {
457
+ ensureProps(props$1, ["id"], "floating-panel");
458
+ return {
459
+ strategy: "fixed",
460
+ gridSize: 1,
461
+ defaultSize: {
462
+ width: 320,
463
+ height: 240
464
+ },
465
+ defaultPosition: {
466
+ x: 300,
467
+ y: 100
468
+ },
469
+ allowOverflow: true,
470
+ resizable: true,
471
+ draggable: true,
472
+ ...props$1,
473
+ hasSpecifiedPosition: !!props$1.defaultPosition || !!props$1.position,
474
+ translations: {
475
+ ...defaultTranslations,
476
+ ...props$1.translations
477
+ }
478
+ };
479
+ },
480
+ initialState({ prop }) {
481
+ return prop("open") || prop("defaultOpen") ? "open" : "closed";
482
+ },
483
+ context({ prop, bindable }) {
484
+ return {
485
+ size: bindable(() => ({
486
+ defaultValue: prop("defaultSize"),
487
+ value: prop("size"),
488
+ isEqual: isSizeEqual,
489
+ sync: true,
490
+ hash(v) {
491
+ return `W:${v.width} H:${v.height}`;
492
+ },
493
+ onChange(value) {
494
+ prop("onSizeChange")?.({ size: value });
495
+ }
496
+ })),
497
+ position: bindable(() => ({
498
+ defaultValue: prop("defaultPosition"),
499
+ value: prop("position"),
500
+ isEqual: isPointEqual,
501
+ sync: true,
502
+ hash(v) {
503
+ return `X:${v.x} Y:${v.y}`;
504
+ },
505
+ onChange(value) {
506
+ prop("onPositionChange")?.({ position: value });
507
+ }
508
+ })),
509
+ stage: bindable(() => ({
510
+ defaultValue: "default",
511
+ onChange(value) {
512
+ prop("onStageChange")?.({ stage: value });
513
+ }
514
+ })),
515
+ lastEventPosition: bindable(() => ({ defaultValue: null })),
516
+ prevPosition: bindable(() => ({ defaultValue: null })),
517
+ prevSize: bindable(() => ({ defaultValue: null })),
518
+ isTopmost: bindable(() => ({ defaultValue: void 0 }))
519
+ };
520
+ },
521
+ computed: {
522
+ isMaximized: ({ context }) => context.get("stage") === "maximized",
523
+ isMinimized: ({ context }) => context.get("stage") === "minimized",
524
+ isStaged: ({ context }) => context.get("stage") !== "default",
525
+ canResize: ({ context, prop }) => prop("resizable") && !prop("disabled") && context.get("stage") === "default",
526
+ canDrag: ({ prop, computed }) => prop("draggable") && !prop("disabled") && !computed("isMaximized")
527
+ },
528
+ watch({ track, context, action, prop }) {
529
+ track([() => context.hash("position")], () => {
530
+ action(["setPositionStyle"]);
531
+ });
532
+ track([() => context.hash("size")], () => {
533
+ action(["setSizeStyle"]);
534
+ });
535
+ track([() => prop("open")], () => {
536
+ action(["toggleVisibility"]);
537
+ });
538
+ },
539
+ effects: ["trackPanelStack"],
540
+ on: {
541
+ CONTENT_FOCUS: { actions: ["bringToFrontOfPanelStack"] },
542
+ SET_POSITION: { actions: ["setPosition"] },
543
+ SET_SIZE: { actions: ["setSize"] }
544
+ },
545
+ states: {
546
+ closed: {
547
+ tags: ["closed"],
548
+ on: {
549
+ "CONTROLLED.OPEN": {
550
+ target: "open",
551
+ actions: [
552
+ "setAnchorPosition",
553
+ "setPositionStyle",
554
+ "setSizeStyle",
555
+ "focusContentEl"
556
+ ]
557
+ },
558
+ OPEN: [{
559
+ guard: "isOpenControlled",
560
+ actions: ["invokeOnOpen"]
561
+ }, {
562
+ target: "open",
563
+ actions: [
564
+ "invokeOnOpen",
565
+ "setAnchorPosition",
566
+ "setPositionStyle",
567
+ "setSizeStyle",
568
+ "focusContentEl"
569
+ ]
570
+ }]
571
+ }
572
+ },
573
+ open: {
574
+ tags: ["open"],
575
+ entry: ["bringToFrontOfPanelStack"],
576
+ effects: ["trackBoundaryRect"],
577
+ on: {
578
+ DRAG_START: {
579
+ guard: not("isMaximized"),
580
+ target: "open.dragging",
581
+ actions: ["setPrevPosition"]
582
+ },
583
+ RESIZE_START: {
584
+ guard: not("isMinimized"),
585
+ target: "open.resizing",
586
+ actions: ["setPrevSize"]
587
+ },
588
+ "CONTROLLED.CLOSE": {
589
+ target: "closed",
590
+ actions: ["resetRect", "focusTriggerEl"]
591
+ },
592
+ CLOSE: [{
593
+ guard: "isOpenControlled",
594
+ target: "closed",
595
+ actions: ["invokeOnClose"]
596
+ }, {
597
+ target: "closed",
598
+ actions: [
599
+ "invokeOnClose",
600
+ "resetRect",
601
+ "focusTriggerEl"
602
+ ]
603
+ }],
604
+ ESCAPE: [{
605
+ guard: and("isOpenControlled", "closeOnEsc"),
606
+ actions: ["invokeOnClose"]
607
+ }, {
608
+ guard: "closeOnEsc",
609
+ target: "closed",
610
+ actions: [
611
+ "invokeOnClose",
612
+ "resetRect",
613
+ "focusTriggerEl"
614
+ ]
615
+ }],
616
+ MINIMIZE: { actions: ["setMinimized"] },
617
+ MAXIMIZE: { actions: ["setMaximized"] },
618
+ RESTORE: { actions: ["setRestored"] },
619
+ MOVE: { actions: ["setPositionFromKeyboard"] }
620
+ }
621
+ },
622
+ "open.dragging": {
623
+ tags: ["open"],
624
+ effects: ["trackPointerMove"],
625
+ exit: ["clearPrevPosition"],
626
+ on: {
627
+ DRAG: { actions: ["setPosition"] },
628
+ DRAG_END: {
629
+ target: "open",
630
+ actions: ["invokeOnDragEnd"]
631
+ },
632
+ "CONTROLLED.CLOSE": {
633
+ target: "closed",
634
+ actions: ["resetRect"]
635
+ },
636
+ CLOSE: [{
637
+ guard: "isOpenControlled",
638
+ target: "closed",
639
+ actions: ["invokeOnClose"]
640
+ }, {
641
+ target: "closed",
642
+ actions: ["invokeOnClose", "resetRect"]
643
+ }],
644
+ ESCAPE: { target: "open" }
645
+ }
646
+ },
647
+ "open.resizing": {
648
+ tags: ["open"],
649
+ effects: ["trackPointerMove"],
650
+ exit: ["clearPrevSize"],
651
+ on: {
652
+ DRAG: { actions: ["setSize"] },
653
+ DRAG_END: {
654
+ target: "open",
655
+ actions: ["invokeOnResizeEnd"]
656
+ },
657
+ "CONTROLLED.CLOSE": {
658
+ target: "closed",
659
+ actions: ["resetRect"]
660
+ },
661
+ CLOSE: [{
662
+ guard: "isOpenControlled",
663
+ target: "closed",
664
+ actions: ["invokeOnClose"]
665
+ }, {
666
+ target: "closed",
667
+ actions: ["invokeOnClose", "resetRect"]
668
+ }],
669
+ ESCAPE: { target: "open" }
670
+ }
671
+ }
672
+ },
673
+ implementations: {
674
+ guards: {
675
+ closeOnEsc: ({ prop }) => !!prop("closeOnEscape"),
676
+ isMaximized: ({ context }) => context.get("stage") === "maximized",
677
+ isMinimized: ({ context }) => context.get("stage") === "minimized",
678
+ isOpenControlled: ({ prop }) => prop("open") != void 0
679
+ },
680
+ effects: {
681
+ trackPointerMove({ scope, send, event: evt, prop }) {
682
+ const doc = scope.getDoc();
683
+ const boundaryEl = prop("getBoundaryEl")?.();
684
+ const boundaryRect = getBoundaryRect(scope, boundaryEl, false);
685
+ return trackPointerMove(doc, {
686
+ onPointerMove({ point, event }) {
687
+ const { altKey, shiftKey } = event;
688
+ send({
689
+ type: "DRAG",
690
+ position: {
691
+ x: clampValue(point.x, boundaryRect.x, boundaryRect.x + boundaryRect.width),
692
+ y: clampValue(point.y, boundaryRect.y, boundaryRect.y + boundaryRect.height)
693
+ },
694
+ axis: evt.axis,
695
+ altKey,
696
+ shiftKey
697
+ });
698
+ },
699
+ onPointerUp() {
700
+ send({ type: "DRAG_END" });
701
+ }
702
+ });
703
+ },
704
+ trackBoundaryRect({ context, scope, prop, computed }) {
705
+ const win = scope.getWin();
706
+ let skip = true;
707
+ const exec = () => {
708
+ if (skip) {
709
+ skip = false;
710
+ return;
711
+ }
712
+ const boundaryEl$1 = prop("getBoundaryEl")?.();
713
+ let boundaryRect = getBoundaryRect(scope, boundaryEl$1, false);
714
+ if (!computed("isMaximized")) boundaryRect = constrainRect({
715
+ ...context.get("position"),
716
+ ...context.get("size")
717
+ }, boundaryRect);
718
+ context.set("size", pick(boundaryRect, ["width", "height"]));
719
+ context.set("position", pick(boundaryRect, ["x", "y"]));
720
+ };
721
+ const boundaryEl = prop("getBoundaryEl")?.();
722
+ if (isHTMLElement(boundaryEl)) return resizeObserverBorderBox.observe(boundaryEl, exec);
723
+ return addDomEvent(win, "resize", exec);
724
+ },
725
+ trackPanelStack({ context, scope }) {
726
+ const unsub = subscribe(panelStack, () => {
727
+ context.set("isTopmost", panelStack.isTopmost(scope.id));
728
+ const contentEl = getContentEl(scope);
729
+ if (!contentEl) return;
730
+ const index = panelStack.indexOf(scope.id);
731
+ if (index === -1) return;
732
+ contentEl.style.setProperty("--z-index", `${index + 1}`);
733
+ });
734
+ return () => {
735
+ panelStack.remove(scope.id);
736
+ unsub();
737
+ };
738
+ }
739
+ },
740
+ actions: {
741
+ setAnchorPosition({ context, prop, scope }) {
742
+ if (prop("hasSpecifiedPosition")) return;
743
+ const hasPrevRect = context.get("prevPosition") || context.get("prevSize");
744
+ if (prop("persistRect") && hasPrevRect) return;
745
+ raf(() => {
746
+ const triggerRect = getTriggerEl(scope);
747
+ const boundaryRect = getBoundaryRect(scope, prop("getBoundaryEl")?.(), false);
748
+ let anchorPosition = prop("getAnchorPosition")?.({
749
+ triggerRect: triggerRect ? DOMRect.fromRect(getElementRect(triggerRect)) : null,
750
+ boundaryRect: DOMRect.fromRect(boundaryRect)
751
+ });
752
+ if (!anchorPosition) {
753
+ const size = context.get("size");
754
+ anchorPosition = {
755
+ x: boundaryRect.x + (boundaryRect.width - size.width) / 2,
756
+ y: boundaryRect.y + (boundaryRect.height - size.height) / 2
757
+ };
758
+ }
759
+ if (!anchorPosition) return;
760
+ context.set("position", anchorPosition);
761
+ });
762
+ },
763
+ setPrevPosition({ context, event }) {
764
+ context.set("prevPosition", { ...context.get("position") });
765
+ context.set("lastEventPosition", event.position);
766
+ },
767
+ clearPrevPosition({ context, prop }) {
768
+ if (!prop("persistRect")) context.set("prevPosition", null);
769
+ context.set("lastEventPosition", null);
770
+ },
771
+ setPosition({ context, event, prop, scope }) {
772
+ let diff = subtractPoints(event.position, context.get("lastEventPosition"));
773
+ diff.x = Math.round(diff.x / prop("gridSize")) * prop("gridSize");
774
+ diff.y = Math.round(diff.y / prop("gridSize")) * prop("gridSize");
775
+ const prevPosition = context.get("prevPosition");
776
+ if (!prevPosition) return;
777
+ let position = addPoints(prevPosition, diff);
778
+ const boundaryEl = prop("getBoundaryEl")?.();
779
+ const boundaryRect = getBoundaryRect(scope, boundaryEl, prop("allowOverflow"));
780
+ position = clampPoint(position, context.get("size"), boundaryRect);
781
+ context.set("position", position);
782
+ },
783
+ setPositionStyle({ scope, context }) {
784
+ const el = getPositionerEl(scope);
785
+ const position = context.get("position");
786
+ el?.style.setProperty("--x", `${position.x}px`);
787
+ el?.style.setProperty("--y", `${position.y}px`);
788
+ },
789
+ resetRect({ context, prop }) {
790
+ context.set("stage", "default");
791
+ if (!prop("persistRect")) {
792
+ context.set("position", context.initial("position"));
793
+ context.set("size", context.initial("size"));
794
+ }
795
+ },
796
+ setPrevSize({ context, event }) {
797
+ context.set("prevSize", { ...context.get("size") });
798
+ context.set("prevPosition", { ...context.get("position") });
799
+ context.set("lastEventPosition", event.position);
800
+ },
801
+ clearPrevSize({ context }) {
802
+ context.set("prevSize", null);
803
+ context.set("prevPosition", null);
804
+ context.set("lastEventPosition", null);
805
+ },
806
+ setSize({ context, event, scope, prop }) {
807
+ const prevSize = context.get("prevSize");
808
+ const prevPosition = context.get("prevPosition");
809
+ const lastEventPosition = context.get("lastEventPosition");
810
+ if (!prevSize || !prevPosition || !lastEventPosition) return;
811
+ const nextRect = resizeRect(createRect({
812
+ ...prevPosition,
813
+ ...prevSize
814
+ }), subtractPoints(event.position, lastEventPosition), event.axis, {
815
+ scalingOriginMode: event.altKey ? "center" : "extent",
816
+ lockAspectRatio: !!prop("lockAspectRatio") || event.shiftKey
817
+ });
818
+ let nextSize = pick(nextRect, ["width", "height"]);
819
+ let nextPosition = pick(nextRect, ["x", "y"]);
820
+ const boundaryEl = prop("getBoundaryEl")?.();
821
+ const boundaryRect = getBoundaryRect(scope, boundaryEl, false);
822
+ nextSize = clampSize(nextSize, prop("minSize"), prop("maxSize"));
823
+ nextSize = clampSize(nextSize, prop("minSize"), boundaryRect);
824
+ context.set("size", nextSize);
825
+ if (nextPosition) {
826
+ const point = clampPoint(nextPosition, nextSize, boundaryRect);
827
+ context.set("position", point);
828
+ }
829
+ },
830
+ setSizeStyle({ scope, context }) {
831
+ queueMicrotask(() => {
832
+ const el = getPositionerEl(scope);
833
+ const size = context.get("size");
834
+ el?.style.setProperty("--width", `${size.width}px`);
835
+ el?.style.setProperty("--height", `${size.height}px`);
836
+ });
837
+ },
838
+ setMaximized({ context, prop, scope }) {
839
+ context.set("stage", "maximized");
840
+ context.set("prevSize", context.get("size"));
841
+ context.set("prevPosition", context.get("position"));
842
+ const boundaryEl = prop("getBoundaryEl")?.();
843
+ const boundaryRect = getBoundaryRect(scope, boundaryEl, false);
844
+ context.set("position", pick(boundaryRect, ["x", "y"]));
845
+ context.set("size", pick(boundaryRect, ["height", "width"]));
846
+ },
847
+ setMinimized({ context, scope }) {
848
+ context.set("stage", "minimized");
849
+ context.set("prevSize", context.get("size"));
850
+ context.set("prevPosition", context.get("position"));
851
+ const headerEl = getHeaderEl(scope);
852
+ if (!headerEl) return;
853
+ const size = {
854
+ ...context.get("size"),
855
+ height: headerEl?.offsetHeight
856
+ };
857
+ context.set("size", size);
858
+ },
859
+ setRestored({ context, prop, scope }) {
860
+ const boundaryRect = getBoundaryRect(scope, prop("getBoundaryEl")?.(), false);
861
+ context.set("stage", "default");
862
+ const prevSize = context.get("prevSize");
863
+ if (prevSize) {
864
+ let nextSize = prevSize;
865
+ nextSize = clampSize(nextSize, prop("minSize"), prop("maxSize"));
866
+ nextSize = clampSize(nextSize, prop("minSize"), boundaryRect);
867
+ context.set("size", nextSize);
868
+ context.set("prevSize", null);
869
+ }
870
+ if (context.get("prevPosition")) {
871
+ let nextPosition = context.get("prevPosition");
872
+ nextPosition = clampPoint(nextPosition, context.get("size"), boundaryRect);
873
+ context.set("position", nextPosition);
874
+ context.set("prevPosition", null);
875
+ }
876
+ },
877
+ setPositionFromKeyboard({ context, event, prop, scope }) {
878
+ invariant(event.step == null, "step is required");
879
+ const position = context.get("position");
880
+ const step = event.step;
881
+ let nextPosition = match(event.direction, {
882
+ left: {
883
+ x: position.x - step,
884
+ y: position.y
885
+ },
886
+ right: {
887
+ x: position.x + step,
888
+ y: position.y
889
+ },
890
+ up: {
891
+ x: position.x,
892
+ y: position.y - step
893
+ },
894
+ down: {
895
+ x: position.x,
896
+ y: position.y + step
897
+ }
898
+ });
899
+ const boundaryEl = prop("getBoundaryEl")?.();
900
+ const boundaryRect = getBoundaryRect(scope, boundaryEl, false);
901
+ nextPosition = clampPoint(nextPosition, context.get("size"), boundaryRect);
902
+ context.set("position", nextPosition);
903
+ },
904
+ bringToFrontOfPanelStack({ prop }) {
905
+ panelStack.bringToFront(prop("id"));
906
+ },
907
+ invokeOnOpen({ prop }) {
908
+ prop("onOpenChange")?.({ open: true });
909
+ },
910
+ invokeOnClose({ prop }) {
911
+ prop("onOpenChange")?.({ open: false });
912
+ },
913
+ invokeOnDragEnd({ context, prop }) {
914
+ prop("onPositionChangeEnd")?.({ position: context.get("position") });
915
+ },
916
+ invokeOnResizeEnd({ context, prop }) {
917
+ prop("onSizeChangeEnd")?.({ size: context.get("size") });
918
+ },
919
+ focusTriggerEl({ scope }) {
920
+ raf(() => {
921
+ getTriggerEl(scope)?.focus();
922
+ });
923
+ },
924
+ focusContentEl({ scope }) {
925
+ raf(() => {
926
+ getContentEl(scope)?.focus();
927
+ });
928
+ },
929
+ toggleVisibility({ send, prop, event }) {
930
+ send({
931
+ type: prop("open") ? "CONTROLLED.OPEN" : "CONTROLLED.CLOSE",
932
+ previousEvent: event
933
+ });
934
+ }
935
+ }
936
+ }
937
+ });
938
+
939
+ //#endregion
940
+ //#region src/machines/floating-panel/floating-panel.props.ts
941
+ const props = createProps()([
942
+ "allowOverflow",
943
+ "closeOnEscape",
944
+ "defaultOpen",
945
+ "defaultPosition",
946
+ "defaultSize",
947
+ "dir",
948
+ "disabled",
949
+ "draggable",
950
+ "getAnchorPosition",
951
+ "getBoundaryEl",
952
+ "getRootNode",
953
+ "gridSize",
954
+ "id",
955
+ "ids",
956
+ "lockAspectRatio",
957
+ "maxSize",
958
+ "minSize",
959
+ "onOpenChange",
960
+ "onPositionChange",
961
+ "onPositionChangeEnd",
962
+ "onSizeChange",
963
+ "onSizeChangeEnd",
964
+ "onStageChange",
965
+ "open",
966
+ "persistRect",
967
+ "position",
968
+ "resizable",
969
+ "size",
970
+ "strategy",
971
+ "translations"
972
+ ]);
973
+ const splitProps = createSplitProps(props);
974
+ const resizeTriggerProps = createProps()(["axis"]);
975
+ const splitResizeTriggerProps = createSplitProps(resizeTriggerProps);
976
+ const resizeTriggerAxes = [
977
+ "n",
978
+ "e",
979
+ "s",
980
+ "w",
981
+ "ne",
982
+ "nw",
983
+ "se",
984
+ "sw"
985
+ ];
986
+
987
+ //#endregion
988
+ export { anatomy, connect, machine, props, resizeTriggerAxes, resizeTriggerProps, splitProps, splitResizeTriggerProps };