@sth87/shadcn-design-system 0.0.35 → 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 (421) hide show
  1. package/README.md +20 -2
  2. package/dist/AI_CONTEXT.md +212 -214
  3. package/dist/cjs/components/Accordion/Accordion.cjs +1 -1
  4. package/dist/cjs/components/Accordion/Accordion.cjs.map +1 -1
  5. package/dist/cjs/components/Avatar/Avatar.cjs +1 -1
  6. package/dist/cjs/components/Avatar/Avatar.cjs.map +1 -1
  7. package/dist/cjs/components/Badge/Badge.cjs +1 -1
  8. package/dist/cjs/components/Badge/Badge.cjs.map +1 -1
  9. package/dist/cjs/components/Breadcrumb/Breadcrumb.cjs +1 -1
  10. package/dist/cjs/components/Breadcrumb/Breadcrumb.cjs.map +1 -1
  11. package/dist/cjs/components/Button/Button.cjs +1 -1
  12. package/dist/cjs/components/Button/Button.cjs.map +1 -1
  13. package/dist/cjs/components/Calendar/Calendar.cjs +1 -1
  14. package/dist/cjs/components/Calendar/Calendar.cjs.map +1 -1
  15. package/dist/cjs/components/Carousel/Carousel.cjs +1 -1
  16. package/dist/cjs/components/Carousel/Carousel.cjs.map +1 -1
  17. package/dist/cjs/components/Checkbox/Checkbox.cjs +1 -1
  18. package/dist/cjs/components/Checkbox/Checkbox.cjs.map +1 -1
  19. package/dist/cjs/components/Collapsible/Collapsible.cjs +1 -1
  20. package/dist/cjs/components/Collapsible/Collapsible.cjs.map +1 -1
  21. package/dist/cjs/components/Command/Command.cjs +1 -1
  22. package/dist/cjs/components/Command/Command.cjs.map +1 -1
  23. package/dist/cjs/components/ContextMenu/ContextMenu.cjs +1 -1
  24. package/dist/cjs/components/ContextMenu/ContextMenu.cjs.map +1 -1
  25. package/dist/cjs/components/Cropper/Cropper.cjs +1 -1
  26. package/dist/cjs/components/Cropper/Cropper.cjs.map +1 -1
  27. package/dist/cjs/components/DatePicker/DatePicker.cjs +1 -1
  28. package/dist/cjs/components/DatePicker/DatePicker.cjs.map +1 -1
  29. package/dist/cjs/components/DatePicker/RangePicker.cjs +1 -1
  30. package/dist/cjs/components/DatePicker/RangePicker.cjs.map +1 -1
  31. package/dist/cjs/components/DatePicker/TimePicker.cjs +1 -1
  32. package/dist/cjs/components/DatePicker/TimePicker.cjs.map +1 -1
  33. package/dist/cjs/components/Dialog/Dialog.cjs +1 -1
  34. package/dist/cjs/components/Dialog/Dialog.cjs.map +1 -1
  35. package/dist/cjs/components/DropdownMenu/DropdownMenu.cjs +1 -1
  36. package/dist/cjs/components/DropdownMenu/DropdownMenu.cjs.map +1 -1
  37. package/dist/cjs/components/FloatLabel.cjs +1 -1
  38. package/dist/cjs/components/FloatLabel.cjs.map +1 -1
  39. package/dist/cjs/components/Glass/Glass.cjs +1 -1
  40. package/dist/cjs/components/Glass/Glass.cjs.map +1 -1
  41. package/dist/cjs/components/ImageViewer/ImageViewer.cjs +1 -1
  42. package/dist/cjs/components/ImageViewer/ImageViewer.cjs.map +1 -1
  43. package/dist/cjs/components/Input/Input.cjs +1 -1
  44. package/dist/cjs/components/Input/Input.cjs.map +1 -1
  45. package/dist/cjs/components/InputOTP/InputOTP.cjs +1 -1
  46. package/dist/cjs/components/InputOTP/InputOTP.cjs.map +1 -1
  47. package/dist/cjs/components/Interactive/CursorFollow.cjs +1 -1
  48. package/dist/cjs/components/Interactive/CursorFollow.cjs.map +1 -1
  49. package/dist/cjs/components/Marquee/Marquee.cjs +1 -1
  50. package/dist/cjs/components/Marquee/Marquee.cjs.map +1 -1
  51. package/dist/cjs/components/Pagination/Pagination.cjs +1 -1
  52. package/dist/cjs/components/Pagination/Pagination.cjs.map +1 -1
  53. package/dist/cjs/components/QrCode/QrCode.cjs +1 -1
  54. package/dist/cjs/components/QrCode/QrCode.cjs.map +1 -1
  55. package/dist/cjs/components/Radio/Radio.cjs +1 -1
  56. package/dist/cjs/components/Radio/Radio.cjs.map +1 -1
  57. package/dist/cjs/components/Rate/Rate.cjs +1 -1
  58. package/dist/cjs/components/Rate/Rate.cjs.map +1 -1
  59. package/dist/cjs/components/Resizable/Resizable.cjs +1 -1
  60. package/dist/cjs/components/Resizable/Resizable.cjs.map +1 -1
  61. package/dist/cjs/components/ScrollArea/ScrollArea.cjs +1 -1
  62. package/dist/cjs/components/ScrollArea/ScrollArea.cjs.map +1 -1
  63. package/dist/cjs/components/Select/Select.cjs +1 -1
  64. package/dist/cjs/components/Select/Select.cjs.map +1 -1
  65. package/dist/cjs/components/Sheet/Sheet.cjs +2 -2
  66. package/dist/cjs/components/Sheet/Sheet.cjs.map +1 -1
  67. package/dist/cjs/components/Slider/Slider.cjs +1 -1
  68. package/dist/cjs/components/Slider/Slider.cjs.map +1 -1
  69. package/dist/cjs/components/Stepper/Stepper.cjs +1 -1
  70. package/dist/cjs/components/Stepper/Stepper.cjs.map +1 -1
  71. package/dist/cjs/components/Stepper/StepperWrapper.cjs +1 -1
  72. package/dist/cjs/components/Stepper/StepperWrapper.cjs.map +1 -1
  73. package/dist/cjs/components/Switch/Switch.cjs +1 -1
  74. package/dist/cjs/components/Switch/Switch.cjs.map +1 -1
  75. package/dist/cjs/components/Table/TableFilter/data-table-date-filter.cjs +1 -1
  76. package/dist/cjs/components/Table/TableFilter/data-table-date-filter.cjs.map +1 -1
  77. package/dist/cjs/components/Table/TableFilter/data-table-filter-popover.cjs +1 -1
  78. package/dist/cjs/components/Table/TableFilter/data-table-filter-popover.cjs.map +1 -1
  79. package/dist/cjs/components/Table/TableFilter/data-table-slider-filter.cjs +1 -1
  80. package/dist/cjs/components/Table/TableFilter/data-table-slider-filter.cjs.map +1 -1
  81. package/dist/cjs/components/Table/data-table-column-header.cjs +1 -1
  82. package/dist/cjs/components/Table/data-table-column-header.cjs.map +1 -1
  83. package/dist/cjs/components/Table/data-table-pagination.cjs +1 -1
  84. package/dist/cjs/components/Table/data-table-pagination.cjs.map +1 -1
  85. package/dist/cjs/components/Table/data-table.cjs +1 -1
  86. package/dist/cjs/components/Table/data-table.cjs.map +1 -1
  87. package/dist/cjs/components/Tabs/Tabs.cjs +1 -1
  88. package/dist/cjs/components/Tabs/Tabs.cjs.map +1 -1
  89. package/dist/cjs/components/Tabs/classes.cjs +1 -1
  90. package/dist/cjs/components/Tabs/classes.cjs.map +1 -1
  91. package/dist/cjs/components/Textarea/Textarea.cjs +1 -1
  92. package/dist/cjs/components/Textarea/Textarea.cjs.map +1 -1
  93. package/dist/cjs/components/TimeGridView.cjs +1 -1
  94. package/dist/cjs/components/TimeGridView.cjs.map +1 -1
  95. package/dist/cjs/components/Toast/Toast.cjs +1 -1
  96. package/dist/cjs/components/Toast/Toast.cjs.map +1 -1
  97. package/dist/cjs/components/Tooltip/Tooltip.cjs +1 -1
  98. package/dist/cjs/components/Tooltip/Tooltip.cjs.map +1 -1
  99. package/dist/cjs/components/Tour/Tour.cjs +1 -1
  100. package/dist/cjs/components/Tour/Tour.cjs.map +1 -1
  101. package/dist/cjs/components/Tour/TourWrapper.cjs +1 -1
  102. package/dist/cjs/components/Tour/TourWrapper.cjs.map +1 -1
  103. package/dist/cjs/components/Upload/Upload.cjs +3 -3
  104. package/dist/cjs/components/Upload/Upload.cjs.map +1 -1
  105. package/dist/cjs/components/WheelColumn.cjs +1 -1
  106. package/dist/cjs/components/WheelColumn.cjs.map +1 -1
  107. package/dist/cjs/lib/TextAnimation/BlurText.cjs +1 -1
  108. package/dist/cjs/lib/TextAnimation/BlurText.cjs.map +1 -1
  109. package/dist/cjs/lib/TextAnimation/CircularText.cjs +1 -1
  110. package/dist/cjs/lib/TextAnimation/CircularText.cjs.map +1 -1
  111. package/dist/cjs/lib/TextAnimation/FlipWords.cjs +1 -1
  112. package/dist/cjs/lib/TextAnimation/FlipWords.cjs.map +1 -1
  113. package/dist/cjs/lib/TextAnimation/GradientText.cjs +1 -1
  114. package/dist/cjs/lib/TextAnimation/GradientText.cjs.map +1 -1
  115. package/dist/cjs/lib/TextAnimation/RollingText.cjs +1 -1
  116. package/dist/cjs/lib/TextAnimation/RollingText.cjs.map +1 -1
  117. package/dist/cjs/lib/TextAnimation/RotatingText.cjs +1 -1
  118. package/dist/cjs/lib/TextAnimation/RotatingText.cjs.map +1 -1
  119. package/dist/cjs/lib/TextAnimation/ShimmeringText.cjs +1 -1
  120. package/dist/cjs/lib/TextAnimation/ShimmeringText.cjs.map +1 -1
  121. package/dist/cjs/lib/TextAnimation/TextGenerateEffect.cjs +1 -1
  122. package/dist/cjs/lib/TextAnimation/TextGenerateEffect.cjs.map +1 -1
  123. package/dist/cjs/lib/TextAnimation/TextHoverEffect.cjs +1 -1
  124. package/dist/cjs/lib/TextAnimation/TextHoverEffect.cjs.map +1 -1
  125. package/dist/cjs/lib/TextAnimation/TextPressureEffect.cjs +2 -2
  126. package/dist/cjs/lib/TextAnimation/TextPressureEffect.cjs.map +1 -1
  127. package/dist/cjs/lib/TextAnimation/TypingText.cjs +1 -1
  128. package/dist/cjs/lib/TextAnimation/TypingText.cjs.map +1 -1
  129. package/dist/cjs/lib/TextAnimation/WritingText.cjs +1 -1
  130. package/dist/cjs/lib/TextAnimation/WritingText.cjs.map +1 -1
  131. package/dist/cjs/node_modules/.pnpm/nuqs@2.8.0_next@15.5.9_@babel_core@7.28.5_react-dom@19.1.1_react@19.1.1__react@19.1.1__react@19.1.1/node_modules/nuqs/dist/server.cjs.map +1 -0
  132. package/dist/cjs/packages/ui/src/components/accordion.cjs +1 -1
  133. package/dist/cjs/packages/ui/src/components/accordion.cjs.map +1 -1
  134. package/dist/cjs/packages/ui/src/components/alert-dialog.cjs +1 -1
  135. package/dist/cjs/packages/ui/src/components/alert-dialog.cjs.map +1 -1
  136. package/dist/cjs/packages/ui/src/components/avatar.cjs +1 -1
  137. package/dist/cjs/packages/ui/src/components/avatar.cjs.map +1 -1
  138. package/dist/cjs/packages/ui/src/components/badge.cjs +1 -1
  139. package/dist/cjs/packages/ui/src/components/badge.cjs.map +1 -1
  140. package/dist/cjs/packages/ui/src/components/breadcrumb.cjs +1 -1
  141. package/dist/cjs/packages/ui/src/components/breadcrumb.cjs.map +1 -1
  142. package/dist/cjs/packages/ui/src/components/button-group.cjs +1 -1
  143. package/dist/cjs/packages/ui/src/components/button-group.cjs.map +1 -1
  144. package/dist/cjs/packages/ui/src/components/button.cjs +1 -1
  145. package/dist/cjs/packages/ui/src/components/button.cjs.map +1 -1
  146. package/dist/cjs/packages/ui/src/components/calendar.cjs +1 -1
  147. package/dist/cjs/packages/ui/src/components/calendar.cjs.map +1 -1
  148. package/dist/cjs/packages/ui/src/components/checkbox.cjs +1 -1
  149. package/dist/cjs/packages/ui/src/components/checkbox.cjs.map +1 -1
  150. package/dist/cjs/packages/ui/src/components/combobox.cjs +1 -1
  151. package/dist/cjs/packages/ui/src/components/combobox.cjs.map +1 -1
  152. package/dist/cjs/packages/ui/src/components/command.cjs +1 -1
  153. package/dist/cjs/packages/ui/src/components/command.cjs.map +1 -1
  154. package/dist/cjs/packages/ui/src/components/context-menu.cjs +1 -1
  155. package/dist/cjs/packages/ui/src/components/context-menu.cjs.map +1 -1
  156. package/dist/cjs/packages/ui/src/components/dialog.cjs +1 -1
  157. package/dist/cjs/packages/ui/src/components/dialog.cjs.map +1 -1
  158. package/dist/cjs/packages/ui/src/components/drawer.cjs +1 -1
  159. package/dist/cjs/packages/ui/src/components/drawer.cjs.map +1 -1
  160. package/dist/cjs/packages/ui/src/components/dropdown-menu.cjs +1 -1
  161. package/dist/cjs/packages/ui/src/components/dropdown-menu.cjs.map +1 -1
  162. package/dist/cjs/packages/ui/src/components/input-otp.cjs +1 -1
  163. package/dist/cjs/packages/ui/src/components/input-otp.cjs.map +1 -1
  164. package/dist/cjs/packages/ui/src/components/input.cjs +1 -1
  165. package/dist/cjs/packages/ui/src/components/input.cjs.map +1 -1
  166. package/dist/cjs/packages/ui/src/components/label.cjs +1 -1
  167. package/dist/cjs/packages/ui/src/components/label.cjs.map +1 -1
  168. package/dist/cjs/packages/ui/src/components/pagination.cjs +1 -1
  169. package/dist/cjs/packages/ui/src/components/pagination.cjs.map +1 -1
  170. package/dist/cjs/packages/ui/src/components/popover.cjs +1 -1
  171. package/dist/cjs/packages/ui/src/components/popover.cjs.map +1 -1
  172. package/dist/cjs/packages/ui/src/components/radio-group.cjs +1 -1
  173. package/dist/cjs/packages/ui/src/components/radio-group.cjs.map +1 -1
  174. package/dist/cjs/packages/ui/src/components/resizable.cjs +1 -1
  175. package/dist/cjs/packages/ui/src/components/resizable.cjs.map +1 -1
  176. package/dist/cjs/packages/ui/src/components/scroll-area.cjs +1 -1
  177. package/dist/cjs/packages/ui/src/components/scroll-area.cjs.map +1 -1
  178. package/dist/cjs/packages/ui/src/components/select.cjs +1 -1
  179. package/dist/cjs/packages/ui/src/components/select.cjs.map +1 -1
  180. package/dist/cjs/packages/ui/src/components/separator.cjs +1 -1
  181. package/dist/cjs/packages/ui/src/components/separator.cjs.map +1 -1
  182. package/dist/cjs/packages/ui/src/components/sheet.cjs +1 -1
  183. package/dist/cjs/packages/ui/src/components/sheet.cjs.map +1 -1
  184. package/dist/cjs/packages/ui/src/components/sidebar.cjs +1 -1
  185. package/dist/cjs/packages/ui/src/components/sidebar.cjs.map +1 -1
  186. package/dist/cjs/packages/ui/src/components/skeleton.cjs +1 -1
  187. package/dist/cjs/packages/ui/src/components/skeleton.cjs.map +1 -1
  188. package/dist/cjs/packages/ui/src/components/switch.cjs +1 -1
  189. package/dist/cjs/packages/ui/src/components/switch.cjs.map +1 -1
  190. package/dist/cjs/packages/ui/src/components/table.cjs +1 -1
  191. package/dist/cjs/packages/ui/src/components/table.cjs.map +1 -1
  192. package/dist/cjs/packages/ui/src/components/tabs.cjs +1 -1
  193. package/dist/cjs/packages/ui/src/components/tabs.cjs.map +1 -1
  194. package/dist/cjs/packages/ui/src/components/textarea.cjs +1 -1
  195. package/dist/cjs/packages/ui/src/components/textarea.cjs.map +1 -1
  196. package/dist/cjs/packages/ui/src/components/toggle.cjs +1 -1
  197. package/dist/cjs/packages/ui/src/components/toggle.cjs.map +1 -1
  198. package/dist/cjs/packages/ui/src/components/tooltip.cjs +1 -1
  199. package/dist/cjs/packages/ui/src/components/tooltip.cjs.map +1 -1
  200. package/dist/cjs/packages/ui/src/components/tree-view.cjs +1 -1
  201. package/dist/cjs/packages/ui/src/components/tree-view.cjs.map +1 -1
  202. package/dist/cjs/styles/index.css +1 -1
  203. package/dist/cjs/utils/animations.cjs +1 -1
  204. package/dist/cjs/utils/animations.cjs.map +1 -1
  205. package/dist/cjs/utils/css.cjs +1 -1
  206. package/dist/cjs/utils/css.cjs.map +1 -1
  207. package/dist/cjs/utils/parsers.cjs +1 -1
  208. package/dist/cjs/utils/parsers.cjs.map +1 -1
  209. package/dist/esm/components/Accordion/Accordion.js +60 -60
  210. package/dist/esm/components/Accordion/Accordion.js.map +1 -1
  211. package/dist/esm/components/Avatar/Avatar.js +40 -40
  212. package/dist/esm/components/Avatar/Avatar.js.map +1 -1
  213. package/dist/esm/components/Badge/Badge.js +1 -1
  214. package/dist/esm/components/Badge/Badge.js.map +1 -1
  215. package/dist/esm/components/Breadcrumb/Breadcrumb.js +36 -36
  216. package/dist/esm/components/Breadcrumb/Breadcrumb.js.map +1 -1
  217. package/dist/esm/components/Button/Button.js +9 -9
  218. package/dist/esm/components/Button/Button.js.map +1 -1
  219. package/dist/esm/components/Calendar/Calendar.js +4 -4
  220. package/dist/esm/components/Calendar/Calendar.js.map +1 -1
  221. package/dist/esm/components/Carousel/Carousel.js +165 -165
  222. package/dist/esm/components/Carousel/Carousel.js.map +1 -1
  223. package/dist/esm/components/Checkbox/Checkbox.js +26 -26
  224. package/dist/esm/components/Checkbox/Checkbox.js.map +1 -1
  225. package/dist/esm/components/Collapsible/Collapsible.js +43 -43
  226. package/dist/esm/components/Collapsible/Collapsible.js.map +1 -1
  227. package/dist/esm/components/Command/Command.js +28 -28
  228. package/dist/esm/components/Command/Command.js.map +1 -1
  229. package/dist/esm/components/ContextMenu/ContextMenu.js +11 -11
  230. package/dist/esm/components/ContextMenu/ContextMenu.js.map +1 -1
  231. package/dist/esm/components/Cropper/Cropper.js +132 -132
  232. package/dist/esm/components/Cropper/Cropper.js.map +1 -1
  233. package/dist/esm/components/DatePicker/DatePicker.js +75 -75
  234. package/dist/esm/components/DatePicker/DatePicker.js.map +1 -1
  235. package/dist/esm/components/DatePicker/RangePicker.js +136 -136
  236. package/dist/esm/components/DatePicker/RangePicker.js.map +1 -1
  237. package/dist/esm/components/DatePicker/TimePicker.js +150 -150
  238. package/dist/esm/components/DatePicker/TimePicker.js.map +1 -1
  239. package/dist/esm/components/Dialog/Dialog.js +114 -114
  240. package/dist/esm/components/Dialog/Dialog.js.map +1 -1
  241. package/dist/esm/components/DropdownMenu/DropdownMenu.js +13 -13
  242. package/dist/esm/components/DropdownMenu/DropdownMenu.js.map +1 -1
  243. package/dist/esm/components/FloatLabel.js +44 -44
  244. package/dist/esm/components/FloatLabel.js.map +1 -1
  245. package/dist/esm/components/Glass/Glass.js +15 -15
  246. package/dist/esm/components/Glass/Glass.js.map +1 -1
  247. package/dist/esm/components/ImageViewer/ImageViewer.js +53 -53
  248. package/dist/esm/components/ImageViewer/ImageViewer.js.map +1 -1
  249. package/dist/esm/components/Input/Input.js +104 -104
  250. package/dist/esm/components/Input/Input.js.map +1 -1
  251. package/dist/esm/components/InputOTP/InputOTP.js +16 -16
  252. package/dist/esm/components/InputOTP/InputOTP.js.map +1 -1
  253. package/dist/esm/components/Interactive/CursorFollow.js +49 -49
  254. package/dist/esm/components/Interactive/CursorFollow.js.map +1 -1
  255. package/dist/esm/components/Marquee/Marquee.js +130 -130
  256. package/dist/esm/components/Marquee/Marquee.js.map +1 -1
  257. package/dist/esm/components/Pagination/Pagination.js +68 -68
  258. package/dist/esm/components/Pagination/Pagination.js.map +1 -1
  259. package/dist/esm/components/QrCode/QrCode.js +37 -37
  260. package/dist/esm/components/QrCode/QrCode.js.map +1 -1
  261. package/dist/esm/components/Radio/Radio.js +16 -16
  262. package/dist/esm/components/Radio/Radio.js.map +1 -1
  263. package/dist/esm/components/Rate/Rate.js +62 -62
  264. package/dist/esm/components/Rate/Rate.js.map +1 -1
  265. package/dist/esm/components/Resizable/Resizable.js +6 -6
  266. package/dist/esm/components/Resizable/Resizable.js.map +1 -1
  267. package/dist/esm/components/ScrollArea/ScrollArea.js +10 -10
  268. package/dist/esm/components/ScrollArea/ScrollArea.js.map +1 -1
  269. package/dist/esm/components/Select/Select.js +64 -64
  270. package/dist/esm/components/Select/Select.js.map +1 -1
  271. package/dist/esm/components/Sheet/Sheet.js +21 -21
  272. package/dist/esm/components/Sheet/Sheet.js.map +1 -1
  273. package/dist/esm/components/Slider/Slider.js +54 -54
  274. package/dist/esm/components/Slider/Slider.js.map +1 -1
  275. package/dist/esm/components/Stepper/Stepper.js +198 -198
  276. package/dist/esm/components/Stepper/Stepper.js.map +1 -1
  277. package/dist/esm/components/Stepper/StepperWrapper.js +15 -15
  278. package/dist/esm/components/Stepper/StepperWrapper.js.map +1 -1
  279. package/dist/esm/components/Switch/Switch.js +38 -38
  280. package/dist/esm/components/Switch/Switch.js.map +1 -1
  281. package/dist/esm/components/Table/TableFilter/data-table-date-filter.js +37 -37
  282. package/dist/esm/components/Table/TableFilter/data-table-date-filter.js.map +1 -1
  283. package/dist/esm/components/Table/TableFilter/data-table-filter-popover.js +25 -25
  284. package/dist/esm/components/Table/TableFilter/data-table-filter-popover.js.map +1 -1
  285. package/dist/esm/components/Table/TableFilter/data-table-slider-filter.js +64 -64
  286. package/dist/esm/components/Table/TableFilter/data-table-slider-filter.js.map +1 -1
  287. package/dist/esm/components/Table/data-table-column-header.js +18 -18
  288. package/dist/esm/components/Table/data-table-column-header.js.map +1 -1
  289. package/dist/esm/components/Table/data-table-pagination.js +21 -21
  290. package/dist/esm/components/Table/data-table-pagination.js.map +1 -1
  291. package/dist/esm/components/Table/data-table.js +18 -18
  292. package/dist/esm/components/Table/data-table.js.map +1 -1
  293. package/dist/esm/components/Tabs/Tabs.js +242 -242
  294. package/dist/esm/components/Tabs/Tabs.js.map +1 -1
  295. package/dist/esm/components/Tabs/classes.js +51 -51
  296. package/dist/esm/components/Tabs/classes.js.map +1 -1
  297. package/dist/esm/components/Textarea/Textarea.js +49 -49
  298. package/dist/esm/components/Textarea/Textarea.js.map +1 -1
  299. package/dist/esm/components/TimeGridView.js +12 -12
  300. package/dist/esm/components/TimeGridView.js.map +1 -1
  301. package/dist/esm/components/Toast/Toast.js +45 -45
  302. package/dist/esm/components/Toast/Toast.js.map +1 -1
  303. package/dist/esm/components/Tooltip/Tooltip.js +19 -19
  304. package/dist/esm/components/Tooltip/Tooltip.js.map +1 -1
  305. package/dist/esm/components/Tour/Tour.js +11 -11
  306. package/dist/esm/components/Tour/Tour.js.map +1 -1
  307. package/dist/esm/components/Tour/TourWrapper.js +15 -15
  308. package/dist/esm/components/Tour/TourWrapper.js.map +1 -1
  309. package/dist/esm/components/Upload/Upload.js +405 -405
  310. package/dist/esm/components/Upload/Upload.js.map +1 -1
  311. package/dist/esm/components/WheelColumn.js +47 -47
  312. package/dist/esm/components/WheelColumn.js.map +1 -1
  313. package/dist/esm/lib/TextAnimation/BlurText.js +18 -18
  314. package/dist/esm/lib/TextAnimation/BlurText.js.map +1 -1
  315. package/dist/esm/lib/TextAnimation/CircularText.js +7 -7
  316. package/dist/esm/lib/TextAnimation/CircularText.js.map +1 -1
  317. package/dist/esm/lib/TextAnimation/FlipWords.js +21 -21
  318. package/dist/esm/lib/TextAnimation/FlipWords.js.map +1 -1
  319. package/dist/esm/lib/TextAnimation/GradientText.js +4 -4
  320. package/dist/esm/lib/TextAnimation/GradientText.js.map +1 -1
  321. package/dist/esm/lib/TextAnimation/RollingText.js +24 -24
  322. package/dist/esm/lib/TextAnimation/RollingText.js.map +1 -1
  323. package/dist/esm/lib/TextAnimation/RotatingText.js +6 -6
  324. package/dist/esm/lib/TextAnimation/RotatingText.js.map +1 -1
  325. package/dist/esm/lib/TextAnimation/ShimmeringText.js +9 -9
  326. package/dist/esm/lib/TextAnimation/ShimmeringText.js.map +1 -1
  327. package/dist/esm/lib/TextAnimation/TextGenerateEffect.js +14 -14
  328. package/dist/esm/lib/TextAnimation/TextGenerateEffect.js.map +1 -1
  329. package/dist/esm/lib/TextAnimation/TextHoverEffect.js +9 -9
  330. package/dist/esm/lib/TextAnimation/TextHoverEffect.js.map +1 -1
  331. package/dist/esm/lib/TextAnimation/TextPressureEffect.js +3 -3
  332. package/dist/esm/lib/TextAnimation/TextPressureEffect.js.map +1 -1
  333. package/dist/esm/lib/TextAnimation/TypingText.js +17 -17
  334. package/dist/esm/lib/TextAnimation/TypingText.js.map +1 -1
  335. package/dist/esm/lib/TextAnimation/WritingText.js +10 -10
  336. package/dist/esm/lib/TextAnimation/WritingText.js.map +1 -1
  337. package/dist/esm/node_modules/.pnpm/nuqs@2.8.0_next@15.5.9_@babel_core@7.28.5_react-dom@19.1.1_react@19.1.1__react@19.1.1__react@19.1.1/node_modules/nuqs/dist/server.js.map +1 -0
  338. package/dist/esm/packages/ui/src/components/accordion.js +31 -31
  339. package/dist/esm/packages/ui/src/components/accordion.js.map +1 -1
  340. package/dist/esm/packages/ui/src/components/alert-dialog.js +33 -33
  341. package/dist/esm/packages/ui/src/components/alert-dialog.js.map +1 -1
  342. package/dist/esm/packages/ui/src/components/avatar.js +20 -20
  343. package/dist/esm/packages/ui/src/components/avatar.js.map +1 -1
  344. package/dist/esm/packages/ui/src/components/badge.js +53 -53
  345. package/dist/esm/packages/ui/src/components/badge.js.map +1 -1
  346. package/dist/esm/packages/ui/src/components/breadcrumb.js +20 -20
  347. package/dist/esm/packages/ui/src/components/breadcrumb.js.map +1 -1
  348. package/dist/esm/packages/ui/src/components/button-group.js +31 -31
  349. package/dist/esm/packages/ui/src/components/button-group.js.map +1 -1
  350. package/dist/esm/packages/ui/src/components/button.js +90 -90
  351. package/dist/esm/packages/ui/src/components/button.js.map +1 -1
  352. package/dist/esm/packages/ui/src/components/calendar.js +94 -94
  353. package/dist/esm/packages/ui/src/components/calendar.js.map +1 -1
  354. package/dist/esm/packages/ui/src/components/checkbox.js +47 -47
  355. package/dist/esm/packages/ui/src/components/checkbox.js.map +1 -1
  356. package/dist/esm/packages/ui/src/components/combobox.js +64 -64
  357. package/dist/esm/packages/ui/src/components/combobox.js.map +1 -1
  358. package/dist/esm/packages/ui/src/components/command.js +77 -77
  359. package/dist/esm/packages/ui/src/components/command.js.map +1 -1
  360. package/dist/esm/packages/ui/src/components/context-menu.js +76 -76
  361. package/dist/esm/packages/ui/src/components/context-menu.js.map +1 -1
  362. package/dist/esm/packages/ui/src/components/dialog.js +54 -54
  363. package/dist/esm/packages/ui/src/components/dialog.js.map +1 -1
  364. package/dist/esm/packages/ui/src/components/drawer.js +39 -39
  365. package/dist/esm/packages/ui/src/components/drawer.js.map +1 -1
  366. package/dist/esm/packages/ui/src/components/dropdown-menu.js +109 -109
  367. package/dist/esm/packages/ui/src/components/dropdown-menu.js.map +1 -1
  368. package/dist/esm/packages/ui/src/components/input-otp.js +30 -30
  369. package/dist/esm/packages/ui/src/components/input-otp.js.map +1 -1
  370. package/dist/esm/packages/ui/src/components/input.js +19 -19
  371. package/dist/esm/packages/ui/src/components/input.js.map +1 -1
  372. package/dist/esm/packages/ui/src/components/label.js +9 -9
  373. package/dist/esm/packages/ui/src/components/label.js.map +1 -1
  374. package/dist/esm/packages/ui/src/components/pagination.js +26 -26
  375. package/dist/esm/packages/ui/src/components/pagination.js.map +1 -1
  376. package/dist/esm/packages/ui/src/components/popover.js +13 -13
  377. package/dist/esm/packages/ui/src/components/popover.js.map +1 -1
  378. package/dist/esm/packages/ui/src/components/radio-group.js +45 -45
  379. package/dist/esm/packages/ui/src/components/radio-group.js.map +1 -1
  380. package/dist/esm/packages/ui/src/components/resizable.js +18 -18
  381. package/dist/esm/packages/ui/src/components/resizable.js.map +1 -1
  382. package/dist/esm/packages/ui/src/components/scroll-area.js +31 -31
  383. package/dist/esm/packages/ui/src/components/scroll-area.js.map +1 -1
  384. package/dist/esm/packages/ui/src/components/select.js +119 -119
  385. package/dist/esm/packages/ui/src/components/select.js.map +1 -1
  386. package/dist/esm/packages/ui/src/components/separator.js +86 -86
  387. package/dist/esm/packages/ui/src/components/separator.js.map +1 -1
  388. package/dist/esm/packages/ui/src/components/sheet.js +50 -50
  389. package/dist/esm/packages/ui/src/components/sheet.js.map +1 -1
  390. package/dist/esm/packages/ui/src/components/sidebar.js +198 -198
  391. package/dist/esm/packages/ui/src/components/sidebar.js.map +1 -1
  392. package/dist/esm/packages/ui/src/components/skeleton.js +3 -3
  393. package/dist/esm/packages/ui/src/components/skeleton.js.map +1 -1
  394. package/dist/esm/packages/ui/src/components/switch.js +57 -57
  395. package/dist/esm/packages/ui/src/components/switch.js.map +1 -1
  396. package/dist/esm/packages/ui/src/components/table.js +17 -17
  397. package/dist/esm/packages/ui/src/components/table.js.map +1 -1
  398. package/dist/esm/packages/ui/src/components/tabs.js +33 -33
  399. package/dist/esm/packages/ui/src/components/tabs.js.map +1 -1
  400. package/dist/esm/packages/ui/src/components/textarea.js +17 -17
  401. package/dist/esm/packages/ui/src/components/textarea.js.map +1 -1
  402. package/dist/esm/packages/ui/src/components/toggle.js +36 -36
  403. package/dist/esm/packages/ui/src/components/toggle.js.map +1 -1
  404. package/dist/esm/packages/ui/src/components/tooltip.js +20 -20
  405. package/dist/esm/packages/ui/src/components/tooltip.js.map +1 -1
  406. package/dist/esm/packages/ui/src/components/tree-view.js +218 -218
  407. package/dist/esm/packages/ui/src/components/tree-view.js.map +1 -1
  408. package/dist/esm/styles/index.css +1 -1
  409. package/dist/esm/utils/animations.js +55 -55
  410. package/dist/esm/utils/animations.js.map +1 -1
  411. package/dist/esm/utils/css.js +7 -7
  412. package/dist/esm/utils/css.js.map +1 -1
  413. package/dist/esm/utils/parsers.js +1 -1
  414. package/dist/types/components/DatePicker/RangePicker.d.ts.map +1 -1
  415. package/dist/types/lib/TextAnimation/TextPressureEffect.d.ts.map +1 -1
  416. package/dist/types/lib/TextAnimation/TypingText.d.ts.map +1 -1
  417. package/package.json +1 -1
  418. package/dist/cjs/node_modules/.pnpm/nuqs@2.8.0_next@15.5.9_react-dom@19.1.1_react@19.1.1__react@19.1.1__react@19.1.1/node_modules/nuqs/dist/server.cjs.map +0 -1
  419. package/dist/esm/node_modules/.pnpm/nuqs@2.8.0_next@15.5.9_react-dom@19.1.1_react@19.1.1__react@19.1.1__react@19.1.1/node_modules/nuqs/dist/server.js.map +0 -1
  420. /package/dist/cjs/node_modules/.pnpm/{nuqs@2.8.0_next@15.5.9_react-dom@19.1.1_react@19.1.1__react@19.1.1__react@19.1.1 → nuqs@2.8.0_next@15.5.9_@babel_core@7.28.5_react-dom@19.1.1_react@19.1.1__react@19.1.1__react@19.1.1}/node_modules/nuqs/dist/server.cjs +0 -0
  421. /package/dist/esm/node_modules/.pnpm/{nuqs@2.8.0_next@15.5.9_react-dom@19.1.1_react@19.1.1__react@19.1.1__react@19.1.1 → nuqs@2.8.0_next@15.5.9_@babel_core@7.28.5_react-dom@19.1.1_react@19.1.1__react@19.1.1__react@19.1.1}/node_modules/nuqs/dist/server.js +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"Carousel.js","sources":["../../../../src/components/Carousel/Carousel.tsx"],"sourcesContent":["import React, {\n useState,\n useEffect,\n useRef,\n useCallback,\n useMemo,\n Children,\n isValidElement,\n cloneElement,\n} from \"react\";\nimport {\n ChevronLeft,\n ChevronRight,\n ChevronUp,\n ChevronDown,\n} from \"lucide-react\";\nimport { cn } from \"@dsui/ui/lib/utils\";\nimport { ImageViewer } from \"../ImageViewer\";\nimport type { ImageInfo } from \"../ImageViewer\";\n\n// ============================================================================\n// Types\n// ============================================================================\n\nexport type SliderEffect =\n | \"slide\"\n | \"fade\"\n | \"cube\"\n | \"coverflow\"\n | \"flip\"\n | \"cards\";\n\nexport type SliderDirection = \"horizontal\" | \"vertical\";\n\nexport type PaginationType =\n | \"bullets\"\n | \"fraction\"\n | \"progressbar\"\n | \"scrollbar\"\n | \"custom\";\n\nexport interface AutoplayOptions {\n delay?: number;\n disableOnInteraction?: boolean;\n pauseOnMouseEnter?: boolean;\n reverseDirection?: boolean;\n stopOnLastSlide?: boolean;\n}\n\nexport interface BreakpointOptions {\n slidesPerView?: number;\n spaceBetween?: number;\n slidesPerGroup?: number;\n}\n\nexport interface NavigationOptions {\n enabled?: boolean;\n prevEl?: React.ReactNode;\n nextEl?: React.ReactNode;\n hideOnClick?: boolean;\n position?: \"inside\" | \"outside\"; // inside = overlay on image, outside = beside image\n}\n\nexport interface PaginationOptions {\n enabled?: boolean;\n type?: PaginationType;\n clickable?: boolean;\n dynamicBullets?: boolean;\n dynamicMainBullets?: number;\n position?: \"inside\" | \"outside\"; // inside = overlay on image, outside = below image\n renderBullet?: (index: number, className: string) => React.ReactNode;\n renderFraction?: (\n currentClass: string,\n totalClass: string\n ) => React.ReactNode;\n renderProgressbar?: (progressbarFillClass: string) => React.ReactNode;\n renderScrollbar?: (scrollbarDragClass: string) => React.ReactNode;\n renderCustom?: (current: number, total: number) => React.ReactNode;\n}\n\nexport interface CarouselProps {\n children: React.ReactNode;\n // Core\n initialSlide?: number;\n direction?: SliderDirection;\n speed?: number;\n spaceBetween?: number;\n slidesPerView?: number | \"auto\";\n slidesPerGroup?: number;\n centeredSlides?: boolean;\n loop?: boolean;\n loopedSlides?: number;\n rewind?: boolean;\n effect?: SliderEffect;\n // Responsive breakpoints\n breakpoints?: Record<number, BreakpointOptions>;\n // Navigation\n navigation?: boolean | NavigationOptions;\n // Pagination\n pagination?: boolean | PaginationOptions;\n // Autoplay\n autoplay?: boolean | AutoplayOptions;\n // Interaction\n allowTouchMove?: boolean;\n grabCursor?: boolean;\n keyboard?: boolean;\n mousewheel?: boolean;\n freeMode?: boolean;\n // Styling\n className?: string;\n containerClassName?: string;\n wrapperClassName?: string;\n slideClassName?: string;\n // Image Viewer\n enableImageViewer?: boolean;\n // Callbacks\n onSlideChange?: (swiper: { activeIndex: number; realIndex: number }) => void;\n onReachBeginning?: () => void;\n onReachEnd?: () => void;\n onAutoplayStart?: () => void;\n onAutoplayStop?: () => void;\n}\n\n// ============================================================================\n// Carousel Slide Component Types\n// ============================================================================\n\nexport interface CarouselSlideProps\n extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode;\n}\n\n// ============================================================================\n// Carousel Component\n// ============================================================================\n\nexport const Carousel = React.forwardRef<HTMLDivElement, CarouselProps>(\n (\n {\n children,\n initialSlide = 0,\n direction = \"horizontal\",\n speed = 300,\n spaceBetween = 0,\n slidesPerView = 1,\n slidesPerGroup = 1,\n centeredSlides = false,\n loop = false,\n rewind = false,\n effect = \"slide\",\n breakpoints,\n navigation = false,\n pagination = false,\n autoplay = false,\n allowTouchMove = true,\n grabCursor = true,\n keyboard = false,\n mousewheel = false,\n className,\n containerClassName,\n wrapperClassName,\n slideClassName,\n enableImageViewer = false,\n onSlideChange,\n onReachBeginning,\n onReachEnd,\n onAutoplayStart,\n onAutoplayStop,\n },\n ref\n ) => {\n // Parse navigation options\n const navigationOptions: NavigationOptions =\n typeof navigation === \"boolean\"\n ? { enabled: navigation, position: \"inside\" }\n : { enabled: true, position: \"inside\", ...navigation };\n\n // Parse pagination options\n const paginationOptions: PaginationOptions =\n typeof pagination === \"boolean\"\n ? { enabled: pagination, type: \"bullets\", position: \"inside\" }\n : { enabled: true, type: \"bullets\", position: \"inside\", ...pagination };\n\n // Parse autoplay options\n const autoplayOptions: AutoplayOptions = useMemo(\n () =>\n typeof autoplay === \"boolean\"\n ? { delay: 3000, disableOnInteraction: true }\n : { delay: 3000, disableOnInteraction: true, ...autoplay },\n [autoplay]\n );\n\n // State\n const [activeIndex, setActiveIndex] = useState(initialSlide);\n const [isBeginning, setIsBeginning] = useState(initialSlide === 0);\n const [isEnd, setIsEnd] = useState(false);\n const [isDragging, setIsDragging] = useState(false);\n const [translate, setTranslate] = useState(0);\n const [isAutoplayRunning, setIsAutoplayRunning] = useState(false);\n const [showScrollbar, setShowScrollbar] = useState(false);\n const [windowWidth, setWindowWidth] = useState(\n typeof window !== \"undefined\" ? window.innerWidth : 1024\n );\n const [viewerVisible, setViewerVisible] = useState(false);\n const [viewerIndex, setViewerIndex] = useState(0);\n\n // Handle window resize for breakpoints\n useEffect(() => {\n if (!breakpoints) return;\n\n const handleResize = () => {\n setWindowWidth(window.innerWidth);\n };\n\n window.addEventListener(\"resize\", handleResize);\n return () => window.removeEventListener(\"resize\", handleResize);\n }, [breakpoints]);\n\n // Get current breakpoint values\n const currentBreakpoint = useMemo(() => {\n if (!breakpoints) {\n return { slidesPerView, spaceBetween, slidesPerGroup };\n }\n\n const breakpointKeys = Object.keys(breakpoints)\n .map(Number)\n .sort((a, b) => b - a); // Sort descending\n\n for (const breakpoint of breakpointKeys) {\n if (windowWidth >= breakpoint) {\n return {\n slidesPerView:\n breakpoints[breakpoint].slidesPerView ?? slidesPerView,\n spaceBetween: breakpoints[breakpoint].spaceBetween ?? spaceBetween,\n slidesPerGroup:\n breakpoints[breakpoint].slidesPerGroup ?? slidesPerGroup,\n };\n }\n }\n\n return { slidesPerView, spaceBetween, slidesPerGroup };\n }, [breakpoints, windowWidth, slidesPerView, spaceBetween, slidesPerGroup]);\n\n // Use breakpoint values\n const actualSlidesPerView = currentBreakpoint.slidesPerView;\n const actualSpaceBetween = currentBreakpoint.spaceBetween;\n const actualSlidesPerGroup = currentBreakpoint.slidesPerGroup;\n\n // Refs\n const containerRef = useRef<HTMLDivElement>(null);\n const wrapperRef = useRef<HTMLDivElement>(null);\n const autoplayTimerRef = useRef<number | null>(null);\n const scrollbarTimerRef = useRef<number | null>(null);\n const dragStateRef = useRef({\n startX: 0,\n startY: 0,\n currentX: 0,\n currentY: 0,\n });\n const hasDraggedRef = useRef(false);\n\n // Get slides\n const slides = Children.toArray(children).filter(\n (child) => isValidElement(child) && child.type === CarouselSlide\n );\n const totalSlides = slides.length;\n\n // Helper function to find image in children\n const findImageInChildren = useCallback(\n (\n children: React.ReactNode\n ): React.ReactElement<\n React.ImgHTMLAttributes<HTMLImageElement>\n > | null => {\n let result: React.ReactElement<\n React.ImgHTMLAttributes<HTMLImageElement>\n > | null = null;\n\n React.Children.forEach(children, (child) => {\n if (result) return;\n\n if (isValidElement(child)) {\n if (child.type === \"img\") {\n result = child as React.ReactElement<\n React.ImgHTMLAttributes<HTMLImageElement>\n >;\n } else if (\n child.props &&\n typeof child.props === \"object\" &&\n \"children\" in child.props\n ) {\n result = findImageInChildren(\n child.props.children as React.ReactNode\n );\n }\n }\n });\n\n return result;\n },\n []\n );\n\n // Extract images for ImageViewer\n const imageInfos = useMemo((): ImageInfo[] => {\n if (!enableImageViewer) return [];\n\n return slides.map((slide) => {\n const slideElement = slide as React.ReactElement<CarouselSlideProps>;\n const imgElement = findImageInChildren(slideElement.props.children);\n\n if (imgElement) {\n return {\n src: imgElement.props.src || \"\",\n alt: imgElement.props.alt || \"\",\n };\n }\n\n return { src: \"\", alt: \"\" };\n });\n }, [slides, enableImageViewer, findImageInChildren]);\n\n // Handle slide click for image viewer\n const handleSlideClick = useCallback(\n (index: number) => {\n console.log(\"Slide clicked:\", {\n index,\n enableImageViewer,\n hasSrc: !!imageInfos[index]?.src,\n hasDragged: hasDraggedRef.current,\n imageInfos,\n });\n\n // Only open viewer if not dragged\n if (\n enableImageViewer &&\n imageInfos[index]?.src &&\n !hasDraggedRef.current\n ) {\n console.log(\"Opening viewer at index:\", index);\n setViewerIndex(index);\n setViewerVisible(true);\n }\n },\n [enableImageViewer, imageInfos]\n );\n\n // Calculate visible slides\n const visibleSlides =\n actualSlidesPerView === \"auto\"\n ? 1\n : Math.min(actualSlidesPerView as number, totalSlides);\n\n // Update beginning/end state\n useEffect(() => {\n if (loop) {\n setIsBeginning(false);\n setIsEnd(false);\n } else {\n setIsBeginning(activeIndex === 0);\n setIsEnd(activeIndex >= totalSlides - visibleSlides);\n }\n }, [activeIndex, totalSlides, visibleSlides, loop]);\n\n // Slide to index\n const slideTo = useCallback(\n (index: number) => {\n let newIndex = index;\n\n if (loop) {\n // In loop mode, allow any index\n newIndex = ((index % totalSlides) + totalSlides) % totalSlides;\n } else if (rewind) {\n // In rewind mode, wrap around\n if (index < 0) newIndex = totalSlides - 1;\n else if (index >= totalSlides) newIndex = 0;\n else newIndex = index;\n } else {\n // Normal mode, clamp to bounds\n newIndex = Math.max(0, Math.min(index, totalSlides - visibleSlides));\n }\n\n setActiveIndex(newIndex);\n\n // Calculate translate\n const containerSize =\n direction === \"horizontal\"\n ? containerRef.current?.offsetWidth || 0\n : containerRef.current?.offsetHeight || 0;\n\n const slideSize = containerSize / visibleSlides;\n let newTranslate = -newIndex * (slideSize + actualSpaceBetween);\n\n if (centeredSlides && visibleSlides < totalSlides) {\n newTranslate += containerSize / 2 - slideSize / 2;\n }\n\n setTranslate(newTranslate);\n\n // Show scrollbar on slide change\n if (paginationOptions.type === \"scrollbar\") {\n setShowScrollbar(true);\n if (scrollbarTimerRef.current) {\n clearTimeout(scrollbarTimerRef.current);\n }\n scrollbarTimerRef.current = setTimeout(() => {\n setShowScrollbar(false);\n }, 1000) as unknown as number;\n }\n\n // Callbacks\n onSlideChange?.({ activeIndex: newIndex, realIndex: newIndex });\n\n if (newIndex === 0) onReachBeginning?.();\n if (newIndex >= totalSlides - visibleSlides) onReachEnd?.();\n },\n [\n totalSlides,\n visibleSlides,\n loop,\n rewind,\n direction,\n actualSpaceBetween,\n centeredSlides,\n paginationOptions.type,\n onSlideChange,\n onReachBeginning,\n onReachEnd,\n ]\n );\n\n // Navigation\n const slideNext = useCallback(() => {\n slideTo(activeIndex + actualSlidesPerGroup);\n }, [activeIndex, actualSlidesPerGroup, slideTo]);\n\n const slidePrev = useCallback(() => {\n slideTo(activeIndex - actualSlidesPerGroup);\n }, [activeIndex, actualSlidesPerGroup, slideTo]);\n\n // Autoplay\n const stopAutoplay = useCallback(() => {\n if (autoplayTimerRef.current) {\n clearInterval(autoplayTimerRef.current);\n autoplayTimerRef.current = null;\n }\n setIsAutoplayRunning(false);\n onAutoplayStop?.();\n }, [onAutoplayStop]);\n\n const startAutoplay = useCallback(() => {\n if (!autoplay) return;\n\n autoplayTimerRef.current = setInterval(() => {\n if (autoplayOptions.reverseDirection) {\n slidePrev();\n } else {\n slideNext();\n }\n\n if (autoplayOptions.stopOnLastSlide && isEnd) {\n stopAutoplay();\n }\n }, autoplayOptions.delay) as unknown as number;\n\n setIsAutoplayRunning(true);\n onAutoplayStart?.();\n }, [\n autoplayOptions,\n autoplay,\n slideNext,\n slidePrev,\n isEnd,\n onAutoplayStart,\n stopAutoplay,\n ]);\n\n // Auto-start autoplay\n useEffect(() => {\n if (autoplay) {\n startAutoplay();\n }\n return () => stopAutoplay();\n }, [autoplay, startAutoplay, stopAutoplay]);\n\n // Pause on hover\n const handleMouseEnter = useCallback(() => {\n if (autoplayOptions.pauseOnMouseEnter && isAutoplayRunning) {\n stopAutoplay();\n }\n }, [autoplayOptions.pauseOnMouseEnter, isAutoplayRunning, stopAutoplay]);\n\n const handleMouseLeave = useCallback(() => {\n if (autoplayOptions.pauseOnMouseEnter && autoplay && !isAutoplayRunning) {\n startAutoplay();\n }\n }, [\n autoplayOptions.pauseOnMouseEnter,\n autoplay,\n isAutoplayRunning,\n startAutoplay,\n ]);\n\n // Touch/drag handlers\n const handlePointerDown = useCallback(\n (e: React.PointerEvent) => {\n if (!allowTouchMove) return;\n\n try {\n e.currentTarget.setPointerCapture(e.pointerId);\n } catch (err) {\n console.error(\"Failed to capture pointer:\", err);\n }\n\n dragStateRef.current.startX = e.clientX;\n dragStateRef.current.startY = e.clientY;\n dragStateRef.current.currentX = e.clientX;\n dragStateRef.current.currentY = e.clientY;\n hasDraggedRef.current = false;\n setIsDragging(true);\n\n if (autoplayOptions.disableOnInteraction) {\n stopAutoplay();\n }\n },\n [allowTouchMove, autoplayOptions.disableOnInteraction, stopAutoplay]\n );\n\n const handlePointerMove = useCallback(\n (e: React.PointerEvent) => {\n if (!allowTouchMove) return;\n\n const startX = dragStateRef.current.startX;\n const startY = dragStateRef.current.startY;\n\n // Check if drag has started (startX/Y are set)\n if (startX === 0 && startY === 0) return;\n\n e.preventDefault();\n dragStateRef.current.currentX = e.clientX;\n dragStateRef.current.currentY = e.clientY;\n\n // Mark as dragged if moved more than 5px\n const diffX = Math.abs(e.clientX - dragStateRef.current.startX);\n const diffY = Math.abs(e.clientY - dragStateRef.current.startY);\n if (diffX > 5 || diffY > 5) {\n hasDraggedRef.current = true;\n }\n\n setIsDragging(true);\n },\n [allowTouchMove]\n );\n\n const handlePointerUp = useCallback(() => {\n const startX = dragStateRef.current.startX;\n const startY = dragStateRef.current.startY;\n\n // Check if we actually dragged\n if (startX === 0 && startY === 0) return;\n\n const diffX = dragStateRef.current.currentX - startX;\n const diffY = dragStateRef.current.currentY - startY;\n const diff = direction === \"horizontal\" ? diffX : diffY;\n\n // Determine slide action with lower threshold\n const threshold = 0;\n if (Math.abs(diff) > threshold && hasDraggedRef.current) {\n if (diff > 0) {\n // Swipe right/down = previous slide\n slidePrev();\n } else {\n // Swipe left/up = next slide\n slideNext();\n }\n } else {\n // Snap back to current\n slideTo(activeIndex);\n }\n\n // Reset after a small delay to allow onClick to check the flag\n setTimeout(() => {\n setIsDragging(false);\n dragStateRef.current.startX = 0;\n dragStateRef.current.startY = 0;\n dragStateRef.current.currentX = 0;\n dragStateRef.current.currentY = 0;\n hasDraggedRef.current = false;\n }, 50);\n }, [direction, slidePrev, slideNext, slideTo, activeIndex]);\n\n // Keyboard navigation\n useEffect(() => {\n if (!keyboard) return;\n\n const handleKeyDown = (e: KeyboardEvent) => {\n if (e.key === \"ArrowLeft\" || e.key === \"ArrowUp\") {\n e.preventDefault();\n slidePrev();\n } else if (e.key === \"ArrowRight\" || e.key === \"ArrowDown\") {\n e.preventDefault();\n slideNext();\n }\n };\n\n window.addEventListener(\"keydown\", handleKeyDown);\n return () => window.removeEventListener(\"keydown\", handleKeyDown);\n }, [keyboard, slideNext, slidePrev]);\n\n // Mousewheel navigation\n useEffect(() => {\n if (!mousewheel) return;\n\n const handleWheel = (e: WheelEvent) => {\n e.preventDefault();\n if (e.deltaY > 0) slideNext();\n else if (e.deltaY < 0) slidePrev();\n };\n\n const container = containerRef.current;\n if (container) {\n container.addEventListener(\"wheel\", handleWheel, { passive: false });\n return () => container.removeEventListener(\"wheel\", handleWheel);\n }\n }, [mousewheel, slideNext, slidePrev]);\n\n // Render pagination\n const renderPagination = () => {\n if (!paginationOptions.enabled) return null;\n\n const {\n type,\n clickable,\n dynamicBullets,\n dynamicMainBullets = 1,\n position = \"inside\",\n } = paginationOptions;\n\n const isOutside = position === \"outside\";\n\n if (type === \"bullets\") {\n const bulletsToShow = dynamicBullets\n ? Math.min(dynamicMainBullets * 2 + 1, totalSlides)\n : totalSlides;\n\n return (\n <div\n className={cn(\n \"flex items-center justify-center gap-2\",\n isOutside\n ? \"mt-4\" // Outside: margin-top for spacing\n : \"absolute bottom-4 left-1/2 -translate-x-1/2\", // Inside: overlay\n direction === \"vertical\" &&\n !isOutside &&\n \"flex-col right-4 left-auto top-1/2 -translate-y-1/2 translate-x-0 bottom-auto\"\n )}\n >\n {Array.from({ length: bulletsToShow }).map((_, i) => {\n const bulletIndex = dynamicBullets\n ? Math.max(\n 0,\n Math.min(\n i + activeIndex - dynamicMainBullets,\n totalSlides - 1\n )\n )\n : i;\n\n const isActive = bulletIndex === activeIndex;\n\n return paginationOptions.renderBullet ? (\n <React.Fragment key={bulletIndex}>\n {paginationOptions.renderBullet(\n bulletIndex,\n cn(\n \"carousel-pagination-bullet\",\n isActive && \"carousel-pagination-bullet-active\"\n )\n )}\n </React.Fragment>\n ) : (\n <button\n key={bulletIndex}\n onClick={() => clickable && slideTo(bulletIndex)}\n className={cn(\n \"rounded-full transition-all\",\n direction === \"horizontal\" ? \"w-2 h-2\" : \"w-2 h-2\",\n isActive\n ? direction === \"horizontal\"\n ? \"bg-primary w-6\"\n : \"bg-primary h-6\"\n : \"bg-muted-foreground/30 hover:bg-muted-foreground/50\",\n clickable && \"cursor-pointer\"\n )}\n aria-label={`Go to slide ${bulletIndex + 1}`}\n />\n );\n })}\n </div>\n );\n }\n\n if (type === \"fraction\") {\n return (\n <div\n className={cn(\n \"text-center text-sm text-muted-foreground bg-background/80 backdrop-blur px-3 py-1 rounded-full\",\n isOutside\n ? \"mt-4 mx-auto w-fit\" // Outside: centered with margin\n : \"absolute bottom-4 left-1/2 -translate-x-1/2\" // Inside: overlay\n )}\n >\n {paginationOptions.renderFraction ? (\n paginationOptions.renderFraction(\n \"carousel-pagination-current\",\n \"carousel-pagination-total\"\n )\n ) : (\n <>\n <span className=\"carousel-pagination-current font-semibold text-foreground\">\n {activeIndex + 1}\n </span>\n {\" / \"}\n <span className=\"carousel-pagination-total\">{totalSlides}</span>\n </>\n )}\n </div>\n );\n }\n\n if (type === \"progressbar\") {\n const progress = ((activeIndex + 1) / totalSlides) * 100;\n const isInside = paginationOptions.position === \"inside\";\n\n const handleProgressbarClick = (\n e: React.MouseEvent<HTMLDivElement>\n ) => {\n if (!clickable) return;\n const rect = e.currentTarget.getBoundingClientRect();\n const clickX = e.clientX - rect.left;\n const percentage = clickX / rect.width;\n const targetIndex = Math.floor(percentage * totalSlides);\n slideTo(Math.min(targetIndex, totalSlides - 1));\n };\n\n return (\n <div\n onClick={handleProgressbarClick}\n className={cn(\n \"w-full h-1 bg-muted rounded-full overflow-hidden\",\n isInside\n ? \"absolute bottom-0 left-0 right-0 rounded-none\"\n : \"mt-4\",\n clickable && \"cursor-pointer\"\n )}\n >\n {paginationOptions.renderProgressbar ? (\n paginationOptions.renderProgressbar(\"carousel-progressbar-fill\")\n ) : (\n <div\n className=\"carousel-progressbar-fill h-full bg-primary transition-all duration-300\"\n style={{ width: `${progress}%` }}\n />\n )}\n </div>\n );\n }\n\n if (type === \"custom\" && paginationOptions.renderCustom) {\n return (\n <div\n className={cn(\n isOutside\n ? \"mt-4 flex justify-center\" // Outside: centered with margin\n : \"absolute bottom-4 left-1/2 -translate-x-1/2\" // Inside: overlay\n )}\n >\n {paginationOptions.renderCustom(activeIndex + 1, totalSlides)}\n </div>\n );\n }\n\n if (type === \"scrollbar\") {\n const dragWidth = (1 / totalSlides) * 100;\n const scrollPosition =\n (activeIndex / (totalSlides - 1)) * (100 - dragWidth);\n\n const handleScrollbarClick = (e: React.MouseEvent<HTMLDivElement>) => {\n if (!clickable) return;\n\n // Show scrollbar on click\n setShowScrollbar(true);\n if (scrollbarTimerRef.current) {\n clearTimeout(scrollbarTimerRef.current);\n }\n\n const rect = e.currentTarget.getBoundingClientRect();\n const clickX = e.clientX - rect.left;\n const percentage = clickX / rect.width;\n const targetIndex = Math.round(percentage * (totalSlides - 1));\n slideTo(Math.max(0, Math.min(targetIndex, totalSlides - 1)));\n\n // Hide after 1s\n scrollbarTimerRef.current = setTimeout(() => {\n setShowScrollbar(false);\n }, 1000) as unknown as number;\n };\n\n return (\n <div\n onClick={handleScrollbarClick}\n className={cn(\n \"w-full h-1 bg-muted/50 rounded-full transition-opacity duration-300\",\n isOutside\n ? \"mt-4\" // Outside: margin-top for spacing\n : \"absolute bottom-0 left-1/2 -translate-x-1/2\", // Inside: overlay at bottom\n clickable && \"cursor-pointer\",\n showScrollbar ? \"opacity-100\" : \"opacity-0\"\n )}\n >\n {paginationOptions.renderScrollbar ? (\n paginationOptions.renderScrollbar(\"carousel-scrollbar-drag\")\n ) : (\n <div\n className=\"carousel-scrollbar-drag h-full bg-primary rounded-full transition-all duration-300 absolute left-0\"\n style={{\n width: `${dragWidth}%`,\n left: `${scrollPosition}%`,\n }}\n />\n )}\n </div>\n );\n }\n\n return null;\n };\n\n // Get effect transform/classes for slides\n const getSlideTransform = (index: number) => {\n const diff = index - activeIndex;\n\n switch (effect) {\n case \"fade\":\n return {\n opacity: diff === 0 ? 1 : 0,\n zIndex: diff === 0 ? 10 : 0,\n };\n case \"cube\":\n return {\n transform: `translateX(${diff * 100}%) rotateY(${diff * -90}deg)`,\n transformOrigin: diff > 0 ? \"left center\" : \"right center\",\n };\n case \"coverflow\":\n return {\n transform: `translateX(${diff * 60}%) translateZ(${Math.abs(diff) * -100}px) rotateY(${diff * -50}deg)`,\n zIndex: -Math.abs(diff),\n };\n case \"flip\":\n return {\n transform: `rotateY(${diff * 180}deg)`,\n backfaceVisibility: \"hidden\" as const,\n };\n case \"cards\":\n return {\n transform: `translateX(${diff * 50}px) translateZ(${-Math.abs(diff) * 100}px) scale(${1 - Math.abs(diff) * 0.2})`,\n opacity: diff === 0 ? 1 : 0.5,\n zIndex: 100 - Math.abs(diff) * 10,\n transition: \"all 0.5s ease\",\n };\n default:\n return {};\n }\n };\n\n return (\n <>\n <div\n ref={ref}\n className={cn(\"carousel-container\", containerClassName, className)}\n onMouseEnter={handleMouseEnter}\n onMouseLeave={handleMouseLeave}\n >\n <div\n ref={containerRef}\n className={cn(\n \"carousel relative overflow-hidden\",\n (effect === \"fade\" ||\n effect === \"cube\" ||\n effect === \"flip\" ||\n effect === \"cards\") &&\n \"aspect-4/3\",\n effect === \"coverflow\" && \"aspect-4/2 rounded-xl\",\n direction === \"vertical\" && effect === \"slide\" && \"h-full\",\n grabCursor && allowTouchMove && !isDragging && \"cursor-grab\",\n isDragging && \"cursor-grabbing\"\n )}\n >\n {/* Wrapper */}\n <div\n ref={wrapperRef}\n className={cn(\n \"carousel-wrapper select-none\",\n effect === \"slide\" && \"flex\",\n direction === \"vertical\" &&\n effect === \"slide\" &&\n \"flex-col h-full\",\n effect !== \"slide\" && \"relative\",\n wrapperClassName\n )}\n style={{\n transform:\n effect === \"slide\"\n ? direction === \"horizontal\"\n ? `translateX(${translate}px)`\n : `translateY(${translate}px)`\n : undefined,\n transition: isDragging ? \"none\" : `transform ${speed}ms ease`,\n gap: effect === \"slide\" ? `${actualSpaceBetween}px` : undefined,\n perspective:\n effect !== \"slide\" && effect !== \"fade\"\n ? \"1200px\"\n : undefined,\n touchAction: allowTouchMove ? \"none\" : \"auto\",\n height:\n direction === \"vertical\" && effect === \"slide\"\n ? \"100%\"\n : undefined,\n }}\n onPointerDown={handlePointerDown}\n onPointerMove={handlePointerMove}\n onPointerUp={handlePointerUp}\n onPointerCancel={handlePointerUp}\n >\n {slides.map((slide, index) => {\n const isActive = index === activeIndex;\n const slideElement =\n slide as React.ReactElement<CarouselSlideProps>;\n\n return cloneElement(slideElement, {\n key: index,\n className: cn(\n \"carousel-slide\",\n slideClassName,\n slideElement.props.className,\n effect !== \"slide\" && \"absolute inset-0\",\n effect === \"fade\" && \"transition-opacity duration-300\",\n effect !== \"slide\" &&\n effect !== \"fade\" &&\n \"transition-all duration-500\",\n enableImageViewer &&\n imageInfos[index]?.src &&\n \"cursor-pointer\"\n ),\n style: {\n flex:\n effect === \"slide\"\n ? direction === \"vertical\"\n ? `0 0 100%`\n : `0 0 calc(${100 / visibleSlides}% - ${(actualSpaceBetween * (visibleSlides - 1)) / visibleSlides}px)`\n : undefined,\n minWidth:\n effect === \"slide\" && direction === \"horizontal\"\n ? 0\n : undefined,\n minHeight:\n effect === \"slide\" && direction === \"vertical\"\n ? 0\n : undefined,\n height:\n direction === \"vertical\" && effect === \"slide\"\n ? \"100%\"\n : undefined,\n userSelect: \"none\",\n // @ts-expect-error - WebkitUserDrag is not in CSSProperties but is valid CSS\n WebkitUserDrag: \"none\",\n ...(effect !== \"slide\" ? getSlideTransform(index) : {}),\n ...slideElement.props.style,\n } as React.CSSProperties,\n onClick: (e: React.MouseEvent) => {\n e.stopPropagation();\n handleSlideClick(index);\n },\n onDragStart: (e: React.DragEvent) => e.preventDefault(),\n \"data-active\": isActive,\n \"data-index\": index,\n } as Partial<CarouselSlideProps>);\n })}\n </div>\n\n {/* Pagination - Inside only (overlay on slider) */}\n {paginationOptions.enabled &&\n paginationOptions.position !== \"outside\" &&\n renderPagination()}\n\n {/* Navigation - Inside (overlay on slider) */}\n {navigationOptions.enabled &&\n navigationOptions.position === \"inside\" && (\n <>\n <button\n onClick={slidePrev}\n disabled={!loop && !rewind && isBeginning}\n className={cn(\n \"absolute z-10 w-10 h-10 rounded-full bg-background/80 backdrop-blur shadow-lg flex items-center justify-center transition-all hover:bg-background disabled:opacity-30 disabled:cursor-not-allowed\",\n direction === \"horizontal\"\n ? \"left-4 top-1/2 -translate-y-1/2\"\n : \"top-4 left-1/2 -translate-x-1/2\"\n )}\n aria-label=\"Previous slide\"\n >\n {navigationOptions.prevEl ||\n (direction === \"horizontal\" ? (\n <ChevronLeft className=\"w-5 h-5\" />\n ) : (\n <ChevronUp className=\"w-5 h-5\" />\n ))}\n </button>\n <button\n onClick={slideNext}\n disabled={!loop && !rewind && isEnd}\n className={cn(\n \"absolute z-10 w-10 h-10 rounded-full bg-background/80 backdrop-blur shadow-lg flex items-center justify-center transition-all hover:bg-background disabled:opacity-30 disabled:cursor-not-allowed\",\n direction === \"horizontal\"\n ? \"right-4 top-1/2 -translate-y-1/2\"\n : \"bottom-4 left-1/2 -translate-x-1/2\"\n )}\n aria-label=\"Next slide\"\n >\n {navigationOptions.nextEl ||\n (direction === \"horizontal\" ? (\n <ChevronRight className=\"w-5 h-5\" />\n ) : (\n <ChevronDown className=\"w-5 h-5\" />\n ))}\n </button>\n </>\n )}\n </div>\n\n {/* Pagination - Outside (below slider) */}\n {paginationOptions.enabled &&\n paginationOptions.position === \"outside\" &&\n renderPagination()}\n </div>\n\n {/* Image Viewer */}\n {enableImageViewer && imageInfos.length > 0 && (\n <ImageViewer\n images={imageInfos}\n visible={viewerVisible}\n onClose={() => {\n console.log(\"Closing viewer\");\n setViewerVisible(false);\n }}\n activeIndex={viewerIndex}\n onIndexChange={setViewerIndex}\n />\n )}\n {/* {enableImageViewer && (\n <div\n style={{\n position: \"fixed\",\n top: 10,\n right: 10,\n background: \"white\",\n padding: \"10px\",\n zIndex: 9999,\n fontSize: \"12px\",\n }}\n >\n Debug: visible={String(viewerVisible)}, images={imageInfos.length},\n index={viewerIndex}\n </div>\n )} */}\n </>\n );\n }\n);\n\nCarousel.displayName = \"Carousel\";\n\n// ============================================================================\n// Carousel Slide Component\n// ============================================================================\n\nexport const CarouselSlide = React.forwardRef<\n HTMLDivElement,\n CarouselSlideProps\n>(({ children, className, style, ...props }, ref) => {\n return (\n <div ref={ref} className={className} style={style} {...props}>\n {children}\n </div>\n );\n});\n\nCarouselSlide.displayName = \"CarouselSlide\";\n\nexport default Carousel;\n"],"names":["Carousel","React","children","initialSlide","direction","speed","spaceBetween","slidesPerView","slidesPerGroup","centeredSlides","loop","rewind","effect","breakpoints","navigation","pagination","autoplay","allowTouchMove","grabCursor","keyboard","mousewheel","className","containerClassName","wrapperClassName","slideClassName","enableImageViewer","onSlideChange","onReachBeginning","onReachEnd","onAutoplayStart","onAutoplayStop","ref","navigationOptions","paginationOptions","autoplayOptions","useMemo","activeIndex","setActiveIndex","useState","isBeginning","setIsBeginning","isEnd","setIsEnd","isDragging","setIsDragging","translate","setTranslate","isAutoplayRunning","setIsAutoplayRunning","showScrollbar","setShowScrollbar","windowWidth","setWindowWidth","viewerVisible","setViewerVisible","viewerIndex","setViewerIndex","useEffect","handleResize","currentBreakpoint","breakpointKeys","a","b","breakpoint","actualSlidesPerView","actualSpaceBetween","actualSlidesPerGroup","containerRef","useRef","wrapperRef","autoplayTimerRef","scrollbarTimerRef","dragStateRef","hasDraggedRef","slides","Children","child","isValidElement","CarouselSlide","totalSlides","findImageInChildren","useCallback","result","imageInfos","slide","imgElement","handleSlideClick","index","visibleSlides","slideTo","newIndex","containerSize","slideSize","newTranslate","slideNext","slidePrev","stopAutoplay","startAutoplay","handleMouseEnter","handleMouseLeave","handlePointerDown","e","err","handlePointerMove","startX","startY","diffX","diffY","handlePointerUp","diff","handleKeyDown","handleWheel","container","renderPagination","type","clickable","dynamicBullets","dynamicMainBullets","position","isOutside","bulletsToShow","jsx","cn","_","i","bulletIndex","isActive","jsxs","Fragment","progress","isInside","rect","percentage","targetIndex","dragWidth","scrollPosition","getSlideTransform","slideElement","cloneElement","ChevronLeft","ChevronUp","ChevronRight","ChevronDown","ImageViewer","style","props"],"mappings":"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"}
1
+ {"version":3,"file":"Carousel.js","sources":["../../../../src/components/Carousel/Carousel.tsx"],"sourcesContent":["import React, {\n useState,\n useEffect,\n useRef,\n useCallback,\n useMemo,\n Children,\n isValidElement,\n cloneElement,\n} from \"react\";\nimport {\n ChevronLeft,\n ChevronRight,\n ChevronUp,\n ChevronDown,\n} from \"lucide-react\";\nimport { cn } from \"@dsui/ui/lib/utils\";\nimport { ImageViewer } from \"../ImageViewer\";\nimport type { ImageInfo } from \"../ImageViewer\";\n\n// ============================================================================\n// Types\n// ============================================================================\n\nexport type SliderEffect =\n | \"slide\"\n | \"fade\"\n | \"cube\"\n | \"coverflow\"\n | \"flip\"\n | \"cards\";\n\nexport type SliderDirection = \"horizontal\" | \"vertical\";\n\nexport type PaginationType =\n | \"bullets\"\n | \"fraction\"\n | \"progressbar\"\n | \"scrollbar\"\n | \"custom\";\n\nexport interface AutoplayOptions {\n delay?: number;\n disableOnInteraction?: boolean;\n pauseOnMouseEnter?: boolean;\n reverseDirection?: boolean;\n stopOnLastSlide?: boolean;\n}\n\nexport interface BreakpointOptions {\n slidesPerView?: number;\n spaceBetween?: number;\n slidesPerGroup?: number;\n}\n\nexport interface NavigationOptions {\n enabled?: boolean;\n prevEl?: React.ReactNode;\n nextEl?: React.ReactNode;\n hideOnClick?: boolean;\n position?: \"inside\" | \"outside\"; // inside = overlay on image, outside = beside image\n}\n\nexport interface PaginationOptions {\n enabled?: boolean;\n type?: PaginationType;\n clickable?: boolean;\n dynamicBullets?: boolean;\n dynamicMainBullets?: number;\n position?: \"inside\" | \"outside\"; // inside = overlay on image, outside = below image\n renderBullet?: (index: number, className: string) => React.ReactNode;\n renderFraction?: (\n currentClass: string,\n totalClass: string\n ) => React.ReactNode;\n renderProgressbar?: (progressbarFillClass: string) => React.ReactNode;\n renderScrollbar?: (scrollbarDragClass: string) => React.ReactNode;\n renderCustom?: (current: number, total: number) => React.ReactNode;\n}\n\nexport interface CarouselProps {\n children: React.ReactNode;\n // Core\n initialSlide?: number;\n direction?: SliderDirection;\n speed?: number;\n spaceBetween?: number;\n slidesPerView?: number | \"auto\";\n slidesPerGroup?: number;\n centeredSlides?: boolean;\n loop?: boolean;\n loopedSlides?: number;\n rewind?: boolean;\n effect?: SliderEffect;\n // Responsive breakpoints\n breakpoints?: Record<number, BreakpointOptions>;\n // Navigation\n navigation?: boolean | NavigationOptions;\n // Pagination\n pagination?: boolean | PaginationOptions;\n // Autoplay\n autoplay?: boolean | AutoplayOptions;\n // Interaction\n allowTouchMove?: boolean;\n grabCursor?: boolean;\n keyboard?: boolean;\n mousewheel?: boolean;\n freeMode?: boolean;\n // Styling\n className?: string;\n containerClassName?: string;\n wrapperClassName?: string;\n slideClassName?: string;\n // Image Viewer\n enableImageViewer?: boolean;\n // Callbacks\n onSlideChange?: (swiper: { activeIndex: number; realIndex: number }) => void;\n onReachBeginning?: () => void;\n onReachEnd?: () => void;\n onAutoplayStart?: () => void;\n onAutoplayStop?: () => void;\n}\n\n// ============================================================================\n// Carousel Slide Component Types\n// ============================================================================\n\nexport interface CarouselSlideProps\n extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode;\n}\n\n// ============================================================================\n// Carousel Component\n// ============================================================================\n\nexport const Carousel = React.forwardRef<HTMLDivElement, CarouselProps>(\n (\n {\n children,\n initialSlide = 0,\n direction = \"horizontal\",\n speed = 300,\n spaceBetween = 0,\n slidesPerView = 1,\n slidesPerGroup = 1,\n centeredSlides = false,\n loop = false,\n rewind = false,\n effect = \"slide\",\n breakpoints,\n navigation = false,\n pagination = false,\n autoplay = false,\n allowTouchMove = true,\n grabCursor = true,\n keyboard = false,\n mousewheel = false,\n className,\n containerClassName,\n wrapperClassName,\n slideClassName,\n enableImageViewer = false,\n onSlideChange,\n onReachBeginning,\n onReachEnd,\n onAutoplayStart,\n onAutoplayStop,\n },\n ref\n ) => {\n // Parse navigation options\n const navigationOptions: NavigationOptions =\n typeof navigation === \"boolean\"\n ? { enabled: navigation, position: \"inside\" }\n : { enabled: true, position: \"inside\", ...navigation };\n\n // Parse pagination options\n const paginationOptions: PaginationOptions =\n typeof pagination === \"boolean\"\n ? { enabled: pagination, type: \"bullets\", position: \"inside\" }\n : { enabled: true, type: \"bullets\", position: \"inside\", ...pagination };\n\n // Parse autoplay options\n const autoplayOptions: AutoplayOptions = useMemo(\n () =>\n typeof autoplay === \"boolean\"\n ? { delay: 3000, disableOnInteraction: true }\n : { delay: 3000, disableOnInteraction: true, ...autoplay },\n [autoplay]\n );\n\n // State\n const [activeIndex, setActiveIndex] = useState(initialSlide);\n const [isBeginning, setIsBeginning] = useState(initialSlide === 0);\n const [isEnd, setIsEnd] = useState(false);\n const [isDragging, setIsDragging] = useState(false);\n const [translate, setTranslate] = useState(0);\n const [isAutoplayRunning, setIsAutoplayRunning] = useState(false);\n const [showScrollbar, setShowScrollbar] = useState(false);\n const [windowWidth, setWindowWidth] = useState(\n typeof window !== \"undefined\" ? window.innerWidth : 1024\n );\n const [viewerVisible, setViewerVisible] = useState(false);\n const [viewerIndex, setViewerIndex] = useState(0);\n\n // Handle window resize for breakpoints\n useEffect(() => {\n if (!breakpoints) return;\n\n const handleResize = () => {\n setWindowWidth(window.innerWidth);\n };\n\n window.addEventListener(\"resize\", handleResize);\n return () => window.removeEventListener(\"resize\", handleResize);\n }, [breakpoints]);\n\n // Get current breakpoint values\n const currentBreakpoint = useMemo(() => {\n if (!breakpoints) {\n return { slidesPerView, spaceBetween, slidesPerGroup };\n }\n\n const breakpointKeys = Object.keys(breakpoints)\n .map(Number)\n .sort((a, b) => b - a); // Sort descending\n\n for (const breakpoint of breakpointKeys) {\n if (windowWidth >= breakpoint) {\n return {\n slidesPerView:\n breakpoints[breakpoint].slidesPerView ?? slidesPerView,\n spaceBetween: breakpoints[breakpoint].spaceBetween ?? spaceBetween,\n slidesPerGroup:\n breakpoints[breakpoint].slidesPerGroup ?? slidesPerGroup,\n };\n }\n }\n\n return { slidesPerView, spaceBetween, slidesPerGroup };\n }, [breakpoints, windowWidth, slidesPerView, spaceBetween, slidesPerGroup]);\n\n // Use breakpoint values\n const actualSlidesPerView = currentBreakpoint.slidesPerView;\n const actualSpaceBetween = currentBreakpoint.spaceBetween;\n const actualSlidesPerGroup = currentBreakpoint.slidesPerGroup;\n\n // Refs\n const containerRef = useRef<HTMLDivElement>(null);\n const wrapperRef = useRef<HTMLDivElement>(null);\n const autoplayTimerRef = useRef<number | null>(null);\n const scrollbarTimerRef = useRef<number | null>(null);\n const dragStateRef = useRef({\n startX: 0,\n startY: 0,\n currentX: 0,\n currentY: 0,\n });\n const hasDraggedRef = useRef(false);\n\n // Get slides\n const slides = Children.toArray(children).filter(\n (child) => isValidElement(child) && child.type === CarouselSlide\n );\n const totalSlides = slides.length;\n\n // Helper function to find image in children\n const findImageInChildren = useCallback(\n (\n children: React.ReactNode\n ): React.ReactElement<\n React.ImgHTMLAttributes<HTMLImageElement>\n > | null => {\n let result: React.ReactElement<\n React.ImgHTMLAttributes<HTMLImageElement>\n > | null = null;\n\n React.Children.forEach(children, (child) => {\n if (result) return;\n\n if (isValidElement(child)) {\n if (child.type === \"img\") {\n result = child as React.ReactElement<\n React.ImgHTMLAttributes<HTMLImageElement>\n >;\n } else if (\n child.props &&\n typeof child.props === \"object\" &&\n \"children\" in child.props\n ) {\n result = findImageInChildren(\n child.props.children as React.ReactNode\n );\n }\n }\n });\n\n return result;\n },\n []\n );\n\n // Extract images for ImageViewer\n const imageInfos = useMemo((): ImageInfo[] => {\n if (!enableImageViewer) return [];\n\n return slides.map((slide) => {\n const slideElement = slide as React.ReactElement<CarouselSlideProps>;\n const imgElement = findImageInChildren(slideElement.props.children);\n\n if (imgElement) {\n return {\n src: imgElement.props.src || \"\",\n alt: imgElement.props.alt || \"\",\n };\n }\n\n return { src: \"\", alt: \"\" };\n });\n }, [slides, enableImageViewer, findImageInChildren]);\n\n // Handle slide click for image viewer\n const handleSlideClick = useCallback(\n (index: number) => {\n console.log(\"Slide clicked:\", {\n index,\n enableImageViewer,\n hasSrc: !!imageInfos[index]?.src,\n hasDragged: hasDraggedRef.current,\n imageInfos,\n });\n\n // Only open viewer if not dragged\n if (\n enableImageViewer &&\n imageInfos[index]?.src &&\n !hasDraggedRef.current\n ) {\n console.log(\"Opening viewer at index:\", index);\n setViewerIndex(index);\n setViewerVisible(true);\n }\n },\n [enableImageViewer, imageInfos]\n );\n\n // Calculate visible slides\n const visibleSlides =\n actualSlidesPerView === \"auto\"\n ? 1\n : Math.min(actualSlidesPerView as number, totalSlides);\n\n // Update beginning/end state\n useEffect(() => {\n if (loop) {\n setIsBeginning(false);\n setIsEnd(false);\n } else {\n setIsBeginning(activeIndex === 0);\n setIsEnd(activeIndex >= totalSlides - visibleSlides);\n }\n }, [activeIndex, totalSlides, visibleSlides, loop]);\n\n // Slide to index\n const slideTo = useCallback(\n (index: number) => {\n let newIndex = index;\n\n if (loop) {\n // In loop mode, allow any index\n newIndex = ((index % totalSlides) + totalSlides) % totalSlides;\n } else if (rewind) {\n // In rewind mode, wrap around\n if (index < 0) newIndex = totalSlides - 1;\n else if (index >= totalSlides) newIndex = 0;\n else newIndex = index;\n } else {\n // Normal mode, clamp to bounds\n newIndex = Math.max(0, Math.min(index, totalSlides - visibleSlides));\n }\n\n setActiveIndex(newIndex);\n\n // Calculate translate\n const containerSize =\n direction === \"horizontal\"\n ? containerRef.current?.offsetWidth || 0\n : containerRef.current?.offsetHeight || 0;\n\n const slideSize = containerSize / visibleSlides;\n let newTranslate = -newIndex * (slideSize + actualSpaceBetween);\n\n if (centeredSlides && visibleSlides < totalSlides) {\n newTranslate += containerSize / 2 - slideSize / 2;\n }\n\n setTranslate(newTranslate);\n\n // Show scrollbar on slide change\n if (paginationOptions.type === \"scrollbar\") {\n setShowScrollbar(true);\n if (scrollbarTimerRef.current) {\n clearTimeout(scrollbarTimerRef.current);\n }\n scrollbarTimerRef.current = setTimeout(() => {\n setShowScrollbar(false);\n }, 1000) as unknown as number;\n }\n\n // Callbacks\n onSlideChange?.({ activeIndex: newIndex, realIndex: newIndex });\n\n if (newIndex === 0) onReachBeginning?.();\n if (newIndex >= totalSlides - visibleSlides) onReachEnd?.();\n },\n [\n totalSlides,\n visibleSlides,\n loop,\n rewind,\n direction,\n actualSpaceBetween,\n centeredSlides,\n paginationOptions.type,\n onSlideChange,\n onReachBeginning,\n onReachEnd,\n ]\n );\n\n // Navigation\n const slideNext = useCallback(() => {\n slideTo(activeIndex + actualSlidesPerGroup);\n }, [activeIndex, actualSlidesPerGroup, slideTo]);\n\n const slidePrev = useCallback(() => {\n slideTo(activeIndex - actualSlidesPerGroup);\n }, [activeIndex, actualSlidesPerGroup, slideTo]);\n\n // Autoplay\n const stopAutoplay = useCallback(() => {\n if (autoplayTimerRef.current) {\n clearInterval(autoplayTimerRef.current);\n autoplayTimerRef.current = null;\n }\n setIsAutoplayRunning(false);\n onAutoplayStop?.();\n }, [onAutoplayStop]);\n\n const startAutoplay = useCallback(() => {\n if (!autoplay) return;\n\n autoplayTimerRef.current = setInterval(() => {\n if (autoplayOptions.reverseDirection) {\n slidePrev();\n } else {\n slideNext();\n }\n\n if (autoplayOptions.stopOnLastSlide && isEnd) {\n stopAutoplay();\n }\n }, autoplayOptions.delay) as unknown as number;\n\n setIsAutoplayRunning(true);\n onAutoplayStart?.();\n }, [\n autoplayOptions,\n autoplay,\n slideNext,\n slidePrev,\n isEnd,\n onAutoplayStart,\n stopAutoplay,\n ]);\n\n // Auto-start autoplay\n useEffect(() => {\n if (autoplay) {\n startAutoplay();\n }\n return () => stopAutoplay();\n }, [autoplay, startAutoplay, stopAutoplay]);\n\n // Pause on hover\n const handleMouseEnter = useCallback(() => {\n if (autoplayOptions.pauseOnMouseEnter && isAutoplayRunning) {\n stopAutoplay();\n }\n }, [autoplayOptions.pauseOnMouseEnter, isAutoplayRunning, stopAutoplay]);\n\n const handleMouseLeave = useCallback(() => {\n if (autoplayOptions.pauseOnMouseEnter && autoplay && !isAutoplayRunning) {\n startAutoplay();\n }\n }, [\n autoplayOptions.pauseOnMouseEnter,\n autoplay,\n isAutoplayRunning,\n startAutoplay,\n ]);\n\n // Touch/drag handlers\n const handlePointerDown = useCallback(\n (e: React.PointerEvent) => {\n if (!allowTouchMove) return;\n\n try {\n e.currentTarget.setPointerCapture(e.pointerId);\n } catch (err) {\n console.error(\"Failed to capture pointer:\", err);\n }\n\n dragStateRef.current.startX = e.clientX;\n dragStateRef.current.startY = e.clientY;\n dragStateRef.current.currentX = e.clientX;\n dragStateRef.current.currentY = e.clientY;\n hasDraggedRef.current = false;\n setIsDragging(true);\n\n if (autoplayOptions.disableOnInteraction) {\n stopAutoplay();\n }\n },\n [allowTouchMove, autoplayOptions.disableOnInteraction, stopAutoplay]\n );\n\n const handlePointerMove = useCallback(\n (e: React.PointerEvent) => {\n if (!allowTouchMove) return;\n\n const startX = dragStateRef.current.startX;\n const startY = dragStateRef.current.startY;\n\n // Check if drag has started (startX/Y are set)\n if (startX === 0 && startY === 0) return;\n\n e.preventDefault();\n dragStateRef.current.currentX = e.clientX;\n dragStateRef.current.currentY = e.clientY;\n\n // Mark as dragged if moved more than 5px\n const diffX = Math.abs(e.clientX - dragStateRef.current.startX);\n const diffY = Math.abs(e.clientY - dragStateRef.current.startY);\n if (diffX > 5 || diffY > 5) {\n hasDraggedRef.current = true;\n }\n\n setIsDragging(true);\n },\n [allowTouchMove]\n );\n\n const handlePointerUp = useCallback(() => {\n const startX = dragStateRef.current.startX;\n const startY = dragStateRef.current.startY;\n\n // Check if we actually dragged\n if (startX === 0 && startY === 0) return;\n\n const diffX = dragStateRef.current.currentX - startX;\n const diffY = dragStateRef.current.currentY - startY;\n const diff = direction === \"horizontal\" ? diffX : diffY;\n\n // Determine slide action with lower threshold\n const threshold = 0;\n if (Math.abs(diff) > threshold && hasDraggedRef.current) {\n if (diff > 0) {\n // Swipe right/down = previous slide\n slidePrev();\n } else {\n // Swipe left/up = next slide\n slideNext();\n }\n } else {\n // Snap back to current\n slideTo(activeIndex);\n }\n\n // Reset after a small delay to allow onClick to check the flag\n setTimeout(() => {\n setIsDragging(false);\n dragStateRef.current.startX = 0;\n dragStateRef.current.startY = 0;\n dragStateRef.current.currentX = 0;\n dragStateRef.current.currentY = 0;\n hasDraggedRef.current = false;\n }, 50);\n }, [direction, slidePrev, slideNext, slideTo, activeIndex]);\n\n // Keyboard navigation\n useEffect(() => {\n if (!keyboard) return;\n\n const handleKeyDown = (e: KeyboardEvent) => {\n if (e.key === \"ArrowLeft\" || e.key === \"ArrowUp\") {\n e.preventDefault();\n slidePrev();\n } else if (e.key === \"ArrowRight\" || e.key === \"ArrowDown\") {\n e.preventDefault();\n slideNext();\n }\n };\n\n window.addEventListener(\"keydown\", handleKeyDown);\n return () => window.removeEventListener(\"keydown\", handleKeyDown);\n }, [keyboard, slideNext, slidePrev]);\n\n // Mousewheel navigation\n useEffect(() => {\n if (!mousewheel) return;\n\n const handleWheel = (e: WheelEvent) => {\n e.preventDefault();\n if (e.deltaY > 0) slideNext();\n else if (e.deltaY < 0) slidePrev();\n };\n\n const container = containerRef.current;\n if (container) {\n container.addEventListener(\"wheel\", handleWheel, { passive: false });\n return () => container.removeEventListener(\"wheel\", handleWheel);\n }\n }, [mousewheel, slideNext, slidePrev]);\n\n // Render pagination\n const renderPagination = () => {\n if (!paginationOptions.enabled) return null;\n\n const {\n type,\n clickable,\n dynamicBullets,\n dynamicMainBullets = 1,\n position = \"inside\",\n } = paginationOptions;\n\n const isOutside = position === \"outside\";\n\n if (type === \"bullets\") {\n const bulletsToShow = dynamicBullets\n ? Math.min(dynamicMainBullets * 2 + 1, totalSlides)\n : totalSlides;\n\n return (\n <div\n className={cn(\n \"ds:flex ds:items-center ds:justify-center ds:gap-2\",\n isOutside\n ? \"ds:mt-4\" // Outside: margin-top for spacing\n : \"ds:absolute ds:bottom-4 ds:left-1/2 ds:-translate-x-1/2\", // Inside: overlay\n direction === \"vertical\" &&\n !isOutside &&\n \"ds:flex-col ds:right-4 ds:left-auto ds:top-1/2 ds:-translate-y-1/2 ds:translate-x-0 ds:bottom-auto\"\n )}\n >\n {Array.from({ length: bulletsToShow }).map((_, i) => {\n const bulletIndex = dynamicBullets\n ? Math.max(\n 0,\n Math.min(\n i + activeIndex - dynamicMainBullets,\n totalSlides - 1\n )\n )\n : i;\n\n const isActive = bulletIndex === activeIndex;\n\n return paginationOptions.renderBullet ? (\n <React.Fragment key={bulletIndex}>\n {paginationOptions.renderBullet(\n bulletIndex,\n cn(\n \"ds:carousel-pagination-bullet\",\n isActive && \"ds:carousel-pagination-bullet-active\"\n )\n )}\n </React.Fragment>\n ) : (\n <button\n key={bulletIndex}\n onClick={() => clickable && slideTo(bulletIndex)}\n className={cn(\n \"ds:rounded-full ds:transition-all\",\n direction === \"horizontal\" ? \"ds:w-2 ds:h-2\" : \"ds:w-2 ds:h-2\",\n isActive\n ? direction === \"horizontal\"\n ? \"ds:bg-primary ds:w-6\"\n : \"ds:bg-primary ds:h-6\"\n : \"ds:bg-muted-foreground/30 ds:hover:bg-muted-foreground/50\",\n clickable && \"ds:cursor-pointer\"\n )}\n aria-label={`Go to slide ${bulletIndex + 1}`}\n />\n );\n })}\n </div>\n );\n }\n\n if (type === \"fraction\") {\n return (\n <div\n className={cn(\n \"ds:text-center ds:text-sm ds:text-muted-foreground ds:bg-background/80 ds:backdrop-blur ds:px-3 ds:py-1 ds:rounded-full\",\n isOutside\n ? \"ds:mt-4 ds:mx-auto ds:w-fit\" // Outside: centered with margin\n : \"ds:absolute ds:bottom-4 ds:left-1/2 ds:-translate-x-1/2\" // Inside: overlay\n )}\n >\n {paginationOptions.renderFraction ? (\n paginationOptions.renderFraction(\n \"carousel-pagination-current\",\n \"carousel-pagination-total\"\n )\n ) : (\n <>\n <span className=\"ds:carousel-pagination-current ds:font-semibold ds:text-foreground\">\n {activeIndex + 1}\n </span>\n {\" / \"}\n <span className=\"ds:carousel-pagination-total\">{totalSlides}</span>\n </>\n )}\n </div>\n );\n }\n\n if (type === \"progressbar\") {\n const progress = ((activeIndex + 1) / totalSlides) * 100;\n const isInside = paginationOptions.position === \"inside\";\n\n const handleProgressbarClick = (\n e: React.MouseEvent<HTMLDivElement>\n ) => {\n if (!clickable) return;\n const rect = e.currentTarget.getBoundingClientRect();\n const clickX = e.clientX - rect.left;\n const percentage = clickX / rect.width;\n const targetIndex = Math.floor(percentage * totalSlides);\n slideTo(Math.min(targetIndex, totalSlides - 1));\n };\n\n return (\n <div\n onClick={handleProgressbarClick}\n className={cn(\n \"ds:w-full ds:h-1 ds:bg-muted ds:rounded-full ds:overflow-hidden\",\n isInside\n ? \"ds:absolute ds:bottom-0 ds:left-0 ds:right-0 ds:rounded-none\"\n : \"ds:mt-4\",\n clickable && \"ds:cursor-pointer\"\n )}\n >\n {paginationOptions.renderProgressbar ? (\n paginationOptions.renderProgressbar(\"carousel-progressbar-fill\")\n ) : (\n <div\n className=\"ds:carousel-progressbar-fill ds:h-full ds:bg-primary ds:transition-all ds:duration-300\"\n style={{ width: `${progress}%` }}\n />\n )}\n </div>\n );\n }\n\n if (type === \"custom\" && paginationOptions.renderCustom) {\n return (\n <div\n className={cn(\n isOutside\n ? \"ds:mt-4 ds:flex ds:justify-center\" // Outside: centered with margin\n : \"ds:absolute ds:bottom-4 ds:left-1/2 ds:-translate-x-1/2\" // Inside: overlay\n )}\n >\n {paginationOptions.renderCustom(activeIndex + 1, totalSlides)}\n </div>\n );\n }\n\n if (type === \"scrollbar\") {\n const dragWidth = (1 / totalSlides) * 100;\n const scrollPosition =\n (activeIndex / (totalSlides - 1)) * (100 - dragWidth);\n\n const handleScrollbarClick = (e: React.MouseEvent<HTMLDivElement>) => {\n if (!clickable) return;\n\n // Show scrollbar on click\n setShowScrollbar(true);\n if (scrollbarTimerRef.current) {\n clearTimeout(scrollbarTimerRef.current);\n }\n\n const rect = e.currentTarget.getBoundingClientRect();\n const clickX = e.clientX - rect.left;\n const percentage = clickX / rect.width;\n const targetIndex = Math.round(percentage * (totalSlides - 1));\n slideTo(Math.max(0, Math.min(targetIndex, totalSlides - 1)));\n\n // Hide after 1s\n scrollbarTimerRef.current = setTimeout(() => {\n setShowScrollbar(false);\n }, 1000) as unknown as number;\n };\n\n return (\n <div\n onClick={handleScrollbarClick}\n className={cn(\n \"ds:w-full ds:h-1 ds:bg-muted/50 ds:rounded-full ds:transition-opacity ds:duration-300\",\n isOutside\n ? \"ds:mt-4\" // Outside: margin-top for spacing\n : \"ds:absolute ds:bottom-0 ds:left-1/2 ds:-translate-x-1/2\", // Inside: overlay at bottom\n clickable && \"ds:cursor-pointer\",\n showScrollbar ? \"ds:opacity-100\" : \"ds:opacity-0\"\n )}\n >\n {paginationOptions.renderScrollbar ? (\n paginationOptions.renderScrollbar(\"carousel-scrollbar-drag\")\n ) : (\n <div\n className=\"ds:carousel-scrollbar-drag ds:h-full ds:bg-primary ds:rounded-full ds:transition-all ds:duration-300 ds:absolute ds:left-0\"\n style={{\n width: `${dragWidth}%`,\n left: `${scrollPosition}%`,\n }}\n />\n )}\n </div>\n );\n }\n\n return null;\n };\n\n // Get effect transform/classes for slides\n const getSlideTransform = (index: number) => {\n const diff = index - activeIndex;\n\n switch (effect) {\n case \"fade\":\n return {\n opacity: diff === 0 ? 1 : 0,\n zIndex: diff === 0 ? 10 : 0,\n };\n case \"cube\":\n return {\n transform: `translateX(${diff * 100}%) rotateY(${diff * -90}deg)`,\n transformOrigin: diff > 0 ? \"left center\" : \"right center\",\n };\n case \"coverflow\":\n return {\n transform: `translateX(${diff * 60}%) translateZ(${Math.abs(diff) * -100}px) rotateY(${diff * -50}deg)`,\n zIndex: -Math.abs(diff),\n };\n case \"flip\":\n return {\n transform: `rotateY(${diff * 180}deg)`,\n backfaceVisibility: \"hidden\" as const,\n };\n case \"cards\":\n return {\n transform: `translateX(${diff * 50}px) translateZ(${-Math.abs(diff) * 100}px) scale(${1 - Math.abs(diff) * 0.2})`,\n opacity: diff === 0 ? 1 : 0.5,\n zIndex: 100 - Math.abs(diff) * 10,\n transition: \"all 0.5s ease\",\n };\n default:\n return {};\n }\n };\n\n return (\n <>\n <div\n ref={ref}\n className={cn(\"ds:carousel-container\", containerClassName, className)}\n onMouseEnter={handleMouseEnter}\n onMouseLeave={handleMouseLeave}\n >\n <div\n ref={containerRef}\n className={cn(\n \"ds:carousel ds:relative ds:overflow-hidden\",\n (effect === \"fade\" ||\n effect === \"cube\" ||\n effect === \"flip\" ||\n effect === \"cards\") &&\n \"ds:aspect-4/3\",\n effect === \"coverflow\" && \"ds:aspect-4/2 ds:rounded-xl\",\n direction === \"vertical\" && effect === \"slide\" && \"ds:h-full\",\n grabCursor && allowTouchMove && !isDragging && \"ds:cursor-grab\",\n isDragging && \"ds:cursor-grabbing\"\n )}\n >\n {/* Wrapper */}\n <div\n ref={wrapperRef}\n className={cn(\n \"ds:carousel-wrapper ds:select-none\",\n effect === \"slide\" && \"ds:flex\",\n direction === \"vertical\" &&\n effect === \"slide\" &&\n \"ds:flex-col ds:h-full\",\n effect !== \"slide\" && \"ds:relative\",\n wrapperClassName\n )}\n style={{\n transform:\n effect === \"slide\"\n ? direction === \"horizontal\"\n ? `translateX(${translate}px)`\n : `translateY(${translate}px)`\n : undefined,\n transition: isDragging ? \"none\" : `transform ${speed}ms ease`,\n gap: effect === \"slide\" ? `${actualSpaceBetween}px` : undefined,\n perspective:\n effect !== \"slide\" && effect !== \"fade\"\n ? \"1200px\"\n : undefined,\n touchAction: allowTouchMove ? \"none\" : \"auto\",\n height:\n direction === \"vertical\" && effect === \"slide\"\n ? \"100%\"\n : undefined,\n }}\n onPointerDown={handlePointerDown}\n onPointerMove={handlePointerMove}\n onPointerUp={handlePointerUp}\n onPointerCancel={handlePointerUp}\n >\n {slides.map((slide, index) => {\n const isActive = index === activeIndex;\n const slideElement =\n slide as React.ReactElement<CarouselSlideProps>;\n\n return cloneElement(slideElement, {\n key: index,\n className: cn(\n \"ds:carousel-slide\",\n slideClassName,\n slideElement.props.className,\n effect !== \"slide\" && \"ds:absolute ds:inset-0\",\n effect === \"fade\" && \"ds:transition-opacity ds:duration-300\",\n effect !== \"slide\" &&\n effect !== \"fade\" &&\n \"ds:transition-all ds:duration-500\",\n enableImageViewer &&\n imageInfos[index]?.src &&\n \"ds:cursor-pointer\"\n ),\n style: {\n flex:\n effect === \"slide\"\n ? direction === \"vertical\"\n ? `0 0 100%`\n : `0 0 calc(${100 / visibleSlides}% - ${(actualSpaceBetween * (visibleSlides - 1)) / visibleSlides}px)`\n : undefined,\n minWidth:\n effect === \"slide\" && direction === \"horizontal\"\n ? 0\n : undefined,\n minHeight:\n effect === \"slide\" && direction === \"vertical\"\n ? 0\n : undefined,\n height:\n direction === \"vertical\" && effect === \"slide\"\n ? \"100%\"\n : undefined,\n userSelect: \"none\",\n // @ts-expect-error - WebkitUserDrag is not in CSSProperties but is valid CSS\n WebkitUserDrag: \"none\",\n ...(effect !== \"slide\" ? getSlideTransform(index) : {}),\n ...slideElement.props.style,\n } as React.CSSProperties,\n onClick: (e: React.MouseEvent) => {\n e.stopPropagation();\n handleSlideClick(index);\n },\n onDragStart: (e: React.DragEvent) => e.preventDefault(),\n \"data-active\": isActive,\n \"data-index\": index,\n } as Partial<CarouselSlideProps>);\n })}\n </div>\n\n {/* Pagination - Inside only (overlay on slider) */}\n {paginationOptions.enabled &&\n paginationOptions.position !== \"outside\" &&\n renderPagination()}\n\n {/* Navigation - Inside (overlay on slider) */}\n {navigationOptions.enabled &&\n navigationOptions.position === \"inside\" && (\n <>\n <button\n onClick={slidePrev}\n disabled={!loop && !rewind && isBeginning}\n className={cn(\n \"ds:absolute ds:z-10 ds:w-10 ds:h-10 ds:rounded-full ds:bg-background/80 ds:backdrop-blur ds:shadow-lg ds:flex ds:items-center ds:justify-center ds:transition-all ds:hover:bg-background ds:disabled:opacity-30 ds:disabled:cursor-not-allowed\",\n direction === \"horizontal\"\n ? \"ds:left-4 ds:top-1/2 ds:-translate-y-1/2\"\n : \"ds:top-4 ds:left-1/2 ds:-translate-x-1/2\"\n )}\n aria-label=\"Previous slide\"\n >\n {navigationOptions.prevEl ||\n (direction === \"horizontal\" ? (\n <ChevronLeft className=\"ds:w-5 ds:h-5\" />\n ) : (\n <ChevronUp className=\"ds:w-5 ds:h-5\" />\n ))}\n </button>\n <button\n onClick={slideNext}\n disabled={!loop && !rewind && isEnd}\n className={cn(\n \"ds:absolute ds:z-10 ds:w-10 ds:h-10 ds:rounded-full ds:bg-background/80 ds:backdrop-blur ds:shadow-lg ds:flex ds:items-center ds:justify-center ds:transition-all ds:hover:bg-background ds:disabled:opacity-30 ds:disabled:cursor-not-allowed\",\n direction === \"horizontal\"\n ? \"ds:right-4 ds:top-1/2 ds:-translate-y-1/2\"\n : \"ds:bottom-4 ds:left-1/2 ds:-translate-x-1/2\"\n )}\n aria-label=\"Next slide\"\n >\n {navigationOptions.nextEl ||\n (direction === \"horizontal\" ? (\n <ChevronRight className=\"ds:w-5 ds:h-5\" />\n ) : (\n <ChevronDown className=\"ds:w-5 ds:h-5\" />\n ))}\n </button>\n </>\n )}\n </div>\n\n {/* Pagination - Outside (below slider) */}\n {paginationOptions.enabled &&\n paginationOptions.position === \"outside\" &&\n renderPagination()}\n </div>\n\n {/* Image Viewer */}\n {enableImageViewer && imageInfos.length > 0 && (\n <ImageViewer\n images={imageInfos}\n visible={viewerVisible}\n onClose={() => {\n console.log(\"Closing viewer\");\n setViewerVisible(false);\n }}\n activeIndex={viewerIndex}\n onIndexChange={setViewerIndex}\n />\n )}\n {/* {enableImageViewer && (\n <div\n style={{\n position: \"fixed\",\n top: 10,\n right: 10,\n background: \"white\",\n padding: \"10px\",\n zIndex: 9999,\n fontSize: \"12px\",\n }}\n >\n Debug: visible={String(viewerVisible)}, images={imageInfos.length},\n index={viewerIndex}\n </div>\n )} */}\n </>\n );\n }\n);\n\nCarousel.displayName = \"Carousel\";\n\n// ============================================================================\n// Carousel Slide Component\n// ============================================================================\n\nexport const CarouselSlide = React.forwardRef<\n HTMLDivElement,\n CarouselSlideProps\n>(({ children, className, style, ...props }, ref) => {\n return (\n <div ref={ref} className={className} style={style} {...props}>\n {children}\n </div>\n );\n});\n\nCarouselSlide.displayName = \"CarouselSlide\";\n\nexport default Carousel;\n"],"names":["Carousel","React","children","initialSlide","direction","speed","spaceBetween","slidesPerView","slidesPerGroup","centeredSlides","loop","rewind","effect","breakpoints","navigation","pagination","autoplay","allowTouchMove","grabCursor","keyboard","mousewheel","className","containerClassName","wrapperClassName","slideClassName","enableImageViewer","onSlideChange","onReachBeginning","onReachEnd","onAutoplayStart","onAutoplayStop","ref","navigationOptions","paginationOptions","autoplayOptions","useMemo","activeIndex","setActiveIndex","useState","isBeginning","setIsBeginning","isEnd","setIsEnd","isDragging","setIsDragging","translate","setTranslate","isAutoplayRunning","setIsAutoplayRunning","showScrollbar","setShowScrollbar","windowWidth","setWindowWidth","viewerVisible","setViewerVisible","viewerIndex","setViewerIndex","useEffect","handleResize","currentBreakpoint","breakpointKeys","a","b","breakpoint","actualSlidesPerView","actualSpaceBetween","actualSlidesPerGroup","containerRef","useRef","wrapperRef","autoplayTimerRef","scrollbarTimerRef","dragStateRef","hasDraggedRef","slides","Children","child","isValidElement","CarouselSlide","totalSlides","findImageInChildren","useCallback","result","imageInfos","slide","imgElement","handleSlideClick","index","visibleSlides","slideTo","newIndex","containerSize","slideSize","newTranslate","slideNext","slidePrev","stopAutoplay","startAutoplay","handleMouseEnter","handleMouseLeave","handlePointerDown","e","err","handlePointerMove","startX","startY","diffX","diffY","handlePointerUp","diff","handleKeyDown","handleWheel","container","renderPagination","type","clickable","dynamicBullets","dynamicMainBullets","position","isOutside","bulletsToShow","jsx","cn","_","i","bulletIndex","isActive","jsxs","Fragment","progress","isInside","rect","percentage","targetIndex","dragWidth","scrollPosition","getSlideTransform","slideElement","cloneElement","ChevronLeft","ChevronUp","ChevronRight","ChevronDown","ImageViewer","style","props"],"mappings":"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"}
@@ -38,35 +38,35 @@ import { ConfettiPiece as q } from "../../utils/css.js";
38
38
  const B = u.forwardRef(
39
39
  (C, N) => {
40
40
  const {
41
- label: i,
42
- infoTooltip: r,
43
- helperText: s,
41
+ label: s,
42
+ infoTooltip: i,
43
+ helperText: r,
44
44
  state: m,
45
45
  variant: w = "default",
46
46
  size: v = "default",
47
47
  color: k,
48
48
  labelPosition: t = "right",
49
- labelAlignment: c = "center",
49
+ labelAlignment: d = "center",
50
50
  icon: y,
51
51
  animation: T,
52
52
  id: I,
53
- onCheckedChange: p,
53
+ onCheckedChange: c,
54
54
  ...j
55
- } = C, [z, d] = D(!1), A = u.useId(), n = I || A, P = {
56
- default: "text-muted-foreground",
57
- success: "text-success",
58
- warning: "text-warning",
59
- error: "text-error"
55
+ } = C, [z, p] = D(!1), A = u.useId(), n = I || A, P = {
56
+ default: "ds:text-muted-foreground",
57
+ success: "ds:text-success",
58
+ warning: "ds:text-warning",
59
+ error: "ds:text-error"
60
60
  }, S = (a) => {
61
- a && (d(!0), setTimeout(() => d(!1), 800)), p?.(a);
62
- }, f = t === "top" || t === "bottom", _ = f ? "flex-col" : "flex-row", F = f ? "gap-1.5" : "gap-2", R = c === "start" ? "items-start" : c === "center" ? "items-center" : "items-end", h = "flex gap-2 peer-disabled:cursor-not-allowed peer-disabled:opacity-70";
63
- return /* @__PURE__ */ o("div", { className: l("flex flex-col gap-1.5 relative", {}), children: [
64
- /* @__PURE__ */ o("div", { className: l("flex", _, F, R), children: [
65
- (t === "top" || t === "left") && i && /* @__PURE__ */ o("label", { htmlFor: n, className: h, children: [
66
- i,
67
- r && /* @__PURE__ */ e(b, { content: r, children: /* @__PURE__ */ e(g, { className: "size-3.5 min-w-3.5" }) })
61
+ a && (p(!0), setTimeout(() => p(!1), 800)), c?.(a);
62
+ }, f = t === "top" || t === "bottom", _ = f ? "flex-col" : "flex-row", F = f ? "gap-1.5" : "gap-2", R = d === "start" ? "items-start" : d === "center" ? "items-center" : "items-end", h = "flex gap-2 peer-disabled:cursor-not-allowed peer-disabled:opacity-70";
63
+ return /* @__PURE__ */ o("div", { className: l("ds:flex ds:flex-col ds:gap-1.5 ds:relative", {}), children: [
64
+ /* @__PURE__ */ o("div", { className: l("ds:flex", _, F, R), children: [
65
+ (t === "top" || t === "left") && s && /* @__PURE__ */ o("label", { htmlFor: n, className: h, children: [
66
+ s,
67
+ i && /* @__PURE__ */ e(b, { content: i, children: /* @__PURE__ */ e(g, { className: "ds:size-3.5 ds:min-w-3.5" }) })
68
68
  ] }),
69
- /* @__PURE__ */ o("div", { className: "relative inline-flex", children: [
69
+ /* @__PURE__ */ o("div", { className: "ds:relative ds:inline-flex", children: [
70
70
  /* @__PURE__ */ e(
71
71
  L,
72
72
  {
@@ -77,24 +77,24 @@ const B = u.forwardRef(
77
77
  size: v,
78
78
  color: k,
79
79
  icon: y,
80
- onCheckedChange: T ? S : p
80
+ onCheckedChange: T ? S : c
81
81
  }
82
82
  ),
83
- /* @__PURE__ */ e($, { children: z && /* @__PURE__ */ e("div", { className: "pointer-events-none absolute inset-0", children: [...Array(12)].map((a, x) => /* @__PURE__ */ e(q, { index: x }, x)) }) })
83
+ /* @__PURE__ */ e($, { children: z && /* @__PURE__ */ e("div", { className: "ds:pointer-events-none ds:absolute ds:inset-0", children: [...Array(12)].map((a, x) => /* @__PURE__ */ e(q, { index: x }, x)) }) })
84
84
  ] }),
85
- (t === "bottom" || t === "right") && i && /* @__PURE__ */ o(V, { htmlFor: n, className: h, children: [
86
- i,
87
- r && /* @__PURE__ */ e(b, { content: r, children: /* @__PURE__ */ e(g, { className: "size-3.5 min-w-3.5" }) })
85
+ (t === "bottom" || t === "right") && s && /* @__PURE__ */ o(V, { htmlFor: n, className: h, children: [
86
+ s,
87
+ i && /* @__PURE__ */ e(b, { content: i, children: /* @__PURE__ */ e(g, { className: "ds:size-3.5 ds:min-w-3.5" }) })
88
88
  ] })
89
89
  ] }),
90
- s && /* @__PURE__ */ e("div", { className: "flex items-center justify-between text-xs gap-2", children: s && /* @__PURE__ */ e(
90
+ r && /* @__PURE__ */ e("div", { className: "ds:flex ds:items-center ds:justify-between ds:text-xs ds:gap-2", children: r && /* @__PURE__ */ e(
91
91
  "p",
92
92
  {
93
93
  className: l(
94
- "text-xs",
94
+ "ds:text-xs",
95
95
  m ? P?.[m] : ""
96
96
  ),
97
- children: s
97
+ children: r
98
98
  }
99
99
  ) })
100
100
  ] });
@@ -1 +1 @@
1
- {"version":3,"file":"Checkbox.js","sources":["../../../../src/components/Checkbox/Checkbox.tsx"],"sourcesContent":["import React, { useState } from \"react\";\nimport { Checkbox as SCheckbox } from \"@dsui/ui/components/checkbox\";\nimport { cn } from \"@dsui/ui/index\";\nimport { Tooltip } from \"../Tooltip/Tooltip\";\nimport { Label } from \"../Label\";\nimport { Info } from \"lucide-react\";\nimport { AnimatePresence } from \"motion/react\";\nimport { ConfettiPiece } from \"@/utils/css\";\nimport type { CheckedState } from \"@radix-ui/react-checkbox\";\n\nexport type CheckboxProps = Omit<\n React.ComponentPropsWithoutRef<typeof SCheckbox>,\n \"onCheckedChange\" | \"variant\" | \"size\" | \"color\" | \"icon\"\n> & {\n onCheckedChange?: (checked: CheckedState) => void;\n variant?: \"default\" | \"circle\";\n size?: \"sm\" | \"default\" | \"lg\";\n color?:\n | \"primary\"\n | \"secondary\"\n | \"accent\"\n | \"destructive\"\n | \"muted\"\n | \"success\"\n | \"error\"\n | \"warning\";\n icon?: React.ReactNode;\n label?: React.ReactNode;\n labelPosition?: \"top\" | \"left\" | \"right\" | \"bottom\";\n labelAlignment?: \"start\" | \"center\" | \"end\";\n infoTooltip?: React.ReactNode;\n helperText?: React.ReactNode;\n state?: \"default\" | \"error\" | \"success\" | \"warning\";\n animation?: \"confetti\" | undefined;\n};\n\nconst Checkbox = React.forwardRef<HTMLButtonElement, CheckboxProps>(\n (props, ref) => {\n const {\n label,\n infoTooltip,\n helperText,\n state,\n variant = \"default\",\n size = \"default\",\n color,\n labelPosition = \"right\",\n labelAlignment = \"center\",\n icon,\n animation,\n id,\n onCheckedChange,\n ...rest\n } = props;\n const [showConfetti, setShowConfetti] = useState(false);\n const generatedId = React.useId();\n const inputId = id || generatedId;\n\n // State\n const helperTextStyles = {\n default: \"text-muted-foreground\",\n success: \"text-success\",\n warning: \"text-warning\",\n error: \"text-error\",\n };\n\n const handleCheckedChange = (checked: CheckedState) => {\n if (checked) {\n setShowConfetti(true);\n setTimeout(() => setShowConfetti(false), 800);\n }\n onCheckedChange?.(checked);\n };\n\n const isVertical = labelPosition === \"top\" || labelPosition === \"bottom\";\n const flexDirection = isVertical ? \"flex-col\" : \"flex-row\";\n const gapClass = isVertical ? \"gap-1.5\" : \"gap-2\";\n\n const alignmentClass =\n labelAlignment === \"start\"\n ? \"items-start\"\n : labelAlignment === \"center\"\n ? \"items-center\"\n : \"items-end\";\n\n const labelClass =\n \"flex gap-2 peer-disabled:cursor-not-allowed peer-disabled:opacity-70\";\n\n return (\n <div className={cn(\"flex flex-col gap-1.5 relative\", {})}>\n <div className={cn(\"flex\", flexDirection, gapClass, alignmentClass)}>\n {(labelPosition === \"top\" || labelPosition === \"left\") && label && (\n <label htmlFor={inputId} className={labelClass}>\n {label}\n {infoTooltip && (\n <Tooltip content={infoTooltip}>\n <Info className=\"size-3.5 min-w-3.5\" />\n </Tooltip>\n )}\n </label>\n )}\n\n <div className=\"relative inline-flex\">\n <SCheckbox\n ref={ref}\n id={inputId}\n {...rest}\n variant={variant}\n size={size}\n color={color}\n icon={icon}\n onCheckedChange={\n animation ? handleCheckedChange : onCheckedChange\n }\n />\n\n <AnimatePresence>\n {showConfetti && (\n <div className=\"pointer-events-none absolute inset-0\">\n {[...Array(12)].map((_, i) => (\n <ConfettiPiece key={i} index={i} />\n ))}\n </div>\n )}\n </AnimatePresence>\n </div>\n\n {(labelPosition === \"bottom\" || labelPosition === \"right\") &&\n label && (\n <Label htmlFor={inputId} className={labelClass}>\n {label}\n {infoTooltip && (\n <Tooltip content={infoTooltip}>\n <Info className=\"size-3.5 min-w-3.5\" />\n </Tooltip>\n )}\n </Label>\n )}\n </div>\n\n {helperText && (\n <div className=\"flex items-center justify-between text-xs gap-2\">\n {helperText && (\n <p\n className={cn(\n \"text-xs\",\n state ? helperTextStyles?.[state] : \"\"\n )}\n >\n {helperText}\n </p>\n )}\n </div>\n )}\n </div>\n );\n }\n);\n\nCheckbox.displayName = \"Checkbox\";\nexport default Checkbox;\n"],"names":["Checkbox","React","props","ref","label","infoTooltip","helperText","state","variant","size","color","labelPosition","labelAlignment","icon","animation","id","onCheckedChange","rest","showConfetti","setShowConfetti","useState","generatedId","inputId","helperTextStyles","handleCheckedChange","checked","isVertical","flexDirection","gapClass","alignmentClass","labelClass","cn","jsxs","Tooltip","jsx","Info","SCheckbox","AnimatePresence","_","i","ConfettiPiece","Label"],"mappings":"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"}
1
+ {"version":3,"file":"Checkbox.js","sources":["../../../../src/components/Checkbox/Checkbox.tsx"],"sourcesContent":["import React, { useState } from \"react\";\nimport { Checkbox as SCheckbox } from \"@dsui/ui/components/checkbox\";\nimport { cn } from \"@dsui/ui/index\";\nimport { Tooltip } from \"../Tooltip/Tooltip\";\nimport { Label } from \"../Label\";\nimport { Info } from \"lucide-react\";\nimport { AnimatePresence } from \"motion/react\";\nimport { ConfettiPiece } from \"@/utils/css\";\nimport type { CheckedState } from \"@radix-ui/react-checkbox\";\n\nexport type CheckboxProps = Omit<\n React.ComponentPropsWithoutRef<typeof SCheckbox>,\n \"onCheckedChange\" | \"variant\" | \"size\" | \"color\" | \"icon\"\n> & {\n onCheckedChange?: (checked: CheckedState) => void;\n variant?: \"default\" | \"circle\";\n size?: \"sm\" | \"default\" | \"lg\";\n color?:\n | \"primary\"\n | \"secondary\"\n | \"accent\"\n | \"destructive\"\n | \"muted\"\n | \"success\"\n | \"error\"\n | \"warning\";\n icon?: React.ReactNode;\n label?: React.ReactNode;\n labelPosition?: \"top\" | \"left\" | \"right\" | \"bottom\";\n labelAlignment?: \"start\" | \"center\" | \"end\";\n infoTooltip?: React.ReactNode;\n helperText?: React.ReactNode;\n state?: \"default\" | \"error\" | \"success\" | \"warning\";\n animation?: \"confetti\" | undefined;\n};\n\nconst Checkbox = React.forwardRef<HTMLButtonElement, CheckboxProps>(\n (props, ref) => {\n const {\n label,\n infoTooltip,\n helperText,\n state,\n variant = \"default\",\n size = \"default\",\n color,\n labelPosition = \"right\",\n labelAlignment = \"center\",\n icon,\n animation,\n id,\n onCheckedChange,\n ...rest\n } = props;\n const [showConfetti, setShowConfetti] = useState(false);\n const generatedId = React.useId();\n const inputId = id || generatedId;\n\n // State\n const helperTextStyles = {\n default: \"ds:text-muted-foreground\",\n success: \"ds:text-success\",\n warning: \"ds:text-warning\",\n error: \"ds:text-error\",\n };\n\n const handleCheckedChange = (checked: CheckedState) => {\n if (checked) {\n setShowConfetti(true);\n setTimeout(() => setShowConfetti(false), 800);\n }\n onCheckedChange?.(checked);\n };\n\n const isVertical = labelPosition === \"top\" || labelPosition === \"bottom\";\n const flexDirection = isVertical ? \"flex-col\" : \"flex-row\";\n const gapClass = isVertical ? \"gap-1.5\" : \"gap-2\";\n\n const alignmentClass =\n labelAlignment === \"start\"\n ? \"items-start\"\n : labelAlignment === \"center\"\n ? \"items-center\"\n : \"items-end\";\n\n const labelClass =\n \"flex gap-2 peer-disabled:cursor-not-allowed peer-disabled:opacity-70\";\n\n return (\n <div className={cn(\"ds:flex ds:flex-col ds:gap-1.5 ds:relative\", {})}>\n <div className={cn(\"ds:flex\", flexDirection, gapClass, alignmentClass)}>\n {(labelPosition === \"top\" || labelPosition === \"left\") && label && (\n <label htmlFor={inputId} className={labelClass}>\n {label}\n {infoTooltip && (\n <Tooltip content={infoTooltip}>\n <Info className=\"ds:size-3.5 ds:min-w-3.5\" />\n </Tooltip>\n )}\n </label>\n )}\n\n <div className=\"ds:relative ds:inline-flex\">\n <SCheckbox\n ref={ref}\n id={inputId}\n {...rest}\n variant={variant}\n size={size}\n color={color}\n icon={icon}\n onCheckedChange={\n animation ? handleCheckedChange : onCheckedChange\n }\n />\n\n <AnimatePresence>\n {showConfetti && (\n <div className=\"ds:pointer-events-none ds:absolute ds:inset-0\">\n {[...Array(12)].map((_, i) => (\n <ConfettiPiece key={i} index={i} />\n ))}\n </div>\n )}\n </AnimatePresence>\n </div>\n\n {(labelPosition === \"bottom\" || labelPosition === \"right\") &&\n label && (\n <Label htmlFor={inputId} className={labelClass}>\n {label}\n {infoTooltip && (\n <Tooltip content={infoTooltip}>\n <Info className=\"ds:size-3.5 ds:min-w-3.5\" />\n </Tooltip>\n )}\n </Label>\n )}\n </div>\n\n {helperText && (\n <div className=\"ds:flex ds:items-center ds:justify-between ds:text-xs ds:gap-2\">\n {helperText && (\n <p\n className={cn(\n \"ds:text-xs\",\n state ? helperTextStyles?.[state] : \"\"\n )}\n >\n {helperText}\n </p>\n )}\n </div>\n )}\n </div>\n );\n }\n);\n\nCheckbox.displayName = \"Checkbox\";\nexport default Checkbox;\n"],"names":["Checkbox","React","props","ref","label","infoTooltip","helperText","state","variant","size","color","labelPosition","labelAlignment","icon","animation","id","onCheckedChange","rest","showConfetti","setShowConfetti","useState","generatedId","inputId","helperTextStyles","handleCheckedChange","checked","isVertical","flexDirection","gapClass","alignmentClass","labelClass","cn","jsxs","Tooltip","jsx","Info","SCheckbox","AnimatePresence","_","i","ConfettiPiece","Label"],"mappings":"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"}
@@ -1,98 +1,98 @@
1
- import { jsx as t, jsxs as C } from "react/jsx-runtime";
2
- import a from "react";
1
+ import { jsx as e, jsxs as C } from "react/jsx-runtime";
2
+ import n from "react";
3
3
  import { Collapsible as x, CollapsibleTrigger as S, CollapsibleContent as z } from "../../packages/ui/src/components/collapsible.js";
4
- import { cn as e } from "../../packages/ui/src/lib/utils.js";
4
+ import { cn as s } from "../../packages/ui/src/lib/utils.js";
5
5
  import { ChevronDown as y } from "lucide-react";
6
- const I = a.forwardRef((N, s) => {
6
+ const I = n.forwardRef((N, d) => {
7
7
  const {
8
- trigger: l,
9
- content: i,
10
- showIcon: c = !0,
11
- iconPosition: p = "right",
12
- iconRotation: d = !0,
8
+ trigger: a,
9
+ content: l,
10
+ showIcon: i = !0,
11
+ iconPosition: c = "right",
12
+ iconRotation: p = !0,
13
13
  triggerClassName: v,
14
14
  contentClassName: O,
15
15
  variant: w = "default",
16
16
  className: g,
17
- open: n,
17
+ open: r,
18
18
  defaultOpen: j,
19
19
  onOpenChange: R,
20
20
  children: m,
21
21
  ...f
22
- } = N, [o, h] = a.useState(j ?? !1);
23
- a.useEffect(() => {
24
- n !== void 0 && h(n);
25
- }, [n]);
22
+ } = N, [t, h] = n.useState(j ?? !1);
23
+ n.useEffect(() => {
24
+ r !== void 0 && h(r);
25
+ }, [r]);
26
26
  const u = (b) => {
27
27
  h(b), R?.(b);
28
- }, r = {
28
+ }, o = {
29
29
  default: {
30
- root: "rounded-lg border bg-card",
31
- trigger: "px-4 py-3 hover:bg-accent/50",
32
- content: "px-4 py-3 border-t"
30
+ root: "ds:rounded-lg ds:border ds:bg-card",
31
+ trigger: "ds:px-4 ds:py-3 ds:hover:bg-accent/50",
32
+ content: "ds:px-4 ds:py-3 ds:border-t"
33
33
  },
34
34
  bordered: {
35
- root: "rounded-lg border-2",
36
- trigger: "px-4 py-3 font-semibold hover:bg-accent",
37
- content: "px-4 py-3 border-t-2"
35
+ root: "ds:rounded-lg ds:border-2",
36
+ trigger: "ds:px-4 ds:py-3 ds:font-semibold ds:hover:bg-accent",
37
+ content: "ds:px-4 ds:py-3 ds:border-t-2"
38
38
  },
39
39
  ghost: {
40
40
  root: "",
41
- trigger: "px-2 py-2 hover:bg-accent/30 rounded-md",
42
- content: "px-2 py-2"
41
+ trigger: "ds:px-2 ds:py-2 ds:hover:bg-accent/30 ds:rounded-md",
42
+ content: "ds:px-2 ds:py-2"
43
43
  }
44
44
  }[w];
45
- return m && !l && !i ? /* @__PURE__ */ t(
45
+ return m && !a && !l ? /* @__PURE__ */ e(
46
46
  x,
47
47
  {
48
- ref: s,
49
- open: o,
48
+ ref: d,
49
+ open: t,
50
50
  onOpenChange: u,
51
- className: e(r.root, g),
51
+ className: s(o.root, g),
52
52
  ...f,
53
53
  children: m
54
54
  }
55
55
  ) : /* @__PURE__ */ C(
56
56
  x,
57
57
  {
58
- ref: s,
59
- open: o,
58
+ ref: d,
59
+ open: t,
60
60
  onOpenChange: u,
61
- className: e(r.root, g),
61
+ className: s(o.root, g),
62
62
  ...f,
63
63
  children: [
64
64
  /* @__PURE__ */ C(
65
65
  S,
66
66
  {
67
- className: e(
68
- "flex w-full items-center justify-between transition-colors",
69
- r.trigger,
67
+ className: s(
68
+ "ds:flex ds:w-full ds:items-center ds:justify-between ds:transition-colors",
69
+ o.trigger,
70
70
  v
71
71
  ),
72
72
  children: [
73
- p === "left" && c && /* @__PURE__ */ t(
73
+ c === "left" && i && /* @__PURE__ */ e(
74
74
  y,
75
75
  {
76
- className: e(
77
- "size-4 transition-transform duration-200",
78
- d && o && "rotate-180"
76
+ className: s(
77
+ "ds:size-4 ds:transition-transform ds:duration-200",
78
+ p && t && "ds:rotate-180"
79
79
  )
80
80
  }
81
81
  ),
82
- /* @__PURE__ */ t("span", { className: "flex-1 text-left", children: l }),
83
- p === "right" && c && /* @__PURE__ */ t(
82
+ /* @__PURE__ */ e("span", { className: "ds:flex-1 ds:text-left", children: a }),
83
+ c === "right" && i && /* @__PURE__ */ e(
84
84
  y,
85
85
  {
86
- className: e(
87
- "size-4 transition-transform duration-200",
88
- d && o && "rotate-180"
86
+ className: s(
87
+ "ds:size-4 ds:transition-transform ds:duration-200",
88
+ p && t && "ds:rotate-180"
89
89
  )
90
90
  }
91
91
  )
92
92
  ]
93
93
  }
94
94
  ),
95
- /* @__PURE__ */ t(z, { className: e(r.content, O), children: i })
95
+ /* @__PURE__ */ e(z, { className: s(o.content, O), children: l })
96
96
  ]
97
97
  }
98
98
  );
@@ -1 +1 @@
1
- {"version":3,"file":"Collapsible.js","sources":["../../../../src/components/Collapsible/Collapsible.tsx"],"sourcesContent":["import React from \"react\";\nimport {\n Collapsible as SCollapsible,\n CollapsibleTrigger,\n CollapsibleContent,\n} from \"@dsui/ui/components/collapsible\";\nimport { cn } from \"@dsui/ui/lib/utils\";\nimport { ChevronDown } from \"lucide-react\";\n\nexport type CollapsibleProps = Omit<\n React.ComponentPropsWithoutRef<typeof SCollapsible>,\n \"children\" | \"content\" | \"open\" | \"defaultOpen\" | \"onOpenChange\"\n> & {\n open?: boolean;\n defaultOpen?: boolean;\n onOpenChange?: (open: boolean) => void;\n trigger?: React.ReactNode;\n content?: React.ReactNode;\n showIcon?: boolean;\n iconPosition?: \"left\" | \"right\";\n iconRotation?: boolean;\n triggerClassName?: string;\n contentClassName?: string;\n variant?: \"default\" | \"bordered\" | \"ghost\";\n children?: React.ReactNode;\n};\n\nconst Collapsible = React.forwardRef<\n React.ElementRef<typeof SCollapsible>,\n CollapsibleProps\n>((props, ref) => {\n const {\n trigger,\n content,\n showIcon = true,\n iconPosition = \"right\",\n iconRotation = true,\n triggerClassName,\n contentClassName,\n variant = \"default\",\n className,\n open,\n defaultOpen,\n onOpenChange,\n children,\n ...rest\n } = props;\n\n const [isOpen, setIsOpen] = React.useState(defaultOpen ?? false);\n\n React.useEffect(() => {\n if (open !== undefined) {\n setIsOpen(open);\n }\n }, [open]);\n\n const handleOpenChange = (newOpen: boolean) => {\n setIsOpen(newOpen);\n onOpenChange?.(newOpen);\n };\n\n const variantStyles = {\n default: {\n root: \"rounded-lg border bg-card\",\n trigger: \"px-4 py-3 hover:bg-accent/50\",\n content: \"px-4 py-3 border-t\",\n },\n bordered: {\n root: \"rounded-lg border-2\",\n trigger: \"px-4 py-3 font-semibold hover:bg-accent\",\n content: \"px-4 py-3 border-t-2\",\n },\n ghost: {\n root: \"\",\n trigger: \"px-2 py-2 hover:bg-accent/30 rounded-md\",\n content: \"px-2 py-2\",\n },\n };\n\n const styles = variantStyles[variant];\n\n // If children are provided, use them directly (custom implementation)\n if (children && !trigger && !content) {\n return (\n <SCollapsible\n ref={ref}\n open={isOpen}\n onOpenChange={handleOpenChange}\n className={cn(styles.root, className)}\n {...rest}\n >\n {children}\n </SCollapsible>\n );\n }\n\n // Default implementation with trigger and content\n return (\n <SCollapsible\n ref={ref}\n open={isOpen}\n onOpenChange={handleOpenChange}\n className={cn(styles.root, className)}\n {...rest}\n >\n <CollapsibleTrigger\n className={cn(\n \"flex w-full items-center justify-between transition-colors\",\n styles.trigger,\n triggerClassName\n )}\n >\n {iconPosition === \"left\" && showIcon && (\n <ChevronDown\n className={cn(\n \"size-4 transition-transform duration-200\",\n iconRotation && isOpen && \"rotate-180\"\n )}\n />\n )}\n <span className=\"flex-1 text-left\">{trigger}</span>\n {iconPosition === \"right\" && showIcon && (\n <ChevronDown\n className={cn(\n \"size-4 transition-transform duration-200\",\n iconRotation && isOpen && \"rotate-180\"\n )}\n />\n )}\n </CollapsibleTrigger>\n <CollapsibleContent className={cn(styles.content, contentClassName)}>\n {content}\n </CollapsibleContent>\n </SCollapsible>\n );\n});\n\nCollapsible.displayName = \"Collapsible\";\n\nexport default Collapsible;\nexport { CollapsibleTrigger, CollapsibleContent };\n"],"names":["Collapsible","React","props","ref","trigger","content","showIcon","iconPosition","iconRotation","triggerClassName","contentClassName","variant","className","open","defaultOpen","onOpenChange","children","rest","isOpen","setIsOpen","handleOpenChange","newOpen","styles","jsx","SCollapsible","cn","jsxs","CollapsibleTrigger","ChevronDown","CollapsibleContent"],"mappings":";;;;;AA2BA,MAAMA,IAAcC,EAAM,WAGxB,CAACC,GAAOC,MAAQ;AAChB,QAAM;AAAA,IACJ,SAAAC;AAAA,IACA,SAAAC;AAAA,IACA,UAAAC,IAAW;AAAA,IACX,cAAAC,IAAe;AAAA,IACf,cAAAC,IAAe;AAAA,IACf,kBAAAC;AAAA,IACA,kBAAAC;AAAA,IACA,SAAAC,IAAU;AAAA,IACV,WAAAC;AAAA,IACA,MAAAC;AAAA,IACA,aAAAC;AAAA,IACA,cAAAC;AAAA,IACA,UAAAC;AAAA,IACA,GAAGC;AAAA,EAAA,IACDf,GAEE,CAACgB,GAAQC,CAAS,IAAIlB,EAAM,SAASa,KAAe,EAAK;AAE/Db,EAAAA,EAAM,UAAU,MAAM;AACpB,IAAIY,MAAS,UACXM,EAAUN,CAAI;AAAA,EAElB,GAAG,CAACA,CAAI,CAAC;AAET,QAAMO,IAAmB,CAACC,MAAqB;AAC7C,IAAAF,EAAUE,CAAO,GACjBN,IAAeM,CAAO;AAAA,EACxB,GAoBMC,IAlBgB;AAAA,IACpB,SAAS;AAAA,MACP,MAAM;AAAA,MACN,SAAS;AAAA,MACT,SAAS;AAAA,IAAA;AAAA,IAEX,UAAU;AAAA,MACR,MAAM;AAAA,MACN,SAAS;AAAA,MACT,SAAS;AAAA,IAAA;AAAA,IAEX,OAAO;AAAA,MACL,MAAM;AAAA,MACN,SAAS;AAAA,MACT,SAAS;AAAA,IAAA;AAAA,EACX,EAG2BX,CAAO;AAGpC,SAAIK,KAAY,CAACZ,KAAW,CAACC,IAEzB,gBAAAkB;AAAA,IAACC;AAAAA,IAAA;AAAA,MACC,KAAArB;AAAA,MACA,MAAMe;AAAA,MACN,cAAcE;AAAA,MACd,WAAWK,EAAGH,EAAO,MAAMV,CAAS;AAAA,MACnC,GAAGK;AAAA,MAEH,UAAAD;AAAA,IAAA;AAAA,EAAA,IAOL,gBAAAU;AAAA,IAACF;AAAAA,IAAA;AAAA,MACC,KAAArB;AAAA,MACA,MAAMe;AAAA,MACN,cAAcE;AAAA,MACd,WAAWK,EAAGH,EAAO,MAAMV,CAAS;AAAA,MACnC,GAAGK;AAAA,MAEJ,UAAA;AAAA,QAAA,gBAAAS;AAAA,UAACC;AAAA,UAAA;AAAA,YACC,WAAWF;AAAA,cACT;AAAA,cACAH,EAAO;AAAA,cACPb;AAAA,YAAA;AAAA,YAGD,UAAA;AAAA,cAAAF,MAAiB,UAAUD,KAC1B,gBAAAiB;AAAA,gBAACK;AAAA,gBAAA;AAAA,kBACC,WAAWH;AAAA,oBACT;AAAA,oBACAjB,KAAgBU,KAAU;AAAA,kBAAA;AAAA,gBAC5B;AAAA,cAAA;AAAA,cAGJ,gBAAAK,EAAC,QAAA,EAAK,WAAU,oBAAoB,UAAAnB,GAAQ;AAAA,cAC3CG,MAAiB,WAAWD,KAC3B,gBAAAiB;AAAA,gBAACK;AAAA,gBAAA;AAAA,kBACC,WAAWH;AAAA,oBACT;AAAA,oBACAjB,KAAgBU,KAAU;AAAA,kBAAA;AAAA,gBAC5B;AAAA,cAAA;AAAA,YACF;AAAA,UAAA;AAAA,QAAA;AAAA,QAGJ,gBAAAK,EAACM,KAAmB,WAAWJ,EAAGH,EAAO,SAASZ,CAAgB,GAC/D,UAAAL,EAAA,CACH;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAGN,CAAC;AAEDL,EAAY,cAAc;"}
1
+ {"version":3,"file":"Collapsible.js","sources":["../../../../src/components/Collapsible/Collapsible.tsx"],"sourcesContent":["import React from \"react\";\nimport {\n Collapsible as SCollapsible,\n CollapsibleTrigger,\n CollapsibleContent,\n} from \"@dsui/ui/components/collapsible\";\nimport { cn } from \"@dsui/ui/lib/utils\";\nimport { ChevronDown } from \"lucide-react\";\n\nexport type CollapsibleProps = Omit<\n React.ComponentPropsWithoutRef<typeof SCollapsible>,\n \"children\" | \"content\" | \"open\" | \"defaultOpen\" | \"onOpenChange\"\n> & {\n open?: boolean;\n defaultOpen?: boolean;\n onOpenChange?: (open: boolean) => void;\n trigger?: React.ReactNode;\n content?: React.ReactNode;\n showIcon?: boolean;\n iconPosition?: \"left\" | \"right\";\n iconRotation?: boolean;\n triggerClassName?: string;\n contentClassName?: string;\n variant?: \"default\" | \"bordered\" | \"ghost\";\n children?: React.ReactNode;\n};\n\nconst Collapsible = React.forwardRef<\n React.ElementRef<typeof SCollapsible>,\n CollapsibleProps\n>((props, ref) => {\n const {\n trigger,\n content,\n showIcon = true,\n iconPosition = \"right\",\n iconRotation = true,\n triggerClassName,\n contentClassName,\n variant = \"default\",\n className,\n open,\n defaultOpen,\n onOpenChange,\n children,\n ...rest\n } = props;\n\n const [isOpen, setIsOpen] = React.useState(defaultOpen ?? false);\n\n React.useEffect(() => {\n if (open !== undefined) {\n setIsOpen(open);\n }\n }, [open]);\n\n const handleOpenChange = (newOpen: boolean) => {\n setIsOpen(newOpen);\n onOpenChange?.(newOpen);\n };\n\n const variantStyles = {\n default: {\n root: \"ds:rounded-lg ds:border ds:bg-card\",\n trigger: \"ds:px-4 ds:py-3 ds:hover:bg-accent/50\",\n content: \"ds:px-4 ds:py-3 ds:border-t\",\n },\n bordered: {\n root: \"ds:rounded-lg ds:border-2\",\n trigger: \"ds:px-4 ds:py-3 ds:font-semibold ds:hover:bg-accent\",\n content: \"ds:px-4 ds:py-3 ds:border-t-2\",\n },\n ghost: {\n root: \"\",\n trigger: \"ds:px-2 ds:py-2 ds:hover:bg-accent/30 ds:rounded-md\",\n content: \"ds:px-2 ds:py-2\",\n },\n };\n\n const styles = variantStyles[variant];\n\n // If children are provided, use them directly (custom implementation)\n if (children && !trigger && !content) {\n return (\n <SCollapsible\n ref={ref}\n open={isOpen}\n onOpenChange={handleOpenChange}\n className={cn(styles.root, className)}\n {...rest}\n >\n {children}\n </SCollapsible>\n );\n }\n\n // Default implementation with trigger and content\n return (\n <SCollapsible\n ref={ref}\n open={isOpen}\n onOpenChange={handleOpenChange}\n className={cn(styles.root, className)}\n {...rest}\n >\n <CollapsibleTrigger\n className={cn(\n \"ds:flex ds:w-full ds:items-center ds:justify-between ds:transition-colors\",\n styles.trigger,\n triggerClassName\n )}\n >\n {iconPosition === \"left\" && showIcon && (\n <ChevronDown\n className={cn(\n \"ds:size-4 ds:transition-transform ds:duration-200\",\n iconRotation && isOpen && \"ds:rotate-180\"\n )}\n />\n )}\n <span className=\"ds:flex-1 ds:text-left\">{trigger}</span>\n {iconPosition === \"right\" && showIcon && (\n <ChevronDown\n className={cn(\n \"ds:size-4 ds:transition-transform ds:duration-200\",\n iconRotation && isOpen && \"ds:rotate-180\"\n )}\n />\n )}\n </CollapsibleTrigger>\n <CollapsibleContent className={cn(styles.content, contentClassName)}>\n {content}\n </CollapsibleContent>\n </SCollapsible>\n );\n});\n\nCollapsible.displayName = \"Collapsible\";\n\nexport default Collapsible;\nexport { CollapsibleTrigger, CollapsibleContent };\n"],"names":["Collapsible","React","props","ref","trigger","content","showIcon","iconPosition","iconRotation","triggerClassName","contentClassName","variant","className","open","defaultOpen","onOpenChange","children","rest","isOpen","setIsOpen","handleOpenChange","newOpen","styles","jsx","SCollapsible","cn","jsxs","CollapsibleTrigger","ChevronDown","CollapsibleContent"],"mappings":";;;;;AA2BA,MAAMA,IAAcC,EAAM,WAGxB,CAACC,GAAOC,MAAQ;AAChB,QAAM;AAAA,IACJ,SAAAC;AAAA,IACA,SAAAC;AAAA,IACA,UAAAC,IAAW;AAAA,IACX,cAAAC,IAAe;AAAA,IACf,cAAAC,IAAe;AAAA,IACf,kBAAAC;AAAA,IACA,kBAAAC;AAAA,IACA,SAAAC,IAAU;AAAA,IACV,WAAAC;AAAA,IACA,MAAAC;AAAA,IACA,aAAAC;AAAA,IACA,cAAAC;AAAA,IACA,UAAAC;AAAA,IACA,GAAGC;AAAA,EAAA,IACDf,GAEE,CAACgB,GAAQC,CAAS,IAAIlB,EAAM,SAASa,KAAe,EAAK;AAE/Db,EAAAA,EAAM,UAAU,MAAM;AACpB,IAAIY,MAAS,UACXM,EAAUN,CAAI;AAAA,EAElB,GAAG,CAACA,CAAI,CAAC;AAET,QAAMO,IAAmB,CAACC,MAAqB;AAC7C,IAAAF,EAAUE,CAAO,GACjBN,IAAeM,CAAO;AAAA,EACxB,GAoBMC,IAlBgB;AAAA,IACpB,SAAS;AAAA,MACP,MAAM;AAAA,MACN,SAAS;AAAA,MACT,SAAS;AAAA,IAAA;AAAA,IAEX,UAAU;AAAA,MACR,MAAM;AAAA,MACN,SAAS;AAAA,MACT,SAAS;AAAA,IAAA;AAAA,IAEX,OAAO;AAAA,MACL,MAAM;AAAA,MACN,SAAS;AAAA,MACT,SAAS;AAAA,IAAA;AAAA,EACX,EAG2BX,CAAO;AAGpC,SAAIK,KAAY,CAACZ,KAAW,CAACC,IAEzB,gBAAAkB;AAAA,IAACC;AAAAA,IAAA;AAAA,MACC,KAAArB;AAAA,MACA,MAAMe;AAAA,MACN,cAAcE;AAAA,MACd,WAAWK,EAAGH,EAAO,MAAMV,CAAS;AAAA,MACnC,GAAGK;AAAA,MAEH,UAAAD;AAAA,IAAA;AAAA,EAAA,IAOL,gBAAAU;AAAA,IAACF;AAAAA,IAAA;AAAA,MACC,KAAArB;AAAA,MACA,MAAMe;AAAA,MACN,cAAcE;AAAA,MACd,WAAWK,EAAGH,EAAO,MAAMV,CAAS;AAAA,MACnC,GAAGK;AAAA,MAEJ,UAAA;AAAA,QAAA,gBAAAS;AAAA,UAACC;AAAA,UAAA;AAAA,YACC,WAAWF;AAAA,cACT;AAAA,cACAH,EAAO;AAAA,cACPb;AAAA,YAAA;AAAA,YAGD,UAAA;AAAA,cAAAF,MAAiB,UAAUD,KAC1B,gBAAAiB;AAAA,gBAACK;AAAA,gBAAA;AAAA,kBACC,WAAWH;AAAA,oBACT;AAAA,oBACAjB,KAAgBU,KAAU;AAAA,kBAAA;AAAA,gBAC5B;AAAA,cAAA;AAAA,cAGJ,gBAAAK,EAAC,QAAA,EAAK,WAAU,0BAA0B,UAAAnB,GAAQ;AAAA,cACjDG,MAAiB,WAAWD,KAC3B,gBAAAiB;AAAA,gBAACK;AAAA,gBAAA;AAAA,kBACC,WAAWH;AAAA,oBACT;AAAA,oBACAjB,KAAgBU,KAAU;AAAA,kBAAA;AAAA,gBAC5B;AAAA,cAAA;AAAA,YACF;AAAA,UAAA;AAAA,QAAA;AAAA,QAGJ,gBAAAK,EAACM,KAAmB,WAAWJ,EAAGH,EAAO,SAASZ,CAAgB,GAC/D,UAAAL,EAAA,CACH;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAGN,CAAC;AAEDL,EAAY,cAAc;"}