@deckai/deck-ui 0.0.18 → 0.0.20

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 (214) hide show
  1. package/dist/components/AboutCard.cjs +5 -5
  2. package/dist/components/AboutCard.cjs.map +1 -1
  3. package/dist/components/AboutCard.js +5 -5
  4. package/dist/components/AboutCard.js.map +1 -1
  5. package/dist/components/Accordion.cjs +6 -6
  6. package/dist/components/Accordion.cjs.map +1 -1
  7. package/dist/components/Accordion.js +6 -6
  8. package/dist/components/Accordion.js.map +1 -1
  9. package/dist/components/AddWorkCard.cjs +6 -6
  10. package/dist/components/AddWorkCard.cjs.map +1 -1
  11. package/dist/components/AddWorkCard.d.cts +2 -2
  12. package/dist/components/AddWorkCard.d.ts +2 -2
  13. package/dist/components/AddWorkCard.js +6 -6
  14. package/dist/components/AddWorkCard.js.map +1 -1
  15. package/dist/components/AutocompleteInput.cjs +5 -5
  16. package/dist/components/AutocompleteInput.cjs.map +1 -1
  17. package/dist/components/AutocompleteInput.d.cts +15 -16
  18. package/dist/components/AutocompleteInput.d.ts +15 -16
  19. package/dist/components/AutocompleteInput.js +5 -5
  20. package/dist/components/AutocompleteInput.js.map +1 -1
  21. package/dist/components/Avatar.cjs +1 -1
  22. package/dist/components/Avatar.cjs.map +1 -1
  23. package/dist/components/Avatar.d.cts +1 -2
  24. package/dist/components/Avatar.d.ts +1 -2
  25. package/dist/components/Avatar.js +1 -1
  26. package/dist/components/Avatar.js.map +1 -1
  27. package/dist/components/Badge.cjs +5 -5
  28. package/dist/components/Badge.cjs.map +1 -1
  29. package/dist/components/Badge.d.cts +1 -1
  30. package/dist/components/Badge.d.ts +1 -1
  31. package/dist/components/Badge.js +5 -5
  32. package/dist/components/Badge.js.map +1 -1
  33. package/dist/components/Breadcrumbs.cjs +6 -6
  34. package/dist/components/Breadcrumbs.cjs.map +1 -1
  35. package/dist/components/Breadcrumbs.js +6 -6
  36. package/dist/components/Breadcrumbs.js.map +1 -1
  37. package/dist/components/Button.cjs +6 -6
  38. package/dist/components/Button.cjs.map +1 -1
  39. package/dist/components/Button.js +6 -6
  40. package/dist/components/Button.js.map +1 -1
  41. package/dist/components/Carousel.cjs +1 -1
  42. package/dist/components/Carousel.cjs.map +1 -1
  43. package/dist/components/Carousel.js +1 -1
  44. package/dist/components/Carousel.js.map +1 -1
  45. package/dist/components/Collapsible.cjs +7 -7
  46. package/dist/components/Collapsible.cjs.map +1 -1
  47. package/dist/components/Collapsible.js +7 -7
  48. package/dist/components/Collapsible.js.map +1 -1
  49. package/dist/components/Combobox.cjs +5 -5
  50. package/dist/components/Combobox.cjs.map +1 -1
  51. package/dist/components/Combobox.js +5 -5
  52. package/dist/components/Combobox.js.map +1 -1
  53. package/dist/components/ContactItem.cjs +6 -6
  54. package/dist/components/ContactItem.cjs.map +1 -1
  55. package/dist/components/ContactItem.js +6 -6
  56. package/dist/components/ContactItem.js.map +1 -1
  57. package/dist/components/Dropdown.cjs +5 -5
  58. package/dist/components/Dropdown.cjs.map +1 -1
  59. package/dist/components/Dropdown.js +5 -5
  60. package/dist/components/Dropdown.js.map +1 -1
  61. package/dist/components/EditButton.cjs +7 -7
  62. package/dist/components/EditButton.cjs.map +1 -1
  63. package/dist/components/EditButton.js +7 -7
  64. package/dist/components/EditButton.js.map +1 -1
  65. package/dist/components/Icon.cjs +1 -1
  66. package/dist/components/Icon.cjs.map +1 -1
  67. package/dist/components/Icon.d.cts +2 -3
  68. package/dist/components/Icon.d.ts +2 -3
  69. package/dist/components/Icon.js +1 -1
  70. package/dist/components/Icon.js.map +1 -1
  71. package/dist/components/IconRenderer.cjs +1 -1
  72. package/dist/components/IconRenderer.cjs.map +1 -1
  73. package/dist/components/IconRenderer.d.cts +2 -1
  74. package/dist/components/IconRenderer.d.ts +2 -1
  75. package/dist/components/IconRenderer.js +1 -1
  76. package/dist/components/IconRenderer.js.map +1 -1
  77. package/dist/components/Input.cjs +6 -6
  78. package/dist/components/Input.cjs.map +1 -1
  79. package/dist/components/Input.d.cts +1 -0
  80. package/dist/components/Input.d.ts +1 -0
  81. package/dist/components/Input.js +6 -6
  82. package/dist/components/Input.js.map +1 -1
  83. package/dist/components/Link.cjs +4 -4
  84. package/dist/components/Link.cjs.map +1 -1
  85. package/dist/components/Link.d.cts +1 -0
  86. package/dist/components/Link.d.ts +1 -0
  87. package/dist/components/Link.js +4 -4
  88. package/dist/components/Link.js.map +1 -1
  89. package/dist/components/Modal.cjs +2 -0
  90. package/dist/components/Modal.cjs.map +1 -0
  91. package/dist/components/Modal.d.cts +31 -0
  92. package/dist/components/Modal.d.ts +31 -0
  93. package/dist/components/Modal.js +2 -0
  94. package/dist/components/Modal.js.map +1 -0
  95. package/dist/components/MultiSelectCombobox.cjs +5 -5
  96. package/dist/components/MultiSelectCombobox.cjs.map +1 -1
  97. package/dist/components/MultiSelectCombobox.js +5 -5
  98. package/dist/components/MultiSelectCombobox.js.map +1 -1
  99. package/dist/components/Navbar.cjs +6 -6
  100. package/dist/components/Navbar.cjs.map +1 -1
  101. package/dist/components/Navbar.d.cts +2 -1
  102. package/dist/components/Navbar.d.ts +2 -1
  103. package/dist/components/Navbar.js +6 -6
  104. package/dist/components/Navbar.js.map +1 -1
  105. package/dist/components/NavbarItem.cjs +7 -1
  106. package/dist/components/NavbarItem.cjs.map +1 -1
  107. package/dist/components/NavbarItem.d.cts +6 -2
  108. package/dist/components/NavbarItem.d.ts +6 -2
  109. package/dist/components/NavbarItem.js +7 -1
  110. package/dist/components/NavbarItem.js.map +1 -1
  111. package/dist/components/Option.cjs +6 -6
  112. package/dist/components/Option.cjs.map +1 -1
  113. package/dist/components/Option.d.cts +4 -0
  114. package/dist/components/Option.d.ts +4 -0
  115. package/dist/components/Option.js +6 -6
  116. package/dist/components/Option.js.map +1 -1
  117. package/dist/components/Pressable.cjs +1 -1
  118. package/dist/components/Pressable.cjs.map +1 -1
  119. package/dist/components/Pressable.js +1 -1
  120. package/dist/components/Pressable.js.map +1 -1
  121. package/dist/components/ProfileCard.cjs +6 -6
  122. package/dist/components/ProfileCard.cjs.map +1 -1
  123. package/dist/components/ProfileCard.js +6 -6
  124. package/dist/components/ProfileCard.js.map +1 -1
  125. package/dist/components/ProgressBar.cjs +1 -1
  126. package/dist/components/ProgressBar.cjs.map +1 -1
  127. package/dist/components/ProgressBar.js +1 -1
  128. package/dist/components/ProgressBar.js.map +1 -1
  129. package/dist/components/RadioGroup.cjs +5 -5
  130. package/dist/components/RadioGroup.cjs.map +1 -1
  131. package/dist/components/RadioGroup.js +5 -5
  132. package/dist/components/RadioGroup.js.map +1 -1
  133. package/dist/components/SegmentedTabs.cjs +5 -5
  134. package/dist/components/SegmentedTabs.cjs.map +1 -1
  135. package/dist/components/SegmentedTabs.js +5 -5
  136. package/dist/components/SegmentedTabs.js.map +1 -1
  137. package/dist/components/Sidebar.cjs +1 -1
  138. package/dist/components/Sidebar.cjs.map +1 -1
  139. package/dist/components/Sidebar.js +1 -1
  140. package/dist/components/Sidebar.js.map +1 -1
  141. package/dist/components/SlideButton.cjs +1 -1
  142. package/dist/components/SlideButton.cjs.map +1 -1
  143. package/dist/components/SlideButton.js +1 -1
  144. package/dist/components/SlideButton.js.map +1 -1
  145. package/dist/components/Slider.cjs +2 -0
  146. package/dist/components/Slider.cjs.map +1 -0
  147. package/dist/components/Slider.d.cts +7 -0
  148. package/dist/components/Slider.d.ts +7 -0
  149. package/dist/components/Slider.js +2 -0
  150. package/dist/components/Slider.js.map +1 -0
  151. package/dist/components/SocialCard.cjs +5 -5
  152. package/dist/components/SocialCard.cjs.map +1 -1
  153. package/dist/components/SocialCard.d.cts +2 -2
  154. package/dist/components/SocialCard.d.ts +2 -2
  155. package/dist/components/SocialCard.js +5 -5
  156. package/dist/components/SocialCard.js.map +1 -1
  157. package/dist/components/Spinner.cjs +1 -1
  158. package/dist/components/Spinner.cjs.map +1 -1
  159. package/dist/components/Spinner.js +1 -1
  160. package/dist/components/Spinner.js.map +1 -1
  161. package/dist/components/Switch.cjs +1 -1
  162. package/dist/components/Switch.cjs.map +1 -1
  163. package/dist/components/Switch.d.cts +1 -1
  164. package/dist/components/Switch.d.ts +1 -1
  165. package/dist/components/Switch.js +1 -1
  166. package/dist/components/Switch.js.map +1 -1
  167. package/dist/components/Tabs.cjs +3 -3
  168. package/dist/components/Tabs.cjs.map +1 -1
  169. package/dist/components/Tabs.js +3 -3
  170. package/dist/components/Tabs.js.map +1 -1
  171. package/dist/components/Tag.cjs +6 -6
  172. package/dist/components/Tag.cjs.map +1 -1
  173. package/dist/components/Tag.js +6 -6
  174. package/dist/components/Tag.js.map +1 -1
  175. package/dist/components/Text.cjs +2 -2
  176. package/dist/components/Text.cjs.map +1 -1
  177. package/dist/components/Text.d.cts +1 -1
  178. package/dist/components/Text.d.ts +1 -1
  179. package/dist/components/Text.js +2 -2
  180. package/dist/components/Text.js.map +1 -1
  181. package/dist/components/TextArea.cjs +4 -4
  182. package/dist/components/TextArea.cjs.map +1 -1
  183. package/dist/components/TextArea.js +4 -4
  184. package/dist/components/TextArea.js.map +1 -1
  185. package/dist/components/Toast.cjs +6 -6
  186. package/dist/components/Toast.cjs.map +1 -1
  187. package/dist/components/Toast.js +6 -6
  188. package/dist/components/Toast.js.map +1 -1
  189. package/dist/components/Tooltip.cjs +7 -1
  190. package/dist/components/Tooltip.cjs.map +1 -1
  191. package/dist/components/Tooltip.js +7 -1
  192. package/dist/components/Tooltip.js.map +1 -1
  193. package/dist/components/VideoPlayer.cjs +8 -0
  194. package/dist/components/VideoPlayer.cjs.map +1 -0
  195. package/dist/components/VideoPlayer.d.cts +36 -0
  196. package/dist/components/VideoPlayer.d.ts +36 -0
  197. package/dist/components/VideoPlayer.js +8 -0
  198. package/dist/components/VideoPlayer.js.map +1 -0
  199. package/dist/components/WorkCard.cjs +6 -6
  200. package/dist/components/WorkCard.cjs.map +1 -1
  201. package/dist/components/WorkCard.d.cts +2 -1
  202. package/dist/components/WorkCard.d.ts +2 -1
  203. package/dist/components/WorkCard.js +6 -6
  204. package/dist/components/WorkCard.js.map +1 -1
  205. package/dist/index.cjs +7 -7
  206. package/dist/index.cjs.map +1 -1
  207. package/dist/index.d.cts +14 -0
  208. package/dist/index.d.ts +14 -0
  209. package/dist/index.js +7 -7
  210. package/dist/index.js.map +1 -1
  211. package/dist/responsive-CjR1yA5N.d.cts +4 -0
  212. package/dist/responsive-CjR1yA5N.d.ts +4 -0
  213. package/dist/styles/styles.css +2 -2
  214. package/package.json +2 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/utils/index.ts","../../src/utils/tailwind.ts","../../src/components/Icon.tsx","../../src/components/Text.tsx","../../src/components/Input.tsx","../../src/components/Option.tsx","../../src/components/AutocompleteInput.tsx","../../src/components/Combobox.tsx"],"names":["cn","inputs","twMerge","clsx","focusRingStylesCoerced","COLOR_MAP","BREAKPOINT_MAP","processSizes","sizes","sizeArray","mediaQueries","baseSize","size","breakpoint","valueStr","value","acc","query","Icon","React","name","color","title","className","style","props","ref","IconComponent","IconMap","sizeStyles","HEADING_ELEMENT_MAP","getElementFromVariant","variant","category","fontWeight","processVariants","variants","typographyClass","Text","as","children","weight","typographyClasses","colorClasses","suggestedElement","baseVariant","Input","f","end","iconName","label","labelClassName","id","forceShowFocusRing","error","errorMessage","helperText","showCharacterCount","maxLength","defaultValue","onChange","currentValue","setCurrentValue","handleChange","e","newValue","characterCount","showCount","HighlightedText","text","highlight","parts","part","i","Option","onKeyDown","onMouseEnter","onMouseLeave","selected","disabled","role","ariaSelected","searchValue","AutocompleteInput","forwardRef","suggestion","placeholder","ariaControls","ariaActiveDescendant","ariaAutocomplete","Combobox","options","container","autocomplete","loading","noOptionsMessage","open","setOpen","useState","setSearchValue","expandedGroups","setExpandedGroups","highlightedIndex","setHighlightedIndex","listRef","useRef","inputRef","isGrouped","useMemo","flatOptions","group","visibleOptions","option","filteredGroups","selectedOption","opt","displayValue","handleOptionChange","useCallback","optionValue","toggleGroup","groupLabel","prev","useEffect","initialState","handleKeyDown","event","matchingOption","handleOptionKeyDown","input","length","highlightedOption","getSelectedOption","index","isOpen","groupIndex","optionIndex","isSelected"],"mappings":"ySAGO,SAASA,CAAAA,CAAAA,GAAMC,CAAsB,CAAA,CAC1C,OAAOC,OAAQC,CAAAA,IAAAA,CAAKF,CAAM,CAAC,CAC7B,CCiEO,IAAMG,EAAyB,CAAA,6BAAA,CCnDtC,IAAMC,EAAAA,CAAwC,CAC5C,OAAA,CAAS,UACT,SAAW,CAAA,SAAA,CACX,KAAO,CAAA,SAAA,CACP,WAAa,CAAA,SAAA,CACb,SAAU,SACV,CAAA,MAAA,CAAQ,SACV,CAAA,CAEMC,EAA6C,CAAA,CACjD,GAAI,OACJ,CAAA,EAAA,CAAI,OACJ,CAAA,EAAA,CAAI,QACJ,CAAA,EAAA,CAAI,SACJ,KAAO,CAAA,QACT,CAEMC,CAAAA,EAAAA,CACJC,CACwB,EAAA,CACxB,GAAI,CAACA,CAAAA,CAAO,OAAO,CAAE,KAAO,CAAA,MAAA,CAAQ,OAAQ,MAAO,CAAA,CAEnD,IAAMC,CAAAA,CAAY,KAAM,CAAA,OAAA,CAAQD,CAAK,CAAIA,CAAAA,CAAAA,CAAQ,CAACA,CAAK,CACjDE,CAAAA,CAAAA,CAAuC,EAAC,CAC1CC,CAGJ,CAAA,OAAAF,CAAU,CAAA,OAAA,CAASG,CAAS,EAAA,CAC1B,GAAI,OAAOA,CAAAA,EAAS,QAClBD,CAAAA,CAAAA,CAAW,CAAGC,EAAAA,CAAI,UACb,CACL,GAAM,CAACC,CAAAA,CAAYC,CAAQ,CAAA,CAAIF,EAAK,KAAM,CAAA,GAAG,CACvCG,CAAAA,CAAAA,CAAQ,QAASD,CAAAA,CAAAA,CAAU,EAAE,CACnCJ,CAAAA,CAAAA,CAAa,CAAsBJ,mBAAAA,EAAAA,EAAAA,CAAeO,CAAU,CAAC,GAAG,CAC9D,CAAA,CAAA,EAAGE,CAAK,CAAA,EAAA,EACZ,CACF,CAAC,EAGM,CACL,KAAA,CAAOJ,CAAY,EAAA,MAAA,CACnB,MAAQA,CAAAA,CAAAA,EAAY,OACpB,GAAG,MAAA,CAAO,OAAQD,CAAAA,CAAY,CAAE,CAAA,MAAA,CAC9B,CAACM,CAAK,CAAA,CAACC,CAAOL,CAAAA,CAAI,CAAO,IAAA,CACvB,GAAGI,CACH,CAAA,CAACC,CAAK,EAAG,CACP,KAAA,CAAOL,EACP,MAAQA,CAAAA,CACV,CACF,CAAA,CAAA,CACA,EACF,CACF,CACF,CAAA,CAEaM,CAAOC,CAAAA,UAAAA,CAAM,UACxB,CAAA,CACE,CACE,IAAAC,CAAAA,CAAAA,CACA,IAAAR,CAAAA,CAAAA,CAAO,EACP,CAAA,KAAA,CAAAS,EAAQ,SACR,CAAA,KAAA,CAAAC,CACA,CAAA,SAAA,CAAAC,CACA,CAAA,KAAA,CAAAC,EAAQ,EAAC,CACT,GAAGC,CACL,CACAC,CAAAA,CAAAA,GACG,CACH,IAAMC,CAAAA,CAAgBC,OAAQR,CAAAA,CAAI,CAC5BS,CAAAA,CAAAA,CAAatB,EAAaK,CAAAA,CAAI,CAEpC,CAAA,OACEO,UAAA,CAAA,aAAA,CAAC,KACC,CAAA,CAAA,SAAA,CAAWnB,EAAG,kCAAoCuB,CAAAA,CAAS,CAC3D,CAAA,KAAA,CAAO,CACL,GAAGM,EACF,eAA4BxB,CAAAA,EAAAA,CAAUgB,CAAK,CAAA,CAC5C,GAAGG,CACL,GAEAL,UAAA,CAAA,aAAA,CAACQ,CAAA,CAAA,CACC,GAAKD,CAAAA,CAAAA,CACL,cAAa,CAACJ,CAAAA,CACd,YAAYA,CAAAA,CAAAA,CACZ,MAAQF,CAAAA,CAAAA,CAAK,SAAS,QAAQ,CAAA,CAAI,KAAYf,CAAAA,CAAAA,EAAAA,CAAUgB,CAAK,CAAA,CAC5D,GAAGI,CACN,CAAA,CACF,CAEJ,CACF,CAEAP,CAAAA,CAAAA,CAAK,YAAc,MC/GnB,CAuEA,IAAMY,EAAAA,CAAmD,CACvD,EAAI,CAAA,IAAA,CACJ,EAAI,CAAA,IAAA,CACJ,EAAI,CAAA,IAAA,CACJ,GAAI,IACJ,CAAA,EAAA,CAAI,IACN,CAAA,CAEMC,EAAyBC,CAAAA,CAAAA,EAAwC,CACrE,GAAM,CAACC,CAAUrB,CAAAA,CAAI,CAAIoB,CAAAA,CAAAA,CAAQ,MAAM,GAAG,CAAA,CAE1C,OAAIC,CAAAA,GAAa,SACRH,CAAAA,EAAAA,CAAoBlB,CAAI,CAAK,EAAA,GAAA,CAGlCqB,CAAa,GAAA,OAAA,CACR,OAGF,CAAA,GACT,EAIMC,EAAqC,CAAA,CACzC,KAAO,CAAA,YAAA,CACP,OAAS,CAAA,cAAA,CACT,SAAU,eACV,CAAA,IAAA,CAAM,WACR,CAAA,CA0BMC,EACJC,CAAAA,CAAAA,EAEKA,GAEgB,KAAM,CAAA,OAAA,CAAQA,CAAQ,CAAA,CAAIA,CAAW,CAAA,CAACA,CAAQ,CAAA,EAGhE,GAAKJ,CAAAA,CAAAA,EAAY,CAChB,GAAIA,CAAQ,CAAA,QAAA,CAAS,GAAG,CAAG,CAAA,CACzB,GAAM,CAACnB,CAAYwB,CAAAA,CAAe,EAAIL,CAAQ,CAAA,KAAA,CAAM,GAAG,CAAA,CACvD,OAAO,CAAA,EAAGnB,CAAU,CAASwB,MAAAA,EAAAA,CAAe,CAC9C,CAAA,CACA,OAAO,CAAA,KAAA,EAAQL,CAAO,CACxB,CAAA,CAAC,CACA,CAAA,IAAA,CAAK,GAAG,CAAA,CAZW,oBAeXM,CAAOnB,CAAAA,UAAAA,CAAM,UACxB,CAAA,CACE,CACE,OAAA,CAAAa,EAAU,cACV,CAAA,KAAA,CAAAX,CAAQ,CAAA,SAAA,CACR,EAAAkB,CAAAA,CAAAA,CACA,UAAAhB,CACA,CAAA,QAAA,CAAAiB,CACA,CAAA,MAAA,CAAAC,CACA,CAAA,GAAGhB,CACL,CACAC,CAAAA,CAAAA,GACG,CAEH,IAAMgB,CAAoBP,CAAAA,EAAAA,CAAgBH,CAAO,CAG3CW,CAAAA,CAAAA,CAAetB,CAAU,GAAA,SAAA,CAAY,cAAiB,CAAA,CAAA,KAAA,EAAQA,CAAK,CAEnEuB,CAAAA,CAAAA,CAAAA,CAAmBzB,UAAM,CAAA,OAAA,CAAQ,IAAM,CAC3C,IAAM0B,CACJ,CAAA,OAAOb,CAAY,EAAA,QAAA,CACfA,CAAQ,CAAA,KAAA,CAAM,GAAG,CAAE,CAAA,GAAA,EACnB,CAAA,KAAA,CAAM,OAAQA,CAAAA,CAAO,EACnBA,CAAQ,CAAA,CAAC,CAAE,CAAA,KAAA,CAAM,GAAG,CAAA,CAAE,KACtB,CAAA,cAAA,CACR,OAAOD,EAAAA,CAAsBc,CAA4B,CAC3D,EAAG,CAACb,CAAO,CAAC,CAAA,CAIZ,OAEEb,UAAAA,CAAA,aAJiBoB,CAAAA,CAAAA,EAAMK,CAItB,CAAA,CACC,GAAKlB,CAAAA,CAAAA,CACL,SAAW,CAAA;AAAA;AAAA,UAAA,EAEPgB,CAAiB;AAAA,UAAA,EACjBC,CAAY;AAAA,UAAA,EACZF,CAAU,EAAA,CAAA,CAAA,EAAIP,EAAWO,CAAAA,CAAM,CAAC,CAAE,CAAA;AAAA,UAAA,EAClClB,CAAS;AAAA,QAEZ,CAAA,CAAA,GAAGE,CAEHe,CAAAA,CAAAA,CACH,CAEJ,CACF,EAEAF,CAAK,CAAA,WAAA,CAAc,MCnKZ,CAAA,IAAMQ,EAAc,CAAAC,CAAA,CAAA,UAAA,CACzB,CACE,CACE,SAAA,CAAAxB,CACA,CAAA,GAAA,CAAAyB,CACA,CAAA,QAAA,CAAAC,CACA,CAAA,KAAA,CAAA5B,CACA,CAAA,IAAA,CAAAT,CACA,CAAA,KAAA,CAAAU,CACA,CAAA,KAAA,CAAA4B,EACA,cAAAC,CAAAA,CAAAA,CACA,EAAAC,CAAAA,CAAAA,CACA,QAAAZ,CAAAA,CAAAA,CACA,kBAAAa,CAAAA,CAAAA,CACA,KAAAC,CAAAA,CAAAA,CACA,YAAAC,CAAAA,CAAAA,CACA,UAAAC,CAAAA,CAAAA,CACA,mBAAAC,CACA,CAAA,SAAA,CAAAC,CACA,CAAA,KAAA,CAAA3C,CACA,CAAA,YAAA,CAAA4C,CACA,CAAA,QAAA,CAAAC,CACA,CAAA,GAAGnC,CACL,CAAA,CACAC,CACG,GAAA,CACH,GAAM,CAACmC,CAAAA,CAAcC,CAAe,CAAA,CAAUf,CAC5ChC,CAAAA,QAAAA,CAAAA,CAAAA,EAAO,UAAc4C,EAAAA,CAAAA,EAAc,QAAS,EAAA,EAAK,EACnD,CAAA,CAGMZ,YAAU,IAAM,CAChBhC,CAAU,GAAA,KAAA,CAAA,EACZ+C,CAAgB/C,CAAAA,CAAAA,CAAM,QAAS,EAAC,EAEpC,CAAA,CAAG,CAACA,CAAK,CAAC,CAAA,CAEV,IAAMgD,CAAqB,CAAAhB,CAAA,CAAA,WAAA,CACxBiB,CAA2C,EAAA,CAC1C,IAAMC,CAAAA,CAAWD,CAAE,CAAA,MAAA,CAAO,KAC1BF,CAAAA,CAAAA,CAAgBG,CAAQ,CAAA,CACxBL,CAAWI,GAAAA,CAAC,EACd,CACA,CAAA,CAACJ,CAAQ,CACX,CAEMM,CAAAA,CAAAA,CAAiBL,CAAa,CAAA,MAAA,CAC9BM,CAAYV,CAAAA,CAAAA,EAAsB,CAAC,CAACC,CAE1C,CAAA,OACEX,gBAAC,KAAI,CAAA,CAAA,SAAA,CAAU,qBACZG,CAAAA,CAAAA,CAAAA,EACCH,CAACT,CAAAA,aAAAA,CAAAA,CAAAA,CAAA,CACC,OAAQ,CAAA,eAAA,CACR,OAASc,CAAAA,CAAAA,CACT,EAAG,CAAA,OAAA,CACH,MAAOE,CAAQ,CAAA,QAAA,CAAW,SAC1B,CAAA,SAAA,CAAWtD,CAAGmD,CAAAA,CAAc,CAE3BD,CAAAA,CAAAA,CACH,CAEF,CAAAH,CAAA,CAAA,aAAA,CAAC,KACC,CAAA,CAAA,SAAA,CAAW/C,CACT,CAAA,uIAAA,CACA,CACE,qBAAuB,CAAA,CAACsD,CAAS,EAAA,CAACD,CAClC,CAAA,oBAAA,CAAsBC,CACtB,CAAA,CAAClD,EAAsB,EAAGiD,CAC5B,CACF,CAEA,CAAA,CAAAN,CAAA,CAAA,aAAA,CAAC,OAAI,SAAU,CAAA,eAAA,CAAA,CACbA,CAAC,CAAA,aAAA,CAAA,OAAA,CAAA,CACC,GAAKrB,CAAAA,CAAAA,CACL,EAAI0B,CAAAA,CAAAA,CACJ,SAAWpD,CAAAA,CAAAA,CACT,sNACAgD,CAAAA,CAAAA,EAAO,OACPzB,CAAAA,CACF,EACA,KAAOsC,CAAAA,CAAAA,CACP,SAAWH,CAAAA,CAAAA,CACX,QAAUK,CAAAA,CAAAA,CACV,eAAcT,CACb,CAAA,GAAG7B,CACN,CAAA,CAAA,CAAA,CACEuB,CAAOC,EAAAA,CAAAA,GACPF,gBAAC,KAAI,CAAA,CAAA,SAAA,CAAU,8CACZE,CAAAA,CAAAA,CAAAA,CACCF,CAAC7B,CAAAA,aAAAA,CAAAA,CAAAA,CAAA,CACC,IAAA,CAAM+B,CACN,CAAA,KAAA,CAAOK,CAAQ,CAAA,QAAA,CAAW,WAC1B,CAAA,IAAA,CAAM1C,EACN,KAAOU,CAAAA,CAAAA,CACT,CAEA0B,CAAAA,CAEJ,CAEJ,CAAA,CACCR,CACH,CAAA,CACAO,CAAC,CAAA,aAAA,CAAA,KAAA,CAAA,CAAI,SAAU,CAAA,4BAAA,CAAA,CACXO,CAASC,EAAAA,CAAAA,EAAiBC,EAC1BT,CAACT,CAAAA,aAAAA,CAAAA,CAAAA,CAAA,CACC,OAAA,CAAQ,UACR,CAAA,KAAA,CAAOgB,CAAQ,CAAA,QAAA,CAAW,WAC1B,CAAA,SAAA,CAAU,MAETA,CAAAA,CAAAA,CAAAA,CAAQC,CAAeC,CAAAA,CAC1B,EACE,IACHW,CAAAA,CAAAA,EACCpB,CAACT,CAAAA,aAAAA,CAAAA,CAAAA,CAAA,CACC,OAAA,CAAQ,WACR,KAAOgB,CAAAA,CAAAA,CAAQ,QAAW,CAAA,WAAA,CAC1B,SAAU,CAAA,iBAAA,CAAA,CAEVP,gBAACT,CAAA,CAAA,CACC,OAAQ,CAAA,UAAA,CACR,EAAG,CAAA,MAAA,CACH,KAAM,CAAA,aAAA,CACN,SAAU,CAAA,WAAA,CAAA,CAET4B,CACH,CAAA,CACCR,CAAa,EAAA,CAAA,CAAA,EAAIA,CAAS,CAAG,CAAA,CAAA,aAChC,CAEJ,CACF,CAEJ,CACF,CCtKA,CA2BA,IAAMU,EAAAA,CAAkB,CAAC,CACvB,KAAAC,CACA,CAAA,SAAA,CAAAC,CACF,CAAA,GAGM,CACJ,GAAI,CAACA,CAAAA,CAAW,OAAOnD,UAAAA,CAAA,aAAAA,CAAAA,UAAAA,CAAA,QAAGkD,CAAAA,IAAAA,CAAAA,CAAK,EAE/B,IAAME,CAAAA,CAAQF,CAAK,CAAA,KAAA,CAAM,IAAI,MAAA,CAAO,IAAIC,CAAS,CAAA,CAAA,CAAA,CAAK,GAAG,CAAC,CAC1D,CAAA,OACEnD,WAAA,aAAAA,CAAAA,UAAAA,CAAA,QACGoD,CAAAA,IAAAA,CAAAA,CAAAA,CAAM,GAAI,CAAA,CAACC,CAAMC,CAAAA,CAAAA,GAChBD,CAAK,CAAA,WAAA,EAAkBF,GAAAA,CAAAA,CAAU,WAAY,EAAA,CAC3CnD,WAAA,aAAC,CAAA,MAAA,CAAA,CAAK,GAAKsD,CAAAA,CAAAA,CAAG,SAAU,CAAA,WAAA,CAAA,CACrBD,CACH,CAAA,CAEAA,CAEJ,CACF,CAEJ,CAAA,CAEaE,EAASvD,CAAAA,UAAAA,CAAM,WAC1B,CACE,CACE,KAAAJ,CAAAA,CAAAA,CACA,KAAAmC,CAAAA,CAAAA,CACA,QAAAU,CAAAA,CAAAA,CACA,SAAAe,CAAAA,CAAAA,CACA,YAAAC,CAAAA,CAAAA,CACA,YAAAC,CAAAA,CAAAA,CACA,SAAAC,CACA,CAAA,KAAA,CAAAzD,CACA,CAAA,QAAA,CAAA0D,CACA,CAAA,SAAA,CAAAxD,EACA,EAAA6B,CAAAA,CAAAA,CACA,IAAA4B,CAAAA,CAAAA,CACA,eAAiBC,CAAAA,CAAAA,CACjB,YAAAC,CAAc,CAAA,EAChB,CACAxD,CAAAA,CAAAA,GAEAP,UAAA,CAAA,aAAA,CAAC,QACC,CAAA,CAAA,GAAA,CAAKO,CACL,CAAA,IAAA,CAAK,QACL,CAAA,EAAA,CAAI0B,CACJ,CAAA,IAAA,CAAM4B,EACN,eAAeC,CAAAA,CAAAA,CACf,QAAUF,CAAAA,CAAAA,CACV,SAAW/E,CAAAA,CAAAA,CACT,oEACA,CAAA,kCAAA,CACA,iDACA8E,CAAAA,CAAAA,EAAY,aACZ,CAAA,yBAAA,CACAvD,CACF,CAAA,CACA,QAAS,IAAM,CACbqC,CAAW7C,GAAAA,CAAK,EAClB,CAAA,CACA,SAAW4D,CAAAA,CAAAA,CACX,YAAcC,CAAAA,CAAAA,CACd,YAAcC,CAAAA,CAAAA,CAAAA,CAEd1D,UAAA,CAAA,aAAA,CAACmB,EAAA,CACC,OAAA,CAAQ,qBACR,CAAA,KAAA,CAAOjB,CAAU,GAAA,QAAA,CAAW,SAAW,SAEtC,CAAA,CAAA,OAAO6B,CAAU,EAAA,QAAA,CAChB/B,UAAA,CAAA,aAAA,CAACiD,GAAA,CAAgB,IAAA,CAAMlB,CAAO,CAAA,SAAA,CAAWgC,CAAa,CAAA,CAAA,CAEtDhC,CAEJ,CACF,CAEJ,CAAA,CC9EO,IAAMiC,CAAAA,CAAoBC,UAI/B,CAAA,CACE,CACE,KAAA,CAAArE,CACA,CAAA,UAAA,CAAAsE,CACA,CAAA,WAAA,CAAAC,CACA,CAAA,QAAA,CAAA1B,CACA,CAAA,SAAA,CAAAe,EACA,KAAAzB,CAAAA,CAAAA,CACA,cAAAC,CAAAA,CAAAA,CACA,EAAAC,CAAAA,CAAAA,CACA,QAAA2B,CAAAA,CAAAA,CACA,GAAA/B,CAAAA,CAAAA,CACA,SAAAzB,CAAAA,CAAAA,CACA,kBAAA8B,CAAAA,CAAAA,CACA,MAAAC,CACA,CAAA,YAAA,CAAAC,CACA,CAAA,UAAA,CAAAC,CACA,CAAA,eAAA,CAAiB+B,EACjB,uBAAyBC,CAAAA,CAAAA,CACzB,mBAAqBC,CAAAA,CACvB,CACA/D,CAAAA,CAAAA,GAGEP,WAAA,aAAC,CAAA,KAAA,CAAA,CAAI,SAAU,CAAA,qBAAA,CAAA,CACZ+B,CACC/B,EAAAA,UAAAA,CAAA,aAACmB,CAAAA,CAAAA,CAAA,CACC,OAAA,CAAQ,eACR,CAAA,OAAA,CAASc,CACT,CAAA,EAAA,CAAG,QACH,KAAOE,CAAAA,CAAAA,CAAQ,QAAW,CAAA,SAAA,CAC1B,SAAWtD,CAAAA,CAAAA,CAAGmD,CAAc,CAAA,CAAA,CAE3BD,CACH,CAAA,CAEF/B,UAAA,CAAA,aAAA,CAAC,KACC,CAAA,CAAA,SAAA,CAAWnB,EACT,mJACA,CAAA,CACE,qBAAuB,CAAA,CAACsD,CACxB,CAAA,oBAAA,CAAsBA,CACtB,CAAA,sBAAA,CAAwBD,CACxB,CAAA,gDAAA,CACE,CAACA,CACL,CACA9B,CAAAA,CACF,GAEAJ,UAAA,CAAA,aAAA,CAAC,KAAI,CAAA,CAAA,SAAA,CAAU,eACbA,CAAAA,CAAAA,UAAAA,CAAA,cAAC,KAAI,CAAA,CAAA,SAAA,CAAU,iBACbA,CAAAA,CAAAA,UAAAA,CAAA,aAAC,CAAA,OAAA,CAAA,CACC,IAAKO,CACL,CAAA,EAAA,CAAI0B,CACJ,CAAA,KAAA,CAAOrC,CACP,CAAA,QAAA,CAAWiD,CAAMJ,EAAAA,CAAAA,CAASI,CAAE,CAAA,MAAA,CAAO,KAAK,CAAA,CACxC,SAAWW,CAAAA,CAAAA,CACX,SAAUI,CACV,CAAA,WAAA,CAAaO,CACb,CAAA,SAAA,CAAWtF,CACT,CAAA,qMAAA,CACAgD,CAAO,EAAA,OACT,CACA,CAAA,cAAA,CAAcM,CACd,CAAA,eAAA,CAAeiC,CACf,CAAA,uBAAA,CAAuBC,EACvB,mBAAmBC,CAAAA,CAAAA,CACrB,CACCJ,CAAAA,CAAAA,EACClE,UAAA,CAAA,aAAA,CAAC,KAAI,CAAA,CAAA,SAAA,CAAU,wEACZJ,CAAAA,CAAAA,CAAAA,CACAsE,CAAW,CAAA,KAAA,CAAMtE,CAAM,CAAA,MAAM,CAChC,CAEJ,CAAA,CACCiC,CACC7B,EAAAA,UAAAA,CAAA,aAAC,CAAA,KAAA,CAAA,CAAI,UAAU,8CACZ6B,CAAAA,CAAAA,CACH,CAEJ,CACF,CACEM,CAAAA,CAAAA,EAASC,GAAiBC,CAC1BrC,CAAAA,UAAAA,CAAA,aAACmB,CAAAA,CAAAA,CAAA,CACC,OAAA,CAAQ,UACR,CAAA,KAAA,CAAOgB,CAAQ,CAAA,QAAA,CAAW,WAC1B,CAAA,SAAA,CAAU,MAETA,CAAAA,CAAAA,CAAAA,CAAQC,EAAeC,CAC1B,CAAA,CACE,IACN,CAGN,CAEA2B,CAAAA,CAAAA,CAAkB,WAAc,CAAA,mBAAA,CC5EnBO,IAAAA,EAAAA,CAAW,CAAC,CACvB,OAAAC,CAAAA,CAAAA,CACA,YAAAL,CAAc,CAAA,mBAAA,CACd,KAAAvE,CAAAA,CAAAA,CACA,QAAA6C,CAAAA,CAAAA,CACA,GAAAZ,CAAAA,CAAAA,CACA,SAAAzB,CAAAA,CAAAA,CACA,KAAA2B,CAAAA,CAAAA,CACA,cAAAC,CAAAA,CAAAA,CACA,GAAAC,CACA,CAAA,QAAA,CAAA2B,CACA,CAAA,SAAA,CAAAa,CACA,CAAA,YAAA,CAAAC,EAAe,CACf,CAAA,CAAA,OAAA,CAAAC,CAAU,CAAA,CAAA,CAAA,CACV,KAAAxC,CAAAA,CAAAA,CAAQ,GACR,YAAAC,CAAAA,CAAAA,CACA,gBAAAwC,CAAAA,CACF,CAAqB,GAAA,CACnB,GAAM,CAACC,CAAMC,CAAAA,CAAO,CAAIC,CAAAA,QAAAA,CAAS,CAAK,CAAA,CAAA,CAChC,CAAChB,CAAaiB,CAAAA,CAAc,CAAID,CAAAA,QAAAA,CAAS,EAAE,CAAA,CAC3C,CAACE,CAAAA,CAAgBC,CAAiB,CAAA,CAAIH,QAC1C,CAAA,EACF,CAAA,CACM,CAACI,CAAkBC,CAAAA,CAAmB,CAAIL,CAAAA,QAAAA,CAAiB,CAAE,CAAA,CAAA,CAC7DM,CAAUC,CAAAA,MAAAA,CAAuB,IAAI,CAAA,CACrCC,CAAWD,CAAAA,MAAAA,CAAyB,IAAI,CAAA,CAExCE,EAAYC,OAChB,CAAA,IAAMjB,CAAQ,CAAA,MAAA,CAAS,CAAK,EAAA,SAAA,GAAaA,EAAQ,CAAC,CAAA,CAClD,CAACA,CAAO,CACV,CAAA,CAEMkB,EAAcD,OAAQ,CAAA,IACrBjB,CAAQ,CAAA,MAAA,CACRgB,CACGhB,CAAAA,CAAAA,CAA0B,MAChC,CAAA,CAAC3E,CAAK8F,CAAAA,CAAAA,GAAU,CAAC,GAAG9F,CAAK,CAAA,GAAG8F,EAAM,OAAO,CAAA,CACzC,EACF,CAJuBnB,CAAAA,CAAAA,CADK,EAAC,CAM5B,CAACgB,CAAAA,CAAWhB,CAAO,CAAC,CAEjBoB,CAAAA,CAAAA,CAAiBH,QAAQ,IACtBC,CAAAA,CAAY,MAAQG,CAAAA,CAAAA,EACzB9B,CAAe,EAAA,OAAO8B,CAAO,CAAA,KAAA,EAAU,QACnCA,CAAAA,CAAAA,CAAO,KAAM,CAAA,WAAA,EAAc,CAAA,QAAA,CAAS9B,EAAY,WAAY,EAAC,CAC7D,CAAA,CAAA,CACN,CACC,CAAA,CAAC2B,EAAa3B,CAAW,CAAC,CAEvB+B,CAAAA,EAAAA,CAAiBL,OAAQ,CAAA,IACxBD,EAMGhB,CACL,CAAA,GAAA,CAAKmB,CAAW,GAAA,CACf,GAAGA,CAAAA,CACH,OAASA,CAAAA,CAAAA,CAAM,OAAQ,CAAA,MAAA,CAAQE,CAC7B9B,EAAAA,CAAAA,EAAe,OAAO8B,CAAAA,CAAO,OAAU,QACnCA,CAAAA,CAAAA,CAAO,KAAM,CAAA,WAAA,EAAc,CAAA,QAAA,CAAS9B,CAAY,CAAA,WAAA,EAAa,CAAA,CAC7D,CACN,CAAA,CACF,CAAE,CAAA,CAAA,CACD,OAAQ4B,CAAUA,EAAAA,CAAAA,CAAM,OAAQ,CAAA,MAAA,CAAS,CAAC,CAAA,CAdpCC,CAAe,CAAA,MAAA,CAAS,CAC3B,CAAA,CAAC,CAAE,KAAA,CAAO,EAAI,CAAA,OAAA,CAASA,CAAe,CAAC,CAAA,CACvC,EAAC,CAaN,CAACJ,CAAAA,CAAWhB,EAAST,CAAa6B,CAAAA,CAAc,CAAC,CAAA,CAE9CG,CAAiBN,CAAAA,OAAAA,CACrB,IAAMC,CAAY,CAAA,IAAA,CAAMM,CAAQA,EAAAA,CAAAA,CAAI,KAAUpG,GAAAA,CAAK,CACnD,CAAA,CAACA,CAAO8F,CAAAA,CAAW,CACrB,CAAA,CAEMO,CAAeR,CAAAA,OAAAA,CAAQ,IACvBZ,CAAad,CAAAA,CAAAA,CACbgC,CAAuBA,EAAAA,CAAAA,CAAe,KAAO,EAAA,QAAA,EAAc,EAAA,EAAA,CAE9D,CAAClB,CAAAA,CAAMd,CAAagC,CAAAA,CAAc,CAAC,CAAA,CAEhC7B,EAAauB,OAAQ,CAAA,IACrB,CAACf,CAAAA,EAAgB,CAACX,CAAAA,EAAe,CAACc,CAAAA,CAAa,EAC5Be,CAAAA,CAAAA,CAAe,IACnCI,CAAAA,CAAAA,EACC,OAAOA,CAAAA,CAAI,OAAU,QACrBA,EAAAA,CAAAA,CAAI,KAAM,CAAA,WAAA,EAAc,CAAA,UAAA,CAAWjC,EAAY,WAAY,EAAC,CAC5DiC,EAAAA,CAAAA,CAAI,KAAM,CAAA,WAAA,KAAkBjC,CAAY,CAAA,WAAA,EAC5C,CAAA,EACuB,KAAO,EAAA,QAAA,EAAc,EAAA,EAAA,CAC3C,CAACW,CAAAA,CAAcX,CAAa6B,CAAAA,CAAAA,CAAgBf,CAAI,CAAC,EAE9CqB,CAAqBC,CAAAA,WAAAA,CACxBC,CAAwB,EAAA,CACvB3D,CAAS2D,CAAAA,CAAW,CACpBtB,CAAAA,CAAAA,CAAQ,CAAK,CAAA,CAAA,CACbE,CAAe,CAAA,EAAE,CACjBI,CAAAA,CAAAA,CAAoB,EAAE,EACxB,CAAA,CACA,CAAC3C,CAAQ,CACX,CAAA,CAEM4D,EAAcF,CAAAA,WAAAA,CAAaG,CAAuB,EAAA,CACtDpB,CAAmBqB,CAAAA,CAAAA,GAAU,CAC3B,GAAGA,EACH,CAACD,CAAU,EAAG,CAACC,CAAKD,CAAAA,CAAU,CAChC,CAAE,CAAA,EACJ,CAAG,CAAA,EAAE,CAAA,CAGLE,UAAU,IAAM,CACd,GAAIhB,CAAAA,CAAW,CACb,IAAMiB,CAAgBjC,CAAAA,CAAAA,CAA0B,MAG9C,CAAA,CAAC3E,CAAK8F,CAAAA,CAAAA,IAAW,CACf,GAAG9F,EACH,CAAC8F,CAAAA,CAAM,KAAK,EAAG,CACjB,CAAA,CAAA,CAAA,CACA,EACF,CACAT,CAAAA,CAAAA,CAAkBuB,CAAY,EAChC,CACF,CAAA,CAAG,CAACjB,CAAWhB,CAAAA,CAAO,CAAC,CAAA,CAEvB,IAAMkC,CAAAA,CAAgBP,WACnBQ,CAAAA,CAAAA,EAA2C,CAC1C,OAAQA,CAAM,CAAA,GAAA,EACZ,IAAK,YACHA,CAAM,CAAA,cAAA,EACFA,CAAAA,CAAAA,CAAM,MACR7B,CAAAA,CAAAA,CAAQ,EAAI,CAEPD,CAAAA,CAAAA,CAIHO,CAAqBmB,CAAAA,CAAAA,EACnBA,CAAOX,CAAAA,CAAAA,CAAe,OAAS,CAAIW,CAAAA,CAAAA,CAAO,CAAI,CAAA,CAChD,CALAzB,EAAAA,CAAAA,CAAQ,CAAI,CAAA,CAAA,CACZM,CAAoB,CAAA,CAAC,CAOzB,CAAA,CAAA,MAEF,IAAK,SAAA,CACHuB,EAAM,cAAe,EAAA,CACjBA,CAAM,CAAA,MAAA,CACR7B,CAAQ,CAAA,CAAA,CAAK,CAERD,CAAAA,CAAAA,CAIHO,CAAqBmB,CAAAA,CAAAA,EACnBA,CAAO,CAAA,CAAA,CAAIA,CAAO,CAAA,CAAA,CAAIX,EAAe,MAAS,CAAA,CAChD,CALAd,EAAAA,CAAAA,CAAQ,CAAI,CAAA,CAAA,CACZM,CAAoBQ,CAAAA,CAAAA,CAAe,MAAS,CAAA,CAAC,CAOjD,CAAA,CAAA,MAEF,IAAK,QAAA,CACHe,EAAM,cAAe,EAAA,CACjB9B,CACFO,EAAAA,CAAAA,CAAqBmB,CAAS,EAAA,IAAA,CAAK,IAAI,CAAGA,CAAAA,CAAAA,CAAO,EAAE,CAAC,CAEtD,CAAA,MAEF,IAAK,UACHI,CAAAA,CAAAA,CAAM,cAAe,EAAA,CACjB9B,CACFO,EAAAA,CAAAA,CAAqBmB,CACnB,EAAA,IAAA,CAAK,GAAIX,CAAAA,CAAAA,CAAe,MAAS,CAAA,CAAA,CAAGW,CAAO,CAAA,EAAE,CAC/C,CAEF,CAAA,MAEF,IAAK,MAAA,CACHI,CAAM,CAAA,cAAA,EACF9B,CAAAA,CAAAA,EACFO,CAAoB,CAAA,CAAC,CAEvB,CAAA,MAEF,IAAK,KAAA,CACHuB,EAAM,cAAe,EAAA,CACjB9B,CACFO,EAAAA,CAAAA,CAAoBQ,CAAe,CAAA,MAAA,CAAS,CAAC,CAAA,CAE/C,MAEF,IAAK,OAEH,CAAA,GADAe,CAAM,CAAA,cAAA,GACFxB,CAAoB,EAAA,CAAA,EAAKS,CAAeT,CAAAA,CAAgB,CAC1De,CAAAA,CAAAA,CAAmBN,EAAeT,CAAgB,CAAA,CAAE,KAAK,CAAA,CAAA,KAAA,GAChDT,CAAgBR,EAAAA,CAAAA,CAAY,CACrC,IAAM0C,CAAAA,CAAiBhB,CAAe,CAAA,IAAA,CACnCI,CACC,EAAA,OAAOA,CAAI,CAAA,KAAA,EAAU,QACrBA,EAAAA,CAAAA,CAAI,KAAM,CAAA,WAAA,EAAc,CAAA,UAAA,CAAWjC,EAAY,WAAY,EAAC,CAChE,CAAA,CACI6C,CACFV,EAAAA,CAAAA,CAAmBU,CAAe,CAAA,KAAK,EAE3C,CACA,MAEF,IAAK,KACE/B,CAAAA,CAAAA,CAKHM,GAAoB,CACpBS,EAAAA,CAAAA,CAAeT,CAAgB,CAAA,GAE/BwB,CAAM,CAAA,cAAA,EACNT,CAAAA,CAAAA,CAAmBN,CAAeT,CAAAA,CAAgB,CAAE,CAAA,KAAK,CARzDwB,CAAAA,EAAAA,CAAAA,CAAM,gBACN7B,CAAAA,CAAAA,CAAQ,CAAI,CAAA,CAAA,CACZM,CAAoB,CAAA,CAAC,GAQvB,MAEF,IAAK,QACHuB,CAAAA,CAAAA,CAAM,cAAe,EAAA,CACrB7B,EAAQ,CAAK,CAAA,CAAA,CACbE,CAAe,CAAA,EAAE,CACjB,CAAA,KACJ,CACF,CAAA,CACA,CACEH,CAAAA,CACAM,CACAS,CAAAA,CAAAA,CACA1B,CACAH,CAAAA,CAAAA,CACAmC,EACAxB,CACF,CACF,CAEMmC,CAAAA,EAAAA,CAAsBV,WACzBQ,CAAAA,CAAAA,EAA4C,CAC3C,OAAQA,CAAM,CAAA,GAAA,EACZ,IAAK,WACHA,CAAAA,CAAAA,CAAM,gBACNvB,CAAAA,CAAAA,CAAqBmB,CACnBA,EAAAA,CAAAA,CAAOX,CAAe,CAAA,MAAA,CAAS,CAAIW,CAAAA,CAAAA,CAAO,CAAI,CAAA,CAChD,CACA,CAAA,MAEF,IAAK,SAAA,CACHI,EAAM,cAAe,EAAA,CACrBvB,CAAqBmB,CAAAA,CAAAA,EACnBA,CAAO,CAAA,CAAA,CAAIA,EAAO,CAAIX,CAAAA,CAAAA,CAAe,MAAS,CAAA,CAChD,CACA,CAAA,MAEF,IAAK,OACL,CAAA,IAAK,OACHe,CAAAA,CAAAA,CAAM,cAAe,EAAA,CACjBxB,CAAoB,EAAA,CAAA,EAAKS,CAAeT,CAAAA,CAAgB,CAC1De,EAAAA,CAAAA,CAAmBN,CAAeT,CAAAA,CAAgB,EAAE,KAAK,CAAA,CAE3D,MAEF,IAAK,QACHwB,CAAAA,CAAAA,CAAM,cAAe,EAAA,CACrB7B,CAAQ,CAAA,CAAA,CAAK,CACbS,CAAAA,CAAAA,CAAS,OAAS,EAAA,KAAA,GAClB,MAEF,IAAK,KACHoB,CAAAA,CAAAA,CAAM,cAAe,EAAA,CACjBxB,CAAoB,EAAA,CAAA,EAAKS,CAAeT,CAAAA,CAAgB,CAC1De,EAAAA,CAAAA,CAAmBN,CAAeT,CAAAA,CAAgB,EAAE,KAAK,CAAA,CAE3D,KACJ,CACF,CACA,CAAA,CAACA,EAAkBS,CAAgBM,CAAAA,CAAkB,CACvD,CAAA,CAGAM,SAAU,CAAA,IAAM,CACd,GAAI3B,CAAAA,CAAM,CACR,IAAMiC,CAAQvB,CAAAA,CAAAA,CAAS,OACvB,CAAA,GAAIuB,CAAO,CAAA,CACTA,CAAM,CAAA,KAAA,CAAM,CAAE,aAAA,CAAe,EAAK,CAAC,CAAA,CAEnC,IAAMC,CAAAA,CAASD,CAAM,CAAA,KAAA,CAAM,MAC3BA,CAAAA,CAAAA,CAAM,iBAAkBC,CAAAA,CAAAA,CAAQA,CAAM,EACxC,CACF,CACF,EAAG,CAAClC,CAAI,CAAC,CAAA,CAGT2B,SAAU,CAAA,IAAM,CACT3B,CAAAA,EACHO,CAAoB,CAAA,CAAA,CAAE,EAE1B,CAAA,CAAG,CAACP,CAAI,CAAC,CAGT2B,CAAAA,SAAAA,CAAU,IAAM,CACd,GAAI3B,CAAAA,EAAQM,GAAoB,CAAKE,EAAAA,CAAAA,CAAQ,OAAS,CAAA,CACpD,IAAM2B,CAAAA,CAAoB3B,EAAQ,OAAQ,CAAA,aAAA,CACxC,CAAQpD,KAAAA,EAAAA,CAAE,CAAWkD,QAAAA,EAAAA,CAAgB,CACvC,EAAA,CAAA,CAAA,CAEI6B,CACFA,EAAAA,CAAAA,CAAkB,cAAe,CAAA,CAC/B,KAAO,CAAA,SAAA,CACP,SAAU,QACZ,CAAC,EAEL,CACF,CAAG,CAAA,CAAC7B,CAAkBN,CAAAA,CAAAA,CAAM5C,CAAE,CAAC,CAE/B,CAAA,IAAMgF,EAAoBd,CAAAA,WAAAA,CACvBN,GAAwB,CACvB,GAAI,CAAChB,CAAAA,CAAM,OAAOjF,CAAAA,GAAUiG,CAAO,CAAA,KAAA,CAEnC,IAAMqB,CAAAA,CAAQtB,CAAe,CAAA,SAAA,CAC1BI,CAAQA,EAAAA,CAAAA,CAAI,QAAUH,CAAO,CAAA,KAChC,CAGA,CAAA,OAAIV,CAAoB,EAAA,CAAA,CACf+B,IAAU/B,CAIfA,CAAAA,CAAAA,GAAqB,CAChB+B,CAAAA,CAAAA,CAAAA,GAAU,CAGZ,CAAA,CAAA,CACT,EACA,CAACrC,CAAAA,CAAMjF,CAAOuF,CAAAA,CAAAA,CAAkBS,CAAc,CAChD,CAGA,CAAA,OAAAY,SAAU,CAAA,IAAM,CACV3B,CAAAA,EAAQM,CAAqB,GAAA,CAAA,CAAA,EAC/BC,EAAoB,CAAC,EAEzB,CAAG,CAAA,CAACP,CAAMM,CAAAA,CAAgB,CAAC,CAAA,CAGzBnF,UAAA,CAAA,aAAA,CAAS,CAAR,CAAA,IAAA,CAAA,CACC,IAAM6E,CAAAA,CAAAA,EAAQ,CAACjB,CACf,CAAA,YAAA,CAAeuD,CAAW,EAAA,CACxB,GAAI,CAACvD,CAEH,CAAA,GADAkB,CAAQqC,CAAAA,CAAM,CACV,CAAA,CAACA,CACHnC,CAAAA,CAAAA,CAAe,EAAE,CACjBI,CAAAA,CAAAA,CAAoB,CAAE,CAAA,CAAA,CAAA,KACjB,CACL,IAAM0B,EAAQvB,CAAS,CAAA,OAAA,CACvB,GAAIuB,CAAAA,CAAO,CACTA,CAAAA,CAAM,MAAM,CAAE,aAAA,CAAe,CAAK,CAAA,CAAC,CACnC,CAAA,IAAMC,CAASD,CAAAA,CAAAA,CAAM,KAAM,CAAA,MAAA,CAC3BA,CAAM,CAAA,iBAAA,CAAkBC,CAAQA,CAAAA,CAAM,EACxC,CACF,CAEJ,CAEA/G,CAAAA,CAAAA,UAAAA,CAAA,aAAC,CAAA,KAAA,CAAA,CACC,SAAW,CAAA,CAAA,yCAAA,EAA4CI,CAAS,CAAA,CAAA,CAChE,IAAK,CAAA,UAAA,CACL,eAAeyE,CAAAA,CAAAA,CACf,gBAAc,SACd,CAAA,eAAA,CAAe,CAAG5C,EAAAA,CAAE,CAEpBjC,QAAAA,CAAAA,CAAAA,CAAAA,UAAAA,CAAA,aAAS,CAAA,CAAA,CAAA,OAAA,CAAR,CAAgB,OAAA,CAAO,CACtBA,CAAAA,CAAAA,CAAAA,UAAAA,CAAA,aAAC,CAAA,QAAA,CAAA,CACC,KAAK,QACL,CAAA,SAAA,CAAU,kBACV,CAAA,QAAA,CAAU4D,CAETc,CAAAA,CAAAA,CAAAA,CACC1E,WAAA,aAACgE,CAAAA,CAAAA,CAAA,CACC,GAAA,CAAKuB,CACL,CAAA,EAAA,CAAItD,EACJ,KAAOF,CAAAA,CAAAA,CACP,cAAgBC,CAAAA,CAAAA,CAChB,WAAamC,CAAAA,CAAAA,CACb,KAAO8B,CAAAA,CAAAA,CACP,UAAY/B,CAAAA,CAAAA,CACZ,QAAWtE,CAAAA,CAAAA,EAAU,CACnBoF,CAAAA,CAAepF,CAAK,CACfiF,CAAAA,CAAAA,EACHC,CAAQ,CAAA,CAAA,CAAI,EAEhB,CAAA,CACA,SAAW4B,CAAAA,CAAAA,CACX,GAAK7E,CAAAA,CAAAA,CACL,SAAU,CAAA,QAAA,CACV,kBAAoBgD,CAAAA,CAAAA,CACpB,SAAUjB,CACV,CAAA,mBAAA,CAAkB,MAClB,CAAA,eAAA,CAAe,CAAG3B,EAAAA,CAAE,CACpB,QAAA,CAAA,CAAA,uBAAA,CACEkD,CAAoB,EAAA,CAAA,CAChB,CAAGlD,EAAAA,CAAE,CAAWkD,QAAAA,EAAAA,CAAgB,GAChC,KAER,CAAA,CAAA,CAAA,CAEAnF,UAAA,CAAA,aAAA,CAAC2B,EAAA,CAAA,CACC,IAAK4D,CACL,CAAA,EAAA,CAAItD,CACJ,CAAA,KAAA,CAAOF,CACP,CAAA,cAAA,CAAgBC,EAChB,WAAamC,CAAAA,CAAAA,CACb,KAAO8B,CAAAA,CAAAA,CACP,QAAW,CAAA,CAAA,EAAM,CACfjB,CAAAA,CAAe,CAAE,CAAA,MAAA,CAAO,KAAK,CAAA,CACxBH,CACHC,EAAAA,CAAAA,CAAQ,EAAI,EAEhB,CAAA,CACA,SAAW4B,CAAAA,CAAAA,CACX,GAAK7E,CAAAA,CAAAA,CACL,SAAU,CAAA,QAAA,CACV,kBAAoBgD,CAAAA,CAAAA,CACpB,QAAUjB,CAAAA,CAAAA,CACV,eAAe,CAAA,CAAA,EAAG3B,CAAE,CACpB,QAAA,CAAA,CAAA,uBAAA,CACEkD,CAAoB,EAAA,CAAA,CAChB,CAAGlD,EAAAA,CAAE,CAAWkD,QAAAA,EAAAA,CAAgB,CAChC,CAAA,CAAA,KAAA,CAAA,CAER,CAEJ,CACF,CAEAnF,CAAAA,UAAAA,CAAA,cAAS,CAAR,CAAA,MAAA,CAAA,CAAe,SAAWyE,CAAAA,CAAAA,CAAAA,CACzBzE,UAAA,CAAA,aAAA,CAAS,UAAR,CACC,SAAA,CAAU,2LACV,CAAA,IAAA,CAAK,QACL,CAAA,KAAA,CAAM,QACN,UAAY,CAAA,CAAA,CACZ,eAAkB,CAAA,CAAA,EAAM,CAAE,CAAA,cAAA,EAC1B,CAAA,gBAAA,CAAmB,CAAM,EAAA,CAAA,CAAE,cAAe,EAAA,CAC1C,cAAiB,CAAA,CAAA,EAAM,EAAE,cAAe,EAAA,CACxC,iBAAoB,CAAA,CAAA,EAAM,CACxB,CAAA,CAAE,cAAe,EAAA,CACjB8E,CAAQ,CAAA,CAAA,CAAK,CACbE,CAAAA,CAAAA,CAAe,EAAE,CAAA,CACjBI,EAAoB,CAAE,CAAA,EACxB,CAEApF,CAAAA,CAAAA,UAAAA,CAAA,aAAC,CAAA,KAAA,CAAA,CACC,GAAKqF,CAAAA,CAAAA,CACL,SAAU,CAAA,oEAAA,CACV,IAAK,CAAA,SAAA,CACL,EAAI,CAAA,CAAA,EAAGpD,CAAE,CACT,QAAA,CAAA,CAAA,YAAA,CAAYF,CACZ,CAAA,WAAA,CAAW4C,CAEVxC,CAAAA,CAAAA,CAAAA,CACCnC,WAAA,aAAC,CAAA,KAAA,CAAA,CAAI,SAAU,CAAA,kCAAA,CAAA,CACZoC,CAAgB,EAAA,wBACnB,EACEuC,CACF3E,CAAAA,UAAAA,CAAA,aAAC,CAAA,KAAA,CAAA,CAAI,SAAU,CAAA,mCAAA,CAAA,CAAoC,YAEnD,CAAA,CACE4F,CAAe,CAAA,MAAA,CAAS,CAC1BE,CAAAA,EAAAA,CAAe,GAAI,CAAA,CAACH,EAAOyB,CACzBpH,GAAAA,UAAAA,CAAA,aAAa,CAAA,CAAA,CAAA,IAAA,CAAZ,CACC,GAAA,CAAK2F,CAAM,CAAA,KAAA,EAASyB,CACpB,CAAA,SAAA,CAAU,QACV,CAAA,IAAA,CAAMnC,CAAeU,CAAAA,CAAAA,CAAM,KAAK,CAAK,EAAA,CAAA,CAAA,CACrC,YAAc,CAAA,IAAMA,CAAM,CAAA,KAAA,EAASU,EAAYV,CAAAA,CAAAA,CAAM,KAAK,CAAA,CAAA,CAEzDA,CAAM,CAAA,KAAA,EACL3F,UAAA,CAAA,aAAA,CAAa,UAAZ,CAAoB,OAAA,CAAO,CAC1BA,CAAAA,CAAAA,CAAAA,UAAAA,CAAA,aAAC,CAAA,KAAA,CAAA,CACC,UAAU,uEACV,CAAA,QAAA,CAAU,CAEVA,CAAAA,CAAAA,CAAAA,UAAAA,CAAA,aAACmB,CAAAA,CAAAA,CAAA,CAAK,OAAQ,CAAA,mBAAA,CAAoB,KAAM,CAAA,WAAA,CAAA,CACrCwE,CAAM,CAAA,KACT,CACA3F,CAAAA,UAAAA,CAAA,aAACD,CAAAA,CAAAA,CAAA,CACC,IAAA,CAAK,YACL,CAAA,SAAA,CAAWlB,EACT,sBACAoG,CAAAA,CAAAA,CAAeU,CAAM,CAAA,KAAK,CAAK,EAAA,YACjC,CACA,CAAA,IAAA,CAAM,EACR,CAAA,CACF,CACF,CAAA,CAEF3F,UAAA,CAAA,aAAA,CAAa,UAAZ,CAAoB,SAAA,CAAU,mFAC5B2F,CAAAA,CAAAA,CAAAA,CAAM,OAAQ,CAAA,GAAA,CAAI,CAACE,CAAAA,CAAQwB,CAAgB,GAAA,CAC1C,IAAMC,EAAAA,CAAaL,EAAkBpB,CAAAA,CAAM,EAC3C,OACE7F,UAAAA,CAAA,aAACuD,CAAAA,EAAAA,CAAA,CACC,GAAA,CAAK,CAAG6D,EAAAA,CAAU,CAAIC,CAAAA,EAAAA,CAAW,CACjC,CAAA,CAAA,QAAA,CAAUnB,CACV,CAAA,SAAA,CAAWW,GACX,KAAOhB,CAAAA,CAAAA,CAAO,KACd,CAAA,KAAA,CAAOA,CAAO,CAAA,KAAA,CACd,SAAWhH,CAAAA,CAAAA,CAAG,MAAM,CAAA,CACpB,QAAUyI,CAAAA,EAAAA,CACV,EAAI,CAAA,CAAA,EAAGrF,CAAE,CAAWoF,QAAAA,EAAAA,CAAW,CAC/B,CAAA,CAAA,IAAA,CAAK,QACL,CAAA,eAAA,CAAeC,EACf,CAAA,WAAA,CAAavD,CACf,CAAA,CAEJ,CAAC,CACH,CACF,CACD,EAED/D,UAAA,CAAA,aAAA,CAAC,KAAI,CAAA,CAAA,SAAA,CAAU,mCACZ4E,CAAAA,CAAAA,CAAAA,EAAoB,kBACvB,CAEJ,CACF,CACF,CACF,CACF,CAEJ","file":"Combobox.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","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\n const safelist: 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 breakpoints = [\"sm\", \"md\", \"lg\", \"xl\", \"2xl\"];\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 return [\n ...typographyClasses,\n ...responsiveTypographyClasses\n // ... rest of your safelist\n ];\n};\n\nexport const focusRingStyles =\n \"focus-visible:outline-none focus-visible:border-2 focus-visible:border-primary-100\";\n\nexport const focusRingStylesCoerced = \"border-2 border-primary-100\";\n","import React, { SVGProps } from \"react\";\nimport { IconName, IconMap } from \"@deckai/icons\";\nimport { IconColors } from \"../types/tailwind\";\nimport { cn } from \"../utils\";\n\ntype Breakpoint = \"sm\" | \"md\" | \"lg\" | \"xl\" | \"2xl\";\ntype ResponsiveSize = number | `${Breakpoint}:${number}`;\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\nconst COLOR_MAP: Record<IconColors, string> = {\n primary: \"#080808\",\n secondary: \"#666666\",\n white: \"#ffffff\",\n primaryBlue: \"#089CCB\",\n disabled: \"#888888\",\n danger: \"#FF0000\"\n};\n\nconst BREAKPOINT_MAP: Record<Breakpoint, string> = {\n sm: \"640px\",\n md: \"768px\",\n lg: \"1024px\",\n xl: \"1280px\",\n \"2xl\": \"1536px\"\n};\n\nconst processSizes = (\n sizes: ResponsiveSize | ResponsiveSize[] | undefined\n): React.CSSProperties => {\n if (!sizes) return { width: \"24px\", height: \"24px\" };\n\n const sizeArray = Array.isArray(sizes) ? sizes : [sizes];\n const mediaQueries: Record<string, string> = {};\n let baseSize: string | undefined;\n\n // Process each size\n sizeArray.forEach((size) => {\n if (typeof size === \"number\") {\n baseSize = `${size}px`;\n } else {\n const [breakpoint, valueStr] = size.split(\":\") as [Breakpoint, string];\n const value = parseInt(valueStr, 10);\n mediaQueries[`@media (min-width: ${BREAKPOINT_MAP[breakpoint]})`] =\n `${value}px`;\n }\n });\n\n // Create the style object with the correct structure\n return {\n width: baseSize || \"24px\",\n height: baseSize || \"24px\",\n ...Object.entries(mediaQueries).reduce(\n (acc, [query, size]) => ({\n ...acc,\n [query]: {\n width: size,\n height: size\n }\n }),\n {}\n )\n };\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 sizeStyles = processSizes(size);\n\n return (\n <div\n className={cn(\"flex justify-center items-center\", className)}\n style={{\n ...sizeStyles,\n [\"--icon-stroke\" as string]: COLOR_MAP[color],\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 React from \"react\";\nimport { Typography } from \"../types/tailwind\";\n\ntype TextElement =\n | \"p\"\n | \"span\"\n | \"h1\"\n | \"h2\"\n | \"h3\"\n | \"h4\"\n | \"h5\"\n | \"h6\"\n | \"strong\"\n | \"em\"\n | \"blockquote\"\n | \"pre\"\n | \"code\"\n | \"small\"\n | \"label\"\n | \"a\";\n\n// HTML element mapping type\ntype HTMLElementByTag = {\n p: HTMLParagraphElement;\n span: HTMLSpanElement;\n h1: HTMLHeadingElement;\n h2: HTMLHeadingElement;\n h3: HTMLHeadingElement;\n h4: HTMLHeadingElement;\n h5: HTMLHeadingElement;\n h6: HTMLHeadingElement;\n strong: HTMLElement;\n em: HTMLElement;\n blockquote: HTMLQuoteElement;\n pre: HTMLPreElement;\n code: HTMLElement;\n small: HTMLElement;\n label: HTMLLabelElement;\n a: HTMLAnchorElement;\n};\n\n// HTML props mapping type\ntype HTMLPropsMap = {\n p: React.HTMLAttributes<HTMLParagraphElement>;\n span: React.HTMLAttributes<HTMLSpanElement>;\n h1: React.HTMLAttributes<HTMLHeadingElement>;\n h2: React.HTMLAttributes<HTMLHeadingElement>;\n h3: React.HTMLAttributes<HTMLHeadingElement>;\n h4: React.HTMLAttributes<HTMLHeadingElement>;\n h5: React.HTMLAttributes<HTMLHeadingElement>;\n h6: React.HTMLAttributes<HTMLHeadingElement>;\n strong: React.HTMLAttributes<HTMLElement>;\n em: React.HTMLAttributes<HTMLElement>;\n blockquote: React.HTMLAttributes<HTMLQuoteElement>;\n pre: React.HTMLAttributes<HTMLPreElement>;\n code: React.HTMLAttributes<HTMLElement>;\n small: React.HTMLAttributes<HTMLElement>;\n label: React.LabelHTMLAttributes<HTMLLabelElement>;\n a: Omit<React.AnchorHTMLAttributes<HTMLAnchorElement>, \"color\">;\n};\n\ntype TextColor =\n | \"primary\"\n | \"secondary\"\n | \"white\"\n | \"primary-blue\"\n | \"disabled\"\n | \"danger\"\n | \"inherit\"\n | \"primary-100\";\n\nconst HEADING_ELEMENT_MAP: Record<string, TextElement> = {\n xl: \"h1\",\n lg: \"h1\",\n md: \"h2\",\n sm: \"h3\",\n xs: \"h4\"\n};\n\nconst getElementFromVariant = (variant: TypographyKey): TextElement => {\n const [category, size] = variant.split(\"-\");\n\n if (category === \"heading\") {\n return HEADING_ELEMENT_MAP[size] || \"p\";\n }\n\n if (category === \"label\") {\n return \"label\";\n }\n\n return \"p\";\n};\n\ntype Weight = \"light\" | \"regular\" | \"semibold\" | \"bold\";\n\nconst fontWeight: Record<Weight, string> = {\n light: \"font-light\",\n regular: \"font-regular\",\n semibold: \"font-semibold\",\n bold: \"font-bold\"\n};\n\n// Add breakpoint types\ntype Breakpoint = \"sm\" | \"md\" | \"lg\" | \"xl\" | \"2xl\";\ntype ResponsiveVariant = TypographyKey | `${Breakpoint}:${TypographyKey}`;\n\ntype TypographyCategory = keyof Typography;\ntype TypographyValue<T extends TypographyCategory> = Extract<\n keyof Typography[T],\n string | number | bigint | boolean | null | undefined\n>;\ntype TypographyKey = {\n [T in TypographyCategory]: `${T}-${TypographyValue<T>}`;\n}[TypographyCategory];\n\n// Update TextProps to use ResponsiveVariant\nexport type TextProps<T extends TextElement = \"p\"> = {\n variant?: ResponsiveVariant | ResponsiveVariant[];\n color?: TextColor;\n as?: T;\n className?: string;\n children: React.ReactNode;\n weight?: Weight;\n} & HTMLPropsMap[T];\n\n// Add helper function to process variants\nconst processVariants = (\n variants: ResponsiveVariant | ResponsiveVariant[] | undefined\n): string => {\n if (!variants) return \"text-body-default\";\n\n const variantArray = Array.isArray(variants) ? variants : [variants];\n\n return variantArray\n .map((variant) => {\n if (variant.includes(\":\")) {\n const [breakpoint, typographyClass] = variant.split(\":\");\n return `${breakpoint}:text-${typographyClass}`;\n }\n return `text-${variant}`;\n })\n .join(\" \");\n};\n\nexport const Text = React.forwardRef(\n <T extends TextElement = \"p\">(\n {\n variant = \"body-default\",\n color = \"primary\",\n as,\n className,\n children,\n weight,\n ...props\n }: TextProps<T>,\n ref: React.ForwardedRef<HTMLElementByTag[T]>\n ) => {\n // Process typography classes with breakpoints\n const typographyClasses = processVariants(variant);\n\n // Get color styles\n const colorClasses = color === \"inherit\" ? \"text-inherit\" : `text-${color}`;\n\n const suggestedElement = React.useMemo(() => {\n const baseVariant =\n typeof variant === \"string\"\n ? variant.split(\":\").pop()!\n : Array.isArray(variant)\n ? variant[0].split(\":\").pop()!\n : \"body-default\";\n return getElementFromVariant(baseVariant as TypographyKey);\n }, [variant]);\n\n const Component = (as || suggestedElement) as T;\n\n return (\n // @ts-expect-error TODO: figure this out\n <Component\n ref={ref}\n className={`\n font-sans antialiased\n ${typographyClasses}\n ${colorClasses}\n ${weight && `!${fontWeight[weight]}`}\n ${className}\n `}\n {...props}\n >\n {children}\n </Component>\n );\n }\n);\n\nText.displayName = \"Text\";\n","import * as React from \"react\";\nimport { cn } from \"../utils\";\nimport { focusRingStyles, focusRingStylesCoerced } from \"../utils/tailwind\";\nimport { IconName } from \"@deckai/icons\";\nimport { Icon, IconProps } from \"./Icon\";\nimport { Text } from \"./Text\";\n\nexport type InputProps = {\n className?: string;\n end?: React.ReactNode;\n /** renders an icon in the end slot */\n iconName?: IconName;\n /** Label text for the input */\n label?: string;\n /** Additional classes for the label */\n labelClassName?: string;\n /** Forces the focus ring to show regardless of focus state */\n forceShowFocusRing?: boolean;\n /** Error state for the input */\n error?: boolean;\n /** Error message to display below the input */\n errorMessage?: string;\n /** Helper text displayed below the input */\n helperText?: string;\n /** Character count display */\n showCharacterCount?: boolean;\n /** Maximum number of characters */\n maxLength?: number;\n} & React.InputHTMLAttributes<HTMLInputElement> &\n Pick<IconProps, \"color\" | \"size\" | \"title\">;\n\nexport const Input = React.forwardRef<HTMLInputElement, InputProps>(\n (\n {\n className,\n end,\n iconName,\n color,\n size,\n title,\n label,\n labelClassName,\n id,\n children,\n forceShowFocusRing,\n error,\n errorMessage,\n helperText,\n showCharacterCount,\n maxLength,\n value,\n defaultValue,\n onChange,\n ...props\n },\n ref\n ) => {\n const [currentValue, setCurrentValue] = React.useState(\n value?.toString() || defaultValue?.toString() || \"\"\n );\n\n // Update internal value when prop changes\n React.useEffect(() => {\n if (value !== undefined) {\n setCurrentValue(value.toString());\n }\n }, [value]);\n\n const handleChange = React.useCallback(\n (e: React.ChangeEvent<HTMLInputElement>) => {\n const newValue = e.target.value;\n setCurrentValue(newValue);\n onChange?.(e);\n },\n [onChange]\n );\n\n const characterCount = currentValue.length;\n const showCount = showCharacterCount || !!maxLength;\n\n return (\n <div className=\"gap-1 flex flex-col\">\n {label && (\n <Text\n variant=\"label-default\"\n htmlFor={id}\n as=\"label\"\n color={error ? \"danger\" : \"primary\"}\n className={cn(labelClassName)}\n >\n {label}\n </Text>\n )}\n <div\n className={cn(\n \"relative flex flex-col gap-2 w-full rounded-lg border bg-background-0 px-3 md:py-3 py-2 text-secondary transition-colors duration-150\",\n {\n \"border-secondary-50\": !error && !forceShowFocusRing,\n \"border-tertiary-10\": error,\n [focusRingStylesCoerced]: forceShowFocusRing\n }\n )}\n >\n <div className=\"flex relative\">\n <input\n ref={ref}\n id={id}\n className={cn(\n \"font-sans text-sm flex w-full file:border-0 file:bg-transparent file:text-sm file:font-medium file:text-foreground placeholder:text-secondary text-primary disabled:cursor-not-allowed focus:outline-none rounded-lg\",\n end && \"pr-10\",\n className\n )}\n value={currentValue}\n maxLength={maxLength}\n onChange={handleChange}\n aria-invalid={error}\n {...props}\n />\n {(end || iconName) && (\n <div className=\"absolute inset-y-0 right-0 flex items-center\">\n {iconName ? (\n <Icon\n name={iconName}\n color={error ? \"danger\" : \"secondary\"}\n size={size}\n title={title}\n />\n ) : (\n end\n )}\n </div>\n )}\n </div>\n {children}\n </div>\n <div className=\"flex justify-between gap-2\">\n {(error && errorMessage) || helperText ? (\n <Text\n variant=\"body-xxs\"\n color={error ? \"danger\" : \"secondary\"}\n className=\"mt-1\"\n >\n {error ? errorMessage : helperText}\n </Text>\n ) : null}\n {showCount && (\n <Text\n variant=\"body-xxs\"\n color={error ? \"danger\" : \"secondary\"}\n className=\"text-right mt-1\"\n >\n <Text\n variant=\"body-xxs\"\n as=\"span\"\n color=\"primary-100\"\n className=\"font-bold\"\n >\n {characterCount}\n </Text>\n {maxLength && `/${maxLength}`} characters\n </Text>\n )}\n </div>\n </div>\n );\n }\n);\n","import React, { KeyboardEvent } from \"react\";\nimport { cn } from \"../utils\";\nimport { Text } from \"./Text\";\n\nexport type OptionProps = {\n label: React.ReactNode;\n value: string;\n /** Optional color override for specific items like \"Logout\" in red */\n color?: \"default\" | \"danger\";\n /** Optional disabled state */\n disabled?: boolean;\n onChange?: (value: string) => void;\n onKeyDown?: (event: KeyboardEvent<HTMLButtonElement>) => void;\n onMouseEnter?: () => void;\n onMouseLeave?: () => void;\n selected?: boolean;\n className?: string;\n /** ID for accessibility */\n id?: string;\n /** ARIA role */\n role?: string;\n /** ARIA selected state */\n \"aria-selected\"?: boolean;\n /** Current search value for highlighting matches */\n searchValue?: string;\n};\n\nconst HighlightedText = ({\n text,\n highlight\n}: {\n text: string;\n highlight: string;\n}) => {\n if (!highlight) return <>{text}</>;\n\n const parts = text.split(new RegExp(`(${highlight})`, \"i\"));\n return (\n <>\n {parts.map((part, i) =>\n part.toLowerCase() === highlight.toLowerCase() ? (\n <span key={i} className=\"font-bold\">\n {part}\n </span>\n ) : (\n part\n )\n )}\n </>\n );\n};\n\nexport const Option = React.forwardRef<HTMLButtonElement, OptionProps>(\n (\n {\n value,\n label,\n onChange,\n onKeyDown,\n onMouseEnter,\n onMouseLeave,\n selected,\n color,\n disabled,\n className,\n id,\n role,\n \"aria-selected\": ariaSelected,\n searchValue = \"\"\n },\n ref\n ) => (\n <button\n ref={ref}\n type=\"button\"\n id={id}\n role={role}\n aria-selected={ariaSelected}\n disabled={disabled}\n className={cn(\n \"relative w-full text-left px-2 py-1.5 text-sm rounded outline-none\",\n \"cursor-pointer hover:bg-gray-100\",\n \"disabled:opacity-50 disabled:cursor-not-allowed\",\n selected && \"bg-gray-100\",\n \"flex items-center gap-2\",\n className\n )}\n onClick={() => {\n onChange?.(value);\n }}\n onKeyDown={onKeyDown}\n onMouseEnter={onMouseEnter}\n onMouseLeave={onMouseLeave}\n >\n <Text\n variant=\"body-default-medium\"\n color={color === \"danger\" ? \"danger\" : \"inherit\"}\n >\n {typeof label === \"string\" ? (\n <HighlightedText text={label} highlight={searchValue} />\n ) : (\n label\n )}\n </Text>\n </button>\n )\n);\n","import React, { forwardRef, KeyboardEvent } from \"react\";\nimport { cn } from \"../utils\";\nimport { Text } from \"./Text\";\n\nexport type AutocompleteInputProps = {\n value: string;\n suggestion: string;\n placeholder?: string;\n onChange: (value: string) => void;\n onKeyDown?: (event: KeyboardEvent<HTMLInputElement>) => void;\n label?: string;\n labelClassName?: string;\n id?: string;\n disabled?: boolean;\n end?: React.ReactNode;\n className?: string;\n forceShowFocusRing?: boolean;\n /** Error state for the input */\n error?: boolean;\n /** Error message to display below the input */\n errorMessage?: string;\n /** Helper text displayed below the input */\n helperText?: string;\n \"aria-controls\"?: string;\n \"aria-activedescendant\"?: string;\n \"aria-autocomplete\"?: \"none\" | \"inline\" | \"list\" | \"both\";\n};\n\nexport const AutocompleteInput = forwardRef<\n HTMLInputElement,\n AutocompleteInputProps\n>(\n (\n {\n value,\n suggestion,\n placeholder,\n onChange,\n onKeyDown,\n label,\n labelClassName,\n id,\n disabled,\n end,\n className,\n forceShowFocusRing,\n error,\n errorMessage,\n helperText,\n \"aria-controls\": ariaControls,\n \"aria-activedescendant\": ariaActiveDescendant,\n \"aria-autocomplete\": ariaAutocomplete\n },\n ref\n ) => {\n return (\n <div className=\"gap-1 flex flex-col\">\n {label && (\n <Text\n variant=\"label-default\"\n htmlFor={id}\n as=\"label\"\n color={error ? \"danger\" : \"primary\"}\n className={cn(labelClassName)}\n >\n {label}\n </Text>\n )}\n <div\n className={cn(\n \"relative flex flex-col gap-2 w-full rounded-lg border bg-background-0 px-3 md:py-3 py-2 text-secondary ring-offset-background disabled:opacity-50\",\n {\n \"border-secondary-50\": !error,\n \"border-tertiary-10\": error,\n \"ring-2 ring-offset-2\": forceShowFocusRing,\n \"focus-within:ring-2 focus-within:ring-offset-2\":\n !forceShowFocusRing\n },\n className\n )}\n >\n <div className=\"flex relative\">\n <div className=\"relative w-full\">\n <input\n ref={ref}\n id={id}\n value={value}\n onChange={(e) => onChange(e.target.value)}\n onKeyDown={onKeyDown}\n disabled={disabled}\n placeholder={placeholder}\n className={cn(\n \"font-sans text-sm flex w-full file:border-0 file:bg-transparent file:text-sm file:font-medium placeholder:text-secondary text-primary disabled:cursor-not-allowed focus:outline-none bg-transparent\",\n end && \"pr-10\"\n )}\n aria-invalid={error}\n aria-controls={ariaControls}\n aria-activedescendant={ariaActiveDescendant}\n aria-autocomplete={ariaAutocomplete}\n />\n {suggestion && (\n <div className=\"absolute inset-0 text-secondary opacity-40 pointer-events-none text-sm\">\n {value}\n {suggestion.slice(value.length)}\n </div>\n )}\n </div>\n {end && (\n <div className=\"absolute inset-y-0 right-0 flex items-center\">\n {end}\n </div>\n )}\n </div>\n </div>\n {(error && errorMessage) || helperText ? (\n <Text\n variant=\"body-xxs\"\n color={error ? \"danger\" : \"secondary\"}\n className=\"mt-1\"\n >\n {error ? errorMessage : helperText}\n </Text>\n ) : null}\n </div>\n );\n }\n);\n\nAutocompleteInput.displayName = \"AutocompleteInput\";\n","import React, {\n useCallback,\n useMemo,\n useState,\n useRef,\n KeyboardEvent,\n useEffect\n} from \"react\";\nimport * as Popover from \"@radix-ui/react-popover\";\nimport * as Collapsible from \"@radix-ui/react-collapsible\";\nimport { Input } from \"./Input\";\nimport { OptionProps, Option } from \"./Option\";\nimport { Text } from \"./Text\";\nimport { Icon } from \"./Icon\";\nimport { cn } from \"../utils\";\nimport { focusRingStyles } from \"../utils/tailwind\";\nimport { AutocompleteInput } from \"./AutocompleteInput\";\n\nexport type OptionGroup = {\n label: string;\n options: OptionProps[];\n};\n\nexport type ComboboxProps = {\n /** Options can be either a flat array or grouped */\n options: OptionProps[] | OptionGroup[];\n placeholder?: string;\n value?: string;\n onChange: (value: string) => void;\n end?: React.ReactNode;\n className?: string;\n /** Label text for the combobox */\n label?: string;\n /** Additional classes for the label */\n labelClassName?: string;\n /** ID for accessibility */\n id?: string;\n /** Whether the combobox is disabled */\n disabled?: boolean;\n /** Optional container for the portal */\n container?: HTMLElement | null;\n autocomplete?: boolean;\n /** Loading state for async options */\n loading?: boolean;\n /** Error state for async options */\n error?: boolean;\n /** Error message to display */\n errorMessage?: string;\n /** Message to show when no options are available */\n noOptionsMessage?: string;\n};\n\nexport const Combobox = ({\n options,\n placeholder = \"Select an item...\",\n value,\n onChange,\n end,\n className,\n label,\n labelClassName,\n id,\n disabled,\n container,\n autocomplete = false,\n loading = false,\n error = false,\n errorMessage,\n noOptionsMessage\n}: ComboboxProps) => {\n const [open, setOpen] = useState(false);\n const [searchValue, setSearchValue] = useState(\"\");\n const [expandedGroups, setExpandedGroups] = useState<Record<string, boolean>>(\n {}\n );\n const [highlightedIndex, setHighlightedIndex] = useState<number>(-1);\n const listRef = useRef<HTMLDivElement>(null);\n const inputRef = useRef<HTMLInputElement>(null);\n\n const isGrouped = useMemo(\n () => options.length > 0 && \"options\" in options[0],\n [options]\n );\n\n const flatOptions = useMemo(() => {\n if (!options.length) return [];\n if (!isGrouped) return options as OptionProps[];\n return (options as OptionGroup[]).reduce<OptionProps[]>(\n (acc, group) => [...acc, ...group.options],\n []\n );\n }, [isGrouped, options]);\n\n const visibleOptions = useMemo(() => {\n return flatOptions.filter((option) =>\n searchValue && typeof option.label === \"string\"\n ? option.label.toLowerCase().includes(searchValue.toLowerCase())\n : true\n );\n }, [flatOptions, searchValue]);\n\n const filteredGroups = useMemo(() => {\n if (!isGrouped) {\n return visibleOptions.length > 0\n ? [{ label: \"\", options: visibleOptions }]\n : [];\n }\n\n return (options as OptionGroup[])\n .map((group) => ({\n ...group,\n options: group.options.filter((option) =>\n searchValue && typeof option.label === \"string\"\n ? option.label.toLowerCase().includes(searchValue.toLowerCase())\n : true\n )\n }))\n .filter((group) => group.options.length > 0);\n }, [isGrouped, options, searchValue, visibleOptions]);\n\n const selectedOption = useMemo(\n () => flatOptions.find((opt) => opt.value === value),\n [value, flatOptions]\n );\n\n const displayValue = useMemo(() => {\n if (open) return searchValue;\n if (selectedOption) return selectedOption.label?.toString() || \"\";\n return \"\";\n }, [open, searchValue, selectedOption]);\n\n const suggestion = useMemo(() => {\n if (!autocomplete || !searchValue || !open) return \"\";\n const matchingOption = visibleOptions.find(\n (opt) =>\n typeof opt.label === \"string\" &&\n opt.label.toLowerCase().startsWith(searchValue.toLowerCase()) &&\n opt.label.toLowerCase() !== searchValue.toLowerCase()\n );\n return matchingOption?.label?.toString() || \"\";\n }, [autocomplete, searchValue, visibleOptions, open]);\n\n const handleOptionChange = useCallback(\n (optionValue: string) => {\n onChange(optionValue);\n setOpen(false);\n setSearchValue(\"\");\n setHighlightedIndex(-1);\n },\n [onChange]\n );\n\n const toggleGroup = useCallback((groupLabel: string) => {\n setExpandedGroups((prev) => ({\n ...prev,\n [groupLabel]: !prev[groupLabel]\n }));\n }, []);\n\n // Initialize expanded state for all groups\n useEffect(() => {\n if (isGrouped) {\n const initialState = (options as OptionGroup[]).reduce<\n Record<string, boolean>\n >(\n (acc, group) => ({\n ...acc,\n [group.label]: true\n }),\n {}\n );\n setExpandedGroups(initialState);\n }\n }, [isGrouped, options]);\n\n const handleKeyDown = useCallback(\n (event: KeyboardEvent<HTMLInputElement>) => {\n switch (event.key) {\n case \"ArrowDown\":\n event.preventDefault();\n if (event.altKey) {\n setOpen(true);\n } else {\n if (!open) {\n setOpen(true);\n setHighlightedIndex(0);\n } else {\n setHighlightedIndex((prev) =>\n prev < visibleOptions.length - 1 ? prev + 1 : 0\n );\n }\n }\n break;\n\n case \"ArrowUp\":\n event.preventDefault();\n if (event.altKey) {\n setOpen(false);\n } else {\n if (!open) {\n setOpen(true);\n setHighlightedIndex(visibleOptions.length - 1);\n } else {\n setHighlightedIndex((prev) =>\n prev > 0 ? prev - 1 : visibleOptions.length - 1\n );\n }\n }\n break;\n\n case \"PageUp\":\n event.preventDefault();\n if (open) {\n setHighlightedIndex((prev) => Math.max(0, prev - 10));\n }\n break;\n\n case \"PageDown\":\n event.preventDefault();\n if (open) {\n setHighlightedIndex((prev) =>\n Math.min(visibleOptions.length - 1, prev + 10)\n );\n }\n break;\n\n case \"Home\":\n event.preventDefault();\n if (open) {\n setHighlightedIndex(0);\n }\n break;\n\n case \"End\":\n event.preventDefault();\n if (open) {\n setHighlightedIndex(visibleOptions.length - 1);\n }\n break;\n\n case \"Enter\":\n event.preventDefault();\n if (highlightedIndex >= 0 && visibleOptions[highlightedIndex]) {\n handleOptionChange(visibleOptions[highlightedIndex].value);\n } else if (autocomplete && suggestion) {\n const matchingOption = visibleOptions.find(\n (opt) =>\n typeof opt.label === \"string\" &&\n opt.label.toLowerCase().startsWith(searchValue.toLowerCase())\n );\n if (matchingOption) {\n handleOptionChange(matchingOption.value);\n }\n }\n break;\n\n case \"Tab\":\n if (!open) {\n event.preventDefault();\n setOpen(true);\n setHighlightedIndex(0);\n } else if (\n highlightedIndex >= 0 &&\n visibleOptions[highlightedIndex]\n ) {\n event.preventDefault();\n handleOptionChange(visibleOptions[highlightedIndex].value);\n }\n break;\n\n case \"Escape\":\n event.preventDefault();\n setOpen(false);\n setSearchValue(\"\");\n break;\n }\n },\n [\n open,\n highlightedIndex,\n visibleOptions,\n suggestion,\n searchValue,\n handleOptionChange,\n autocomplete\n ]\n );\n\n const handleOptionKeyDown = useCallback(\n (event: KeyboardEvent<HTMLButtonElement>) => {\n switch (event.key) {\n case \"ArrowDown\":\n event.preventDefault();\n setHighlightedIndex((prev) =>\n prev < visibleOptions.length - 1 ? prev + 1 : 0\n );\n break;\n\n case \"ArrowUp\":\n event.preventDefault();\n setHighlightedIndex((prev) =>\n prev > 0 ? prev - 1 : visibleOptions.length - 1\n );\n break;\n\n case \"Enter\":\n case \"Space\":\n event.preventDefault();\n if (highlightedIndex >= 0 && visibleOptions[highlightedIndex]) {\n handleOptionChange(visibleOptions[highlightedIndex].value);\n }\n break;\n\n case \"Escape\":\n event.preventDefault();\n setOpen(false);\n inputRef.current?.focus();\n break;\n\n case \"Tab\":\n event.preventDefault();\n if (highlightedIndex >= 0 && visibleOptions[highlightedIndex]) {\n handleOptionChange(visibleOptions[highlightedIndex].value);\n }\n break;\n }\n },\n [highlightedIndex, visibleOptions, handleOptionChange]\n );\n\n // Keep input focused when dropdown is open\n useEffect(() => {\n if (open) {\n const input = inputRef.current;\n if (input) {\n input.focus({ preventScroll: true });\n // Move cursor to end of text\n const length = input.value.length;\n input.setSelectionRange(length, length);\n }\n }\n }, [open]);\n\n // Reset highlighted index when dropdown closes\n useEffect(() => {\n if (!open) {\n setHighlightedIndex(-1);\n }\n }, [open]);\n\n // Scroll highlighted option into view\n useEffect(() => {\n if (open && highlightedIndex >= 0 && listRef.current) {\n const highlightedOption = listRef.current.querySelector(\n `[id=\"${id}-option-${highlightedIndex}\"]`\n ) as HTMLElement;\n\n if (highlightedOption) {\n highlightedOption.scrollIntoView({\n block: \"nearest\",\n behavior: \"smooth\"\n });\n }\n }\n }, [highlightedIndex, open, id]);\n\n const getSelectedOption = useCallback(\n (option: OptionProps) => {\n if (!open) return value === option.value;\n\n const index = visibleOptions.findIndex(\n (opt) => opt.value === option.value\n );\n\n // If using keyboard navigation, show that highlight\n if (highlightedIndex >= 0) {\n return index === highlightedIndex;\n }\n\n // If no option is highlighted, highlight the first one\n if (highlightedIndex === -1) {\n return index === 0;\n }\n\n return false;\n },\n [open, value, highlightedIndex, visibleOptions]\n );\n\n // Set initial highlight when opening dropdown\n useEffect(() => {\n if (open && highlightedIndex === -1) {\n setHighlightedIndex(0);\n }\n }, [open, highlightedIndex]);\n\n return (\n <Popover.Root\n open={open && !disabled}\n onOpenChange={(isOpen) => {\n if (!disabled) {\n setOpen(isOpen);\n if (!isOpen) {\n setSearchValue(\"\");\n setHighlightedIndex(-1);\n } else {\n const input = inputRef.current;\n if (input) {\n input.focus({ preventScroll: true });\n const length = input.value.length;\n input.setSelectionRange(length, length);\n }\n }\n }\n }}\n >\n <div\n className={`relative w-full font-sans text-secondary ${className}`}\n role=\"combobox\"\n aria-expanded={open}\n aria-haspopup=\"listbox\"\n aria-controls={`${id}-listbox`}\n >\n <Popover.Trigger asChild>\n <button\n type=\"button\"\n className=\"w-full text-left\"\n disabled={disabled}\n >\n {autocomplete ? (\n <AutocompleteInput\n ref={inputRef}\n id={id}\n label={label}\n labelClassName={labelClassName}\n placeholder={placeholder}\n value={displayValue}\n suggestion={suggestion}\n onChange={(value) => {\n setSearchValue(value);\n if (!open) {\n setOpen(true);\n }\n }}\n onKeyDown={handleKeyDown}\n end={end}\n className=\"flex-1\"\n forceShowFocusRing={open}\n disabled={disabled}\n aria-autocomplete=\"list\"\n aria-controls={`${id}-listbox`}\n aria-activedescendant={\n highlightedIndex >= 0\n ? `${id}-option-${highlightedIndex}`\n : undefined\n }\n />\n ) : (\n <Input\n ref={inputRef}\n id={id}\n label={label}\n labelClassName={labelClassName}\n placeholder={placeholder}\n value={displayValue}\n onChange={(e) => {\n setSearchValue(e.target.value);\n if (!open) {\n setOpen(true);\n }\n }}\n onKeyDown={handleKeyDown}\n end={end}\n className=\"flex-1\"\n forceShowFocusRing={open}\n disabled={disabled}\n aria-controls={`${id}-listbox`}\n aria-activedescendant={\n highlightedIndex >= 0\n ? `${id}-option-${highlightedIndex}`\n : undefined\n }\n />\n )}\n </button>\n </Popover.Trigger>\n\n <Popover.Portal container={container}>\n <Popover.Content\n className=\"w-[--radix-popover-trigger-width] p-1 bg-white rounded-md shadow-lg border z-[9999] data-[state=open]:animate-fade-in data-[state=closed]:animate-fade-out overflow-y-scroll outline-none\"\n side=\"bottom\"\n align=\"start\"\n sideOffset={8}\n onOpenAutoFocus={(e) => e.preventDefault()}\n onCloseAutoFocus={(e) => e.preventDefault()}\n onFocusOutside={(e) => e.preventDefault()}\n onInteractOutside={(e) => {\n e.preventDefault();\n setOpen(false);\n setSearchValue(\"\");\n setHighlightedIndex(-1);\n }}\n >\n <div\n ref={listRef}\n className=\"max-h-60 !overflow-y-scroll flex flex-col items-start outline-none\"\n role=\"listbox\"\n id={`${id}-listbox`}\n aria-label={label}\n aria-busy={loading}\n >\n {error ? (\n <div className=\"px-2 py-1.5 text-sm text-red-500\">\n {errorMessage || \"Failed to load options\"}\n </div>\n ) : loading ? (\n <div className=\"px-2 py-1.5 text-sm text-gray-500\">\n Loading...\n </div>\n ) : visibleOptions.length > 0 ? (\n filteredGroups.map((group, groupIndex) => (\n <Collapsible.Root\n key={group.label || groupIndex}\n className=\"w-full\"\n open={expandedGroups[group.label] ?? true}\n onOpenChange={() => group.label && toggleGroup(group.label)}\n >\n {group.label && (\n <Collapsible.Trigger asChild>\n <div\n className=\"w-full flex items-center justify-between px-2 py-1.5 hover:bg-gray-50\"\n tabIndex={-1}\n >\n <Text variant=\"body-default-bold\" color=\"secondary\">\n {group.label}\n </Text>\n <Icon\n name=\"arrow-down\"\n className={cn(\n \"transition-transform\",\n expandedGroups[group.label] && \"rotate-180\"\n )}\n size={16}\n />\n </div>\n </Collapsible.Trigger>\n )}\n <Collapsible.Content className=\"data-[state=open]:animate-accordion-down data-[state=closed]:animate-accordion-up\">\n {group.options.map((option, optionIndex) => {\n const isSelected = getSelectedOption(option);\n return (\n <Option\n key={`${groupIndex}-${optionIndex}`}\n onChange={handleOptionChange}\n onKeyDown={handleOptionKeyDown}\n value={option.value}\n label={option.label}\n className={cn(\"pl-4\")}\n selected={isSelected}\n id={`${id}-option-${optionIndex}`}\n role=\"option\"\n aria-selected={isSelected}\n searchValue={searchValue}\n />\n );\n })}\n </Collapsible.Content>\n </Collapsible.Root>\n ))\n ) : (\n <div className=\"px-2 py-1.5 text-sm text-gray-500\">\n {noOptionsMessage || \"No results found\"}\n </div>\n )}\n </div>\n </Popover.Content>\n </Popover.Portal>\n </div>\n </Popover.Root>\n );\n};\n"]}
1
+ {"version":3,"sources":["../../src/utils/index.ts","../../src/utils/tailwind.ts","../../src/utils/responsive.ts","../../src/components/Icon.tsx","../../src/components/Text.tsx","../../src/components/Input.tsx","../../src/components/AutocompleteInput.tsx","../../src/components/Option.tsx","../../src/components/Badge.tsx","../../src/components/Tooltip.tsx","../../src/components/Combobox.tsx"],"names":["cn","inputs","twMerge","clsx","focusRingStylesCoerced","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","HEADING_ELEMENT_MAP","getElementFromVariant","variant","category","fontWeight","processVariants","variants","typographyClass","Text","as","children","weight","typographyClasses","colorClasses","suggestedElement","baseVariant","Input","y","end","iconName","label","labelClassName","id","forceShowFocusRing","error","errorMessage","helperText","showCharacterCount","maxLength","defaultValue","onChange","disabled","currentValue","setCurrentValue","handleChange","e","newValue","characterCount","showCount","AutocompleteInput","forwardRef","suggestion","onKeyDown","ariaControls","ariaActiveDescendant","ariaAutocomplete","stringToVariant","str","variantKeys","hash","acc","char","index","Badge","B","finalVariant","Tooltip","content","side","align","delayDuration","defaultOpen","controlledOpen","onOpenChange","longPressDuration","isOpen","setIsOpen","useState","longPressTimer","open","handleOpenChange","useCallback","newOpen","handleTouchStart","handleTouchEnd","R","HighlightedText","text","highlight","parts","part","i","Option","onMouseEnter","onMouseLeave","selected","role","ariaSelected","searchValue","tooltip","onClick","badge","Combobox","options","placeholder","container","autocomplete","loading","noOptionsMessage","setOpen","setSearchValue","expandedGroups","setExpandedGroups","highlightedIndex","setHighlightedIndex","listRef","useRef","inputRef","isGrouped","useMemo","flatOptions","group","visibleOptions","option","filteredGroups","selectedOption","opt","displayValue","handleOptionChange","optionValue","toggleGroup","groupLabel","prev","useEffect","initialState","handleKeyDown","event","matchingOption","handleOptionKeyDown","input","length","highlightedOption","getSelectedOption","groupIndex","optionIndex","isSelected"],"mappings":"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","file":"Combobox.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","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","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\nconst COLOR_MAP: Record<IconColors, string> = {\n primary: \"#080808\",\n secondary: \"#666666\",\n white: \"#ffffff\",\n primaryBlue: \"#089CCB\",\n disabled: \"#888888\",\n danger: \"#FF0000\"\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 React from \"react\";\nimport { Typography } from \"../types/tailwind\";\nimport { Breakpoint } from \"../utils/responsive\";\n\ntype TextElement =\n | \"p\"\n | \"span\"\n | \"h1\"\n | \"h2\"\n | \"h3\"\n | \"h4\"\n | \"h5\"\n | \"h6\"\n | \"strong\"\n | \"em\"\n | \"blockquote\"\n | \"pre\"\n | \"code\"\n | \"small\"\n | \"label\"\n | \"a\";\n\n// HTML element mapping type\ntype HTMLElementByTag = {\n p: HTMLParagraphElement;\n span: HTMLSpanElement;\n h1: HTMLHeadingElement;\n h2: HTMLHeadingElement;\n h3: HTMLHeadingElement;\n h4: HTMLHeadingElement;\n h5: HTMLHeadingElement;\n h6: HTMLHeadingElement;\n strong: HTMLElement;\n em: HTMLElement;\n blockquote: HTMLQuoteElement;\n pre: HTMLPreElement;\n code: HTMLElement;\n small: HTMLElement;\n label: HTMLLabelElement;\n a: HTMLAnchorElement;\n};\n\n// HTML props mapping type\ntype HTMLPropsMap = {\n p: React.HTMLAttributes<HTMLParagraphElement>;\n span: React.HTMLAttributes<HTMLSpanElement>;\n h1: React.HTMLAttributes<HTMLHeadingElement>;\n h2: React.HTMLAttributes<HTMLHeadingElement>;\n h3: React.HTMLAttributes<HTMLHeadingElement>;\n h4: React.HTMLAttributes<HTMLHeadingElement>;\n h5: React.HTMLAttributes<HTMLHeadingElement>;\n h6: React.HTMLAttributes<HTMLHeadingElement>;\n strong: React.HTMLAttributes<HTMLElement>;\n em: React.HTMLAttributes<HTMLElement>;\n blockquote: React.HTMLAttributes<HTMLQuoteElement>;\n pre: React.HTMLAttributes<HTMLPreElement>;\n code: React.HTMLAttributes<HTMLElement>;\n small: React.HTMLAttributes<HTMLElement>;\n label: React.LabelHTMLAttributes<HTMLLabelElement>;\n a: Omit<React.AnchorHTMLAttributes<HTMLAnchorElement>, \"color\">;\n};\n\ntype TextColor =\n | \"primary\"\n | \"secondary\"\n | \"white\"\n | \"primary-blue\"\n | \"disabled\"\n | \"danger\"\n | \"inherit\"\n | \"primary-100\";\n\nconst HEADING_ELEMENT_MAP: Record<string, TextElement> = {\n xl: \"h1\",\n lg: \"h1\",\n md: \"h2\",\n sm: \"h3\",\n xs: \"h4\"\n};\n\nconst getElementFromVariant = (variant: TypographyKey): TextElement => {\n const [category, size] = variant.split(\"-\");\n\n if (category === \"heading\") {\n return HEADING_ELEMENT_MAP[size] || \"p\";\n }\n\n if (category === \"label\") {\n return \"label\";\n }\n\n return \"p\";\n};\n\ntype Weight = \"light\" | \"regular\" | \"semibold\" | \"bold\";\n\nconst fontWeight: Record<Weight, string> = {\n light: \"font-light\",\n regular: \"font-regular\",\n semibold: \"font-semibold\",\n bold: \"font-bold\"\n};\n\ntype ResponsiveVariant = TypographyKey | `${Breakpoint}:${TypographyKey}`;\n\ntype TypographyCategory = keyof Typography;\ntype TypographyValue<T extends TypographyCategory> = Extract<\n keyof Typography[T],\n string | number | bigint | boolean | null | undefined\n>;\ntype TypographyKey = {\n [T in TypographyCategory]: `${T}-${TypographyValue<T>}`;\n}[TypographyCategory];\n\n// Update TextProps to use ResponsiveVariant\nexport type TextProps<T extends TextElement = \"p\"> = {\n variant?: ResponsiveVariant | ResponsiveVariant[];\n color?: TextColor;\n as?: T;\n className?: string;\n children: React.ReactNode;\n weight?: Weight;\n} & HTMLPropsMap[T];\n\n// Add helper function to process variants\nconst processVariants = (\n variants: ResponsiveVariant | ResponsiveVariant[] | undefined\n): string => {\n if (!variants) return \"text-body-default\";\n\n const variantArray = Array.isArray(variants) ? variants : [variants];\n\n return variantArray\n .map((variant) => {\n if (variant.includes(\":\")) {\n const [breakpoint, typographyClass] = variant.split(\":\");\n return `${breakpoint}:text-${typographyClass}`;\n }\n return `text-${variant}`;\n })\n .join(\" \");\n};\n\nexport const Text = React.forwardRef(\n <T extends TextElement = \"p\">(\n {\n variant = \"body-default\",\n color = \"primary\",\n as,\n className,\n children,\n weight,\n ...props\n }: TextProps<T>,\n ref: React.ForwardedRef<HTMLElementByTag[T]>\n ) => {\n // Process typography classes with breakpoints\n const typographyClasses = processVariants(variant);\n\n // Get color styles\n const colorClasses = color === \"inherit\" ? \"text-inherit\" : `text-${color}`;\n\n const suggestedElement = React.useMemo(() => {\n const baseVariant =\n typeof variant === \"string\"\n ? variant.split(\":\").pop()!\n : Array.isArray(variant)\n ? variant[0].split(\":\").pop()!\n : \"body-default\";\n return getElementFromVariant(baseVariant as TypographyKey);\n }, [variant]);\n\n const Component = (as || suggestedElement) as T;\n\n return (\n // @ts-expect-error TODO: figure this out\n <Component\n ref={ref}\n className={`\n font-sans antialiased\n ${typographyClasses}\n ${colorClasses}\n ${weight && `!${fontWeight[weight]}`}\n ${className}\n `}\n {...props}\n >\n {children}\n </Component>\n );\n }\n);\n\nText.displayName = \"Text\";\n","import * as React from \"react\";\nimport { cn } from \"../utils\";\nimport { focusRingStyles, focusRingStylesCoerced } from \"../utils/tailwind\";\nimport { IconName } from \"@deckai/icons\";\nimport { Icon, IconProps } from \"./Icon\";\nimport { Text } from \"./Text\";\n\nexport type InputProps = {\n className?: string;\n end?: React.ReactNode;\n /** renders an icon in the end slot */\n iconName?: IconName;\n /** Label text for the input */\n label?: string;\n /** Additional classes for the label */\n labelClassName?: string;\n /** Forces the focus ring to show regardless of focus state */\n forceShowFocusRing?: boolean;\n /** Error state for the input */\n error?: boolean;\n /** Error message to display below the input */\n errorMessage?: string;\n /** Helper text displayed below the input */\n helperText?: string;\n /** Character count display */\n showCharacterCount?: boolean;\n /** Maximum number of characters */\n maxLength?: number;\n} & React.InputHTMLAttributes<HTMLInputElement> &\n Pick<IconProps, \"color\" | \"size\" | \"title\">;\n\nexport const Input = React.forwardRef<HTMLInputElement, InputProps>(\n (\n {\n className,\n end,\n iconName,\n color,\n size,\n title,\n label,\n labelClassName,\n id,\n children,\n forceShowFocusRing,\n error,\n errorMessage,\n helperText,\n showCharacterCount,\n maxLength,\n value,\n defaultValue,\n onChange,\n disabled,\n ...props\n },\n ref\n ) => {\n const [currentValue, setCurrentValue] = React.useState(\n value?.toString() || defaultValue?.toString() || \"\"\n );\n\n // Update internal value when prop changes\n React.useEffect(() => {\n if (value !== undefined) {\n setCurrentValue(value.toString());\n }\n }, [value]);\n\n const handleChange = React.useCallback(\n (e: React.ChangeEvent<HTMLInputElement>) => {\n const newValue = e.target.value;\n setCurrentValue(newValue);\n onChange?.(e);\n },\n [onChange]\n );\n\n const characterCount = currentValue.length;\n const showCount = showCharacterCount || !!maxLength;\n\n return (\n <div className=\"gap-1 flex flex-col\">\n {label && (\n <Text\n variant=\"label-default\"\n htmlFor={id}\n as=\"label\"\n color={error ? \"danger\" : \"primary\"}\n className={cn(labelClassName)}\n >\n {label}\n </Text>\n )}\n <div\n className={cn(\n \"relative flex flex-col gap-2 w-full rounded-lg border bg-background-0 px-3 md:py-3 py-2 text-secondary transition-colors duration-150\",\n !error && !forceShowFocusRing && \"border-secondary-50\",\n error && \"border-tertiary-10\",\n disabled && \"cursor-not-allowed opacity-50\",\n \"focus-within:ring-2 focus-within:ring-primary-100\",\n forceShowFocusRing && focusRingStylesCoerced\n )}\n >\n <div className=\"flex relative\">\n <input\n ref={ref}\n id={id}\n className={cn(\n \"font-sans text-sm flex w-full file:border-0 file:bg-transparent file:text-sm file:font-medium file:text-foreground placeholder:text-secondary text-primary disabled:cursor-not-allowed focus:outline-none rounded-lg\",\n end && \"pr-10\",\n className\n )}\n value={currentValue}\n maxLength={maxLength}\n onChange={handleChange}\n aria-invalid={error}\n disabled={disabled}\n {...props}\n />\n {(end || iconName) && (\n <div className=\"absolute inset-y-0 right-0 flex items-center\">\n {iconName ? (\n <Icon\n name={iconName}\n color={error ? \"danger\" : \"secondary\"}\n size={size}\n title={title}\n />\n ) : (\n end\n )}\n </div>\n )}\n </div>\n {children}\n </div>\n <div className=\"flex justify-between gap-2\">\n {(error && errorMessage) || helperText ? (\n <Text\n variant=\"body-xxs\"\n color={error ? \"danger\" : \"secondary\"}\n className=\"mt-1\"\n >\n {error ? errorMessage : helperText}\n </Text>\n ) : null}\n {showCount && (\n <Text\n variant=\"body-xxs\"\n color={error ? \"danger\" : \"secondary\"}\n className=\"text-right mt-1\"\n >\n <Text\n variant=\"body-xxs\"\n as=\"span\"\n color=\"primary-100\"\n className=\"font-bold\"\n >\n {characterCount}\n </Text>\n {maxLength && `/${maxLength}`} characters\n </Text>\n )}\n </div>\n </div>\n );\n }\n);\n","import React, { forwardRef, KeyboardEvent } from \"react\";\nimport { cn } from \"../utils\";\nimport { Input } from \"./Input\";\nimport type { InputProps } from \"./Input\";\n\nexport type AutocompleteInputProps = {\n value: string;\n suggestion: string;\n onChange: (value: string) => void;\n onKeyDown?: (event: KeyboardEvent<HTMLInputElement>) => void;\n \"aria-controls\"?: string;\n \"aria-activedescendant\"?: string;\n \"aria-autocomplete\"?: \"none\" | \"inline\" | \"list\" | \"both\";\n} & Omit<InputProps, \"value\" | \"onChange\" | \"onKeyDown\">;\n\nexport const AutocompleteInput = forwardRef<\n HTMLInputElement,\n AutocompleteInputProps\n>(\n (\n {\n value,\n suggestion,\n onChange,\n onKeyDown,\n className,\n \"aria-controls\": ariaControls,\n \"aria-activedescendant\": ariaActiveDescendant,\n \"aria-autocomplete\": ariaAutocomplete,\n ...props\n },\n ref\n ) => {\n return (\n <div className=\"relative w-full\">\n <Input\n ref={ref}\n value={value}\n onChange={(e) => onChange(e.target.value)}\n onKeyDown={onKeyDown}\n className={cn(\"bg-transparent\", className)}\n aria-controls={ariaControls}\n aria-activedescendant={ariaActiveDescendant}\n aria-autocomplete={ariaAutocomplete}\n {...props}\n />\n {suggestion && (\n <div className=\"absolute inset-0 top-6 flex items-center px-3 md:py-3 py-2 text-secondary opacity-40 pointer-events-none text-sm\">\n {value}\n {suggestion.slice(value.length)}\n </div>\n )}\n </div>\n );\n }\n);\n\nAutocompleteInput.displayName = \"AutocompleteInput\";\n","import React, { KeyboardEvent } from \"react\";\nimport { cn } from \"../utils\";\nimport { Badge } from \"./Badge\";\nimport { Text } from \"./Text\";\nimport { Tooltip } from \"./Tooltip\";\n\nexport type OptionProps = {\n label: React.ReactNode;\n value: string;\n /** Optional color override for specific items like \"Logout\" in red */\n color?: \"default\" | \"danger\";\n /** Optional disabled state */\n disabled?: boolean;\n onChange?: (value: string) => void;\n onKeyDown?: (event: KeyboardEvent<HTMLButtonElement>) => void;\n onMouseEnter?: () => void;\n onMouseLeave?: () => void;\n selected?: boolean;\n className?: string;\n /** ID for accessibility */\n id?: string;\n /** ARIA role */\n role?: string;\n /** ARIA selected state */\n \"aria-selected\"?: boolean;\n /** Current search value for highlighting matches */\n searchValue?: string;\n /** Optional tooltip content */\n tooltip?: React.ReactNode;\n onClick?: () => void;\n badge?: React.ReactNode;\n};\n\nconst HighlightedText = ({\n text,\n highlight\n}: {\n text: string;\n highlight: string;\n}) => {\n if (!highlight) return <>{text}</>;\n\n const parts = text.split(new RegExp(`(${highlight})`, \"i\"));\n return (\n <>\n {parts.map((part, i) =>\n part.toLowerCase() === highlight.toLowerCase() ? (\n <span key={i} className=\"font-bold\">\n {part}\n </span>\n ) : (\n part\n )\n )}\n </>\n );\n};\n\nexport const Option = React.forwardRef<HTMLButtonElement, OptionProps>(\n (\n {\n value,\n label,\n onChange,\n onKeyDown,\n onMouseEnter,\n onMouseLeave,\n selected,\n color,\n disabled,\n className,\n id,\n role,\n \"aria-selected\": ariaSelected,\n searchValue = \"\",\n tooltip,\n onClick,\n badge\n },\n ref\n ) => {\n const content = (\n <button\n ref={ref}\n type=\"button\"\n id={id}\n role={role}\n aria-selected={ariaSelected}\n disabled={disabled}\n className={cn(\n \"relative w-full text-left px-2 py-1.5 text-sm rounded outline-none\",\n \"cursor-pointer hover:bg-gray-100\",\n \"disabled:opacity-50 disabled:cursor-not-allowed\",\n selected && \"bg-gray-100\",\n \"flex items-center gap-2\",\n className\n )}\n onClick={() => {\n onChange?.(value);\n onClick?.();\n }}\n onKeyDown={onKeyDown}\n onMouseEnter={onMouseEnter}\n onMouseLeave={onMouseLeave}\n >\n <Text\n variant=\"body-default-medium\"\n color={color === \"danger\" ? \"danger\" : \"inherit\"}\n >\n {typeof label === \"string\" ? (\n <HighlightedText text={label} highlight={searchValue} />\n ) : (\n label\n )}\n </Text>\n {badge && <Badge>{badge}</Badge>}\n </button>\n );\n return tooltip ? <Tooltip content={tooltip}>{content}</Tooltip> : content;\n }\n);\n","import { IconName } from \"@deckai/icons\";\nimport * as React from \"react\";\nimport { cn } from \"../utils\";\nimport { Icon } from \"./Icon\";\nimport { Text } from \"./Text\";\n\nexport type BadgeProps = {\n variant?: \"pink\" | \"orange\" | \"green\" | \"purple\";\n iconName?: IconName;\n} & React.HTMLAttributes<HTMLSpanElement>;\n\nconst variants = {\n pink: \"bg-tertiary-5\",\n orange: \"bg-tertiary-15\",\n green: \"bg-tertiary-25\",\n purple: \"bg-secondary-300\"\n};\n\nconst stringToVariant = (str: string): keyof typeof variants => {\n const variantKeys = Object.keys(variants) as Array<keyof typeof variants>;\n // Let's log some values to understand what's happening\n const hash = str\n .split(\"\")\n .reduce((acc, char) => char.charCodeAt(0) + ((acc << 5) - acc), 0);\n\n const index = Math.abs(hash) % variantKeys.length;\n const selectedVariant = variantKeys[index];\n\n return selectedVariant;\n};\n\nexport const Badge = React.forwardRef<HTMLSpanElement, BadgeProps>(\n ({ className, variant, iconName, children, ...props }, ref) => {\n const finalVariant =\n variant ||\n (typeof children === \"string\" ? stringToVariant(children) : \"pink\");\n return (\n <span\n ref={ref}\n className={cn(\n \"inline-flex items-center gap-2\",\n \"rounded px-2 py-1.5\",\n \"text-sm font-medium\",\n variants[finalVariant],\n className\n )}\n {...props}\n >\n {iconName && <Icon size={16} name={iconName} />}\n <Text variant=\"body-xxs-semibold\" className=\"mt-0.5\">\n {children}\n </Text>\n </span>\n );\n }\n);\n\nBadge.displayName = \"Badge\";\n","import * as TooltipPrimitive from \"@radix-ui/react-tooltip\";\nimport * as React from \"react\";\nimport { useCallback, useState } from \"react\";\nimport { cn } from \"../utils\";\nimport { Text } from \"./Text\";\nexport interface TooltipProps {\n content: React.ReactNode;\n children: React.ReactNode;\n side?: \"top\" | \"right\" | \"bottom\" | \"left\";\n align?: \"start\" | \"center\" | \"end\";\n className?: string;\n delayDuration?: number;\n defaultOpen?: boolean;\n open?: boolean;\n onOpenChange?: (open: boolean) => void;\n /** Duration in ms for long press on mobile devices */\n longPressDuration?: number;\n}\n\nexport const Tooltip = ({\n content,\n children,\n side = \"bottom\",\n align = \"center\",\n className,\n delayDuration = 200,\n defaultOpen,\n open: controlledOpen,\n onOpenChange,\n longPressDuration = 500\n}: TooltipProps) => {\n const [isOpen, setIsOpen] = useState(defaultOpen || false);\n let longPressTimer: Timer | null = null;\n\n const open = controlledOpen ?? isOpen;\n const handleOpenChange = useCallback(\n (newOpen: boolean) => {\n if (!controlledOpen) {\n setIsOpen(newOpen);\n }\n onOpenChange?.(newOpen);\n },\n [controlledOpen, onOpenChange]\n );\n\n const handleTouchStart = useCallback(() => {\n const timer = setTimeout(() => {\n handleOpenChange(true);\n }, longPressDuration);\n longPressTimer = timer;\n }, [handleOpenChange, longPressDuration]);\n\n const handleTouchEnd = useCallback(() => {\n if (longPressTimer) {\n clearTimeout(longPressTimer);\n longPressTimer = null;\n }\n // Keep tooltip open for a brief moment after touch\n setTimeout(() => handleOpenChange(false), 1500);\n }, [longPressTimer, handleOpenChange]);\n\n return (\n <TooltipPrimitive.Provider delayDuration={delayDuration}>\n <TooltipPrimitive.Root open={open} onOpenChange={handleOpenChange}>\n <TooltipPrimitive.Trigger asChild>\n <span\n tabIndex={0}\n onTouchStart={handleTouchStart}\n onTouchEnd={handleTouchEnd}\n onTouchCancel={handleTouchEnd}\n >\n {children}\n </span>\n </TooltipPrimitive.Trigger>\n <TooltipPrimitive.Portal>\n <TooltipPrimitive.Content\n side={side}\n align={align}\n sideOffset={4}\n className={cn(\n \"z-50 overflow-hidden rounded-lg\",\n \"bg-black px-3 py-1.5\",\n \"text-xs text-white\",\n \"animate-in fade-in-0 zoom-in-95\",\n \"data-[state=closed]:animate-out data-[state=closed]:fade-out-0\",\n \"data-[side=bottom]:slide-in-from-top-2\",\n \"data-[side=top]:slide-in-from-bottom-2\",\n \"select-none\",\n \"max-w-60\",\n \"touch-none\", // Prevent touch events from interfering with scrolling\n className\n )}\n >\n {typeof content === \"string\" ? (\n <Text variant=\"body-default-medium\" color=\"white\">\n {content}\n </Text>\n ) : (\n content\n )}\n <TooltipPrimitive.Arrow\n className=\"fill-text-primary\"\n width={10}\n height={5}\n />\n </TooltipPrimitive.Content>\n </TooltipPrimitive.Portal>\n </TooltipPrimitive.Root>\n </TooltipPrimitive.Provider>\n );\n};\n","import * as Collapsible from \"@radix-ui/react-collapsible\";\nimport * as Popover from \"@radix-ui/react-popover\";\nimport React, {\n KeyboardEvent,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState\n} from \"react\";\nimport { cn } from \"../utils\";\nimport { AutocompleteInput } from \"./AutocompleteInput\";\nimport { Icon } from \"./Icon\";\nimport { Input } from \"./Input\";\nimport { Option, OptionProps } from \"./Option\";\nimport { Text } from \"./Text\";\n\nexport type OptionGroup = {\n label: string;\n options: OptionProps[];\n};\n\nexport type ComboboxProps = {\n /** Options can be either a flat array or grouped */\n options: OptionProps[] | OptionGroup[];\n placeholder?: string;\n value?: string;\n onChange: (value: string) => void;\n end?: React.ReactNode;\n className?: string;\n /** Label text for the combobox */\n label?: string;\n /** Additional classes for the label */\n labelClassName?: string;\n /** ID for accessibility */\n id?: string;\n /** Whether the combobox is disabled */\n disabled?: boolean;\n /** Optional container for the portal */\n container?: HTMLElement | null;\n autocomplete?: boolean;\n /** Loading state for async options */\n loading?: boolean;\n /** Error state for async options */\n error?: boolean;\n /** Error message to display */\n errorMessage?: string;\n /** Message to show when no options are available */\n noOptionsMessage?: string;\n};\n\nexport const Combobox = ({\n options,\n placeholder = \"Select an item...\",\n value,\n onChange,\n end,\n className,\n label,\n labelClassName,\n id,\n disabled,\n container,\n autocomplete = false,\n loading = false,\n error = false,\n errorMessage,\n noOptionsMessage\n}: ComboboxProps) => {\n const [open, setOpen] = useState(false);\n const [searchValue, setSearchValue] = useState(\"\");\n const [expandedGroups, setExpandedGroups] = useState<Record<string, boolean>>(\n {}\n );\n const [highlightedIndex, setHighlightedIndex] = useState<number>(-1);\n const listRef = useRef<HTMLDivElement>(null);\n const inputRef = useRef<HTMLInputElement>(null);\n\n const isGrouped = useMemo(\n () => options.length > 0 && \"options\" in options[0],\n [options]\n );\n\n const flatOptions = useMemo(() => {\n if (!options.length) return [];\n if (!isGrouped) return options as OptionProps[];\n return (options as OptionGroup[]).reduce<OptionProps[]>(\n (acc, group) => [...acc, ...group.options],\n []\n );\n }, [isGrouped, options]);\n\n const visibleOptions = useMemo(() => {\n return flatOptions.filter((option) =>\n searchValue && typeof option.label === \"string\"\n ? option.label.toLowerCase().includes(searchValue.toLowerCase())\n : true\n );\n }, [flatOptions, searchValue]);\n\n const filteredGroups = useMemo(() => {\n if (!isGrouped) {\n return visibleOptions.length > 0\n ? [{ label: \"\", options: visibleOptions }]\n : [];\n }\n\n return (options as OptionGroup[])\n .map((group) => ({\n ...group,\n options: group.options.filter((option) =>\n searchValue && typeof option.label === \"string\"\n ? option.label.toLowerCase().includes(searchValue.toLowerCase())\n : true\n )\n }))\n .filter((group) => group.options.length > 0);\n }, [isGrouped, options, searchValue, visibleOptions]);\n\n const selectedOption = useMemo(\n () => flatOptions.find((opt) => opt.value === value),\n [value, flatOptions]\n );\n\n const displayValue = useMemo(() => {\n if (open) return searchValue;\n if (selectedOption) return selectedOption.label?.toString() || \"\";\n return \"\";\n }, [open, searchValue, selectedOption]);\n\n const suggestion = useMemo(() => {\n if (!autocomplete || !searchValue || !open) return \"\";\n const matchingOption = visibleOptions.find(\n (opt) =>\n typeof opt.label === \"string\" &&\n opt.label.toLowerCase().startsWith(searchValue.toLowerCase()) &&\n opt.label.toLowerCase() !== searchValue.toLowerCase()\n );\n return matchingOption?.label?.toString() || \"\";\n }, [autocomplete, searchValue, visibleOptions, open]);\n\n const handleOptionChange = useCallback(\n (optionValue: string) => {\n onChange(optionValue);\n setOpen(false);\n setSearchValue(\"\");\n setHighlightedIndex(-1);\n },\n [onChange]\n );\n\n const toggleGroup = useCallback((groupLabel: string) => {\n setExpandedGroups((prev) => ({\n ...prev,\n [groupLabel]: !prev[groupLabel]\n }));\n }, []);\n\n // Initialize expanded state for all groups\n useEffect(() => {\n if (isGrouped) {\n const initialState = (options as OptionGroup[]).reduce<\n Record<string, boolean>\n >(\n (acc, group) => ({\n ...acc,\n [group.label]: true\n }),\n {}\n );\n setExpandedGroups(initialState);\n }\n }, [isGrouped, options]);\n\n const handleKeyDown = useCallback(\n (event: KeyboardEvent<HTMLInputElement>) => {\n switch (event.key) {\n case \"ArrowDown\":\n event.preventDefault();\n if (event.altKey) {\n setOpen(true);\n } else {\n if (!open) {\n setOpen(true);\n setHighlightedIndex(0);\n } else {\n setHighlightedIndex((prev) =>\n prev < visibleOptions.length - 1 ? prev + 1 : 0\n );\n }\n }\n break;\n\n case \"ArrowUp\":\n event.preventDefault();\n if (event.altKey) {\n setOpen(false);\n } else {\n if (!open) {\n setOpen(true);\n setHighlightedIndex(visibleOptions.length - 1);\n } else {\n setHighlightedIndex((prev) =>\n prev > 0 ? prev - 1 : visibleOptions.length - 1\n );\n }\n }\n break;\n\n case \"PageUp\":\n event.preventDefault();\n if (open) {\n setHighlightedIndex((prev) => Math.max(0, prev - 10));\n }\n break;\n\n case \"PageDown\":\n event.preventDefault();\n if (open) {\n setHighlightedIndex((prev) =>\n Math.min(visibleOptions.length - 1, prev + 10)\n );\n }\n break;\n\n case \"Home\":\n event.preventDefault();\n if (open) {\n setHighlightedIndex(0);\n }\n break;\n\n case \"End\":\n event.preventDefault();\n if (open) {\n setHighlightedIndex(visibleOptions.length - 1);\n }\n break;\n\n case \"Enter\":\n event.preventDefault();\n if (highlightedIndex >= 0 && visibleOptions[highlightedIndex]) {\n handleOptionChange(visibleOptions[highlightedIndex].value);\n } else if (autocomplete && suggestion) {\n const matchingOption = visibleOptions.find(\n (opt) =>\n typeof opt.label === \"string\" &&\n opt.label.toLowerCase().startsWith(searchValue.toLowerCase())\n );\n if (matchingOption) {\n handleOptionChange(matchingOption.value);\n }\n }\n break;\n\n case \"Tab\":\n if (!open) {\n event.preventDefault();\n setOpen(true);\n setHighlightedIndex(0);\n } else if (\n highlightedIndex >= 0 &&\n visibleOptions[highlightedIndex]\n ) {\n event.preventDefault();\n handleOptionChange(visibleOptions[highlightedIndex].value);\n }\n break;\n\n case \"Escape\":\n event.preventDefault();\n setOpen(false);\n setSearchValue(\"\");\n break;\n }\n },\n [\n open,\n highlightedIndex,\n visibleOptions,\n suggestion,\n searchValue,\n handleOptionChange,\n autocomplete\n ]\n );\n\n const handleOptionKeyDown = useCallback(\n (event: KeyboardEvent<HTMLButtonElement>) => {\n switch (event.key) {\n case \"ArrowDown\":\n event.preventDefault();\n setHighlightedIndex((prev) =>\n prev < visibleOptions.length - 1 ? prev + 1 : 0\n );\n break;\n\n case \"ArrowUp\":\n event.preventDefault();\n setHighlightedIndex((prev) =>\n prev > 0 ? prev - 1 : visibleOptions.length - 1\n );\n break;\n\n case \"Enter\":\n case \"Space\":\n event.preventDefault();\n if (highlightedIndex >= 0 && visibleOptions[highlightedIndex]) {\n handleOptionChange(visibleOptions[highlightedIndex].value);\n }\n break;\n\n case \"Escape\":\n event.preventDefault();\n setOpen(false);\n inputRef.current?.focus();\n break;\n\n case \"Tab\":\n event.preventDefault();\n if (highlightedIndex >= 0 && visibleOptions[highlightedIndex]) {\n handleOptionChange(visibleOptions[highlightedIndex].value);\n }\n break;\n }\n },\n [highlightedIndex, visibleOptions, handleOptionChange]\n );\n\n // Keep input focused when dropdown is open\n useEffect(() => {\n if (open) {\n const input = inputRef.current;\n if (input) {\n input.focus({ preventScroll: true });\n // Move cursor to end of text\n const length = input.value.length;\n input.setSelectionRange(length, length);\n }\n }\n }, [open]);\n\n // Reset highlighted index when dropdown closes\n useEffect(() => {\n if (!open) {\n setHighlightedIndex(-1);\n }\n }, [open]);\n\n // Scroll highlighted option into view\n useEffect(() => {\n if (open && highlightedIndex >= 0 && listRef.current) {\n const highlightedOption = listRef.current.querySelector(\n `[id=\"${id}-option-${highlightedIndex}\"]`\n ) as HTMLElement;\n\n if (highlightedOption) {\n highlightedOption.scrollIntoView({\n block: \"nearest\",\n behavior: \"smooth\"\n });\n }\n }\n }, [highlightedIndex, open, id]);\n\n const getSelectedOption = useCallback(\n (option: OptionProps) => {\n if (!open) return value === option.value;\n\n const index = visibleOptions.findIndex(\n (opt) => opt.value === option.value\n );\n\n // If using keyboard navigation, show that highlight\n if (highlightedIndex >= 0) {\n return index === highlightedIndex;\n }\n\n // If no option is highlighted, highlight the first one\n if (highlightedIndex === -1) {\n return index === 0;\n }\n\n return false;\n },\n [open, value, highlightedIndex, visibleOptions]\n );\n\n // Set initial highlight when opening dropdown\n useEffect(() => {\n if (open && highlightedIndex === -1) {\n setHighlightedIndex(0);\n }\n }, [open, highlightedIndex]);\n\n return (\n <Popover.Root\n open={open && !disabled}\n onOpenChange={(isOpen) => {\n if (!disabled) {\n setOpen(isOpen);\n if (!isOpen) {\n setSearchValue(\"\");\n setHighlightedIndex(-1);\n } else {\n const input = inputRef.current;\n if (input) {\n input.focus({ preventScroll: true });\n const length = input.value.length;\n input.setSelectionRange(length, length);\n }\n }\n }\n }}\n >\n <div\n className={`relative w-full font-sans text-secondary ${className}`}\n role=\"combobox\"\n aria-expanded={open}\n aria-haspopup=\"listbox\"\n aria-controls={`${id}-listbox`}\n >\n <Popover.Trigger asChild>\n <button\n type=\"button\"\n className=\"w-full text-left\"\n disabled={disabled}\n >\n {autocomplete ? (\n <AutocompleteInput\n ref={inputRef}\n id={id}\n label={label}\n labelClassName={labelClassName}\n placeholder={placeholder}\n value={displayValue}\n suggestion={suggestion}\n onChange={(value) => {\n setSearchValue(value);\n if (!open) {\n setOpen(true);\n }\n }}\n onKeyDown={handleKeyDown}\n end={end}\n className={cn(\"flex-1\", className)}\n forceShowFocusRing={open}\n disabled={disabled}\n aria-autocomplete=\"list\"\n aria-controls={`${id}-listbox`}\n aria-activedescendant={\n highlightedIndex >= 0\n ? `${id}-option-${highlightedIndex}`\n : undefined\n }\n />\n ) : (\n <Input\n ref={inputRef}\n id={id}\n label={label}\n labelClassName={labelClassName}\n placeholder={placeholder}\n value={displayValue}\n onChange={(e) => {\n setSearchValue(e.target.value);\n if (!open) {\n setOpen(true);\n }\n }}\n onKeyDown={handleKeyDown}\n end={end}\n className={cn(\"flex-1\", className)}\n forceShowFocusRing={open}\n disabled={disabled}\n aria-controls={`${id}-listbox`}\n aria-activedescendant={\n highlightedIndex >= 0\n ? `${id}-option-${highlightedIndex}`\n : undefined\n }\n />\n )}\n </button>\n </Popover.Trigger>\n\n <Popover.Portal container={container}>\n <Popover.Content\n className=\"w-[--radix-popover-trigger-width] p-1 bg-white rounded-md shadow-lg border z-[9999] data-[state=open]:animate-fade-in data-[state=closed]:animate-fade-out outline-none\"\n side=\"bottom\"\n align=\"start\"\n sideOffset={4}\n onOpenAutoFocus={(e) => e.preventDefault()}\n onCloseAutoFocus={(e) => e.preventDefault()}\n onFocusOutside={(e) => e.preventDefault()}\n onInteractOutside={(e) => {\n e.preventDefault();\n setOpen(false);\n setSearchValue(\"\");\n setHighlightedIndex(-1);\n }}\n >\n <div\n ref={listRef}\n className=\"max-h-60 overflow-y-auto flex flex-col items-start outline-none\"\n role=\"listbox\"\n id={`${id}-listbox`}\n aria-label={label}\n aria-busy={loading}\n >\n {error ? (\n <div className=\"px-2 py-1.5 text-sm text-red-500\">\n {errorMessage || \"Failed to load options\"}\n </div>\n ) : loading ? (\n <div className=\"px-2 py-1.5 text-sm text-gray-500\">\n Loading...\n </div>\n ) : visibleOptions.length > 0 ? (\n filteredGroups.map((group, groupIndex) => (\n <Collapsible.Root\n key={group.label || groupIndex}\n className=\"w-full\"\n open={expandedGroups[group.label] ?? true}\n onOpenChange={() => group.label && toggleGroup(group.label)}\n >\n {group.label && (\n <Collapsible.Trigger asChild>\n <div\n className=\"w-full flex items-center justify-between px-2 py-1.5 hover:bg-gray-50\"\n tabIndex={-1}\n >\n <Text variant=\"body-default-bold\" color=\"secondary\">\n {group.label}\n </Text>\n <Icon\n name=\"arrow-down\"\n className={cn(\n \"transition-transform\",\n expandedGroups[group.label] && \"rotate-180\"\n )}\n size={16}\n />\n </div>\n </Collapsible.Trigger>\n )}\n <Collapsible.Content className=\"data-[state=open]:animate-accordion-down data-[state=closed]:animate-accordion-up\">\n {group.options.map((option, optionIndex) => {\n const isSelected = getSelectedOption(option);\n return (\n <Option\n key={`${groupIndex}-${optionIndex}`}\n onChange={handleOptionChange}\n onKeyDown={handleOptionKeyDown}\n value={option.value}\n label={option.label}\n className={cn(\"pl-4\")}\n selected={isSelected}\n id={`${id}-option-${optionIndex}`}\n role=\"option\"\n aria-selected={isSelected}\n searchValue={searchValue}\n />\n );\n })}\n </Collapsible.Content>\n </Collapsible.Root>\n ))\n ) : (\n <div className=\"px-2 py-1.5 text-sm text-gray-500\">\n {noOptionsMessage || \"No results found\"}\n </div>\n )}\n </div>\n </Popover.Content>\n </Popover.Portal>\n </div>\n </Popover.Root>\n );\n};\n"]}
@@ -1,8 +1,8 @@
1
- 'use strict';var i=require('react'),clsx=require('clsx'),tailwindMerge=require('tailwind-merge');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var i__default=/*#__PURE__*/_interopDefault(i);var c=({icon:e,size:t=40,className:r})=>{let o=e.match(/<svg[^>]*>([\s\S]*?)<\/svg>/);if(!o)return i__default.default.createElement("div",{style:{width:t,height:t,display:"flex",alignItems:"center",justifyContent:"center"},className:r});let n=e.match(/<svg([^>]*)>/),a=(n?n[1]:"").match(/viewBox=["']([^"']*)["']/),l=a?a[1]:"0 0 40 40";return i__default.default.createElement("div",{style:{width:t,height:t,display:"flex",alignItems:"center",justifyContent:"center"},className:r},i__default.default.createElement("svg",{width:"100%",height:"100%",viewBox:l,preserveAspectRatio:"xMidYMid meet",dangerouslySetInnerHTML:{__html:o[1]}}))};c.displayName="IconRenderer";var M={xl:"h1",lg:"h1",md:"h2",sm:"h3",xs:"h4"},L=e=>{let[t,r]=e.split("-");return t==="heading"?M[r]||"p":t==="label"?"label":"p"},x={light:"font-light",regular:"font-regular",semibold:"font-semibold",bold:"font-bold"},E=e=>e?(Array.isArray(e)?e:[e]).map(r=>{if(r.includes(":")){let[o,n]=r.split(":");return `${o}:text-${n}`}return `text-${r}`}).join(" "):"text-body-default",y=i__default.default.forwardRef(({variant:e="body-default",color:t="primary",as:r,className:o,children:n,weight:s,...a},l)=>{let u=E(e),b=t==="inherit"?"text-inherit":`text-${t}`,f=i__default.default.useMemo(()=>{let H=typeof e=="string"?e.split(":").pop():Array.isArray(e)?e[0].split(":").pop():"body-default";return L(H)},[e]);return i__default.default.createElement(r||f,{ref:l,className:`
1
+ 'use strict';var c=require('react'),clsx=require('clsx'),tailwindMerge=require('tailwind-merge');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var c__default=/*#__PURE__*/_interopDefault(c);function a(...e){return tailwindMerge.twMerge(clsx.clsx(e))}var g={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]"},f={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]"}},h=e=>String(e),w=(e,s=24)=>{let t=[],r={};if(e===undefined){let p=h(s);p?t.push(g[p]):(r.height=`${s}px`,r.width=`${s}px`);}if(typeof e=="number"){let p=h(e);p?t.push(g[p]):(r.height=`${e}px`,r.width=`${e}px`);}if(Array.isArray(e)){let p=h(s),n=[p&&g[p]||`h-[${s}px] w-[${s}px]`];e.forEach(o=>{if(typeof o=="string"){let[i,l]=o.split(":"),x=parseInt(l,10),m=h(x);t.push(m&&f[i]?.[m]||`${i}:h-[${x}px] ${i}:w-[${x}px]`);}}),t.push(...n);}if(typeof e=="string"){let[p,n]=e.split(":"),o=parseInt(n,10),i=h(o);t.push(i&&f[p]?.[i]||`${p}:h-[${o}px] ${p}:w-[${o}px]`);}return {responsiveSizeClasses:t.join(" "),responsiveSizeStyles:r}};var y=({icon:e,size:s=40,className:t})=>{let r=e.match(/<svg[^>]*>([\s\S]*?)<\/svg>/),{responsiveSizeClasses:p,responsiveSizeStyles:n}=w(s,40);if(!r)return c__default.default.createElement("div",{style:{display:"flex",alignItems:"center",justifyContent:"center",...n},className:a(p,t)});let o=e.match(/<svg([^>]*)>/),l=(o?o[1]:"").match(/viewBox=["']([^"']*)["']/),x=l?l[1]:"0 0 40 40";return c__default.default.createElement("div",{style:{display:"flex",alignItems:"center",justifyContent:"center",...n},className:a(p,t)},c__default.default.createElement("svg",{width:"100%",height:"100%",viewBox:x,preserveAspectRatio:"xMidYMid meet",dangerouslySetInnerHTML:{__html:r[1]}}))};y.displayName="IconRenderer";var R={xl:"h1",lg:"h1",md:"h2",sm:"h3",xs:"h4"},v=e=>{let[s,t]=e.split("-");return s==="heading"?R[t]||"p":s==="label"?"label":"p"},S={light:"font-light",regular:"font-regular",semibold:"font-semibold",bold:"font-bold"},A=e=>e?(Array.isArray(e)?e:[e]).map(t=>{if(t.includes(":")){let[r,p]=t.split(":");return `${r}:text-${p}`}return `text-${t}`}).join(" "):"text-body-default",T=c__default.default.forwardRef(({variant:e="body-default",color:s="primary",as:t,className:r,children:p,weight:n,...o},i)=>{let l=A(e),x=s==="inherit"?"text-inherit":`text-${s}`,m=c__default.default.useMemo(()=>{let L=typeof e=="string"?e.split(":").pop():Array.isArray(e)?e[0].split(":").pop():"body-default";return v(L)},[e]);return c__default.default.createElement(t||m,{ref:i,className:`
2
2
  font-sans antialiased
3
- ${u}
4
- ${b}
5
- ${s&&`!${x[s]}`}
6
- ${o}
7
- `,...a},n)});y.displayName="Text";function T(...e){return tailwindMerge.twMerge(clsx.clsx(e))}var h="focus-visible:outline-none focus-visible:border-2 focus-visible:border-primary-100";var g=({children:e,color:t="inherit",variant:r="body-default-semibold",href:o,className:n,...s})=>i__default.default.createElement(y,{variant:r,color:t},i__default.default.createElement("a",{href:o,className:T("hover:opacity-80 transition-all ease-in-out active:scale-95 hover:underline",h,n),...s},e));var D=({icon:e,children:t,href:r,...o})=>i__default.default.createElement("div",{className:"row gap-2 flex items-center"},i__default.default.createElement("div",{className:"bg-secondary-400 rounded-full p-2.5 items-center justify-center"},i__default.default.createElement(c,{icon:e,size:18,className:"text-primary"})),i__default.default.createElement(g,{className:"hover:underline",href:r,...o,variant:["body-default-semibold","md:body-default-semibold"]},t));exports.ContactItem=D;//# sourceMappingURL=ContactItem.cjs.map
3
+ ${l}
4
+ ${x}
5
+ ${n&&`!${S[n]}`}
6
+ ${r}
7
+ `,...o},p)});T.displayName="Text";var M="focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-primary-100";var H=({children:e,color:s="inherit",variant:t="body-default-semibold",href:r,className:p,...n})=>c__default.default.createElement(T,{variant:t,color:s},c__default.default.createElement("a",{href:r,className:a("hover:opacity-80 transition-all ease-in-out active:scale-95 hover:underline",M,p),...n},e));var ee=({icon:e,children:s,href:t,...r})=>c__default.default.createElement("div",{className:"row gap-2 flex items-center"},c__default.default.createElement("div",{className:"bg-secondary-400 rounded-full p-2.5 items-center justify-center"},c__default.default.createElement(y,{icon:e,size:18,className:"text-primary"})),c__default.default.createElement(H,{className:"hover:underline",href:t,...r,variant:["body-default-semibold","md:body-default-semibold"]},s));exports.ContactItem=ee;//# sourceMappingURL=ContactItem.cjs.map
8
8
  //# sourceMappingURL=ContactItem.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/components/IconRenderer.tsx","../../src/components/Text.tsx","../../src/utils/index.ts","../../src/utils/tailwind.ts","../../src/components/Link.tsx","../../src/components/ContactItem.tsx"],"names":["IconRenderer","icon","size","className","svgMatch","React","attributesMatch","viewBoxMatch","viewBox","HEADING_ELEMENT_MAP","getElementFromVariant","variant","category","fontWeight","processVariants","variants","breakpoint","typographyClass","Text","color","as","children","weight","props","ref","typographyClasses","colorClasses","suggestedElement","baseVariant","cn","inputs","twMerge","clsx","focusRingStyles","Link","href","ContactItem","linkProps"],"mappings":"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","file":"ContactItem.cjs","sourcesContent":["import React from \"react\";\n\nexport type IconRendererProps = {\n icon: string;\n size?: number;\n className?: string;\n};\n\nexport const IconRenderer = ({\n icon,\n size = 40,\n className\n}: IconRendererProps) => {\n // Extract SVG content from the string (everything between <svg> and </svg>)\n const svgMatch = icon.match(/<svg[^>]*>([\\s\\S]*?)<\\/svg>/);\n\n if (!svgMatch) {\n return (\n <div\n style={{\n width: size,\n height: size,\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\"\n }}\n className={className}\n />\n );\n }\n\n // Extract attributes from the SVG tag\n const attributesMatch = icon.match(/<svg([^>]*)>/);\n const attributesString = attributesMatch ? attributesMatch[1] : \"\";\n\n // Parse viewBox\n const viewBoxMatch = attributesString.match(/viewBox=[\"']([^\"']*)[\"']/);\n const viewBox = viewBoxMatch ? viewBoxMatch[1] : \"0 0 40 40\";\n\n return (\n <div\n style={{\n width: size,\n height: size,\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\"\n }}\n className={className}\n >\n <svg\n width=\"100%\"\n height=\"100%\"\n viewBox={viewBox}\n preserveAspectRatio=\"xMidYMid meet\"\n dangerouslySetInnerHTML={{ __html: svgMatch[1] }}\n />\n </div>\n );\n};\n\nIconRenderer.displayName = \"IconRenderer\";\n","import React from \"react\";\nimport { Typography } from \"../types/tailwind\";\n\ntype TextElement =\n | \"p\"\n | \"span\"\n | \"h1\"\n | \"h2\"\n | \"h3\"\n | \"h4\"\n | \"h5\"\n | \"h6\"\n | \"strong\"\n | \"em\"\n | \"blockquote\"\n | \"pre\"\n | \"code\"\n | \"small\"\n | \"label\"\n | \"a\";\n\n// HTML element mapping type\ntype HTMLElementByTag = {\n p: HTMLParagraphElement;\n span: HTMLSpanElement;\n h1: HTMLHeadingElement;\n h2: HTMLHeadingElement;\n h3: HTMLHeadingElement;\n h4: HTMLHeadingElement;\n h5: HTMLHeadingElement;\n h6: HTMLHeadingElement;\n strong: HTMLElement;\n em: HTMLElement;\n blockquote: HTMLQuoteElement;\n pre: HTMLPreElement;\n code: HTMLElement;\n small: HTMLElement;\n label: HTMLLabelElement;\n a: HTMLAnchorElement;\n};\n\n// HTML props mapping type\ntype HTMLPropsMap = {\n p: React.HTMLAttributes<HTMLParagraphElement>;\n span: React.HTMLAttributes<HTMLSpanElement>;\n h1: React.HTMLAttributes<HTMLHeadingElement>;\n h2: React.HTMLAttributes<HTMLHeadingElement>;\n h3: React.HTMLAttributes<HTMLHeadingElement>;\n h4: React.HTMLAttributes<HTMLHeadingElement>;\n h5: React.HTMLAttributes<HTMLHeadingElement>;\n h6: React.HTMLAttributes<HTMLHeadingElement>;\n strong: React.HTMLAttributes<HTMLElement>;\n em: React.HTMLAttributes<HTMLElement>;\n blockquote: React.HTMLAttributes<HTMLQuoteElement>;\n pre: React.HTMLAttributes<HTMLPreElement>;\n code: React.HTMLAttributes<HTMLElement>;\n small: React.HTMLAttributes<HTMLElement>;\n label: React.LabelHTMLAttributes<HTMLLabelElement>;\n a: Omit<React.AnchorHTMLAttributes<HTMLAnchorElement>, \"color\">;\n};\n\ntype TextColor =\n | \"primary\"\n | \"secondary\"\n | \"white\"\n | \"primary-blue\"\n | \"disabled\"\n | \"danger\"\n | \"inherit\"\n | \"primary-100\";\n\nconst HEADING_ELEMENT_MAP: Record<string, TextElement> = {\n xl: \"h1\",\n lg: \"h1\",\n md: \"h2\",\n sm: \"h3\",\n xs: \"h4\"\n};\n\nconst getElementFromVariant = (variant: TypographyKey): TextElement => {\n const [category, size] = variant.split(\"-\");\n\n if (category === \"heading\") {\n return HEADING_ELEMENT_MAP[size] || \"p\";\n }\n\n if (category === \"label\") {\n return \"label\";\n }\n\n return \"p\";\n};\n\ntype Weight = \"light\" | \"regular\" | \"semibold\" | \"bold\";\n\nconst fontWeight: Record<Weight, string> = {\n light: \"font-light\",\n regular: \"font-regular\",\n semibold: \"font-semibold\",\n bold: \"font-bold\"\n};\n\n// Add breakpoint types\ntype Breakpoint = \"sm\" | \"md\" | \"lg\" | \"xl\" | \"2xl\";\ntype ResponsiveVariant = TypographyKey | `${Breakpoint}:${TypographyKey}`;\n\ntype TypographyCategory = keyof Typography;\ntype TypographyValue<T extends TypographyCategory> = Extract<\n keyof Typography[T],\n string | number | bigint | boolean | null | undefined\n>;\ntype TypographyKey = {\n [T in TypographyCategory]: `${T}-${TypographyValue<T>}`;\n}[TypographyCategory];\n\n// Update TextProps to use ResponsiveVariant\nexport type TextProps<T extends TextElement = \"p\"> = {\n variant?: ResponsiveVariant | ResponsiveVariant[];\n color?: TextColor;\n as?: T;\n className?: string;\n children: React.ReactNode;\n weight?: Weight;\n} & HTMLPropsMap[T];\n\n// Add helper function to process variants\nconst processVariants = (\n variants: ResponsiveVariant | ResponsiveVariant[] | undefined\n): string => {\n if (!variants) return \"text-body-default\";\n\n const variantArray = Array.isArray(variants) ? variants : [variants];\n\n return variantArray\n .map((variant) => {\n if (variant.includes(\":\")) {\n const [breakpoint, typographyClass] = variant.split(\":\");\n return `${breakpoint}:text-${typographyClass}`;\n }\n return `text-${variant}`;\n })\n .join(\" \");\n};\n\nexport const Text = React.forwardRef(\n <T extends TextElement = \"p\">(\n {\n variant = \"body-default\",\n color = \"primary\",\n as,\n className,\n children,\n weight,\n ...props\n }: TextProps<T>,\n ref: React.ForwardedRef<HTMLElementByTag[T]>\n ) => {\n // Process typography classes with breakpoints\n const typographyClasses = processVariants(variant);\n\n // Get color styles\n const colorClasses = color === \"inherit\" ? \"text-inherit\" : `text-${color}`;\n\n const suggestedElement = React.useMemo(() => {\n const baseVariant =\n typeof variant === \"string\"\n ? variant.split(\":\").pop()!\n : Array.isArray(variant)\n ? variant[0].split(\":\").pop()!\n : \"body-default\";\n return getElementFromVariant(baseVariant as TypographyKey);\n }, [variant]);\n\n const Component = (as || suggestedElement) as T;\n\n return (\n // @ts-expect-error TODO: figure this out\n <Component\n ref={ref}\n className={`\n font-sans antialiased\n ${typographyClasses}\n ${colorClasses}\n ${weight && `!${fontWeight[weight]}`}\n ${className}\n `}\n {...props}\n >\n {children}\n </Component>\n );\n }\n);\n\nText.displayName = \"Text\";\n","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","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\n const safelist: 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 breakpoints = [\"sm\", \"md\", \"lg\", \"xl\", \"2xl\"];\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 return [\n ...typographyClasses,\n ...responsiveTypographyClasses\n // ... rest of your safelist\n ];\n};\n\nexport const focusRingStyles =\n \"focus-visible:outline-none focus-visible:border-2 focus-visible:border-primary-100\";\n\nexport const focusRingStylesCoerced = \"border-2 border-primary-100\";\n","import React from \"react\";\nimport { Text, TextProps } from \"./Text\";\nimport { cn } from \"../utils\";\nimport { focusRingStyles } from \"../utils/tailwind\";\n\nexport type LinkProps = {\n href: string;\n children: React.ReactNode;\n className?: string;\n style?: React.CSSProperties;\n} & Pick<TextProps, \"variant\" | \"color\"> &\n React.AnchorHTMLAttributes<HTMLAnchorElement>;\n\nexport const Link = ({\n children,\n color = \"inherit\",\n variant = \"body-default-semibold\",\n href,\n className,\n ...props\n}: LinkProps) => (\n <Text variant={variant} color={color}>\n <a\n href={href}\n className={cn(\n \"hover:opacity-80 transition-all ease-in-out active:scale-95 hover:underline\",\n focusRingStyles,\n className\n )}\n {...props}\n >\n {children}\n </a>\n </Text>\n);\n","import React, { HTMLAttributes } from \"react\";\nimport { IconRenderer } from \"./IconRenderer\";\nimport { Link } from \"./Link\";\n\nexport type ContactItemProps = {\n // TODO: figure out how to get filled icons to work correctly\n icon: string;\n children: React.ReactNode;\n href: string;\n} & Omit<HTMLAttributes<HTMLAnchorElement>, \"color\">;\n\nexport const ContactItem = ({\n icon,\n children,\n href,\n ...linkProps\n}: ContactItemProps) => (\n <div className=\"row gap-2 flex items-center\">\n <div className=\"bg-secondary-400 rounded-full p-2.5 items-center justify-center\">\n <IconRenderer icon={icon} size={18} className=\"text-primary\" />\n </div>\n <Link\n className=\"hover:underline\"\n href={href}\n {...linkProps}\n variant={[\"body-default-semibold\", \"md:body-default-semibold\"]}\n >\n {children}\n </Link>\n </div>\n);\n"]}
1
+ {"version":3,"sources":["../../src/utils/index.ts","../../src/utils/responsive.ts","../../src/components/IconRenderer.tsx","../../src/components/Link.tsx","../../src/components/Text.tsx","../../src/utils/tailwind.ts","../../src/components/ContactItem.tsx"],"names":["cn","inputs","twMerge","clsx","BASE_SIZES","RESPONSIVE_SIZES","getSizeKey","size","getResponsiveSize","baseSize","classes","styles","key","baseKey","responsiveClasses","s","breakpoint","valueStr","value","valueKey","IconRenderer","icon","className","svgMatch","responsiveSizeClasses","responsiveSizeStyles","React","attributesMatch","viewBoxMatch","viewBox","HEADING_ELEMENT_MAP","getElementFromVariant","variant","category","fontWeight","processVariants","variants","typographyClass","Text","color","as","children","weight","props","ref","typographyClasses","colorClasses","suggestedElement","baseVariant","focusRingStyles","Link","href","ContactItem","linkProps"],"mappings":"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","file":"ContactItem.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 React from \"react\";\nimport { cn } from \"../utils\";\nimport { getResponsiveSize, ResponsiveSize } from \"../utils/responsive\";\n\nexport type IconRendererProps = {\n icon: string;\n size?: ResponsiveSize | ResponsiveSize[];\n className?: string;\n};\n\nexport const IconRenderer = ({\n icon,\n size = 40,\n className\n}: IconRendererProps) => {\n // Extract SVG content from the string (everything between <svg> and </svg>)\n const svgMatch = icon.match(/<svg[^>]*>([\\s\\S]*?)<\\/svg>/);\n const { responsiveSizeClasses, responsiveSizeStyles } = getResponsiveSize(\n size,\n 40\n );\n\n if (!svgMatch) {\n return (\n <div\n style={{\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n ...responsiveSizeStyles\n }}\n className={cn(responsiveSizeClasses, className)}\n />\n );\n }\n\n // Extract attributes from the SVG tag\n const attributesMatch = icon.match(/<svg([^>]*)>/);\n const attributesString = attributesMatch ? attributesMatch[1] : \"\";\n\n // Parse viewBox\n const viewBoxMatch = attributesString.match(/viewBox=[\"']([^\"']*)[\"']/);\n const viewBox = viewBoxMatch ? viewBoxMatch[1] : \"0 0 40 40\";\n\n return (\n <div\n style={{\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n ...responsiveSizeStyles\n }}\n className={cn(responsiveSizeClasses, className)}\n >\n <svg\n width=\"100%\"\n height=\"100%\"\n viewBox={viewBox}\n preserveAspectRatio=\"xMidYMid meet\"\n dangerouslySetInnerHTML={{ __html: svgMatch[1] }}\n />\n </div>\n );\n};\n\nIconRenderer.displayName = \"IconRenderer\";\n","import React from \"react\";\nimport { Text, TextProps } from \"./Text\";\nimport { cn } from \"../utils\";\nimport { focusRingStyles } from \"../utils/tailwind\";\n\nexport type LinkProps = {\n href: string;\n children: React.ReactNode;\n className?: string;\n style?: React.CSSProperties;\n} & Pick<TextProps, \"variant\" | \"color\"> &\n React.AnchorHTMLAttributes<HTMLAnchorElement>;\n\nexport const Link = ({\n children,\n color = \"inherit\",\n variant = \"body-default-semibold\",\n href,\n className,\n ...props\n}: LinkProps) => (\n <Text variant={variant} color={color}>\n <a\n href={href}\n className={cn(\n \"hover:opacity-80 transition-all ease-in-out active:scale-95 hover:underline\",\n focusRingStyles,\n className\n )}\n {...props}\n >\n {children}\n </a>\n </Text>\n);\n","import React from \"react\";\nimport { Typography } from \"../types/tailwind\";\nimport { Breakpoint } from \"../utils/responsive\";\n\ntype TextElement =\n | \"p\"\n | \"span\"\n | \"h1\"\n | \"h2\"\n | \"h3\"\n | \"h4\"\n | \"h5\"\n | \"h6\"\n | \"strong\"\n | \"em\"\n | \"blockquote\"\n | \"pre\"\n | \"code\"\n | \"small\"\n | \"label\"\n | \"a\";\n\n// HTML element mapping type\ntype HTMLElementByTag = {\n p: HTMLParagraphElement;\n span: HTMLSpanElement;\n h1: HTMLHeadingElement;\n h2: HTMLHeadingElement;\n h3: HTMLHeadingElement;\n h4: HTMLHeadingElement;\n h5: HTMLHeadingElement;\n h6: HTMLHeadingElement;\n strong: HTMLElement;\n em: HTMLElement;\n blockquote: HTMLQuoteElement;\n pre: HTMLPreElement;\n code: HTMLElement;\n small: HTMLElement;\n label: HTMLLabelElement;\n a: HTMLAnchorElement;\n};\n\n// HTML props mapping type\ntype HTMLPropsMap = {\n p: React.HTMLAttributes<HTMLParagraphElement>;\n span: React.HTMLAttributes<HTMLSpanElement>;\n h1: React.HTMLAttributes<HTMLHeadingElement>;\n h2: React.HTMLAttributes<HTMLHeadingElement>;\n h3: React.HTMLAttributes<HTMLHeadingElement>;\n h4: React.HTMLAttributes<HTMLHeadingElement>;\n h5: React.HTMLAttributes<HTMLHeadingElement>;\n h6: React.HTMLAttributes<HTMLHeadingElement>;\n strong: React.HTMLAttributes<HTMLElement>;\n em: React.HTMLAttributes<HTMLElement>;\n blockquote: React.HTMLAttributes<HTMLQuoteElement>;\n pre: React.HTMLAttributes<HTMLPreElement>;\n code: React.HTMLAttributes<HTMLElement>;\n small: React.HTMLAttributes<HTMLElement>;\n label: React.LabelHTMLAttributes<HTMLLabelElement>;\n a: Omit<React.AnchorHTMLAttributes<HTMLAnchorElement>, \"color\">;\n};\n\ntype TextColor =\n | \"primary\"\n | \"secondary\"\n | \"white\"\n | \"primary-blue\"\n | \"disabled\"\n | \"danger\"\n | \"inherit\"\n | \"primary-100\";\n\nconst HEADING_ELEMENT_MAP: Record<string, TextElement> = {\n xl: \"h1\",\n lg: \"h1\",\n md: \"h2\",\n sm: \"h3\",\n xs: \"h4\"\n};\n\nconst getElementFromVariant = (variant: TypographyKey): TextElement => {\n const [category, size] = variant.split(\"-\");\n\n if (category === \"heading\") {\n return HEADING_ELEMENT_MAP[size] || \"p\";\n }\n\n if (category === \"label\") {\n return \"label\";\n }\n\n return \"p\";\n};\n\ntype Weight = \"light\" | \"regular\" | \"semibold\" | \"bold\";\n\nconst fontWeight: Record<Weight, string> = {\n light: \"font-light\",\n regular: \"font-regular\",\n semibold: \"font-semibold\",\n bold: \"font-bold\"\n};\n\ntype ResponsiveVariant = TypographyKey | `${Breakpoint}:${TypographyKey}`;\n\ntype TypographyCategory = keyof Typography;\ntype TypographyValue<T extends TypographyCategory> = Extract<\n keyof Typography[T],\n string | number | bigint | boolean | null | undefined\n>;\ntype TypographyKey = {\n [T in TypographyCategory]: `${T}-${TypographyValue<T>}`;\n}[TypographyCategory];\n\n// Update TextProps to use ResponsiveVariant\nexport type TextProps<T extends TextElement = \"p\"> = {\n variant?: ResponsiveVariant | ResponsiveVariant[];\n color?: TextColor;\n as?: T;\n className?: string;\n children: React.ReactNode;\n weight?: Weight;\n} & HTMLPropsMap[T];\n\n// Add helper function to process variants\nconst processVariants = (\n variants: ResponsiveVariant | ResponsiveVariant[] | undefined\n): string => {\n if (!variants) return \"text-body-default\";\n\n const variantArray = Array.isArray(variants) ? variants : [variants];\n\n return variantArray\n .map((variant) => {\n if (variant.includes(\":\")) {\n const [breakpoint, typographyClass] = variant.split(\":\");\n return `${breakpoint}:text-${typographyClass}`;\n }\n return `text-${variant}`;\n })\n .join(\" \");\n};\n\nexport const Text = React.forwardRef(\n <T extends TextElement = \"p\">(\n {\n variant = \"body-default\",\n color = \"primary\",\n as,\n className,\n children,\n weight,\n ...props\n }: TextProps<T>,\n ref: React.ForwardedRef<HTMLElementByTag[T]>\n ) => {\n // Process typography classes with breakpoints\n const typographyClasses = processVariants(variant);\n\n // Get color styles\n const colorClasses = color === \"inherit\" ? \"text-inherit\" : `text-${color}`;\n\n const suggestedElement = React.useMemo(() => {\n const baseVariant =\n typeof variant === \"string\"\n ? variant.split(\":\").pop()!\n : Array.isArray(variant)\n ? variant[0].split(\":\").pop()!\n : \"body-default\";\n return getElementFromVariant(baseVariant as TypographyKey);\n }, [variant]);\n\n const Component = (as || suggestedElement) as T;\n\n return (\n // @ts-expect-error TODO: figure this out\n <Component\n ref={ref}\n className={`\n font-sans antialiased\n ${typographyClasses}\n ${colorClasses}\n ${weight && `!${fontWeight[weight]}`}\n ${className}\n `}\n {...props}\n >\n {children}\n </Component>\n );\n }\n);\n\nText.displayName = \"Text\";\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, { HTMLAttributes } from \"react\";\nimport { IconRenderer } from \"./IconRenderer\";\nimport { Link } from \"./Link\";\n\nexport type ContactItemProps = {\n // TODO: figure out how to get filled icons to work correctly\n icon: string;\n children: React.ReactNode;\n href: string;\n} & Omit<HTMLAttributes<HTMLAnchorElement>, \"color\">;\n\nexport const ContactItem = ({\n icon,\n children,\n href,\n ...linkProps\n}: ContactItemProps) => (\n <div className=\"row gap-2 flex items-center\">\n <div className=\"bg-secondary-400 rounded-full p-2.5 items-center justify-center\">\n <IconRenderer icon={icon} size={18} className=\"text-primary\" />\n </div>\n <Link\n className=\"hover:underline\"\n href={href}\n {...linkProps}\n variant={[\"body-default-semibold\", \"md:body-default-semibold\"]}\n >\n {children}\n </Link>\n </div>\n);\n"]}
@@ -1,8 +1,8 @@
1
- import i from'react';import {clsx}from'clsx';import {twMerge}from'tailwind-merge';var c=({icon:e,size:t=40,className:r})=>{let o=e.match(/<svg[^>]*>([\s\S]*?)<\/svg>/);if(!o)return i.createElement("div",{style:{width:t,height:t,display:"flex",alignItems:"center",justifyContent:"center"},className:r});let n=e.match(/<svg([^>]*)>/),a=(n?n[1]:"").match(/viewBox=["']([^"']*)["']/),l=a?a[1]:"0 0 40 40";return i.createElement("div",{style:{width:t,height:t,display:"flex",alignItems:"center",justifyContent:"center"},className:r},i.createElement("svg",{width:"100%",height:"100%",viewBox:l,preserveAspectRatio:"xMidYMid meet",dangerouslySetInnerHTML:{__html:o[1]}}))};c.displayName="IconRenderer";var M={xl:"h1",lg:"h1",md:"h2",sm:"h3",xs:"h4"},L=e=>{let[t,r]=e.split("-");return t==="heading"?M[r]||"p":t==="label"?"label":"p"},x={light:"font-light",regular:"font-regular",semibold:"font-semibold",bold:"font-bold"},E=e=>e?(Array.isArray(e)?e:[e]).map(r=>{if(r.includes(":")){let[o,n]=r.split(":");return `${o}:text-${n}`}return `text-${r}`}).join(" "):"text-body-default",y=i.forwardRef(({variant:e="body-default",color:t="primary",as:r,className:o,children:n,weight:s,...a},l)=>{let u=E(e),b=t==="inherit"?"text-inherit":`text-${t}`,f=i.useMemo(()=>{let H=typeof e=="string"?e.split(":").pop():Array.isArray(e)?e[0].split(":").pop():"body-default";return L(H)},[e]);return i.createElement(r||f,{ref:l,className:`
1
+ import c from'react';import {clsx}from'clsx';import {twMerge}from'tailwind-merge';function a(...e){return twMerge(clsx(e))}var g={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]"},f={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]"}},h=e=>String(e),w=(e,s=24)=>{let t=[],r={};if(e===undefined){let p=h(s);p?t.push(g[p]):(r.height=`${s}px`,r.width=`${s}px`);}if(typeof e=="number"){let p=h(e);p?t.push(g[p]):(r.height=`${e}px`,r.width=`${e}px`);}if(Array.isArray(e)){let p=h(s),n=[p&&g[p]||`h-[${s}px] w-[${s}px]`];e.forEach(o=>{if(typeof o=="string"){let[i,l]=o.split(":"),x=parseInt(l,10),m=h(x);t.push(m&&f[i]?.[m]||`${i}:h-[${x}px] ${i}:w-[${x}px]`);}}),t.push(...n);}if(typeof e=="string"){let[p,n]=e.split(":"),o=parseInt(n,10),i=h(o);t.push(i&&f[p]?.[i]||`${p}:h-[${o}px] ${p}:w-[${o}px]`);}return {responsiveSizeClasses:t.join(" "),responsiveSizeStyles:r}};var y=({icon:e,size:s=40,className:t})=>{let r=e.match(/<svg[^>]*>([\s\S]*?)<\/svg>/),{responsiveSizeClasses:p,responsiveSizeStyles:n}=w(s,40);if(!r)return c.createElement("div",{style:{display:"flex",alignItems:"center",justifyContent:"center",...n},className:a(p,t)});let o=e.match(/<svg([^>]*)>/),l=(o?o[1]:"").match(/viewBox=["']([^"']*)["']/),x=l?l[1]:"0 0 40 40";return c.createElement("div",{style:{display:"flex",alignItems:"center",justifyContent:"center",...n},className:a(p,t)},c.createElement("svg",{width:"100%",height:"100%",viewBox:x,preserveAspectRatio:"xMidYMid meet",dangerouslySetInnerHTML:{__html:r[1]}}))};y.displayName="IconRenderer";var R={xl:"h1",lg:"h1",md:"h2",sm:"h3",xs:"h4"},v=e=>{let[s,t]=e.split("-");return s==="heading"?R[t]||"p":s==="label"?"label":"p"},S={light:"font-light",regular:"font-regular",semibold:"font-semibold",bold:"font-bold"},A=e=>e?(Array.isArray(e)?e:[e]).map(t=>{if(t.includes(":")){let[r,p]=t.split(":");return `${r}:text-${p}`}return `text-${t}`}).join(" "):"text-body-default",T=c.forwardRef(({variant:e="body-default",color:s="primary",as:t,className:r,children:p,weight:n,...o},i)=>{let l=A(e),x=s==="inherit"?"text-inherit":`text-${s}`,m=c.useMemo(()=>{let L=typeof e=="string"?e.split(":").pop():Array.isArray(e)?e[0].split(":").pop():"body-default";return v(L)},[e]);return c.createElement(t||m,{ref:i,className:`
2
2
  font-sans antialiased
3
- ${u}
4
- ${b}
5
- ${s&&`!${x[s]}`}
6
- ${o}
7
- `,...a},n)});y.displayName="Text";function T(...e){return twMerge(clsx(e))}var h="focus-visible:outline-none focus-visible:border-2 focus-visible:border-primary-100";var g=({children:e,color:t="inherit",variant:r="body-default-semibold",href:o,className:n,...s})=>i.createElement(y,{variant:r,color:t},i.createElement("a",{href:o,className:T("hover:opacity-80 transition-all ease-in-out active:scale-95 hover:underline",h,n),...s},e));var D=({icon:e,children:t,href:r,...o})=>i.createElement("div",{className:"row gap-2 flex items-center"},i.createElement("div",{className:"bg-secondary-400 rounded-full p-2.5 items-center justify-center"},i.createElement(c,{icon:e,size:18,className:"text-primary"})),i.createElement(g,{className:"hover:underline",href:r,...o,variant:["body-default-semibold","md:body-default-semibold"]},t));export{D as ContactItem};//# sourceMappingURL=ContactItem.js.map
3
+ ${l}
4
+ ${x}
5
+ ${n&&`!${S[n]}`}
6
+ ${r}
7
+ `,...o},p)});T.displayName="Text";var M="focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-primary-100";var H=({children:e,color:s="inherit",variant:t="body-default-semibold",href:r,className:p,...n})=>c.createElement(T,{variant:t,color:s},c.createElement("a",{href:r,className:a("hover:opacity-80 transition-all ease-in-out active:scale-95 hover:underline",M,p),...n},e));var ee=({icon:e,children:s,href:t,...r})=>c.createElement("div",{className:"row gap-2 flex items-center"},c.createElement("div",{className:"bg-secondary-400 rounded-full p-2.5 items-center justify-center"},c.createElement(y,{icon:e,size:18,className:"text-primary"})),c.createElement(H,{className:"hover:underline",href:t,...r,variant:["body-default-semibold","md:body-default-semibold"]},s));export{ee as ContactItem};//# sourceMappingURL=ContactItem.js.map
8
8
  //# sourceMappingURL=ContactItem.js.map