@vuer-ai/vuer-uikit 0.0.121 → 0.1.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 (628) hide show
  1. package/README.md +28 -0
  2. package/dist/SyncScroll/SyncScroll.cjs +4 -4
  3. package/dist/SyncScroll/SyncScroll.mjs +4 -4
  4. package/dist/SyncScroll/index.cjs +4 -4
  5. package/dist/SyncScroll/index.mjs +4 -4
  6. package/dist/SyncScroll/useSyncScroll.d.cts +5 -5
  7. package/dist/SyncScroll/useSyncScroll.d.ts +5 -5
  8. package/dist/{chunk-3SUV56TH.mjs → chunk-2IMCDH5J.mjs} +2 -2
  9. package/dist/{chunk-3P2OP4KO.mjs → chunk-2J466BYZ.mjs} +2 -1
  10. package/dist/{chunk-QF3JWGWX.cjs → chunk-2KBNQ5PY.cjs} +2 -2
  11. package/dist/{chunk-D5WTSBUX.cjs → chunk-3UQ323EB.cjs} +6 -40
  12. package/dist/{chunk-G45SP3DA.mjs → chunk-44U6VC46.mjs} +480 -62
  13. package/dist/{chunk-VW2NEQHK.cjs → chunk-4FIP3EXW.cjs} +2 -2
  14. package/dist/chunk-4SI4QV5R.cjs +14 -0
  15. package/dist/{chunk-O5YP3JQ4.mjs → chunk-4W7JKZVN.mjs} +2 -1
  16. package/dist/chunk-52GNIM6H.mjs +12 -0
  17. package/dist/{chunk-6ZLK2RYS.mjs → chunk-5GBMVMLS.mjs} +4 -4
  18. package/dist/{chunk-MMQR4IEY.cjs → chunk-753HUOAI.cjs} +6 -6
  19. package/dist/chunk-7MKCWXNV.cjs +32 -0
  20. package/dist/{chunk-ZQ2DPA2M.mjs → chunk-7WJ73FEI.mjs} +1 -1
  21. package/dist/{chunk-XMVARRN6.cjs → chunk-AFALU3AK.cjs} +2 -2
  22. package/dist/{chunk-XDIHVSZ5.cjs → chunk-BNXJ5VBE.cjs} +2 -2
  23. package/dist/{chunk-YBUMQX6M.mjs → chunk-BPCD4L7T.mjs} +1 -1
  24. package/dist/{chunk-BDFUHPX2.mjs → chunk-BTGAKK3B.mjs} +1 -1
  25. package/dist/{chunk-4G2LN6XU.cjs → chunk-BXJTOIRR.cjs} +513 -93
  26. package/dist/{chunk-B6CIRZI4.cjs → chunk-BZI74LKX.cjs} +1 -0
  27. package/dist/{chunk-KWSH253U.cjs → chunk-CMO3SLOU.cjs} +2 -2
  28. package/dist/{chunk-HGN7J4CP.mjs → chunk-D2LUQKPM.mjs} +128 -89
  29. package/dist/chunk-DF7WIFZK.cjs +316 -0
  30. package/dist/{chunk-HVACIZB5.cjs → chunk-DKLVWYTC.cjs} +29 -12
  31. package/dist/chunk-DKWLF3KW.mjs +149 -0
  32. package/dist/{chunk-4WKFVKFF.cjs → chunk-DPJPOBUT.cjs} +2 -2
  33. package/dist/{chunk-XHNM6XE3.mjs → chunk-EG6JETUN.mjs} +1 -1
  34. package/dist/{chunk-QYYMLZFE.mjs → chunk-EXM6QMNR.mjs} +1 -1
  35. package/dist/{chunk-2KQXKQNU.mjs → chunk-EYMZP5PL.mjs} +1 -1
  36. package/dist/chunk-FRM27RLN.cjs +264 -0
  37. package/dist/chunk-FTB337IJ.cjs +143 -0
  38. package/dist/{chunk-PZDC5ZKG.mjs → chunk-G35PQKU5.mjs} +3 -3
  39. package/dist/{chunk-BLG4IPRR.mjs → chunk-GAAP5JO4.mjs} +1 -1
  40. package/dist/{chunk-LOMLR5AA.mjs → chunk-HI4LO6IJ.mjs} +1 -1
  41. package/dist/{chunk-FUMJBAQI.mjs → chunk-HNW2DRPV.mjs} +2 -6
  42. package/dist/{chunk-YAFKQ5ZV.cjs → chunk-HSUL5OUG.cjs} +2 -1
  43. package/dist/{chunk-KKGDRIR2.cjs → chunk-I2COLDHC.cjs} +2 -2
  44. package/dist/{chunk-E7ACJ3NX.cjs → chunk-IAWMCOHS.cjs} +2 -2
  45. package/dist/{chunk-PC42NEBI.mjs → chunk-ITOTSGSL.mjs} +1 -1
  46. package/dist/{chunk-CEYNTMQP.mjs → chunk-IYTGWOZY.mjs} +1 -1
  47. package/dist/chunk-J74A5LNZ.cjs +179 -0
  48. package/dist/{chunk-CV2EDA3W.cjs → chunk-JDEZ6NNG.cjs} +2 -2
  49. package/dist/chunk-JEWTYDLX.cjs +119 -0
  50. package/dist/{chunk-UTHAZV2T.cjs → chunk-JTFQFULL.cjs} +2 -6
  51. package/dist/{chunk-GJKFQHUX.mjs → chunk-KXKUQSNY.mjs} +1 -1
  52. package/dist/chunk-L2AKG4VJ.mjs +258 -0
  53. package/dist/{chunk-7MR3M2HW.mjs → chunk-L2DME42Q.mjs} +1 -1
  54. package/dist/{chunk-Z7PWETGZ.mjs → chunk-LHP7FLGK.mjs} +1 -1
  55. package/dist/{chunk-LJYIEOGQ.mjs → chunk-LLFE3UHZ.mjs} +5 -5
  56. package/dist/chunk-NUBFD3YP.mjs +117 -0
  57. package/dist/{chunk-COL2MXGC.cjs → chunk-OX5FXH6W.cjs} +2 -2
  58. package/dist/{chunk-COJRGW3A.cjs → chunk-P7J7XHDE.cjs} +2 -2
  59. package/dist/chunk-PHRZ5JE6.mjs +1 -0
  60. package/dist/chunk-PMYOKSO3.mjs +30 -0
  61. package/dist/chunk-PTUZYCOY.mjs +314 -0
  62. package/dist/{chunk-WQT7JQN4.cjs → chunk-PZZW3E5D.cjs} +2 -2
  63. package/dist/chunk-Q3UN25WC.mjs +141 -0
  64. package/dist/{chunk-JVZ6J2UX.cjs → chunk-QS6WNNLM.cjs} +2 -2
  65. package/dist/{chunk-S4BL7C3Y.mjs → chunk-QSDYNIZB.mjs} +1 -0
  66. package/dist/{chunk-WYD3KNAT.cjs → chunk-QTLUPDLH.cjs} +5 -4
  67. package/dist/{chunk-NC2U7QTW.cjs → chunk-RHVKIZMQ.cjs} +2 -2
  68. package/dist/{chunk-67H3OSM3.mjs → chunk-RR76Z6OK.mjs} +2 -2
  69. package/dist/chunk-SBAVMK7J.cjs +181 -0
  70. package/dist/{chunk-GBRIW266.cjs → chunk-SOHGIAGF.cjs} +2 -2
  71. package/dist/{chunk-4YVKJKWV.mjs → chunk-TCCFFSXM.mjs} +27 -10
  72. package/dist/{chunk-EMZEL54F.cjs → chunk-THE6FZKP.cjs} +2 -0
  73. package/dist/{chunk-DGJ7E77I.mjs → chunk-TQOGGHSJ.mjs} +1 -1
  74. package/dist/{chunk-XC25ZQ7H.mjs → chunk-UBGNADCN.mjs} +1 -1
  75. package/dist/chunk-UEHPZIQB.cjs +2 -0
  76. package/dist/{chunk-DG2EVWIW.cjs → chunk-UZTOUPJ7.cjs} +128 -89
  77. package/dist/{chunk-HUPECWNG.mjs → chunk-V4THHKSO.mjs} +1 -1
  78. package/dist/chunk-VDYJAOMN.mjs +177 -0
  79. package/dist/{chunk-6NSLYQ35.mjs → chunk-VLNU7Y2K.mjs} +7 -42
  80. package/dist/{chunk-Z42BBOSG.cjs → chunk-VT6E2N6C.cjs} +2 -2
  81. package/dist/{chunk-RS4T6S3Z.mjs → chunk-VWLZKPDB.mjs} +5 -4
  82. package/dist/{chunk-OON7LFBQ.cjs → chunk-W22SQYEO.cjs} +6 -6
  83. package/dist/{chunk-42DBXENE.cjs → chunk-WGY33IHV.cjs} +2 -2
  84. package/dist/{chunk-EOTGD64D.cjs → chunk-WX3VWVWD.cjs} +2 -2
  85. package/dist/{chunk-UFYHIDMC.cjs → chunk-WZQ2BT3P.cjs} +25 -6
  86. package/dist/{chunk-KR7VBV3B.cjs → chunk-XIDCYS6G.cjs} +2 -1
  87. package/dist/chunk-YDF6VWBW.cjs +151 -0
  88. package/dist/{chunk-FB3M2JJV.cjs → chunk-YQL6JDVP.cjs} +5 -5
  89. package/dist/{chunk-7RRQ2HHL.mjs → chunk-YRNI7ZJ7.mjs} +25 -6
  90. package/dist/{chunk-FK6ZROZE.mjs → chunk-ZJYPKTF4.mjs} +2 -1
  91. package/dist/chunk-ZMRODJ3I.mjs +149 -0
  92. package/dist/dial/DialPanel.cjs +66 -56
  93. package/dist/dial/DialPanel.d.cts +4 -3
  94. package/dist/dial/DialPanel.d.ts +4 -3
  95. package/dist/dial/DialPanel.mjs +65 -55
  96. package/dist/dial/DialProvider.d.cts +3 -3
  97. package/dist/dial/DialProvider.d.ts +3 -3
  98. package/dist/dial/IconRenderer.d.cts +2 -2
  99. package/dist/dial/IconRenderer.d.ts +2 -2
  100. package/dist/dial/components/DialButton.cjs +22 -0
  101. package/dist/dial/components/DialButton.d.cts +28 -0
  102. package/dist/dial/components/DialButton.d.ts +28 -0
  103. package/dist/dial/components/DialButton.mjs +13 -0
  104. package/dist/dial/components/DialCustom.cjs +11 -0
  105. package/dist/dial/components/DialCustom.d.cts +34 -0
  106. package/dist/dial/components/DialCustom.d.ts +34 -0
  107. package/dist/dial/components/DialCustom.mjs +2 -0
  108. package/dist/dial/components/index.cjs +29 -0
  109. package/dist/dial/components/index.d.cts +4 -0
  110. package/dist/dial/components/index.d.ts +4 -0
  111. package/dist/dial/components/index.mjs +16 -0
  112. package/dist/dial/index.cjs +90 -72
  113. package/dist/dial/index.d.cts +4 -1
  114. package/dist/dial/index.d.ts +4 -1
  115. package/dist/dial/index.mjs +65 -55
  116. package/dist/dial/types.d.cts +4 -93
  117. package/dist/dial/types.d.ts +4 -93
  118. package/dist/dial/wrapped-inputs/ControlledInputs.cjs +70 -60
  119. package/dist/dial/wrapped-inputs/ControlledInputs.d.cts +7 -6
  120. package/dist/dial/wrapped-inputs/ControlledInputs.d.ts +7 -6
  121. package/dist/dial/wrapped-inputs/ControlledInputs.mjs +65 -55
  122. package/dist/{auth/components/index.cjs → dial/wrapped-inputs/DialArrayInput.cjs} +67 -57
  123. package/dist/dial/wrapped-inputs/DialArrayInput.d.cts +20 -0
  124. package/dist/dial/wrapped-inputs/DialArrayInput.d.ts +20 -0
  125. package/dist/{auth/components/index.mjs → dial/wrapped-inputs/DialArrayInput.mjs} +65 -55
  126. package/dist/dial/wrapped-inputs/DialInputs.cjs +79 -69
  127. package/dist/dial/wrapped-inputs/DialInputs.d.cts +18 -15
  128. package/dist/dial/wrapped-inputs/DialInputs.d.ts +18 -15
  129. package/dist/dial/wrapped-inputs/DialInputs.mjs +65 -55
  130. package/dist/dial/wrapped-inputs/DialInterfaceInput.cjs +66 -56
  131. package/dist/dial/wrapped-inputs/DialInterfaceInput.d.cts +7 -2
  132. package/dist/dial/wrapped-inputs/DialInterfaceInput.d.ts +7 -2
  133. package/dist/dial/wrapped-inputs/DialInterfaceInput.mjs +65 -55
  134. package/dist/dial/wrapped-inputs/DialPresetsInput.cjs +56 -49
  135. package/dist/dial/wrapped-inputs/DialPresetsInput.d.cts +3 -2
  136. package/dist/dial/wrapped-inputs/DialPresetsInput.d.ts +3 -2
  137. package/dist/dial/wrapped-inputs/DialPresetsInput.mjs +55 -48
  138. package/dist/dial/wrapped-inputs/DialTupleInput.cjs +139 -0
  139. package/dist/dial/wrapped-inputs/DialTupleInput.d.cts +18 -0
  140. package/dist/dial/wrapped-inputs/DialTupleInput.d.ts +18 -0
  141. package/dist/dial/wrapped-inputs/DialTupleInput.mjs +130 -0
  142. package/dist/dial/wrapped-inputs/DialVectorInput.cjs +66 -56
  143. package/dist/dial/wrapped-inputs/DialVectorInput.d.cts +2 -2
  144. package/dist/dial/wrapped-inputs/DialVectorInput.d.ts +2 -2
  145. package/dist/dial/wrapped-inputs/DialVectorInput.mjs +65 -55
  146. package/dist/dial/wrapped-inputs/index.cjs +94 -76
  147. package/dist/dial/wrapped-inputs/index.d.cts +3 -0
  148. package/dist/dial/wrapped-inputs/index.d.ts +3 -0
  149. package/dist/dial/wrapped-inputs/index.mjs +65 -55
  150. package/dist/highlight-cursor/cursor-context.d.cts +2 -2
  151. package/dist/highlight-cursor/cursor-context.d.ts +2 -2
  152. package/dist/highlight-cursor/cursor-provider.cjs +2 -2
  153. package/dist/highlight-cursor/cursor-provider.d.cts +1 -1
  154. package/dist/highlight-cursor/cursor-provider.d.ts +1 -1
  155. package/dist/highlight-cursor/cursor-provider.mjs +1 -1
  156. package/dist/highlight-cursor/enhanced-components.cjs +14 -14
  157. package/dist/highlight-cursor/enhanced-components.d.cts +4 -4
  158. package/dist/highlight-cursor/enhanced-components.d.ts +4 -4
  159. package/dist/highlight-cursor/enhanced-components.mjs +9 -9
  160. package/dist/highlight-cursor/index.cjs +16 -16
  161. package/dist/highlight-cursor/index.mjs +10 -10
  162. package/dist/highlight-cursor/types.d.cts +2 -1
  163. package/dist/highlight-cursor/types.d.ts +2 -1
  164. package/dist/highlight-cursor/with-cursor.d.cts +2 -2
  165. package/dist/highlight-cursor/with-cursor.d.ts +2 -2
  166. package/dist/hooks/clientOnly.d.cts +4 -4
  167. package/dist/hooks/clientOnly.d.ts +4 -4
  168. package/dist/hooks/index.cjs +20 -20
  169. package/dist/hooks/index.mjs +4 -4
  170. package/dist/index.cjs +340 -254
  171. package/dist/index.css +13 -13
  172. package/dist/index.d.cts +14 -3
  173. package/dist/index.d.ts +14 -3
  174. package/dist/index.mjs +65 -55
  175. package/dist/schema-types-D9b7Dc1G.d.cts +163 -0
  176. package/dist/schema-types-D9b7Dc1G.d.ts +163 -0
  177. package/dist/styles/theme.css +1 -1
  178. package/dist/ui/DialBadge.cjs +9 -9
  179. package/dist/ui/DialBadge.mjs +5 -5
  180. package/dist/ui/UIKitBadge.cjs +9 -9
  181. package/dist/ui/UIKitBadge.mjs +5 -5
  182. package/dist/ui/alert-dialog.cjs +60 -0
  183. package/dist/ui/alert-dialog.d.cts +17 -0
  184. package/dist/ui/alert-dialog.d.ts +17 -0
  185. package/dist/ui/alert-dialog.mjs +11 -0
  186. package/dist/ui/avatar.cjs +4 -4
  187. package/dist/ui/avatar.d.cts +2 -2
  188. package/dist/ui/avatar.d.ts +2 -2
  189. package/dist/ui/avatar.mjs +4 -4
  190. package/dist/ui/badge.cjs +7 -7
  191. package/dist/ui/badge.d.cts +2 -2
  192. package/dist/ui/badge.d.ts +2 -2
  193. package/dist/ui/badge.mjs +5 -5
  194. package/dist/ui/button.cjs +4 -4
  195. package/dist/ui/button.d.cts +2 -2
  196. package/dist/ui/button.d.ts +2 -2
  197. package/dist/ui/button.mjs +4 -4
  198. package/dist/ui/card.cjs +12 -12
  199. package/dist/ui/card.mjs +5 -5
  200. package/dist/ui/checkbox.cjs +4 -4
  201. package/dist/ui/checkbox.mjs +4 -4
  202. package/dist/ui/collapsible.cjs +4 -4
  203. package/dist/ui/collapsible.mjs +4 -4
  204. package/dist/ui/context-menu.cjs +4 -4
  205. package/dist/ui/context-menu.mjs +4 -4
  206. package/dist/ui/drag-selectable/createSelectable.d.cts +2 -2
  207. package/dist/ui/drag-selectable/createSelectable.d.ts +2 -2
  208. package/dist/ui/drawer.cjs +4 -4
  209. package/dist/ui/drawer.d.cts +11 -11
  210. package/dist/ui/drawer.d.ts +11 -11
  211. package/dist/ui/drawer.mjs +4 -4
  212. package/dist/ui/dropdown.cjs +4 -4
  213. package/dist/ui/dropdown.mjs +4 -4
  214. package/dist/ui/icons/index.cjs +9 -9
  215. package/dist/ui/icons/index.mjs +1 -1
  216. package/dist/ui/index.cjs +246 -171
  217. package/dist/ui/index.d.cts +10 -2
  218. package/dist/ui/index.d.ts +10 -2
  219. package/dist/ui/index.mjs +52 -45
  220. package/dist/ui/inputs/color-input.cjs +6 -6
  221. package/dist/ui/inputs/color-input.d.cts +7 -3
  222. package/dist/ui/inputs/color-input.d.ts +7 -3
  223. package/dist/ui/inputs/color-input.mjs +5 -5
  224. package/dist/ui/inputs/index.cjs +50 -50
  225. package/dist/ui/inputs/index.mjs +21 -21
  226. package/dist/ui/inputs/input-numbers.cjs +6 -6
  227. package/dist/ui/inputs/input-numbers.d.cts +7 -3
  228. package/dist/ui/inputs/input-numbers.d.ts +7 -3
  229. package/dist/ui/inputs/input-numbers.mjs +5 -5
  230. package/dist/ui/inputs/input.cjs +4 -4
  231. package/dist/ui/inputs/input.d.cts +4 -4
  232. package/dist/ui/inputs/input.d.ts +4 -4
  233. package/dist/ui/inputs/input.mjs +4 -4
  234. package/dist/ui/inputs/number-inputs/CmInput.cjs +7 -7
  235. package/dist/ui/inputs/number-inputs/CmInput.d.cts +2 -2
  236. package/dist/ui/inputs/number-inputs/CmInput.d.ts +2 -2
  237. package/dist/ui/inputs/number-inputs/CmInput.mjs +6 -6
  238. package/dist/ui/inputs/number-inputs/DegInput.cjs +7 -7
  239. package/dist/ui/inputs/number-inputs/DegInput.d.cts +2 -2
  240. package/dist/ui/inputs/number-inputs/DegInput.d.ts +2 -2
  241. package/dist/ui/inputs/number-inputs/DegInput.mjs +6 -6
  242. package/dist/ui/inputs/number-inputs/EulerDegInput.cjs +9 -9
  243. package/dist/ui/inputs/number-inputs/EulerDegInput.d.cts +2 -2
  244. package/dist/ui/inputs/number-inputs/EulerDegInput.d.ts +2 -2
  245. package/dist/ui/inputs/number-inputs/EulerDegInput.mjs +8 -8
  246. package/dist/ui/inputs/number-inputs/EulerInput.cjs +8 -8
  247. package/dist/ui/inputs/number-inputs/EulerInput.d.cts +2 -2
  248. package/dist/ui/inputs/number-inputs/EulerInput.d.ts +2 -2
  249. package/dist/ui/inputs/number-inputs/EulerInput.mjs +7 -7
  250. package/dist/ui/inputs/number-inputs/EulerRadInput.cjs +8 -8
  251. package/dist/ui/inputs/number-inputs/EulerRadInput.d.cts +2 -2
  252. package/dist/ui/inputs/number-inputs/EulerRadInput.d.ts +2 -2
  253. package/dist/ui/inputs/number-inputs/EulerRadInput.mjs +7 -7
  254. package/dist/ui/inputs/number-inputs/InchInput.cjs +7 -7
  255. package/dist/ui/inputs/number-inputs/InchInput.d.cts +2 -2
  256. package/dist/ui/inputs/number-inputs/InchInput.d.ts +2 -2
  257. package/dist/ui/inputs/number-inputs/InchInput.mjs +6 -6
  258. package/dist/ui/inputs/number-inputs/IntInput.cjs +7 -7
  259. package/dist/ui/inputs/number-inputs/IntInput.d.cts +2 -2
  260. package/dist/ui/inputs/number-inputs/IntInput.d.ts +2 -2
  261. package/dist/ui/inputs/number-inputs/IntInput.mjs +6 -6
  262. package/dist/ui/inputs/number-inputs/KVectorInput.cjs +8 -8
  263. package/dist/ui/inputs/number-inputs/KVectorInput.d.cts +2 -2
  264. package/dist/ui/inputs/number-inputs/KVectorInput.d.ts +2 -2
  265. package/dist/ui/inputs/number-inputs/KVectorInput.mjs +7 -7
  266. package/dist/ui/inputs/number-inputs/QuaternionInput.cjs +8 -8
  267. package/dist/ui/inputs/number-inputs/QuaternionInput.d.cts +2 -2
  268. package/dist/ui/inputs/number-inputs/QuaternionInput.d.ts +2 -2
  269. package/dist/ui/inputs/number-inputs/QuaternionInput.mjs +7 -7
  270. package/dist/ui/inputs/number-inputs/RadInput.cjs +7 -7
  271. package/dist/ui/inputs/number-inputs/RadInput.d.cts +2 -2
  272. package/dist/ui/inputs/number-inputs/RadInput.d.ts +2 -2
  273. package/dist/ui/inputs/number-inputs/RadInput.mjs +6 -6
  274. package/dist/ui/inputs/number-inputs/TimeInput.cjs +7 -7
  275. package/dist/ui/inputs/number-inputs/TimeInput.d.cts +2 -2
  276. package/dist/ui/inputs/number-inputs/TimeInput.d.ts +2 -2
  277. package/dist/ui/inputs/number-inputs/TimeInput.mjs +6 -6
  278. package/dist/ui/inputs/number-inputs/Vec3Input.cjs +8 -8
  279. package/dist/ui/inputs/number-inputs/Vec3Input.d.cts +2 -2
  280. package/dist/ui/inputs/number-inputs/Vec3Input.d.ts +2 -2
  281. package/dist/ui/inputs/number-inputs/Vec3Input.mjs +7 -7
  282. package/dist/ui/inputs/number-inputs/VectorInput.cjs +7 -7
  283. package/dist/ui/inputs/number-inputs/VectorInput.d.cts +4 -2
  284. package/dist/ui/inputs/number-inputs/VectorInput.d.ts +4 -2
  285. package/dist/ui/inputs/number-inputs/VectorInput.mjs +6 -6
  286. package/dist/ui/inputs/number-inputs/index.cjs +41 -41
  287. package/dist/ui/inputs/number-inputs/index.mjs +18 -18
  288. package/dist/ui/inputs/presets-input.cjs +7 -7
  289. package/dist/ui/inputs/presets-input.d.cts +2 -2
  290. package/dist/ui/inputs/presets-input.d.ts +2 -2
  291. package/dist/ui/inputs/presets-input.mjs +6 -6
  292. package/dist/ui/inputs/presets-rad-input.cjs +8 -8
  293. package/dist/ui/inputs/presets-rad-input.d.cts +2 -2
  294. package/dist/ui/inputs/presets-rad-input.d.ts +2 -2
  295. package/dist/ui/inputs/presets-rad-input.mjs +7 -7
  296. package/dist/ui/inputs/text-input.cjs +4 -4
  297. package/dist/ui/inputs/text-input.d.cts +2 -2
  298. package/dist/ui/inputs/text-input.d.ts +2 -2
  299. package/dist/ui/inputs/text-input.mjs +4 -4
  300. package/dist/ui/label.cjs +4 -4
  301. package/dist/ui/label.d.cts +4 -4
  302. package/dist/ui/label.d.ts +4 -4
  303. package/dist/ui/label.mjs +4 -4
  304. package/dist/ui/layout.cjs +4 -4
  305. package/dist/ui/layout.mjs +4 -4
  306. package/dist/ui/layouts/dock-layout/DockLayoutView.cjs +4 -4
  307. package/dist/ui/layouts/dock-layout/DockLayoutView.mjs +4 -4
  308. package/dist/ui/layouts/dock-layout/LayoutSlots.cjs +4 -4
  309. package/dist/ui/layouts/dock-layout/LayoutSlots.d.cts +3 -3
  310. package/dist/ui/layouts/dock-layout/LayoutSlots.d.ts +3 -3
  311. package/dist/ui/layouts/dock-layout/LayoutSlots.mjs +4 -4
  312. package/dist/ui/layouts/dock-layout/index.cjs +4 -4
  313. package/dist/ui/layouts/dock-layout/index.mjs +4 -4
  314. package/dist/ui/layouts/index.cjs +5 -5
  315. package/dist/ui/layouts/index.mjs +5 -5
  316. package/dist/ui/layouts/liquid-layout/LayoutSlots.cjs +4 -4
  317. package/dist/ui/layouts/liquid-layout/LayoutSlots.mjs +4 -4
  318. package/dist/ui/layouts/liquid-layout/LiquidLayoutView.cjs +4 -4
  319. package/dist/ui/layouts/liquid-layout/LiquidLayoutView.mjs +4 -4
  320. package/dist/ui/layouts/liquid-layout/index.cjs +4 -4
  321. package/dist/ui/layouts/liquid-layout/index.mjs +4 -4
  322. package/dist/ui/modal.cjs +4 -4
  323. package/dist/ui/modal.mjs +4 -4
  324. package/dist/ui/navigation.cjs +4 -4
  325. package/dist/ui/navigation.d.cts +2 -2
  326. package/dist/ui/navigation.d.ts +2 -2
  327. package/dist/ui/navigation.mjs +4 -4
  328. package/dist/ui/pagination.cjs +4 -4
  329. package/dist/ui/pagination.mjs +4 -4
  330. package/dist/ui/popover.cjs +13 -9
  331. package/dist/ui/popover.d.cts +18 -8
  332. package/dist/ui/popover.d.ts +18 -8
  333. package/dist/ui/popover.mjs +5 -5
  334. package/dist/ui/progress.cjs +4 -4
  335. package/dist/ui/progress.mjs +4 -4
  336. package/dist/ui/radio-group.cjs +4 -4
  337. package/dist/ui/radio-group.mjs +4 -4
  338. package/dist/ui/resizable.cjs +4 -4
  339. package/dist/ui/resizable.d.cts +2 -2
  340. package/dist/ui/resizable.d.ts +2 -2
  341. package/dist/ui/resizable.mjs +4 -4
  342. package/dist/ui/select.cjs +16 -16
  343. package/dist/ui/select.d.cts +3 -2
  344. package/dist/ui/select.d.ts +3 -2
  345. package/dist/ui/select.mjs +5 -5
  346. package/dist/ui/separator.cjs +4 -4
  347. package/dist/ui/separator.mjs +4 -4
  348. package/dist/ui/sheet.cjs +4 -4
  349. package/dist/ui/sheet.mjs +4 -4
  350. package/dist/ui/sidebar.cjs +4 -4
  351. package/dist/ui/sidebar.mjs +4 -4
  352. package/dist/ui/simple-tree-view.cjs +4 -4
  353. package/dist/ui/simple-tree-view.d.cts +2 -2
  354. package/dist/ui/simple-tree-view.d.ts +2 -2
  355. package/dist/ui/simple-tree-view.mjs +4 -4
  356. package/dist/ui/skeleton.cjs +4 -4
  357. package/dist/ui/skeleton.mjs +4 -4
  358. package/dist/ui/slider.cjs +4 -4
  359. package/dist/ui/slider.d.cts +2 -2
  360. package/dist/ui/slider.d.ts +2 -2
  361. package/dist/ui/slider.mjs +4 -4
  362. package/dist/ui/switch.cjs +6 -6
  363. package/dist/ui/switch.d.cts +4 -1
  364. package/dist/ui/switch.d.ts +4 -1
  365. package/dist/ui/switch.mjs +5 -5
  366. package/dist/ui/table.cjs +4 -4
  367. package/dist/ui/table.d.cts +9 -9
  368. package/dist/ui/table.d.ts +9 -9
  369. package/dist/ui/table.mjs +4 -4
  370. package/dist/ui/tabs.cjs +13 -9
  371. package/dist/ui/tabs.d.cts +4 -1
  372. package/dist/ui/tabs.d.ts +4 -1
  373. package/dist/ui/tabs.mjs +5 -5
  374. package/dist/ui/textarea.cjs +4 -4
  375. package/dist/ui/textarea.d.cts +1 -1
  376. package/dist/ui/textarea.d.ts +1 -1
  377. package/dist/ui/textarea.mjs +4 -4
  378. package/dist/ui/theme/ThemeProvider.cjs +15 -15
  379. package/dist/ui/theme/ThemeProvider.d.cts +2 -2
  380. package/dist/ui/theme/ThemeProvider.d.ts +2 -2
  381. package/dist/ui/theme/ThemeProvider.mjs +1 -1
  382. package/dist/ui/theme/ThemeToggles.cjs +8 -8
  383. package/dist/ui/theme/ThemeToggles.d.cts +18 -3
  384. package/dist/ui/theme/ThemeToggles.d.ts +18 -3
  385. package/dist/ui/theme/ThemeToggles.mjs +6 -6
  386. package/dist/ui/theme/index.cjs +12 -12
  387. package/dist/ui/theme/index.mjs +6 -6
  388. package/dist/ui/theme/themeScript.d.cts +2 -2
  389. package/dist/ui/theme/themeScript.d.ts +2 -2
  390. package/dist/ui/toast.cjs +9 -9
  391. package/dist/ui/toast.mjs +7 -7
  392. package/dist/ui/toggle-buttons.cjs +4 -4
  393. package/dist/ui/toggle-buttons.d.cts +7 -7
  394. package/dist/ui/toggle-buttons.d.ts +7 -7
  395. package/dist/ui/toggle-buttons.mjs +4 -4
  396. package/dist/ui/toggle-group.cjs +4 -4
  397. package/dist/ui/toggle-group.d.cts +3 -3
  398. package/dist/ui/toggle-group.d.ts +3 -3
  399. package/dist/ui/toggle-group.mjs +4 -4
  400. package/dist/ui/toggle.cjs +4 -4
  401. package/dist/ui/toggle.mjs +4 -4
  402. package/dist/ui/toolbar.cjs +4 -4
  403. package/dist/ui/toolbar.mjs +4 -4
  404. package/dist/ui/tooltip.cjs +4 -4
  405. package/dist/ui/tooltip.mjs +4 -4
  406. package/dist/ui/tree-view/TreeSearchBar.cjs +4 -4
  407. package/dist/ui/tree-view/TreeSearchBar.mjs +4 -4
  408. package/dist/ui/tree-view/TreeView.cjs +7 -7
  409. package/dist/ui/tree-view/TreeView.mjs +5 -5
  410. package/dist/ui/tree-view/index.cjs +12 -12
  411. package/dist/ui/tree-view/index.mjs +6 -6
  412. package/dist/ui/tree-view/types.d.cts +1 -0
  413. package/dist/ui/tree-view/types.d.ts +1 -0
  414. package/dist/ui/tree-view-legacy.cjs +4 -4
  415. package/dist/ui/tree-view-legacy.mjs +4 -4
  416. package/dist/ui/virtual-grid/VirtualGrid.cjs +21 -0
  417. package/dist/ui/virtual-grid/VirtualGrid.d.cts +10 -0
  418. package/dist/ui/virtual-grid/VirtualGrid.d.ts +10 -0
  419. package/dist/ui/virtual-grid/VirtualGrid.mjs +12 -0
  420. package/dist/ui/virtual-grid/index.cjs +26 -0
  421. package/dist/ui/virtual-grid/index.d.cts +4 -0
  422. package/dist/ui/virtual-grid/index.d.ts +4 -0
  423. package/dist/ui/virtual-grid/index.mjs +13 -0
  424. package/dist/ui/virtual-grid/types.cjs +2 -0
  425. package/dist/ui/virtual-grid/types.d.cts +70 -0
  426. package/dist/ui/virtual-grid/types.d.ts +70 -0
  427. package/dist/ui/virtual-grid/types.mjs +1 -0
  428. package/dist/ui/virtual-grid/useVirtualGrid.cjs +10 -0
  429. package/dist/ui/virtual-grid/useVirtualGrid.d.cts +9 -0
  430. package/dist/ui/virtual-grid/useVirtualGrid.d.ts +9 -0
  431. package/dist/ui/virtual-grid/useVirtualGrid.mjs +1 -0
  432. package/dist/ui/virtual-list/VirtualList.cjs +21 -0
  433. package/dist/ui/virtual-list/VirtualList.d.cts +10 -0
  434. package/dist/ui/virtual-list/VirtualList.d.ts +10 -0
  435. package/dist/ui/virtual-list/VirtualList.mjs +12 -0
  436. package/dist/ui/virtual-list/index.cjs +26 -0
  437. package/dist/ui/virtual-list/index.d.cts +4 -0
  438. package/dist/ui/virtual-list/index.d.ts +4 -0
  439. package/dist/ui/virtual-list/index.mjs +13 -0
  440. package/dist/ui/virtual-list/types.cjs +2 -0
  441. package/dist/ui/virtual-list/types.d.cts +54 -0
  442. package/dist/ui/virtual-list/types.d.ts +54 -0
  443. package/dist/ui/virtual-list/types.mjs +1 -0
  444. package/dist/ui/virtual-list/useVirtualList.cjs +10 -0
  445. package/dist/ui/virtual-list/useVirtualList.d.cts +9 -0
  446. package/dist/ui/virtual-list/useVirtualList.d.ts +9 -0
  447. package/dist/ui/virtual-list/useVirtualList.mjs +1 -0
  448. package/dist/ui/waterfall/CursorOverlay.cjs +4 -4
  449. package/dist/ui/waterfall/CursorOverlay.mjs +4 -4
  450. package/dist/ui/waterfall/NavigationControls.d.cts +2 -2
  451. package/dist/ui/waterfall/NavigationControls.d.ts +2 -2
  452. package/dist/ui/waterfall/TimelineEvent.cjs +4 -4
  453. package/dist/ui/waterfall/TimelineEvent.mjs +4 -4
  454. package/dist/ui/waterfall/TimelineProcessBar.cjs +4 -4
  455. package/dist/ui/waterfall/TimelineProcessBar.mjs +4 -4
  456. package/dist/ui/waterfall/Wedges.cjs +4 -4
  457. package/dist/ui/waterfall/Wedges.mjs +4 -4
  458. package/dist/ui/waterfall/WheelZoomContext.d.cts +2 -2
  459. package/dist/ui/waterfall/WheelZoomContext.d.ts +2 -2
  460. package/dist/ui/waterfall/hooks/useTimelineState.d.cts +4 -3
  461. package/dist/ui/waterfall/hooks/useTimelineState.d.ts +4 -3
  462. package/dist/ui/waterfall/hooks/useViewport.d.cts +4 -4
  463. package/dist/ui/waterfall/hooks/useViewport.d.ts +4 -4
  464. package/dist/ui/waterfall/index.cjs +13 -13
  465. package/dist/ui/waterfall/index.d.cts +2 -2
  466. package/dist/ui/waterfall/index.d.ts +2 -2
  467. package/dist/ui/waterfall/index.mjs +12 -12
  468. package/package.json +5 -9
  469. package/src/dial/DialPanel.tsx +118 -6
  470. package/src/dial/components/DialButton.tsx +52 -0
  471. package/src/dial/components/DialCustom.tsx +45 -0
  472. package/src/dial/components/index.ts +3 -0
  473. package/src/dial/index.ts +4 -1
  474. package/src/dial/types.ts +4 -12
  475. package/src/dial/wrapped-inputs/ControlledInputs.tsx +16 -11
  476. package/src/dial/wrapped-inputs/DialArrayInput.tsx +175 -0
  477. package/src/dial/wrapped-inputs/DialInputs.tsx +117 -22
  478. package/src/dial/wrapped-inputs/DialInterfaceInput.tsx +48 -12
  479. package/src/dial/wrapped-inputs/DialPresetsInput.tsx +1 -1
  480. package/src/dial/wrapped-inputs/DialTupleInput.tsx +102 -0
  481. package/src/dial/wrapped-inputs/DialVectorInput.tsx +9 -4
  482. package/src/dial/wrapped-inputs/index.ts +6 -0
  483. package/src/highlight-cursor/cursor-provider.tsx +279 -131
  484. package/src/highlight-cursor/types.ts +2 -1
  485. package/src/styles/theme.css +2 -2
  486. package/src/ui/alert-dialog.tsx +168 -0
  487. package/src/ui/badge.tsx +1 -0
  488. package/src/ui/card.tsx +1 -5
  489. package/src/ui/index.ts +4 -0
  490. package/src/ui/inputs/color-input.tsx +92 -8
  491. package/src/ui/inputs/input-numbers.tsx +148 -92
  492. package/src/ui/inputs/number-inputs/VectorInput.tsx +2 -0
  493. package/src/ui/popover.tsx +10 -49
  494. package/src/ui/select.tsx +5 -2
  495. package/src/ui/switch.tsx +7 -2
  496. package/src/ui/tabs.tsx +2 -1
  497. package/src/ui/theme/ThemeProvider.tsx +4 -3
  498. package/src/ui/theme/ThemeToggles.tsx +48 -12
  499. package/src/ui/toast.tsx +1 -3
  500. package/src/ui/tree-view/TreeView.tsx +37 -8
  501. package/src/ui/tree-view/types.ts +1 -0
  502. package/src/ui/virtual-grid/VirtualGrid.tsx +345 -0
  503. package/src/ui/virtual-grid/index.ts +10 -0
  504. package/src/ui/virtual-grid/types.ts +72 -0
  505. package/src/ui/virtual-grid/useVirtualGrid.ts +243 -0
  506. package/src/ui/virtual-list/VirtualList.tsx +207 -0
  507. package/src/ui/virtual-list/index.ts +8 -0
  508. package/src/ui/virtual-list/types.ts +54 -0
  509. package/src/ui/virtual-list/useVirtualList.ts +203 -0
  510. package/dist/auth/components/index.d.cts +0 -2
  511. package/dist/auth/components/index.d.ts +0 -2
  512. package/dist/auth/components/user-avatar/index.cjs +0 -128
  513. package/dist/auth/components/user-avatar/index.d.cts +0 -8
  514. package/dist/auth/components/user-avatar/index.d.ts +0 -8
  515. package/dist/auth/components/user-avatar/index.mjs +0 -119
  516. package/dist/auth/context/user-context.cjs +0 -10
  517. package/dist/auth/context/user-context.d.cts +0 -13
  518. package/dist/auth/context/user-context.d.ts +0 -13
  519. package/dist/auth/context/user-context.mjs +0 -1
  520. package/dist/auth/handler/fetch-auth.cjs +0 -11
  521. package/dist/auth/handler/fetch-auth.d.cts +0 -3
  522. package/dist/auth/handler/fetch-auth.d.ts +0 -3
  523. package/dist/auth/handler/fetch-auth.mjs +0 -2
  524. package/dist/auth/handler/fetch-server.cjs +0 -11
  525. package/dist/auth/handler/fetch-server.d.cts +0 -3
  526. package/dist/auth/handler/fetch-server.d.ts +0 -3
  527. package/dist/auth/handler/fetch-server.mjs +0 -2
  528. package/dist/auth/handler/get-session.cjs +0 -12
  529. package/dist/auth/handler/get-session.d.cts +0 -21
  530. package/dist/auth/handler/get-session.d.ts +0 -21
  531. package/dist/auth/handler/get-session.mjs +0 -3
  532. package/dist/auth/handler/get-sessions.cjs +0 -12
  533. package/dist/auth/handler/get-sessions.d.cts +0 -21
  534. package/dist/auth/handler/get-sessions.d.ts +0 -21
  535. package/dist/auth/handler/get-sessions.mjs +0 -3
  536. package/dist/auth/handler/sign-in-handler.cjs +0 -11
  537. package/dist/auth/handler/sign-in-handler.d.cts +0 -6
  538. package/dist/auth/handler/sign-in-handler.d.ts +0 -6
  539. package/dist/auth/handler/sign-in-handler.mjs +0 -2
  540. package/dist/auth/handler/sign-out-handler.cjs +0 -12
  541. package/dist/auth/handler/sign-out-handler.d.cts +0 -5
  542. package/dist/auth/handler/sign-out-handler.d.ts +0 -5
  543. package/dist/auth/handler/sign-out-handler.mjs +0 -3
  544. package/dist/auth/hooks/use-sign-in.cjs +0 -14
  545. package/dist/auth/hooks/use-sign-in.d.cts +0 -9
  546. package/dist/auth/hooks/use-sign-in.d.ts +0 -9
  547. package/dist/auth/hooks/use-sign-in.mjs +0 -5
  548. package/dist/auth/hooks/use-sign-out.cjs +0 -15
  549. package/dist/auth/hooks/use-sign-out.d.cts +0 -6
  550. package/dist/auth/hooks/use-sign-out.d.ts +0 -6
  551. package/dist/auth/hooks/use-sign-out.mjs +0 -6
  552. package/dist/auth/hooks/use-user.cjs +0 -11
  553. package/dist/auth/hooks/use-user.d.cts +0 -8
  554. package/dist/auth/hooks/use-user.d.ts +0 -8
  555. package/dist/auth/hooks/use-user.mjs +0 -2
  556. package/dist/auth/hooks/use-vuer-sessions.cjs +0 -15
  557. package/dist/auth/hooks/use-vuer-sessions.d.cts +0 -9
  558. package/dist/auth/hooks/use-vuer-sessions.d.ts +0 -9
  559. package/dist/auth/hooks/use-vuer-sessions.mjs +0 -6
  560. package/dist/auth/index.cjs +0 -166
  561. package/dist/auth/index.d.cts +0 -13
  562. package/dist/auth/index.d.ts +0 -13
  563. package/dist/auth/index.mjs +0 -125
  564. package/dist/auth/localstorage-key.cjs +0 -14
  565. package/dist/auth/localstorage-key.d.cts +0 -4
  566. package/dist/auth/localstorage-key.d.ts +0 -4
  567. package/dist/auth/localstorage-key.mjs +0 -1
  568. package/dist/auth/types.d.cts +0 -27
  569. package/dist/auth/types.d.ts +0 -27
  570. package/dist/auth/vuer-user-provider.cjs +0 -14
  571. package/dist/auth/vuer-user-provider.d.cts +0 -9
  572. package/dist/auth/vuer-user-provider.d.ts +0 -9
  573. package/dist/auth/vuer-user-provider.mjs +0 -5
  574. package/dist/chunk-2DXJJLJL.mjs +0 -51
  575. package/dist/chunk-3WMO5QJJ.cjs +0 -8
  576. package/dist/chunk-4TRHQ7MJ.cjs +0 -68
  577. package/dist/chunk-5OHAV55L.mjs +0 -24
  578. package/dist/chunk-6GJM7TPE.cjs +0 -28
  579. package/dist/chunk-7E5Y224I.cjs +0 -14
  580. package/dist/chunk-7R5HY3IM.cjs +0 -12
  581. package/dist/chunk-C4U5BMQH.mjs +0 -206
  582. package/dist/chunk-EMVKGL5D.mjs +0 -28
  583. package/dist/chunk-EMXEFZEB.cjs +0 -30
  584. package/dist/chunk-F4Z5KATZ.cjs +0 -8
  585. package/dist/chunk-FROQ45MN.mjs +0 -6
  586. package/dist/chunk-HOMAESTR.mjs +0 -12
  587. package/dist/chunk-HZBP6QTE.cjs +0 -208
  588. package/dist/chunk-IKSER6BF.mjs +0 -66
  589. package/dist/chunk-KIZEJMW4.cjs +0 -15
  590. package/dist/chunk-MO5V43Z3.mjs +0 -13
  591. package/dist/chunk-MRMSCW3P.cjs +0 -19
  592. package/dist/chunk-OOHCJIRV.cjs +0 -26
  593. package/dist/chunk-PX2H7Z4D.mjs +0 -26
  594. package/dist/chunk-PXDT5GFJ.mjs +0 -13
  595. package/dist/chunk-Q76WU4DL.cjs +0 -17
  596. package/dist/chunk-RSBVQ7SJ.cjs +0 -54
  597. package/dist/chunk-RTZNHV43.cjs +0 -58
  598. package/dist/chunk-SO2UTKSV.mjs +0 -17
  599. package/dist/chunk-SQJL67BU.mjs +0 -56
  600. package/dist/chunk-UT7B4TLZ.mjs +0 -5
  601. package/dist/chunk-V4KDK3BN.mjs +0 -52
  602. package/dist/chunk-VSFPXAGN.mjs +0 -10
  603. package/dist/chunk-VSIOXWSI.cjs +0 -53
  604. package/dist/chunk-X3H6FYAM.cjs +0 -15
  605. package/dist/chunk-Z7BZFZEV.mjs +0 -15
  606. package/src/auth/components/index.ts +0 -1
  607. package/src/auth/components/user-avatar/index.tsx +0 -94
  608. package/src/auth/context/user-context.ts +0 -15
  609. package/src/auth/handler/fetch-auth.ts +0 -10
  610. package/src/auth/handler/fetch-server.ts +0 -10
  611. package/src/auth/handler/get-session.ts +0 -19
  612. package/src/auth/handler/get-sessions.ts +0 -16
  613. package/src/auth/handler/sign-in-handler.ts +0 -64
  614. package/src/auth/handler/sign-out-handler.ts +0 -9
  615. package/src/auth/hooks/use-sign-in.ts +0 -33
  616. package/src/auth/hooks/use-sign-out.ts +0 -30
  617. package/src/auth/hooks/use-user.ts +0 -10
  618. package/src/auth/hooks/use-vuer-sessions.ts +0 -29
  619. package/src/auth/index.ts +0 -12
  620. package/src/auth/localstorage-key.ts +0 -3
  621. package/src/auth/types.ts +0 -38
  622. package/src/auth/vuer-user-provider.tsx +0 -58
  623. /package/dist/{auth/types.mjs → chunk-6NZ5VXK7.mjs} +0 -0
  624. /package/dist/{auth/types.cjs → chunk-AS3GNGJN.cjs} +0 -0
  625. /package/dist/{chunk-NK7L5H2Y.cjs → chunk-DPILGC4Y.cjs} +0 -0
  626. /package/dist/{chunk-OBWKFURE.cjs → chunk-IM5QVMGO.cjs} +0 -0
  627. /package/dist/{chunk-U4AANBRZ.mjs → chunk-NU5W73NH.mjs} +0 -0
  628. /package/dist/{chunk-UXWS62ZO.mjs → chunk-O57DAVOQ.mjs} +0 -0
@@ -5,247 +5,395 @@ import { CursorContext } from "./cursor-context";
5
5
  import type { CursorProviderProps } from "./types";
6
6
  import { cn } from "../hooks/cn";
7
7
 
8
+ // Spring physics configuration
9
+ const SPRING_CONFIG = {
10
+ stiffness: 0.15, // How snappy (higher = faster)
11
+ damping: 0.75, // How bouncy (lower = more bounce, 1 = no bounce)
12
+ mass: 1,
13
+ };
14
+
15
+ // Squish configuration
16
+ const SQUISH_CONFIG = {
17
+ maxSquish: 0.15, // Maximum squish amount (0.15 = 15% squish)
18
+ velocityScale: 0.008, // How much velocity affects squish
19
+ recovery: 0.15, // How fast squish recovers
20
+ };
21
+
22
+ interface SpringState {
23
+ x: number;
24
+ y: number;
25
+ width: number;
26
+ height: number;
27
+ velocityX: number;
28
+ velocityY: number;
29
+ velocityW: number;
30
+ velocityH: number;
31
+ scaleX: number;
32
+ scaleY: number;
33
+ }
34
+
8
35
  export const CursorProvider = ({
9
36
  children,
10
37
  maxOffsetX = 5,
11
38
  maxOffsetY = 20,
12
39
  cursorSize = 20,
13
- transitionDuration = 100,
40
+ boundaryThreshold = 4,
41
+ outerThreshold = 8,
14
42
  cursorClassName,
15
43
  className,
16
44
  as: Component = "div",
17
45
  ...props
18
46
  }: CursorProviderProps) => {
19
- // Check if we're in a browser environment
20
47
  const [isClient, setIsClient] = useState(false);
21
48
  const [isMouseInside, setIsMouseInside] = useState(false);
22
- const [mousePosition, setMousePosition] = useState({ x: 0, y: 0 });
23
- const [hoveredElementId, setHoveredElementId] = useState<string | null>(null);
24
- const [elementDimensions, setElementDimensions] = useState({
25
- width: 0,
26
- height: 0,
49
+
50
+ // Refs for high-frequency updates
51
+ const cursorRef = useRef<HTMLDivElement>(null);
52
+ const cursorInnerRef = useRef<HTMLDivElement>(null);
53
+ const mousePositionRef = useRef({ x: 0, y: 0 });
54
+ const prevMousePositionRef = useRef({ x: 0, y: 0 });
55
+ const hoveredElementIdRef = useRef<string | null>(null);
56
+ const hoveredElementRef = useRef<HTMLElement | null>(null);
57
+ const elementDimensionsRef = useRef({ width: 0, height: 0, x: 0, y: 0, right: 0, bottom: 0 });
58
+ const elementBorderRadiusRef = useRef<string>("9999px");
59
+ const animationFrameRef = useRef<number | null>(null);
60
+
61
+ // Spring animation state
62
+ const springRef = useRef<SpringState>({
27
63
  x: 0,
28
64
  y: 0,
29
- right: 0,
30
- bottom: 0,
65
+ width: cursorSize,
66
+ height: cursorSize,
67
+ velocityX: 0,
68
+ velocityY: 0,
69
+ velocityW: 0,
70
+ velocityH: 0,
71
+ scaleX: 1,
72
+ scaleY: 1,
31
73
  });
32
74
 
33
- const hoveredElementRef = useRef<HTMLElement | null>(null);
75
+ // Target state (where we want the cursor to be)
76
+ const targetRef = useRef({
77
+ x: 0,
78
+ y: 0,
79
+ width: cursorSize,
80
+ height: cursorSize,
81
+ });
82
+
83
+ const [hoveredElementId, setHoveredElementId] = useState<string | null>(null);
34
84
 
35
- // Set isClient to true after component mounts (client-side only)
36
85
  useEffect(() => {
37
86
  setIsClient(true);
38
87
  }, []);
39
88
 
89
+ // Calculate target position and size based on current state
90
+ const updateTarget = useCallback(() => {
91
+ const mouse = mousePositionRef.current;
92
+ const dims = elementDimensionsRef.current;
93
+ const isHovering = hoveredElementIdRef.current !== null;
94
+
95
+ if (isHovering && dims.width > 0) {
96
+ // Calculate distance from each edge (negative = outside)
97
+ const distFromLeft = mouse.x - dims.x;
98
+ const distFromRight = dims.x + dims.width - mouse.x;
99
+ const distFromTop = mouse.y - dims.y;
100
+ const distFromBottom = dims.y + dims.height - mouse.y;
101
+
102
+ // Total threshold zone = inner boundary + outer threshold
103
+ const totalThreshold = boundaryThreshold + outerThreshold;
104
+
105
+ let offsetX = 0;
106
+ let offsetY = 0;
107
+
108
+ // Left side: inside near edge or outside within threshold
109
+ if (distFromLeft < boundaryThreshold) {
110
+ // Map from boundaryThreshold (inside) to -outerThreshold (outside) -> 0 to maxOffset
111
+ const progress = Math.min(1, (boundaryThreshold - distFromLeft) / totalThreshold);
112
+ offsetX = -maxOffsetX * progress;
113
+ }
114
+ // Right side
115
+ else if (distFromRight < boundaryThreshold) {
116
+ const progress = Math.min(1, (boundaryThreshold - distFromRight) / totalThreshold);
117
+ offsetX = maxOffsetX * progress;
118
+ }
119
+
120
+ // Top side
121
+ if (distFromTop < boundaryThreshold) {
122
+ const progress = Math.min(1, (boundaryThreshold - distFromTop) / totalThreshold);
123
+ offsetY = -maxOffsetY * progress;
124
+ }
125
+ // Bottom side
126
+ else if (distFromBottom < boundaryThreshold) {
127
+ const progress = Math.min(1, (boundaryThreshold - distFromBottom) / totalThreshold);
128
+ offsetY = maxOffsetY * progress;
129
+ }
130
+
131
+ targetRef.current = {
132
+ x: dims.x + offsetX,
133
+ y: dims.y + offsetY,
134
+ width: dims.width,
135
+ height: dims.height,
136
+ };
137
+ } else {
138
+ // Follow mouse as a dot
139
+ targetRef.current = {
140
+ x: mouse.x - cursorSize / 2,
141
+ y: mouse.y - cursorSize / 2,
142
+ width: cursorSize,
143
+ height: cursorSize,
144
+ };
145
+ }
146
+ }, [cursorSize, maxOffsetX, maxOffsetY, boundaryThreshold, outerThreshold]);
147
+
148
+ // Animation loop with spring physics
149
+ const animate = useCallback(() => {
150
+ const cursor = cursorRef.current;
151
+ const cursorInner = cursorInnerRef.current;
152
+ if (!cursor || !cursorInner) {
153
+ animationFrameRef.current = requestAnimationFrame(animate);
154
+ return;
155
+ }
156
+
157
+ const spring = springRef.current;
158
+ const target = targetRef.current;
159
+ const { stiffness, damping } = SPRING_CONFIG;
160
+
161
+ // Calculate mouse velocity for squish effect
162
+ const mouse = mousePositionRef.current;
163
+ const prevMouse = prevMousePositionRef.current;
164
+ const mouseVelocityX = mouse.x - prevMouse.x;
165
+ const mouseVelocityY = mouse.y - prevMouse.y;
166
+ prevMousePositionRef.current = { ...mouse };
167
+
168
+ // Spring physics for position
169
+ const forceX = (target.x - spring.x) * stiffness;
170
+ const forceY = (target.y - spring.y) * stiffness;
171
+ spring.velocityX = (spring.velocityX + forceX) * damping;
172
+ spring.velocityY = (spring.velocityY + forceY) * damping;
173
+ spring.x += spring.velocityX;
174
+ spring.y += spring.velocityY;
175
+
176
+ // Spring physics for size
177
+ const forceW = (target.width - spring.width) * stiffness;
178
+ const forceH = (target.height - spring.height) * stiffness;
179
+ spring.velocityW = (spring.velocityW + forceW) * damping;
180
+ spring.velocityH = (spring.velocityH + forceH) * damping;
181
+ spring.width += spring.velocityW;
182
+ spring.height += spring.velocityH;
183
+
184
+ // Squish effect based on velocity
185
+ // Moving horizontally -> squish vertically (and vice versa)
186
+ const targetScaleX = 1 - Math.abs(mouseVelocityY) * SQUISH_CONFIG.velocityScale;
187
+ const targetScaleY = 1 - Math.abs(mouseVelocityX) * SQUISH_CONFIG.velocityScale;
188
+
189
+ // Clamp squish and smoothly interpolate
190
+ const clampedTargetScaleX = Math.max(1 - SQUISH_CONFIG.maxSquish, Math.min(1, targetScaleX));
191
+ const clampedTargetScaleY = Math.max(1 - SQUISH_CONFIG.maxSquish, Math.min(1, targetScaleY));
192
+
193
+ spring.scaleX += (clampedTargetScaleX - spring.scaleX) * SQUISH_CONFIG.recovery;
194
+ spring.scaleY += (clampedTargetScaleY - spring.scaleY) * SQUISH_CONFIG.recovery;
195
+
196
+ // Also add squish from spring velocity (bouncing)
197
+ const bounceSquishX = 1 - Math.abs(spring.velocityY) * 0.02;
198
+ const bounceSquishY = 1 - Math.abs(spring.velocityX) * 0.02;
199
+ const finalScaleX = Math.max(0.85, spring.scaleX * bounceSquishX);
200
+ const finalScaleY = Math.max(0.85, spring.scaleY * bounceSquishY);
201
+
202
+ // Apply to DOM
203
+ cursor.style.transform = `translate3d(${spring.x}px, ${spring.y}px, 0)`;
204
+ cursor.style.width = `${spring.width}px`;
205
+ cursor.style.height = `${spring.height}px`;
206
+
207
+ // Apply squish to inner element
208
+ cursorInner.style.transform = `scale(${finalScaleX}, ${finalScaleY})`;
209
+
210
+ // Update border radius based on hover state - use target element's radius
211
+ const isHovering = hoveredElementIdRef.current !== null;
212
+ if (isHovering) {
213
+ cursorInner.style.borderRadius = elementBorderRadiusRef.current;
214
+ } else {
215
+ cursorInner.style.borderRadius = "9999px";
216
+ }
217
+
218
+ animationFrameRef.current = requestAnimationFrame(animate);
219
+ }, []);
220
+
221
+ // Start animation loop
222
+ useEffect(() => {
223
+ if (!isClient) return;
224
+
225
+ animationFrameRef.current = requestAnimationFrame(animate);
226
+
227
+ return () => {
228
+ if (animationFrameRef.current) {
229
+ cancelAnimationFrame(animationFrameRef.current);
230
+ }
231
+ };
232
+ }, [isClient, animate]);
233
+
234
+ // Handle mouse movement
40
235
  useEffect(() => {
41
236
  if (!isClient) return;
42
237
 
43
238
  const handleMouseMove = (e: MouseEvent) => {
44
- setMousePosition({ x: e.clientX, y: e.clientY });
239
+ mousePositionRef.current = { x: e.clientX, y: e.clientY };
240
+ updateTarget();
45
241
  };
46
242
 
47
- document.addEventListener("mousemove", handleMouseMove);
243
+ document.addEventListener("mousemove", handleMouseMove, { passive: true });
48
244
  return () => document.removeEventListener("mousemove", handleMouseMove);
49
- }, [isClient]);
245
+ }, [isClient, updateTarget]);
50
246
 
51
247
  const handleMouseEnter = useCallback(() => {
52
248
  setIsMouseInside(true);
53
- }, []);
249
+ // Initialize spring position to current mouse position
250
+ const mouse = mousePositionRef.current;
251
+ springRef.current.x = mouse.x - cursorSize / 2;
252
+ springRef.current.y = mouse.y - cursorSize / 2;
253
+ updateTarget();
254
+ }, [cursorSize, updateTarget]);
54
255
 
55
256
  const handleMouseLeave = useCallback(() => {
56
257
  setIsMouseInside(false);
57
- setHoveredElementId(null);
258
+ hoveredElementIdRef.current = null;
58
259
  hoveredElementRef.current = null;
59
- }, []);
260
+ setHoveredElementId(null);
261
+ updateTarget();
262
+ }, [updateTarget]);
60
263
 
61
264
  const checkMouseInElement = useCallback(() => {
62
- if (!hoveredElementRef.current || !hoveredElementId) {
63
- return;
64
- }
265
+ if (!hoveredElementRef.current || !hoveredElementIdRef.current) return;
65
266
 
66
267
  const rect = hoveredElementRef.current.getBoundingClientRect();
268
+ const mouse = mousePositionRef.current;
67
269
 
68
- setElementDimensions({
270
+ elementDimensionsRef.current = {
69
271
  width: rect.width,
70
272
  height: rect.height,
71
273
  x: rect.left,
72
274
  y: rect.top,
73
275
  right: rect.right,
74
276
  bottom: rect.bottom,
75
- });
277
+ };
76
278
 
77
279
  const isInside =
78
- mousePosition.x >= rect.left &&
79
- mousePosition.x <= rect.right &&
80
- mousePosition.y >= rect.top &&
81
- mousePosition.y <= rect.bottom;
280
+ mouse.x >= rect.left &&
281
+ mouse.x <= rect.right &&
282
+ mouse.y >= rect.top &&
283
+ mouse.y <= rect.bottom;
82
284
 
83
285
  if (!isInside) {
84
- setHoveredElementId(null);
286
+ hoveredElementIdRef.current = null;
85
287
  hoveredElementRef.current = null;
288
+ setHoveredElementId(null);
86
289
  }
87
- }, [mousePosition, hoveredElementId]);
290
+
291
+ updateTarget();
292
+ }, [updateTarget]);
88
293
 
89
294
  useEffect(() => {
90
295
  if (!isClient) return;
91
296
 
92
- const handleScroll = () => {
93
- checkMouseInElement();
94
- };
297
+ const handleScroll = () => checkMouseInElement();
95
298
 
96
299
  document.addEventListener("scroll", handleScroll, { passive: true, capture: true });
97
-
98
- return () => {
99
- document.removeEventListener("scroll", handleScroll, { capture: true });
100
- };
300
+ return () => document.removeEventListener("scroll", handleScroll, { capture: true });
101
301
  }, [checkMouseInElement, isClient]);
102
302
 
103
303
  const registerHoveredElement = useCallback(
104
304
  (id: string, dimensions: DOMRect, element?: HTMLElement) => {
105
- setHoveredElementId(id);
106
- setElementDimensions({
305
+ hoveredElementIdRef.current = id;
306
+ elementDimensionsRef.current = {
107
307
  width: dimensions.width,
108
308
  height: dimensions.height,
109
309
  x: dimensions.left,
110
310
  y: dimensions.top,
111
311
  right: dimensions.right,
112
312
  bottom: dimensions.bottom,
113
- });
114
-
313
+ };
115
314
  if (element) {
116
315
  hoveredElementRef.current = element;
316
+ // Get computed border-radius from the target element
317
+ const computedStyle = window.getComputedStyle(element);
318
+ elementBorderRadiusRef.current = computedStyle.borderRadius || "8px";
117
319
  }
320
+ setHoveredElementId(id);
321
+ updateTarget();
118
322
  },
119
- [],
323
+ [updateTarget],
120
324
  );
121
325
 
122
326
  const unregisterHoveredElement = useCallback(() => {
123
- setHoveredElementId(null);
327
+ hoveredElementIdRef.current = null;
124
328
  hoveredElementRef.current = null;
125
- }, []);
329
+ elementBorderRadiusRef.current = "9999px";
330
+ setHoveredElementId(null);
331
+ updateTarget();
332
+ }, [updateTarget]);
126
333
 
127
334
  const updateElementDimensions = useCallback(
128
335
  (dimensions: DOMRect) => {
129
- if (hoveredElementId) {
130
- setElementDimensions({
336
+ if (hoveredElementIdRef.current) {
337
+ elementDimensionsRef.current = {
131
338
  width: dimensions.width,
132
339
  height: dimensions.height,
133
340
  x: dimensions.left,
134
341
  y: dimensions.top,
135
342
  right: dimensions.right,
136
343
  bottom: dimensions.bottom,
137
- });
344
+ };
345
+ updateTarget();
138
346
  }
139
347
  },
140
- [hoveredElementId],
348
+ [updateTarget],
141
349
  );
142
350
 
143
- const getCursorPosition = () => {
144
- if (!hoveredElementId) {
145
- return {
146
- x: mousePosition.x - cursorSize / 2,
147
- y: mousePosition.y - cursorSize / 2,
148
- };
149
- }
150
-
151
- // Calculate the center of the element
152
- const elementCenterX = elementDimensions.x + elementDimensions.width / 2;
153
- const elementCenterY = elementDimensions.y + elementDimensions.height / 2;
154
-
155
- // Calculate offset from center (with some dampening for smoothness)
156
- const offsetX = (mousePosition.x - elementCenterX) * 0.1;
157
- const offsetY = (mousePosition.y - elementCenterY) * 0.1;
158
-
159
- // Apply bounds to keep cursor within reasonable limits
160
- const boundedOffsetX = Math.max(-maxOffsetX, Math.min(maxOffsetX, offsetX));
161
- const boundedOffsetY = Math.max(-maxOffsetY, Math.min(maxOffsetY, offsetY));
162
-
163
- return {
164
- x: elementDimensions.x + boundedOffsetX,
165
- y: elementDimensions.y + boundedOffsetY,
166
- };
167
- };
168
-
169
351
  const contextValue = useMemo(
170
352
  () => ({
171
- // State values that change during component lifecycle
172
- mousePosition,
173
- hoveredElementId,
174
- elementDimensions,
175
-
176
- // Callbacks that should be stable references
177
- registerHoveredElement,
178
- unregisterHoveredElement,
179
- updateElementDimensions,
180
- }),
181
- [
182
- mousePosition,
353
+ mousePosition: mousePositionRef.current,
183
354
  hoveredElementId,
184
- elementDimensions,
355
+ elementDimensions: elementDimensionsRef.current,
185
356
  registerHoveredElement,
186
357
  unregisterHoveredElement,
187
358
  updateElementDimensions,
188
- ],
189
- );
190
-
191
- const cursorPosition = getCursorPosition();
192
-
193
- const cursorStyleObject = useMemo(
194
- () => ({
195
- left: cursorPosition.x,
196
- top: cursorPosition.y,
197
- width: hoveredElementId
198
- ? elementDimensions.width > 0
199
- ? elementDimensions.width
200
- : cursorSize
201
- : cursorSize,
202
- height: hoveredElementId
203
- ? elementDimensions.height > 0
204
- ? elementDimensions.height
205
- : cursorSize
206
- : cursorSize,
207
- willChange: "transform, width, height",
208
359
  }),
209
- [
210
- cursorPosition.x,
211
- cursorPosition.y,
212
- hoveredElementId,
213
- elementDimensions.width,
214
- elementDimensions.height,
215
- cursorSize,
216
- ],
360
+ [hoveredElementId, registerHoveredElement, unregisterHoveredElement, updateElementDimensions],
217
361
  );
218
362
 
219
- let styleClass;
220
- if (hoveredElementId) {
221
- styleClass = `opacity-[0.05] rounded-uk-md transition-[width,height,left,top] duration-${transitionDuration} ease-out`;
222
- } else {
223
- styleClass = `opacity-90 rounded-full z-10 transition-[width,height,left,top] duration-${transitionDuration} ease-out transition-opacity duration-${transitionDuration}`;
224
- }
225
-
226
- // Create cursor element to be portaled
227
- const cursorElement = isClient && isMouseInside && (
363
+ // Cursor with halo/glow effect from original design
364
+ const cursorElement = isClient && (
228
365
  <div
229
- className={`pointer-events-none fixed ${styleClass} ${hoveredElementId ? "" : cursorClassName || ""}`}
366
+ ref={cursorRef}
367
+ className="pointer-events-none fixed z-50"
230
368
  style={{
231
- ...cursorStyleObject,
232
- backgroundColor: "var(--shadow-tertiary)",
369
+ left: 0,
370
+ top: 0,
371
+ width: cursorSize,
372
+ height: cursorSize,
373
+ display: isMouseInside ? "block" : "none",
374
+ willChange: "transform, width, height",
233
375
  }}
234
- />
376
+ >
377
+ <div
378
+ ref={cursorInnerRef}
379
+ className={cn("h-full w-full border border-white/50", cursorClassName)}
380
+ style={{
381
+ backgroundColor: "rgba(156, 163, 175, 0.2)",
382
+ boxShadow: "0 0 25px rgba(255, 255, 255, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.5)",
383
+ borderRadius: "9999px",
384
+ transformOrigin: "center center",
385
+ }}
386
+ />
387
+ </div>
235
388
  );
236
389
 
237
- // Use React.Fragment at the top level to avoid any DOM structure that might affect layout
238
390
  return (
239
391
  <>
240
- {/* Portal the cursor overlay to document.body to completely avoid layout impact */}
241
392
  {isClient &&
242
393
  typeof document !== "undefined" &&
243
394
  document.body &&
244
- cursorElement &&
245
395
  createPortal(cursorElement, document.body)}
246
- {/* Context provider with no DOM element */}
247
396
  <CursorContext.Provider value={contextValue}>
248
- {/* Use the Component directly with no extra wrappers */}
249
397
  <Component
250
398
  {...props}
251
399
  className={cn(className)}
@@ -21,7 +21,8 @@ export interface CursorProviderProps extends HTMLAttributes<HTMLDivElement> {
21
21
  maxOffsetX?: number;
22
22
  maxOffsetY?: number;
23
23
  cursorSize?: number;
24
- transitionDuration?: number;
24
+ boundaryThreshold?: number;
25
+ outerThreshold?: number;
25
26
  cursorClassName?: string;
26
27
  as?: ElementType;
27
28
  }
@@ -16,8 +16,8 @@
16
16
  @utility liquid-light-bg {
17
17
  background: linear-gradient(
18
18
  147.1deg,
19
- rgba(236, 236, 236, 0.6) 0%,
20
- rgba(202, 202, 202, 0.6) 105.28%
19
+ rgba(246, 246, 246, 0.6) 0%,
20
+ rgba(232, 232, 232, 0.6) 105.28%
21
21
  ) !important;
22
22
  backdrop-filter: blur(5px) !important;
23
23
  }