@purpur/library 9.0.9 → 9.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (306) hide show
  1. package/CHANGELOG.json +63 -0
  2. package/CHANGELOG.md +28 -1
  3. package/dist/LICENSE.txt +48 -27
  4. package/dist/{autocomplete-B_OBQM2h.js → autocomplete-B421J7CS.js} +2 -2
  5. package/dist/{autocomplete-B_OBQM2h.js.map → autocomplete-B421J7CS.js.map} +1 -1
  6. package/dist/{autocomplete-DJ3zbA0m.mjs → autocomplete-B8L-dTmF.mjs} +3 -3
  7. package/dist/{autocomplete-DJ3zbA0m.mjs.map → autocomplete-B8L-dTmF.mjs.map} +1 -1
  8. package/dist/autocomplete.cjs.js +1 -1
  9. package/dist/autocomplete.es.js +1 -1
  10. package/dist/button-Cv7NlYbv.mjs +109 -0
  11. package/dist/button-Cv7NlYbv.mjs.map +1 -0
  12. package/dist/button-Dqxdc3nC.js +2 -0
  13. package/dist/button-Dqxdc3nC.js.map +1 -0
  14. package/dist/button.cjs.js +1 -1
  15. package/dist/button.es.js +1 -1
  16. package/dist/{calendar-BSdvi_DA.js → calendar-C-F-pVCe.js} +2 -2
  17. package/dist/{calendar-BSdvi_DA.js.map → calendar-C-F-pVCe.js.map} +1 -1
  18. package/dist/{calendar-9p_aA7KY.mjs → calendar-DWpnuylk.mjs} +2 -2
  19. package/dist/{calendar-9p_aA7KY.mjs.map → calendar-DWpnuylk.mjs.map} +1 -1
  20. package/dist/calendar.cjs.js +1 -1
  21. package/dist/calendar.es.js +1 -1
  22. package/dist/chat-field-CxOqk0-9.js +2 -0
  23. package/dist/chat-field-CxOqk0-9.js.map +1 -0
  24. package/dist/chat-field-yK-TwW0D.mjs +149 -0
  25. package/dist/chat-field-yK-TwW0D.mjs.map +1 -0
  26. package/dist/chat-field.cjs.js +2 -0
  27. package/dist/chat-field.cjs.js.map +1 -0
  28. package/dist/chat-field.es.js +5 -0
  29. package/dist/chat-field.es.js.map +1 -0
  30. package/dist/components/autocomplete/src/autocomplete.d.ts.map +1 -1
  31. package/dist/components/button/src/button.d.ts +4 -0
  32. package/dist/components/button/src/button.d.ts.map +1 -1
  33. package/dist/components/chat-field/src/chat-field.d.ts +71 -0
  34. package/dist/components/chat-field/src/chat-field.d.ts.map +1 -0
  35. package/dist/components/dismissable-chip-group/src/dismissable-chip-group-item.d.ts.map +1 -1
  36. package/dist/components/dismissable-chip-group/src/dismissable-chip-group.d.ts +6 -1
  37. package/dist/components/dismissable-chip-group/src/dismissable-chip-group.d.ts.map +1 -1
  38. package/dist/components/drawer/src/drawer-container.d.ts +2 -0
  39. package/dist/components/drawer/src/drawer-container.d.ts.map +1 -1
  40. package/dist/components/drawer/src/drawer-content.d.ts.map +1 -1
  41. package/dist/components/drawer/src/drawer-frame.d.ts +2 -1
  42. package/dist/components/drawer/src/drawer-frame.d.ts.map +1 -1
  43. package/dist/components/drawer/src/drawer-handle.d.ts +2 -1
  44. package/dist/components/drawer/src/drawer-handle.d.ts.map +1 -1
  45. package/dist/components/drawer/src/drawer-header.d.ts +2 -0
  46. package/dist/components/drawer/src/drawer-header.d.ts.map +1 -1
  47. package/dist/components/drawer/src/drawer-scroll-area.d.ts +2 -0
  48. package/dist/components/drawer/src/drawer-scroll-area.d.ts.map +1 -1
  49. package/dist/components/drawer/src/drawer.context.d.ts +6 -2
  50. package/dist/components/drawer/src/drawer.context.d.ts.map +1 -1
  51. package/dist/components/drawer/src/drawer.d.ts +3 -0
  52. package/dist/components/drawer/src/drawer.d.ts.map +1 -1
  53. package/dist/components/drawer/src/types.d.ts +1 -0
  54. package/dist/components/drawer/src/types.d.ts.map +1 -1
  55. package/dist/components/dropdown/src/dropdown-combobox.d.ts +34 -0
  56. package/dist/components/dropdown/src/dropdown-combobox.d.ts.map +1 -0
  57. package/dist/components/dropdown/src/dropdown-select.d.ts +34 -0
  58. package/dist/components/dropdown/src/dropdown-select.d.ts.map +1 -0
  59. package/dist/components/dropdown/src/dropdown-shared.d.ts +51 -0
  60. package/dist/components/dropdown/src/dropdown-shared.d.ts.map +1 -0
  61. package/dist/components/dropdown/src/dropdown.d.ts +6 -0
  62. package/dist/components/dropdown/src/dropdown.d.ts.map +1 -0
  63. package/dist/components/dropdown/src/dropdown.types.d.ts +94 -0
  64. package/dist/components/dropdown/src/dropdown.types.d.ts.map +1 -0
  65. package/dist/components/dropdown/src/useDropdown.d.ts +38 -0
  66. package/dist/components/dropdown/src/useDropdown.d.ts.map +1 -0
  67. package/dist/components/dropdown/src/useDropdownFilter.d.ts +9 -0
  68. package/dist/components/dropdown/src/useDropdownFilter.d.ts.map +1 -0
  69. package/dist/components/dropdown/src/useDropdownHighlight.d.ts +19 -0
  70. package/dist/components/dropdown/src/useDropdownHighlight.d.ts.map +1 -0
  71. package/dist/components/dropdown/src/useDropdownInput.d.ts +12 -0
  72. package/dist/components/dropdown/src/useDropdownInput.d.ts.map +1 -0
  73. package/dist/components/dropdown/src/useOnClickOutside.d.ts +2 -0
  74. package/dist/components/dropdown/src/useOnClickOutside.d.ts.map +1 -0
  75. package/dist/components/listbox/src/listbox-item.d.ts +2 -0
  76. package/dist/components/listbox/src/listbox-item.d.ts.map +1 -1
  77. package/dist/components/notification/src/notification.d.ts +2 -1
  78. package/dist/components/notification/src/notification.d.ts.map +1 -1
  79. package/dist/components/search-field/src/search-field-autocomplete.d.ts +73 -0
  80. package/dist/components/search-field/src/search-field-autocomplete.d.ts.map +1 -0
  81. package/dist/components/search-field/src/search-field-base.d.ts +97 -0
  82. package/dist/components/search-field/src/search-field-base.d.ts.map +1 -0
  83. package/dist/components/search-field/src/search-field.d.ts +123 -41
  84. package/dist/components/search-field/src/search-field.d.ts.map +1 -1
  85. package/dist/components/text-field/src/text-field-ai.d.ts +669 -0
  86. package/dist/components/text-field/src/text-field-ai.d.ts.map +1 -0
  87. package/dist/components/text-field/src/text-field-base.d.ts +671 -0
  88. package/dist/components/text-field/src/text-field-base.d.ts.map +1 -0
  89. package/dist/components/text-field/src/text-field.d.ts +42 -4
  90. package/dist/components/text-field/src/text-field.d.ts.map +1 -1
  91. package/dist/components-metadata.js +30 -1
  92. package/dist/{date-field-Ch2lM7-P.mjs → date-field-4tYMPw89.mjs} +2 -2
  93. package/dist/{date-field-Ch2lM7-P.mjs.map → date-field-4tYMPw89.mjs.map} +1 -1
  94. package/dist/{date-field-DTI5mQkg.js → date-field-B7ipm5sH.js} +2 -2
  95. package/dist/{date-field-DTI5mQkg.js.map → date-field-B7ipm5sH.js.map} +1 -1
  96. package/dist/date-field.cjs.js +1 -1
  97. package/dist/date-field.es.js +1 -1
  98. package/dist/{date-picker-Dk39IXG5.js → date-picker-B8L1Hm8r.js} +2 -2
  99. package/dist/{date-picker-Dk39IXG5.js.map → date-picker-B8L1Hm8r.js.map} +1 -1
  100. package/dist/{date-picker-Bt3IaH23.mjs → date-picker-Bp_XpoOF.mjs} +4 -4
  101. package/dist/{date-picker-Bt3IaH23.mjs.map → date-picker-Bp_XpoOF.mjs.map} +1 -1
  102. package/dist/date-picker.cjs.js +1 -1
  103. package/dist/date-picker.es.js +1 -1
  104. package/dist/dismissable-chip-group-Cd23yjBa.js +2 -0
  105. package/dist/dismissable-chip-group-Cd23yjBa.js.map +1 -0
  106. package/dist/dismissable-chip-group-D-gD93ON.mjs +89 -0
  107. package/dist/dismissable-chip-group-D-gD93ON.mjs.map +1 -0
  108. package/dist/dismissable-chip-group.cjs.js +1 -1
  109. package/dist/dismissable-chip-group.es.js +5 -2
  110. package/dist/drawer-UdK-u7IX.js +2 -0
  111. package/dist/drawer-UdK-u7IX.js.map +1 -0
  112. package/dist/drawer-Vi9H2O3N.mjs +562 -0
  113. package/dist/drawer-Vi9H2O3N.mjs.map +1 -0
  114. package/dist/drawer.cjs.js +1 -1
  115. package/dist/drawer.es.js +1 -1
  116. package/dist/dropdown-BC6evqyq.js +2 -0
  117. package/dist/dropdown-BC6evqyq.js.map +1 -0
  118. package/dist/dropdown-C-Ze4gvG.mjs +771 -0
  119. package/dist/dropdown-C-Ze4gvG.mjs.map +1 -0
  120. package/dist/dropdown.cjs.js +2 -0
  121. package/dist/dropdown.cjs.js.map +1 -0
  122. package/dist/dropdown.es.js +6 -0
  123. package/dist/dropdown.es.js.map +1 -0
  124. package/dist/{hero-banner-B5HKmkXc.mjs → hero-banner-BjwICxaJ.mjs} +2 -2
  125. package/dist/{hero-banner-B5HKmkXc.mjs.map → hero-banner-BjwICxaJ.mjs.map} +1 -1
  126. package/dist/{hero-banner-OnNSuxNT.js → hero-banner-yGRM4OlS.js} +2 -2
  127. package/dist/{hero-banner-OnNSuxNT.js.map → hero-banner-yGRM4OlS.js.map} +1 -1
  128. package/dist/hero-banner.cjs.js +1 -1
  129. package/dist/hero-banner.es.js +1 -1
  130. package/dist/illustrative-icon/assets/json/cart-checkmark-duocolor-animated.json.d.ts +1 -1
  131. package/dist/illustrative-icon/assets/json/cart-checkmark-offblack-animated.json.d.ts +1 -1
  132. package/dist/illustrative-icon/assets/json/checkmark-duocolor-animated.json.d.ts +1 -1
  133. package/dist/illustrative-icon/assets/json/checkmark-offblack-animated.json.d.ts +1 -1
  134. package/dist/illustrative-icon/assets/json/document-checkmark-duocolor-animated.json.d.ts +1 -1
  135. package/dist/illustrative-icon/assets/json/document-checkmark-offblack-animated.json.d.ts +1 -1
  136. package/dist/illustrative-icon/assets/json/support-checkmark-duocolor-animated.json.d.ts +1 -1
  137. package/dist/illustrative-icon/assets/json/support-checkmark-offblack-animated.json.d.ts +1 -1
  138. package/dist/illustrative-icon/assets/json/user-checkmark-duocolor-animated.json.d.ts +1 -1
  139. package/dist/illustrative-icon/assets/json/user-checkmark-offblack-animated.json.d.ts +1 -1
  140. package/dist/illustrative-icon/components/cart-checkmark-duocolor-animated.cjs.js +1 -1
  141. package/dist/illustrative-icon/components/cart-checkmark-duocolor-animated.cjs.js.map +1 -1
  142. package/dist/illustrative-icon/components/cart-checkmark-duocolor-animated.es.js +1 -1
  143. package/dist/illustrative-icon/components/cart-checkmark-offblack-animated.cjs.js +1 -1
  144. package/dist/illustrative-icon/components/cart-checkmark-offblack-animated.cjs.js.map +1 -1
  145. package/dist/illustrative-icon/components/cart-checkmark-offblack-animated.es.js +1 -1
  146. package/dist/illustrative-icon/components/checkmark-duocolor-animated.cjs.js +1 -1
  147. package/dist/illustrative-icon/components/checkmark-duocolor-animated.cjs.js.map +1 -1
  148. package/dist/illustrative-icon/components/checkmark-duocolor-animated.es.js +1 -1
  149. package/dist/illustrative-icon/components/checkmark-offblack-animated.cjs.js +1 -1
  150. package/dist/illustrative-icon/components/checkmark-offblack-animated.cjs.js.map +1 -1
  151. package/dist/illustrative-icon/components/checkmark-offblack-animated.es.js +1 -1
  152. package/dist/illustrative-icon/components/document-checkmark-duocolor-animated.cjs.js +2 -2
  153. package/dist/illustrative-icon/components/document-checkmark-duocolor-animated.es.js +2 -2
  154. package/dist/illustrative-icon/components/document-checkmark-offblack-animated.cjs.js +2 -2
  155. package/dist/illustrative-icon/components/document-checkmark-offblack-animated.es.js +2 -2
  156. package/dist/illustrative-icon/components/support-checkmark-duocolor-animated.cjs.js +1 -1
  157. package/dist/illustrative-icon/components/support-checkmark-duocolor-animated.cjs.js.map +1 -1
  158. package/dist/illustrative-icon/components/support-checkmark-duocolor-animated.es.js +1 -1
  159. package/dist/illustrative-icon/components/support-checkmark-offblack-animated.cjs.js +1 -1
  160. package/dist/illustrative-icon/components/support-checkmark-offblack-animated.cjs.js.map +1 -1
  161. package/dist/illustrative-icon/components/support-checkmark-offblack-animated.es.js +1 -1
  162. package/dist/illustrative-icon/components/user-checkmark-duocolor-animated.cjs.js +1 -1
  163. package/dist/illustrative-icon/components/user-checkmark-duocolor-animated.es.js +1 -1
  164. package/dist/illustrative-icon/components/user-checkmark-offblack-animated.cjs.js +1 -1
  165. package/dist/illustrative-icon/components/user-checkmark-offblack-animated.es.js +1 -1
  166. package/dist/libraries/library/src/chat-field.d.ts +6 -0
  167. package/dist/libraries/library/src/chat-field.d.ts.map +1 -0
  168. package/dist/libraries/library/src/dropdown.d.ts +6 -0
  169. package/dist/libraries/library/src/dropdown.d.ts.map +1 -0
  170. package/dist/libraries/library/src/library.d.ts +2 -0
  171. package/dist/libraries/library/src/library.d.ts.map +1 -1
  172. package/dist/libraries/theme/src/theme-props.d.ts +1 -0
  173. package/dist/libraries/theme/src/theme-props.d.ts.map +1 -1
  174. package/dist/libraries/tokens/dist/border/variables.d.ts +1 -0
  175. package/dist/libraries/tokens/dist/border/variables.dark.d.ts +1 -0
  176. package/dist/library.cjs.js +1 -1
  177. package/dist/library.es.js +603 -592
  178. package/dist/library.es.js.map +1 -1
  179. package/dist/listbox-COBHLRtB.js +2 -0
  180. package/dist/listbox-COBHLRtB.js.map +1 -0
  181. package/dist/listbox-DG4KmQP_.mjs +66 -0
  182. package/dist/listbox-DG4KmQP_.mjs.map +1 -0
  183. package/dist/listbox.cjs.js +1 -1
  184. package/dist/listbox.es.js +1 -1
  185. package/dist/{modal-CQiJ98iI.js → modal-DMeRO1wE.js} +2 -2
  186. package/dist/{modal-CQiJ98iI.js.map → modal-DMeRO1wE.js.map} +1 -1
  187. package/dist/{modal-B1eJu9HN.mjs → modal-fTWvPEPW.mjs} +2 -2
  188. package/dist/{modal-B1eJu9HN.mjs.map → modal-fTWvPEPW.mjs.map} +1 -1
  189. package/dist/modal.cjs.js +1 -1
  190. package/dist/modal.es.js +1 -1
  191. package/dist/{notification-BtcM7Ndu.mjs → notification-BvoL7BIW.mjs} +60 -51
  192. package/dist/notification-BvoL7BIW.mjs.map +1 -0
  193. package/dist/notification-DE1pvk9W.js +2 -0
  194. package/dist/notification-DE1pvk9W.js.map +1 -0
  195. package/dist/{notification-banner-CbKcE7o4.mjs → notification-banner-C4gkkSlf.mjs} +2 -2
  196. package/dist/{notification-banner-CbKcE7o4.mjs.map → notification-banner-C4gkkSlf.mjs.map} +1 -1
  197. package/dist/{notification-banner-B0CUuKZn.js → notification-banner-COH7wJu2.js} +2 -2
  198. package/dist/{notification-banner-B0CUuKZn.js.map → notification-banner-COH7wJu2.js.map} +1 -1
  199. package/dist/notification-banner.cjs.js +1 -1
  200. package/dist/notification-banner.es.js +1 -1
  201. package/dist/notification.cjs.js +1 -1
  202. package/dist/notification.es.js +1 -1
  203. package/dist/{popover-D6k4-oO1.js → popover-BnUVNqSi.js} +2 -2
  204. package/dist/{popover-D6k4-oO1.js.map → popover-BnUVNqSi.js.map} +1 -1
  205. package/dist/{popover-D3b2gHm-.mjs → popover-lxTyKALA.mjs} +2 -2
  206. package/dist/{popover-D3b2gHm-.mjs.map → popover-lxTyKALA.mjs.map} +1 -1
  207. package/dist/popover.cjs.js +1 -1
  208. package/dist/popover.es.js +1 -1
  209. package/dist/purpur.css +1 -1
  210. package/dist/{quantity-selector-Djf8APeL.mjs → quantity-selector-CsR6KTG3.mjs} +3 -3
  211. package/dist/{quantity-selector-Djf8APeL.mjs.map → quantity-selector-CsR6KTG3.mjs.map} +1 -1
  212. package/dist/{quantity-selector-Bc-4Dnpc.js → quantity-selector-DWDg4aFO.js} +2 -2
  213. package/dist/{quantity-selector-Bc-4Dnpc.js.map → quantity-selector-DWDg4aFO.js.map} +1 -1
  214. package/dist/quantity-selector.cjs.js +1 -1
  215. package/dist/quantity-selector.es.js +1 -1
  216. package/dist/search-field-Caj2dKLn.mjs +151 -0
  217. package/dist/search-field-Caj2dKLn.mjs.map +1 -0
  218. package/dist/search-field-DAktzYb0.js +2 -0
  219. package/dist/search-field-DAktzYb0.js.map +1 -0
  220. package/dist/search-field.cjs.js +1 -1
  221. package/dist/search-field.es.js +3 -2
  222. package/dist/{stepper-CTdGj87I.mjs → stepper-B351hexi.mjs} +3 -3
  223. package/dist/{stepper-CTdGj87I.mjs.map → stepper-B351hexi.mjs.map} +1 -1
  224. package/dist/{stepper-BaoOY4Ea.js → stepper-Cb4_9D2h.js} +2 -2
  225. package/dist/{stepper-BaoOY4Ea.js.map → stepper-Cb4_9D2h.js.map} +1 -1
  226. package/dist/stepper.cjs.js +1 -1
  227. package/dist/stepper.es.js +1 -1
  228. package/dist/{table-D7qthqj_.mjs → table-DXYHrKI7.mjs} +5 -5
  229. package/dist/{table-D7qthqj_.mjs.map → table-DXYHrKI7.mjs.map} +1 -1
  230. package/dist/{table-TdOPMFoP.js → table-x3SDCR-z.js} +2 -2
  231. package/dist/{table-TdOPMFoP.js.map → table-x3SDCR-z.js.map} +1 -1
  232. package/dist/table.cjs.js +1 -1
  233. package/dist/table.es.js +1 -1
  234. package/dist/text-field-BQYzwIrG.mjs +322 -0
  235. package/dist/text-field-BQYzwIrG.mjs.map +1 -0
  236. package/dist/text-field-BwxGMWds.js +2 -0
  237. package/dist/text-field-BwxGMWds.js.map +1 -0
  238. package/dist/text-field.cjs.js +1 -1
  239. package/dist/text-field.es.js +4 -3
  240. package/dist/tokens/border/variables.css +1 -0
  241. package/dist/tokens/border/variables.d.ts +1 -0
  242. package/dist/tokens/border/variables.dark.css +1 -0
  243. package/dist/tokens/border/variables.dark.d.ts +1 -0
  244. package/dist/tokens/border/variables.dark.js +1 -0
  245. package/dist/tokens/border/variables.dark.json +1 -0
  246. package/dist/tokens/border/variables.dark.scss +1 -0
  247. package/dist/tokens/border/variables.js +1 -0
  248. package/dist/tokens/border/variables.json +1 -0
  249. package/dist/tokens/border/variables.scss +1 -0
  250. package/dist/tokens.cjs.js +1 -1
  251. package/dist/tokens.cjs.js.map +1 -1
  252. package/dist/tokens.es.js +337 -336
  253. package/dist/tokens.es.js.map +1 -1
  254. package/dist/{tooltip-BtGtu3ph.mjs → tooltip-BHsVKFJ3.mjs} +2 -2
  255. package/dist/{tooltip-BtGtu3ph.mjs.map → tooltip-BHsVKFJ3.mjs.map} +1 -1
  256. package/dist/{tooltip-eUP35j3v.js → tooltip-B_qTqtcF.js} +2 -2
  257. package/dist/{tooltip-eUP35j3v.js.map → tooltip-B_qTqtcF.js.map} +1 -1
  258. package/dist/tooltip.cjs.js +1 -1
  259. package/dist/tooltip.es.js +1 -1
  260. package/dist/use-autocomplete.es-BHDgQLae.js +2 -0
  261. package/dist/use-autocomplete.es-BHDgQLae.js.map +1 -0
  262. package/dist/use-autocomplete.es-CVv3z8t6.mjs +142 -0
  263. package/dist/use-autocomplete.es-CVv3z8t6.mjs.map +1 -0
  264. package/package.json +22 -20
  265. package/src/aliases.ts +8 -0
  266. package/src/chat-field.ts +6 -0
  267. package/src/dropdown.ts +6 -0
  268. package/src/entries.js +2 -0
  269. package/src/library.ts +4 -0
  270. package/tokens/border/variables.css +1 -0
  271. package/tokens/border/variables.d.ts +1 -0
  272. package/tokens/border/variables.dark.css +1 -0
  273. package/tokens/border/variables.dark.d.ts +1 -0
  274. package/tokens/border/variables.dark.js +1 -0
  275. package/tokens/border/variables.dark.json +1 -0
  276. package/tokens/border/variables.dark.scss +1 -0
  277. package/tokens/border/variables.js +1 -0
  278. package/tokens/border/variables.json +1 -0
  279. package/tokens/border/variables.scss +1 -0
  280. package/dist/button-BxdChrq-.js +0 -2
  281. package/dist/button-BxdChrq-.js.map +0 -1
  282. package/dist/button-D-BBdNhd.mjs +0 -105
  283. package/dist/button-D-BBdNhd.mjs.map +0 -1
  284. package/dist/dismissable-chip-group-CnziecOt.js +0 -2
  285. package/dist/dismissable-chip-group-CnziecOt.js.map +0 -1
  286. package/dist/dismissable-chip-group-ZCYOt1sB.mjs +0 -79
  287. package/dist/dismissable-chip-group-ZCYOt1sB.mjs.map +0 -1
  288. package/dist/drawer-B6j8nfAY.mjs +0 -530
  289. package/dist/drawer-B6j8nfAY.mjs.map +0 -1
  290. package/dist/drawer-CJsLdd2x.js +0 -2
  291. package/dist/drawer-CJsLdd2x.js.map +0 -1
  292. package/dist/listbox-BmjBtIv8.js +0 -2
  293. package/dist/listbox-BmjBtIv8.js.map +0 -1
  294. package/dist/listbox-oDeP8FvH.mjs +0 -65
  295. package/dist/listbox-oDeP8FvH.mjs.map +0 -1
  296. package/dist/notification-BtcM7Ndu.mjs.map +0 -1
  297. package/dist/notification-Dsg3Vzfi.js +0 -2
  298. package/dist/notification-Dsg3Vzfi.js.map +0 -1
  299. package/dist/search-field-0CBoxcNH.js +0 -2
  300. package/dist/search-field-0CBoxcNH.js.map +0 -1
  301. package/dist/search-field-aP_i6Nr0.mjs +0 -91
  302. package/dist/search-field-aP_i6Nr0.mjs.map +0 -1
  303. package/dist/text-field-9zPmL99g.mjs +0 -185
  304. package/dist/text-field-9zPmL99g.mjs.map +0 -1
  305. package/dist/text-field-CKCwxTJX.js +0 -2
  306. package/dist/text-field-CKCwxTJX.js.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-autocomplete.es-BHDgQLae.js","sources":["../../../hooks/autocomplete/dist/use-autocomplete.es.js"],"sourcesContent":["import { useId as Z, useRef as b, useState as A, useCallback as $, useEffect as _ } from \"react\";\nconst ee = ({\n id: p,\n options: m,\n listboxLabel: O,\n selectedOption: r,\n disabled: v = !1,\n readOnly: h = !1,\n openOnFocus: K = !1,\n listboxMaxHeight: u,\n highlightFirstOption: y = !1,\n onSelect: S,\n closeOnSelect: T = !0,\n noOptionsText: P,\n [\"data-testid\"]: w\n}) => {\n const M = Z(), l = b(null), x = b(null), d = b(null), g = b({}), [k, I] = A(!1), [n, a] = A(\n y ? m[0] : void 0\n ), C = `${p}-listbox`, N = `${p}-input`, E = (e) => `${p}-listbox-item-${e.id}`, R = `--purpur-autocomplete-${M.replace(/:/g, \"\")}`, Y = { anchorName: R }, B = (e) => w ? `${w}-${e}` : void 0, o = $(() => {\n I(!1), a(void 0);\n }, []);\n _(() => {\n const e = (t) => {\n l.current && !l.current.contains(t.target) && !d.current?.contains(t.target) && o();\n };\n return document.addEventListener(\"mousedown\", e), () => document.removeEventListener(\"mousedown\", e);\n }, [o]);\n const f = ({ eventType: e }) => {\n I(!0), r && requestAnimationFrame(() => {\n a({ ...r, isSetByClickEvent: e === \"CLICK\" }), D(g.current[r.id]);\n });\n }, D = (e) => {\n if (!e) return;\n const t = e.getBoundingClientRect(), s = d.current?.getBoundingClientRect() ?? { top: 0, bottom: 0 };\n (t.top < s.top || t.bottom > s.bottom) && e.scrollIntoView({ block: \"nearest\" });\n }, c = k && (m.length > 0 || !!P), q = (e) => {\n const t = m.filter((i) => !i.disabled);\n if (!t.length) return;\n const s = n ? t.findIndex((i) => i.id === n.id) : -1;\n return e === \"ArrowDown\" ? t[(s + 1) % t.length] : t[(s - 1 + t.length) % t.length];\n }, F = (e) => {\n c || f({ eventType: \"KEYBOARD\" });\n const t = q(e);\n a(t ? { ...t } : void 0), t && D(g.current[t.id]);\n }, L = (e) => {\n e.disabled || (S?.(e), x.current?.focus(), T && o());\n }, U = () => {\n f({ eventType: \"KEYBOARD\" });\n }, V = (e) => {\n if (!(v || h))\n switch (e.key) {\n case \"ArrowUp\":\n case \"ArrowDown\":\n e.preventDefault(), F(e.key);\n break;\n case \"Enter\":\n c && n && (e.preventDefault(), L(n));\n break;\n case \"Escape\":\n e.preventDefault(), o();\n break;\n case \"Tab\":\n o();\n break;\n }\n }, j = () => {\n !k && K && !v && !h && f({ eventType: \"KEYBOARD\" });\n }, z = () => {\n setTimeout(() => {\n const e = document.activeElement;\n e !== document.body && !x.current?.contains(e) && !d.current?.contains(e) && !l.current?.contains(e) && o();\n });\n }, G = () => {\n v || h || (c ? o() : f({ eventType: \"CLICK\" }));\n }, J = $((e) => {\n if (d.current = e, e && typeof e.showPopover == \"function\")\n try {\n e.showPopover();\n } catch {\n }\n }, []), Q = {\n \"aria-label\": O,\n \"aria-expanded\": c,\n \"data-testid\": B(\"listbox\"),\n id: C,\n ref: J,\n onMouseLeave: () => a(void 0),\n popover: \"manual\",\n style: {\n ...u ? {\n maxHeight: typeof u == \"number\" ? `${u}px` : u\n } : {},\n positionAnchor: R\n }\n }, W = (e, t) => {\n const s = (e.id === n?.id || y && !n && t === 0) && !n?.isSetByClickEvent;\n return {\n \"data-testid\": B(`listbox-item-${e.id}`),\n id: E(e),\n key: e.id,\n onMouseMove: () => {\n e.id !== n?.id && a({ ...e, isSetByClickEvent: !0 });\n },\n onMouseUp: () => L(e),\n ref: (i) => {\n i && (g.current[e.id] = i);\n },\n tabIndex: -1,\n selected: e.id === r?.id,\n disabled: e.disabled,\n highlighted: s,\n hovered: e.id === n?.id && !!n?.isSetByClickEvent,\n \"aria-selected\": e.id === r?.id\n };\n }, X = {\n role: \"combobox\",\n \"aria-autocomplete\": \"list\",\n \"aria-expanded\": c,\n \"aria-controls\": C,\n \"aria-activedescendant\": n ? E(n) : void 0,\n autoComplete: \"off\",\n onKeyDown: V,\n onFocus: j,\n onBlur: z,\n onMouseDown: G\n };\n return {\n rootRef: l,\n inputRef: x,\n inputId: N,\n inputProps: X,\n listboxProps: Q,\n getListboxItemProps: W,\n isOpen: c,\n openListbox: U,\n anchorStyle: Y\n };\n};\nexport {\n ee as useAutocomplete\n};\n//# sourceMappingURL=use-autocomplete.es.js.map\n"],"names":["ee","p","m","O","r","v","h","K","u","S","T","P","w","Z","l","b","x","d","g","k","I","A","a","C","N","E","R","Y","B","o","$","_","f","D","c","q","i","F","L","U","V","j","z","G","J","Q","W","X"],"mappings":"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"}
@@ -0,0 +1,142 @@
1
+ import { useId as X, useRef as b, useState as R, useCallback as $, useEffect as Z } from "react";
2
+ const ee = ({
3
+ id: f,
4
+ options: v,
5
+ listboxLabel: A,
6
+ selectedOption: a,
7
+ disabled: m = !1,
8
+ readOnly: g = !1,
9
+ openOnFocus: S = !1,
10
+ listboxMaxHeight: d,
11
+ highlightFirstOption: y = !1,
12
+ onSelect: T,
13
+ closeOnSelect: M = !0,
14
+ noOptionsText: K,
15
+ ["data-testid"]: k
16
+ }) => {
17
+ const F = X(), l = b(null), x = b(null), u = b(null), h = b({}), [E, C] = R(!1), [o, c] = R(
18
+ y ? v[0] : void 0
19
+ ), w = `${f}-listbox`, P = `${f}-input`, B = (e) => `${f}-listbox-item-${e.id}`, D = `--purpur-autocomplete-${F.replace(/:/g, "")}`, Y = { anchorName: D }, O = (e) => k ? `${k}-${e}` : void 0, n = $(() => {
20
+ C(!1), c(void 0);
21
+ }, []);
22
+ Z(() => {
23
+ const e = (t) => {
24
+ l.current && !l.current.contains(t.target) && !u.current?.contains(t.target) && n();
25
+ };
26
+ return document.addEventListener("mousedown", e), () => document.removeEventListener("mousedown", e);
27
+ }, [n]);
28
+ const p = ({ eventType: e }) => {
29
+ C(!0), a && requestAnimationFrame(() => {
30
+ c({ ...a, isSetByClickEvent: e === "CLICK" }), I(h.current[a.id]);
31
+ });
32
+ }, I = (e) => {
33
+ if (!e) return;
34
+ const t = e.getBoundingClientRect(), i = u.current?.getBoundingClientRect() ?? { top: 0, bottom: 0 };
35
+ (t.top < i.top || t.bottom > i.bottom) && e.scrollIntoView({ block: "nearest" });
36
+ }, r = E && (v.length > 0 || !!K), U = (e) => {
37
+ const t = v.filter((s) => !s.disabled);
38
+ if (!t.length) return;
39
+ const i = o ? t.findIndex((s) => s.id === o.id) : -1;
40
+ return e === "ArrowDown" ? t[(i + 1) % t.length] : t[(i - 1 + t.length) % t.length];
41
+ }, q = (e) => {
42
+ r || p({ eventType: "KEYBOARD" });
43
+ const t = U(e);
44
+ c(t ? { ...t } : void 0), t && I(h.current[t.id]);
45
+ }, L = (e) => {
46
+ e.disabled || (T?.(e), x.current?.focus(), M && n());
47
+ }, H = () => {
48
+ p({ eventType: "KEYBOARD" });
49
+ }, N = (e) => {
50
+ if (!(m || g))
51
+ switch (e.key) {
52
+ case "ArrowUp":
53
+ case "ArrowDown":
54
+ e.preventDefault(), q(e.key);
55
+ break;
56
+ case "Enter":
57
+ r && o && (e.preventDefault(), L(o));
58
+ break;
59
+ case "Escape":
60
+ e.preventDefault(), n();
61
+ break;
62
+ case "Tab":
63
+ n();
64
+ break;
65
+ }
66
+ }, V = () => {
67
+ !E && S && !m && !g && p({ eventType: "KEYBOARD" });
68
+ }, j = () => {
69
+ setTimeout(() => {
70
+ const e = document.activeElement;
71
+ e !== document.body && !x.current?.contains(e) && !u.current?.contains(e) && !l.current?.contains(e) && n();
72
+ });
73
+ }, z = () => {
74
+ m || g || (r ? n() : p({ eventType: "CLICK" }));
75
+ }, G = $((e) => {
76
+ if (u.current = e, e && typeof e.showPopover == "function")
77
+ try {
78
+ e.showPopover();
79
+ } catch {
80
+ }
81
+ }, []), J = {
82
+ "aria-label": A,
83
+ "aria-expanded": r,
84
+ "data-testid": O("listbox"),
85
+ id: w,
86
+ ref: G,
87
+ onMouseLeave: () => c(void 0),
88
+ popover: "manual",
89
+ style: {
90
+ ...d ? {
91
+ maxHeight: typeof d == "number" ? `${d}px` : d
92
+ } : {},
93
+ positionAnchor: D
94
+ }
95
+ }, Q = (e, t) => {
96
+ const i = (e.id === o?.id || y && !o && t === 0) && !o?.isSetByClickEvent;
97
+ return {
98
+ "data-testid": O(`listbox-item-${e.id}`),
99
+ id: B(e),
100
+ key: e.id,
101
+ onMouseMove: () => {
102
+ e.id !== o?.id && c({ ...e, isSetByClickEvent: !0 });
103
+ },
104
+ onMouseUp: () => L(e),
105
+ ref: (s) => {
106
+ s && (h.current[e.id] = s);
107
+ },
108
+ tabIndex: -1,
109
+ selected: e.id === a?.id,
110
+ disabled: e.disabled,
111
+ highlighted: i,
112
+ hovered: e.id === o?.id && !!o?.isSetByClickEvent,
113
+ "aria-selected": e.id === a?.id
114
+ };
115
+ }, W = {
116
+ role: "combobox",
117
+ "aria-autocomplete": "list",
118
+ "aria-expanded": r,
119
+ "aria-controls": w,
120
+ "aria-activedescendant": o ? B(o) : void 0,
121
+ autoComplete: "off",
122
+ onKeyDown: N,
123
+ onFocus: V,
124
+ onBlur: j,
125
+ onMouseDown: z
126
+ };
127
+ return {
128
+ rootRef: l,
129
+ inputRef: x,
130
+ inputId: P,
131
+ inputProps: W,
132
+ listboxProps: J,
133
+ getListboxItemProps: Q,
134
+ isOpen: r,
135
+ openListbox: H,
136
+ anchorStyle: Y
137
+ };
138
+ };
139
+ export {
140
+ ee as e
141
+ };
142
+ //# sourceMappingURL=use-autocomplete.es-CVv3z8t6.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-autocomplete.es-CVv3z8t6.mjs","sources":["../../../hooks/autocomplete/dist/use-autocomplete.es.js"],"sourcesContent":["import { useId as Z, useRef as b, useState as A, useCallback as $, useEffect as _ } from \"react\";\nconst ee = ({\n id: p,\n options: m,\n listboxLabel: O,\n selectedOption: r,\n disabled: v = !1,\n readOnly: h = !1,\n openOnFocus: K = !1,\n listboxMaxHeight: u,\n highlightFirstOption: y = !1,\n onSelect: S,\n closeOnSelect: T = !0,\n noOptionsText: P,\n [\"data-testid\"]: w\n}) => {\n const M = Z(), l = b(null), x = b(null), d = b(null), g = b({}), [k, I] = A(!1), [n, a] = A(\n y ? m[0] : void 0\n ), C = `${p}-listbox`, N = `${p}-input`, E = (e) => `${p}-listbox-item-${e.id}`, R = `--purpur-autocomplete-${M.replace(/:/g, \"\")}`, Y = { anchorName: R }, B = (e) => w ? `${w}-${e}` : void 0, o = $(() => {\n I(!1), a(void 0);\n }, []);\n _(() => {\n const e = (t) => {\n l.current && !l.current.contains(t.target) && !d.current?.contains(t.target) && o();\n };\n return document.addEventListener(\"mousedown\", e), () => document.removeEventListener(\"mousedown\", e);\n }, [o]);\n const f = ({ eventType: e }) => {\n I(!0), r && requestAnimationFrame(() => {\n a({ ...r, isSetByClickEvent: e === \"CLICK\" }), D(g.current[r.id]);\n });\n }, D = (e) => {\n if (!e) return;\n const t = e.getBoundingClientRect(), s = d.current?.getBoundingClientRect() ?? { top: 0, bottom: 0 };\n (t.top < s.top || t.bottom > s.bottom) && e.scrollIntoView({ block: \"nearest\" });\n }, c = k && (m.length > 0 || !!P), q = (e) => {\n const t = m.filter((i) => !i.disabled);\n if (!t.length) return;\n const s = n ? t.findIndex((i) => i.id === n.id) : -1;\n return e === \"ArrowDown\" ? t[(s + 1) % t.length] : t[(s - 1 + t.length) % t.length];\n }, F = (e) => {\n c || f({ eventType: \"KEYBOARD\" });\n const t = q(e);\n a(t ? { ...t } : void 0), t && D(g.current[t.id]);\n }, L = (e) => {\n e.disabled || (S?.(e), x.current?.focus(), T && o());\n }, U = () => {\n f({ eventType: \"KEYBOARD\" });\n }, V = (e) => {\n if (!(v || h))\n switch (e.key) {\n case \"ArrowUp\":\n case \"ArrowDown\":\n e.preventDefault(), F(e.key);\n break;\n case \"Enter\":\n c && n && (e.preventDefault(), L(n));\n break;\n case \"Escape\":\n e.preventDefault(), o();\n break;\n case \"Tab\":\n o();\n break;\n }\n }, j = () => {\n !k && K && !v && !h && f({ eventType: \"KEYBOARD\" });\n }, z = () => {\n setTimeout(() => {\n const e = document.activeElement;\n e !== document.body && !x.current?.contains(e) && !d.current?.contains(e) && !l.current?.contains(e) && o();\n });\n }, G = () => {\n v || h || (c ? o() : f({ eventType: \"CLICK\" }));\n }, J = $((e) => {\n if (d.current = e, e && typeof e.showPopover == \"function\")\n try {\n e.showPopover();\n } catch {\n }\n }, []), Q = {\n \"aria-label\": O,\n \"aria-expanded\": c,\n \"data-testid\": B(\"listbox\"),\n id: C,\n ref: J,\n onMouseLeave: () => a(void 0),\n popover: \"manual\",\n style: {\n ...u ? {\n maxHeight: typeof u == \"number\" ? `${u}px` : u\n } : {},\n positionAnchor: R\n }\n }, W = (e, t) => {\n const s = (e.id === n?.id || y && !n && t === 0) && !n?.isSetByClickEvent;\n return {\n \"data-testid\": B(`listbox-item-${e.id}`),\n id: E(e),\n key: e.id,\n onMouseMove: () => {\n e.id !== n?.id && a({ ...e, isSetByClickEvent: !0 });\n },\n onMouseUp: () => L(e),\n ref: (i) => {\n i && (g.current[e.id] = i);\n },\n tabIndex: -1,\n selected: e.id === r?.id,\n disabled: e.disabled,\n highlighted: s,\n hovered: e.id === n?.id && !!n?.isSetByClickEvent,\n \"aria-selected\": e.id === r?.id\n };\n }, X = {\n role: \"combobox\",\n \"aria-autocomplete\": \"list\",\n \"aria-expanded\": c,\n \"aria-controls\": C,\n \"aria-activedescendant\": n ? E(n) : void 0,\n autoComplete: \"off\",\n onKeyDown: V,\n onFocus: j,\n onBlur: z,\n onMouseDown: G\n };\n return {\n rootRef: l,\n inputRef: x,\n inputId: N,\n inputProps: X,\n listboxProps: Q,\n getListboxItemProps: W,\n isOpen: c,\n openListbox: U,\n anchorStyle: Y\n };\n};\nexport {\n ee as useAutocomplete\n};\n//# sourceMappingURL=use-autocomplete.es.js.map\n"],"names":["p","m","O","r","v","h","K","u","S","T","P","w","M","Z","b","d","g","k","I","A","n","a","C","N","E","R","B","o","$","_","f","D","s","c","q","i","F","U","V","j","z","G","J","Q","W","X"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@purpur/library",
3
- "version": "9.0.9",
3
+ "version": "9.1.0",
4
4
  "license": "AGPL-3.0-only",
5
5
  "sideEffects": [
6
6
  "*.css",
@@ -113,64 +113,66 @@
113
113
  "@purpur/badge": "8.21.0",
114
114
  "@purpur/breadcrumbs": "8.21.0",
115
115
  "@purpur/button": "8.21.0",
116
- "@purpur/card": "8.21.0",
117
116
  "@purpur/calendar": "8.21.0",
118
- "@purpur/color-dot": "8.21.0",
119
117
  "@purpur/checkbox": "8.21.0",
120
118
  "@purpur/chip-group": "8.21.0",
119
+ "@purpur/card": "8.21.0",
120
+ "@purpur/color-dot": "8.21.0",
121
121
  "@purpur/common-types": "8.21.0",
122
- "@purpur/component-rig": "1.0.0",
123
122
  "@purpur/container": "8.21.0",
123
+ "@purpur/component-rig": "1.0.0",
124
124
  "@purpur/content-block": "8.21.0",
125
- "@purpur/countdown": "8.21.0",
126
- "@purpur/cta-link": "8.21.0",
127
125
  "@purpur/counter-badge": "8.21.0",
126
+ "@purpur/countdown": "8.21.0",
128
127
  "@purpur/date-field": "8.21.0",
128
+ "@purpur/cta-link": "8.21.0",
129
129
  "@purpur/date-picker": "8.21.0",
130
130
  "@purpur/dismissable-chip-group": "8.21.0",
131
131
  "@purpur/field-error-text": "8.21.0",
132
- "@purpur/drawer": "8.21.0",
133
- "@purpur/field-helper-text": "8.21.0",
134
132
  "@purpur/footer": "8.21.0",
133
+ "@purpur/drawer": "8.21.0",
134
+ "@purpur/grid": "8.21.0",
135
135
  "@purpur/heading": "8.21.0",
136
136
  "@purpur/hero-banner": "8.21.0",
137
- "@purpur/icon": "8.21.0",
138
- "@purpur/grid": "8.21.0",
137
+ "@purpur/field-helper-text": "8.21.0",
138
+ "@purpur/illustrative-icon": "8.21.0",
139
139
  "@purpur/label": "8.21.0",
140
140
  "@purpur/link": "8.21.0",
141
- "@purpur/illustrative-icon": "8.21.0",
142
- "@purpur/logo": "8.21.0",
141
+ "@purpur/icon": "8.21.0",
143
142
  "@purpur/listbox": "8.21.0",
143
+ "@purpur/logo": "8.21.0",
144
144
  "@purpur/modal": "8.21.0",
145
145
  "@purpur/notification-banner": "8.21.0",
146
146
  "@purpur/notification": "8.21.0",
147
147
  "@purpur/pagination": "8.21.0",
148
148
  "@purpur/paragraph": "8.21.0",
149
+ "@purpur/password-field": "8.21.0",
150
+ "@purpur/promotion-card": "8.21.0",
149
151
  "@purpur/popover": "8.21.0",
150
152
  "@purpur/product-card": "8.21.0",
151
- "@purpur/promotion-card": "8.21.0",
152
- "@purpur/quantity-selector": "8.21.0",
153
- "@purpur/password-field": "8.21.0",
154
153
  "@purpur/radio-button-group": "8.21.0",
154
+ "@purpur/quantity-selector": "8.21.0",
155
155
  "@purpur/radio-card-group": "8.21.0",
156
156
  "@purpur/rich-text": "8.21.0",
157
157
  "@purpur/skeleton": "8.21.0",
158
- "@purpur/slider": "8.21.0",
159
- "@purpur/spacer": "8.21.0",
160
158
  "@purpur/select": "8.21.0",
161
159
  "@purpur/search-field": "8.21.0",
160
+ "@purpur/spacer": "8.21.0",
161
+ "@purpur/slider": "8.21.0",
162
162
  "@purpur/spinner": "8.21.0",
163
163
  "@purpur/stepper": "8.21.0",
164
164
  "@purpur/table": "8.21.0",
165
- "@purpur/tabs": "8.21.0",
166
165
  "@purpur/text-area": "8.21.0",
167
166
  "@purpur/text-field": "8.21.0",
168
167
  "@purpur/text-spacing": "8.21.0",
168
+ "@purpur/tabs": "8.21.0",
169
169
  "@purpur/theme": "8.21.0",
170
- "@purpur/tokens": "8.21.0",
171
170
  "@purpur/toggle": "8.21.0",
172
171
  "@purpur/tooltip": "8.21.0",
173
- "@purpur/visually-hidden": "8.21.0"
172
+ "@purpur/tokens": "8.21.0",
173
+ "@purpur/chat-field": "9.1.0",
174
+ "@purpur/visually-hidden": "8.21.0",
175
+ "@purpur/dropdown": "0.1.0"
174
176
  },
175
177
  "peerDependencies": {
176
178
  "@types/react": "^18 || ^19",
package/src/aliases.ts CHANGED
@@ -41,6 +41,10 @@ export const aliases = [
41
41
  find: /^@purpur\/card$/,
42
42
  replacement: resolve(__dirname, "../../../components/card/src/card.tsx"),
43
43
  },
44
+ {
45
+ find: /^@purpur\/chat-field$/,
46
+ replacement: resolve(__dirname, "../../../components/chat-field/src/chat-field.tsx"),
47
+ },
44
48
  {
45
49
  find: /^@purpur\/checkbox$/,
46
50
  replacement: resolve(__dirname, "../../../components/checkbox/src/checkbox.tsx"),
@@ -92,6 +96,10 @@ export const aliases = [
92
96
  find: /^@purpur\/drawer$/,
93
97
  replacement: resolve(__dirname, "../../../components/drawer/src/drawer.tsx"),
94
98
  },
99
+ {
100
+ find: /^@purpur\/dropdown$/,
101
+ replacement: resolve(__dirname, "../../../components/dropdown/src/dropdown.tsx"),
102
+ },
95
103
  {
96
104
  find: /^@purpur\/field-error-text$/,
97
105
  replacement: resolve(
@@ -0,0 +1,6 @@
1
+ /**
2
+ * ⚠️ WARNING ⚠️
3
+ * This file is automatically generated, do not edit it manually
4
+ */
5
+
6
+ export * from "@purpur/chat-field";
@@ -0,0 +1,6 @@
1
+ /**
2
+ * ⚠️ WARNING ⚠️
3
+ * This file is automatically generated, do not edit it manually
4
+ */
5
+
6
+ export * from "@purpur/dropdown";
package/src/entries.js CHANGED
@@ -12,6 +12,7 @@ export const entries = [
12
12
  "button",
13
13
  "calendar",
14
14
  "card",
15
+ "chat-field",
15
16
  "checkbox",
16
17
  "chip-group",
17
18
  "color-dot",
@@ -24,6 +25,7 @@ export const entries = [
24
25
  "date-picker",
25
26
  "dismissable-chip-group",
26
27
  "drawer",
28
+ "dropdown",
27
29
  "field-error-text",
28
30
  "field-helper-text",
29
31
  "footer",
package/src/library.ts CHANGED
@@ -29,6 +29,8 @@ export * from "@purpur/calendar";
29
29
 
30
30
  export * from "@purpur/card";
31
31
 
32
+ export * from "@purpur/chat-field";
33
+
32
34
  export * from "@purpur/checkbox";
33
35
 
34
36
  export * from "@purpur/chip-group";
@@ -53,6 +55,8 @@ export * from "@purpur/dismissable-chip-group";
53
55
 
54
56
  export * from "@purpur/drawer";
55
57
 
58
+ export * from "@purpur/dropdown";
59
+
56
60
  export * from "@purpur/field-error-text";
57
61
 
58
62
  export * from "@purpur/field-helper-text";
@@ -4,6 +4,7 @@
4
4
  --purpur-border-radius-sm: 4px;
5
5
  --purpur-border-radius-md: 8px;
6
6
  --purpur-border-radius-lg: 16px;
7
+ --purpur-border-radius-xl: 24px;
7
8
  --purpur-border-radius-full: 999px;
8
9
  --purpur-border-width-xs: 1px;
9
10
  --purpur-border-width-sm: 2px;
@@ -2,6 +2,7 @@ export const purpurBorderRadiusXs: string;
2
2
  export const purpurBorderRadiusSm: string;
3
3
  export const purpurBorderRadiusMd: string;
4
4
  export const purpurBorderRadiusLg: string;
5
+ export const purpurBorderRadiusXl: string;
5
6
  export const purpurBorderRadiusFull: string;
6
7
  export const purpurBorderWidthXs: string;
7
8
  export const purpurBorderWidthSm: string;
@@ -3,6 +3,7 @@
3
3
  --purpur-border-radius-sm: 4px;
4
4
  --purpur-border-radius-md: 8px;
5
5
  --purpur-border-radius-lg: 16px;
6
+ --purpur-border-radius-xl: 24px;
6
7
  --purpur-border-radius-full: 999px;
7
8
  --purpur-border-width-xs: 1px;
8
9
  --purpur-border-width-sm: 2px;
@@ -2,6 +2,7 @@ export const purpurBorderRadiusXs: string;
2
2
  export const purpurBorderRadiusSm: string;
3
3
  export const purpurBorderRadiusMd: string;
4
4
  export const purpurBorderRadiusLg: string;
5
+ export const purpurBorderRadiusXl: string;
5
6
  export const purpurBorderRadiusFull: string;
6
7
  export const purpurBorderWidthXs: string;
7
8
  export const purpurBorderWidthSm: string;
@@ -2,6 +2,7 @@ export const purpurBorderRadiusXs = "2px";
2
2
  export const purpurBorderRadiusSm = "4px";
3
3
  export const purpurBorderRadiusMd = "8px";
4
4
  export const purpurBorderRadiusLg = "16px";
5
+ export const purpurBorderRadiusXl = "24px";
5
6
  export const purpurBorderRadiusFull = "999px";
6
7
  export const purpurBorderWidthXs = "1px";
7
8
  export const purpurBorderWidthSm = "2px";
@@ -5,6 +5,7 @@
5
5
  "sm": "4px",
6
6
  "md": "8px",
7
7
  "lg": "16px",
8
+ "xl": "24px",
8
9
  "full": "999px"
9
10
  },
10
11
  "width": {
@@ -2,6 +2,7 @@ $purpur-border-radius-xs: 2px;
2
2
  $purpur-border-radius-sm: 4px;
3
3
  $purpur-border-radius-md: 8px;
4
4
  $purpur-border-radius-lg: 16px;
5
+ $purpur-border-radius-xl: 24px;
5
6
  $purpur-border-radius-full: 999px;
6
7
  $purpur-border-width-xs: 1px;
7
8
  $purpur-border-width-sm: 2px;
@@ -2,6 +2,7 @@ export const purpurBorderRadiusXs = "2px";
2
2
  export const purpurBorderRadiusSm = "4px";
3
3
  export const purpurBorderRadiusMd = "8px";
4
4
  export const purpurBorderRadiusLg = "16px";
5
+ export const purpurBorderRadiusXl = "24px";
5
6
  export const purpurBorderRadiusFull = "999px";
6
7
  export const purpurBorderWidthXs = "1px";
7
8
  export const purpurBorderWidthSm = "2px";
@@ -5,6 +5,7 @@
5
5
  "sm": "4px",
6
6
  "md": "8px",
7
7
  "lg": "16px",
8
+ "xl": "24px",
8
9
  "full": "999px"
9
10
  },
10
11
  "width": {
@@ -2,6 +2,7 @@ $purpur-border-radius-xs: 2px;
2
2
  $purpur-border-radius-sm: 4px;
3
3
  $purpur-border-radius-md: 8px;
4
4
  $purpur-border-radius-lg: 16px;
5
+ $purpur-border-radius-xl: 24px;
5
6
  $purpur-border-radius-full: 999px;
6
7
  $purpur-border-width-xs: 1px;
7
8
  $purpur-border-width-sm: 2px;
@@ -1,2 +0,0 @@
1
- "use strict";const a=require("react/jsx-runtime"),R=require("react"),f=require("./spinner-tKunS_o-.js"),E=require("./bind-DeUYJ6m9.js"),N={PRIMARY:"primary",SECONDARY:"secondary",EXPRESSIVE:"expressive"},$={LG:"lg"},A={"purpur-button":"_purpur-button_1g3z1_1","purpur-button--xs":"_purpur-button--xs_1g3z1_22","purpur-button--icon-only":"_purpur-button--icon-only_1g3z1_25","purpur-button--sm":"_purpur-button--sm_1g3z1_28","purpur-button--md":"_purpur-button--md_1g3z1_34","purpur-button--lg":"_purpur-button--lg_1g3z1_40","purpur-button--full-width":"_purpur-button--full-width_1g3z1_46","purpur-button--primary":"_purpur-button--primary_1g3z1_64","purpur-button--disabled":"_purpur-button--disabled_1g3z1_68","purpur-button--primary-negative":"_purpur-button--primary-negative_1g3z1_74","purpur-button--secondary":"_purpur-button--secondary_1g3z1_86","purpur-button--secondary-negative":"_purpur-button--secondary-negative_1g3z1_97","purpur-button--expressive":"_purpur-button--expressive_1g3z1_108","purpur-button--expressive-negative":"_purpur-button--expressive-negative_1g3z1_118","purpur-button--negative":"_purpur-button--negative_1g3z1_130","purpur-button--destructive":"_purpur-button--destructive_1g3z1_137","purpur-button--destructive-negative":"_purpur-button--destructive-negative_1g3z1_147","purpur-button--tertiary-purple":"_purpur-button--tertiary-purple_1g3z1_157","purpur-button--tertiary-purple-negative":"_purpur-button--tertiary-purple-negative_1g3z1_170","purpur-button--text":"_purpur-button--text_1g3z1_185","purpur-button--text-negative":"_purpur-button--text-negative_1g3z1_207","purpur-button__spinner":"_purpur-button__spinner_1g3z1_235"},l={...N,DESTRUCTIVE:"destructive",TERTIARY_PURPLE:"tertiary-purple",TEXT:"text"},B=Object.values(l),c=E.c.bind(A),t="purpur-button",I=["button","submit","reset"],g=R.forwardRef(({children:d,className:v,disabled:r=!1,fullWidth:z=!1,iconOnly:n,loading:u=!1,negative:e=!1,onClick:o,size:s="md",variant:p,type:x="button",..._},y)=>{if(n&&p==="destructive")return null;const T=c([t,`${t}--${e?`${p}-negative`:p}`,`${t}--${s}`],{[`${t}--icon-only`]:n,[`${t}--negative`]:e,[`${t}--full-width`]:z,[`${t}--disabled`]:r||u},v),m=b=>{r||u?b.preventDefault():o&&o(b)},i=!!_["aria-disabled"]||r||u;return a.jsxs("button",{className:T,type:x,ref:y,"aria-disabled":i,onClick:m,..._,children:[u&&a.jsx(f.Spinner,{size:s===$.LG?"xs":"xxs",negative:e,disabled:i,className:c(`${t}__spinner`)})," ",d]})});g.displayName="Button";exports.BUTTON_TYPES=I;exports.BUTTON_VARIANT=l;exports.Button=g;exports.buttonVariants=B;
2
- //# sourceMappingURL=button-BxdChrq-.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"button-BxdChrq-.js","sources":["../../action/src/action.tsx","../../../components/button/src/button.tsx"],"sourcesContent":["import { type ReactNode } from \"react\";\n\nexport const VARIANT = {\n PRIMARY: \"primary\",\n SECONDARY: \"secondary\",\n EXPRESSIVE: \"expressive\",\n} as const;\n\nexport const variants = Object.values(VARIANT);\nexport type Variant = (typeof VARIANT)[keyof typeof VARIANT];\n\nexport const SIZE = {\n XS: \"xs\",\n SM: \"sm\",\n MD: \"md\",\n LG: \"lg\",\n} as const;\n\nexport const sizes = Object.values(SIZE);\nexport type Size = (typeof SIZE)[keyof typeof SIZE];\n\ntype DefaultProps<TVariant, T = object> = {\n [\"data-testid\"]?: string;\n children?: ReactNode;\n className?: string;\n fullWidth?: boolean;\n negative?: boolean;\n size?: Size;\n variant: TVariant | Variant;\n} & T;\n\nexport type UnionParams<TVariant> =\n | DefaultProps<TVariant, { iconOnly: boolean; [\"aria-label\"]: string }>\n | DefaultProps<TVariant, { [\"aria-label\"]?: string }>;\n\ntype UnionKeys<T> = T extends T ? keyof T : never;\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype StrictUnionHelper<T, TAll> = T extends any\n ? T & Partial<Record<Exclude<UnionKeys<TAll>, keyof T>, never>>\n : never;\n\ntype StrictUnion<T> = StrictUnionHelper<T, T>;\n\nexport type ActionProps<TVariant extends string = Variant> = StrictUnion<UnionParams<TVariant>>;\n","import React, { type ButtonHTMLAttributes, forwardRef, type MouseEvent } from \"react\";\nimport { type ActionProps, SIZE, VARIANT } from \"@purpur/action\";\nimport type { BaseProps } from \"@purpur/common-types\";\nimport { Spinner } from \"@purpur/spinner\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./button.module.scss\";\n\nexport const BUTTON_VARIANT = {\n ...VARIANT,\n DESTRUCTIVE: \"destructive\",\n TERTIARY_PURPLE: \"tertiary-purple\",\n TEXT: \"text\",\n} as const;\n\nexport const buttonVariants = Object.values(BUTTON_VARIANT);\nexport type ButtonVariant = (typeof BUTTON_VARIANT)[keyof typeof BUTTON_VARIANT];\n\nconst cx = c.bind(styles);\nconst rootClassName = \"purpur-button\";\n\ntype ButtonType = Pick<ButtonHTMLAttributes<HTMLButtonElement>, \"type\">[\"type\"];\nexport const BUTTON_TYPES: ButtonType[] = [\"button\", \"submit\", \"reset\"] as const;\n\ntype ButtonBaseProps = BaseProps<\"button\"> & { loading?: boolean };\n\nexport type ButtonProps =\n | (ActionProps<ButtonVariant> & ButtonBaseProps & { iconOnly?: false | undefined })\n | (ActionProps<Exclude<ButtonVariant, \"destructive\">> & ButtonBaseProps & { iconOnly: true });\n\ntype DistributiveOmit<T, K extends keyof never> = T extends unknown ? Omit<T, K> : never;\n\nexport const Button = forwardRef<\n HTMLButtonElement,\n DistributiveOmit<ButtonProps, \"type\"> & { type?: ButtonType }\n>(\n (\n {\n children,\n className,\n disabled = false,\n fullWidth = false,\n iconOnly,\n loading = false,\n negative = false,\n onClick,\n size = \"md\",\n variant,\n type = \"button\",\n ...props\n },\n ref\n ) => {\n if (iconOnly && variant === (\"destructive\" as string)) {\n return null;\n }\n\n const classes = cx(\n [\n rootClassName,\n `${rootClassName}--${negative ? `${variant}-negative` : variant}`,\n `${rootClassName}--${size}`,\n ],\n {\n [`${rootClassName}--icon-only`]: iconOnly,\n [`${rootClassName}--negative`]: negative,\n [`${rootClassName}--full-width`]: fullWidth,\n [`${rootClassName}--disabled`]: disabled || loading,\n },\n className\n );\n\n const handleClick = (e: MouseEvent<HTMLButtonElement>) => {\n if (disabled || loading) {\n e.preventDefault();\n } else if (onClick) {\n onClick(e);\n }\n };\n\n const _disabled = Boolean(props[\"aria-disabled\"]) || disabled || loading;\n\n return (\n <button\n className={classes}\n type={type}\n ref={ref}\n aria-disabled={_disabled}\n onClick={handleClick}\n {...props}\n >\n {loading && (\n <Spinner\n size={size === SIZE.LG ? \"xs\" : \"xxs\"}\n negative={negative}\n disabled={_disabled}\n className={cx(`${rootClassName}__spinner`)}\n />\n )}{\" \"}\n {children}\n </button>\n );\n }\n);\n\nButton.displayName = \"Button\";\n"],"names":["VARIANT","SIZE","BUTTON_VARIANT","buttonVariants","cx","c","styles","rootClassName","BUTTON_TYPES","Button","forwardRef","children","className","disabled","fullWidth","iconOnly","loading","negative","onClick","size","variant","type","props","ref","classes","handleClick","e","_disabled","jsxs","jsx","Spinner"],"mappings":"wIAEaA,EAAU,CACrB,QAAS,UACT,UAAW,YACX,WAAY,YACd,EAKaC,EAAO,CAIlB,GAAI,IACN,+6CCRaC,EAAiB,CAC5B,GAAGF,EACH,YAAa,cACb,gBAAiB,kBACjB,KAAM,MACR,EAEaG,EAAiB,OAAO,OAAOD,CAAc,EAGpDE,EAAKC,EAAAA,EAAE,KAAKC,CAAM,EAClBC,EAAgB,gBAGTC,EAA6B,CAAC,SAAU,SAAU,OAAO,EAUzDC,EAASC,EAAAA,WAIpB,CACE,CACE,SAAAC,EACA,UAAAC,EACA,SAAAC,EAAW,GACX,UAAAC,EAAY,GACZ,SAAAC,EACA,QAAAC,EAAU,GACV,SAAAC,EAAW,GACX,QAAAC,EACA,KAAAC,EAAO,KACP,QAAAC,EACA,KAAAC,EAAO,SACP,GAAGC,CAAA,EAELC,IACG,CACH,GAAIR,GAAYK,IAAa,cAC3B,OAAO,KAGT,MAAMI,EAAUpB,EACd,CACEG,EACA,GAAGA,CAAa,KAAKU,EAAW,GAAGG,CAAO,YAAcA,CAAO,GAC/D,GAAGb,CAAa,KAAKY,CAAI,EAAA,EAE3B,CACE,CAAC,GAAGZ,CAAa,aAAa,EAAGQ,EACjC,CAAC,GAAGR,CAAa,YAAY,EAAGU,EAChC,CAAC,GAAGV,CAAa,cAAc,EAAGO,EAClC,CAAC,GAAGP,CAAa,YAAY,EAAGM,GAAYG,CAAA,EAE9CJ,CAAA,EAGIa,EAAeC,GAAqC,CACpDb,GAAYG,EACdU,EAAE,eAAA,EACOR,GACTA,EAAQQ,CAAC,CAEb,EAEMC,EAAY,EAAQL,EAAM,eAAe,GAAMT,GAAYG,EAEjE,OACEY,EAAAA,KAAC,SAAA,CACC,UAAWJ,EACX,KAAAH,EACA,IAAAE,EACA,gBAAeI,EACf,QAASF,EACR,GAAGH,EAEH,SAAA,CAAAN,GACCa,EAAAA,IAACC,EAAAA,QAAA,CACC,KAAMX,IAASlB,EAAK,GAAK,KAAO,MAChC,SAAAgB,EACA,SAAUU,EACV,UAAWvB,EAAG,GAAGG,CAAa,WAAW,CAAA,CAAA,EAE1C,IACFI,CAAA,CAAA,CAAA,CAGP,CACF,EAEAF,EAAO,YAAc"}
@@ -1,105 +0,0 @@
1
- import { jsxs as x, jsx as y } from "react/jsx-runtime";
2
- import { forwardRef as f } from "react";
3
- import { a as T } from "./spinner-DRQN6YdK.mjs";
4
- import { c as E } from "./bind-CU-R61T-.mjs";
5
- const R = {
6
- PRIMARY: "primary",
7
- SECONDARY: "secondary",
8
- EXPRESSIVE: "expressive"
9
- }, $ = {
10
- LG: "lg"
11
- }, N = {
12
- "purpur-button": "_purpur-button_1g3z1_1",
13
- "purpur-button--xs": "_purpur-button--xs_1g3z1_22",
14
- "purpur-button--icon-only": "_purpur-button--icon-only_1g3z1_25",
15
- "purpur-button--sm": "_purpur-button--sm_1g3z1_28",
16
- "purpur-button--md": "_purpur-button--md_1g3z1_34",
17
- "purpur-button--lg": "_purpur-button--lg_1g3z1_40",
18
- "purpur-button--full-width": "_purpur-button--full-width_1g3z1_46",
19
- "purpur-button--primary": "_purpur-button--primary_1g3z1_64",
20
- "purpur-button--disabled": "_purpur-button--disabled_1g3z1_68",
21
- "purpur-button--primary-negative": "_purpur-button--primary-negative_1g3z1_74",
22
- "purpur-button--secondary": "_purpur-button--secondary_1g3z1_86",
23
- "purpur-button--secondary-negative": "_purpur-button--secondary-negative_1g3z1_97",
24
- "purpur-button--expressive": "_purpur-button--expressive_1g3z1_108",
25
- "purpur-button--expressive-negative": "_purpur-button--expressive-negative_1g3z1_118",
26
- "purpur-button--negative": "_purpur-button--negative_1g3z1_130",
27
- "purpur-button--destructive": "_purpur-button--destructive_1g3z1_137",
28
- "purpur-button--destructive-negative": "_purpur-button--destructive-negative_1g3z1_147",
29
- "purpur-button--tertiary-purple": "_purpur-button--tertiary-purple_1g3z1_157",
30
- "purpur-button--tertiary-purple-negative": "_purpur-button--tertiary-purple-negative_1g3z1_170",
31
- "purpur-button--text": "_purpur-button--text_1g3z1_185",
32
- "purpur-button--text-negative": "_purpur-button--text-negative_1g3z1_207",
33
- "purpur-button__spinner": "_purpur-button__spinner_1g3z1_235"
34
- }, A = {
35
- ...R,
36
- DESTRUCTIVE: "destructive",
37
- TERTIARY_PURPLE: "tertiary-purple",
38
- TEXT: "text"
39
- }, V = Object.values(A), b = E.bind(N), t = "purpur-button", w = ["button", "submit", "reset"], I = f(
40
- ({
41
- children: l,
42
- className: g,
43
- disabled: r = !1,
44
- fullWidth: c = !1,
45
- iconOnly: n,
46
- loading: u = !1,
47
- negative: p = !1,
48
- onClick: o,
49
- size: _ = "md",
50
- variant: e,
51
- type: d = "button",
52
- ...s
53
- }, v) => {
54
- if (n && e === "destructive")
55
- return null;
56
- const m = b(
57
- [
58
- t,
59
- `${t}--${p ? `${e}-negative` : e}`,
60
- `${t}--${_}`
61
- ],
62
- {
63
- [`${t}--icon-only`]: n,
64
- [`${t}--negative`]: p,
65
- [`${t}--full-width`]: c,
66
- [`${t}--disabled`]: r || u
67
- },
68
- g
69
- ), z = (a) => {
70
- r || u ? a.preventDefault() : o && o(a);
71
- }, i = !!s["aria-disabled"] || r || u;
72
- return /* @__PURE__ */ x(
73
- "button",
74
- {
75
- className: m,
76
- type: d,
77
- ref: v,
78
- "aria-disabled": i,
79
- onClick: z,
80
- ...s,
81
- children: [
82
- u && /* @__PURE__ */ y(
83
- T,
84
- {
85
- size: _ === $.LG ? "xs" : "xxs",
86
- negative: p,
87
- disabled: i,
88
- className: b(`${t}__spinner`)
89
- }
90
- ),
91
- " ",
92
- l
93
- ]
94
- }
95
- );
96
- }
97
- );
98
- I.displayName = "Button";
99
- export {
100
- w as B,
101
- A as a,
102
- I as b,
103
- V as c
104
- };
105
- //# sourceMappingURL=button-D-BBdNhd.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"button-D-BBdNhd.mjs","sources":["../../action/src/action.tsx","../../../components/button/src/button.tsx"],"sourcesContent":["import { type ReactNode } from \"react\";\n\nexport const VARIANT = {\n PRIMARY: \"primary\",\n SECONDARY: \"secondary\",\n EXPRESSIVE: \"expressive\",\n} as const;\n\nexport const variants = Object.values(VARIANT);\nexport type Variant = (typeof VARIANT)[keyof typeof VARIANT];\n\nexport const SIZE = {\n XS: \"xs\",\n SM: \"sm\",\n MD: \"md\",\n LG: \"lg\",\n} as const;\n\nexport const sizes = Object.values(SIZE);\nexport type Size = (typeof SIZE)[keyof typeof SIZE];\n\ntype DefaultProps<TVariant, T = object> = {\n [\"data-testid\"]?: string;\n children?: ReactNode;\n className?: string;\n fullWidth?: boolean;\n negative?: boolean;\n size?: Size;\n variant: TVariant | Variant;\n} & T;\n\nexport type UnionParams<TVariant> =\n | DefaultProps<TVariant, { iconOnly: boolean; [\"aria-label\"]: string }>\n | DefaultProps<TVariant, { [\"aria-label\"]?: string }>;\n\ntype UnionKeys<T> = T extends T ? keyof T : never;\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype StrictUnionHelper<T, TAll> = T extends any\n ? T & Partial<Record<Exclude<UnionKeys<TAll>, keyof T>, never>>\n : never;\n\ntype StrictUnion<T> = StrictUnionHelper<T, T>;\n\nexport type ActionProps<TVariant extends string = Variant> = StrictUnion<UnionParams<TVariant>>;\n","import React, { type ButtonHTMLAttributes, forwardRef, type MouseEvent } from \"react\";\nimport { type ActionProps, SIZE, VARIANT } from \"@purpur/action\";\nimport type { BaseProps } from \"@purpur/common-types\";\nimport { Spinner } from \"@purpur/spinner\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./button.module.scss\";\n\nexport const BUTTON_VARIANT = {\n ...VARIANT,\n DESTRUCTIVE: \"destructive\",\n TERTIARY_PURPLE: \"tertiary-purple\",\n TEXT: \"text\",\n} as const;\n\nexport const buttonVariants = Object.values(BUTTON_VARIANT);\nexport type ButtonVariant = (typeof BUTTON_VARIANT)[keyof typeof BUTTON_VARIANT];\n\nconst cx = c.bind(styles);\nconst rootClassName = \"purpur-button\";\n\ntype ButtonType = Pick<ButtonHTMLAttributes<HTMLButtonElement>, \"type\">[\"type\"];\nexport const BUTTON_TYPES: ButtonType[] = [\"button\", \"submit\", \"reset\"] as const;\n\ntype ButtonBaseProps = BaseProps<\"button\"> & { loading?: boolean };\n\nexport type ButtonProps =\n | (ActionProps<ButtonVariant> & ButtonBaseProps & { iconOnly?: false | undefined })\n | (ActionProps<Exclude<ButtonVariant, \"destructive\">> & ButtonBaseProps & { iconOnly: true });\n\ntype DistributiveOmit<T, K extends keyof never> = T extends unknown ? Omit<T, K> : never;\n\nexport const Button = forwardRef<\n HTMLButtonElement,\n DistributiveOmit<ButtonProps, \"type\"> & { type?: ButtonType }\n>(\n (\n {\n children,\n className,\n disabled = false,\n fullWidth = false,\n iconOnly,\n loading = false,\n negative = false,\n onClick,\n size = \"md\",\n variant,\n type = \"button\",\n ...props\n },\n ref\n ) => {\n if (iconOnly && variant === (\"destructive\" as string)) {\n return null;\n }\n\n const classes = cx(\n [\n rootClassName,\n `${rootClassName}--${negative ? `${variant}-negative` : variant}`,\n `${rootClassName}--${size}`,\n ],\n {\n [`${rootClassName}--icon-only`]: iconOnly,\n [`${rootClassName}--negative`]: negative,\n [`${rootClassName}--full-width`]: fullWidth,\n [`${rootClassName}--disabled`]: disabled || loading,\n },\n className\n );\n\n const handleClick = (e: MouseEvent<HTMLButtonElement>) => {\n if (disabled || loading) {\n e.preventDefault();\n } else if (onClick) {\n onClick(e);\n }\n };\n\n const _disabled = Boolean(props[\"aria-disabled\"]) || disabled || loading;\n\n return (\n <button\n className={classes}\n type={type}\n ref={ref}\n aria-disabled={_disabled}\n onClick={handleClick}\n {...props}\n >\n {loading && (\n <Spinner\n size={size === SIZE.LG ? \"xs\" : \"xxs\"}\n negative={negative}\n disabled={_disabled}\n className={cx(`${rootClassName}__spinner`)}\n />\n )}{\" \"}\n {children}\n </button>\n );\n }\n);\n\nButton.displayName = \"Button\";\n"],"names":["VARIANT","SIZE","BUTTON_VARIANT","buttonVariants","cx","c","styles","rootClassName","BUTTON_TYPES","Button","forwardRef","children","className","disabled","fullWidth","iconOnly","loading","negative","onClick","size","variant","type","props","ref","classes","handleClick","e","_disabled","jsxs","jsx","Spinner"],"mappings":";;;;AAEO,MAAMA,IAAU;AAAA,EACrB,SAAS;AAAA,EACT,WAAW;AAAA,EACX,YAAY;AACd,GAKaC,IAAO;AAAA,EAIlB,IAAI;AACN;;;;;;;;;;;;;;;;;;;;;;;GCRaC,IAAiB;AAAA,EAC5B,GAAGF;AAAA,EACH,aAAa;AAAA,EACb,iBAAiB;AAAA,EACjB,MAAM;AACR,GAEaG,IAAiB,OAAO,OAAOD,CAAc,GAGpDE,IAAKC,EAAE,KAAKC,CAAM,GAClBC,IAAgB,iBAGTC,IAA6B,CAAC,UAAU,UAAU,OAAO,GAUzDC,IAASC;AAAA,EAIpB,CACE;AAAA,IACE,UAAAC;AAAA,IACA,WAAAC;AAAA,IACA,UAAAC,IAAW;AAAA,IACX,WAAAC,IAAY;AAAA,IACZ,UAAAC;AAAA,IACA,SAAAC,IAAU;AAAA,IACV,UAAAC,IAAW;AAAA,IACX,SAAAC;AAAA,IACA,MAAAC,IAAO;AAAA,IACP,SAAAC;AAAA,IACA,MAAAC,IAAO;AAAA,IACP,GAAGC;AAAA,EAAA,GAELC,MACG;AACH,QAAIR,KAAYK,MAAa;AAC3B,aAAO;AAGT,UAAMI,IAAUpB;AAAA,MACd;AAAA,QACEG;AAAA,QACA,GAAGA,CAAa,KAAKU,IAAW,GAAGG,CAAO,cAAcA,CAAO;AAAA,QAC/D,GAAGb,CAAa,KAAKY,CAAI;AAAA,MAAA;AAAA,MAE3B;AAAA,QACE,CAAC,GAAGZ,CAAa,aAAa,GAAGQ;AAAA,QACjC,CAAC,GAAGR,CAAa,YAAY,GAAGU;AAAA,QAChC,CAAC,GAAGV,CAAa,cAAc,GAAGO;AAAA,QAClC,CAAC,GAAGP,CAAa,YAAY,GAAGM,KAAYG;AAAA,MAAA;AAAA,MAE9CJ;AAAA,IAAA,GAGIa,IAAc,CAACC,MAAqC;AACxD,MAAIb,KAAYG,IACdU,EAAE,eAAA,IACOR,KACTA,EAAQQ,CAAC;AAAA,IAEb,GAEMC,IAAY,EAAQL,EAAM,eAAe,KAAMT,KAAYG;AAEjE,WACE,gBAAAY;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,WAAWJ;AAAA,QACX,MAAAH;AAAA,QACA,KAAAE;AAAA,QACA,iBAAeI;AAAA,QACf,SAASF;AAAA,QACR,GAAGH;AAAA,QAEH,UAAA;AAAA,UAAAN,KACC,gBAAAa;AAAA,YAACC;AAAA,YAAA;AAAA,cACC,MAAMX,MAASlB,EAAK,KAAK,OAAO;AAAA,cAChC,UAAAgB;AAAA,cACA,UAAUU;AAAA,cACV,WAAWvB,EAAG,GAAGG,CAAa,WAAW;AAAA,YAAA;AAAA,UAAA;AAAA,UAE1C;AAAA,UACFI;AAAA,QAAA;AAAA,MAAA;AAAA,IAAA;AAAA,EAGP;AACF;AAEAF,EAAO,cAAc;"}
@@ -1,2 +0,0 @@
1
- "use strict";const e=require("react/jsx-runtime"),d=require("react"),j=require("./heading-drD5ugCC.js"),_=require("./bind-DeUYJ6m9.js"),k=require("./close.es-VL3lKi1O.js"),b={"purpur-dismissable-chip-group":"_purpur-dismissable-chip-group_17jk4_1","purpur-dismissable-chip-group__container":"_purpur-dismissable-chip-group__container_17jk4_7","purpur-dismissable-chip-group__container--full-width":"_purpur-dismissable-chip-group__container--full-width_17jk4_14","purpur-dismissable-chip-group-item-wrapper":"_purpur-dismissable-chip-group-item-wrapper_17jk4_17","purpur-dismissable-chip-group-item":"_purpur-dismissable-chip-group-item_17jk4_17","purpur-dismissable-chip-group-item--disabled":"_purpur-dismissable-chip-group-item--disabled_17jk4_43"},n=_.c.bind(b),c="purpur-dismissable-chip-group-item",h=({children:r,id:i,onDismiss:p,disabled:s,...a})=>{const u=l=>{s?l.preventDefault():p?.(i)};return e.jsx("li",{className:n(`${c}-wrapper`),children:d.createElement("button",{...a,className:n(`${c}`,{[`${c}--disabled`]:s}),key:i,disabled:s,"aria-disabled":s,onClick:u},r,e.jsx(k.r,{size:"sm"}))},i)};h.displayName="DismissableChipGroupItem";const m=_.c.bind(b),o="purpur-dismissable-chip-group",t=({children:r,className:i,fullWidth:p=!1,title:s,titleTag:a,...u})=>{const l=d.useId(),g=m([o,i]);return e.jsxs("div",{...u,"aria-labelledby":s?`${l}-label`:void 0,className:g,role:"group",children:[s&&e.jsx(j.Heading,{tag:a??"h2",variant:"subsection-100",children:s}),e.jsx("ul",{"data-testid":"dismissable-chip-group-container",className:m(`${o}__container`,{[`${o}__container--full-width`]:p}),"aria-live":"polite","aria-relevant":"additions removals",children:r})]})};t.Item=h;t.displayName="DismissableChipGroup";exports.DismissableChipGroup=t;
2
- //# sourceMappingURL=dismissable-chip-group-CnziecOt.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"dismissable-chip-group-CnziecOt.js","sources":["../../../components/dismissable-chip-group/src/dismissable-chip-group-item.tsx","../../../components/dismissable-chip-group/src/dismissable-chip-group.tsx"],"sourcesContent":["import React, { type MouseEvent, type ReactNode } from \"react\";\nimport type { BaseProps } from \"@purpur/common-types\";\nimport { IconClose } from \"@purpur/icon/close\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./dismissable-chip-group.module.scss\";\n\nconst cx = c.bind(styles);\n\nexport type DismissableChipGroupItemProps = Omit<BaseProps<\"button\">, \"aria-label\" | \"children\"> & {\n [\"aria-label\"]: string;\n children: ReactNode;\n onDismiss?: (id?: string) => void;\n};\n\nconst rootClassName = \"purpur-dismissable-chip-group-item\";\n\nexport const DismissableChipGroupItem = ({\n children,\n id,\n onDismiss,\n disabled,\n ...props\n}: DismissableChipGroupItemProps) => {\n const handleClick = (e: MouseEvent<HTMLButtonElement>) => {\n if (disabled) {\n e.preventDefault();\n } else {\n onDismiss?.(id);\n }\n };\n\n return (\n <li key={id} className={cx(`${rootClassName}-wrapper`)}>\n <button\n {...props}\n className={cx(`${rootClassName}`, {\n [`${rootClassName}--disabled`]: disabled,\n })}\n key={id}\n disabled={disabled}\n aria-disabled={disabled}\n onClick={handleClick}\n >\n {children}\n <IconClose size=\"sm\" />\n </button>\n </li>\n );\n};\n\nDismissableChipGroupItem.displayName = \"DismissableChipGroupItem\";\n","import React, { type ReactNode, useId } from \"react\";\nimport type { BaseProps } from \"@purpur/common-types\";\nimport { Heading, type HeadingTagType } from \"@purpur/heading\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./dismissable-chip-group.module.scss\";\nimport { DismissableChipGroupItem } from \"./dismissable-chip-group-item\";\n\nconst cx = c.bind(styles);\n\nexport type DismissableChipGroupProps = Omit<BaseProps, \"children\"> & {\n children: ReactNode;\n fullWidth?: boolean;\n title?: string;\n titleTag?: HeadingTagType;\n};\n\nconst rootClassName = \"purpur-dismissable-chip-group\";\n\nexport const DismissableChipGroup = ({\n children,\n className,\n fullWidth = false,\n title,\n titleTag,\n ...props\n}: DismissableChipGroupProps) => {\n const id = useId();\n const classes = cx([rootClassName, className]);\n\n return (\n <div\n {...props}\n aria-labelledby={title ? `${id}-label` : undefined}\n className={classes}\n role=\"group\"\n >\n {title && (\n <Heading tag={titleTag ?? \"h2\"} variant=\"subsection-100\">\n {title}\n </Heading>\n )}\n <ul\n data-testid=\"dismissable-chip-group-container\"\n className={cx(`${rootClassName}__container`, {\n [`${rootClassName}__container--full-width`]: fullWidth,\n })}\n aria-live=\"polite\"\n aria-relevant=\"additions removals\"\n >\n {children}\n </ul>\n </div>\n );\n};\n\nDismissableChipGroup.Item = DismissableChipGroupItem;\n\nDismissableChipGroup.displayName = \"DismissableChipGroup\";\n"],"names":["cx","c","styles","rootClassName","DismissableChipGroupItem","children","id","onDismiss","disabled","props","handleClick","e","createElement","jsx","IconClose","DismissableChipGroup","className","fullWidth","title","titleTag","useId","classes","jsxs","Heading"],"mappings":"gvBAOMA,EAAKC,EAAAA,EAAE,KAAKC,CAAM,EAQlBC,EAAgB,qCAETC,EAA2B,CAAC,CACvC,SAAAC,EACA,GAAAC,EACA,UAAAC,EACA,SAAAC,EACA,GAAGC,CACL,IAAqC,CACnC,MAAMC,EAAeC,GAAqC,CACpDH,EACFG,EAAE,eAAA,EAEFJ,IAAYD,CAAE,CAElB,EAEA,aACG,KAAA,CAAY,UAAWN,EAAG,GAAGG,CAAa,UAAU,EACnD,SAAAS,EAAAA,cAAC,SAAA,CACE,GAAGH,EACJ,UAAWT,EAAG,GAAGG,CAAa,GAAI,CAChC,CAAC,GAAGA,CAAa,YAAY,EAAGK,CAAA,CACjC,EACD,IAAKF,EACL,SAAAE,EACA,gBAAeA,EACf,QAASE,CAAA,EAERL,EACDQ,EAAAA,IAACC,EAAAA,EAAA,CAAU,KAAK,IAAA,CAAK,CAAA,GAZhBR,CAcT,CAEJ,EAEAF,EAAyB,YAAc,2BC3CvC,MAAMJ,EAAKC,EAAAA,EAAE,KAAKC,CAAM,EASlBC,EAAgB,gCAETY,EAAuB,CAAC,CACnC,SAAAV,EACA,UAAAW,EACA,UAAAC,EAAY,GACZ,MAAAC,EACA,SAAAC,EACA,GAAGV,CACL,IAAiC,CAC/B,MAAMH,EAAKc,EAAAA,MAAA,EACLC,EAAUrB,EAAG,CAACG,EAAea,CAAS,CAAC,EAE7C,OACEM,EAAAA,KAAC,MAAA,CACE,GAAGb,EACJ,kBAAiBS,EAAQ,GAAGZ,CAAE,SAAW,OACzC,UAAWe,EACX,KAAK,QAEJ,SAAA,CAAAH,SACEK,UAAA,CAAQ,IAAKJ,GAAY,KAAM,QAAQ,iBACrC,SAAAD,CAAA,CACH,EAEFL,EAAAA,IAAC,KAAA,CACC,cAAY,mCACZ,UAAWb,EAAG,GAAGG,CAAa,cAAe,CAC3C,CAAC,GAAGA,CAAa,yBAAyB,EAAGc,CAAA,CAC9C,EACD,YAAU,SACV,gBAAc,qBAEb,SAAAZ,CAAA,CAAA,CACH,CAAA,CAAA,CAGN,EAEAU,EAAqB,KAAOX,EAE5BW,EAAqB,YAAc"}