@deckai/deck-ui 0.0.22 → 0.0.23

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 (249) hide show
  1. package/README.md +0 -1
  2. package/dist/components/AboutCard.cjs +3 -3
  3. package/dist/components/AboutCard.cjs.map +1 -1
  4. package/dist/components/AboutCard.d.cts +1 -1
  5. package/dist/components/AboutCard.d.ts +1 -1
  6. package/dist/components/AboutCard.js +3 -3
  7. package/dist/components/AboutCard.js.map +1 -1
  8. package/dist/components/Accordion.cjs +2 -2
  9. package/dist/components/Accordion.cjs.map +1 -1
  10. package/dist/components/Accordion.js +2 -2
  11. package/dist/components/Accordion.js.map +1 -1
  12. package/dist/components/AddWorkCard.cjs +4 -4
  13. package/dist/components/AddWorkCard.cjs.map +1 -1
  14. package/dist/components/AddWorkCard.d.cts +1 -1
  15. package/dist/components/AddWorkCard.d.ts +1 -1
  16. package/dist/components/AddWorkCard.js +4 -4
  17. package/dist/components/AddWorkCard.js.map +1 -1
  18. package/dist/components/AutocompleteInput.cjs +4 -4
  19. package/dist/components/AutocompleteInput.cjs.map +1 -1
  20. package/dist/components/AutocompleteInput.d.cts +6 -6
  21. package/dist/components/AutocompleteInput.d.ts +6 -6
  22. package/dist/components/AutocompleteInput.js +4 -4
  23. package/dist/components/AutocompleteInput.js.map +1 -1
  24. package/dist/components/Avatar.cjs +1 -1
  25. package/dist/components/Avatar.cjs.map +1 -1
  26. package/dist/components/Avatar.d.cts +2 -2
  27. package/dist/components/Avatar.d.ts +2 -2
  28. package/dist/components/Avatar.js +1 -1
  29. package/dist/components/Avatar.js.map +1 -1
  30. package/dist/components/Badge.cjs +4 -4
  31. package/dist/components/Badge.cjs.map +1 -1
  32. package/dist/components/Badge.d.cts +2 -2
  33. package/dist/components/Badge.d.ts +2 -2
  34. package/dist/components/Badge.js +4 -4
  35. package/dist/components/Badge.js.map +1 -1
  36. package/dist/components/Breadcrumbs.cjs +2 -2
  37. package/dist/components/Breadcrumbs.cjs.map +1 -1
  38. package/dist/components/Breadcrumbs.js +2 -2
  39. package/dist/components/Breadcrumbs.js.map +1 -1
  40. package/dist/components/Button.cjs +5 -5
  41. package/dist/components/Button.cjs.map +1 -1
  42. package/dist/components/Button.d.cts +5 -5
  43. package/dist/components/Button.d.ts +5 -5
  44. package/dist/components/Button.js +5 -5
  45. package/dist/components/Button.js.map +1 -1
  46. package/dist/components/Carousel.cjs +1 -1
  47. package/dist/components/Carousel.cjs.map +1 -1
  48. package/dist/components/Carousel.d.cts +1 -1
  49. package/dist/components/Carousel.d.ts +1 -1
  50. package/dist/components/Carousel.js +1 -1
  51. package/dist/components/Carousel.js.map +1 -1
  52. package/dist/components/Collapsible.cjs +2 -2
  53. package/dist/components/Collapsible.cjs.map +1 -1
  54. package/dist/components/Collapsible.d.cts +4 -4
  55. package/dist/components/Collapsible.d.ts +4 -4
  56. package/dist/components/Collapsible.js +2 -2
  57. package/dist/components/Collapsible.js.map +1 -1
  58. package/dist/components/Combobox.cjs +4 -4
  59. package/dist/components/Combobox.cjs.map +1 -1
  60. package/dist/components/Combobox.d.cts +5 -2
  61. package/dist/components/Combobox.d.ts +5 -2
  62. package/dist/components/Combobox.js +4 -4
  63. package/dist/components/Combobox.js.map +1 -1
  64. package/dist/components/ContactItem.cjs +3 -3
  65. package/dist/components/ContactItem.cjs.map +1 -1
  66. package/dist/components/ContactItem.d.cts +1 -1
  67. package/dist/components/ContactItem.d.ts +1 -1
  68. package/dist/components/ContactItem.js +3 -3
  69. package/dist/components/ContactItem.js.map +1 -1
  70. package/dist/components/Dropdown.cjs +3 -3
  71. package/dist/components/Dropdown.cjs.map +1 -1
  72. package/dist/components/Dropdown.js +3 -3
  73. package/dist/components/Dropdown.js.map +1 -1
  74. package/dist/components/EditButton.cjs +5 -5
  75. package/dist/components/EditButton.cjs.map +1 -1
  76. package/dist/components/EditButton.d.cts +4 -4
  77. package/dist/components/EditButton.d.ts +4 -4
  78. package/dist/components/EditButton.js +5 -5
  79. package/dist/components/EditButton.js.map +1 -1
  80. package/dist/components/Fallback.cjs +1 -1
  81. package/dist/components/Fallback.cjs.map +1 -1
  82. package/dist/components/Fallback.js +1 -1
  83. package/dist/components/Fallback.js.map +1 -1
  84. package/dist/components/Icon.cjs +1 -1
  85. package/dist/components/Icon.cjs.map +1 -1
  86. package/dist/components/Icon.js +1 -1
  87. package/dist/components/Icon.js.map +1 -1
  88. package/dist/components/IconRenderer.cjs +1 -1
  89. package/dist/components/IconRenderer.cjs.map +1 -1
  90. package/dist/components/IconRenderer.d.cts +4 -4
  91. package/dist/components/IconRenderer.d.ts +4 -4
  92. package/dist/components/IconRenderer.js +1 -1
  93. package/dist/components/IconRenderer.js.map +1 -1
  94. package/dist/components/Input.cjs +3 -3
  95. package/dist/components/Input.cjs.map +1 -1
  96. package/dist/components/Input.d.cts +11 -11
  97. package/dist/components/Input.d.ts +11 -11
  98. package/dist/components/Input.js +3 -3
  99. package/dist/components/Input.js.map +1 -1
  100. package/dist/components/Link.cjs +4 -4
  101. package/dist/components/Link.cjs.map +1 -1
  102. package/dist/components/Link.d.cts +1 -1
  103. package/dist/components/Link.d.ts +1 -1
  104. package/dist/components/Link.js +4 -4
  105. package/dist/components/Link.js.map +1 -1
  106. package/dist/components/Logo.cjs +1 -1
  107. package/dist/components/Logo.cjs.map +1 -1
  108. package/dist/components/Logo.d.cts +1 -1
  109. package/dist/components/Logo.d.ts +1 -1
  110. package/dist/components/Logo.js +1 -1
  111. package/dist/components/Logo.js.map +1 -1
  112. package/dist/components/Modal.cjs +1 -1
  113. package/dist/components/Modal.cjs.map +1 -1
  114. package/dist/components/Modal.d.cts +4 -4
  115. package/dist/components/Modal.d.ts +4 -4
  116. package/dist/components/Modal.js +1 -1
  117. package/dist/components/Modal.js.map +1 -1
  118. package/dist/components/MultiSelectCombobox.cjs +2 -2
  119. package/dist/components/MultiSelectCombobox.cjs.map +1 -1
  120. package/dist/components/MultiSelectCombobox.d.cts +1 -1
  121. package/dist/components/MultiSelectCombobox.d.ts +1 -1
  122. package/dist/components/MultiSelectCombobox.js +2 -2
  123. package/dist/components/MultiSelectCombobox.js.map +1 -1
  124. package/dist/components/Navbar.cjs +7 -7
  125. package/dist/components/Navbar.cjs.map +1 -1
  126. package/dist/components/Navbar.d.cts +1 -1
  127. package/dist/components/Navbar.d.ts +1 -1
  128. package/dist/components/Navbar.js +7 -7
  129. package/dist/components/Navbar.js.map +1 -1
  130. package/dist/components/NavbarItem.cjs +4 -4
  131. package/dist/components/NavbarItem.cjs.map +1 -1
  132. package/dist/components/NavbarItem.d.cts +1 -1
  133. package/dist/components/NavbarItem.d.ts +1 -1
  134. package/dist/components/NavbarItem.js +4 -4
  135. package/dist/components/NavbarItem.js.map +1 -1
  136. package/dist/components/Option.cjs +2 -2
  137. package/dist/components/Option.cjs.map +1 -1
  138. package/dist/components/Option.js +2 -2
  139. package/dist/components/Option.js.map +1 -1
  140. package/dist/components/Pressable.cjs +1 -1
  141. package/dist/components/Pressable.cjs.map +1 -1
  142. package/dist/components/Pressable.js +1 -1
  143. package/dist/components/Pressable.js.map +1 -1
  144. package/dist/components/ProfileCard.cjs +2 -2
  145. package/dist/components/ProfileCard.cjs.map +1 -1
  146. package/dist/components/ProfileCard.d.cts +1 -1
  147. package/dist/components/ProfileCard.d.ts +1 -1
  148. package/dist/components/ProfileCard.js +2 -2
  149. package/dist/components/ProfileCard.js.map +1 -1
  150. package/dist/components/ProgressBar.cjs +3 -3
  151. package/dist/components/ProgressBar.cjs.map +1 -1
  152. package/dist/components/ProgressBar.js +3 -3
  153. package/dist/components/ProgressBar.js.map +1 -1
  154. package/dist/components/RadioGroup.cjs +3 -3
  155. package/dist/components/RadioGroup.cjs.map +1 -1
  156. package/dist/components/RadioGroup.js +3 -3
  157. package/dist/components/RadioGroup.js.map +1 -1
  158. package/dist/components/SegmentedTabs.cjs +4 -4
  159. package/dist/components/SegmentedTabs.cjs.map +1 -1
  160. package/dist/components/SegmentedTabs.js +4 -4
  161. package/dist/components/SegmentedTabs.js.map +1 -1
  162. package/dist/components/Sidebar.cjs +1 -1
  163. package/dist/components/Sidebar.cjs.map +1 -1
  164. package/dist/components/Sidebar.d.cts +1 -1
  165. package/dist/components/Sidebar.d.ts +1 -1
  166. package/dist/components/Sidebar.js +1 -1
  167. package/dist/components/Sidebar.js.map +1 -1
  168. package/dist/components/SlideButton.cjs +1 -1
  169. package/dist/components/SlideButton.cjs.map +1 -1
  170. package/dist/components/SlideButton.js +1 -1
  171. package/dist/components/SlideButton.js.map +1 -1
  172. package/dist/components/Slider.cjs.map +1 -1
  173. package/dist/components/Slider.js.map +1 -1
  174. package/dist/components/SocialCard.cjs +4 -4
  175. package/dist/components/SocialCard.cjs.map +1 -1
  176. package/dist/components/SocialCard.d.cts +1 -1
  177. package/dist/components/SocialCard.d.ts +1 -1
  178. package/dist/components/SocialCard.js +4 -4
  179. package/dist/components/SocialCard.js.map +1 -1
  180. package/dist/components/Spinner.cjs +1 -1
  181. package/dist/components/Spinner.cjs.map +1 -1
  182. package/dist/components/Spinner.d.cts +2 -2
  183. package/dist/components/Spinner.d.ts +2 -2
  184. package/dist/components/Spinner.js +1 -1
  185. package/dist/components/Spinner.js.map +1 -1
  186. package/dist/components/Switch.cjs.map +1 -1
  187. package/dist/components/Switch.d.cts +2 -2
  188. package/dist/components/Switch.d.ts +2 -2
  189. package/dist/components/Switch.js.map +1 -1
  190. package/dist/components/Tabs.cjs +3 -3
  191. package/dist/components/Tabs.cjs.map +1 -1
  192. package/dist/components/Tabs.js +3 -3
  193. package/dist/components/Tabs.js.map +1 -1
  194. package/dist/components/Tag.cjs +3 -3
  195. package/dist/components/Tag.cjs.map +1 -1
  196. package/dist/components/Tag.d.cts +1 -1
  197. package/dist/components/Tag.d.ts +1 -1
  198. package/dist/components/Tag.js +3 -3
  199. package/dist/components/Tag.js.map +1 -1
  200. package/dist/components/Text.cjs +1 -1
  201. package/dist/components/Text.cjs.map +1 -1
  202. package/dist/components/Text.d.cts +1 -1
  203. package/dist/components/Text.d.ts +1 -1
  204. package/dist/components/Text.js +1 -1
  205. package/dist/components/Text.js.map +1 -1
  206. package/dist/components/TextArea.cjs +4 -4
  207. package/dist/components/TextArea.cjs.map +1 -1
  208. package/dist/components/TextArea.d.cts +1 -1
  209. package/dist/components/TextArea.d.ts +1 -1
  210. package/dist/components/TextArea.js +4 -4
  211. package/dist/components/TextArea.js.map +1 -1
  212. package/dist/components/Toast.cjs +3 -3
  213. package/dist/components/Toast.cjs.map +1 -1
  214. package/dist/components/Toast.d.cts +7 -7
  215. package/dist/components/Toast.d.ts +7 -7
  216. package/dist/components/Toast.js +3 -3
  217. package/dist/components/Toast.js.map +1 -1
  218. package/dist/components/ToastProvider.cjs +1 -1
  219. package/dist/components/ToastProvider.cjs.map +1 -1
  220. package/dist/components/ToastProvider.d.cts +1 -1
  221. package/dist/components/ToastProvider.d.ts +1 -1
  222. package/dist/components/ToastProvider.js +1 -1
  223. package/dist/components/ToastProvider.js.map +1 -1
  224. package/dist/components/Tooltip.cjs +3 -3
  225. package/dist/components/Tooltip.cjs.map +1 -1
  226. package/dist/components/Tooltip.d.cts +1 -1
  227. package/dist/components/Tooltip.d.ts +1 -1
  228. package/dist/components/Tooltip.js +3 -3
  229. package/dist/components/Tooltip.js.map +1 -1
  230. package/dist/components/VideoPlayer.cjs +2 -2
  231. package/dist/components/VideoPlayer.cjs.map +1 -1
  232. package/dist/components/VideoPlayer.d.cts +4 -4
  233. package/dist/components/VideoPlayer.d.ts +4 -4
  234. package/dist/components/VideoPlayer.js +2 -2
  235. package/dist/components/VideoPlayer.js.map +1 -1
  236. package/dist/components/WorkCard.cjs +3 -3
  237. package/dist/components/WorkCard.cjs.map +1 -1
  238. package/dist/components/WorkCard.d.cts +1 -1
  239. package/dist/components/WorkCard.d.ts +1 -1
  240. package/dist/components/WorkCard.js +3 -3
  241. package/dist/components/WorkCard.js.map +1 -1
  242. package/dist/index.cjs +8 -8
  243. package/dist/index.cjs.map +1 -1
  244. package/dist/index.d.cts +39 -39
  245. package/dist/index.d.ts +39 -39
  246. package/dist/index.js +8 -8
  247. package/dist/index.js.map +1 -1
  248. package/dist/styles/styles.css +1 -1
  249. package/package.json +2 -2
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/utils/index.ts","../../src/utils/responsive.ts","../../src/components/Icon.tsx","../../src/utils/tailwind.ts","../../src/components/Pressable.tsx","../../src/hooks/useMediaQuery.ts","../../src/components/Carousel.tsx"],"names":["cn","inputs","twMerge","clsx","BASE_SIZES","RESPONSIVE_SIZES","getSizeKey","size","getResponsiveSize","baseSize","classes","styles","key","baseKey","responsiveClasses","s","breakpoint","valueStr","value","valueKey","COLOR_MAP","Icon","React","name","color","title","className","style","props","ref","IconComponent","IconMap","responsiveSizeClasses","responsiveSizeStyles","focusRingStyles","Pressable","children","type","disabled","useIsomorphicLayoutEffect","useEffect","useMediaQuery","query","matches","setMatches","useState","getMatches","useCallback","mediaQuery","handleChange","Carousel","gap","scrollContainerRef","useRef","showLeftPaddle","setShowLeftPaddle","showRightPaddle","setShowRightPaddle","isHoveringStart","setIsHoveringStart","isHoveringEnd","setIsHoveringEnd","touchStart","setTouchStart","touchEnd","setTouchEnd","isMobile","checkScrollPosition","container","scrollLeft","scrollWidth","clientWidth","handleMouseMove","rect","mouseX","HOVER_THRESHOLD","handleTouchStart","handleTouchMove","handleTouchEnd","distance","itemWidth","direction","targetScroll","handleWheel","isHorizontalScroll","scrollAmount","observer","scroll","handleKeyDown","C","child"],"mappings":"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","file":"Carousel.cjs","sourcesContent":["import { clsx, type ClassValue } from \"clsx\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport function cn(...inputs: ClassValue[]) {\n return twMerge(clsx(inputs));\n}\n\nexport const noopFn = () => {};\n","export type Breakpoint = \"sm\" | \"md\" | \"lg\" | \"xl\" | \"2xl\";\nexport type ResponsiveSize = number | `${Breakpoint}:${number}`;\n\ntype SizeKey =\n | \"12\"\n | \"16\"\n | \"18\"\n | \"20\"\n | \"24\"\n | \"32\"\n | \"36\"\n | \"40\"\n | \"42\"\n | \"48\"\n | \"64\"\n | \"72\";\n\n// These constants help Tailwind identify the classes during compilation\nconst BASE_SIZES: Record<SizeKey, string> = {\n \"12\": \"h-[12px] w-[12px]\",\n \"16\": \"h-[16px] w-[16px]\",\n \"18\": \"h-[18px] w-[18px]\",\n \"20\": \"h-[20px] w-[20px]\",\n \"24\": \"h-[24px] w-[24px]\",\n \"32\": \"h-[32px] w-[32px]\",\n \"36\": \"h-[36px] w-[36px]\",\n \"40\": \"h-[40px] w-[40px]\",\n \"42\": \"h-[42px] w-[42px]\",\n \"48\": \"h-[48px] w-[48px]\",\n \"64\": \"h-[64px] w-[64px]\",\n \"72\": \"h-[72px] w-[72px]\"\n};\n\nconst RESPONSIVE_SIZES: Record<Breakpoint, Record<SizeKey, string>> = {\n sm: {\n \"12\": \"sm:h-[12px] sm:w-[12px]\",\n \"16\": \"sm:h-[16px] sm:w-[16px]\",\n \"18\": \"sm:h-[18px] sm:w-[18px]\",\n \"20\": \"sm:h-[20px] sm:w-[20px]\",\n \"24\": \"sm:h-[24px] sm:w-[24px]\",\n \"32\": \"sm:h-[32px] sm:w-[32px]\",\n \"36\": \"sm:h-[36px] sm:w-[36px]\",\n \"40\": \"sm:h-[40px] sm:w-[40px]\",\n \"42\": \"sm:h-[42px] sm:w-[42px]\",\n \"48\": \"sm:h-[48px] sm:w-[48px]\",\n \"64\": \"sm:h-[64px] sm:w-[64px]\",\n \"72\": \"sm:h-[72px] sm:w-[72px]\"\n },\n md: {\n \"12\": \"md:h-[12px] md:w-[12px]\",\n \"16\": \"md:h-[16px] md:w-[16px]\",\n \"18\": \"md:h-[18px] md:w-[18px]\",\n \"20\": \"md:h-[20px] md:w-[20px]\",\n \"24\": \"md:h-[24px] md:w-[24px]\",\n \"32\": \"md:h-[32px] md:w-[32px]\",\n \"36\": \"md:h-[36px] md:w-[36px]\",\n \"40\": \"md:h-[40px] md:w-[40px]\",\n \"42\": \"md:h-[42px] md:w-[42px]\",\n \"48\": \"md:h-[48px] md:w-[48px]\",\n \"64\": \"md:h-[64px] md:w-[64px]\",\n \"72\": \"md:h-[72px] md:w-[72px]\"\n },\n lg: {\n \"12\": \"lg:h-[12px] lg:w-[12px]\",\n \"16\": \"lg:h-[16px] lg:w-[16px]\",\n \"18\": \"lg:h-[18px] lg:w-[18px]\",\n \"20\": \"lg:h-[20px] lg:w-[20px]\",\n \"24\": \"lg:h-[24px] lg:w-[24px]\",\n \"32\": \"lg:h-[32px] lg:w-[32px]\",\n \"36\": \"lg:h-[36px] lg:w-[36px]\",\n \"40\": \"lg:h-[40px] lg:w-[40px]\",\n \"42\": \"lg:h-[42px] lg:w-[42px]\",\n \"48\": \"lg:h-[48px] lg:w-[48px]\",\n \"64\": \"lg:h-[64px] lg:w-[64px]\",\n \"72\": \"lg:h-[72px] lg:w-[72px]\"\n },\n xl: {\n \"12\": \"xl:h-[12px] xl:w-[12px]\",\n \"16\": \"xl:h-[16px] xl:w-[16px]\",\n \"18\": \"xl:h-[18px] xl:w-[18px]\",\n \"20\": \"xl:h-[20px] xl:w-[20px]\",\n \"24\": \"xl:h-[24px] xl:w-[24px]\",\n \"32\": \"xl:h-[32px] xl:w-[32px]\",\n \"36\": \"xl:h-[36px] xl:w-[36px]\",\n \"40\": \"xl:h-[40px] xl:w-[40px]\",\n \"42\": \"xl:h-[42px] xl:w-[42px]\",\n \"48\": \"xl:h-[48px] xl:w-[48px]\",\n \"64\": \"xl:h-[64px] xl:w-[64px]\",\n \"72\": \"xl:h-[72px] xl:w-[72px]\"\n },\n \"2xl\": {\n \"12\": \"2xl:h-[12px] 2xl:w-[12px]\",\n \"16\": \"2xl:h-[16px] 2xl:w-[16px]\",\n \"18\": \"2xl:h-[18px] 2xl:w-[18px]\",\n \"20\": \"2xl:h-[20px] 2xl:w-[20px]\",\n \"24\": \"2xl:h-[24px] 2xl:w-[24px]\",\n \"32\": \"2xl:h-[32px] 2xl:w-[32px]\",\n \"36\": \"2xl:h-[36px] 2xl:w-[36px]\",\n \"40\": \"2xl:h-[40px] 2xl:w-[40px]\",\n \"42\": \"2xl:h-[42px] 2xl:w-[42px]\",\n \"48\": \"2xl:h-[48px] 2xl:w-[48px]\",\n \"64\": \"2xl:h-[64px] 2xl:w-[64px]\",\n \"72\": \"2xl:h-[72px] 2xl:w-[72px]\"\n }\n};\n\nconst getSizeKey = (size: number): SizeKey | undefined => {\n return String(size) as SizeKey;\n};\n\nexport const getResponsiveSize = (\n size: ResponsiveSize | ResponsiveSize[] | undefined,\n baseSize: number = 24\n): {\n responsiveSizeClasses: string;\n responsiveSizeStyles: Record<string, string>;\n} => {\n const classes: string[] = [];\n const styles: Record<string, string> = {};\n\n // If no size provided, use baseSize\n if (size === undefined) {\n const key = getSizeKey(baseSize);\n if (key) {\n classes.push(BASE_SIZES[key]);\n } else {\n styles.height = `${baseSize}px`;\n styles.width = `${baseSize}px`;\n }\n }\n\n // If size is a number, use that directly\n if (typeof size === \"number\") {\n const key = getSizeKey(size);\n if (key) {\n classes.push(BASE_SIZES[key]);\n } else {\n styles.height = `${size}px`;\n styles.width = `${size}px`;\n }\n }\n\n // If array of responsive sizes, generate responsive classes\n if (Array.isArray(size)) {\n const baseKey = getSizeKey(baseSize);\n const responsiveClasses = [\n (baseKey && BASE_SIZES[baseKey]) || `h-[${baseSize}px] w-[${baseSize}px]`\n ];\n\n size.forEach((s) => {\n if (typeof s === \"string\") {\n const [breakpoint, valueStr] = s.split(\":\") as [Breakpoint, string];\n const value = parseInt(valueStr, 10);\n const key = getSizeKey(value);\n classes.push(\n (key && RESPONSIVE_SIZES[breakpoint]?.[key]) ||\n `${breakpoint}:h-[${value}px] ${breakpoint}:w-[${value}px]`\n );\n }\n });\n\n classes.push(...responsiveClasses);\n }\n\n if (typeof size === \"string\") {\n const [breakpoint, valueStr] = size.split(\":\") as [Breakpoint, string];\n const value = parseInt(valueStr, 10);\n const valueKey = getSizeKey(value);\n classes.push(\n (valueKey && RESPONSIVE_SIZES[breakpoint]?.[valueKey]) ||\n `${breakpoint}:h-[${value}px] ${breakpoint}:w-[${value}px]`\n );\n }\n\n return {\n responsiveSizeClasses: classes.join(\" \"),\n responsiveSizeStyles: styles\n };\n};\n","import { IconMap, IconName } from \"@deckai/icons\";\nimport React, { SVGProps } from \"react\";\nimport { IconColors } from \"../types/tailwind\";\nimport { cn } from \"../utils\";\nimport { ResponsiveSize, getResponsiveSize } from \"../utils/responsive\";\n\nexport type IconProps = {\n name: IconName;\n /** @default 24 */\n size?: ResponsiveSize | ResponsiveSize[];\n /** @default primary */\n color?: IconColors;\n title?: string;\n className?: string;\n style?: React.CSSProperties;\n} & Omit<SVGProps<SVGSVGElement>, \"aria-hidden\" | \"aria-label\">;\n\n// Using CSS variables to support dark mode\nconst COLOR_MAP: Record<IconColors, string> = {\n primary: \"var(--color-primary)\",\n secondary: \"var(--color-secondary)\",\n white: \"var(--color-white)\",\n primaryBlue: \"var(--color-primary-100)\",\n disabled: \"var(--color-disabled)\",\n danger: \"var(--color-danger)\"\n};\n\nexport const Icon = React.forwardRef<SVGSVGElement, IconProps>(\n (\n {\n name,\n size = 24,\n color = \"primary\",\n title,\n className,\n style = {},\n ...props\n },\n ref\n ) => {\n const IconComponent = IconMap[name];\n const { responsiveSizeClasses, responsiveSizeStyles } = getResponsiveSize(\n size,\n 24\n );\n\n return (\n <div\n className={cn(\n \"flex justify-center items-center\",\n responsiveSizeClasses,\n className\n )}\n style={{\n [\"--icon-stroke\" as string]: COLOR_MAP[color],\n ...responsiveSizeStyles,\n ...style\n }}\n >\n <IconComponent\n ref={ref}\n aria-hidden={!title}\n aria-label={title}\n stroke={name.includes(\"filled\") ? undefined : COLOR_MAP[color]}\n {...props}\n />\n </div>\n );\n }\n);\n\nIcon.displayName = \"Icon\";\n","import { Colors, Typography } from \"../types/tailwind\";\n\n// Generate safelist patterns for all color utilities so you can use any theme color variable in your code\nexport const generateSafelist = (colors: Colors, typography: Typography) => {\n const colorNames = Object.keys(colors) as (keyof Colors)[];\n const utilities = [\"bg\", \"text\", \"border\", \"ring\", \"divide\", \"outline\"];\n const variants = [\"hover:\", \"focus:\", \"active:\", \"disabled:\"];\n const breakpoints = [\"sm\", \"md\", \"lg\", \"xl\", \"2xl\"];\n const sizes = [\"24\", \"42\", \"48\", \"64\", \"72\"]; // Add all the sizes you need\n\n const safelist: (string | { pattern: RegExp; variants: string[] })[] = [];\n\n colorNames.forEach((colorName) => {\n if (typeof colors[colorName] === \"object\") {\n // Handle nested color objects (with number keys)\n Object.keys(colors[colorName]).forEach((shade) => {\n utilities.forEach((utility) => {\n // Base utility\n safelist.push(`${utility}-${colorName}-${shade}`);\n\n // Variant utilities\n variants.forEach((variant) => {\n safelist.push(`${variant}${utility}-${colorName}-${shade}`);\n });\n });\n });\n } else {\n // Handle direct color values\n utilities.forEach((utility) => {\n safelist.push(`${utility}-${colorName}`);\n\n variants.forEach((variant) => {\n safelist.push(`${variant}${utility}-${colorName}`);\n });\n });\n }\n });\n\n // Generate typography classes\n Object.entries(typography).forEach(([family, sizes]) => {\n Object.keys(sizes).forEach((size) => {\n // Base typography classes\n safelist.push(`text-${family}-${size}`);\n\n // Add variants\n variants.forEach((variant) => {\n safelist.push(`${variant}text-${family}-${size}`);\n });\n });\n });\n\n const typographyClasses = Object.entries(typography).flatMap(\n ([category, sizes]) =>\n Object.keys(sizes).map((size) => `text-${category}-${size}`)\n );\n\n // Generate responsive variants\n const responsiveTypographyClasses = typographyClasses.flatMap((className) =>\n breakpoints.map((breakpoint) => `${breakpoint}:${className}`)\n );\n\n // Generate size classes with responsive variants\n const sizeClasses = sizes.flatMap((size) => [\n `h-[${size}px]`,\n `w-[${size}px]`,\n ...breakpoints.flatMap((bp) => [\n `${bp}:h-[${size}px]`,\n `${bp}:w-[${size}px]`\n ])\n ]);\n\n return [...typographyClasses, ...responsiveTypographyClasses, ...sizeClasses];\n};\n\nexport const focusRingStyles =\n \"focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-primary-100\";\nexport const focusRingWithinStyles =\n \"focus-within:outline-none focus-within:ring-2 focus-within:ring-primary-100\";\nexport const focusRingStylesCoerced = \"ring-2 ring-primary-100\";\n","import React, { ButtonHTMLAttributes } from \"react\";\nimport { focusRingStyles } from \"../utils/tailwind\";\nimport { cn } from \"../utils\";\n\nexport type PressableProps = ButtonHTMLAttributes<HTMLButtonElement>;\n\nexport const Pressable = React.forwardRef<HTMLButtonElement, PressableProps>(\n ({ children, type = \"button\", className, disabled, ...props }, ref) => (\n <button\n ref={ref}\n type={type}\n disabled={disabled}\n className={cn(\n \"appearance-none hover:opacity-80 transition-all active:scale-95\",\n focusRingStyles,\n disabled && \"opacity-50 cursor-not-allowed\",\n className\n )}\n {...props}\n >\n {children}\n </button>\n )\n);\n\nPressable.displayName = \"Pressable\";\n","import { useCallback, useEffect, useState } from \"react\";\n\nconst useIsomorphicLayoutEffect =\n typeof window !== \"undefined\" ? useEffect : () => {};\n\nexport const useMediaQuery = (query: string): boolean => {\n // Initialize with null to prevent hydration mismatch\n const [matches, setMatches] = useState<boolean | null>(null);\n\n const getMatches = useCallback((query: string): boolean => {\n if (typeof window !== \"undefined\") {\n return window.matchMedia(query).matches;\n }\n return false;\n }, []);\n\n // Update matches after mount to prevent hydration mismatch\n useIsomorphicLayoutEffect(() => {\n setMatches(getMatches(query));\n }, [query, getMatches]);\n\n useEffect(() => {\n if (typeof window !== \"undefined\") {\n const mediaQuery = window.matchMedia(query);\n\n const handleChange = () => {\n setMatches(getMatches(query));\n };\n\n mediaQuery.addEventListener(\"change\", handleChange);\n\n return () => {\n mediaQuery.removeEventListener(\"change\", handleChange);\n };\n }\n }, [query, getMatches]);\n\n // Return false during SSR, actual value after hydration\n return matches ?? false;\n};\n","import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport * as ScrollArea from \"@radix-ui/react-scroll-area\";\nimport { Icon } from \"./Icon\";\nimport { Pressable } from \"./Pressable\";\nimport { useMediaQuery } from \"../hooks/useMediaQuery\";\n\nexport type CarouselProps = {\n children: React.ReactNode;\n /** Optional className for the root element */\n className?: string;\n /** Optional gap between items in pixels */\n gap?: number;\n};\n\nexport const Carousel = ({\n children,\n className = \"\",\n gap = 20\n}: CarouselProps) => {\n const scrollContainerRef = useRef<HTMLDivElement>(null);\n const [showLeftPaddle, setShowLeftPaddle] = useState(false);\n const [showRightPaddle, setShowRightPaddle] = useState(false);\n const [isHoveringStart, setIsHoveringStart] = useState(false);\n const [isHoveringEnd, setIsHoveringEnd] = useState(false);\n const [touchStart, setTouchStart] = useState<number | null>(null);\n const [touchEnd, setTouchEnd] = useState<number | null>(null);\n const isMobile = useMediaQuery(\"(max-width: 768px)\");\n\n const checkScrollPosition = useCallback(() => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const { scrollLeft, scrollWidth, clientWidth } = container;\n setShowLeftPaddle(scrollLeft > 0);\n setShowRightPaddle(Math.ceil(scrollLeft + clientWidth) < scrollWidth);\n }, []);\n\n const handleMouseMove = useCallback(\n (e: React.MouseEvent) => {\n if (isMobile) return;\n\n const container = e.currentTarget;\n const rect = container.getBoundingClientRect();\n const mouseX = e.clientX - rect.left;\n const HOVER_THRESHOLD = 300;\n\n setIsHoveringStart(mouseX < HOVER_THRESHOLD);\n setIsHoveringEnd(mouseX > rect.width - HOVER_THRESHOLD);\n },\n [isMobile]\n );\n\n // Touch handling\n const handleTouchStart = useCallback((e: React.TouchEvent) => {\n setTouchStart(e.touches[0].clientX);\n setTouchEnd(null);\n }, []);\n\n const handleTouchMove = useCallback((e: React.TouchEvent) => {\n setTouchEnd(e.touches[0].clientX);\n }, []);\n\n const handleTouchEnd = useCallback(() => {\n if (!touchStart || !touchEnd) return;\n\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const distance = touchStart - touchEnd;\n const minSwipeDistance = 50;\n\n if (Math.abs(distance) < minSwipeDistance) {\n return;\n }\n\n const itemWidth = container.clientWidth;\n const direction = distance > 0 ? 1 : -1;\n const targetScroll = container.scrollLeft + itemWidth * direction;\n\n container.scrollTo({\n left: targetScroll,\n behavior: \"smooth\"\n });\n }, [touchStart, touchEnd]);\n\n const handleWheel = useCallback((e: WheelEvent) => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n // Check if the scroll is predominantly horizontal or if shift key is pressed\n const isHorizontalScroll = Math.abs(e.deltaX) > Math.abs(e.deltaY);\n if (!isHorizontalScroll && !e.shiftKey) return;\n\n e.preventDefault();\n\n // Determine the scroll amount based on the input type\n const scrollAmount = isHorizontalScroll ? e.deltaX : e.deltaY;\n\n // Apply smooth scrolling\n container.scrollBy({\n left: scrollAmount,\n behavior: \"smooth\"\n });\n }, []);\n\n useEffect(() => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const observer = new ResizeObserver(checkScrollPosition);\n observer.observe(container);\n\n container.addEventListener(\"scroll\", checkScrollPosition);\n container.addEventListener(\"wheel\", handleWheel, { passive: false });\n\n return () => {\n observer.disconnect();\n container.removeEventListener(\"scroll\", checkScrollPosition);\n container.removeEventListener(\"wheel\", handleWheel);\n };\n }, [checkScrollPosition, handleWheel]);\n\n const scroll = useCallback((direction: \"left\" | \"right\") => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const scrollAmount = container.clientWidth;\n const targetScroll =\n container.scrollLeft +\n (direction === \"left\" ? -scrollAmount : scrollAmount);\n\n container.scrollTo({\n left: targetScroll,\n behavior: \"smooth\"\n });\n }, []);\n\n const handleKeyDown = useCallback(\n (e: React.KeyboardEvent) => {\n if (e.key === \"ArrowLeft\") {\n scroll(\"left\");\n } else if (e.key === \"ArrowRight\") {\n scroll(\"right\");\n }\n },\n [scroll]\n );\n\n return (\n <div\n className={`relative group ${className}`}\n onKeyDown={handleKeyDown}\n onMouseMove={handleMouseMove}\n onMouseLeave={() => {\n setIsHoveringStart(false);\n setIsHoveringEnd(false);\n }}\n onTouchStart={handleTouchStart}\n onTouchMove={handleTouchMove}\n onTouchEnd={handleTouchEnd}\n role=\"region\"\n aria-label=\"Carousel\"\n >\n <ScrollArea.Root className=\"overflow-hidden\" type=\"hover\">\n <ScrollArea.Viewport\n ref={scrollContainerRef}\n className=\"w-full overflow-x-auto snap-x snap-mandatory\"\n style={{\n scrollbarWidth: \"none\",\n msOverflowStyle: \"none\",\n WebkitOverflowScrolling: \"touch\"\n }}\n >\n <div\n className=\"inline-flex\"\n style={{\n gap: `${gap}px`\n }}\n >\n {React.Children.map(children, (child) =>\n child === null ? null : (\n <div className=\"snap-start shrink-0\">{child}</div>\n )\n )}\n </div>\n </ScrollArea.Viewport>\n </ScrollArea.Root>\n\n {/* Navigation Paddles - Only show on desktop */}\n {!isMobile && (\n <>\n {showLeftPaddle && isHoveringStart && (\n <Pressable\n onClick={() => scroll(\"left\")}\n className=\"absolute left-4 top-1/2 -translate-y-1/2 z-20 transition-opacity duration-200\"\n aria-label=\"Scroll left\"\n >\n <div className=\"flex items-center justify-center w-10 h-10 rounded-full bg-overlay backdrop-blur-sm\">\n <Icon name=\"arrow-left\" size={24} color=\"white\" />\n </div>\n </Pressable>\n )}\n\n {showRightPaddle && isHoveringEnd && (\n <Pressable\n onClick={() => scroll(\"right\")}\n className=\"absolute right-4 top-1/2 -translate-y-1/2 z-20 transition-opacity duration-200\"\n aria-label=\"Scroll right\"\n >\n <div className=\"flex items-center justify-center w-10 h-10 rounded-full bg-overlay backdrop-blur-sm\">\n <Icon name=\"arrow-right\" size={24} color=\"white\" />\n </div>\n </Pressable>\n )}\n </>\n )}\n </div>\n );\n};\n"]}
1
+ {"version":3,"sources":["../../src/utils/index.ts","../../src/utils/responsive.ts","../../src/components/Icon.tsx","../../src/utils/tailwind.ts","../../src/components/Pressable.tsx","../../src/hooks/useMediaQuery.ts","../../src/components/Carousel.tsx"],"names":["cn","inputs","twMerge","clsx","BASE_SIZES","RESPONSIVE_SIZES","getSizeKey","size","getResponsiveSize","baseSize","classes","styles","key","baseKey","responsiveClasses","s","breakpoint","valueStr","value","valueKey","COLOR_MAP","Icon","React","name","color","title","className","style","props","ref","IconComponent","IconMap","responsiveSizeClasses","responsiveSizeStyles","focusRingStyles","Pressable","children","type","disabled","useIsomorphicLayoutEffect","useEffect","useMediaQuery","query","matches","setMatches","useState","getMatches","useCallback","mediaQuery","handleChange","Carousel","gap","scrollContainerRef","useRef","showLeftPaddle","setShowLeftPaddle","showRightPaddle","setShowRightPaddle","isHoveringStart","setIsHoveringStart","isHoveringEnd","setIsHoveringEnd","touchStart","setTouchStart","touchEnd","setTouchEnd","isMobile","checkScrollPosition","container","scrollLeft","scrollWidth","clientWidth","handleMouseMove","rect","mouseX","HOVER_THRESHOLD","handleTouchStart","handleTouchMove","handleTouchEnd","distance","itemWidth","direction","targetScroll","handleWheel","isHorizontalScroll","scrollAmount","observer","scroll","handleKeyDown","C","child"],"mappings":"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","file":"Carousel.cjs","sourcesContent":["import { clsx, type ClassValue } from \"clsx\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport function cn(...inputs: ClassValue[]) {\n return twMerge(clsx(inputs));\n}\n\nexport const noopFn = () => {};\n","export type Breakpoint = \"sm\" | \"md\" | \"lg\" | \"xl\" | \"2xl\";\nexport type ResponsiveSize = number | `${Breakpoint}:${number}`;\n\ntype SizeKey =\n | \"12\"\n | \"16\"\n | \"18\"\n | \"20\"\n | \"24\"\n | \"32\"\n | \"36\"\n | \"40\"\n | \"42\"\n | \"48\"\n | \"64\"\n | \"72\";\n\n// These constants help Tailwind identify the classes during compilation\nconst BASE_SIZES: Record<SizeKey, string> = {\n \"12\": \"h-[12px] w-[12px]\",\n \"16\": \"h-[16px] w-[16px]\",\n \"18\": \"h-[18px] w-[18px]\",\n \"20\": \"h-[20px] w-[20px]\",\n \"24\": \"h-[24px] w-[24px]\",\n \"32\": \"h-[32px] w-[32px]\",\n \"36\": \"h-[36px] w-[36px]\",\n \"40\": \"h-[40px] w-[40px]\",\n \"42\": \"h-[42px] w-[42px]\",\n \"48\": \"h-[48px] w-[48px]\",\n \"64\": \"h-[64px] w-[64px]\",\n \"72\": \"h-[72px] w-[72px]\"\n};\n\nconst RESPONSIVE_SIZES: Record<Breakpoint, Record<SizeKey, string>> = {\n sm: {\n \"12\": \"sm:h-[12px] sm:w-[12px]\",\n \"16\": \"sm:h-[16px] sm:w-[16px]\",\n \"18\": \"sm:h-[18px] sm:w-[18px]\",\n \"20\": \"sm:h-[20px] sm:w-[20px]\",\n \"24\": \"sm:h-[24px] sm:w-[24px]\",\n \"32\": \"sm:h-[32px] sm:w-[32px]\",\n \"36\": \"sm:h-[36px] sm:w-[36px]\",\n \"40\": \"sm:h-[40px] sm:w-[40px]\",\n \"42\": \"sm:h-[42px] sm:w-[42px]\",\n \"48\": \"sm:h-[48px] sm:w-[48px]\",\n \"64\": \"sm:h-[64px] sm:w-[64px]\",\n \"72\": \"sm:h-[72px] sm:w-[72px]\"\n },\n md: {\n \"12\": \"md:h-[12px] md:w-[12px]\",\n \"16\": \"md:h-[16px] md:w-[16px]\",\n \"18\": \"md:h-[18px] md:w-[18px]\",\n \"20\": \"md:h-[20px] md:w-[20px]\",\n \"24\": \"md:h-[24px] md:w-[24px]\",\n \"32\": \"md:h-[32px] md:w-[32px]\",\n \"36\": \"md:h-[36px] md:w-[36px]\",\n \"40\": \"md:h-[40px] md:w-[40px]\",\n \"42\": \"md:h-[42px] md:w-[42px]\",\n \"48\": \"md:h-[48px] md:w-[48px]\",\n \"64\": \"md:h-[64px] md:w-[64px]\",\n \"72\": \"md:h-[72px] md:w-[72px]\"\n },\n lg: {\n \"12\": \"lg:h-[12px] lg:w-[12px]\",\n \"16\": \"lg:h-[16px] lg:w-[16px]\",\n \"18\": \"lg:h-[18px] lg:w-[18px]\",\n \"20\": \"lg:h-[20px] lg:w-[20px]\",\n \"24\": \"lg:h-[24px] lg:w-[24px]\",\n \"32\": \"lg:h-[32px] lg:w-[32px]\",\n \"36\": \"lg:h-[36px] lg:w-[36px]\",\n \"40\": \"lg:h-[40px] lg:w-[40px]\",\n \"42\": \"lg:h-[42px] lg:w-[42px]\",\n \"48\": \"lg:h-[48px] lg:w-[48px]\",\n \"64\": \"lg:h-[64px] lg:w-[64px]\",\n \"72\": \"lg:h-[72px] lg:w-[72px]\"\n },\n xl: {\n \"12\": \"xl:h-[12px] xl:w-[12px]\",\n \"16\": \"xl:h-[16px] xl:w-[16px]\",\n \"18\": \"xl:h-[18px] xl:w-[18px]\",\n \"20\": \"xl:h-[20px] xl:w-[20px]\",\n \"24\": \"xl:h-[24px] xl:w-[24px]\",\n \"32\": \"xl:h-[32px] xl:w-[32px]\",\n \"36\": \"xl:h-[36px] xl:w-[36px]\",\n \"40\": \"xl:h-[40px] xl:w-[40px]\",\n \"42\": \"xl:h-[42px] xl:w-[42px]\",\n \"48\": \"xl:h-[48px] xl:w-[48px]\",\n \"64\": \"xl:h-[64px] xl:w-[64px]\",\n \"72\": \"xl:h-[72px] xl:w-[72px]\"\n },\n \"2xl\": {\n \"12\": \"2xl:h-[12px] 2xl:w-[12px]\",\n \"16\": \"2xl:h-[16px] 2xl:w-[16px]\",\n \"18\": \"2xl:h-[18px] 2xl:w-[18px]\",\n \"20\": \"2xl:h-[20px] 2xl:w-[20px]\",\n \"24\": \"2xl:h-[24px] 2xl:w-[24px]\",\n \"32\": \"2xl:h-[32px] 2xl:w-[32px]\",\n \"36\": \"2xl:h-[36px] 2xl:w-[36px]\",\n \"40\": \"2xl:h-[40px] 2xl:w-[40px]\",\n \"42\": \"2xl:h-[42px] 2xl:w-[42px]\",\n \"48\": \"2xl:h-[48px] 2xl:w-[48px]\",\n \"64\": \"2xl:h-[64px] 2xl:w-[64px]\",\n \"72\": \"2xl:h-[72px] 2xl:w-[72px]\"\n }\n};\n\nconst getSizeKey = (size: number): SizeKey | undefined => {\n return String(size) as SizeKey;\n};\n\nexport const getResponsiveSize = (\n size: ResponsiveSize | ResponsiveSize[] | undefined,\n baseSize: number = 24\n): {\n responsiveSizeClasses: string;\n responsiveSizeStyles: Record<string, string>;\n} => {\n const classes: string[] = [];\n const styles: Record<string, string> = {};\n\n // If no size provided, use baseSize\n if (size === undefined) {\n const key = getSizeKey(baseSize);\n if (key) {\n classes.push(BASE_SIZES[key]);\n } else {\n styles.height = `${baseSize}px`;\n styles.width = `${baseSize}px`;\n }\n }\n\n // If size is a number, use that directly\n if (typeof size === \"number\") {\n const key = getSizeKey(size);\n if (key) {\n classes.push(BASE_SIZES[key]);\n } else {\n styles.height = `${size}px`;\n styles.width = `${size}px`;\n }\n }\n\n // If array of responsive sizes, generate responsive classes\n if (Array.isArray(size)) {\n const baseKey = getSizeKey(baseSize);\n const responsiveClasses = [\n (baseKey && BASE_SIZES[baseKey]) || `h-[${baseSize}px] w-[${baseSize}px]`\n ];\n\n size.forEach((s) => {\n if (typeof s === \"string\") {\n const [breakpoint, valueStr] = s.split(\":\") as [Breakpoint, string];\n const value = parseInt(valueStr, 10);\n const key = getSizeKey(value);\n classes.push(\n (key && RESPONSIVE_SIZES[breakpoint]?.[key]) ||\n `${breakpoint}:h-[${value}px] ${breakpoint}:w-[${value}px]`\n );\n }\n });\n\n classes.push(...responsiveClasses);\n }\n\n if (typeof size === \"string\") {\n const [breakpoint, valueStr] = size.split(\":\") as [Breakpoint, string];\n const value = parseInt(valueStr, 10);\n const valueKey = getSizeKey(value);\n classes.push(\n (valueKey && RESPONSIVE_SIZES[breakpoint]?.[valueKey]) ||\n `${breakpoint}:h-[${value}px] ${breakpoint}:w-[${value}px]`\n );\n }\n\n return {\n responsiveSizeClasses: classes.join(\" \"),\n responsiveSizeStyles: styles\n };\n};\n","import type { IconName } from \"@deckai/icons\";\nimport { IconMap } from \"@deckai/icons\";\nimport type { SVGProps } from \"react\";\nimport React from \"react\";\n\nimport type { IconColors } from \"../types/tailwind\";\nimport { cn } from \"../utils\";\nimport type { ResponsiveSize } from \"../utils/responsive\";\nimport { getResponsiveSize } from \"../utils/responsive\";\n\nexport type IconProps = {\n name: IconName;\n /** @default 24 */\n size?: ResponsiveSize | ResponsiveSize[];\n /** @default primary */\n color?: IconColors;\n title?: string;\n className?: string;\n style?: React.CSSProperties;\n} & Omit<SVGProps<SVGSVGElement>, \"aria-hidden\" | \"aria-label\">;\n\n// Using CSS variables to support dark mode\nconst COLOR_MAP: Record<IconColors, string> = {\n primary: \"var(--color-primary)\",\n secondary: \"var(--color-secondary)\",\n white: \"var(--color-white)\",\n primaryBlue: \"var(--color-primary-100)\",\n disabled: \"var(--color-disabled)\",\n danger: \"var(--color-danger)\"\n};\n\nexport const Icon = React.forwardRef<SVGSVGElement, IconProps>(\n (\n {\n name,\n size = 24,\n color = \"primary\",\n title,\n className,\n style = {},\n ...props\n },\n ref\n ) => {\n const IconComponent = IconMap[name];\n const { responsiveSizeClasses, responsiveSizeStyles } = getResponsiveSize(\n size,\n 24\n );\n\n return (\n <div\n className={cn(\n \"flex justify-center items-center\",\n responsiveSizeClasses,\n className\n )}\n style={{\n [\"--icon-stroke\" as string]: COLOR_MAP[color],\n ...responsiveSizeStyles,\n ...style\n }}\n >\n <IconComponent\n ref={ref}\n aria-hidden={!title}\n aria-label={title}\n stroke={name.includes(\"filled\") ? undefined : COLOR_MAP[color]}\n {...props}\n />\n </div>\n );\n }\n);\n\nIcon.displayName = \"Icon\";\n","import type { Colors, Typography } from \"../types/tailwind\";\n\n// Generate safelist patterns for all color utilities so you can use any theme color variable in your code\nexport const generateSafelist = (colors: Colors, typography: Typography) => {\n const colorNames = Object.keys(colors) as (keyof Colors)[];\n const utilities = [\"bg\", \"text\", \"border\", \"ring\", \"divide\", \"outline\"];\n const variants = [\"hover:\", \"focus:\", \"active:\", \"disabled:\"];\n const breakpoints = [\"sm\", \"md\", \"lg\", \"xl\", \"2xl\"];\n const sizes = [\"24\", \"42\", \"48\", \"64\", \"72\"]; // Add all the sizes you need\n\n const safelist: (string | { pattern: RegExp; variants: string[] })[] = [];\n\n colorNames.forEach((colorName) => {\n if (typeof colors[colorName] === \"object\") {\n // Handle nested color objects (with number keys)\n Object.keys(colors[colorName]).forEach((shade) => {\n utilities.forEach((utility) => {\n // Base utility\n safelist.push(`${utility}-${colorName}-${shade}`);\n\n // Variant utilities\n variants.forEach((variant) => {\n safelist.push(`${variant}${utility}-${colorName}-${shade}`);\n });\n });\n });\n } else {\n // Handle direct color values\n utilities.forEach((utility) => {\n safelist.push(`${utility}-${colorName}`);\n\n variants.forEach((variant) => {\n safelist.push(`${variant}${utility}-${colorName}`);\n });\n });\n }\n });\n\n // Generate typography classes\n Object.entries(typography).forEach(([family, sizes]) => {\n Object.keys(sizes).forEach((size) => {\n // Base typography classes\n safelist.push(`text-${family}-${size}`);\n\n // Add variants\n variants.forEach((variant) => {\n safelist.push(`${variant}text-${family}-${size}`);\n });\n });\n });\n\n const typographyClasses = Object.entries(typography).flatMap(\n ([category, sizes]) =>\n Object.keys(sizes).map((size) => `text-${category}-${size}`)\n );\n\n // Generate responsive variants\n const responsiveTypographyClasses = typographyClasses.flatMap((className) =>\n breakpoints.map((breakpoint) => `${breakpoint}:${className}`)\n );\n\n // Generate size classes with responsive variants\n const sizeClasses = sizes.flatMap((size) => [\n `h-[${size}px]`,\n `w-[${size}px]`,\n ...breakpoints.flatMap((bp) => [\n `${bp}:h-[${size}px]`,\n `${bp}:w-[${size}px]`\n ])\n ]);\n\n return [...typographyClasses, ...responsiveTypographyClasses, ...sizeClasses];\n};\n\nexport const focusRingStyles =\n \"focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-primary-100\";\nexport const focusRingWithinStyles =\n \"focus-within:outline-none focus-within:ring-2 focus-within:ring-primary-100\";\nexport const focusRingStylesCoerced = \"ring-2 ring-primary-100\";\n","import type { ButtonHTMLAttributes } from \"react\";\nimport React from \"react\";\n\nimport { cn } from \"../utils\";\nimport { focusRingStyles } from \"../utils/tailwind\";\n\nexport type PressableProps = ButtonHTMLAttributes<HTMLButtonElement>;\n\nexport const Pressable = React.forwardRef<HTMLButtonElement, PressableProps>(\n ({ children, type = \"button\", className, disabled, ...props }, ref) => (\n <button\n ref={ref}\n type={type}\n disabled={disabled}\n className={cn(\n \"appearance-none hover:opacity-80 transition-all active:scale-95\",\n focusRingStyles,\n disabled && \"opacity-50 cursor-not-allowed\",\n className\n )}\n {...props}\n >\n {children}\n </button>\n )\n);\n\nPressable.displayName = \"Pressable\";\n","import { useCallback, useEffect, useState } from \"react\";\n\nconst useIsomorphicLayoutEffect =\n typeof window !== \"undefined\" ? useEffect : () => {};\n\nexport const useMediaQuery = (query: string): boolean => {\n // Initialize with null to prevent hydration mismatch\n const [matches, setMatches] = useState<boolean | null>(null);\n\n const getMatches = useCallback((query: string): boolean => {\n if (typeof window !== \"undefined\") {\n return window.matchMedia(query).matches;\n }\n return false;\n }, []);\n\n // Update matches after mount to prevent hydration mismatch\n useIsomorphicLayoutEffect(() => {\n setMatches(getMatches(query));\n }, [query, getMatches]);\n\n useEffect(() => {\n if (typeof window !== \"undefined\") {\n const mediaQuery = window.matchMedia(query);\n\n const handleChange = () => {\n setMatches(getMatches(query));\n };\n\n mediaQuery.addEventListener(\"change\", handleChange);\n\n return () => {\n mediaQuery.removeEventListener(\"change\", handleChange);\n };\n }\n }, [query, getMatches]);\n\n // Return false during SSR, actual value after hydration\n return matches ?? false;\n};\n","import * as ScrollArea from \"@radix-ui/react-scroll-area\";\nimport React, { useCallback, useEffect, useRef, useState } from \"react\";\n\nimport { Icon } from \"./Icon\";\nimport { Pressable } from \"./Pressable\";\nimport { useMediaQuery } from \"../hooks/useMediaQuery\";\n\nexport type CarouselProps = {\n children: React.ReactNode;\n /** Optional className for the root element */\n className?: string;\n /** Optional gap between items in pixels */\n gap?: number;\n};\n\nexport function Carousel({\n children,\n className = \"\",\n gap = 20\n}: CarouselProps) {\n const scrollContainerRef = useRef<HTMLDivElement>(null);\n const [showLeftPaddle, setShowLeftPaddle] = useState(false);\n const [showRightPaddle, setShowRightPaddle] = useState(false);\n const [isHoveringStart, setIsHoveringStart] = useState(false);\n const [isHoveringEnd, setIsHoveringEnd] = useState(false);\n const [touchStart, setTouchStart] = useState<number | null>(null);\n const [touchEnd, setTouchEnd] = useState<number | null>(null);\n const isMobile = useMediaQuery(\"(max-width: 768px)\");\n\n const checkScrollPosition = useCallback(() => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const { scrollLeft, scrollWidth, clientWidth } = container;\n setShowLeftPaddle(scrollLeft > 0);\n setShowRightPaddle(Math.ceil(scrollLeft + clientWidth) < scrollWidth);\n }, []);\n\n const handleMouseMove = useCallback(\n (e: React.MouseEvent) => {\n if (isMobile) return;\n\n const container = e.currentTarget;\n const rect = container.getBoundingClientRect();\n const mouseX = e.clientX - rect.left;\n const HOVER_THRESHOLD = 300;\n\n setIsHoveringStart(mouseX < HOVER_THRESHOLD);\n setIsHoveringEnd(mouseX > rect.width - HOVER_THRESHOLD);\n },\n [isMobile]\n );\n\n // Touch handling\n const handleTouchStart = useCallback((e: React.TouchEvent) => {\n setTouchStart(e.touches[0].clientX);\n setTouchEnd(null);\n }, []);\n\n const handleTouchMove = useCallback((e: React.TouchEvent) => {\n setTouchEnd(e.touches[0].clientX);\n }, []);\n\n const handleTouchEnd = useCallback(() => {\n if (!touchStart || !touchEnd) return;\n\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const distance = touchStart - touchEnd;\n const minSwipeDistance = 50;\n\n if (Math.abs(distance) < minSwipeDistance) {\n return;\n }\n\n const itemWidth = container.clientWidth;\n const direction = distance > 0 ? 1 : -1;\n const targetScroll = container.scrollLeft + itemWidth * direction;\n\n container.scrollTo({\n left: targetScroll,\n behavior: \"smooth\"\n });\n }, [touchStart, touchEnd]);\n\n const handleWheel = useCallback((e: WheelEvent) => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n // Check if the scroll is predominantly horizontal or if shift key is pressed\n const isHorizontalScroll = Math.abs(e.deltaX) > Math.abs(e.deltaY);\n if (!isHorizontalScroll && !e.shiftKey) return;\n\n e.preventDefault();\n\n // Determine the scroll amount based on the input type\n const scrollAmount = isHorizontalScroll ? e.deltaX : e.deltaY;\n\n // Apply smooth scrolling\n container.scrollBy({\n left: scrollAmount,\n behavior: \"smooth\"\n });\n }, []);\n\n useEffect(() => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const observer = new ResizeObserver(checkScrollPosition);\n observer.observe(container);\n\n container.addEventListener(\"scroll\", checkScrollPosition);\n container.addEventListener(\"wheel\", handleWheel, { passive: false });\n\n return () => {\n observer.disconnect();\n container.removeEventListener(\"scroll\", checkScrollPosition);\n container.removeEventListener(\"wheel\", handleWheel);\n };\n }, [checkScrollPosition, handleWheel]);\n\n const scroll = useCallback((direction: \"left\" | \"right\") => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const scrollAmount = container.clientWidth;\n const targetScroll =\n container.scrollLeft +\n (direction === \"left\" ? -scrollAmount : scrollAmount);\n\n container.scrollTo({\n left: targetScroll,\n behavior: \"smooth\"\n });\n }, []);\n\n const handleKeyDown = useCallback(\n (e: React.KeyboardEvent) => {\n if (e.key === \"ArrowLeft\") {\n scroll(\"left\");\n } else if (e.key === \"ArrowRight\") {\n scroll(\"right\");\n }\n },\n [scroll]\n );\n\n return (\n <div\n className={`relative group ${className}`}\n onKeyDown={handleKeyDown}\n onMouseMove={handleMouseMove}\n onMouseLeave={() => {\n setIsHoveringStart(false);\n setIsHoveringEnd(false);\n }}\n onTouchStart={handleTouchStart}\n onTouchMove={handleTouchMove}\n onTouchEnd={handleTouchEnd}\n role=\"region\"\n aria-label=\"Carousel\"\n >\n <ScrollArea.Root className=\"overflow-hidden\" type=\"hover\">\n <ScrollArea.Viewport\n ref={scrollContainerRef}\n className=\"w-full overflow-x-auto snap-x snap-mandatory\"\n style={{\n scrollbarWidth: \"none\",\n msOverflowStyle: \"none\",\n WebkitOverflowScrolling: \"touch\"\n }}\n >\n <div\n className=\"inline-flex\"\n style={{\n gap: `${gap}px`\n }}\n >\n {React.Children.map(children, (child) =>\n child === null ? null : (\n <div className=\"snap-start shrink-0\">{child}</div>\n )\n )}\n </div>\n </ScrollArea.Viewport>\n </ScrollArea.Root>\n\n {/* Navigation Paddles - Only show on desktop */}\n {!isMobile && (\n <>\n {showLeftPaddle && isHoveringStart && (\n <Pressable\n onClick={() => scroll(\"left\")}\n className=\"absolute left-4 top-1/2 -translate-y-1/2 z-20 transition-opacity duration-200\"\n aria-label=\"Scroll left\"\n >\n <div className=\"flex items-center justify-center w-10 h-10 rounded-full bg-overlay backdrop-blur-sm\">\n <Icon name=\"arrow-left\" size={24} color=\"white\" />\n </div>\n </Pressable>\n )}\n\n {showRightPaddle && isHoveringEnd && (\n <Pressable\n onClick={() => scroll(\"right\")}\n className=\"absolute right-4 top-1/2 -translate-y-1/2 z-20 transition-opacity duration-200\"\n aria-label=\"Scroll right\"\n >\n <div className=\"flex items-center justify-center w-10 h-10 rounded-full bg-overlay backdrop-blur-sm\">\n <Icon name=\"arrow-right\" size={24} color=\"white\" />\n </div>\n </Pressable>\n )}\n </>\n )}\n </div>\n );\n}\n"]}
@@ -7,6 +7,6 @@ type CarouselProps = {
7
7
  /** Optional gap between items in pixels */
8
8
  gap?: number;
9
9
  };
10
- declare const Carousel: ({ children, className, gap }: CarouselProps) => React__default.JSX.Element;
10
+ declare function Carousel({ children, className, gap }: CarouselProps): React__default.JSX.Element;
11
11
 
12
12
  export { Carousel, type CarouselProps };
@@ -7,6 +7,6 @@ type CarouselProps = {
7
7
  /** Optional gap between items in pixels */
8
8
  gap?: number;
9
9
  };
10
- declare const Carousel: ({ children, className, gap }: CarouselProps) => React__default.JSX.Element;
10
+ declare function Carousel({ children, className, gap }: CarouselProps): React__default.JSX.Element;
11
11
 
12
12
  export { Carousel, type CarouselProps };
@@ -1,2 +1,2 @@
1
- import p,{useRef,useState,useCallback,useEffect}from'react';import*as C from'@radix-ui/react-scroll-area';import {IconMap}from'@deckai/icons';import {clsx}from'clsx';import {twMerge}from'tailwind-merge';function b(...t){return twMerge(clsx(t))}var T={12:"h-[12px] w-[12px]",16:"h-[16px] w-[16px]",18:"h-[18px] w-[18px]",20:"h-[20px] w-[20px]",24:"h-[24px] w-[24px]",32:"h-[32px] w-[32px]",36:"h-[36px] w-[36px]",40:"h-[40px] w-[40px]",42:"h-[42px] w-[42px]",48:"h-[48px] w-[48px]",64:"h-[64px] w-[64px]",72:"h-[72px] w-[72px]"},N={sm:{12:"sm:h-[12px] sm:w-[12px]",16:"sm:h-[16px] sm:w-[16px]",18:"sm:h-[18px] sm:w-[18px]",20:"sm:h-[20px] sm:w-[20px]",24:"sm:h-[24px] sm:w-[24px]",32:"sm:h-[32px] sm:w-[32px]",36:"sm:h-[36px] sm:w-[36px]",40:"sm:h-[40px] sm:w-[40px]",42:"sm:h-[42px] sm:w-[42px]",48:"sm:h-[48px] sm:w-[48px]",64:"sm:h-[64px] sm:w-[64px]",72:"sm:h-[72px] sm:w-[72px]"},md:{12:"md:h-[12px] md:w-[12px]",16:"md:h-[16px] md:w-[16px]",18:"md:h-[18px] md:w-[18px]",20:"md:h-[20px] md:w-[20px]",24:"md:h-[24px] md:w-[24px]",32:"md:h-[32px] md:w-[32px]",36:"md:h-[36px] md:w-[36px]",40:"md:h-[40px] md:w-[40px]",42:"md:h-[42px] md:w-[42px]",48:"md:h-[48px] md:w-[48px]",64:"md:h-[64px] md:w-[64px]",72:"md:h-[72px] md:w-[72px]"},lg:{12:"lg:h-[12px] lg:w-[12px]",16:"lg:h-[16px] lg:w-[16px]",18:"lg:h-[18px] lg:w-[18px]",20:"lg:h-[20px] lg:w-[20px]",24:"lg:h-[24px] lg:w-[24px]",32:"lg:h-[32px] lg:w-[32px]",36:"lg:h-[36px] lg:w-[36px]",40:"lg:h-[40px] lg:w-[40px]",42:"lg:h-[42px] lg:w-[42px]",48:"lg:h-[48px] lg:w-[48px]",64:"lg:h-[64px] lg:w-[64px]",72:"lg:h-[72px] lg:w-[72px]"},xl:{12:"xl:h-[12px] xl:w-[12px]",16:"xl:h-[16px] xl:w-[16px]",18:"xl:h-[18px] xl:w-[18px]",20:"xl:h-[20px] xl:w-[20px]",24:"xl:h-[24px] xl:w-[24px]",32:"xl:h-[32px] xl:w-[32px]",36:"xl:h-[36px] xl:w-[36px]",40:"xl:h-[40px] xl:w-[40px]",42:"xl:h-[42px] xl:w-[42px]",48:"xl:h-[48px] xl:w-[48px]",64:"xl:h-[64px] xl:w-[64px]",72:"xl:h-[72px] xl:w-[72px]"},"2xl":{12:"2xl:h-[12px] 2xl:w-[12px]",16:"2xl:h-[16px] 2xl:w-[16px]",18:"2xl:h-[18px] 2xl:w-[18px]",20:"2xl:h-[20px] 2xl:w-[20px]",24:"2xl:h-[24px] 2xl:w-[24px]",32:"2xl:h-[32px] 2xl:w-[32px]",36:"2xl:h-[36px] 2xl:w-[36px]",40:"2xl:h-[40px] 2xl:w-[40px]",42:"2xl:h-[42px] 2xl:w-[42px]",48:"2xl:h-[48px] 2xl:w-[48px]",64:"2xl:h-[64px] 2xl:w-[64px]",72:"2xl:h-[72px] 2xl:w-[72px]"}},v=t=>String(t),O=(t,l=24)=>{let n=[],o={};if(t===undefined){let s=v(l);s?n.push(T[s]):(o.height=`${l}px`,o.width=`${l}px`);}if(typeof t=="number"){let s=v(t);s?n.push(T[s]):(o.height=`${t}px`,o.width=`${t}px`);}if(Array.isArray(t)){let s=v(l),i=[s&&T[s]||`h-[${l}px] w-[${l}px]`];t.forEach(c=>{if(typeof c=="string"){let[x,w]=c.split(":"),m=parseInt(w,10),u=v(m);n.push(u&&N[x]?.[u]||`${x}:h-[${m}px] ${x}:w-[${m}px]`);}}),n.push(...i);}if(typeof t=="string"){let[s,i]=t.split(":"),c=parseInt(i,10),x=v(c);n.push(x&&N[s]?.[x]||`${s}:h-[${c}px] ${s}:w-[${c}px]`);}return {responsiveSizeClasses:n.join(" "),responsiveSizeStyles:o}};var B={primary:"var(--color-primary)",secondary:"var(--color-secondary)",white:"var(--color-white)",primaryBlue:"var(--color-primary-100)",disabled:"var(--color-disabled)",danger:"var(--color-danger)"},$=p.forwardRef(({name:t,size:l=24,color:n="primary",title:o,className:s,style:i={},...c},x)=>{let w=IconMap[t],{responsiveSizeClasses:m,responsiveSizeStyles:u}=O(l,24);return p.createElement("div",{className:b("flex justify-center items-center",m,s),style:{"--icon-stroke":B[n],...u,...i}},p.createElement(w,{ref:x,"aria-hidden":!o,"aria-label":o,stroke:t.includes("filled")?undefined:B[n],...c}))});$.displayName="Icon";var H="focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-primary-100";var E=p.forwardRef(({children:t,type:l="button",className:n,disabled:o,...s},i)=>p.createElement("button",{ref:i,type:l,disabled:o,className:b("appearance-none hover:opacity-80 transition-all active:scale-95",H,o&&"opacity-50 cursor-not-allowed",n),...s},t));E.displayName="Pressable";var q=typeof window<"u"?useEffect:()=>{},V=t=>{let[l,n]=useState(null),o=useCallback(s=>typeof window<"u"?window.matchMedia(s).matches:false,[]);return q(()=>{n(o(t));},[t,o]),useEffect(()=>{if(typeof window<"u"){let s=window.matchMedia(t),i=()=>{n(o(t));};return s.addEventListener("change",i),()=>{s.removeEventListener("change",i);}}},[t,o]),l??false};var Me=({children:t,className:l="",gap:n=20})=>{let o=useRef(null),[s,i]=useState(false),[c,x]=useState(false),[w,m]=useState(false),[u,I]=useState(false),[M,j]=useState(null),[k,A]=useState(null),R=V("(max-width: 768px)"),y=useCallback(()=>{let e=o.current;if(!e)return;let{scrollLeft:r,scrollWidth:a,clientWidth:h}=e;i(r>0),x(Math.ceil(r+h)<a);},[]),W=useCallback(e=>{if(R)return;let a=e.currentTarget.getBoundingClientRect(),h=e.clientX-a.left,S=300;m(h<S),I(h>a.width-S);},[R]),D=useCallback(e=>{j(e.touches[0].clientX),A(null);},[]),G=useCallback(e=>{A(e.touches[0].clientX);},[]),X=useCallback(()=>{if(!M||!k)return;let e=o.current;if(!e)return;let r=M-k;if(Math.abs(r)<50)return;let h=e.clientWidth,S=r>0?1:-1,Q=e.scrollLeft+h*S;e.scrollTo({left:Q,behavior:"smooth"});},[M,k]),P=useCallback(e=>{let r=o.current;if(!r)return;let a=Math.abs(e.deltaX)>Math.abs(e.deltaY);if(!a&&!e.shiftKey)return;e.preventDefault();let h=a?e.deltaX:e.deltaY;r.scrollBy({left:h,behavior:"smooth"});},[]);useEffect(()=>{let e=o.current;if(!e)return;let r=new ResizeObserver(y);return r.observe(e),e.addEventListener("scroll",y),e.addEventListener("wheel",P,{passive:false}),()=>{r.disconnect(),e.removeEventListener("scroll",y),e.removeEventListener("wheel",P);}},[y,P]);let g=useCallback(e=>{let r=o.current;if(!r)return;let a=r.clientWidth,h=r.scrollLeft+(e==="left"?-a:a);r.scrollTo({left:h,behavior:"smooth"});},[]),_=useCallback(e=>{e.key==="ArrowLeft"?g("left"):e.key==="ArrowRight"&&g("right");},[g]);return p.createElement("div",{className:`relative group ${l}`,onKeyDown:_,onMouseMove:W,onMouseLeave:()=>{m(false),I(false);},onTouchStart:D,onTouchMove:G,onTouchEnd:X,role:"region","aria-label":"Carousel"},p.createElement(C.Root,{className:"overflow-hidden",type:"hover"},p.createElement(C.Viewport,{ref:o,className:"w-full overflow-x-auto snap-x snap-mandatory",style:{scrollbarWidth:"none",msOverflowStyle:"none",WebkitOverflowScrolling:"touch"}},p.createElement("div",{className:"inline-flex",style:{gap:`${n}px`}},p.Children.map(t,e=>e===null?null:p.createElement("div",{className:"snap-start shrink-0"},e))))),!R&&p.createElement(p.Fragment,null,s&&w&&p.createElement(E,{onClick:()=>g("left"),className:"absolute left-4 top-1/2 -translate-y-1/2 z-20 transition-opacity duration-200","aria-label":"Scroll left"},p.createElement("div",{className:"flex items-center justify-center w-10 h-10 rounded-full bg-overlay backdrop-blur-sm"},p.createElement($,{name:"arrow-left",size:24,color:"white"}))),c&&u&&p.createElement(E,{onClick:()=>g("right"),className:"absolute right-4 top-1/2 -translate-y-1/2 z-20 transition-opacity duration-200","aria-label":"Scroll right"},p.createElement("div",{className:"flex items-center justify-center w-10 h-10 rounded-full bg-overlay backdrop-blur-sm"},p.createElement($,{name:"arrow-right",size:24,color:"white"})))))};export{Me as Carousel};//# sourceMappingURL=Carousel.js.map
1
+ import*as C from'@radix-ui/react-scroll-area';import p,{useRef,useState,useCallback,useEffect}from'react';import {IconMap}from'@deckai/icons';import {clsx}from'clsx';import {twMerge}from'tailwind-merge';function b(...t){return twMerge(clsx(t))}var T={12:"h-[12px] w-[12px]",16:"h-[16px] w-[16px]",18:"h-[18px] w-[18px]",20:"h-[20px] w-[20px]",24:"h-[24px] w-[24px]",32:"h-[32px] w-[32px]",36:"h-[36px] w-[36px]",40:"h-[40px] w-[40px]",42:"h-[42px] w-[42px]",48:"h-[48px] w-[48px]",64:"h-[64px] w-[64px]",72:"h-[72px] w-[72px]"},N={sm:{12:"sm:h-[12px] sm:w-[12px]",16:"sm:h-[16px] sm:w-[16px]",18:"sm:h-[18px] sm:w-[18px]",20:"sm:h-[20px] sm:w-[20px]",24:"sm:h-[24px] sm:w-[24px]",32:"sm:h-[32px] sm:w-[32px]",36:"sm:h-[36px] sm:w-[36px]",40:"sm:h-[40px] sm:w-[40px]",42:"sm:h-[42px] sm:w-[42px]",48:"sm:h-[48px] sm:w-[48px]",64:"sm:h-[64px] sm:w-[64px]",72:"sm:h-[72px] sm:w-[72px]"},md:{12:"md:h-[12px] md:w-[12px]",16:"md:h-[16px] md:w-[16px]",18:"md:h-[18px] md:w-[18px]",20:"md:h-[20px] md:w-[20px]",24:"md:h-[24px] md:w-[24px]",32:"md:h-[32px] md:w-[32px]",36:"md:h-[36px] md:w-[36px]",40:"md:h-[40px] md:w-[40px]",42:"md:h-[42px] md:w-[42px]",48:"md:h-[48px] md:w-[48px]",64:"md:h-[64px] md:w-[64px]",72:"md:h-[72px] md:w-[72px]"},lg:{12:"lg:h-[12px] lg:w-[12px]",16:"lg:h-[16px] lg:w-[16px]",18:"lg:h-[18px] lg:w-[18px]",20:"lg:h-[20px] lg:w-[20px]",24:"lg:h-[24px] lg:w-[24px]",32:"lg:h-[32px] lg:w-[32px]",36:"lg:h-[36px] lg:w-[36px]",40:"lg:h-[40px] lg:w-[40px]",42:"lg:h-[42px] lg:w-[42px]",48:"lg:h-[48px] lg:w-[48px]",64:"lg:h-[64px] lg:w-[64px]",72:"lg:h-[72px] lg:w-[72px]"},xl:{12:"xl:h-[12px] xl:w-[12px]",16:"xl:h-[16px] xl:w-[16px]",18:"xl:h-[18px] xl:w-[18px]",20:"xl:h-[20px] xl:w-[20px]",24:"xl:h-[24px] xl:w-[24px]",32:"xl:h-[32px] xl:w-[32px]",36:"xl:h-[36px] xl:w-[36px]",40:"xl:h-[40px] xl:w-[40px]",42:"xl:h-[42px] xl:w-[42px]",48:"xl:h-[48px] xl:w-[48px]",64:"xl:h-[64px] xl:w-[64px]",72:"xl:h-[72px] xl:w-[72px]"},"2xl":{12:"2xl:h-[12px] 2xl:w-[12px]",16:"2xl:h-[16px] 2xl:w-[16px]",18:"2xl:h-[18px] 2xl:w-[18px]",20:"2xl:h-[20px] 2xl:w-[20px]",24:"2xl:h-[24px] 2xl:w-[24px]",32:"2xl:h-[32px] 2xl:w-[32px]",36:"2xl:h-[36px] 2xl:w-[36px]",40:"2xl:h-[40px] 2xl:w-[40px]",42:"2xl:h-[42px] 2xl:w-[42px]",48:"2xl:h-[48px] 2xl:w-[48px]",64:"2xl:h-[64px] 2xl:w-[64px]",72:"2xl:h-[72px] 2xl:w-[72px]"}},v=t=>String(t),O=(t,l=24)=>{let n=[],o={};if(t===void 0){let s=v(l);s?n.push(T[s]):(o.height=`${l}px`,o.width=`${l}px`);}if(typeof t=="number"){let s=v(t);s?n.push(T[s]):(o.height=`${t}px`,o.width=`${t}px`);}if(Array.isArray(t)){let s=v(l),i=[s&&T[s]||`h-[${l}px] w-[${l}px]`];t.forEach(c=>{if(typeof c=="string"){let[x,w]=c.split(":"),m=parseInt(w,10),u=v(m);n.push(u&&N[x]?.[u]||`${x}:h-[${m}px] ${x}:w-[${m}px]`);}}),n.push(...i);}if(typeof t=="string"){let[s,i]=t.split(":"),c=parseInt(i,10),x=v(c);n.push(x&&N[s]?.[x]||`${s}:h-[${c}px] ${s}:w-[${c}px]`);}return {responsiveSizeClasses:n.join(" "),responsiveSizeStyles:o}};var B={primary:"var(--color-primary)",secondary:"var(--color-secondary)",white:"var(--color-white)",primaryBlue:"var(--color-primary-100)",disabled:"var(--color-disabled)",danger:"var(--color-danger)"},$=p.forwardRef(({name:t,size:l=24,color:n="primary",title:o,className:s,style:i={},...c},x)=>{let w=IconMap[t],{responsiveSizeClasses:m,responsiveSizeStyles:u}=O(l,24);return p.createElement("div",{className:b("flex justify-center items-center",m,s),style:{"--icon-stroke":B[n],...u,...i}},p.createElement(w,{ref:x,"aria-hidden":!o,"aria-label":o,stroke:t.includes("filled")?void 0:B[n],...c}))});$.displayName="Icon";var H="focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-primary-100";var E=p.forwardRef(({children:t,type:l="button",className:n,disabled:o,...s},i)=>p.createElement("button",{ref:i,type:l,disabled:o,className:b("appearance-none hover:opacity-80 transition-all active:scale-95",H,o&&"opacity-50 cursor-not-allowed",n),...s},t));E.displayName="Pressable";var q=typeof window<"u"?useEffect:()=>{},V=t=>{let[l,n]=useState(null),o=useCallback(s=>typeof window<"u"?window.matchMedia(s).matches:false,[]);return q(()=>{n(o(t));},[t,o]),useEffect(()=>{if(typeof window<"u"){let s=window.matchMedia(t),i=()=>{n(o(t));};return s.addEventListener("change",i),()=>{s.removeEventListener("change",i);}}},[t,o]),l??false};function be({children:t,className:l="",gap:n=20}){let o=useRef(null),[s,i]=useState(false),[c,x]=useState(false),[w,m]=useState(false),[u,I]=useState(false),[M,j]=useState(null),[k,A]=useState(null),R=V("(max-width: 768px)"),y=useCallback(()=>{let e=o.current;if(!e)return;let{scrollLeft:r,scrollWidth:a,clientWidth:h}=e;i(r>0),x(Math.ceil(r+h)<a);},[]),W=useCallback(e=>{if(R)return;let a=e.currentTarget.getBoundingClientRect(),h=e.clientX-a.left,S=300;m(h<S),I(h>a.width-S);},[R]),D=useCallback(e=>{j(e.touches[0].clientX),A(null);},[]),G=useCallback(e=>{A(e.touches[0].clientX);},[]),X=useCallback(()=>{if(!M||!k)return;let e=o.current;if(!e)return;let r=M-k;if(Math.abs(r)<50)return;let h=e.clientWidth,S=r>0?1:-1,Q=e.scrollLeft+h*S;e.scrollTo({left:Q,behavior:"smooth"});},[M,k]),P=useCallback(e=>{let r=o.current;if(!r)return;let a=Math.abs(e.deltaX)>Math.abs(e.deltaY);if(!a&&!e.shiftKey)return;e.preventDefault();let h=a?e.deltaX:e.deltaY;r.scrollBy({left:h,behavior:"smooth"});},[]);useEffect(()=>{let e=o.current;if(!e)return;let r=new ResizeObserver(y);return r.observe(e),e.addEventListener("scroll",y),e.addEventListener("wheel",P,{passive:false}),()=>{r.disconnect(),e.removeEventListener("scroll",y),e.removeEventListener("wheel",P);}},[y,P]);let g=useCallback(e=>{let r=o.current;if(!r)return;let a=r.clientWidth,h=r.scrollLeft+(e==="left"?-a:a);r.scrollTo({left:h,behavior:"smooth"});},[]),_=useCallback(e=>{e.key==="ArrowLeft"?g("left"):e.key==="ArrowRight"&&g("right");},[g]);return p.createElement("div",{className:`relative group ${l}`,onKeyDown:_,onMouseMove:W,onMouseLeave:()=>{m(false),I(false);},onTouchStart:D,onTouchMove:G,onTouchEnd:X,role:"region","aria-label":"Carousel"},p.createElement(C.Root,{className:"overflow-hidden",type:"hover"},p.createElement(C.Viewport,{ref:o,className:"w-full overflow-x-auto snap-x snap-mandatory",style:{scrollbarWidth:"none",msOverflowStyle:"none",WebkitOverflowScrolling:"touch"}},p.createElement("div",{className:"inline-flex",style:{gap:`${n}px`}},p.Children.map(t,e=>e===null?null:p.createElement("div",{className:"snap-start shrink-0"},e))))),!R&&p.createElement(p.Fragment,null,s&&w&&p.createElement(E,{onClick:()=>g("left"),className:"absolute left-4 top-1/2 -translate-y-1/2 z-20 transition-opacity duration-200","aria-label":"Scroll left"},p.createElement("div",{className:"flex items-center justify-center w-10 h-10 rounded-full bg-overlay backdrop-blur-sm"},p.createElement($,{name:"arrow-left",size:24,color:"white"}))),c&&u&&p.createElement(E,{onClick:()=>g("right"),className:"absolute right-4 top-1/2 -translate-y-1/2 z-20 transition-opacity duration-200","aria-label":"Scroll right"},p.createElement("div",{className:"flex items-center justify-center w-10 h-10 rounded-full bg-overlay backdrop-blur-sm"},p.createElement($,{name:"arrow-right",size:24,color:"white"})))))}export{be as Carousel};//# sourceMappingURL=Carousel.js.map
2
2
  //# sourceMappingURL=Carousel.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/utils/index.ts","../../src/utils/responsive.ts","../../src/components/Icon.tsx","../../src/utils/tailwind.ts","../../src/components/Pressable.tsx","../../src/hooks/useMediaQuery.ts","../../src/components/Carousel.tsx"],"names":["cn","inputs","twMerge","clsx","BASE_SIZES","RESPONSIVE_SIZES","getSizeKey","size","getResponsiveSize","baseSize","classes","styles","key","baseKey","responsiveClasses","s","breakpoint","valueStr","value","valueKey","COLOR_MAP","Icon","React","name","color","title","className","style","props","ref","IconComponent","IconMap","responsiveSizeClasses","responsiveSizeStyles","focusRingStyles","Pressable","children","type","disabled","useIsomorphicLayoutEffect","useEffect","useMediaQuery","query","matches","setMatches","useState","getMatches","useCallback","mediaQuery","handleChange","Carousel","gap","scrollContainerRef","useRef","showLeftPaddle","setShowLeftPaddle","showRightPaddle","setShowRightPaddle","isHoveringStart","setIsHoveringStart","isHoveringEnd","setIsHoveringEnd","touchStart","setTouchStart","touchEnd","setTouchEnd","isMobile","checkScrollPosition","container","scrollLeft","scrollWidth","clientWidth","handleMouseMove","rect","mouseX","HOVER_THRESHOLD","handleTouchStart","handleTouchMove","handleTouchEnd","distance","itemWidth","direction","targetScroll","handleWheel","isHorizontalScroll","scrollAmount","observer","scroll","handleKeyDown","child"],"mappings":"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","file":"Carousel.js","sourcesContent":["import { clsx, type ClassValue } from \"clsx\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport function cn(...inputs: ClassValue[]) {\n return twMerge(clsx(inputs));\n}\n\nexport const noopFn = () => {};\n","export type Breakpoint = \"sm\" | \"md\" | \"lg\" | \"xl\" | \"2xl\";\nexport type ResponsiveSize = number | `${Breakpoint}:${number}`;\n\ntype SizeKey =\n | \"12\"\n | \"16\"\n | \"18\"\n | \"20\"\n | \"24\"\n | \"32\"\n | \"36\"\n | \"40\"\n | \"42\"\n | \"48\"\n | \"64\"\n | \"72\";\n\n// These constants help Tailwind identify the classes during compilation\nconst BASE_SIZES: Record<SizeKey, string> = {\n \"12\": \"h-[12px] w-[12px]\",\n \"16\": \"h-[16px] w-[16px]\",\n \"18\": \"h-[18px] w-[18px]\",\n \"20\": \"h-[20px] w-[20px]\",\n \"24\": \"h-[24px] w-[24px]\",\n \"32\": \"h-[32px] w-[32px]\",\n \"36\": \"h-[36px] w-[36px]\",\n \"40\": \"h-[40px] w-[40px]\",\n \"42\": \"h-[42px] w-[42px]\",\n \"48\": \"h-[48px] w-[48px]\",\n \"64\": \"h-[64px] w-[64px]\",\n \"72\": \"h-[72px] w-[72px]\"\n};\n\nconst RESPONSIVE_SIZES: Record<Breakpoint, Record<SizeKey, string>> = {\n sm: {\n \"12\": \"sm:h-[12px] sm:w-[12px]\",\n \"16\": \"sm:h-[16px] sm:w-[16px]\",\n \"18\": \"sm:h-[18px] sm:w-[18px]\",\n \"20\": \"sm:h-[20px] sm:w-[20px]\",\n \"24\": \"sm:h-[24px] sm:w-[24px]\",\n \"32\": \"sm:h-[32px] sm:w-[32px]\",\n \"36\": \"sm:h-[36px] sm:w-[36px]\",\n \"40\": \"sm:h-[40px] sm:w-[40px]\",\n \"42\": \"sm:h-[42px] sm:w-[42px]\",\n \"48\": \"sm:h-[48px] sm:w-[48px]\",\n \"64\": \"sm:h-[64px] sm:w-[64px]\",\n \"72\": \"sm:h-[72px] sm:w-[72px]\"\n },\n md: {\n \"12\": \"md:h-[12px] md:w-[12px]\",\n \"16\": \"md:h-[16px] md:w-[16px]\",\n \"18\": \"md:h-[18px] md:w-[18px]\",\n \"20\": \"md:h-[20px] md:w-[20px]\",\n \"24\": \"md:h-[24px] md:w-[24px]\",\n \"32\": \"md:h-[32px] md:w-[32px]\",\n \"36\": \"md:h-[36px] md:w-[36px]\",\n \"40\": \"md:h-[40px] md:w-[40px]\",\n \"42\": \"md:h-[42px] md:w-[42px]\",\n \"48\": \"md:h-[48px] md:w-[48px]\",\n \"64\": \"md:h-[64px] md:w-[64px]\",\n \"72\": \"md:h-[72px] md:w-[72px]\"\n },\n lg: {\n \"12\": \"lg:h-[12px] lg:w-[12px]\",\n \"16\": \"lg:h-[16px] lg:w-[16px]\",\n \"18\": \"lg:h-[18px] lg:w-[18px]\",\n \"20\": \"lg:h-[20px] lg:w-[20px]\",\n \"24\": \"lg:h-[24px] lg:w-[24px]\",\n \"32\": \"lg:h-[32px] lg:w-[32px]\",\n \"36\": \"lg:h-[36px] lg:w-[36px]\",\n \"40\": \"lg:h-[40px] lg:w-[40px]\",\n \"42\": \"lg:h-[42px] lg:w-[42px]\",\n \"48\": \"lg:h-[48px] lg:w-[48px]\",\n \"64\": \"lg:h-[64px] lg:w-[64px]\",\n \"72\": \"lg:h-[72px] lg:w-[72px]\"\n },\n xl: {\n \"12\": \"xl:h-[12px] xl:w-[12px]\",\n \"16\": \"xl:h-[16px] xl:w-[16px]\",\n \"18\": \"xl:h-[18px] xl:w-[18px]\",\n \"20\": \"xl:h-[20px] xl:w-[20px]\",\n \"24\": \"xl:h-[24px] xl:w-[24px]\",\n \"32\": \"xl:h-[32px] xl:w-[32px]\",\n \"36\": \"xl:h-[36px] xl:w-[36px]\",\n \"40\": \"xl:h-[40px] xl:w-[40px]\",\n \"42\": \"xl:h-[42px] xl:w-[42px]\",\n \"48\": \"xl:h-[48px] xl:w-[48px]\",\n \"64\": \"xl:h-[64px] xl:w-[64px]\",\n \"72\": \"xl:h-[72px] xl:w-[72px]\"\n },\n \"2xl\": {\n \"12\": \"2xl:h-[12px] 2xl:w-[12px]\",\n \"16\": \"2xl:h-[16px] 2xl:w-[16px]\",\n \"18\": \"2xl:h-[18px] 2xl:w-[18px]\",\n \"20\": \"2xl:h-[20px] 2xl:w-[20px]\",\n \"24\": \"2xl:h-[24px] 2xl:w-[24px]\",\n \"32\": \"2xl:h-[32px] 2xl:w-[32px]\",\n \"36\": \"2xl:h-[36px] 2xl:w-[36px]\",\n \"40\": \"2xl:h-[40px] 2xl:w-[40px]\",\n \"42\": \"2xl:h-[42px] 2xl:w-[42px]\",\n \"48\": \"2xl:h-[48px] 2xl:w-[48px]\",\n \"64\": \"2xl:h-[64px] 2xl:w-[64px]\",\n \"72\": \"2xl:h-[72px] 2xl:w-[72px]\"\n }\n};\n\nconst getSizeKey = (size: number): SizeKey | undefined => {\n return String(size) as SizeKey;\n};\n\nexport const getResponsiveSize = (\n size: ResponsiveSize | ResponsiveSize[] | undefined,\n baseSize: number = 24\n): {\n responsiveSizeClasses: string;\n responsiveSizeStyles: Record<string, string>;\n} => {\n const classes: string[] = [];\n const styles: Record<string, string> = {};\n\n // If no size provided, use baseSize\n if (size === undefined) {\n const key = getSizeKey(baseSize);\n if (key) {\n classes.push(BASE_SIZES[key]);\n } else {\n styles.height = `${baseSize}px`;\n styles.width = `${baseSize}px`;\n }\n }\n\n // If size is a number, use that directly\n if (typeof size === \"number\") {\n const key = getSizeKey(size);\n if (key) {\n classes.push(BASE_SIZES[key]);\n } else {\n styles.height = `${size}px`;\n styles.width = `${size}px`;\n }\n }\n\n // If array of responsive sizes, generate responsive classes\n if (Array.isArray(size)) {\n const baseKey = getSizeKey(baseSize);\n const responsiveClasses = [\n (baseKey && BASE_SIZES[baseKey]) || `h-[${baseSize}px] w-[${baseSize}px]`\n ];\n\n size.forEach((s) => {\n if (typeof s === \"string\") {\n const [breakpoint, valueStr] = s.split(\":\") as [Breakpoint, string];\n const value = parseInt(valueStr, 10);\n const key = getSizeKey(value);\n classes.push(\n (key && RESPONSIVE_SIZES[breakpoint]?.[key]) ||\n `${breakpoint}:h-[${value}px] ${breakpoint}:w-[${value}px]`\n );\n }\n });\n\n classes.push(...responsiveClasses);\n }\n\n if (typeof size === \"string\") {\n const [breakpoint, valueStr] = size.split(\":\") as [Breakpoint, string];\n const value = parseInt(valueStr, 10);\n const valueKey = getSizeKey(value);\n classes.push(\n (valueKey && RESPONSIVE_SIZES[breakpoint]?.[valueKey]) ||\n `${breakpoint}:h-[${value}px] ${breakpoint}:w-[${value}px]`\n );\n }\n\n return {\n responsiveSizeClasses: classes.join(\" \"),\n responsiveSizeStyles: styles\n };\n};\n","import { IconMap, IconName } from \"@deckai/icons\";\nimport React, { SVGProps } from \"react\";\nimport { IconColors } from \"../types/tailwind\";\nimport { cn } from \"../utils\";\nimport { ResponsiveSize, getResponsiveSize } from \"../utils/responsive\";\n\nexport type IconProps = {\n name: IconName;\n /** @default 24 */\n size?: ResponsiveSize | ResponsiveSize[];\n /** @default primary */\n color?: IconColors;\n title?: string;\n className?: string;\n style?: React.CSSProperties;\n} & Omit<SVGProps<SVGSVGElement>, \"aria-hidden\" | \"aria-label\">;\n\n// Using CSS variables to support dark mode\nconst COLOR_MAP: Record<IconColors, string> = {\n primary: \"var(--color-primary)\",\n secondary: \"var(--color-secondary)\",\n white: \"var(--color-white)\",\n primaryBlue: \"var(--color-primary-100)\",\n disabled: \"var(--color-disabled)\",\n danger: \"var(--color-danger)\"\n};\n\nexport const Icon = React.forwardRef<SVGSVGElement, IconProps>(\n (\n {\n name,\n size = 24,\n color = \"primary\",\n title,\n className,\n style = {},\n ...props\n },\n ref\n ) => {\n const IconComponent = IconMap[name];\n const { responsiveSizeClasses, responsiveSizeStyles } = getResponsiveSize(\n size,\n 24\n );\n\n return (\n <div\n className={cn(\n \"flex justify-center items-center\",\n responsiveSizeClasses,\n className\n )}\n style={{\n [\"--icon-stroke\" as string]: COLOR_MAP[color],\n ...responsiveSizeStyles,\n ...style\n }}\n >\n <IconComponent\n ref={ref}\n aria-hidden={!title}\n aria-label={title}\n stroke={name.includes(\"filled\") ? undefined : COLOR_MAP[color]}\n {...props}\n />\n </div>\n );\n }\n);\n\nIcon.displayName = \"Icon\";\n","import { Colors, Typography } from \"../types/tailwind\";\n\n// Generate safelist patterns for all color utilities so you can use any theme color variable in your code\nexport const generateSafelist = (colors: Colors, typography: Typography) => {\n const colorNames = Object.keys(colors) as (keyof Colors)[];\n const utilities = [\"bg\", \"text\", \"border\", \"ring\", \"divide\", \"outline\"];\n const variants = [\"hover:\", \"focus:\", \"active:\", \"disabled:\"];\n const breakpoints = [\"sm\", \"md\", \"lg\", \"xl\", \"2xl\"];\n const sizes = [\"24\", \"42\", \"48\", \"64\", \"72\"]; // Add all the sizes you need\n\n const safelist: (string | { pattern: RegExp; variants: string[] })[] = [];\n\n colorNames.forEach((colorName) => {\n if (typeof colors[colorName] === \"object\") {\n // Handle nested color objects (with number keys)\n Object.keys(colors[colorName]).forEach((shade) => {\n utilities.forEach((utility) => {\n // Base utility\n safelist.push(`${utility}-${colorName}-${shade}`);\n\n // Variant utilities\n variants.forEach((variant) => {\n safelist.push(`${variant}${utility}-${colorName}-${shade}`);\n });\n });\n });\n } else {\n // Handle direct color values\n utilities.forEach((utility) => {\n safelist.push(`${utility}-${colorName}`);\n\n variants.forEach((variant) => {\n safelist.push(`${variant}${utility}-${colorName}`);\n });\n });\n }\n });\n\n // Generate typography classes\n Object.entries(typography).forEach(([family, sizes]) => {\n Object.keys(sizes).forEach((size) => {\n // Base typography classes\n safelist.push(`text-${family}-${size}`);\n\n // Add variants\n variants.forEach((variant) => {\n safelist.push(`${variant}text-${family}-${size}`);\n });\n });\n });\n\n const typographyClasses = Object.entries(typography).flatMap(\n ([category, sizes]) =>\n Object.keys(sizes).map((size) => `text-${category}-${size}`)\n );\n\n // Generate responsive variants\n const responsiveTypographyClasses = typographyClasses.flatMap((className) =>\n breakpoints.map((breakpoint) => `${breakpoint}:${className}`)\n );\n\n // Generate size classes with responsive variants\n const sizeClasses = sizes.flatMap((size) => [\n `h-[${size}px]`,\n `w-[${size}px]`,\n ...breakpoints.flatMap((bp) => [\n `${bp}:h-[${size}px]`,\n `${bp}:w-[${size}px]`\n ])\n ]);\n\n return [...typographyClasses, ...responsiveTypographyClasses, ...sizeClasses];\n};\n\nexport const focusRingStyles =\n \"focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-primary-100\";\nexport const focusRingWithinStyles =\n \"focus-within:outline-none focus-within:ring-2 focus-within:ring-primary-100\";\nexport const focusRingStylesCoerced = \"ring-2 ring-primary-100\";\n","import React, { ButtonHTMLAttributes } from \"react\";\nimport { focusRingStyles } from \"../utils/tailwind\";\nimport { cn } from \"../utils\";\n\nexport type PressableProps = ButtonHTMLAttributes<HTMLButtonElement>;\n\nexport const Pressable = React.forwardRef<HTMLButtonElement, PressableProps>(\n ({ children, type = \"button\", className, disabled, ...props }, ref) => (\n <button\n ref={ref}\n type={type}\n disabled={disabled}\n className={cn(\n \"appearance-none hover:opacity-80 transition-all active:scale-95\",\n focusRingStyles,\n disabled && \"opacity-50 cursor-not-allowed\",\n className\n )}\n {...props}\n >\n {children}\n </button>\n )\n);\n\nPressable.displayName = \"Pressable\";\n","import { useCallback, useEffect, useState } from \"react\";\n\nconst useIsomorphicLayoutEffect =\n typeof window !== \"undefined\" ? useEffect : () => {};\n\nexport const useMediaQuery = (query: string): boolean => {\n // Initialize with null to prevent hydration mismatch\n const [matches, setMatches] = useState<boolean | null>(null);\n\n const getMatches = useCallback((query: string): boolean => {\n if (typeof window !== \"undefined\") {\n return window.matchMedia(query).matches;\n }\n return false;\n }, []);\n\n // Update matches after mount to prevent hydration mismatch\n useIsomorphicLayoutEffect(() => {\n setMatches(getMatches(query));\n }, [query, getMatches]);\n\n useEffect(() => {\n if (typeof window !== \"undefined\") {\n const mediaQuery = window.matchMedia(query);\n\n const handleChange = () => {\n setMatches(getMatches(query));\n };\n\n mediaQuery.addEventListener(\"change\", handleChange);\n\n return () => {\n mediaQuery.removeEventListener(\"change\", handleChange);\n };\n }\n }, [query, getMatches]);\n\n // Return false during SSR, actual value after hydration\n return matches ?? false;\n};\n","import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport * as ScrollArea from \"@radix-ui/react-scroll-area\";\nimport { Icon } from \"./Icon\";\nimport { Pressable } from \"./Pressable\";\nimport { useMediaQuery } from \"../hooks/useMediaQuery\";\n\nexport type CarouselProps = {\n children: React.ReactNode;\n /** Optional className for the root element */\n className?: string;\n /** Optional gap between items in pixels */\n gap?: number;\n};\n\nexport const Carousel = ({\n children,\n className = \"\",\n gap = 20\n}: CarouselProps) => {\n const scrollContainerRef = useRef<HTMLDivElement>(null);\n const [showLeftPaddle, setShowLeftPaddle] = useState(false);\n const [showRightPaddle, setShowRightPaddle] = useState(false);\n const [isHoveringStart, setIsHoveringStart] = useState(false);\n const [isHoveringEnd, setIsHoveringEnd] = useState(false);\n const [touchStart, setTouchStart] = useState<number | null>(null);\n const [touchEnd, setTouchEnd] = useState<number | null>(null);\n const isMobile = useMediaQuery(\"(max-width: 768px)\");\n\n const checkScrollPosition = useCallback(() => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const { scrollLeft, scrollWidth, clientWidth } = container;\n setShowLeftPaddle(scrollLeft > 0);\n setShowRightPaddle(Math.ceil(scrollLeft + clientWidth) < scrollWidth);\n }, []);\n\n const handleMouseMove = useCallback(\n (e: React.MouseEvent) => {\n if (isMobile) return;\n\n const container = e.currentTarget;\n const rect = container.getBoundingClientRect();\n const mouseX = e.clientX - rect.left;\n const HOVER_THRESHOLD = 300;\n\n setIsHoveringStart(mouseX < HOVER_THRESHOLD);\n setIsHoveringEnd(mouseX > rect.width - HOVER_THRESHOLD);\n },\n [isMobile]\n );\n\n // Touch handling\n const handleTouchStart = useCallback((e: React.TouchEvent) => {\n setTouchStart(e.touches[0].clientX);\n setTouchEnd(null);\n }, []);\n\n const handleTouchMove = useCallback((e: React.TouchEvent) => {\n setTouchEnd(e.touches[0].clientX);\n }, []);\n\n const handleTouchEnd = useCallback(() => {\n if (!touchStart || !touchEnd) return;\n\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const distance = touchStart - touchEnd;\n const minSwipeDistance = 50;\n\n if (Math.abs(distance) < minSwipeDistance) {\n return;\n }\n\n const itemWidth = container.clientWidth;\n const direction = distance > 0 ? 1 : -1;\n const targetScroll = container.scrollLeft + itemWidth * direction;\n\n container.scrollTo({\n left: targetScroll,\n behavior: \"smooth\"\n });\n }, [touchStart, touchEnd]);\n\n const handleWheel = useCallback((e: WheelEvent) => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n // Check if the scroll is predominantly horizontal or if shift key is pressed\n const isHorizontalScroll = Math.abs(e.deltaX) > Math.abs(e.deltaY);\n if (!isHorizontalScroll && !e.shiftKey) return;\n\n e.preventDefault();\n\n // Determine the scroll amount based on the input type\n const scrollAmount = isHorizontalScroll ? e.deltaX : e.deltaY;\n\n // Apply smooth scrolling\n container.scrollBy({\n left: scrollAmount,\n behavior: \"smooth\"\n });\n }, []);\n\n useEffect(() => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const observer = new ResizeObserver(checkScrollPosition);\n observer.observe(container);\n\n container.addEventListener(\"scroll\", checkScrollPosition);\n container.addEventListener(\"wheel\", handleWheel, { passive: false });\n\n return () => {\n observer.disconnect();\n container.removeEventListener(\"scroll\", checkScrollPosition);\n container.removeEventListener(\"wheel\", handleWheel);\n };\n }, [checkScrollPosition, handleWheel]);\n\n const scroll = useCallback((direction: \"left\" | \"right\") => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const scrollAmount = container.clientWidth;\n const targetScroll =\n container.scrollLeft +\n (direction === \"left\" ? -scrollAmount : scrollAmount);\n\n container.scrollTo({\n left: targetScroll,\n behavior: \"smooth\"\n });\n }, []);\n\n const handleKeyDown = useCallback(\n (e: React.KeyboardEvent) => {\n if (e.key === \"ArrowLeft\") {\n scroll(\"left\");\n } else if (e.key === \"ArrowRight\") {\n scroll(\"right\");\n }\n },\n [scroll]\n );\n\n return (\n <div\n className={`relative group ${className}`}\n onKeyDown={handleKeyDown}\n onMouseMove={handleMouseMove}\n onMouseLeave={() => {\n setIsHoveringStart(false);\n setIsHoveringEnd(false);\n }}\n onTouchStart={handleTouchStart}\n onTouchMove={handleTouchMove}\n onTouchEnd={handleTouchEnd}\n role=\"region\"\n aria-label=\"Carousel\"\n >\n <ScrollArea.Root className=\"overflow-hidden\" type=\"hover\">\n <ScrollArea.Viewport\n ref={scrollContainerRef}\n className=\"w-full overflow-x-auto snap-x snap-mandatory\"\n style={{\n scrollbarWidth: \"none\",\n msOverflowStyle: \"none\",\n WebkitOverflowScrolling: \"touch\"\n }}\n >\n <div\n className=\"inline-flex\"\n style={{\n gap: `${gap}px`\n }}\n >\n {React.Children.map(children, (child) =>\n child === null ? null : (\n <div className=\"snap-start shrink-0\">{child}</div>\n )\n )}\n </div>\n </ScrollArea.Viewport>\n </ScrollArea.Root>\n\n {/* Navigation Paddles - Only show on desktop */}\n {!isMobile && (\n <>\n {showLeftPaddle && isHoveringStart && (\n <Pressable\n onClick={() => scroll(\"left\")}\n className=\"absolute left-4 top-1/2 -translate-y-1/2 z-20 transition-opacity duration-200\"\n aria-label=\"Scroll left\"\n >\n <div className=\"flex items-center justify-center w-10 h-10 rounded-full bg-overlay backdrop-blur-sm\">\n <Icon name=\"arrow-left\" size={24} color=\"white\" />\n </div>\n </Pressable>\n )}\n\n {showRightPaddle && isHoveringEnd && (\n <Pressable\n onClick={() => scroll(\"right\")}\n className=\"absolute right-4 top-1/2 -translate-y-1/2 z-20 transition-opacity duration-200\"\n aria-label=\"Scroll right\"\n >\n <div className=\"flex items-center justify-center w-10 h-10 rounded-full bg-overlay backdrop-blur-sm\">\n <Icon name=\"arrow-right\" size={24} color=\"white\" />\n </div>\n </Pressable>\n )}\n </>\n )}\n </div>\n );\n};\n"]}
1
+ {"version":3,"sources":["../../src/utils/index.ts","../../src/utils/responsive.ts","../../src/components/Icon.tsx","../../src/utils/tailwind.ts","../../src/components/Pressable.tsx","../../src/hooks/useMediaQuery.ts","../../src/components/Carousel.tsx"],"names":["cn","inputs","twMerge","clsx","BASE_SIZES","RESPONSIVE_SIZES","getSizeKey","size","getResponsiveSize","baseSize","classes","styles","key","baseKey","responsiveClasses","s","breakpoint","valueStr","value","valueKey","COLOR_MAP","Icon","React","name","color","title","className","style","props","ref","IconComponent","IconMap","responsiveSizeClasses","responsiveSizeStyles","focusRingStyles","Pressable","children","type","disabled","useIsomorphicLayoutEffect","useEffect","useMediaQuery","query","matches","setMatches","useState","getMatches","useCallback","mediaQuery","handleChange","Carousel","gap","scrollContainerRef","useRef","showLeftPaddle","setShowLeftPaddle","showRightPaddle","setShowRightPaddle","isHoveringStart","setIsHoveringStart","isHoveringEnd","setIsHoveringEnd","touchStart","setTouchStart","touchEnd","setTouchEnd","isMobile","checkScrollPosition","container","scrollLeft","scrollWidth","clientWidth","handleMouseMove","rect","mouseX","HOVER_THRESHOLD","handleTouchStart","handleTouchMove","handleTouchEnd","distance","itemWidth","direction","targetScroll","handleWheel","isHorizontalScroll","scrollAmount","observer","scroll","handleKeyDown","child"],"mappings":"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","file":"Carousel.js","sourcesContent":["import { clsx, type ClassValue } from \"clsx\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport function cn(...inputs: ClassValue[]) {\n return twMerge(clsx(inputs));\n}\n\nexport const noopFn = () => {};\n","export type Breakpoint = \"sm\" | \"md\" | \"lg\" | \"xl\" | \"2xl\";\nexport type ResponsiveSize = number | `${Breakpoint}:${number}`;\n\ntype SizeKey =\n | \"12\"\n | \"16\"\n | \"18\"\n | \"20\"\n | \"24\"\n | \"32\"\n | \"36\"\n | \"40\"\n | \"42\"\n | \"48\"\n | \"64\"\n | \"72\";\n\n// These constants help Tailwind identify the classes during compilation\nconst BASE_SIZES: Record<SizeKey, string> = {\n \"12\": \"h-[12px] w-[12px]\",\n \"16\": \"h-[16px] w-[16px]\",\n \"18\": \"h-[18px] w-[18px]\",\n \"20\": \"h-[20px] w-[20px]\",\n \"24\": \"h-[24px] w-[24px]\",\n \"32\": \"h-[32px] w-[32px]\",\n \"36\": \"h-[36px] w-[36px]\",\n \"40\": \"h-[40px] w-[40px]\",\n \"42\": \"h-[42px] w-[42px]\",\n \"48\": \"h-[48px] w-[48px]\",\n \"64\": \"h-[64px] w-[64px]\",\n \"72\": \"h-[72px] w-[72px]\"\n};\n\nconst RESPONSIVE_SIZES: Record<Breakpoint, Record<SizeKey, string>> = {\n sm: {\n \"12\": \"sm:h-[12px] sm:w-[12px]\",\n \"16\": \"sm:h-[16px] sm:w-[16px]\",\n \"18\": \"sm:h-[18px] sm:w-[18px]\",\n \"20\": \"sm:h-[20px] sm:w-[20px]\",\n \"24\": \"sm:h-[24px] sm:w-[24px]\",\n \"32\": \"sm:h-[32px] sm:w-[32px]\",\n \"36\": \"sm:h-[36px] sm:w-[36px]\",\n \"40\": \"sm:h-[40px] sm:w-[40px]\",\n \"42\": \"sm:h-[42px] sm:w-[42px]\",\n \"48\": \"sm:h-[48px] sm:w-[48px]\",\n \"64\": \"sm:h-[64px] sm:w-[64px]\",\n \"72\": \"sm:h-[72px] sm:w-[72px]\"\n },\n md: {\n \"12\": \"md:h-[12px] md:w-[12px]\",\n \"16\": \"md:h-[16px] md:w-[16px]\",\n \"18\": \"md:h-[18px] md:w-[18px]\",\n \"20\": \"md:h-[20px] md:w-[20px]\",\n \"24\": \"md:h-[24px] md:w-[24px]\",\n \"32\": \"md:h-[32px] md:w-[32px]\",\n \"36\": \"md:h-[36px] md:w-[36px]\",\n \"40\": \"md:h-[40px] md:w-[40px]\",\n \"42\": \"md:h-[42px] md:w-[42px]\",\n \"48\": \"md:h-[48px] md:w-[48px]\",\n \"64\": \"md:h-[64px] md:w-[64px]\",\n \"72\": \"md:h-[72px] md:w-[72px]\"\n },\n lg: {\n \"12\": \"lg:h-[12px] lg:w-[12px]\",\n \"16\": \"lg:h-[16px] lg:w-[16px]\",\n \"18\": \"lg:h-[18px] lg:w-[18px]\",\n \"20\": \"lg:h-[20px] lg:w-[20px]\",\n \"24\": \"lg:h-[24px] lg:w-[24px]\",\n \"32\": \"lg:h-[32px] lg:w-[32px]\",\n \"36\": \"lg:h-[36px] lg:w-[36px]\",\n \"40\": \"lg:h-[40px] lg:w-[40px]\",\n \"42\": \"lg:h-[42px] lg:w-[42px]\",\n \"48\": \"lg:h-[48px] lg:w-[48px]\",\n \"64\": \"lg:h-[64px] lg:w-[64px]\",\n \"72\": \"lg:h-[72px] lg:w-[72px]\"\n },\n xl: {\n \"12\": \"xl:h-[12px] xl:w-[12px]\",\n \"16\": \"xl:h-[16px] xl:w-[16px]\",\n \"18\": \"xl:h-[18px] xl:w-[18px]\",\n \"20\": \"xl:h-[20px] xl:w-[20px]\",\n \"24\": \"xl:h-[24px] xl:w-[24px]\",\n \"32\": \"xl:h-[32px] xl:w-[32px]\",\n \"36\": \"xl:h-[36px] xl:w-[36px]\",\n \"40\": \"xl:h-[40px] xl:w-[40px]\",\n \"42\": \"xl:h-[42px] xl:w-[42px]\",\n \"48\": \"xl:h-[48px] xl:w-[48px]\",\n \"64\": \"xl:h-[64px] xl:w-[64px]\",\n \"72\": \"xl:h-[72px] xl:w-[72px]\"\n },\n \"2xl\": {\n \"12\": \"2xl:h-[12px] 2xl:w-[12px]\",\n \"16\": \"2xl:h-[16px] 2xl:w-[16px]\",\n \"18\": \"2xl:h-[18px] 2xl:w-[18px]\",\n \"20\": \"2xl:h-[20px] 2xl:w-[20px]\",\n \"24\": \"2xl:h-[24px] 2xl:w-[24px]\",\n \"32\": \"2xl:h-[32px] 2xl:w-[32px]\",\n \"36\": \"2xl:h-[36px] 2xl:w-[36px]\",\n \"40\": \"2xl:h-[40px] 2xl:w-[40px]\",\n \"42\": \"2xl:h-[42px] 2xl:w-[42px]\",\n \"48\": \"2xl:h-[48px] 2xl:w-[48px]\",\n \"64\": \"2xl:h-[64px] 2xl:w-[64px]\",\n \"72\": \"2xl:h-[72px] 2xl:w-[72px]\"\n }\n};\n\nconst getSizeKey = (size: number): SizeKey | undefined => {\n return String(size) as SizeKey;\n};\n\nexport const getResponsiveSize = (\n size: ResponsiveSize | ResponsiveSize[] | undefined,\n baseSize: number = 24\n): {\n responsiveSizeClasses: string;\n responsiveSizeStyles: Record<string, string>;\n} => {\n const classes: string[] = [];\n const styles: Record<string, string> = {};\n\n // If no size provided, use baseSize\n if (size === undefined) {\n const key = getSizeKey(baseSize);\n if (key) {\n classes.push(BASE_SIZES[key]);\n } else {\n styles.height = `${baseSize}px`;\n styles.width = `${baseSize}px`;\n }\n }\n\n // If size is a number, use that directly\n if (typeof size === \"number\") {\n const key = getSizeKey(size);\n if (key) {\n classes.push(BASE_SIZES[key]);\n } else {\n styles.height = `${size}px`;\n styles.width = `${size}px`;\n }\n }\n\n // If array of responsive sizes, generate responsive classes\n if (Array.isArray(size)) {\n const baseKey = getSizeKey(baseSize);\n const responsiveClasses = [\n (baseKey && BASE_SIZES[baseKey]) || `h-[${baseSize}px] w-[${baseSize}px]`\n ];\n\n size.forEach((s) => {\n if (typeof s === \"string\") {\n const [breakpoint, valueStr] = s.split(\":\") as [Breakpoint, string];\n const value = parseInt(valueStr, 10);\n const key = getSizeKey(value);\n classes.push(\n (key && RESPONSIVE_SIZES[breakpoint]?.[key]) ||\n `${breakpoint}:h-[${value}px] ${breakpoint}:w-[${value}px]`\n );\n }\n });\n\n classes.push(...responsiveClasses);\n }\n\n if (typeof size === \"string\") {\n const [breakpoint, valueStr] = size.split(\":\") as [Breakpoint, string];\n const value = parseInt(valueStr, 10);\n const valueKey = getSizeKey(value);\n classes.push(\n (valueKey && RESPONSIVE_SIZES[breakpoint]?.[valueKey]) ||\n `${breakpoint}:h-[${value}px] ${breakpoint}:w-[${value}px]`\n );\n }\n\n return {\n responsiveSizeClasses: classes.join(\" \"),\n responsiveSizeStyles: styles\n };\n};\n","import type { IconName } from \"@deckai/icons\";\nimport { IconMap } from \"@deckai/icons\";\nimport type { SVGProps } from \"react\";\nimport React from \"react\";\n\nimport type { IconColors } from \"../types/tailwind\";\nimport { cn } from \"../utils\";\nimport type { ResponsiveSize } from \"../utils/responsive\";\nimport { getResponsiveSize } from \"../utils/responsive\";\n\nexport type IconProps = {\n name: IconName;\n /** @default 24 */\n size?: ResponsiveSize | ResponsiveSize[];\n /** @default primary */\n color?: IconColors;\n title?: string;\n className?: string;\n style?: React.CSSProperties;\n} & Omit<SVGProps<SVGSVGElement>, \"aria-hidden\" | \"aria-label\">;\n\n// Using CSS variables to support dark mode\nconst COLOR_MAP: Record<IconColors, string> = {\n primary: \"var(--color-primary)\",\n secondary: \"var(--color-secondary)\",\n white: \"var(--color-white)\",\n primaryBlue: \"var(--color-primary-100)\",\n disabled: \"var(--color-disabled)\",\n danger: \"var(--color-danger)\"\n};\n\nexport const Icon = React.forwardRef<SVGSVGElement, IconProps>(\n (\n {\n name,\n size = 24,\n color = \"primary\",\n title,\n className,\n style = {},\n ...props\n },\n ref\n ) => {\n const IconComponent = IconMap[name];\n const { responsiveSizeClasses, responsiveSizeStyles } = getResponsiveSize(\n size,\n 24\n );\n\n return (\n <div\n className={cn(\n \"flex justify-center items-center\",\n responsiveSizeClasses,\n className\n )}\n style={{\n [\"--icon-stroke\" as string]: COLOR_MAP[color],\n ...responsiveSizeStyles,\n ...style\n }}\n >\n <IconComponent\n ref={ref}\n aria-hidden={!title}\n aria-label={title}\n stroke={name.includes(\"filled\") ? undefined : COLOR_MAP[color]}\n {...props}\n />\n </div>\n );\n }\n);\n\nIcon.displayName = \"Icon\";\n","import type { Colors, Typography } from \"../types/tailwind\";\n\n// Generate safelist patterns for all color utilities so you can use any theme color variable in your code\nexport const generateSafelist = (colors: Colors, typography: Typography) => {\n const colorNames = Object.keys(colors) as (keyof Colors)[];\n const utilities = [\"bg\", \"text\", \"border\", \"ring\", \"divide\", \"outline\"];\n const variants = [\"hover:\", \"focus:\", \"active:\", \"disabled:\"];\n const breakpoints = [\"sm\", \"md\", \"lg\", \"xl\", \"2xl\"];\n const sizes = [\"24\", \"42\", \"48\", \"64\", \"72\"]; // Add all the sizes you need\n\n const safelist: (string | { pattern: RegExp; variants: string[] })[] = [];\n\n colorNames.forEach((colorName) => {\n if (typeof colors[colorName] === \"object\") {\n // Handle nested color objects (with number keys)\n Object.keys(colors[colorName]).forEach((shade) => {\n utilities.forEach((utility) => {\n // Base utility\n safelist.push(`${utility}-${colorName}-${shade}`);\n\n // Variant utilities\n variants.forEach((variant) => {\n safelist.push(`${variant}${utility}-${colorName}-${shade}`);\n });\n });\n });\n } else {\n // Handle direct color values\n utilities.forEach((utility) => {\n safelist.push(`${utility}-${colorName}`);\n\n variants.forEach((variant) => {\n safelist.push(`${variant}${utility}-${colorName}`);\n });\n });\n }\n });\n\n // Generate typography classes\n Object.entries(typography).forEach(([family, sizes]) => {\n Object.keys(sizes).forEach((size) => {\n // Base typography classes\n safelist.push(`text-${family}-${size}`);\n\n // Add variants\n variants.forEach((variant) => {\n safelist.push(`${variant}text-${family}-${size}`);\n });\n });\n });\n\n const typographyClasses = Object.entries(typography).flatMap(\n ([category, sizes]) =>\n Object.keys(sizes).map((size) => `text-${category}-${size}`)\n );\n\n // Generate responsive variants\n const responsiveTypographyClasses = typographyClasses.flatMap((className) =>\n breakpoints.map((breakpoint) => `${breakpoint}:${className}`)\n );\n\n // Generate size classes with responsive variants\n const sizeClasses = sizes.flatMap((size) => [\n `h-[${size}px]`,\n `w-[${size}px]`,\n ...breakpoints.flatMap((bp) => [\n `${bp}:h-[${size}px]`,\n `${bp}:w-[${size}px]`\n ])\n ]);\n\n return [...typographyClasses, ...responsiveTypographyClasses, ...sizeClasses];\n};\n\nexport const focusRingStyles =\n \"focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-primary-100\";\nexport const focusRingWithinStyles =\n \"focus-within:outline-none focus-within:ring-2 focus-within:ring-primary-100\";\nexport const focusRingStylesCoerced = \"ring-2 ring-primary-100\";\n","import type { ButtonHTMLAttributes } from \"react\";\nimport React from \"react\";\n\nimport { cn } from \"../utils\";\nimport { focusRingStyles } from \"../utils/tailwind\";\n\nexport type PressableProps = ButtonHTMLAttributes<HTMLButtonElement>;\n\nexport const Pressable = React.forwardRef<HTMLButtonElement, PressableProps>(\n ({ children, type = \"button\", className, disabled, ...props }, ref) => (\n <button\n ref={ref}\n type={type}\n disabled={disabled}\n className={cn(\n \"appearance-none hover:opacity-80 transition-all active:scale-95\",\n focusRingStyles,\n disabled && \"opacity-50 cursor-not-allowed\",\n className\n )}\n {...props}\n >\n {children}\n </button>\n )\n);\n\nPressable.displayName = \"Pressable\";\n","import { useCallback, useEffect, useState } from \"react\";\n\nconst useIsomorphicLayoutEffect =\n typeof window !== \"undefined\" ? useEffect : () => {};\n\nexport const useMediaQuery = (query: string): boolean => {\n // Initialize with null to prevent hydration mismatch\n const [matches, setMatches] = useState<boolean | null>(null);\n\n const getMatches = useCallback((query: string): boolean => {\n if (typeof window !== \"undefined\") {\n return window.matchMedia(query).matches;\n }\n return false;\n }, []);\n\n // Update matches after mount to prevent hydration mismatch\n useIsomorphicLayoutEffect(() => {\n setMatches(getMatches(query));\n }, [query, getMatches]);\n\n useEffect(() => {\n if (typeof window !== \"undefined\") {\n const mediaQuery = window.matchMedia(query);\n\n const handleChange = () => {\n setMatches(getMatches(query));\n };\n\n mediaQuery.addEventListener(\"change\", handleChange);\n\n return () => {\n mediaQuery.removeEventListener(\"change\", handleChange);\n };\n }\n }, [query, getMatches]);\n\n // Return false during SSR, actual value after hydration\n return matches ?? false;\n};\n","import * as ScrollArea from \"@radix-ui/react-scroll-area\";\nimport React, { useCallback, useEffect, useRef, useState } from \"react\";\n\nimport { Icon } from \"./Icon\";\nimport { Pressable } from \"./Pressable\";\nimport { useMediaQuery } from \"../hooks/useMediaQuery\";\n\nexport type CarouselProps = {\n children: React.ReactNode;\n /** Optional className for the root element */\n className?: string;\n /** Optional gap between items in pixels */\n gap?: number;\n};\n\nexport function Carousel({\n children,\n className = \"\",\n gap = 20\n}: CarouselProps) {\n const scrollContainerRef = useRef<HTMLDivElement>(null);\n const [showLeftPaddle, setShowLeftPaddle] = useState(false);\n const [showRightPaddle, setShowRightPaddle] = useState(false);\n const [isHoveringStart, setIsHoveringStart] = useState(false);\n const [isHoveringEnd, setIsHoveringEnd] = useState(false);\n const [touchStart, setTouchStart] = useState<number | null>(null);\n const [touchEnd, setTouchEnd] = useState<number | null>(null);\n const isMobile = useMediaQuery(\"(max-width: 768px)\");\n\n const checkScrollPosition = useCallback(() => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const { scrollLeft, scrollWidth, clientWidth } = container;\n setShowLeftPaddle(scrollLeft > 0);\n setShowRightPaddle(Math.ceil(scrollLeft + clientWidth) < scrollWidth);\n }, []);\n\n const handleMouseMove = useCallback(\n (e: React.MouseEvent) => {\n if (isMobile) return;\n\n const container = e.currentTarget;\n const rect = container.getBoundingClientRect();\n const mouseX = e.clientX - rect.left;\n const HOVER_THRESHOLD = 300;\n\n setIsHoveringStart(mouseX < HOVER_THRESHOLD);\n setIsHoveringEnd(mouseX > rect.width - HOVER_THRESHOLD);\n },\n [isMobile]\n );\n\n // Touch handling\n const handleTouchStart = useCallback((e: React.TouchEvent) => {\n setTouchStart(e.touches[0].clientX);\n setTouchEnd(null);\n }, []);\n\n const handleTouchMove = useCallback((e: React.TouchEvent) => {\n setTouchEnd(e.touches[0].clientX);\n }, []);\n\n const handleTouchEnd = useCallback(() => {\n if (!touchStart || !touchEnd) return;\n\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const distance = touchStart - touchEnd;\n const minSwipeDistance = 50;\n\n if (Math.abs(distance) < minSwipeDistance) {\n return;\n }\n\n const itemWidth = container.clientWidth;\n const direction = distance > 0 ? 1 : -1;\n const targetScroll = container.scrollLeft + itemWidth * direction;\n\n container.scrollTo({\n left: targetScroll,\n behavior: \"smooth\"\n });\n }, [touchStart, touchEnd]);\n\n const handleWheel = useCallback((e: WheelEvent) => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n // Check if the scroll is predominantly horizontal or if shift key is pressed\n const isHorizontalScroll = Math.abs(e.deltaX) > Math.abs(e.deltaY);\n if (!isHorizontalScroll && !e.shiftKey) return;\n\n e.preventDefault();\n\n // Determine the scroll amount based on the input type\n const scrollAmount = isHorizontalScroll ? e.deltaX : e.deltaY;\n\n // Apply smooth scrolling\n container.scrollBy({\n left: scrollAmount,\n behavior: \"smooth\"\n });\n }, []);\n\n useEffect(() => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const observer = new ResizeObserver(checkScrollPosition);\n observer.observe(container);\n\n container.addEventListener(\"scroll\", checkScrollPosition);\n container.addEventListener(\"wheel\", handleWheel, { passive: false });\n\n return () => {\n observer.disconnect();\n container.removeEventListener(\"scroll\", checkScrollPosition);\n container.removeEventListener(\"wheel\", handleWheel);\n };\n }, [checkScrollPosition, handleWheel]);\n\n const scroll = useCallback((direction: \"left\" | \"right\") => {\n const container = scrollContainerRef.current;\n if (!container) return;\n\n const scrollAmount = container.clientWidth;\n const targetScroll =\n container.scrollLeft +\n (direction === \"left\" ? -scrollAmount : scrollAmount);\n\n container.scrollTo({\n left: targetScroll,\n behavior: \"smooth\"\n });\n }, []);\n\n const handleKeyDown = useCallback(\n (e: React.KeyboardEvent) => {\n if (e.key === \"ArrowLeft\") {\n scroll(\"left\");\n } else if (e.key === \"ArrowRight\") {\n scroll(\"right\");\n }\n },\n [scroll]\n );\n\n return (\n <div\n className={`relative group ${className}`}\n onKeyDown={handleKeyDown}\n onMouseMove={handleMouseMove}\n onMouseLeave={() => {\n setIsHoveringStart(false);\n setIsHoveringEnd(false);\n }}\n onTouchStart={handleTouchStart}\n onTouchMove={handleTouchMove}\n onTouchEnd={handleTouchEnd}\n role=\"region\"\n aria-label=\"Carousel\"\n >\n <ScrollArea.Root className=\"overflow-hidden\" type=\"hover\">\n <ScrollArea.Viewport\n ref={scrollContainerRef}\n className=\"w-full overflow-x-auto snap-x snap-mandatory\"\n style={{\n scrollbarWidth: \"none\",\n msOverflowStyle: \"none\",\n WebkitOverflowScrolling: \"touch\"\n }}\n >\n <div\n className=\"inline-flex\"\n style={{\n gap: `${gap}px`\n }}\n >\n {React.Children.map(children, (child) =>\n child === null ? null : (\n <div className=\"snap-start shrink-0\">{child}</div>\n )\n )}\n </div>\n </ScrollArea.Viewport>\n </ScrollArea.Root>\n\n {/* Navigation Paddles - Only show on desktop */}\n {!isMobile && (\n <>\n {showLeftPaddle && isHoveringStart && (\n <Pressable\n onClick={() => scroll(\"left\")}\n className=\"absolute left-4 top-1/2 -translate-y-1/2 z-20 transition-opacity duration-200\"\n aria-label=\"Scroll left\"\n >\n <div className=\"flex items-center justify-center w-10 h-10 rounded-full bg-overlay backdrop-blur-sm\">\n <Icon name=\"arrow-left\" size={24} color=\"white\" />\n </div>\n </Pressable>\n )}\n\n {showRightPaddle && isHoveringEnd && (\n <Pressable\n onClick={() => scroll(\"right\")}\n className=\"absolute right-4 top-1/2 -translate-y-1/2 z-20 transition-opacity duration-200\"\n aria-label=\"Scroll right\"\n >\n <div className=\"flex items-center justify-center w-10 h-10 rounded-full bg-overlay backdrop-blur-sm\">\n <Icon name=\"arrow-right\" size={24} color=\"white\" />\n </div>\n </Pressable>\n )}\n </>\n )}\n </div>\n );\n}\n"]}
@@ -1,4 +1,4 @@
1
- 'use strict';var v=require('@radix-ui/react-collapsible'),a=require('react'),x=require('@radix-ui/react-toast'),clsx=require('clsx'),tailwindMerge=require('tailwind-merge'),icons=require('@deckai/icons');function _interopNamespace(e){if(e&&e.__esModule)return e;var n=Object.create(null);if(e){Object.keys(e).forEach(function(k){if(k!=='default'){var d=Object.getOwnPropertyDescriptor(e,k);Object.defineProperty(n,k,d.get?d:{enumerable:true,get:function(){return e[k]}});}})}n.default=e;return Object.freeze(n)}var v__namespace=/*#__PURE__*/_interopNamespace(v);var a__namespace=/*#__PURE__*/_interopNamespace(a);var x__namespace=/*#__PURE__*/_interopNamespace(x);function d(...e){return tailwindMerge.twMerge(clsx.clsx(e))}var j={xl:"h1",lg:"h1",md:"h2",sm:"h3",xs:"h4"},K=e=>{let[r,t]=e.split("-");return r==="heading"?j[t]||"p":r==="label"?"label":"p"},z={light:"font-light",regular:"font-regular",semibold:"font-semibold",bold:"font-bold"},G=e=>e?(Array.isArray(e)?e:[e]).map(t=>{if(t.includes(":")){let[s,o]=t.split(":");return `${s}:text-${o}`}return `text-${t}`}).join(" "):"text-body-default",h=a__namespace.default.forwardRef(({variant:e="body-default",color:r="primary",as:t,className:s,children:o,weight:n,...p},i)=>{let l=G(e),c=r==="inherit"?"text-inherit":`text-${r}`,m=a__namespace.default.useMemo(()=>{let y=typeof e=="string"?e.split(":").pop():Array.isArray(e)?e[0].split(":").pop():"body-default";return K(y)},[e]);return a__namespace.default.createElement(t||m,{ref:i,className:`
1
+ 'use strict';var v=require('@radix-ui/react-collapsible'),a=require('react'),m=require('@radix-ui/react-toast'),clsx=require('clsx'),tailwindMerge=require('tailwind-merge'),icons=require('@deckai/icons');function _interopNamespace(e){if(e&&e.__esModule)return e;var n=Object.create(null);if(e){Object.keys(e).forEach(function(k){if(k!=='default'){var d=Object.getOwnPropertyDescriptor(e,k);Object.defineProperty(n,k,d.get?d:{enumerable:true,get:function(){return e[k]}});}})}n.default=e;return Object.freeze(n)}var v__namespace=/*#__PURE__*/_interopNamespace(v);var a__namespace=/*#__PURE__*/_interopNamespace(a);var m__namespace=/*#__PURE__*/_interopNamespace(m);function d(...e){return tailwindMerge.twMerge(clsx.clsx(e))}var j={xl:"h1",lg:"h1",md:"h2",sm:"h3",xs:"h4"},K=e=>{let[r,t]=e.split("-");return r==="heading"?j[t]||"p":r==="label"?"label":"p"},z={light:"font-light",regular:"font-regular",semibold:"font-semibold",bold:"font-bold"},G=e=>e?(Array.isArray(e)?e:[e]).map(t=>{if(t.includes(":")){let[s,o]=t.split(":");return `${s}:text-${o}`}return `text-${t}`}).join(" "):"text-body-default",h=a__namespace.default.forwardRef(({variant:e="body-default",color:r="primary",as:t,className:s,children:o,weight:n,...p},i)=>{let l=G(e),c=r==="inherit"?"text-inherit":`text-${r}`,x=a__namespace.default.useMemo(()=>{let y=typeof e=="string"?e.split(":").pop():Array.isArray(e)?e[0].split(":").pop():"body-default";return K(y)},[e]);return a__namespace.default.createElement(t||x,{ref:i,className:`
2
2
  font-sans antialiased
3
3
  ${l}
4
4
  ${c}
@@ -12,5 +12,5 @@
12
12
  transition-colors duration-200
13
13
  disabled:opacity-50 disabled:pointer-events-none
14
14
  hover:opacity-80 active:scale-95
15
- truncate`,b,r==="filled"?W[t]:r==="transparent"?"bg-transparent text-text":_[t],e),disabled:n||s,type:"button",...i},typeof o=="string"?a__namespace.createElement(h,{variant:["sm:body-default-bold","body-xxs-semibold"],color:"inherit"},o):o,p));T.displayName="Button";var M={12:"h-[12px] w-[12px]",16:"h-[16px] w-[16px]",18:"h-[18px] w-[18px]",20:"h-[20px] w-[20px]",24:"h-[24px] w-[24px]",32:"h-[32px] w-[32px]",36:"h-[36px] w-[36px]",40:"h-[40px] w-[40px]",42:"h-[42px] w-[42px]",48:"h-[48px] w-[48px]",64:"h-[64px] w-[64px]",72:"h-[72px] w-[72px]"},P={sm:{12:"sm:h-[12px] sm:w-[12px]",16:"sm:h-[16px] sm:w-[16px]",18:"sm:h-[18px] sm:w-[18px]",20:"sm:h-[20px] sm:w-[20px]",24:"sm:h-[24px] sm:w-[24px]",32:"sm:h-[32px] sm:w-[32px]",36:"sm:h-[36px] sm:w-[36px]",40:"sm:h-[40px] sm:w-[40px]",42:"sm:h-[42px] sm:w-[42px]",48:"sm:h-[48px] sm:w-[48px]",64:"sm:h-[64px] sm:w-[64px]",72:"sm:h-[72px] sm:w-[72px]"},md:{12:"md:h-[12px] md:w-[12px]",16:"md:h-[16px] md:w-[16px]",18:"md:h-[18px] md:w-[18px]",20:"md:h-[20px] md:w-[20px]",24:"md:h-[24px] md:w-[24px]",32:"md:h-[32px] md:w-[32px]",36:"md:h-[36px] md:w-[36px]",40:"md:h-[40px] md:w-[40px]",42:"md:h-[42px] md:w-[42px]",48:"md:h-[48px] md:w-[48px]",64:"md:h-[64px] md:w-[64px]",72:"md:h-[72px] md:w-[72px]"},lg:{12:"lg:h-[12px] lg:w-[12px]",16:"lg:h-[16px] lg:w-[16px]",18:"lg:h-[18px] lg:w-[18px]",20:"lg:h-[20px] lg:w-[20px]",24:"lg:h-[24px] lg:w-[24px]",32:"lg:h-[32px] lg:w-[32px]",36:"lg:h-[36px] lg:w-[36px]",40:"lg:h-[40px] lg:w-[40px]",42:"lg:h-[42px] lg:w-[42px]",48:"lg:h-[48px] lg:w-[48px]",64:"lg:h-[64px] lg:w-[64px]",72:"lg:h-[72px] lg:w-[72px]"},xl:{12:"xl:h-[12px] xl:w-[12px]",16:"xl:h-[16px] xl:w-[16px]",18:"xl:h-[18px] xl:w-[18px]",20:"xl:h-[20px] xl:w-[20px]",24:"xl:h-[24px] xl:w-[24px]",32:"xl:h-[32px] xl:w-[32px]",36:"xl:h-[36px] xl:w-[36px]",40:"xl:h-[40px] xl:w-[40px]",42:"xl:h-[42px] xl:w-[42px]",48:"xl:h-[48px] xl:w-[48px]",64:"xl:h-[64px] xl:w-[64px]",72:"xl:h-[72px] xl:w-[72px]"},"2xl":{12:"2xl:h-[12px] 2xl:w-[12px]",16:"2xl:h-[16px] 2xl:w-[16px]",18:"2xl:h-[18px] 2xl:w-[18px]",20:"2xl:h-[20px] 2xl:w-[20px]",24:"2xl:h-[24px] 2xl:w-[24px]",32:"2xl:h-[32px] 2xl:w-[32px]",36:"2xl:h-[36px] 2xl:w-[36px]",40:"2xl:h-[40px] 2xl:w-[40px]",42:"2xl:h-[42px] 2xl:w-[42px]",48:"2xl:h-[48px] 2xl:w-[48px]",64:"2xl:h-[64px] 2xl:w-[64px]",72:"2xl:h-[72px] 2xl:w-[72px]"}},f=e=>String(e),k=(e,r=24)=>{let t=[],s={};if(e===undefined){let o=f(r);o?t.push(M[o]):(s.height=`${r}px`,s.width=`${r}px`);}if(typeof e=="number"){let o=f(e);o?t.push(M[o]):(s.height=`${e}px`,s.width=`${e}px`);}if(Array.isArray(e)){let o=f(r),n=[o&&M[o]||`h-[${r}px] w-[${r}px]`];e.forEach(p=>{if(typeof p=="string"){let[i,l]=p.split(":"),c=parseInt(l,10),m=f(c);t.push(m&&P[i]?.[m]||`${i}:h-[${c}px] ${i}:w-[${c}px]`);}}),t.push(...n);}if(typeof e=="string"){let[o,n]=e.split(":"),p=parseInt(n,10),i=f(p);t.push(i&&P[o]?.[i]||`${o}:h-[${p}px] ${o}:w-[${p}px]`);}return {responsiveSizeClasses:t.join(" "),responsiveSizeStyles:s}};var S={primary:"var(--color-primary)",secondary:"var(--color-secondary)",white:"var(--color-white)",primaryBlue:"var(--color-primary-100)",disabled:"var(--color-disabled)",danger:"var(--color-danger)"},w=a__namespace.default.forwardRef(({name:e,size:r=24,color:t="primary",title:s,className:o,style:n={},...p},i)=>{let l=icons.IconMap[e],{responsiveSizeClasses:c,responsiveSizeStyles:m}=k(r,24);return a__namespace.default.createElement("div",{className:d("flex justify-center items-center",c,o),style:{"--icon-stroke":S[t],...m,...n}},a__namespace.default.createElement(l,{ref:i,"aria-hidden":!s,"aria-label":s,stroke:e.includes("filled")?undefined:S[t],...p}))});w.displayName="Icon";var Q={default:{icon:"information",className:"bg-gray-900 text-white"},success:{icon:"check",className:"bg-green-600 text-white"},error:{icon:"danger",className:"bg-tertiary-10 text-white"},warning:{icon:"warning-2",className:"bg-tertiary-20 text-white"}},N=a__namespace.forwardRef(({title:e,message:r,action:t,secondaryAction:s,variant:o="default",duration:n=5e3,className:p,onOpenChange:i,allowOutsideClick:l=true,onClose:c,...m},$)=>{let y=Q[o],I=a__namespace.useCallback(R=>{!l&&R===false||(i?.(R),R||c?.());},[i,l,c]);return a__namespace.createElement(x__namespace.Root,{ref:$,onOpenChange:I,duration:n,className:d("group pointer-events-auto relative flex w-full flex-col gap-4 rounded-lg p-4 items-center","shadow-lg","data-[state=open]:animate-in data-[state=closed]:animate-out","data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0","data-[state=closed]:slide-out-to-right-full data-[state=open]:slide-in-from-right-full",y.className,p),...m},a__namespace.createElement(x__namespace.Close,{className:"absolute right-1 top-1 h-[40px] w-[40px] p-1 hover:bg-background-0/10 flex items-center justify-center rounded-lg","aria-label":"Close",onClick:c},a__namespace.createElement(w,{name:"close",size:16,color:"white"})),a__namespace.createElement("div",{className:"flex gap-4"},a__namespace.createElement(w,{name:y.icon,className:"h-5 w-5 shrink-0",color:"white"}),a__namespace.createElement("div",{className:"flex flex-col flex-1 gap-2"},e&&a__namespace.createElement(x__namespace.Title,{asChild:true},a__namespace.createElement(h,{variant:"body-default-bold",color:"inherit"},e)),a__namespace.createElement(x__namespace.Description,{asChild:true},a__namespace.createElement(h,{variant:"body-xs-medium",color:"inherit"},r)))),(t||s)&&a__namespace.createElement("div",{className:"flex gap-2 justify-end mt-2"},s&&a__namespace.createElement(x__namespace.Action,{asChild:true,altText:s.label},a__namespace.createElement("div",{className:"min-h-[40px] flex items-center"},a__namespace.createElement(T,{variant:s.variant||"outlined",color:"black",className:"border-white text-white hover:bg-background-0/10",onClick:s.onClick},s.label))),t&&a__namespace.createElement(x__namespace.Action,{asChild:true,altText:t.label},a__namespace.createElement("div",{className:"flex items-center"},a__namespace.createElement(T,{variant:t.variant||"outlined",color:"black",className:"border-white text-white hover:bg-background-0/10",onClick:t.onClick},t.label)))))});N.displayName="Toast";var A=typeof window<"u"?a.useLayoutEffect:a.useEffect;var C=a__namespace.default.forwardRef(({children:e,type:r="button",className:t,disabled:s,...o},n)=>a__namespace.default.createElement("button",{ref:n,type:r,disabled:s,className:d("appearance-none hover:opacity-80 transition-all active:scale-95",b,s&&"opacity-50 cursor-not-allowed",t),...o},e));C.displayName="Pressable";var X=({children:e,maxHeight:r=100})=>{let[t,s]=a__namespace.default.useState(false),o=a.useRef(null),[n,p]=a.useState(r);A(()=>{if(!o.current)return;let l=new ResizeObserver(c=>{for(let m of c)p(m.target.scrollHeight);});return l.observe(o.current),()=>l.disconnect()},[]);let i=n>r;return a__namespace.default.createElement(v__namespace.Root,{open:t,onOpenChange:s},a__namespace.default.createElement("div",{className:"relative"},a__namespace.default.createElement("div",{className:"overflow-hidden transition-[height] duration-300 ease-in-out",style:{height:t?`${n}px`:`${r}px`}},a__namespace.default.createElement("div",{ref:o,className:"w-full"},e)),i&&a__namespace.default.createElement(v__namespace.Trigger,{asChild:true},a__namespace.default.createElement(C,{className:d("absolute -bottom-8 left-0 right-0","flex items-end justify-center","h-16 pt-8 pb-2",!t&&"bg-gradient-to-b from-transparent via-background-0 to-background-0","hover:opacity-100 transition-opacity")},a__namespace.default.createElement(h,{variant:"label-default",color:"secondary"},t?"See less":"See more")))))};X.displayName="Collapsible";exports.Collapsible=X;//# sourceMappingURL=Collapsible.cjs.map
15
+ truncate`,b,r==="filled"?W[t]:r==="transparent"?"bg-transparent text-text":_[t],e),disabled:n||s,type:"button",...i},typeof o=="string"?a__namespace.createElement(h,{variant:["sm:body-default-bold","body-xxs-semibold"],color:"inherit"},o):o,p));T.displayName="Button";var M={12:"h-[12px] w-[12px]",16:"h-[16px] w-[16px]",18:"h-[18px] w-[18px]",20:"h-[20px] w-[20px]",24:"h-[24px] w-[24px]",32:"h-[32px] w-[32px]",36:"h-[36px] w-[36px]",40:"h-[40px] w-[40px]",42:"h-[42px] w-[42px]",48:"h-[48px] w-[48px]",64:"h-[64px] w-[64px]",72:"h-[72px] w-[72px]"},k={sm:{12:"sm:h-[12px] sm:w-[12px]",16:"sm:h-[16px] sm:w-[16px]",18:"sm:h-[18px] sm:w-[18px]",20:"sm:h-[20px] sm:w-[20px]",24:"sm:h-[24px] sm:w-[24px]",32:"sm:h-[32px] sm:w-[32px]",36:"sm:h-[36px] sm:w-[36px]",40:"sm:h-[40px] sm:w-[40px]",42:"sm:h-[42px] sm:w-[42px]",48:"sm:h-[48px] sm:w-[48px]",64:"sm:h-[64px] sm:w-[64px]",72:"sm:h-[72px] sm:w-[72px]"},md:{12:"md:h-[12px] md:w-[12px]",16:"md:h-[16px] md:w-[16px]",18:"md:h-[18px] md:w-[18px]",20:"md:h-[20px] md:w-[20px]",24:"md:h-[24px] md:w-[24px]",32:"md:h-[32px] md:w-[32px]",36:"md:h-[36px] md:w-[36px]",40:"md:h-[40px] md:w-[40px]",42:"md:h-[42px] md:w-[42px]",48:"md:h-[48px] md:w-[48px]",64:"md:h-[64px] md:w-[64px]",72:"md:h-[72px] md:w-[72px]"},lg:{12:"lg:h-[12px] lg:w-[12px]",16:"lg:h-[16px] lg:w-[16px]",18:"lg:h-[18px] lg:w-[18px]",20:"lg:h-[20px] lg:w-[20px]",24:"lg:h-[24px] lg:w-[24px]",32:"lg:h-[32px] lg:w-[32px]",36:"lg:h-[36px] lg:w-[36px]",40:"lg:h-[40px] lg:w-[40px]",42:"lg:h-[42px] lg:w-[42px]",48:"lg:h-[48px] lg:w-[48px]",64:"lg:h-[64px] lg:w-[64px]",72:"lg:h-[72px] lg:w-[72px]"},xl:{12:"xl:h-[12px] xl:w-[12px]",16:"xl:h-[16px] xl:w-[16px]",18:"xl:h-[18px] xl:w-[18px]",20:"xl:h-[20px] xl:w-[20px]",24:"xl:h-[24px] xl:w-[24px]",32:"xl:h-[32px] xl:w-[32px]",36:"xl:h-[36px] xl:w-[36px]",40:"xl:h-[40px] xl:w-[40px]",42:"xl:h-[42px] xl:w-[42px]",48:"xl:h-[48px] xl:w-[48px]",64:"xl:h-[64px] xl:w-[64px]",72:"xl:h-[72px] xl:w-[72px]"},"2xl":{12:"2xl:h-[12px] 2xl:w-[12px]",16:"2xl:h-[16px] 2xl:w-[16px]",18:"2xl:h-[18px] 2xl:w-[18px]",20:"2xl:h-[20px] 2xl:w-[20px]",24:"2xl:h-[24px] 2xl:w-[24px]",32:"2xl:h-[32px] 2xl:w-[32px]",36:"2xl:h-[36px] 2xl:w-[36px]",40:"2xl:h-[40px] 2xl:w-[40px]",42:"2xl:h-[42px] 2xl:w-[42px]",48:"2xl:h-[48px] 2xl:w-[48px]",64:"2xl:h-[64px] 2xl:w-[64px]",72:"2xl:h-[72px] 2xl:w-[72px]"}},g=e=>String(e),P=(e,r=24)=>{let t=[],s={};if(e===void 0){let o=g(r);o?t.push(M[o]):(s.height=`${r}px`,s.width=`${r}px`);}if(typeof e=="number"){let o=g(e);o?t.push(M[o]):(s.height=`${e}px`,s.width=`${e}px`);}if(Array.isArray(e)){let o=g(r),n=[o&&M[o]||`h-[${r}px] w-[${r}px]`];e.forEach(p=>{if(typeof p=="string"){let[i,l]=p.split(":"),c=parseInt(l,10),x=g(c);t.push(x&&k[i]?.[x]||`${i}:h-[${c}px] ${i}:w-[${c}px]`);}}),t.push(...n);}if(typeof e=="string"){let[o,n]=e.split(":"),p=parseInt(n,10),i=g(p);t.push(i&&k[o]?.[i]||`${o}:h-[${p}px] ${o}:w-[${p}px]`);}return {responsiveSizeClasses:t.join(" "),responsiveSizeStyles:s}};var S={primary:"var(--color-primary)",secondary:"var(--color-secondary)",white:"var(--color-white)",primaryBlue:"var(--color-primary-100)",disabled:"var(--color-disabled)",danger:"var(--color-danger)"},w=a__namespace.default.forwardRef(({name:e,size:r=24,color:t="primary",title:s,className:o,style:n={},...p},i)=>{let l=icons.IconMap[e],{responsiveSizeClasses:c,responsiveSizeStyles:x}=P(r,24);return a__namespace.default.createElement("div",{className:d("flex justify-center items-center",c,o),style:{"--icon-stroke":S[t],...x,...n}},a__namespace.default.createElement(l,{ref:i,"aria-hidden":!s,"aria-label":s,stroke:e.includes("filled")?void 0:S[t],...p}))});w.displayName="Icon";var Q={default:{icon:"information",className:"bg-gray-900 text-white"},success:{icon:"check",className:"bg-green-600 text-white"},error:{icon:"danger",className:"bg-tertiary-10 text-white"},warning:{icon:"warning-2",className:"bg-tertiary-20 text-white"}},N=a__namespace.forwardRef(({title:e,message:r,action:t,secondaryAction:s,variant:o="default",duration:n=5e3,className:p,onOpenChange:i,allowOutsideClick:l=true,onClose:c,...x},$)=>{let y=Q[o],I=a__namespace.useCallback(R=>{!l&&R===false||(i?.(R),R||c?.());},[i,l,c]);return a__namespace.createElement(m__namespace.Root,{ref:$,onOpenChange:I,duration:n,className:d("group pointer-events-auto relative flex w-full flex-col gap-4 rounded-lg p-4 items-center","shadow-lg","data-[state=open]:animate-in data-[state=closed]:animate-out","data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0","data-[state=closed]:slide-out-to-right-full data-[state=open]:slide-in-from-right-full",y.className,p),...x},a__namespace.createElement(m__namespace.Close,{className:"absolute right-1 top-1 h-[40px] w-[40px] p-1 hover:bg-background-0/10 flex items-center justify-center rounded-lg","aria-label":"Close",onClick:c},a__namespace.createElement(w,{name:"close",size:16,color:"white"})),a__namespace.createElement("div",{className:"flex gap-4"},a__namespace.createElement(w,{name:y.icon,className:"h-5 w-5 shrink-0",color:"white"}),a__namespace.createElement("div",{className:"flex flex-col flex-1 gap-2"},e&&a__namespace.createElement(m__namespace.Title,{asChild:true},a__namespace.createElement(h,{variant:"body-default-bold",color:"inherit"},e)),a__namespace.createElement(m__namespace.Description,{asChild:true},a__namespace.createElement(h,{variant:"body-xs-medium",color:"inherit"},r)))),(t||s)&&a__namespace.createElement("div",{className:"flex gap-2 justify-end mt-2"},s&&a__namespace.createElement(m__namespace.Action,{asChild:true,altText:s.label},a__namespace.createElement("div",{className:"min-h-[40px] flex items-center"},a__namespace.createElement(T,{variant:s.variant||"outlined",color:"black",className:"border-white text-white hover:bg-background-0/10",onClick:s.onClick},s.label))),t&&a__namespace.createElement(m__namespace.Action,{asChild:true,altText:t.label},a__namespace.createElement("div",{className:"flex items-center"},a__namespace.createElement(T,{variant:t.variant||"outlined",color:"black",className:"border-white text-white hover:bg-background-0/10",onClick:t.onClick},t.label)))))});N.displayName="Toast";var A=typeof window<"u"?a.useLayoutEffect:a.useEffect;var C=a__namespace.default.forwardRef(({children:e,type:r="button",className:t,disabled:s,...o},n)=>a__namespace.default.createElement("button",{ref:n,type:r,disabled:s,className:d("appearance-none hover:opacity-80 transition-all active:scale-95",b,s&&"opacity-50 cursor-not-allowed",t),...o},e));C.displayName="Pressable";function X({children:e,maxHeight:r=100}){let[t,s]=a__namespace.default.useState(false),o=a.useRef(null),[n,p]=a.useState(r);A(()=>{if(!o.current)return;let l=new ResizeObserver(c=>{for(let x of c)p(x.target.scrollHeight);});return l.observe(o.current),()=>l.disconnect()},[]);let i=n>r;return a__namespace.default.createElement(v__namespace.Root,{open:t,onOpenChange:s},a__namespace.default.createElement("div",{className:"relative"},a__namespace.default.createElement("div",{className:"overflow-hidden transition-[height] duration-300 ease-in-out",style:{height:t?`${n}px`:`${r}px`}},a__namespace.default.createElement("div",{ref:o,className:"w-full"},e)),i&&a__namespace.default.createElement(v__namespace.Trigger,{asChild:true},a__namespace.default.createElement(C,{className:d("absolute -bottom-8 left-0 right-0","flex items-end justify-center","h-16 pt-8 pb-2",!t&&"bg-gradient-to-b from-transparent via-background-0 to-background-0","hover:opacity-100 transition-opacity")},a__namespace.default.createElement(h,{variant:"label-default",color:"secondary"},t?"See less":"See more")))))}X.displayName="Collapsible";exports.Collapsible=X;//# sourceMappingURL=Collapsible.cjs.map
16
16
  //# sourceMappingURL=Collapsible.cjs.map