@bspk/ui 1.1.34 → 1.2.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 (961) hide show
  1. package/build.ts +75 -27
  2. package/dist/components/Accordion/Accordion.d.ts +34 -0
  3. package/dist/components/Accordion/Accordion.js +42 -0
  4. package/dist/components/Accordion/Accordion.js.map +1 -0
  5. package/dist/components/Accordion/AccordionExample.d.ts +3 -0
  6. package/dist/components/Accordion/AccordionExample.js +72 -0
  7. package/dist/components/Accordion/AccordionExample.js.map +1 -0
  8. package/dist/components/Accordion/AccordionSection.d.ts +84 -0
  9. package/dist/components/Accordion/AccordionSection.js +27 -0
  10. package/dist/components/Accordion/AccordionSection.js.map +1 -0
  11. package/dist/components/Accordion/accordion.css +74 -0
  12. package/dist/components/Accordion/accordion.css.js +79 -0
  13. package/dist/components/Accordion/index.d.ts +1 -0
  14. package/dist/components/Accordion/index.js +2 -0
  15. package/dist/components/Accordion/index.js.map +1 -0
  16. package/dist/components/Avatar/Avatar.d.ts +16 -12
  17. package/dist/components/Avatar/Avatar.js +7 -9
  18. package/dist/components/Avatar/Avatar.js.map +1 -1
  19. package/dist/components/Avatar/AvatarExample.d.ts +1 -1
  20. package/dist/components/Avatar/AvatarExample.js +11 -2
  21. package/dist/components/Avatar/AvatarExample.js.map +1 -1
  22. package/dist/components/Avatar/avatar.css +27 -1
  23. package/dist/components/Avatar/avatar.css.js +27 -2
  24. package/dist/components/AvatarGroup/AvatarGroup.d.ts +10 -12
  25. package/dist/components/AvatarGroup/AvatarGroup.js +6 -6
  26. package/dist/components/AvatarGroup/AvatarGroup.js.map +1 -1
  27. package/dist/components/AvatarGroup/AvatarGroupExample.d.ts +3 -0
  28. package/dist/components/AvatarGroup/AvatarGroupExample.js +31 -0
  29. package/dist/components/AvatarGroup/AvatarGroupExample.js.map +1 -0
  30. package/dist/components/AvatarGroup/avatar-group.css +12 -1
  31. package/dist/components/AvatarGroup/avatar-group.css.js +12 -2
  32. package/dist/components/Badge/Badge.d.ts +6 -12
  33. package/dist/components/Badge/Badge.js +8 -10
  34. package/dist/components/Badge/Badge.js.map +1 -1
  35. package/dist/components/Badge/BadgeExample.d.ts +1 -1
  36. package/dist/components/Badge/BadgeExample.js +7 -38
  37. package/dist/components/Badge/BadgeExample.js.map +1 -1
  38. package/dist/components/Badge/badge.css +15 -24
  39. package/dist/components/Badge/badge.css.js +15 -25
  40. package/dist/components/BadgeDot/BadgeDot.d.ts +47 -0
  41. package/dist/components/BadgeDot/BadgeDot.js +35 -0
  42. package/dist/components/BadgeDot/BadgeDot.js.map +1 -0
  43. package/dist/components/BadgeDot/BadgeDotExample.d.ts +3 -0
  44. package/dist/components/BadgeDot/BadgeDotExample.js +16 -0
  45. package/dist/components/BadgeDot/BadgeDotExample.js.map +1 -0
  46. package/dist/components/BadgeDot/badge-dot.css +22 -0
  47. package/dist/components/BadgeDot/badge-dot.css.js +27 -0
  48. package/dist/components/BadgeDot/index.d.ts +1 -0
  49. package/dist/components/BadgeDot/index.js +2 -0
  50. package/dist/components/BadgeDot/index.js.map +1 -0
  51. package/dist/components/BannerAlert/BannerAlert.d.ts +7 -7
  52. package/dist/components/BannerAlert/BannerAlert.js +7 -5
  53. package/dist/components/BannerAlert/BannerAlert.js.map +1 -1
  54. package/dist/components/BannerAlert/BannerAlertExample.d.ts +1 -1
  55. package/dist/components/BannerAlert/BannerAlertExample.js +6 -6
  56. package/dist/components/BannerAlert/BannerAlertExample.js.map +1 -1
  57. package/dist/components/BannerAlert/banner-alert.css.js +0 -1
  58. package/dist/components/Breadcrumb/Breadcrumb.d.ts +6 -9
  59. package/dist/components/Breadcrumb/Breadcrumb.js +6 -8
  60. package/dist/components/Breadcrumb/Breadcrumb.js.map +1 -1
  61. package/dist/components/Breadcrumb/BreadcrumbExample.d.ts +1 -1
  62. package/dist/components/Breadcrumb/BreadcrumbExample.js +67 -0
  63. package/dist/components/Breadcrumb/BreadcrumbExample.js.map +1 -1
  64. package/dist/components/Breadcrumb/breadcrumb.css.js +0 -1
  65. package/dist/components/Button/Button.d.ts +11 -12
  66. package/dist/components/Button/Button.js +19 -19
  67. package/dist/components/Button/Button.js.map +1 -1
  68. package/dist/components/Button/ButtonExample.d.ts +1 -1
  69. package/dist/components/Button/ButtonExample.js +8 -1
  70. package/dist/components/Button/ButtonExample.js.map +1 -1
  71. package/dist/components/Button/button.css +1 -1
  72. package/dist/components/Button/button.css.js +1 -2
  73. package/dist/components/Card/Card.d.ts +2 -6
  74. package/dist/components/Card/Card.js +2 -4
  75. package/dist/components/Card/Card.js.map +1 -1
  76. package/dist/components/Card/CardExample.d.ts +1 -1
  77. package/dist/components/Card/card.css.js +0 -1
  78. package/dist/components/Checkbox/Checkbox.d.ts +6 -8
  79. package/dist/components/Checkbox/Checkbox.js +4 -6
  80. package/dist/components/Checkbox/Checkbox.js.map +1 -1
  81. package/dist/components/Checkbox/checkbox.css +0 -6
  82. package/dist/components/Checkbox/checkbox.css.js +0 -7
  83. package/dist/components/CheckboxGroup/CheckboxGroup.d.ts +6 -10
  84. package/dist/components/CheckboxGroup/CheckboxGroup.js +3 -5
  85. package/dist/components/CheckboxGroup/CheckboxGroup.js.map +1 -1
  86. package/dist/components/CheckboxGroup/CheckboxGroupExample.d.ts +1 -1
  87. package/dist/components/CheckboxGroup/CheckboxGroupExample.js +23 -1
  88. package/dist/components/CheckboxGroup/CheckboxGroupExample.js.map +1 -1
  89. package/dist/components/CheckboxOption/CheckboxOption.d.ts +5 -17
  90. package/dist/components/CheckboxOption/CheckboxOption.js +4 -5
  91. package/dist/components/CheckboxOption/CheckboxOption.js.map +1 -1
  92. package/dist/components/ChipAssist/ChipAssist.d.ts +3 -7
  93. package/dist/components/ChipAssist/ChipAssist.js +3 -5
  94. package/dist/components/ChipAssist/ChipAssist.js.map +1 -1
  95. package/dist/components/ChipAssist/ChipAssistExample.d.ts +1 -1
  96. package/dist/components/ChipAssist/ChipAssistExample.js.map +1 -1
  97. package/dist/components/ChipFilter/ChipFilter.d.ts +3 -7
  98. package/dist/components/ChipFilter/ChipFilter.js +3 -5
  99. package/dist/components/ChipFilter/ChipFilter.js.map +1 -1
  100. package/dist/components/ChipFilter/ChipFilterExample.d.ts +2 -2
  101. package/dist/components/ChipFilter/ChipFilterExample.js.map +1 -1
  102. package/dist/components/ChipGroup/ChipGroup.d.ts +4 -8
  103. package/dist/components/ChipGroup/ChipGroup.js +3 -5
  104. package/dist/components/ChipGroup/ChipGroup.js.map +1 -1
  105. package/dist/components/ChipGroup/ChipGroupExample.d.ts +2 -2
  106. package/dist/components/ChipGroup/ChipGroupExample.js +1 -1
  107. package/dist/components/ChipGroup/ChipGroupExample.js.map +1 -1
  108. package/dist/components/ChipGroup/chip-group.css.js +0 -1
  109. package/dist/components/ChipInput/ChipInput.d.ts +3 -7
  110. package/dist/components/ChipInput/ChipInput.js +3 -5
  111. package/dist/components/ChipInput/ChipInput.js.map +1 -1
  112. package/dist/components/ChipInput/ChipInputExample.d.ts +1 -1
  113. package/dist/components/ChipInput/ChipInputExample.js.map +1 -1
  114. package/dist/components/ChipSuggestion/ChipSuggestion.d.ts +3 -7
  115. package/dist/components/ChipSuggestion/ChipSuggestion.js +3 -5
  116. package/dist/components/ChipSuggestion/ChipSuggestion.js.map +1 -1
  117. package/dist/components/ChipSuggestion/ChipSuggestionExample.d.ts +1 -1
  118. package/dist/components/ChipSuggestion/ChipSuggestionExample.js.map +1 -1
  119. package/dist/components/ChipUtility/ChipUtility.d.ts +4 -8
  120. package/dist/components/ChipUtility/ChipUtility.js +2 -5
  121. package/dist/components/ChipUtility/ChipUtility.js.map +1 -1
  122. package/dist/components/ChipUtility/ChipUtilityExample.d.ts +1 -1
  123. package/dist/components/ChipUtility/ChipUtilityExample.js +2 -0
  124. package/dist/components/ChipUtility/ChipUtilityExample.js.map +1 -1
  125. package/dist/components/ChipUtility/chip-utility.css +10 -10
  126. package/dist/components/ChipUtility/chip-utility.css.js +10 -11
  127. package/dist/components/Combobox/Combobox.d.ts +7 -11
  128. package/dist/components/Combobox/Combobox.js +8 -33
  129. package/dist/components/Combobox/Combobox.js.map +1 -1
  130. package/dist/components/Combobox/ListItems.d.ts +26 -0
  131. package/dist/components/Combobox/ListItems.js +22 -0
  132. package/dist/components/Combobox/ListItems.js.map +1 -0
  133. package/dist/components/Dialog/Dialog.d.ts +4 -10
  134. package/dist/components/Dialog/Dialog.js +11 -48
  135. package/dist/components/Dialog/Dialog.js.map +1 -1
  136. package/dist/components/Dialog/DialogExample.d.ts +1 -1
  137. package/dist/components/Dialog/DialogExample.js +3 -4
  138. package/dist/components/Dialog/DialogExample.js.map +1 -1
  139. package/dist/components/Dialog/dialog.css +67 -37
  140. package/dist/components/Dialog/dialog.css.js +67 -38
  141. package/dist/components/Divider/Divider.d.ts +3 -7
  142. package/dist/components/Divider/Divider.js +3 -5
  143. package/dist/components/Divider/Divider.js.map +1 -1
  144. package/dist/components/Divider/DividerExample.d.ts +1 -1
  145. package/dist/components/Divider/divider.css +3 -7
  146. package/dist/components/Divider/divider.css.js +3 -8
  147. package/dist/components/EmptyState/EmptyState.d.ts +3 -7
  148. package/dist/components/EmptyState/EmptyState.js +2 -4
  149. package/dist/components/EmptyState/EmptyState.js.map +1 -1
  150. package/dist/components/EmptyState/EmptyStateExample.d.ts +1 -1
  151. package/dist/components/EmptyState/EmptyStateExample.js +11 -6
  152. package/dist/components/EmptyState/EmptyStateExample.js.map +1 -1
  153. package/dist/components/ExamplePlaceholder/ExamplePlaceholder.d.ts +30 -11
  154. package/dist/components/ExamplePlaceholder/ExamplePlaceholder.js +2 -4
  155. package/dist/components/ExamplePlaceholder/ExamplePlaceholder.js.map +1 -1
  156. package/dist/components/Fab/Fab.d.ts +6 -10
  157. package/dist/components/Fab/Fab.js +19 -13
  158. package/dist/components/Fab/Fab.js.map +1 -1
  159. package/dist/components/Fab/FabExample.d.ts +1 -1
  160. package/dist/components/Fab/fab.css +1 -1
  161. package/dist/components/Fab/fab.css.js +1 -2
  162. package/dist/components/FileUpload/FileUpload.d.ts +87 -0
  163. package/dist/components/FileUpload/FileUpload.js +140 -0
  164. package/dist/components/FileUpload/FileUpload.js.map +1 -0
  165. package/dist/components/FileUpload/FileUploadExample.d.ts +3 -0
  166. package/dist/components/FileUpload/FileUploadExample.js +66 -0
  167. package/dist/components/FileUpload/FileUploadExample.js.map +1 -0
  168. package/dist/components/FileUpload/file-upload.css +20 -0
  169. package/dist/components/FileUpload/file-upload.css.js +25 -0
  170. package/dist/components/FileUpload/index.d.ts +1 -0
  171. package/dist/components/FileUpload/index.js +2 -0
  172. package/dist/components/FileUpload/index.js.map +1 -0
  173. package/dist/components/FileUploadItem/FileUploadItem.d.ts +40 -0
  174. package/dist/components/FileUploadItem/FileUploadItem.js +60 -0
  175. package/dist/components/FileUploadItem/FileUploadItem.js.map +1 -0
  176. package/dist/components/FileUploadItem/FileUploadItemExample.d.ts +3 -0
  177. package/dist/components/FileUploadItem/FileUploadItemExample.js +67 -0
  178. package/dist/components/FileUploadItem/FileUploadItemExample.js.map +1 -0
  179. package/dist/components/FileUploadItem/file-upload-item.css +40 -0
  180. package/dist/components/FileUploadItem/file-upload-item.css.js +45 -0
  181. package/dist/components/FileUploadItem/index.d.ts +1 -0
  182. package/dist/components/FileUploadItem/index.js +2 -0
  183. package/dist/components/FileUploadItem/index.js.map +1 -0
  184. package/dist/components/FormField/FormField.d.ts +10 -24
  185. package/dist/components/FormField/FormField.js +4 -7
  186. package/dist/components/FormField/FormField.js.map +1 -1
  187. package/dist/components/FormField/FormFieldExample.d.ts +4 -0
  188. package/dist/components/FormField/FormFieldExample.js +12 -0
  189. package/dist/components/FormField/FormFieldExample.js.map +1 -0
  190. package/dist/components/FormField/form-field.css.js +0 -1
  191. package/dist/components/Img/Img.d.ts +2 -6
  192. package/dist/components/Img/Img.js +1 -3
  193. package/dist/components/Img/Img.js.map +1 -1
  194. package/dist/components/InlineAlert/InlineAlert.d.ts +3 -7
  195. package/dist/components/InlineAlert/InlineAlert.js +4 -7
  196. package/dist/components/InlineAlert/InlineAlert.js.map +1 -1
  197. package/dist/components/InlineAlert/SvgWarningTwoTone.d.ts +1 -0
  198. package/dist/components/InlineAlert/SvgWarningTwoTone.js +5 -0
  199. package/dist/components/InlineAlert/SvgWarningTwoTone.js.map +1 -0
  200. package/dist/components/InlineAlert/inline-alert.css +1 -0
  201. package/dist/components/InlineAlert/inline-alert.css.js +1 -1
  202. package/dist/components/Layout/Layout.d.ts +4 -8
  203. package/dist/components/Layout/Layout.js +1 -3
  204. package/dist/components/Layout/Layout.js.map +1 -1
  205. package/dist/components/Layout/LayoutExample.d.ts +3 -0
  206. package/dist/components/Layout/LayoutExample.js +7 -0
  207. package/dist/components/Layout/LayoutExample.js.map +1 -0
  208. package/dist/components/Link/Link.d.ts +3 -7
  209. package/dist/components/Link/Link.js +2 -4
  210. package/dist/components/Link/Link.js.map +1 -1
  211. package/dist/components/Link/LinkExample.d.ts +1 -1
  212. package/dist/components/Link/LinkExample.js +7 -7
  213. package/dist/components/Link/LinkExample.js.map +1 -1
  214. package/dist/components/Link/link.css +1 -1
  215. package/dist/components/Link/link.css.js +1 -2
  216. package/dist/components/ListItem/ListItem.d.ts +9 -21
  217. package/dist/components/ListItem/ListItem.js +12 -66
  218. package/dist/components/ListItem/ListItem.js.map +1 -1
  219. package/dist/components/ListItem/ListItemButton.d.ts +2 -0
  220. package/dist/components/ListItem/ListItemButton.js +7 -0
  221. package/dist/components/ListItem/ListItemButton.js.map +1 -0
  222. package/dist/components/ListItem/ListItemExample.d.ts +2 -3
  223. package/dist/components/ListItem/ListItemExample.js +22 -41
  224. package/dist/components/ListItem/ListItemExample.js.map +1 -1
  225. package/dist/components/ListItem/list-item.css +11 -25
  226. package/dist/components/ListItem/list-item.css.js +12 -27
  227. package/dist/components/Listbox/Listbox.d.ts +7 -10
  228. package/dist/components/Listbox/Listbox.js +6 -8
  229. package/dist/components/Listbox/Listbox.js.map +1 -1
  230. package/dist/components/Menu/Menu.d.ts +27 -23
  231. package/dist/components/Menu/Menu.js +25 -32
  232. package/dist/components/Menu/Menu.js.map +1 -1
  233. package/dist/components/Menu/MenuExample.d.ts +2 -2
  234. package/dist/components/Menu/MenuExample.js +25 -2
  235. package/dist/components/Menu/MenuExample.js.map +1 -1
  236. package/dist/components/Menu/menu.css +5 -2
  237. package/dist/components/Menu/menu.css.js +5 -3
  238. package/dist/components/MenuButton/MenuButton.d.ts +3 -7
  239. package/dist/components/MenuButton/MenuButton.js +1 -3
  240. package/dist/components/MenuButton/MenuButton.js.map +1 -1
  241. package/dist/components/MenuButton/menu-button.css.js +0 -1
  242. package/dist/components/Modal/Modal.d.ts +6 -10
  243. package/dist/components/Modal/Modal.js +3 -5
  244. package/dist/components/Modal/Modal.js.map +1 -1
  245. package/dist/components/Modal/ModalExample.d.ts +1 -1
  246. package/dist/components/Modal/ModalExample.js +3 -3
  247. package/dist/components/Modal/ModalExample.js.map +1 -1
  248. package/dist/components/Modal/modal.css +6 -14
  249. package/dist/components/Modal/modal.css.js +6 -15
  250. package/dist/components/NumberField/NumberField.d.ts +5 -9
  251. package/dist/components/NumberField/NumberField.js +3 -6
  252. package/dist/components/NumberField/NumberField.js.map +1 -1
  253. package/dist/components/NumberInput/IncrementButton.d.ts +7 -0
  254. package/dist/components/NumberInput/IncrementButton.js +10 -0
  255. package/dist/components/NumberInput/IncrementButton.js.map +1 -0
  256. package/dist/components/NumberInput/NumberInput.d.ts +4 -11
  257. package/dist/components/NumberInput/NumberInput.js +22 -37
  258. package/dist/components/NumberInput/NumberInput.js.map +1 -1
  259. package/dist/components/NumberInput/NumberInputExample.d.ts +3 -0
  260. package/dist/components/NumberInput/NumberInputExample.js +5 -0
  261. package/dist/components/NumberInput/NumberInputExample.js.map +1 -0
  262. package/dist/components/NumberInput/number-input.css +8 -5
  263. package/dist/components/NumberInput/number-input.css.js +8 -6
  264. package/dist/components/OTPInput/OTPInput.d.ts +41 -0
  265. package/dist/components/OTPInput/OTPInput.js +57 -0
  266. package/dist/components/OTPInput/OTPInput.js.map +1 -0
  267. package/dist/components/OTPInput/OTPInputExample.d.ts +3 -0
  268. package/dist/components/OTPInput/OTPInputExample.js +25 -0
  269. package/dist/components/OTPInput/OTPInputExample.js.map +1 -0
  270. package/dist/components/OTPInput/index.d.ts +1 -0
  271. package/dist/components/OTPInput/index.js +2 -0
  272. package/dist/components/OTPInput/index.js.map +1 -0
  273. package/dist/components/OTPInput/otp-input.css +72 -0
  274. package/dist/components/OTPInput/otp-input.css.js +77 -0
  275. package/dist/components/PageControl/PageControl.d.ts +43 -0
  276. package/dist/components/PageControl/PageControl.js +46 -0
  277. package/dist/components/PageControl/PageControl.js.map +1 -0
  278. package/dist/components/PageControl/index.d.ts +1 -0
  279. package/dist/components/PageControl/index.js +2 -0
  280. package/dist/components/PageControl/index.js.map +1 -0
  281. package/dist/components/PageControl/page-control.css +33 -0
  282. package/dist/components/PageControl/page-control.css.js +38 -0
  283. package/dist/components/Pagination/PageInput.d.ts +5 -0
  284. package/dist/components/Pagination/PageInput.js +36 -0
  285. package/dist/components/Pagination/PageInput.js.map +1 -0
  286. package/dist/components/Pagination/PageList.d.ts +3 -0
  287. package/dist/components/Pagination/PageList.js +9 -0
  288. package/dist/components/Pagination/PageList.js.map +1 -0
  289. package/dist/components/Pagination/Pagination.d.ts +43 -0
  290. package/dist/components/Pagination/Pagination.js +49 -0
  291. package/dist/components/Pagination/Pagination.js.map +1 -0
  292. package/dist/components/Pagination/index.d.ts +1 -0
  293. package/dist/components/Pagination/index.js +2 -0
  294. package/dist/components/Pagination/index.js.map +1 -0
  295. package/dist/components/Pagination/pagination.css +31 -0
  296. package/dist/components/Pagination/pagination.css.js +36 -0
  297. package/dist/components/PasswordField/PasswordField.d.ts +31 -0
  298. package/dist/components/PasswordField/PasswordField.js +33 -0
  299. package/dist/components/PasswordField/PasswordField.js.map +1 -0
  300. package/dist/components/PasswordField/index.d.ts +1 -0
  301. package/dist/components/PasswordField/index.js +2 -0
  302. package/dist/components/PasswordField/index.js.map +1 -0
  303. package/dist/components/PasswordInput/PasswordInput.d.ts +21 -0
  304. package/dist/components/PasswordInput/PasswordInput.js +34 -0
  305. package/dist/components/PasswordInput/PasswordInput.js.map +1 -0
  306. package/dist/components/PasswordInput/index.d.ts +1 -0
  307. package/dist/components/PasswordInput/index.js +2 -0
  308. package/dist/components/PasswordInput/index.js.map +1 -0
  309. package/dist/components/PasswordInput/password-input.css +28 -0
  310. package/dist/components/PasswordInput/password-input.css.js +33 -0
  311. package/dist/components/PhoneNumberField/PhoneNumberField.d.ts +5 -9
  312. package/dist/components/PhoneNumberField/PhoneNumberField.js +3 -6
  313. package/dist/components/PhoneNumberField/PhoneNumberField.js.map +1 -1
  314. package/dist/components/PhoneNumberInput/PhoneNumberInput.d.ts +6 -10
  315. package/dist/components/PhoneNumberInput/PhoneNumberInput.js +5 -9
  316. package/dist/components/PhoneNumberInput/PhoneNumberInput.js.map +1 -1
  317. package/dist/components/PhoneNumberInput/phone-number-input.css.js +0 -1
  318. package/dist/components/Popover/Popover.d.ts +11 -9
  319. package/dist/components/Popover/Popover.js +27 -11
  320. package/dist/components/Popover/Popover.js.map +1 -1
  321. package/dist/components/Popover/PopoverExample.d.ts +1 -1
  322. package/dist/components/Popover/PopoverExample.js +19 -3
  323. package/dist/components/Popover/PopoverExample.js.map +1 -1
  324. package/dist/components/Popover/popover.css +17 -22
  325. package/dist/components/Popover/popover.css.js +17 -23
  326. package/dist/components/Portal/Portal.d.ts +1 -5
  327. package/dist/components/Portal/Portal.js +5 -5
  328. package/dist/components/Portal/Portal.js.map +1 -1
  329. package/dist/components/ProgressBar/ProgressBar.d.ts +16 -6
  330. package/dist/components/ProgressBar/ProgressBar.js +7 -6
  331. package/dist/components/ProgressBar/ProgressBar.js.map +1 -1
  332. package/dist/components/ProgressBar/progress-bar.css +3 -0
  333. package/dist/components/ProgressBar/progress-bar.css.js +3 -1
  334. package/dist/components/ProgressCircle/ProgressCircle.d.ts +1 -2
  335. package/dist/components/ProgressCircle/ProgressCircle.js +4 -10
  336. package/dist/components/ProgressCircle/ProgressCircle.js.map +1 -1
  337. package/dist/components/ProgressCircle/ProgressCircleSVG.d.ts +3 -0
  338. package/dist/components/ProgressCircle/ProgressCircleSVG.js +9 -0
  339. package/dist/components/ProgressCircle/ProgressCircleSVG.js.map +1 -0
  340. package/dist/components/ProgressCircle/progress-circle.css.js +0 -1
  341. package/dist/components/ProgressionStepper/ProgressionStepper.d.ts +4 -12
  342. package/dist/components/ProgressionStepper/ProgressionStepper.js +6 -8
  343. package/dist/components/ProgressionStepper/ProgressionStepper.js.map +1 -1
  344. package/dist/components/ProgressionStepper/ProgressionStepperExample.d.ts +1 -1
  345. package/dist/components/ProgressionStepper/ProgressionStepperExample.js +2 -1
  346. package/dist/components/ProgressionStepper/ProgressionStepperExample.js.map +1 -1
  347. package/dist/components/ProgressionStepper/progression-stepper.css +11 -0
  348. package/dist/components/ProgressionStepper/progression-stepper.css.js +11 -1
  349. package/dist/components/ProgressionStepperBar/ProgressionStepperBar.d.ts +2 -6
  350. package/dist/components/ProgressionStepperBar/ProgressionStepperBar.js +3 -5
  351. package/dist/components/ProgressionStepperBar/ProgressionStepperBar.js.map +1 -1
  352. package/dist/components/ProgressionStepperBar/progression-stepper-bar.css +1 -1
  353. package/dist/components/ProgressionStepperBar/progression-stepper-bar.css.js +1 -2
  354. package/dist/components/Radio/Radio.d.ts +3 -7
  355. package/dist/components/Radio/Radio.js +3 -5
  356. package/dist/components/Radio/Radio.js.map +1 -1
  357. package/dist/components/Radio/RadioExample.d.ts +1 -1
  358. package/dist/components/Radio/radio.css +1 -1
  359. package/dist/components/Radio/radio.css.js +1 -2
  360. package/dist/components/RadioGroup/RadioGroup.d.ts +9 -13
  361. package/dist/components/RadioGroup/RadioGroup.js +6 -9
  362. package/dist/components/RadioGroup/RadioGroup.js.map +1 -1
  363. package/dist/components/RadioGroup/RadioGroupExample.d.ts +1 -1
  364. package/dist/components/RadioGroup/RadioGroupExample.js +2 -22
  365. package/dist/components/RadioGroup/RadioGroupExample.js.map +1 -1
  366. package/dist/components/RadioGroup/radio-group.css +0 -1
  367. package/dist/components/RadioGroup/radio-group.css.js +0 -2
  368. package/dist/components/RadioOption/RadioOption.d.ts +4 -17
  369. package/dist/components/RadioOption/RadioOption.js +3 -4
  370. package/dist/components/RadioOption/RadioOption.js.map +1 -1
  371. package/dist/components/RadioOption/RadioOptionExample.d.ts +1 -1
  372. package/dist/components/Rating/Rating.d.ts +39 -0
  373. package/dist/components/Rating/Rating.js +41 -0
  374. package/dist/components/Rating/Rating.js.map +1 -0
  375. package/dist/components/Rating/RatingExample.d.ts +3 -0
  376. package/dist/components/Rating/RatingExample.js +17 -0
  377. package/dist/components/Rating/RatingExample.js.map +1 -0
  378. package/dist/components/Rating/index.d.ts +1 -0
  379. package/dist/components/Rating/index.js +2 -0
  380. package/dist/components/Rating/index.js.map +1 -0
  381. package/dist/components/Rating/rating.css +65 -0
  382. package/dist/components/Rating/rating.css.js +70 -0
  383. package/dist/components/Scrim/Scrim.d.ts +3 -15
  384. package/dist/components/Scrim/Scrim.js +2 -4
  385. package/dist/components/Scrim/Scrim.js.map +1 -1
  386. package/dist/components/Scrim/scrim.css +12 -2
  387. package/dist/components/Scrim/scrim.css.js +12 -3
  388. package/dist/components/SearchBar/SearchBar.d.ts +5 -9
  389. package/dist/components/SearchBar/SearchBar.js +10 -11
  390. package/dist/components/SearchBar/SearchBar.js.map +1 -1
  391. package/dist/components/SearchBar/SearchBarExample.d.ts +1 -1
  392. package/dist/components/SearchBar/SearchBarExample.js +1 -1
  393. package/dist/components/SearchBar/SearchBarExample.js.map +1 -1
  394. package/dist/components/SearchBar/search-bar.css +1 -1
  395. package/dist/components/SearchBar/search-bar.css.js +1 -2
  396. package/dist/components/SegmentedControl/SegmentedControl.d.ts +6 -86
  397. package/dist/components/SegmentedControl/SegmentedControl.js +5 -15
  398. package/dist/components/SegmentedControl/SegmentedControl.js.map +1 -1
  399. package/dist/components/SegmentedControl/SegmentedControlExample.d.ts +1 -1
  400. package/dist/components/SegmentedControl/SegmentedControlExample.js +41 -20
  401. package/dist/components/SegmentedControl/SegmentedControlExample.js.map +1 -1
  402. package/dist/components/SegmentedControl/segmented-control.css +26 -73
  403. package/dist/components/SegmentedControl/segmented-control.css.js +26 -74
  404. package/dist/components/Select/Select.d.ts +5 -9
  405. package/dist/components/Select/Select.js +6 -8
  406. package/dist/components/Select/Select.js.map +1 -1
  407. package/dist/components/Select/SelectExample.d.ts +1 -1
  408. package/dist/components/Select/SelectExample.js +3 -3
  409. package/dist/components/Select/SelectExample.js.map +1 -1
  410. package/dist/components/Select/select.css +9 -8
  411. package/dist/components/Select/select.css.js +9 -9
  412. package/dist/components/SelectField/SelectField.d.ts +5 -9
  413. package/dist/components/SelectField/SelectField.js +5 -6
  414. package/dist/components/SelectField/SelectField.js.map +1 -1
  415. package/dist/components/Skeleton/Circular.d.ts +2 -0
  416. package/dist/components/Skeleton/Circular.js +6 -0
  417. package/dist/components/Skeleton/Circular.js.map +1 -0
  418. package/dist/components/Skeleton/Photo.d.ts +2 -0
  419. package/dist/components/Skeleton/Photo.js +6 -0
  420. package/dist/components/Skeleton/Photo.js.map +1 -0
  421. package/dist/components/Skeleton/Profile.d.ts +2 -0
  422. package/dist/components/Skeleton/Profile.js +6 -0
  423. package/dist/components/Skeleton/Profile.js.map +1 -0
  424. package/dist/components/Skeleton/Rectangular.d.ts +2 -0
  425. package/dist/components/Skeleton/Rectangular.js +6 -0
  426. package/dist/components/Skeleton/Rectangular.js.map +1 -0
  427. package/dist/components/Skeleton/Skeleton.d.ts +4 -12
  428. package/dist/components/Skeleton/Skeleton.js +2 -19
  429. package/dist/components/Skeleton/Skeleton.js.map +1 -1
  430. package/dist/components/Skeleton/SkeletonExample.d.ts +1 -1
  431. package/dist/components/Skeleton/SkeletonExample.js +13 -10
  432. package/dist/components/Skeleton/SkeletonExample.js.map +1 -1
  433. package/dist/components/Skeleton/Thumbnail.d.ts +2 -0
  434. package/dist/components/Skeleton/Thumbnail.js +6 -0
  435. package/dist/components/Skeleton/Thumbnail.js.map +1 -0
  436. package/dist/components/Skeleton/index.d.ts +5 -0
  437. package/dist/components/Skeleton/index.js +5 -0
  438. package/dist/components/Skeleton/index.js.map +1 -1
  439. package/dist/components/SkeletonText/SkeletonText.d.ts +3 -7
  440. package/dist/components/SkeletonText/SkeletonText.js +2 -4
  441. package/dist/components/SkeletonText/SkeletonText.js.map +1 -1
  442. package/dist/components/SkeletonText/SkeletonTextExample.d.ts +1 -1
  443. package/dist/components/SkeletonText/SkeletonTextExample.js.map +1 -1
  444. package/dist/components/Slider/Slider.d.ts +80 -0
  445. package/dist/components/Slider/Slider.js +131 -0
  446. package/dist/components/Slider/Slider.js.map +1 -0
  447. package/dist/components/Slider/SliderExample.d.ts +3 -0
  448. package/dist/components/Slider/SliderExample.js +59 -0
  449. package/dist/components/Slider/SliderExample.js.map +1 -0
  450. package/dist/components/Slider/SliderIntervalDots.d.ts +6 -0
  451. package/dist/components/Slider/SliderIntervalDots.js +20 -0
  452. package/dist/components/Slider/SliderIntervalDots.js.map +1 -0
  453. package/dist/components/Slider/index.d.ts +1 -0
  454. package/dist/components/Slider/index.js +2 -0
  455. package/dist/components/Slider/index.js.map +1 -0
  456. package/dist/components/Slider/slider.css +122 -0
  457. package/dist/components/Slider/slider.css.js +127 -0
  458. package/dist/components/Slider/useNormalizeSliderValue.d.ts +7 -0
  459. package/dist/components/Slider/useNormalizeSliderValue.js +12 -0
  460. package/dist/components/Slider/useNormalizeSliderValue.js.map +1 -0
  461. package/dist/components/StylesProviderAnywhere/StylesProviderAnywhere.d.ts +4 -6
  462. package/dist/components/StylesProviderAnywhere/StylesProviderAnywhere.js +4 -4
  463. package/dist/components/StylesProviderAnywhere/StylesProviderAnywhere.js.map +1 -1
  464. package/dist/components/StylesProviderBetterHomesGardens/StylesProviderBetterHomesGardens.d.ts +4 -6
  465. package/dist/components/StylesProviderBetterHomesGardens/StylesProviderBetterHomesGardens.js +4 -4
  466. package/dist/components/StylesProviderBetterHomesGardens/StylesProviderBetterHomesGardens.js.map +1 -1
  467. package/dist/components/StylesProviderCartus/StylesProviderCartus.d.ts +4 -6
  468. package/dist/components/StylesProviderCartus/StylesProviderCartus.js +4 -4
  469. package/dist/components/StylesProviderCartus/StylesProviderCartus.js.map +1 -1
  470. package/dist/components/StylesProviderCentury21/StylesProviderCentury21.d.ts +4 -6
  471. package/dist/components/StylesProviderCentury21/StylesProviderCentury21.js +4 -4
  472. package/dist/components/StylesProviderCentury21/StylesProviderCentury21.js.map +1 -1
  473. package/dist/components/StylesProviderColdwellBanker/StylesProviderColdwellBanker.d.ts +4 -6
  474. package/dist/components/StylesProviderColdwellBanker/StylesProviderColdwellBanker.js +4 -4
  475. package/dist/components/StylesProviderColdwellBanker/StylesProviderColdwellBanker.js.map +1 -1
  476. package/dist/components/StylesProviderCorcoran/StylesProviderCorcoran.d.ts +4 -6
  477. package/dist/components/StylesProviderCorcoran/StylesProviderCorcoran.js +4 -4
  478. package/dist/components/StylesProviderCorcoran/StylesProviderCorcoran.js.map +1 -1
  479. package/dist/components/StylesProviderDemo/StylesProviderDemo.d.ts +25 -0
  480. package/dist/components/StylesProviderDemo/StylesProviderDemo.js +35 -0
  481. package/dist/components/StylesProviderDemo/StylesProviderDemo.js.map +1 -0
  482. package/dist/components/StylesProviderDemo/brandsCss.d.ts +2 -0
  483. package/dist/components/StylesProviderDemo/brandsCss.js +12 -0
  484. package/dist/components/StylesProviderDemo/brandsCss.js.map +1 -0
  485. package/dist/components/StylesProviderDemo/index.d.ts +1 -0
  486. package/dist/components/StylesProviderDemo/index.js +2 -0
  487. package/dist/components/StylesProviderDemo/index.js.map +1 -0
  488. package/dist/components/StylesProviderDenaliBoss/StylesProviderDenaliBoss.d.ts +4 -6
  489. package/dist/components/StylesProviderDenaliBoss/StylesProviderDenaliBoss.js +4 -4
  490. package/dist/components/StylesProviderDenaliBoss/StylesProviderDenaliBoss.js.map +1 -1
  491. package/dist/components/StylesProviderEra/StylesProviderEra.d.ts +4 -6
  492. package/dist/components/StylesProviderEra/StylesProviderEra.js +4 -4
  493. package/dist/components/StylesProviderEra/StylesProviderEra.js.map +1 -1
  494. package/dist/components/StylesProviderSothebys/StylesProviderSothebys.d.ts +4 -6
  495. package/dist/components/StylesProviderSothebys/StylesProviderSothebys.js +4 -4
  496. package/dist/components/StylesProviderSothebys/StylesProviderSothebys.js.map +1 -1
  497. package/dist/components/Switch/Switch.d.ts +3 -7
  498. package/dist/components/Switch/Switch.js +2 -4
  499. package/dist/components/Switch/Switch.js.map +1 -1
  500. package/dist/components/Switch/switch.css +1 -1
  501. package/dist/components/Switch/switch.css.js +1 -2
  502. package/dist/components/SwitchOption/SwitchOption.d.ts +5 -9
  503. package/dist/components/SwitchOption/SwitchOption.js +4 -5
  504. package/dist/components/SwitchOption/SwitchOption.js.map +1 -1
  505. package/dist/components/TabGroup/TabGroup.d.ts +5 -87
  506. package/dist/components/TabGroup/TabGroup.js +7 -22
  507. package/dist/components/TabGroup/TabGroup.js.map +1 -1
  508. package/dist/components/TabGroup/TabGroupExample.d.ts +1 -1
  509. package/dist/components/TabGroup/TabGroupExample.js +74 -70
  510. package/dist/components/TabGroup/TabGroupExample.js.map +1 -1
  511. package/dist/components/TabGroup/tab-group.css +18 -54
  512. package/dist/components/TabGroup/tab-group.css.js +18 -55
  513. package/dist/components/TabList/TabList.d.ts +129 -0
  514. package/dist/components/TabList/TabList.js +80 -0
  515. package/dist/components/TabList/TabList.js.map +1 -0
  516. package/dist/components/TabList/TabListExample.d.ts +3 -0
  517. package/dist/components/TabList/TabListExample.js +6 -0
  518. package/dist/components/TabList/TabListExample.js.map +1 -0
  519. package/dist/components/TabList/index.d.ts +1 -0
  520. package/dist/components/TabList/index.js +2 -0
  521. package/dist/components/TabList/index.js.map +1 -0
  522. package/dist/components/TabList/tab-list.css +64 -0
  523. package/dist/components/TabList/tab-list.css.js +69 -0
  524. package/dist/components/Table/Footer.d.ts +8 -0
  525. package/dist/components/Table/Footer.js +8 -0
  526. package/dist/components/Table/Footer.js.map +1 -0
  527. package/dist/components/Table/Table.d.ts +46 -30
  528. package/dist/components/Table/Table.js +73 -12
  529. package/dist/components/Table/Table.js.map +1 -1
  530. package/dist/components/Table/TableExample.d.ts +4 -0
  531. package/dist/components/Table/TableExample.js +126 -0
  532. package/dist/components/Table/TableExample.js.map +1 -0
  533. package/dist/components/Table/table.css +167 -20
  534. package/dist/components/Table/table.css.js +167 -21
  535. package/dist/components/Table/utils.d.ts +81 -0
  536. package/dist/components/Table/utils.js +89 -0
  537. package/dist/components/Table/utils.js.map +1 -0
  538. package/dist/components/Tag/Tag.d.ts +7 -35
  539. package/dist/components/Tag/Tag.js +5 -11
  540. package/dist/components/Tag/Tag.js.map +1 -1
  541. package/dist/components/Tag/TagExample.d.ts +3 -0
  542. package/dist/components/Tag/TagExample.js +14 -0
  543. package/dist/components/Tag/TagExample.js.map +1 -0
  544. package/dist/components/Tag/tag.css +7 -11
  545. package/dist/components/Tag/tag.css.js +7 -12
  546. package/dist/components/TextField/TextField.d.ts +5 -9
  547. package/dist/components/TextField/TextField.js +3 -5
  548. package/dist/components/TextField/TextField.js.map +1 -1
  549. package/dist/components/TextInput/TextInput.d.ts +17 -11
  550. package/dist/components/TextInput/TextInput.js +4 -6
  551. package/dist/components/TextInput/TextInput.js.map +1 -1
  552. package/dist/components/TextInput/TextInputExample.d.ts +1 -1
  553. package/dist/components/TextInput/TextInputExample.js +2 -0
  554. package/dist/components/TextInput/TextInputExample.js.map +1 -1
  555. package/dist/components/TextInput/text-input.css +2 -2
  556. package/dist/components/TextInput/text-input.css.js +2 -3
  557. package/dist/components/Textarea/Textarea.d.ts +4 -8
  558. package/dist/components/Textarea/Textarea.js +3 -5
  559. package/dist/components/Textarea/Textarea.js.map +1 -1
  560. package/dist/components/Textarea/TextareaExample.d.ts +1 -1
  561. package/dist/components/Textarea/TextareaExample.js +4 -1
  562. package/dist/components/Textarea/TextareaExample.js.map +1 -1
  563. package/dist/components/Textarea/textarea.css.js +0 -1
  564. package/dist/components/TextareaField/TextareaField.d.ts +5 -9
  565. package/dist/components/TextareaField/TextareaField.js +9 -12
  566. package/dist/components/TextareaField/TextareaField.js.map +1 -1
  567. package/dist/components/TextareaField/TextareaFieldExample.d.ts +1 -1
  568. package/dist/components/TextareaField/TextareaFieldExample.js +2 -1
  569. package/dist/components/TextareaField/TextareaFieldExample.js.map +1 -1
  570. package/dist/components/TimeInput/Listbox.d.ts +10 -0
  571. package/dist/components/TimeInput/Listbox.js +66 -0
  572. package/dist/components/TimeInput/Listbox.js.map +1 -0
  573. package/dist/components/TimeInput/Segment.d.ts +21 -0
  574. package/dist/components/TimeInput/Segment.js +160 -0
  575. package/dist/components/TimeInput/Segment.js.map +1 -0
  576. package/dist/components/TimeInput/TimeInput.d.ts +26 -0
  577. package/dist/components/TimeInput/TimeInput.js +66 -0
  578. package/dist/components/TimeInput/TimeInput.js.map +1 -0
  579. package/dist/components/TimeInput/TimeInputExample.d.ts +3 -0
  580. package/dist/components/TimeInput/TimeInputExample.js +4 -0
  581. package/dist/components/TimeInput/TimeInputExample.js.map +1 -0
  582. package/dist/components/TimeInput/index.d.ts +1 -0
  583. package/dist/components/TimeInput/index.js +2 -0
  584. package/dist/components/TimeInput/index.js.map +1 -0
  585. package/dist/components/TimeInput/time-input.css +138 -0
  586. package/dist/components/TimeInput/time-input.css.js +143 -0
  587. package/dist/components/ToggleOption/ToggleOption.d.ts +7 -7
  588. package/dist/components/ToggleOption/ToggleOption.js +2 -4
  589. package/dist/components/ToggleOption/ToggleOption.js.map +1 -1
  590. package/dist/components/ToggleOption/toggle-option.css +17 -12
  591. package/dist/components/ToggleOption/toggle-option.css.js +17 -13
  592. package/dist/components/Tooltip/Tooltip.d.ts +12 -11
  593. package/dist/components/Tooltip/Tooltip.js +17 -15
  594. package/dist/components/Tooltip/Tooltip.js.map +1 -1
  595. package/dist/components/Tooltip/TooltipExample.d.ts +3 -2
  596. package/dist/components/Tooltip/TooltipExample.js +1 -1
  597. package/dist/components/Tooltip/TooltipExample.js.map +1 -1
  598. package/dist/components/Tooltip/tooltip.css.js +0 -1
  599. package/dist/components/TopNavigation/TopNavigation.d.ts +1 -5
  600. package/dist/components/TopNavigation/TopNavigation.js +1 -3
  601. package/dist/components/TopNavigation/TopNavigation.js.map +1 -1
  602. package/dist/components/TopNavigation/top-navigation.css.js +0 -1
  603. package/dist/components/Truncated/Truncated.d.ts +7 -8
  604. package/dist/components/Truncated/Truncated.js +11 -6
  605. package/dist/components/Truncated/Truncated.js.map +1 -1
  606. package/dist/components/Txt/Txt.d.ts +4 -8
  607. package/dist/components/Txt/Txt.js +2 -4
  608. package/dist/components/Txt/Txt.js.map +1 -1
  609. package/dist/components/UIProvider/UIProvider.d.ts +1 -5
  610. package/dist/components/UIProvider/UIProvider.js +2 -4
  611. package/dist/components/UIProvider/UIProvider.js.map +1 -1
  612. package/dist/constants/brands.d.ts +7 -0
  613. package/dist/{index.js → constants/brands.js} +1 -9
  614. package/dist/{index.js.map → constants/brands.js.map} +1 -1
  615. package/dist/constants/phases.d.ts +3 -0
  616. package/dist/constants/phases.js +9 -0
  617. package/dist/constants/phases.js.map +1 -0
  618. package/dist/hooks/useCheckboxGroupState.d.ts +1 -1
  619. package/dist/hooks/useCheckboxState.d.ts +1 -1
  620. package/dist/hooks/useCombobox.d.ts +4 -3
  621. package/dist/hooks/useCombobox.js +7 -7
  622. package/dist/hooks/useCombobox.js.map +1 -1
  623. package/dist/hooks/useFloating.d.ts +1 -3
  624. package/dist/hooks/useFloating.js +4 -3
  625. package/dist/hooks/useFloating.js.map +1 -1
  626. package/dist/hooks/useId.js +5 -3
  627. package/dist/hooks/useId.js.map +1 -1
  628. package/dist/hooks/useKeyNavigation.d.ts +17 -0
  629. package/dist/hooks/useKeyNavigation.js +46 -0
  630. package/dist/hooks/useKeyNavigation.js.map +1 -0
  631. package/dist/hooks/useLongPress.d.ts +2 -1
  632. package/dist/hooks/useLongPress.js +2 -1
  633. package/dist/hooks/useLongPress.js.map +1 -1
  634. package/dist/hooks/useOutsideClick.d.ts +5 -1
  635. package/dist/hooks/useOutsideClick.js +1 -1
  636. package/dist/hooks/useOutsideClick.js.map +1 -1
  637. package/dist/hooks/usePaginationState.d.ts +4 -0
  638. package/dist/hooks/usePaginationState.js +22 -0
  639. package/dist/hooks/usePaginationState.js.map +1 -0
  640. package/dist/hooks/useRadioState.d.ts +2 -2
  641. package/dist/hooks/useTimeout.d.ts +8 -5
  642. package/dist/hooks/useTimeout.js +7 -23
  643. package/dist/hooks/useTimeout.js.map +1 -1
  644. package/dist/hooks/useUIContext.d.ts +1 -1
  645. package/dist/styles/anywhere.css +14 -14
  646. package/dist/styles/anywhere.css.js +14 -15
  647. package/dist/{base.css → styles/base.css} +27 -12
  648. package/dist/{base.css.js → styles/base.css.js} +27 -13
  649. package/dist/styles/better-homes-gardens.css +12 -12
  650. package/dist/styles/better-homes-gardens.css.js +12 -13
  651. package/dist/styles/cartus.css +13 -13
  652. package/dist/styles/cartus.css.js +13 -14
  653. package/dist/styles/century-21.css +14 -14
  654. package/dist/styles/century-21.css.js +14 -15
  655. package/dist/styles/coldwell-banker.css +12 -12
  656. package/dist/styles/coldwell-banker.css.js +12 -13
  657. package/dist/{colors.css.js → styles/colors.css.js} +0 -1
  658. package/dist/styles/corcoran.css +10 -10
  659. package/dist/styles/corcoran.css.js +10 -11
  660. package/dist/styles/denali-boss.css +13 -13
  661. package/dist/styles/denali-boss.css.js +13 -14
  662. package/dist/styles/era.css +13 -13
  663. package/dist/styles/era.css.js +13 -14
  664. package/dist/styles/sothebys.css +14 -14
  665. package/dist/styles/sothebys.css.js +14 -15
  666. package/dist/{index.d.ts → types/common.d.ts} +12 -22
  667. package/dist/types/common.js +10 -0
  668. package/dist/types/common.js.map +1 -0
  669. package/{meta-types.ts → dist/types/meta.d.ts} +7 -14
  670. package/dist/types/meta.js +47 -0
  671. package/dist/types/meta.js.map +1 -0
  672. package/dist/utils/bound.d.ts +18 -0
  673. package/dist/utils/bound.js +22 -0
  674. package/dist/utils/bound.js.map +1 -0
  675. package/dist/utils/createExampleChildElement.d.ts +17 -0
  676. package/dist/utils/createExampleChildElement.js +50 -0
  677. package/dist/utils/createExampleChildElement.js.map +1 -0
  678. package/dist/utils/demo.d.ts +29 -10
  679. package/dist/utils/demo.js.map +1 -1
  680. package/dist/utils/fileUploads.d.ts +51 -0
  681. package/dist/utils/fileUploads.js +2 -0
  682. package/dist/utils/fileUploads.js.map +1 -0
  683. package/dist/utils/handleKeyDown.d.ts +12 -0
  684. package/dist/utils/handleKeyDown.js +20 -0
  685. package/dist/utils/handleKeyDown.js.map +1 -0
  686. package/dist/utils/keyboard.js +2 -2
  687. package/dist/utils/keyboard.js.map +1 -1
  688. package/dist/utils/random.d.ts +15 -0
  689. package/dist/utils/random.js +26 -0
  690. package/dist/utils/random.js.map +1 -0
  691. package/dist/utils/scrollElementIntoView.d.ts +1 -1
  692. package/dist/utils/scrollElementIntoView.js +2 -0
  693. package/dist/utils/scrollElementIntoView.js.map +1 -1
  694. package/meta.ts +15 -28
  695. package/package.json +115 -91
  696. package/src/components/Accordion/Accordion.tsx +77 -0
  697. package/src/components/Accordion/AccordionExample.tsx +87 -0
  698. package/src/components/Accordion/AccordionSection.tsx +128 -0
  699. package/src/components/Accordion/accordion.scss +105 -0
  700. package/src/components/Accordion/index.tsx +1 -0
  701. package/src/components/Avatar/Avatar.tsx +37 -18
  702. package/src/components/Avatar/AvatarExample.tsx +12 -4
  703. package/src/components/Avatar/avatar.scss +34 -1
  704. package/src/components/AvatarGroup/AvatarGroup.tsx +20 -14
  705. package/src/components/AvatarGroup/AvatarGroupExample.tsx +33 -0
  706. package/src/components/AvatarGroup/avatar-group.scss +16 -1
  707. package/src/components/Badge/Badge.tsx +16 -16
  708. package/src/components/Badge/BadgeExample.tsx +11 -66
  709. package/src/components/Badge/badge.scss +18 -25
  710. package/src/components/BadgeDot/BadgeDot.tsx +83 -0
  711. package/src/components/BadgeDot/BadgeDotExample.tsx +25 -0
  712. package/src/components/BadgeDot/badge-dot.scss +26 -0
  713. package/src/components/BadgeDot/index.tsx +1 -0
  714. package/src/components/BannerAlert/BannerAlert.tsx +10 -9
  715. package/src/components/BannerAlert/BannerAlertExample.tsx +7 -8
  716. package/src/components/Breadcrumb/Breadcrumb.tsx +15 -17
  717. package/src/components/Breadcrumb/BreadcrumbExample.tsx +68 -2
  718. package/src/components/Button/Button.tsx +44 -29
  719. package/src/components/Button/ButtonExample.tsx +8 -3
  720. package/src/components/Button/button.scss +1 -1
  721. package/src/components/Card/Card.tsx +3 -6
  722. package/src/components/Checkbox/Checkbox.tsx +27 -25
  723. package/src/components/Checkbox/checkbox.scss +0 -7
  724. package/src/components/CheckboxGroup/CheckboxGroup.tsx +65 -59
  725. package/src/components/CheckboxGroup/CheckboxGroupExample.tsx +24 -3
  726. package/src/components/CheckboxOption/CheckboxOption.tsx +7 -20
  727. package/src/components/ChipAssist/ChipAssist.tsx +11 -7
  728. package/src/components/ChipAssist/ChipAssistExample.tsx +1 -2
  729. package/src/components/ChipFilter/ChipFilter.tsx +10 -6
  730. package/src/components/ChipFilter/ChipFilterExample.tsx +1 -2
  731. package/src/components/ChipGroup/ChipGroup.tsx +4 -8
  732. package/src/components/ChipGroup/ChipGroupExample.tsx +6 -7
  733. package/src/components/ChipInput/ChipInput.tsx +3 -6
  734. package/src/components/ChipInput/ChipInputExample.tsx +1 -2
  735. package/src/components/ChipSuggestion/ChipSuggestion.tsx +3 -7
  736. package/src/components/ChipSuggestion/ChipSuggestionExample.tsx +1 -2
  737. package/src/components/ChipUtility/ChipUtility.tsx +7 -12
  738. package/src/components/ChipUtility/ChipUtilityExample.tsx +2 -2
  739. package/src/components/ChipUtility/chip-utility.scss +1 -1
  740. package/src/components/Combobox/Combobox.tsx +33 -123
  741. package/src/components/Combobox/ListItems.tsx +107 -0
  742. package/src/components/Dialog/Dialog.tsx +54 -95
  743. package/src/components/Dialog/DialogExample.tsx +4 -13
  744. package/src/components/Dialog/dialog.scss +81 -63
  745. package/src/components/Divider/Divider.tsx +5 -7
  746. package/src/components/Divider/divider.scss +3 -7
  747. package/src/components/EmptyState/EmptyState.tsx +3 -7
  748. package/src/components/EmptyState/EmptyStateExample.tsx +16 -18
  749. package/src/components/ExamplePlaceholder/ExamplePlaceholder.tsx +33 -15
  750. package/src/components/Fab/Fab.tsx +50 -40
  751. package/src/components/Fab/fab.scss +1 -1
  752. package/src/components/FileUpload/FileUpload.tsx +285 -0
  753. package/src/components/FileUpload/FileUploadExample.tsx +91 -0
  754. package/src/components/FileUpload/file-upload.scss +20 -0
  755. package/src/components/FileUpload/index.tsx +1 -0
  756. package/src/components/FileUploadItem/FileUploadItem.tsx +121 -0
  757. package/src/components/FileUploadItem/FileUploadItemExample.tsx +78 -0
  758. package/src/components/FileUploadItem/file-upload-item.scss +46 -0
  759. package/src/components/FileUploadItem/index.tsx +1 -0
  760. package/src/components/FormField/FormField.tsx +30 -42
  761. package/src/components/FormField/FormFieldExample.tsx +41 -0
  762. package/src/components/Img/Img.tsx +2 -6
  763. package/src/components/InlineAlert/InlineAlert.tsx +6 -27
  764. package/src/components/InlineAlert/SvgWarningTwoTone.tsx +18 -0
  765. package/src/components/InlineAlert/inline-alert.scss +1 -0
  766. package/src/components/Layout/Layout.tsx +4 -8
  767. package/src/components/Layout/LayoutExample.tsx +14 -0
  768. package/src/components/Link/Link.tsx +3 -7
  769. package/src/components/Link/LinkExample.tsx +7 -8
  770. package/src/components/Link/link.scss +1 -1
  771. package/src/components/ListItem/ListItem.tsx +40 -121
  772. package/src/components/ListItem/ListItemButton.tsx +6 -0
  773. package/src/components/ListItem/ListItemExample.tsx +26 -77
  774. package/src/components/ListItem/list-item.scss +11 -30
  775. package/src/components/Listbox/Listbox.tsx +14 -14
  776. package/src/components/Menu/Menu.tsx +83 -85
  777. package/src/components/Menu/MenuExample.tsx +28 -6
  778. package/src/components/Menu/menu.scss +6 -2
  779. package/src/components/MenuButton/MenuButton.tsx +3 -6
  780. package/src/components/Modal/Modal.tsx +12 -15
  781. package/src/components/Modal/ModalExample.tsx +3 -4
  782. package/src/components/Modal/modal.scss +8 -21
  783. package/src/components/NumberField/NumberField.tsx +18 -27
  784. package/src/components/NumberInput/IncrementButton.tsx +31 -0
  785. package/src/components/NumberInput/NumberInput.tsx +54 -68
  786. package/src/components/NumberInput/NumberInputExample.tsx +6 -0
  787. package/src/components/NumberInput/number-input.scss +9 -5
  788. package/src/components/OTPInput/OTPInput.tsx +121 -0
  789. package/src/components/OTPInput/OTPInputExample.tsx +26 -0
  790. package/src/components/OTPInput/index.tsx +1 -0
  791. package/src/components/OTPInput/otp-input.scss +87 -0
  792. package/src/components/PageControl/PageControl.tsx +98 -0
  793. package/src/components/PageControl/index.tsx +1 -0
  794. package/src/components/PageControl/page-control.scss +38 -0
  795. package/src/components/Pagination/PageInput.tsx +65 -0
  796. package/src/components/Pagination/PageList.tsx +21 -0
  797. package/src/components/Pagination/Pagination.tsx +104 -0
  798. package/src/components/Pagination/index.tsx +1 -0
  799. package/src/components/Pagination/pagination.scss +36 -0
  800. package/src/components/PasswordField/PasswordField.tsx +68 -0
  801. package/src/components/PasswordField/index.tsx +1 -0
  802. package/src/components/PasswordInput/PasswordInput.tsx +115 -0
  803. package/src/components/PasswordInput/index.tsx +1 -0
  804. package/src/components/PasswordInput/password-input.scss +36 -0
  805. package/src/components/PhoneNumberField/PhoneNumberField.tsx +10 -49
  806. package/src/components/PhoneNumberInput/PhoneNumberInput.tsx +20 -19
  807. package/src/components/Popover/Popover.tsx +94 -53
  808. package/src/components/Popover/PopoverExample.tsx +20 -4
  809. package/src/components/Popover/popover.scss +17 -29
  810. package/src/components/Portal/Portal.tsx +4 -6
  811. package/src/components/ProgressBar/ProgressBar.tsx +33 -9
  812. package/src/components/ProgressBar/progress-bar.scss +6 -0
  813. package/src/components/ProgressCircle/ProgressCircle.tsx +5 -43
  814. package/src/components/ProgressCircle/ProgressCircleSVG.tsx +38 -0
  815. package/src/components/ProgressionStepper/ProgressionStepper.tsx +20 -19
  816. package/src/components/ProgressionStepper/ProgressionStepperExample.tsx +3 -3
  817. package/src/components/ProgressionStepper/progression-stepper.scss +13 -0
  818. package/src/components/ProgressionStepperBar/ProgressionStepperBar.tsx +5 -8
  819. package/src/components/ProgressionStepperBar/progression-stepper-bar.scss +1 -1
  820. package/src/components/Radio/Radio.tsx +4 -10
  821. package/src/components/Radio/radio.scss +1 -1
  822. package/src/components/RadioGroup/RadioGroup.tsx +80 -82
  823. package/src/components/RadioGroup/RadioGroupExample.tsx +3 -24
  824. package/src/components/RadioGroup/radio-group.scss +0 -1
  825. package/src/components/RadioOption/RadioOption.tsx +6 -21
  826. package/src/components/Rating/Rating.tsx +100 -0
  827. package/src/components/Rating/RatingExample.tsx +18 -0
  828. package/src/components/Rating/index.tsx +1 -0
  829. package/src/components/Rating/rating.scss +85 -0
  830. package/src/components/Scrim/Scrim.tsx +5 -24
  831. package/src/components/Scrim/scrim.scss +15 -4
  832. package/src/components/SearchBar/SearchBar.tsx +18 -13
  833. package/src/components/SearchBar/SearchBarExample.tsx +9 -3
  834. package/src/components/SearchBar/search-bar.scss +1 -1
  835. package/src/components/SegmentedControl/SegmentedControl.tsx +19 -123
  836. package/src/components/SegmentedControl/SegmentedControlExample.tsx +42 -21
  837. package/src/components/SegmentedControl/segmented-control.scss +37 -89
  838. package/src/components/Select/Select.tsx +26 -34
  839. package/src/components/Select/SelectExample.tsx +4 -13
  840. package/src/components/Select/select.scss +13 -10
  841. package/src/components/SelectField/SelectField.tsx +20 -28
  842. package/src/components/Skeleton/Circular.tsx +5 -0
  843. package/src/components/Skeleton/Photo.tsx +5 -0
  844. package/src/components/Skeleton/Profile.tsx +5 -0
  845. package/src/components/Skeleton/Rectangular.tsx +5 -0
  846. package/src/components/Skeleton/Skeleton.tsx +6 -29
  847. package/src/components/Skeleton/SkeletonExample.tsx +21 -36
  848. package/src/components/Skeleton/Thumbnail.tsx +5 -0
  849. package/src/components/Skeleton/index.tsx +5 -0
  850. package/src/components/SkeletonText/SkeletonText.tsx +2 -6
  851. package/src/components/SkeletonText/SkeletonTextExample.tsx +1 -2
  852. package/src/components/Slider/Slider.tsx +281 -0
  853. package/src/components/Slider/SliderExample.tsx +63 -0
  854. package/src/components/Slider/SliderIntervalDots.tsx +35 -0
  855. package/src/components/Slider/index.tsx +1 -0
  856. package/src/components/Slider/slider.scss +121 -0
  857. package/src/components/Slider/useNormalizeSliderValue.ts +16 -0
  858. package/src/components/StylesProviderAnywhere/StylesProviderAnywhere.tsx +4 -6
  859. package/src/components/StylesProviderBetterHomesGardens/StylesProviderBetterHomesGardens.tsx +4 -6
  860. package/src/components/StylesProviderCartus/StylesProviderCartus.tsx +4 -6
  861. package/src/components/StylesProviderCentury21/StylesProviderCentury21.tsx +4 -6
  862. package/src/components/StylesProviderColdwellBanker/StylesProviderColdwellBanker.tsx +4 -6
  863. package/src/components/StylesProviderCorcoran/StylesProviderCorcoran.tsx +4 -6
  864. package/src/components/StylesProviderDemo/StylesProviderDemo.tsx +49 -0
  865. package/src/components/StylesProviderDemo/brandsCss.ts +20 -0
  866. package/src/components/StylesProviderDemo/index.tsx +1 -0
  867. package/src/components/StylesProviderDenaliBoss/StylesProviderDenaliBoss.tsx +4 -6
  868. package/src/components/StylesProviderEra/StylesProviderEra.tsx +4 -6
  869. package/src/components/StylesProviderSothebys/StylesProviderSothebys.tsx +4 -6
  870. package/src/components/Switch/Switch.tsx +3 -7
  871. package/src/components/Switch/switch.scss +1 -1
  872. package/src/components/SwitchOption/SwitchOption.tsx +6 -9
  873. package/src/components/TabGroup/TabGroup.tsx +17 -130
  874. package/src/components/TabGroup/TabGroupExample.tsx +78 -71
  875. package/src/components/TabGroup/tab-group.scss +33 -79
  876. package/src/components/TabList/TabList.tsx +239 -0
  877. package/src/components/TabList/TabListExample.tsx +7 -0
  878. package/src/components/TabList/index.tsx +1 -0
  879. package/src/components/TabList/tab-list.scss +76 -0
  880. package/src/components/Table/Footer.tsx +40 -0
  881. package/src/components/Table/Table.tsx +181 -53
  882. package/src/components/Table/TableExample.tsx +138 -0
  883. package/src/components/Table/table.scss +228 -26
  884. package/src/components/Table/utils.ts +179 -0
  885. package/src/components/Tag/Tag.tsx +11 -54
  886. package/src/components/Tag/TagExample.tsx +16 -0
  887. package/src/components/Tag/tag.scss +7 -12
  888. package/src/components/TextField/TextField.tsx +6 -27
  889. package/src/components/TextInput/TextInput.tsx +72 -54
  890. package/src/components/TextInput/TextInputExample.tsx +2 -2
  891. package/src/components/TextInput/text-input.scss +2 -1
  892. package/src/components/Textarea/Textarea.tsx +10 -11
  893. package/src/components/Textarea/TextareaExample.tsx +4 -3
  894. package/src/components/TextareaField/TextareaField.tsx +22 -39
  895. package/src/components/TextareaField/TextareaFieldExample.tsx +3 -9
  896. package/src/components/TimeInput/Listbox.tsx +95 -0
  897. package/src/components/TimeInput/Segment.tsx +221 -0
  898. package/src/components/TimeInput/TimeInput.tsx +192 -0
  899. package/src/components/TimeInput/TimeInputExample.tsx +6 -0
  900. package/src/components/TimeInput/index.tsx +1 -0
  901. package/src/components/TimeInput/time-input.scss +176 -0
  902. package/src/components/ToggleOption/ToggleOption.tsx +11 -12
  903. package/src/components/ToggleOption/toggle-option.scss +15 -11
  904. package/src/components/Tooltip/Tooltip.tsx +30 -27
  905. package/src/components/Tooltip/TooltipExample.tsx +10 -6
  906. package/src/components/TopNavigation/TopNavigation.tsx +1 -5
  907. package/src/components/Truncated/Truncated.tsx +24 -13
  908. package/src/components/Txt/Txt.tsx +3 -7
  909. package/src/components/UIProvider/UIProvider.tsx +2 -5
  910. package/src/constants/brands.ts +45 -0
  911. package/src/constants/phases.ts +11 -0
  912. package/src/global.d.ts +3 -0
  913. package/src/hooks/useCombobox.ts +9 -12
  914. package/src/hooks/useFloating.ts +5 -7
  915. package/src/hooks/useId.ts +5 -3
  916. package/src/hooks/useKeyNavigation.ts +66 -0
  917. package/src/hooks/useLongPress.ts +3 -2
  918. package/src/hooks/useOutsideClick.ts +9 -5
  919. package/src/hooks/usePaginationState.tsx +24 -0
  920. package/src/hooks/useTimeout.ts +14 -4
  921. package/src/{base.scss → styles/base.scss} +24 -8
  922. package/src/{index.ts → types/common.ts} +15 -62
  923. package/src/types/meta.ts +109 -0
  924. package/src/utils/bound.ts +30 -0
  925. package/src/utils/createExampleChildElement.tsx +83 -0
  926. package/src/utils/demo.ts +25 -17
  927. package/src/utils/fileUploads.ts +73 -0
  928. package/src/utils/handleKeyDown.ts +24 -0
  929. package/src/utils/keyboard.ts +2 -2
  930. package/src/utils/random.ts +25 -0
  931. package/src/utils/scrollElementIntoView.ts +3 -1
  932. package/tsconfig.json +12 -5
  933. package/dist/components/Chip/Chip.d.ts +0 -64
  934. package/dist/components/Chip/Chip.js +0 -33
  935. package/dist/components/Chip/Chip.js.map +0 -1
  936. package/dist/components/Chip/chip.css +0 -44
  937. package/dist/components/Chip/chip.css.js +0 -50
  938. package/dist/components/Chip/index.d.ts +0 -1
  939. package/dist/components/Chip/index.js +0 -2
  940. package/dist/components/Chip/index.js.map +0 -1
  941. package/dist/hooks/useOptionIconsInvalid.d.ts +0 -36
  942. package/dist/hooks/useOptionIconsInvalid.js +0 -21
  943. package/dist/hooks/useOptionIconsInvalid.js.map +0 -1
  944. package/dist/hooks/useValidChildren.d.ts +0 -6
  945. package/dist/hooks/useValidChildren.js +0 -30
  946. package/dist/hooks/useValidChildren.js.map +0 -1
  947. package/dist/utils/children.d.ts +0 -29
  948. package/dist/utils/children.js +0 -67
  949. package/dist/utils/children.js.map +0 -1
  950. package/dist/utils/srOnly.d.ts +0 -14
  951. package/dist/utils/srOnly.js +0 -13
  952. package/dist/utils/srOnly.js.map +0 -1
  953. package/src/components/Chip/Chip.tsx +0 -104
  954. package/src/components/Chip/chip.scss +0 -66
  955. package/src/components/Chip/index.tsx +0 -1
  956. package/src/hooks/useOptionIconsInvalid.ts +0 -58
  957. package/src/hooks/useValidChildren.ts +0 -54
  958. package/src/utils/children.ts +0 -80
  959. package/src/utils/srOnly.ts +0 -14
  960. /package/dist/{colors.css → styles/colors.css} +0 -0
  961. /package/src/{colors.scss → styles/colors.scss} +0 -0
@@ -1,5 +1,5 @@
1
- import { ChangeEvent, HTMLInputAutoCompleteAttribute, HTMLInputTypeAttribute, ReactNode } from 'react';
2
- import { ElementProps, CommonProps, InvalidPropsLibrary, SetRef } from '../../index.js';
1
+ import { ChangeEvent, HTMLInputTypeAttribute, ReactNode } from 'react';
2
+ import { CommonProps, ElementProps, FormFieldControlProps, SetRef } from '-/types/common';
3
3
  import './text-input.scss';
4
4
  export declare const DEFAULT: {
5
5
  readonly size: "medium";
@@ -7,7 +7,7 @@ export declare const DEFAULT: {
7
7
  readonly type: Extract<HTMLInputTypeAttribute, "number" | "text">;
8
8
  readonly autoComplete: "off";
9
9
  };
10
- export type TextInputProps = CommonProps<'aria-label' | 'disabled' | 'id' | 'name' | 'readOnly' | 'required' | 'size' | 'value'> & InvalidPropsLibrary & {
10
+ type TextInputBaseProps = {
11
11
  /**
12
12
  * Callback when the value of the field changes.
13
13
  *
@@ -37,13 +37,22 @@ export type TextInputProps = CommonProps<'aria-label' | 'disabled' | 'id' | 'nam
37
37
  *
38
38
  * @default text
39
39
  */
40
- type?: Extract<HTMLInputTypeAttribute, 'number' | 'text'>;
40
+ type?: Extract<HTMLInputTypeAttribute, 'number' | 'password' | 'text'>;
41
41
  /**
42
42
  * Specifies if user agent has any permission to provide automated assistance in filling out form field values
43
43
  *
44
44
  * @default off
45
45
  */
46
- autoComplete?: HTMLInputAutoCompleteAttribute;
46
+ autoComplete?: '' | 'off' | 'on';
47
+ /**
48
+ * Specifies if the clear button should be shown. This should almost always be true, but can be set to false.
49
+ *
50
+ * @default true
51
+ */
52
+ showClearButton?: boolean;
53
+ };
54
+ export type TextInputProps = CommonProps<'aria-label' | 'disabled' | 'id' | 'invalid' | 'name' | 'owner' | 'readOnly' | 'required' | 'size' | 'value'> & FormFieldControlProps & TextInputBaseProps & {
55
+ inputProps?: Omit<React.InputHTMLAttributes<HTMLInputElement>, keyof TextInputBaseProps>;
47
56
  };
48
57
  /**
49
58
  * A text input that allows users to enter text, numbers or symbols in a singular line. This is the base element and is
@@ -62,11 +71,8 @@ export type TextInputProps = CommonProps<'aria-label' | 'disabled' | 'id' | 'nam
62
71
  * @element
63
72
  *
64
73
  * @name TextInput
65
- * @phase DesignReview
74
+ * @phase Utility
66
75
  */
67
- declare function TextInput({ invalid: invalidProp, onChange, size, value, name, 'aria-label': ariaLabel, inputRef, required, placeholder, id: idProp, leading, trailing, type, readOnly, disabled, autoComplete, containerRef, errorMessage, ...otherProps }: ElementProps<TextInputProps, 'div'>): import("react/jsx-runtime").JSX.Element;
68
- declare namespace TextInput {
69
- var bspkName: string;
70
- }
71
- export { TextInput };
76
+ export declare function TextInput({ invalid: invalidProp, onChange, size, value, name, 'aria-label': ariaLabel, inputRef, required, placeholder, id: idProp, leading, trailing, type, readOnly, disabled, autoComplete, containerRef, showClearButton, owner, 'aria-describedby': ariaDescribedBy, 'aria-errormessage': ariaErrorMessage, inputProps, ...props }: ElementProps<TextInputProps, 'div'>): import("react/jsx-runtime").JSX.Element;
77
+ export {};
72
78
  /** Copyright 2025 Anywhere Real Estate - CC BY 4.0 */
@@ -25,15 +25,13 @@ export const DEFAULT = {
25
25
  * @element
26
26
  *
27
27
  * @name TextInput
28
- * @phase DesignReview
28
+ * @phase Utility
29
29
  */
30
- function TextInput({ invalid: invalidProp, onChange, size = DEFAULT.size, value = DEFAULT.value, name, 'aria-label': ariaLabel, inputRef, required, placeholder, id: idProp, leading, trailing, type = DEFAULT.type, readOnly, disabled, autoComplete = DEFAULT.autoComplete, containerRef, errorMessage, ...otherProps }) {
30
+ export function TextInput({ invalid: invalidProp, onChange, size = DEFAULT.size, value = DEFAULT.value, name, 'aria-label': ariaLabel, inputRef, required, placeholder, id: idProp, leading, trailing, type = DEFAULT.type, readOnly, disabled, autoComplete = DEFAULT.autoComplete, containerRef, showClearButton = true, owner, 'aria-describedby': ariaDescribedBy, 'aria-errormessage': ariaErrorMessage, inputProps, ...props }) {
31
31
  const id = useId(idProp);
32
32
  const invalid = !readOnly && !disabled && invalidProp;
33
- return (_jsxs("div", { "data-bspk": "text-input", "data-disabled": disabled || undefined, "data-empty": !value.toString().length || undefined, "data-invalid": invalid || undefined, "data-readonly": readOnly || undefined, "data-required": required || undefined, "data-size": size, ref: containerRef, ...otherProps, children: [leading && _jsx("span", { "data-leading": true, children: leading }), _jsx("input", { "aria-errormessage": errorMessage || undefined, "aria-invalid": invalid || undefined, "aria-label": ariaLabel, autoComplete: autoComplete, disabled: disabled || undefined, id: id, name: name, onChange: (event) => {
33
+ return (_jsxs("div", { ...props, "data-bspk": "text-input", "data-bspk-owner": owner || undefined, "data-clear-hidden": showClearButton === false || undefined, "data-disabled": disabled || undefined, "data-empty": !value.toString().length || undefined, "data-invalid": invalid || undefined, "data-readonly": readOnly || undefined, "data-size": size, ref: containerRef, children: [leading && _jsx("span", { "data-leading": true, children: leading }), _jsx("input", { ...inputProps, "aria-describedby": ariaDescribedBy || undefined, "aria-errormessage": ariaErrorMessage || undefined, "aria-invalid": invalid || undefined, "aria-label": ariaLabel, autoComplete: autoComplete, disabled: disabled || undefined, id: id, name: name, onChange: (event) => {
34
34
  onChange(event.target.value, event);
35
- }, placeholder: placeholder || ' ', readOnly: readOnly || undefined, ref: inputRef, required: required || undefined, type: type, value: value || '' }), trailing && _jsx("span", { "data-trailing": true, children: trailing }), _jsx("button", { "aria-label": "clear", "data-clear": true, onClick: () => onChange(''), children: _jsx(SvgCancel, {}) })] }));
35
+ }, placeholder: placeholder || ' ', readOnly: readOnly || undefined, ref: inputRef, required: required || undefined, type: type, value: value || '' }), trailing && _jsx("span", { "data-trailing": true, children: trailing }), showClearButton !== false && (_jsx("button", { "aria-label": "clear", "data-clear": true, onClick: () => onChange(''), children: _jsx(SvgCancel, {}) }))] }));
36
36
  }
37
- TextInput.bspkName = 'TextInput';
38
- export { TextInput };
39
37
  //# sourceMappingURL=TextInput.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TextInput.js","sourceRoot":"","sources":["../../../src/components/TextInput/TextInput.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAI/C,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAEtC,OAAO,mBAAmB,CAAC;AAE3B,MAAM,CAAC,MAAM,OAAO,GAAG;IACnB,IAAI,EAAE,QAAQ;IACd,KAAK,EAAE,EAAE;IACT,IAAI,EAAE,MAA4D;IAClE,YAAY,EAAE,KAAK;CACb,CAAC;AA4CX;;;;;;;;;;;;;;;;;;GAkBG;AACH,SAAS,SAAS,CAAC,EACf,OAAO,EAAE,WAAW,EACpB,QAAQ,EACR,IAAI,GAAG,OAAO,CAAC,IAAI,EACnB,KAAK,GAAG,OAAO,CAAC,KAAK,EACrB,IAAI,EACJ,YAAY,EAAE,SAAS,EACvB,QAAQ,EACR,QAAQ,EACR,WAAW,EACX,EAAE,EAAE,MAAM,EACV,OAAO,EACP,QAAQ,EACR,IAAI,GAAG,OAAO,CAAC,IAAI,EACnB,QAAQ,EACR,QAAQ,EACR,YAAY,GAAG,OAAO,CAAC,YAAY,EACnC,YAAY,EACZ,YAAY,EACZ,GAAG,UAAU,EACqB;IAClC,MAAM,EAAE,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC;IAEzB,MAAM,OAAO,GAAG,CAAC,QAAQ,IAAI,CAAC,QAAQ,IAAI,WAAW,CAAC;IAEtD,OAAO,CACH,4BACc,YAAY,mBACP,QAAQ,IAAI,SAAS,gBACxB,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC,MAAM,IAAI,SAAS,kBACnC,OAAO,IAAI,SAAS,mBACnB,QAAQ,IAAI,SAAS,mBACrB,QAAQ,IAAI,SAAS,eACzB,IAAI,EACf,GAAG,EAAE,YAAY,KACb,UAAU,aAEb,OAAO,IAAI,+CAAoB,OAAO,GAAQ,EAC/C,qCACuB,YAAY,IAAI,SAAS,kBAC9B,OAAO,IAAI,SAAS,gBACtB,SAAS,EACrB,YAAY,EAAE,YAAY,EAC1B,QAAQ,EAAE,QAAQ,IAAI,SAAS,EAC/B,EAAE,EAAE,EAAE,EACN,IAAI,EAAE,IAAI,EACV,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE;oBAChB,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;gBACxC,CAAC,EACD,WAAW,EAAE,WAAW,IAAI,GAAG,EAC/B,QAAQ,EAAE,QAAQ,IAAI,SAAS,EAC/B,GAAG,EAAE,QAAQ,EACb,QAAQ,EAAE,QAAQ,IAAI,SAAS,EAC/B,IAAI,EAAE,IAAI,EACV,KAAK,EAAE,KAAK,IAAI,EAAE,GACpB,EACD,QAAQ,IAAI,gDAAqB,QAAQ,GAAQ,EAClD,+BAAmB,OAAO,sBAAY,OAAO,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,YAC7D,KAAC,SAAS,KAAG,GACR,IACP,CACT,CAAC;AACN,CAAC;AAED,SAAS,CAAC,QAAQ,GAAG,WAAW,CAAC;AAEjC,OAAO,EAAE,SAAS,EAAE,CAAC"}
1
+ {"version":3,"file":"TextInput.js","sourceRoot":"","sources":["../../../src/components/TextInput/TextInput.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAG/C,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAGtC,OAAO,mBAAmB,CAAC;AAE3B,MAAM,CAAC,MAAM,OAAO,GAAG;IACnB,IAAI,EAAE,QAAQ;IACd,KAAK,EAAE,EAAE;IACT,IAAI,EAAE,MAA4D;IAClE,YAAY,EAAE,KAAK;CACb,CAAC;AAuDX;;;;;;;;;;;;;;;;;;GAkBG;AACH,MAAM,UAAU,SAAS,CAAC,EACtB,OAAO,EAAE,WAAW,EACpB,QAAQ,EACR,IAAI,GAAG,OAAO,CAAC,IAAI,EACnB,KAAK,GAAG,OAAO,CAAC,KAAK,EACrB,IAAI,EACJ,YAAY,EAAE,SAAS,EACvB,QAAQ,EACR,QAAQ,EACR,WAAW,EACX,EAAE,EAAE,MAAM,EACV,OAAO,EACP,QAAQ,EACR,IAAI,GAAG,OAAO,CAAC,IAAI,EACnB,QAAQ,EACR,QAAQ,EACR,YAAY,GAAG,OAAO,CAAC,YAAY,EACnC,YAAY,EACZ,eAAe,GAAG,IAAI,EACtB,KAAK,EACL,kBAAkB,EAAE,eAAe,EACnC,mBAAmB,EAAE,gBAAgB,EAErC,UAAU,EACV,GAAG,KAAK,EAC0B;IAClC,MAAM,EAAE,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC;IAEzB,MAAM,OAAO,GAAG,CAAC,QAAQ,IAAI,CAAC,QAAQ,IAAI,WAAW,CAAC;IAEtD,OAAO,CACH,kBACQ,KAAK,eACC,YAAY,qBACL,KAAK,IAAI,SAAS,uBAChB,eAAe,KAAK,KAAK,IAAI,SAAS,mBAC1C,QAAQ,IAAI,SAAS,gBACxB,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC,MAAM,IAAI,SAAS,kBACnC,OAAO,IAAI,SAAS,mBACnB,QAAQ,IAAI,SAAS,eACzB,IAAI,EACf,GAAG,EAAE,YAAY,aAEhB,OAAO,IAAI,+CAAoB,OAAO,GAAQ,EAE/C,mBACQ,UAAU,sBACI,eAAe,IAAI,SAAS,uBAC3B,gBAAgB,IAAI,SAAS,kBAClC,OAAO,IAAI,SAAS,gBACtB,SAAS,EACrB,YAAY,EAAE,YAAY,EAC1B,QAAQ,EAAE,QAAQ,IAAI,SAAS,EAC/B,EAAE,EAAE,EAAE,EACN,IAAI,EAAE,IAAI,EACV,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE;oBAChB,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;gBACxC,CAAC,EACD,WAAW,EAAE,WAAW,IAAI,GAAG,EAC/B,QAAQ,EAAE,QAAQ,IAAI,SAAS,EAC/B,GAAG,EAAE,QAAQ,EACb,QAAQ,EAAE,QAAQ,IAAI,SAAS,EAC/B,IAAI,EAAE,IAAI,EACV,KAAK,EAAE,KAAK,IAAI,EAAE,GACpB,EACD,QAAQ,IAAI,gDAAqB,QAAQ,GAAQ,EACjD,eAAe,KAAK,KAAK,IAAI,CAC1B,+BAAmB,OAAO,sBAAY,OAAO,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,YAC7D,KAAC,SAAS,KAAG,GACR,CACZ,IACC,CACT,CAAC;AACN,CAAC"}
@@ -1,3 +1,3 @@
1
- import { ComponentExample } from '../../utils/demo';
2
1
  import { TextInputProps } from '.';
2
+ import { ComponentExample } from '-/utils/demo';
3
3
  export declare const TextInputExample: ComponentExample<TextInputProps>;
@@ -1,4 +1,6 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
1
2
  export const TextInputExample = {
3
+ render: ({ props, Component }) => _jsx(Component, { ...props }),
2
4
  presets: [
3
5
  {
4
6
  label: 'Currency',
@@ -1 +1 @@
1
- {"version":3,"file":"TextInputExample.js","sourceRoot":"","sources":["../../../src/components/TextInput/TextInputExample.tsx"],"names":[],"mappings":"AAIA,MAAM,CAAC,MAAM,gBAAgB,GAAqC;IAC9D,OAAO,EAAE;QACL;YACI,KAAK,EAAE,UAAU;YACjB,SAAS,EAAE;gBACP,IAAI,EAAE,QAAQ;gBACd,OAAO,EAAE,GAAG;gBACZ,QAAQ,EAAE,SAAS;gBACnB,WAAW,EAAE,UAAU;aAC1B;SACJ;QACD;YACI,KAAK,EAAE,SAAS;YAChB,SAAS,EAAE;gBACP,IAAI,EAAE,QAAQ;gBACd,OAAO,EAAE,SAAS;gBAClB,QAAQ,EAAE,GAAG;gBACb,WAAW,EAAE,SAAS;aACzB;SACJ;QACD;YACI,KAAK,EAAE,WAAW;YAClB,SAAS,EAAE;gBACP,IAAI,EAAE,QAAQ;gBACd,OAAO,EAAE,SAAS;gBAClB,WAAW,EAAE,YAAY;gBACzB,QAAQ,EAAE,IAAI;aACjB;SACJ;KACJ;CACJ,CAAC"}
1
+ {"version":3,"file":"TextInputExample.js","sourceRoot":"","sources":["../../../src/components/TextInput/TextInputExample.tsx"],"names":[],"mappings":";AAGA,MAAM,CAAC,MAAM,gBAAgB,GAAqC;IAC9D,MAAM,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE,EAAE,CAAC,KAAC,SAAS,OAAK,KAAK,GAAI;IAC1D,OAAO,EAAE;QACL;YACI,KAAK,EAAE,UAAU;YACjB,SAAS,EAAE;gBACP,IAAI,EAAE,QAAQ;gBACd,OAAO,EAAE,GAAG;gBACZ,QAAQ,EAAE,SAAS;gBACnB,WAAW,EAAE,UAAU;aAC1B;SACJ;QACD;YACI,KAAK,EAAE,SAAS;YAChB,SAAS,EAAE;gBACP,IAAI,EAAE,QAAQ;gBACd,OAAO,EAAE,SAAS;gBAClB,QAAQ,EAAE,GAAG;gBACb,WAAW,EAAE,SAAS;aACzB;SACJ;QACD;YACI,KAAK,EAAE,WAAW;YAClB,SAAS,EAAE;gBACP,IAAI,EAAE,QAAQ;gBACd,OAAO,EAAE,SAAS;gBAClB,WAAW,EAAE,YAAY;gBACzB,QAAQ,EAAE,IAAI;aACjB;SACJ;KACJ;CACJ,CAAC"}
@@ -94,10 +94,10 @@
94
94
  pointer-events: none;
95
95
  width: var(--field-clear-width);
96
96
  }
97
- [data-bspk=text-input]:not(:focus-within), [data-bspk=text-input][data-empty], [data-bspk=text-input][data-readonly], [data-bspk=text-input][data-disabled] {
97
+ [data-bspk=text-input]:not(:focus-within), [data-bspk=text-input][data-empty], [data-bspk=text-input][data-readonly], [data-bspk=text-input][data-disabled], [data-bspk=text-input][data-clear-hidden] {
98
98
  padding-right: var(--field-padding);
99
99
  }
100
- [data-bspk=text-input]:not(:focus-within) button[data-clear], [data-bspk=text-input][data-empty] button[data-clear], [data-bspk=text-input][data-readonly] button[data-clear], [data-bspk=text-input][data-disabled] button[data-clear] {
100
+ [data-bspk=text-input]:not(:focus-within) button[data-clear], [data-bspk=text-input][data-empty] button[data-clear], [data-bspk=text-input][data-readonly] button[data-clear], [data-bspk=text-input][data-disabled] button[data-clear], [data-bspk=text-input][data-clear-hidden] button[data-clear] {
101
101
  display: none;
102
102
  }
103
103
  [data-bspk=text-input]:focus-within {
@@ -97,10 +97,10 @@ style.appendChild(document.createTextNode(`[data-bspk=text-input] {
97
97
  pointer-events: none;
98
98
  width: var(--field-clear-width);
99
99
  }
100
- [data-bspk=text-input]:not(:focus-within), [data-bspk=text-input][data-empty], [data-bspk=text-input][data-readonly], [data-bspk=text-input][data-disabled] {
100
+ [data-bspk=text-input]:not(:focus-within), [data-bspk=text-input][data-empty], [data-bspk=text-input][data-readonly], [data-bspk=text-input][data-disabled], [data-bspk=text-input][data-clear-hidden] {
101
101
  padding-right: var(--field-padding);
102
102
  }
103
- [data-bspk=text-input]:not(:focus-within) button[data-clear], [data-bspk=text-input][data-empty] button[data-clear], [data-bspk=text-input][data-readonly] button[data-clear], [data-bspk=text-input][data-disabled] button[data-clear] {
103
+ [data-bspk=text-input]:not(:focus-within) button[data-clear], [data-bspk=text-input][data-empty] button[data-clear], [data-bspk=text-input][data-readonly] button[data-clear], [data-bspk=text-input][data-disabled] button[data-clear], [data-bspk=text-input][data-clear-hidden] button[data-clear] {
104
104
  display: none;
105
105
  }
106
106
  [data-bspk=text-input]:focus-within {
@@ -111,4 +111,3 @@ style.appendChild(document.createTextNode(`[data-bspk=text-input] {
111
111
  /** Copyright 2025 Anywhere Real Estate - CC BY 4.0 */
112
112
  `));
113
113
  document.head.appendChild(style);
114
-
@@ -1,7 +1,7 @@
1
1
  import { ChangeEvent } from 'react';
2
- import { CommonProps, InvalidPropsLibrary, SetRef } from '../../index.js';
2
+ import { CommonProps, FormFieldControlProps, SetRef } from '-/types/common';
3
3
  import './textarea.scss';
4
- export type TextareaProps = CommonProps<'aria-label' | 'disabled' | 'id' | 'readOnly' | 'required'> & InvalidPropsLibrary & {
4
+ export type TextareaProps = CommonProps<'aria-label' | 'disabled' | 'id' | 'invalid' | 'readOnly'> & FormFieldControlProps & {
5
5
  /**
6
6
  * Callback when the value of the field changes.
7
7
  *
@@ -76,11 +76,7 @@ export type TextareaProps = CommonProps<'aria-label' | 'disabled' | 'id' | 'read
76
76
  * @element
77
77
  *
78
78
  * @name Textarea
79
- * @phase DesignReview
79
+ * @phase Utility
80
80
  */
81
- declare function Textarea({ invalid: invalidProp, onChange, textSize, value, name, 'aria-label': ariaLabel, innerRef, placeholder, id: idProp, minRows: minRowsProp, maxRows: maxRowsProp, errorMessage, ...otherProps }: TextareaProps): import("react/jsx-runtime").JSX.Element;
82
- declare namespace Textarea {
83
- var bspkName: string;
84
- }
85
- export { Textarea };
81
+ export declare function Textarea({ invalid: invalidProp, onChange, textSize, value, name, 'aria-label': ariaLabel, innerRef, placeholder, id: idProp, minRows: minRowsProp, maxRows: maxRowsProp, 'aria-describedby': ariaDescribedBy, 'aria-errormessage': ariaErrorMessage, ...otherProps }: TextareaProps): import("react/jsx-runtime").JSX.Element;
86
82
  /** Copyright 2025 Anywhere Real Estate - CC BY 4.0 */
@@ -28,9 +28,9 @@ const DEFAULT = {
28
28
  * @element
29
29
  *
30
30
  * @name Textarea
31
- * @phase DesignReview
31
+ * @phase Utility
32
32
  */
33
- function Textarea({ invalid: invalidProp, onChange, textSize = DEFAULT.textSize, value = '', name, 'aria-label': ariaLabel, innerRef, placeholder, id: idProp, minRows: minRowsProp = DEFAULT.minRows, maxRows: maxRowsProp = DEFAULT.maxRows, errorMessage, ...otherProps }) {
33
+ export function Textarea({ invalid: invalidProp, onChange, textSize = DEFAULT.textSize, value = '', name, 'aria-label': ariaLabel, innerRef, placeholder, id: idProp, minRows: minRowsProp = DEFAULT.minRows, maxRows: maxRowsProp = DEFAULT.maxRows, 'aria-describedby': ariaDescribedBy, 'aria-errormessage': ariaErrorMessage, ...otherProps }) {
34
34
  const id = useId(idProp);
35
35
  const invalid = !otherProps.readOnly && !otherProps.disabled && invalidProp;
36
36
  // ensure minRows and maxRows are within bounds
@@ -49,7 +49,7 @@ function Textarea({ invalid: invalidProp, onChange, textSize = DEFAULT.textSize,
49
49
  return (_jsxs("div", { "data-bspk": "textarea", "data-size": textSize, style: cssWithVars({
50
50
  '--min-rows': minRows,
51
51
  '--max-rows': maxRows,
52
- }), children: [_jsx("textarea", { ...otherProps, "aria-errormessage": errorMessage || undefined, "aria-invalid": invalid || undefined, "aria-label": ariaLabel, id: id, name: name, onBlur: (event) => {
52
+ }), children: [_jsx("textarea", { ...otherProps, "aria-describedby": ariaDescribedBy || undefined, "aria-errormessage": ariaErrorMessage || undefined, "aria-invalid": invalid || undefined, "aria-label": ariaLabel, id: id, name: name, onBlur: (event) => {
53
53
  const target = event.target;
54
54
  target.scrollTop = 0;
55
55
  }, onChange: (event) => onChange(event.target.value, event), onInput: onInput, placeholder: placeholder, ref: (node) => {
@@ -58,6 +58,4 @@ function Textarea({ invalid: invalidProp, onChange, textSize = DEFAULT.textSize,
58
58
  onInput();
59
59
  }, value: value, wrap: "hard" }), _jsx("div", { "aria-hidden": true, "data-replicated-value": true })] }));
60
60
  }
61
- Textarea.bspkName = 'Textarea';
62
- export { Textarea };
63
61
  //# sourceMappingURL=Textarea.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Textarea.js","sourceRoot":"","sources":["../../../src/components/Textarea/Textarea.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"Textarea.js","sourceRoot":"","sources":["../../../src/components/Textarea/Textarea.tsx"],"names":[],"mappings":"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"}
@@ -1,3 +1,3 @@
1
- import { ComponentExample } from '../../utils/demo';
2
1
  import { TextareaProps } from '.';
2
+ import { ComponentExample } from '-/utils/demo';
3
3
  export declare const TextareaExample: ComponentExample<TextareaProps>;
@@ -1,2 +1,5 @@
1
- export const TextareaExample = {};
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ export const TextareaExample = {
3
+ render: ({ props, Component }) => _jsx(Component, { ...props }),
4
+ };
2
5
  //# sourceMappingURL=TextareaExample.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TextareaExample.js","sourceRoot":"","sources":["../../../src/components/Textarea/TextareaExample.tsx"],"names":[],"mappings":"AAIA,MAAM,CAAC,MAAM,eAAe,GAAoC,EAAE,CAAC"}
1
+ {"version":3,"file":"TextareaExample.js","sourceRoot":"","sources":["../../../src/components/Textarea/TextareaExample.tsx"],"names":[],"mappings":";AAGA,MAAM,CAAC,MAAM,eAAe,GAAoC;IAC5D,MAAM,EAAE,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE,EAAE,CAAC,KAAC,SAAS,OAAK,KAAK,GAAI;CAC7D,CAAC"}
@@ -75,4 +75,3 @@ style.appendChild(document.createTextNode(`[data-bspk=textarea] {
75
75
  /** Copyright 2025 Anywhere Real Estate - CC BY 4.0 */
76
76
  `));
77
77
  document.head.appendChild(style);
78
-
@@ -1,6 +1,6 @@
1
- import { FormFieldProps } from '../FormField';
2
- import { TextareaProps } from '../Textarea';
3
- export type TextareaFieldProps = Pick<FormFieldProps, 'controlId' | 'helperText' | 'label'> & TextareaProps & {
1
+ import { FormFieldWrapProps } from '-/components/FormField';
2
+ import { TextareaProps } from '-/components/Textarea';
3
+ export type TextareaFieldProps = FormFieldWrapProps<TextareaProps> & {
4
4
  /**
5
5
  * Whether the character count should be displayed.
6
6
  *
@@ -33,11 +33,7 @@ export type TextareaFieldProps = Pick<FormFieldProps, 'controlId' | 'helperText'
33
33
  * }
34
34
  *
35
35
  * @name TextareaField
36
- * @phase DesignReview
36
+ * @phase UXReview
37
37
  */
38
- declare function TextareaField({ label, errorMessage: errorMessageProp, helperText, controlId: id, onChange, maxLength: maxLengthProp, invalid, readOnly, disabled, required, characterCount, ...textareaProps }: TextareaFieldProps): import("react/jsx-runtime").JSX.Element | null;
39
- declare namespace TextareaField {
40
- var bspkName: string;
41
- }
42
- export { TextareaField };
38
+ export declare function TextareaField({ label, helperText, controlId, required, invalid, characterCount, ...inputProps }: TextareaFieldProps): import("react/jsx-runtime").JSX.Element;
43
39
  /** Copyright 2025 Anywhere Real Estate - CC BY 4.0 */
@@ -28,19 +28,16 @@ import { tryIntParse } from '../../utils/tryIntPsrse';
28
28
  * }
29
29
  *
30
30
  * @name TextareaField
31
- * @phase DesignReview
31
+ * @phase UXReview
32
32
  */
33
- function TextareaField({ label, errorMessage: errorMessageProp, helperText, controlId: id, onChange, maxLength: maxLengthProp, invalid, readOnly, disabled, required, characterCount = true, ...textareaProps }) {
34
- const maxLength = tryIntParse(maxLengthProp) || -1;
35
- const errorMessage = (!readOnly && !disabled && errorMessageProp) || undefined;
36
- if (typeof onChange !== 'function')
37
- return null;
38
- return (_jsx(FormField, { controlId: id, "data-bspk": "textarea-field", errorMessage: errorMessage, helperText: helperText, invalid: invalid, label: label, labelTrailing: characterCount && (_jsx(Txt, { style: {
33
+ export function TextareaField({ label, helperText, controlId, required, invalid, characterCount, ...inputProps }) {
34
+ const maxLength = tryIntParse(inputProps.maxLength) || -1;
35
+ return (_jsx(FormField, { controlId: controlId, "data-bspk": "textarea-field", helperText: helperText, invalid: invalid, label: label, labelTrailing:
36
+ // If characterCount is falsey, we don't want to show the labelTrailing
37
+ characterCount && (_jsx(Txt, { style: {
39
38
  color: 'var(--foreground-neutral-on-surface-variant-02)',
40
- }, variant: "body-small", children: `${textareaProps?.value?.length || 0}${maxLength > 0 ? `/${maxLength}` : ''}` })), required: required, children: (fieldProps) => (_jsx(Textarea, { ...textareaProps, ...fieldProps, "aria-label": textareaProps['aria-label'] || label, id: id, invalid: invalid, onChange: (next, event) => {
41
- onChange(next, event);
42
- }, required: required })) }));
39
+ }, variant: "body-small", children: `${inputProps?.value?.length || 0}${maxLength > 0 ? `/${maxLength}` : ''}` })), required: required, children: (fieldProps) => (_jsx(Textarea
40
+ //
41
+ , { ...inputProps, ...fieldProps, invalid: invalid })) }));
43
42
  }
44
- TextareaField.bspkName = 'TextareaField';
45
- export { TextareaField };
46
43
  //# sourceMappingURL=TextareaField.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TextareaField.js","sourceRoot":"","sources":["../../../src/components/TextareaField/TextareaField.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAkB,SAAS,EAAE,MAAM,wBAAwB,CAAC;AACnE,OAAO,EAAiB,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAChE,OAAO,EAAE,GAAG,EAAE,MAAM,kBAAkB,CAAC;AACvC,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAWlD;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,SAAS,aAAa,CAAC,EACnB,KAAK,EACL,YAAY,EAAE,gBAAgB,EAC9B,UAAU,EACV,SAAS,EAAE,EAAE,EACb,QAAQ,EACR,SAAS,EAAE,aAAa,EACxB,OAAO,EACP,QAAQ,EACR,QAAQ,EACR,QAAQ,EACR,cAAc,GAAG,IAAI,EACrB,GAAG,aAAa,EACC;IACjB,MAAM,SAAS,GAAG,WAAW,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC;IACnD,MAAM,YAAY,GAAG,CAAC,CAAC,QAAQ,IAAI,CAAC,QAAQ,IAAI,gBAAgB,CAAC,IAAI,SAAS,CAAC;IAE/E,IAAI,OAAO,QAAQ,KAAK,UAAU;QAAE,OAAO,IAAI,CAAC;IAEhD,OAAO,CACH,KAAC,SAAS,IACN,SAAS,EAAE,EAAE,eACH,gBAAgB,EAC1B,YAAY,EAAE,YAAY,EAC1B,UAAU,EAAE,UAAU,EACtB,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE,KAAK,EACZ,aAAa,EACT,cAAc,IAAI,CACd,KAAC,GAAG,IACA,KAAK,EAAE;gBACH,KAAK,EAAE,iDAAiD;aAC3D,EACD,OAAO,EAAC,YAAY,YAEnB,GAAG,aAAa,EAAE,KAAK,EAAE,MAAM,IAAI,CAAC,GAAG,SAAS,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,GAC5E,CACT,EAEL,QAAQ,EAAE,QAAQ,YAEjB,CAAC,UAAU,EAAE,EAAE,CAAC,CACb,KAAC,QAAQ,OACD,aAAa,KACb,UAAU,gBACF,aAAa,CAAC,YAAY,CAAC,IAAI,KAAK,EAChD,EAAE,EAAE,EAAE,EACN,OAAO,EAAE,OAAO,EAChB,QAAQ,EAAE,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;gBACtB,QAAQ,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;YAC1B,CAAC,EACD,QAAQ,EAAE,QAAQ,GACpB,CACL,GACO,CACf,CAAC;AACN,CAAC;AAED,aAAa,CAAC,QAAQ,GAAG,eAAe,CAAC;AAEzC,OAAO,EAAE,aAAa,EAAE,CAAC"}
1
+ {"version":3,"file":"TextareaField.js","sourceRoot":"","sources":["../../../src/components/TextareaField/TextareaField.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAsB,SAAS,EAAE,MAAM,wBAAwB,CAAC;AACvE,OAAO,EAAiB,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAChE,OAAO,EAAE,GAAG,EAAE,MAAM,kBAAkB,CAAC;AACvC,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAWlD;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,MAAM,UAAU,aAAa,CAAC,EAC1B,KAAK,EACL,UAAU,EACV,SAAS,EACT,QAAQ,EACR,OAAO,EACP,cAAc,EACd,GAAG,UAAU,EACI;IACjB,MAAM,SAAS,GAAG,WAAW,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC;IAE1D,OAAO,CACH,KAAC,SAAS,IACN,SAAS,EAAE,SAAS,eACV,gBAAgB,EAC1B,UAAU,EAAE,UAAU,EACtB,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE,KAAK,EACZ,aAAa;QACT,uEAAuE;QACvE,cAAc,IAAI,CACd,KAAC,GAAG,IACA,KAAK,EAAE;gBACH,KAAK,EAAE,iDAAiD;aAC3D,EACD,OAAO,EAAC,YAAY,YAEnB,GAAG,UAAU,EAAE,KAAK,EAAE,MAAM,IAAI,CAAC,GAAG,SAAS,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,GACzE,CACT,EAEL,QAAQ,EAAE,QAAQ,YAEjB,CAAC,UAAU,EAAE,EAAE,CAAC,CACb,KAAC,QAAQ;QACL,EAAE;eACE,UAAU,KACV,UAAU,EACd,OAAO,EAAE,OAAO,GAClB,CACL,GACO,CACf,CAAC;AACN,CAAC"}
@@ -1,3 +1,3 @@
1
- import { ComponentExample } from '../../utils/demo';
2
1
  import { TextareaFieldProps } from '.';
2
+ import { ComponentExample } from '-/utils/demo';
3
3
  export declare const TextareaFieldExample: ComponentExample<TextareaFieldProps>;
@@ -3,7 +3,8 @@ export const TextareaFieldExample = {
3
3
  render: ({ Component, props }) => {
4
4
  const tooManyCharacters = Boolean(props.value && props.maxLength && props.value?.length > props.maxLength);
5
5
  const invalid = props.invalid || tooManyCharacters;
6
- return (_jsx(Component, { ...props, errorMessage: invalid ? props.errorMessage || 'Too Many characters' : '', invalid: invalid }));
6
+ const errorMessage = tooManyCharacters ? 'Too Many characters' : props.errorMessage || '';
7
+ return _jsx(Component, { ...props, errorMessage: errorMessage, invalid: invalid });
7
8
  },
8
9
  };
9
10
  //# sourceMappingURL=TextareaFieldExample.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TextareaFieldExample.js","sourceRoot":"","sources":["../../../src/components/TextareaField/TextareaFieldExample.tsx"],"names":[],"mappings":";AAIA,MAAM,CAAC,MAAM,oBAAoB,GAAyC;IACtE,MAAM,EAAE,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,EAAE;QAC7B,MAAM,iBAAiB,GAAG,OAAO,CAAC,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,SAAS,IAAI,KAAK,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,CAAC,SAAS,CAAC,CAAC;QAE3G,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,IAAI,iBAAiB,CAAC;QAEnD,OAAO,CACH,KAAC,SAAS,OACF,KAAK,EACT,YAAY,EAAE,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,YAAY,IAAI,qBAAqB,CAAC,CAAC,CAAC,EAAE,EACxE,OAAO,EAAE,OAAO,GAClB,CACL,CAAC;IACN,CAAC;CACJ,CAAC"}
1
+ {"version":3,"file":"TextareaFieldExample.js","sourceRoot":"","sources":["../../../src/components/TextareaField/TextareaFieldExample.tsx"],"names":[],"mappings":";AAGA,MAAM,CAAC,MAAM,oBAAoB,GAAyC;IACtE,MAAM,EAAE,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,EAAE;QAC7B,MAAM,iBAAiB,GAAG,OAAO,CAAC,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,SAAS,IAAI,KAAK,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,CAAC,SAAS,CAAC,CAAC;QAE3G,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,IAAI,iBAAiB,CAAC;QACnD,MAAM,YAAY,GAAG,iBAAiB,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,KAAK,CAAC,YAAY,IAAI,EAAE,CAAC;QAE1F,OAAO,KAAC,SAAS,OAAK,KAAK,EAAE,YAAY,EAAE,YAAY,EAAE,OAAO,EAAE,OAAO,GAAI,CAAC;IAClF,CAAC;CACJ,CAAC"}
@@ -0,0 +1,10 @@
1
+ import { TimeInputType } from './Segment';
2
+ type TimeInputListboxProps<T> = {
3
+ options: T[];
4
+ selectedValue?: T;
5
+ type: TimeInputType;
6
+ onSelect?: (value: T) => void;
7
+ onTab?: (e: React.KeyboardEvent) => void;
8
+ };
9
+ export declare function TimeInputListbox<T>({ options, selectedValue, type: kind, onSelect, onTab }: TimeInputListboxProps<T>): import("react/jsx-runtime").JSX.Element;
10
+ export {};
@@ -0,0 +1,66 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { useRef, useState } from 'react';
3
+ import { bound } from '../../utils/bound';
4
+ import { handleKeyDown } from '../../utils/handleKeyDown';
5
+ import { scrollElementIntoView } from '../../utils/scrollElementIntoView';
6
+ export function TimeInputListbox({ options, selectedValue, type: kind, onSelect, onTab }) {
7
+ const [activeIndex, setActiveIndex] = useState(-1);
8
+ const listRef = useRef(null);
9
+ const handleArrow = (dir) => {
10
+ return (e) => {
11
+ e.preventDefault();
12
+ setActiveIndex((prevIndex) => {
13
+ const next = bound({
14
+ num: prevIndex + (dir === 'down' ? 1 : -1),
15
+ min: 0,
16
+ max: options.length - 1,
17
+ rollover: true,
18
+ });
19
+ scrollElementIntoView(listRef.current?.children[next], listRef.current);
20
+ return next;
21
+ });
22
+ };
23
+ };
24
+ return (_jsx("div", { "aria-label": `Select ${kind}`, "data-scroll-column": kind, onClick: (event) => {
25
+ const target = event.target;
26
+ if (target.dataset.value)
27
+ onSelect?.(target.dataset.value);
28
+ }, onFocus: () => {
29
+ if (activeIndex < 0 && options.length > 0)
30
+ scrollElementIntoView(listRef.current?.children[activeIndex], listRef.current);
31
+ }, onKeyDown: handleKeyDown({
32
+ ArrowDown: handleArrow('down'),
33
+ ArrowUp: handleArrow('up'),
34
+ ArrowLeft: (e) => {
35
+ e.preventDefault();
36
+ const previousSibling = e.currentTarget.previousElementSibling;
37
+ if (previousSibling)
38
+ previousSibling.focus();
39
+ else
40
+ e.currentTarget.parentNode?.lastElementChild?.focus();
41
+ },
42
+ ArrowRight: (e) => {
43
+ e.preventDefault();
44
+ const nextSibling = e.currentTarget.nextElementSibling;
45
+ if (nextSibling)
46
+ nextSibling.focus();
47
+ else
48
+ e.currentTarget.parentNode?.firstElementChild?.focus();
49
+ },
50
+ Enter: (e) => {
51
+ e.preventDefault();
52
+ if (activeIndex >= 0 && activeIndex < options.length)
53
+ onSelect?.(options[activeIndex]);
54
+ },
55
+ Tab: onTab,
56
+ }), onMouseMove: (event) => {
57
+ const target = event.target;
58
+ setActiveIndex(Number(target.dataset.index));
59
+ event.currentTarget.focus();
60
+ }, ref: (node) => {
61
+ if (!node)
62
+ return;
63
+ listRef.current = node;
64
+ }, role: "listbox", tabIndex: 0, children: options.map((val, index) => (_jsx("span", { "aria-label": `${val}`.padStart(2, '0'), "aria-selected": `${val}` === `${selectedValue}` || undefined, "data-active": activeIndex === index || undefined, "data-index": index, "data-value": val, role: "option", children: `${val}`.padStart(2, '0') }, `${val}`))) }));
65
+ }
66
+ //# sourceMappingURL=Listbox.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Listbox.js","sourceRoot":"","sources":["../../../src/components/TimeInput/Listbox.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,21 @@
1
+ export declare const MINUTE_BOUNDS: {
2
+ readonly min: 0;
3
+ readonly max: 59;
4
+ };
5
+ export declare const HOUR_BOUNDS: {
6
+ readonly min: 1;
7
+ readonly max: 12;
8
+ };
9
+ export declare const NUMBER_PLACEHOLDER: "--";
10
+ export type TimeInputType = 'hours' | 'meridiem' | 'minutes';
11
+ type TimeInputSegmentProps<T extends number | string> = {
12
+ ariaLabel?: string;
13
+ disabled?: boolean;
14
+ name: string;
15
+ readOnly?: boolean;
16
+ defaultValue?: T;
17
+ type: TimeInputType;
18
+ onChange: (value: T | null) => void;
19
+ };
20
+ export declare function TimeInputSegment<T extends number | string>({ ariaLabel, disabled, name, readOnly, defaultValue, type: kind, onChange, }: TimeInputSegmentProps<T>): import("react/jsx-runtime").JSX.Element;
21
+ export {};
@@ -0,0 +1,160 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { useCallback, useEffect, useRef } from 'react';
3
+ import { bound } from '../../utils/bound';
4
+ import { handleKeyDown } from '../../utils/handleKeyDown';
5
+ export const MINUTE_BOUNDS = { min: 0, max: 59 };
6
+ export const HOUR_BOUNDS = { min: 1, max: 12 };
7
+ export const NUMBER_PLACEHOLDER = '--';
8
+ export function TimeInputSegment({ ariaLabel, disabled, name, readOnly, defaultValue, type: kind, onChange, }) {
9
+ const ref = useRef(null);
10
+ const selectAll = (element = ref.current) => {
11
+ if (!element)
12
+ return;
13
+ setTimeout(() => {
14
+ window.getSelection()?.selectAllChildren(element);
15
+ }, 10);
16
+ };
17
+ const valueToContent = useCallback((value) => {
18
+ if (kind === 'meridiem')
19
+ return value?.toString() || 'AM';
20
+ if (typeof value === 'undefined')
21
+ return NUMBER_PLACEHOLDER;
22
+ const boundedValue = bound({
23
+ num: value,
24
+ rollover: true,
25
+ ...(kind === 'hours' ? HOUR_BOUNDS : MINUTE_BOUNDS),
26
+ });
27
+ return boundedValue.toString().padStart(2, '0');
28
+ }, [kind]);
29
+ useEffect(() => {
30
+ if (ref.current)
31
+ ref.current.textContent = valueToContent(defaultValue);
32
+ }, [defaultValue, valueToContent]);
33
+ const handleBlur = () => {
34
+ window.getSelection()?.removeAllRanges();
35
+ };
36
+ const handleIncrement = useCallback((increment) => {
37
+ const currentValue = ref.current?.textContent;
38
+ if (kind === 'meridiem') {
39
+ const nextMeridiem = currentValue === 'AM' ? 'PM' : 'AM';
40
+ onChange(nextMeridiem);
41
+ return;
42
+ }
43
+ const nextValue = bound({
44
+ num: Number(currentValue) + increment,
45
+ rollover: true,
46
+ ...(kind === 'minutes' ? MINUTE_BOUNDS : HOUR_BOUNDS),
47
+ });
48
+ onChange(nextValue);
49
+ if (ref.current)
50
+ ref.current.textContent = nextValue.toString().padStart(2, '0');
51
+ }, [kind, onChange]);
52
+ const nextSibling = () => getNextSibling(ref.current, '[data-input]');
53
+ const previousSibling = () => getPreviousSibling(ref.current, '[data-input]');
54
+ const handleInputKeyDown = useCallback((event) => {
55
+ // Prevent default behavior for all keys - we handle them manually
56
+ if (handleKeyDown({
57
+ ArrowRight: () => {
58
+ nextSibling()?.focus();
59
+ event.preventDefault();
60
+ },
61
+ ArrowLeft: () => {
62
+ previousSibling()?.focus();
63
+ event.preventDefault();
64
+ },
65
+ ArrowUp: () => {
66
+ handleIncrement(1);
67
+ event.preventDefault();
68
+ },
69
+ ArrowDown: () => {
70
+ handleIncrement(-1);
71
+ event.preventDefault();
72
+ },
73
+ Enter: () => ref.current?.blur(),
74
+ Escape: () => ref.current?.blur(),
75
+ Backspace: () => onChange(null),
76
+ Tab: () => {
77
+ // do nothing
78
+ },
79
+ })(event))
80
+ return;
81
+ event.preventDefault();
82
+ // if hours only allow digits and if digit is found only once in VALID_HOURS then set the value and move to next element
83
+ if (kind === 'meridiem') {
84
+ const inputValue = event.key.toUpperCase();
85
+ if (inputValue === 'A' || inputValue === 'P') {
86
+ onChange(`${inputValue}M`);
87
+ nextSibling()?.focus();
88
+ selectAll();
89
+ return;
90
+ }
91
+ return;
92
+ }
93
+ // only handle digits from here
94
+ if (!/^\d$/.test(event.key))
95
+ return;
96
+ let nextNumber = Number(event.key);
97
+ const currentValue = ref.current?.textContent;
98
+ const addToExisting = (kind === 'hours' && currentValue === '01' && nextNumber < 3) ||
99
+ (kind === 'minutes' && Number(currentValue) < 6);
100
+ if (addToExisting)
101
+ nextNumber = Number(`${currentValue}${nextNumber}`);
102
+ else if (nextNumber === 0)
103
+ return; // ignore leading zero
104
+ nextNumber = bound({
105
+ num: nextNumber,
106
+ ...(kind === 'minutes' ? MINUTE_BOUNDS : HOUR_BOUNDS),
107
+ });
108
+ onChange(nextNumber);
109
+ if (ref.current)
110
+ ref.current.textContent = nextNumber.toString().padStart(2, '0');
111
+ const moveToNext = (kind === 'hours' && nextNumber > 2) || (kind === 'minutes' && nextNumber > 5);
112
+ if (moveToNext) {
113
+ nextSibling()?.focus();
114
+ selectAll(nextSibling());
115
+ }
116
+ else {
117
+ selectAll();
118
+ }
119
+ return;
120
+ }, [kind, handleIncrement, onChange]);
121
+ return (_jsx("span", { "aria-disabled": disabled, "aria-label": `${ariaLabel} ${name.charAt(0).toUpperCase() + name.slice(1)}`, "aria-readonly": readOnly, contentEditable: !readOnly && !disabled, "data-input": "", "data-type": kind, "data-value": defaultValue || undefined, id: `${name}`, onBlur: handleBlur, onClick: () => {
122
+ if (disabled || readOnly)
123
+ return;
124
+ selectAll();
125
+ }, onFocus: () => {
126
+ if (disabled || readOnly)
127
+ return;
128
+ selectAll();
129
+ }, onKeyDown: handleInputKeyDown, ref: (element) => {
130
+ if (!element)
131
+ return;
132
+ ref.current = element;
133
+ element.textContent = valueToContent(defaultValue);
134
+ }, role: "spinbutton", tabIndex: 0 }));
135
+ }
136
+ function getNextSibling(elem, selector) {
137
+ // Get the next sibling element
138
+ let sibling = elem?.nextElementSibling;
139
+ // If the sibling matches our selector, use it
140
+ // If not, jump to the next sibling and continue the loop
141
+ while (sibling) {
142
+ if (sibling.matches(selector))
143
+ return sibling;
144
+ sibling = sibling.nextElementSibling;
145
+ }
146
+ return null;
147
+ }
148
+ function getPreviousSibling(elem, selector) {
149
+ // Get the previous sibling element
150
+ let sibling = elem?.previousElementSibling;
151
+ // If the sibling matches our selector, use it
152
+ // If not, jump to the previous sibling and continue the loop
153
+ while (sibling) {
154
+ if (sibling.matches(selector))
155
+ return sibling;
156
+ sibling = sibling.previousElementSibling;
157
+ }
158
+ return null;
159
+ }
160
+ //# sourceMappingURL=Segment.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Segment.js","sourceRoot":"","sources":["../../../src/components/TimeInput/Segment.tsx"],"names":[],"mappings":"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"}