@bspk/ui 1.0.1 → 1.1.12

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 (677) hide show
  1. package/README.md +5 -0
  2. package/{Avatar.d.ts → dist/Avatar.d.ts} +2 -2
  3. package/dist/Avatar.js +27 -0
  4. package/dist/Avatar.js.map +1 -0
  5. package/{Badge.d.ts → dist/Badge.d.ts} +2 -2
  6. package/dist/Badge.js +16 -0
  7. package/dist/Badge.js.map +1 -0
  8. package/{BannerAlert.d.ts → dist/BannerAlert.d.ts} +4 -4
  9. package/dist/BannerAlert.js +20 -0
  10. package/dist/BannerAlert.js.map +1 -0
  11. package/{Button.d.ts → dist/Button.d.ts} +1 -1
  12. package/dist/Button.js +30 -0
  13. package/dist/Button.js.map +1 -0
  14. package/{Card.d.ts → dist/Card.d.ts} +2 -2
  15. package/dist/Card.js +18 -0
  16. package/dist/Card.js.map +1 -0
  17. package/{Checkbox.d.ts → dist/Checkbox.d.ts} +2 -2
  18. package/dist/Checkbox.js +32 -0
  19. package/dist/Checkbox.js.map +1 -0
  20. package/{CheckboxGroup.d.ts → dist/CheckboxGroup.d.ts} +1 -1
  21. package/dist/CheckboxGroup.js +16 -0
  22. package/dist/CheckboxGroup.js.map +1 -0
  23. package/{CheckboxOption.d.ts → dist/CheckboxOption.d.ts} +1 -1
  24. package/dist/CheckboxOption.js +14 -0
  25. package/dist/CheckboxOption.js.map +1 -0
  26. package/{Chip.d.ts → dist/Chip.d.ts} +2 -2
  27. package/dist/Chip.js +22 -0
  28. package/dist/Chip.js.map +1 -0
  29. package/{Dialog.d.ts → dist/Dialog.d.ts} +2 -2
  30. package/dist/Dialog.js +70 -0
  31. package/dist/Dialog.js.map +1 -0
  32. package/{Divider.d.ts → dist/Divider.d.ts} +2 -2
  33. package/dist/Divider.js +26 -0
  34. package/dist/Divider.js.map +1 -0
  35. package/{Dropdown.d.ts → dist/Dropdown.d.ts} +2 -2
  36. package/dist/Dropdown.js +37 -0
  37. package/dist/Dropdown.js.map +1 -0
  38. package/{DropdownField.d.ts → dist/DropdownField.d.ts} +1 -1
  39. package/{DropdownField.js → dist/DropdownField.js} +5 -7
  40. package/dist/DropdownField.js.map +1 -0
  41. package/{EmptyState.d.ts → dist/EmptyState.d.ts} +7 -1
  42. package/dist/EmptyState.js +18 -0
  43. package/dist/EmptyState.js.map +1 -0
  44. package/{Fab.d.ts → dist/Fab.d.ts} +2 -2
  45. package/dist/Fab.js +24 -0
  46. package/dist/Fab.js.map +1 -0
  47. package/{FormField.d.ts → dist/FormField.d.ts} +2 -2
  48. package/dist/FormField.js +27 -0
  49. package/dist/FormField.js.map +1 -0
  50. package/{Img.d.ts → dist/Img.d.ts} +1 -1
  51. package/dist/Img.js +12 -0
  52. package/dist/Img.js.map +1 -0
  53. package/{InlineAlert.d.ts → dist/InlineAlert.d.ts} +2 -2
  54. package/dist/InlineAlert.js +27 -0
  55. package/dist/InlineAlert.js.map +1 -0
  56. package/{Layout.d.ts → dist/Layout.d.ts} +1 -1
  57. package/{Layout.js → dist/Layout.js} +3 -5
  58. package/dist/Layout.js.map +1 -0
  59. package/{Link.d.ts → dist/Link.d.ts} +2 -2
  60. package/dist/Link.js +17 -0
  61. package/dist/Link.js.map +1 -0
  62. package/{ListItem.d.ts → dist/ListItem.d.ts} +3 -3
  63. package/dist/ListItem.js +93 -0
  64. package/dist/ListItem.js.map +1 -0
  65. package/{Menu.d.ts → dist/Menu.d.ts} +2 -2
  66. package/dist/Menu.js +62 -0
  67. package/dist/Menu.js.map +1 -0
  68. package/{MenuButton.d.ts → dist/MenuButton.d.ts} +2 -2
  69. package/dist/MenuButton.js +15 -0
  70. package/dist/MenuButton.js.map +1 -0
  71. package/{Modal.d.ts → dist/Modal.d.ts} +2 -2
  72. package/dist/Modal.js +32 -0
  73. package/dist/Modal.js.map +1 -0
  74. package/{NumberField.d.ts → dist/NumberField.d.ts} +1 -1
  75. package/{NumberField.js → dist/NumberField.js} +5 -7
  76. package/dist/NumberField.js.map +1 -0
  77. package/{NumberInput.d.ts → dist/NumberInput.d.ts} +2 -2
  78. package/dist/NumberInput.js +64 -0
  79. package/dist/NumberInput.js.map +1 -0
  80. package/{Popover.d.ts → dist/Popover.d.ts} +2 -2
  81. package/dist/Popover.js +46 -0
  82. package/dist/Popover.js.map +1 -0
  83. package/{Portal.js → dist/Portal.js} +4 -5
  84. package/dist/Portal.js.map +1 -0
  85. package/{ProgressBar.d.ts → dist/ProgressBar.d.ts} +2 -2
  86. package/dist/ProgressBar.js +17 -0
  87. package/dist/ProgressBar.js.map +1 -0
  88. package/{ProgressCircle.d.ts → dist/ProgressCircle.d.ts} +3 -3
  89. package/dist/ProgressCircle.js +30 -0
  90. package/dist/ProgressCircle.js.map +1 -0
  91. package/{ProgressionStepper.d.ts → dist/ProgressionStepper.d.ts} +2 -2
  92. package/dist/ProgressionStepper.js +24 -0
  93. package/dist/ProgressionStepper.js.map +1 -0
  94. package/{ProgressionStepperBar.d.ts → dist/ProgressionStepperBar.d.ts} +7 -3
  95. package/dist/ProgressionStepperBar.js +15 -0
  96. package/dist/ProgressionStepperBar.js.map +1 -0
  97. package/{Radio.d.ts → dist/Radio.d.ts} +2 -2
  98. package/dist/Radio.js +18 -0
  99. package/dist/Radio.js.map +1 -0
  100. package/{RadioGroup.d.ts → dist/RadioGroup.d.ts} +1 -1
  101. package/dist/RadioGroup.js +16 -0
  102. package/dist/RadioGroup.js.map +1 -0
  103. package/{RadioOption.d.ts → dist/RadioOption.d.ts} +1 -1
  104. package/dist/RadioOption.js +14 -0
  105. package/dist/RadioOption.js.map +1 -0
  106. package/{SearchBar.d.ts → dist/SearchBar.d.ts} +2 -2
  107. package/{SearchBar.js → dist/SearchBar.js} +13 -19
  108. package/dist/SearchBar.js.map +1 -0
  109. package/{SegmentedControl.d.ts → dist/SegmentedControl.d.ts} +2 -2
  110. package/dist/SegmentedControl.js +22 -0
  111. package/dist/SegmentedControl.js.map +1 -0
  112. package/dist/Skeleton.d.ts +45 -0
  113. package/dist/Skeleton.js +25 -0
  114. package/dist/Skeleton.js.map +1 -0
  115. package/{StylesProviderAnywhere.d.ts → dist/StylesProviderAnywhere.d.ts} +4 -1
  116. package/dist/StylesProviderAnywhere.js +15 -0
  117. package/dist/StylesProviderAnywhere.js.map +1 -0
  118. package/{StylesProviderBetterHomesGardens.d.ts → dist/StylesProviderBetterHomesGardens.d.ts} +4 -1
  119. package/dist/StylesProviderBetterHomesGardens.js +15 -0
  120. package/dist/StylesProviderBetterHomesGardens.js.map +1 -0
  121. package/{StylesProviderCartus.d.ts → dist/StylesProviderCartus.d.ts} +4 -1
  122. package/dist/StylesProviderCartus.js +15 -0
  123. package/dist/StylesProviderCartus.js.map +1 -0
  124. package/{StylesProviderCentury21.d.ts → dist/StylesProviderCentury21.d.ts} +4 -1
  125. package/dist/StylesProviderCentury21.js +15 -0
  126. package/dist/StylesProviderCentury21.js.map +1 -0
  127. package/{StylesProviderColdwellBanker.d.ts → dist/StylesProviderColdwellBanker.d.ts} +4 -1
  128. package/dist/StylesProviderColdwellBanker.js +15 -0
  129. package/dist/StylesProviderColdwellBanker.js.map +1 -0
  130. package/{StylesProviderCorcoran.d.ts → dist/StylesProviderCorcoran.d.ts} +4 -1
  131. package/dist/StylesProviderCorcoran.js +15 -0
  132. package/dist/StylesProviderCorcoran.js.map +1 -0
  133. package/{StylesProviderDenaliBoss.d.ts → dist/StylesProviderDenaliBoss.d.ts} +4 -1
  134. package/dist/StylesProviderDenaliBoss.js +15 -0
  135. package/dist/StylesProviderDenaliBoss.js.map +1 -0
  136. package/{StylesProviderEra.d.ts → dist/StylesProviderEra.d.ts} +4 -1
  137. package/dist/StylesProviderEra.js +15 -0
  138. package/dist/StylesProviderEra.js.map +1 -0
  139. package/{StylesProviderSothebys.d.ts → dist/StylesProviderSothebys.d.ts} +4 -1
  140. package/dist/StylesProviderSothebys.js +15 -0
  141. package/dist/StylesProviderSothebys.js.map +1 -0
  142. package/{Switch.d.ts → dist/Switch.d.ts} +2 -2
  143. package/dist/Switch.js +21 -0
  144. package/dist/Switch.js.map +1 -0
  145. package/{SwitchGroup.d.ts → dist/SwitchGroup.d.ts} +1 -1
  146. package/dist/SwitchGroup.js +16 -0
  147. package/dist/SwitchGroup.js.map +1 -0
  148. package/{SwitchOption.d.ts → dist/SwitchOption.d.ts} +1 -1
  149. package/dist/SwitchOption.js +14 -0
  150. package/dist/SwitchOption.js.map +1 -0
  151. package/{TabGroup.d.ts → dist/TabGroup.d.ts} +2 -2
  152. package/dist/TabGroup.js +22 -0
  153. package/dist/TabGroup.js.map +1 -0
  154. package/{Table.d.ts → dist/Table.d.ts} +2 -2
  155. package/dist/Table.js +20 -0
  156. package/dist/Table.js.map +1 -0
  157. package/{Tag.d.ts → dist/Tag.d.ts} +2 -2
  158. package/dist/Tag.js +15 -0
  159. package/dist/Tag.js.map +1 -0
  160. package/{TextField.d.ts → dist/TextField.d.ts} +1 -1
  161. package/dist/TextField.js +17 -0
  162. package/dist/TextField.js.map +1 -0
  163. package/{TextInput.d.ts → dist/TextInput.d.ts} +2 -2
  164. package/dist/TextInput.js +23 -0
  165. package/dist/TextInput.js.map +1 -0
  166. package/{Textarea.d.ts → dist/Textarea.d.ts} +2 -2
  167. package/dist/Textarea.js +39 -0
  168. package/dist/Textarea.js.map +1 -0
  169. package/{TextareaField.d.ts → dist/TextareaField.d.ts} +1 -1
  170. package/dist/TextareaField.js +24 -0
  171. package/dist/TextareaField.js.map +1 -0
  172. package/{ToggleOption.d.ts → dist/ToggleOption.d.ts} +2 -2
  173. package/dist/ToggleOption.js +14 -0
  174. package/dist/ToggleOption.js.map +1 -0
  175. package/{Tooltip.d.ts → dist/Tooltip.d.ts} +2 -2
  176. package/dist/Tooltip.js +42 -0
  177. package/dist/Tooltip.js.map +1 -0
  178. package/{TopNavigation.d.ts → dist/TopNavigation.d.ts} +2 -2
  179. package/dist/TopNavigation.js +14 -0
  180. package/dist/TopNavigation.js.map +1 -0
  181. package/{Txt.d.ts → dist/Txt.d.ts} +1 -1
  182. package/{Txt.js → dist/Txt.js} +3 -8
  183. package/dist/Txt.js.map +1 -0
  184. package/dist/avatar.css +1 -0
  185. package/dist/badge.css +1 -0
  186. package/dist/banner-alert.css +1 -0
  187. package/dist/base.css +1 -0
  188. package/dist/button.css +1 -0
  189. package/dist/card.css +1 -0
  190. package/dist/checkbox.css +1 -0
  191. package/dist/chip.css +1 -0
  192. package/dist/colors.css +1 -0
  193. package/dist/dialog.css +1 -0
  194. package/dist/divider.css +1 -0
  195. package/dist/dropdown.css +1 -0
  196. package/dist/fab.css +1 -0
  197. package/dist/form-field.css +1 -0
  198. package/{hooks → dist/hooks}/useCheckboxGroupState.d.ts +1 -1
  199. package/{hooks → dist/hooks}/useCheckboxGroupState.js +3 -6
  200. package/dist/hooks/useCheckboxGroupState.js.map +1 -0
  201. package/{hooks → dist/hooks}/useCheckboxState.js +2 -5
  202. package/dist/hooks/useCheckboxState.js.map +1 -0
  203. package/{hooks → dist/hooks}/useFloating.js +5 -8
  204. package/dist/hooks/useFloating.js.map +1 -0
  205. package/{hooks → dist/hooks}/useFloatingMenu.js +6 -9
  206. package/dist/hooks/useFloatingMenu.js.map +1 -0
  207. package/{hooks → dist/hooks}/useId.js +4 -7
  208. package/dist/hooks/useId.js.map +1 -0
  209. package/{hooks → dist/hooks}/useKeyboardNavigation.js +4 -7
  210. package/dist/hooks/useKeyboardNavigation.js.map +1 -0
  211. package/{hooks → dist/hooks}/useLongPress.js +3 -6
  212. package/dist/hooks/useLongPress.js.map +1 -0
  213. package/{hooks → dist/hooks}/useModalState.js +3 -6
  214. package/dist/hooks/useModalState.js.map +1 -0
  215. package/{hooks → dist/hooks}/useNavOptions.js +4 -7
  216. package/dist/hooks/useNavOptions.js.map +1 -0
  217. package/{hooks → dist/hooks}/useOutsideClick.js +2 -5
  218. package/dist/hooks/useOutsideClick.js.map +1 -0
  219. package/{hooks → dist/hooks}/useRadioState.js +2 -5
  220. package/dist/hooks/useRadioState.js.map +1 -0
  221. package/{hooks → dist/hooks}/useSwitchGroupState.d.ts +1 -1
  222. package/{hooks → dist/hooks}/useSwitchGroupState.js +3 -6
  223. package/dist/hooks/useSwitchGroupState.js.map +1 -0
  224. package/{hooks → dist/hooks}/useTimeout.js +2 -5
  225. package/dist/hooks/useTimeout.js.map +1 -0
  226. package/{hooks → dist/hooks}/useValidChildren.js +4 -7
  227. package/dist/hooks/useValidChildren.js.map +1 -0
  228. package/{index.js → dist/index.js} +2 -4
  229. package/dist/index.js.map +1 -0
  230. package/dist/inline-alert.css +1 -0
  231. package/dist/link.css +1 -0
  232. package/dist/list-item.css +1 -0
  233. package/dist/menu-button.css +1 -0
  234. package/dist/menu.css +1 -0
  235. package/dist/modal.css +1 -0
  236. package/dist/number-input.css +1 -0
  237. package/dist/popover.css +1 -0
  238. package/dist/progress-bar.css +1 -0
  239. package/dist/progress-circle.css +1 -0
  240. package/dist/progression-stepper-bar.css +1 -0
  241. package/dist/progression-stepper.css +1 -0
  242. package/dist/radio.css +1 -0
  243. package/dist/search-bar.css +1 -0
  244. package/dist/segmented-control.css +1 -0
  245. package/dist/skeleton.css +6 -0
  246. package/dist/switch.css +1 -0
  247. package/dist/tab-group.css +1 -0
  248. package/dist/table.css +1 -0
  249. package/dist/tag.css +1 -0
  250. package/dist/text-input.css +1 -0
  251. package/dist/textarea.css +4 -0
  252. package/dist/toggle-option.css +1 -0
  253. package/dist/tooltip.css +1 -0
  254. package/dist/top-navigation.css +1 -0
  255. package/{utils → dist/utils}/children.js +9 -12
  256. package/dist/utils/children.js.map +1 -0
  257. package/dist/utils/colorVariants.d.ts +7 -0
  258. package/dist/utils/colorVariants.js +22 -0
  259. package/dist/utils/colorVariants.js.map +1 -0
  260. package/{utils → dist/utils}/errors.d.ts +1 -1
  261. package/{utils → dist/utils}/errors.js +20 -12
  262. package/dist/utils/errors.js.map +1 -0
  263. package/{utils → dist/utils}/getValidNode.js +2 -5
  264. package/dist/utils/getValidNode.js.map +1 -0
  265. package/{utils → dist/utils}/keyboard.js +2 -4
  266. package/dist/utils/keyboard.js.map +1 -0
  267. package/dist/utils/placeholder.test.d.ts +1 -0
  268. package/dist/utils/placeholder.test.js +7 -0
  269. package/dist/utils/placeholder.test.js.map +1 -0
  270. package/{utils → dist/utils}/ref.js +2 -4
  271. package/dist/utils/ref.js.map +1 -0
  272. package/{utils → dist/utils}/scrollElementIntoView.js +2 -4
  273. package/dist/utils/scrollElementIntoView.js.map +1 -0
  274. package/{utils → dist/utils}/srOnly.js +2 -4
  275. package/dist/utils/srOnly.js.map +1 -0
  276. package/dist/utils/styleAdd.d.ts +1 -0
  277. package/dist/utils/styleAdd.js +11 -0
  278. package/dist/utils/styleAdd.js.map +1 -0
  279. package/{utils → dist/utils}/tryIntPsrse.js +2 -4
  280. package/dist/utils/tryIntPsrse.js.map +1 -0
  281. package/dist/utils/txtVariants.d.ts +7 -0
  282. package/{utils → dist/utils}/txtVariants.js +7 -4
  283. package/dist/utils/txtVariants.js.map +1 -0
  284. package/meta-types.ts +46 -0
  285. package/meta.ts +465 -0
  286. package/package.json +31 -20
  287. package/src/Avatar.tsx +3 -61
  288. package/src/Badge.tsx +2 -30
  289. package/src/BannerAlert.tsx +6 -119
  290. package/src/Button.tsx +3 -228
  291. package/src/Card.tsx +2 -22
  292. package/src/Checkbox.tsx +2 -94
  293. package/src/CheckboxGroup.tsx +2 -2
  294. package/src/CheckboxOption.tsx +3 -3
  295. package/src/Chip.tsx +2 -68
  296. package/src/Dialog.tsx +2 -154
  297. package/src/Divider.tsx +2 -54
  298. package/src/Dropdown.tsx +2 -119
  299. package/src/DropdownField.tsx +3 -2
  300. package/src/EmptyState.tsx +10 -4
  301. package/src/Fab.tsx +2 -125
  302. package/src/FormField.tsx +2 -15
  303. package/src/Img.tsx +1 -9
  304. package/src/InlineAlert.tsx +2 -48
  305. package/src/Layout.tsx +1 -0
  306. package/src/Link.tsx +2 -23
  307. package/src/ListItem.tsx +3 -118
  308. package/src/Menu.tsx +3 -41
  309. package/src/MenuButton.tsx +2 -17
  310. package/src/Modal.tsx +3 -24
  311. package/src/NumberField.tsx +3 -2
  312. package/src/NumberInput.tsx +2 -126
  313. package/src/Popover.tsx +3 -110
  314. package/src/Portal.tsx +1 -0
  315. package/src/ProgressBar.tsx +2 -49
  316. package/src/ProgressCircle.tsx +2 -57
  317. package/src/ProgressionStepper.tsx +2 -175
  318. package/src/ProgressionStepperBar.tsx +7 -44
  319. package/src/Radio.tsx +2 -82
  320. package/src/RadioGroup.tsx +2 -2
  321. package/src/RadioOption.tsx +3 -3
  322. package/src/SearchBar.tsx +4 -10
  323. package/src/SegmentedControl.tsx +2 -116
  324. package/src/Skeleton.tsx +40 -56
  325. package/src/StylesProviderAnywhere.tsx +4 -18
  326. package/src/StylesProviderBetterHomesGardens.tsx +4 -18
  327. package/src/StylesProviderCartus.tsx +4 -18
  328. package/src/StylesProviderCentury21.tsx +4 -18
  329. package/src/StylesProviderColdwellBanker.tsx +4 -18
  330. package/src/StylesProviderCorcoran.tsx +4 -18
  331. package/src/StylesProviderDenaliBoss.tsx +4 -18
  332. package/src/StylesProviderEra.tsx +4 -18
  333. package/src/StylesProviderSothebys.tsx +4 -18
  334. package/src/Switch.tsx +2 -66
  335. package/src/SwitchGroup.tsx +2 -2
  336. package/src/SwitchOption.tsx +3 -3
  337. package/src/TabGroup.tsx +2 -100
  338. package/src/Table.tsx +2 -49
  339. package/src/Tag.tsx +3 -67
  340. package/src/TextField.tsx +3 -2
  341. package/src/TextInput.tsx +2 -152
  342. package/src/Textarea.tsx +2 -80
  343. package/src/TextareaField.tsx +3 -2
  344. package/src/ToggleOption.tsx +2 -79
  345. package/src/Tooltip.tsx +3 -66
  346. package/src/TopNavigation.tsx +2 -10
  347. package/src/Txt.tsx +1 -9
  348. package/src/avatar.scss +74 -0
  349. package/src/badge.scss +28 -0
  350. package/{BannerAlert.js → src/banner-alert.scss} +5 -23
  351. package/src/{styles/base.css → base.scss} +5 -3
  352. package/src/button.scss +218 -0
  353. package/src/card.scss +23 -0
  354. package/{Checkbox.js → src/checkbox.scss} +9 -34
  355. package/{Chip.js → src/chip.scss} +3 -24
  356. package/src/colors.scss +76 -0
  357. package/{Dialog.js → src/dialog.scss} +7 -76
  358. package/src/divider.scss +47 -0
  359. package/{Dropdown.js → src/dropdown.scss} +4 -45
  360. package/{Fab.js → src/fab.scss} +4 -27
  361. package/src/form-field.scss +13 -0
  362. package/src/hooks/useFloating.ts +5 -5
  363. package/src/inline-alert.scss +51 -0
  364. package/src/link.scss +21 -0
  365. package/src/list-item.scss +113 -0
  366. package/src/menu-button.scss +16 -0
  367. package/src/menu.scss +36 -0
  368. package/src/modal.scss +22 -0
  369. package/src/number-input.scss +128 -0
  370. package/{Popover.js → src/popover.scss} +10 -49
  371. package/src/progress-bar.scss +50 -0
  372. package/src/progress-circle.scss +56 -0
  373. package/src/progression-stepper-bar.scss +39 -0
  374. package/{ProgressionStepper.js → src/progression-stepper.scss} +8 -27
  375. package/{Radio.js → src/radio.scss} +6 -22
  376. package/src/search-bar.scss +7 -0
  377. package/{SegmentedControl.js → src/segmented-control.scss} +7 -24
  378. package/src/skeleton.scss +83 -0
  379. package/{Switch.js → src/switch.scss} +4 -25
  380. package/{TabGroup.js → src/tab-group.scss} +9 -26
  381. package/{Table.js → src/table.scss} +4 -22
  382. package/{Tag.js → src/tag.scss} +5 -28
  383. package/{TextInput.js → src/text-input.scss} +7 -31
  384. package/{Textarea.js → src/textarea.scss} +9 -38
  385. package/{ToggleOption.js → src/toggle-option.scss} +3 -16
  386. package/src/tooltip.scss +63 -0
  387. package/src/top-navigation.scss +5 -0
  388. package/src/utils/children.ts +1 -1
  389. package/src/utils/colorVariants.ts +22 -73
  390. package/src/utils/styleAdd.ts +7 -0
  391. package/src/utils/txtVariants.ts +8 -27
  392. package/Accordion.d.ts +0 -20
  393. package/Accordion.js +0 -18
  394. package/Accordion.js.map +0 -1
  395. package/Avatar.js +0 -81
  396. package/Avatar.js.map +0 -1
  397. package/Badge.js +0 -43
  398. package/Badge.js.map +0 -1
  399. package/BannerAlert.js.map +0 -1
  400. package/BottomNavigation.d.ts +0 -20
  401. package/BottomNavigation.js +0 -18
  402. package/BottomNavigation.js.map +0 -1
  403. package/BottomSheet.d.ts +0 -20
  404. package/BottomSheet.js +0 -18
  405. package/BottomSheet.js.map +0 -1
  406. package/Breadcrumb.d.ts +0 -20
  407. package/Breadcrumb.js +0 -18
  408. package/Breadcrumb.js.map +0 -1
  409. package/Button.js +0 -254
  410. package/Button.js.map +0 -1
  411. package/ButtonDock.d.ts +0 -20
  412. package/ButtonDock.js +0 -18
  413. package/ButtonDock.js.map +0 -1
  414. package/CODE_OF_CONDUCT.md +0 -137
  415. package/CONTRIBUTING.md +0 -42
  416. package/Card.js +0 -38
  417. package/Card.js.map +0 -1
  418. package/Chart.d.ts +0 -20
  419. package/Chart.js +0 -18
  420. package/Chart.js.map +0 -1
  421. package/Checkbox.js.map +0 -1
  422. package/CheckboxGroup.js +0 -18
  423. package/CheckboxGroup.js.map +0 -1
  424. package/CheckboxOption.js +0 -16
  425. package/CheckboxOption.js.map +0 -1
  426. package/Chip.js.map +0 -1
  427. package/DatePicker.d.ts +0 -20
  428. package/DatePicker.js +0 -18
  429. package/DatePicker.js.map +0 -1
  430. package/Dialog.js.map +0 -1
  431. package/Divider.js +0 -76
  432. package/Divider.js.map +0 -1
  433. package/Drawer.d.ts +0 -20
  434. package/Drawer.js +0 -18
  435. package/Drawer.js.map +0 -1
  436. package/Dropdown.js.map +0 -1
  437. package/DropdownField.js.map +0 -1
  438. package/EmptyState.js +0 -20
  439. package/EmptyState.js.map +0 -1
  440. package/Fab.js.map +0 -1
  441. package/FileUpload.d.ts +0 -20
  442. package/FileUpload.js +0 -18
  443. package/FileUpload.js.map +0 -1
  444. package/FormField.js +0 -39
  445. package/FormField.js.map +0 -1
  446. package/GUIDELINES.md +0 -41
  447. package/Image.d.ts +0 -20
  448. package/Image.js +0 -18
  449. package/Image.js.map +0 -1
  450. package/Img.js +0 -20
  451. package/Img.js.map +0 -1
  452. package/InlineAlert.js +0 -73
  453. package/InlineAlert.js.map +0 -1
  454. package/Layout.js.map +0 -1
  455. package/Link.js +0 -37
  456. package/Link.js.map +0 -1
  457. package/ListItem.js +0 -207
  458. package/ListItem.js.map +0 -1
  459. package/Menu.js +0 -98
  460. package/Menu.js.map +0 -1
  461. package/MenuButton.js +0 -30
  462. package/MenuButton.js.map +0 -1
  463. package/Modal.js +0 -53
  464. package/Modal.js.map +0 -1
  465. package/MultiSelection.d.ts +0 -20
  466. package/MultiSelection.js +0 -18
  467. package/MultiSelection.js.map +0 -1
  468. package/NavigationRail.d.ts +0 -20
  469. package/NavigationRail.js +0 -18
  470. package/NavigationRail.js.map +0 -1
  471. package/NumberField.js.map +0 -1
  472. package/NumberInput.js +0 -188
  473. package/NumberInput.js.map +0 -1
  474. package/OTPInput.d.ts +0 -20
  475. package/OTPInput.js +0 -18
  476. package/OTPInput.js.map +0 -1
  477. package/PageControl.d.ts +0 -20
  478. package/PageControl.js +0 -18
  479. package/PageControl.js.map +0 -1
  480. package/PasswordInput.d.ts +0 -20
  481. package/PasswordInput.js +0 -18
  482. package/PasswordInput.js.map +0 -1
  483. package/PhoneNumberInput.d.ts +0 -20
  484. package/PhoneNumberInput.js +0 -18
  485. package/PhoneNumberInput.js.map +0 -1
  486. package/Popover.js.map +0 -1
  487. package/Portal.js.map +0 -1
  488. package/ProgressBar.js +0 -64
  489. package/ProgressBar.js.map +0 -1
  490. package/ProgressCircle.js +0 -82
  491. package/ProgressCircle.js.map +0 -1
  492. package/ProgressionStepper.js.map +0 -1
  493. package/ProgressionStepperBar.js +0 -51
  494. package/ProgressionStepperBar.js.map +0 -1
  495. package/Radio.js.map +0 -1
  496. package/RadioGroup.js +0 -18
  497. package/RadioGroup.js.map +0 -1
  498. package/RadioOption.js +0 -16
  499. package/RadioOption.js.map +0 -1
  500. package/Rating.d.ts +0 -16
  501. package/Rating.js +0 -18
  502. package/Rating.js.map +0 -1
  503. package/SearchBar.js.map +0 -1
  504. package/SegmentedControl.js.map +0 -1
  505. package/Skeleton.d.ts +0 -28
  506. package/Skeleton.js +0 -57
  507. package/Skeleton.js.map +0 -1
  508. package/SliderInput.d.ts +0 -16
  509. package/SliderInput.js +0 -18
  510. package/SliderInput.js.map +0 -1
  511. package/Snackbar.d.ts +0 -16
  512. package/Snackbar.js +0 -18
  513. package/Snackbar.js.map +0 -1
  514. package/StylesProviderAnywhere.js +0 -29
  515. package/StylesProviderAnywhere.js.map +0 -1
  516. package/StylesProviderBetterHomesGardens.js +0 -29
  517. package/StylesProviderBetterHomesGardens.js.map +0 -1
  518. package/StylesProviderCartus.js +0 -29
  519. package/StylesProviderCartus.js.map +0 -1
  520. package/StylesProviderCentury21.js +0 -29
  521. package/StylesProviderCentury21.js.map +0 -1
  522. package/StylesProviderColdwellBanker.js +0 -29
  523. package/StylesProviderColdwellBanker.js.map +0 -1
  524. package/StylesProviderCorcoran.js +0 -29
  525. package/StylesProviderCorcoran.js.map +0 -1
  526. package/StylesProviderDenaliBoss.js +0 -29
  527. package/StylesProviderDenaliBoss.js.map +0 -1
  528. package/StylesProviderEra.js +0 -29
  529. package/StylesProviderEra.js.map +0 -1
  530. package/StylesProviderSothebys.js +0 -29
  531. package/StylesProviderSothebys.js.map +0 -1
  532. package/Switch.js.map +0 -1
  533. package/SwitchGroup.js +0 -18
  534. package/SwitchGroup.js.map +0 -1
  535. package/SwitchOption.js +0 -16
  536. package/SwitchOption.js.map +0 -1
  537. package/TabGroup.js.map +0 -1
  538. package/Table.js.map +0 -1
  539. package/Tag.js.map +0 -1
  540. package/TextField.js +0 -19
  541. package/TextField.js.map +0 -1
  542. package/TextInput.js.map +0 -1
  543. package/Textarea.js.map +0 -1
  544. package/TextareaField.js +0 -26
  545. package/TextareaField.js.map +0 -1
  546. package/TimePicker.d.ts +0 -16
  547. package/TimePicker.js +0 -18
  548. package/TimePicker.js.map +0 -1
  549. package/ToggleOption.js.map +0 -1
  550. package/Tooltip.js +0 -104
  551. package/Tooltip.js.map +0 -1
  552. package/TopNavigation.js +0 -18
  553. package/TopNavigation.js.map +0 -1
  554. package/Txt.js.map +0 -1
  555. package/hooks/useCheckboxGroupState.js.map +0 -1
  556. package/hooks/useCheckboxState.js.map +0 -1
  557. package/hooks/useFloating.js.map +0 -1
  558. package/hooks/useFloatingMenu.js.map +0 -1
  559. package/hooks/useId.js.map +0 -1
  560. package/hooks/useKeyboardNavigation.js.map +0 -1
  561. package/hooks/useLongPress.js.map +0 -1
  562. package/hooks/useModalState.js.map +0 -1
  563. package/hooks/useNavOptions.js.map +0 -1
  564. package/hooks/useOutsideClick.js.map +0 -1
  565. package/hooks/useRadioState.js.map +0 -1
  566. package/hooks/useSwitchGroupState.js.map +0 -1
  567. package/hooks/useTimeout.js.map +0 -1
  568. package/hooks/useValidChildren.js.map +0 -1
  569. package/index.js.map +0 -1
  570. package/meta.d.ts +0 -44
  571. package/meta.js +0 -5789
  572. package/meta.js.map +0 -1
  573. package/src/Accordion.tsx +0 -33
  574. package/src/BottomNavigation.tsx +0 -33
  575. package/src/BottomSheet.tsx +0 -33
  576. package/src/Breadcrumb.tsx +0 -33
  577. package/src/ButtonDock.tsx +0 -33
  578. package/src/Chart.tsx +0 -33
  579. package/src/DatePicker.tsx +0 -33
  580. package/src/Drawer.tsx +0 -33
  581. package/src/FileUpload.tsx +0 -33
  582. package/src/Image.tsx +0 -33
  583. package/src/MultiSelection.tsx +0 -33
  584. package/src/NavigationRail.tsx +0 -33
  585. package/src/OTPInput.tsx +0 -33
  586. package/src/PageControl.tsx +0 -33
  587. package/src/PasswordInput.tsx +0 -33
  588. package/src/PhoneNumberInput.tsx +0 -33
  589. package/src/Rating.tsx +0 -29
  590. package/src/SliderInput.tsx +0 -29
  591. package/src/Snackbar.tsx +0 -29
  592. package/src/TimePicker.tsx +0 -29
  593. package/src/meta.ts +0 -6238
  594. package/src/package.json +0 -3
  595. package/src/styles/anywhere.css +0 -1693
  596. package/src/styles/anywhere.ts +0 -1694
  597. package/src/styles/base.ts +0 -161
  598. package/src/styles/better-homes-gardens.css +0 -1693
  599. package/src/styles/better-homes-gardens.ts +0 -1694
  600. package/src/styles/cartus.css +0 -1691
  601. package/src/styles/cartus.ts +0 -1692
  602. package/src/styles/century-21.css +0 -1689
  603. package/src/styles/century-21.ts +0 -1690
  604. package/src/styles/coldwell-banker.css +0 -1691
  605. package/src/styles/coldwell-banker.ts +0 -1692
  606. package/src/styles/corcoran.css +0 -1685
  607. package/src/styles/corcoran.ts +0 -1686
  608. package/src/styles/denali-boss.css +0 -1681
  609. package/src/styles/denali-boss.ts +0 -1682
  610. package/src/styles/era.css +0 -1685
  611. package/src/styles/era.ts +0 -1686
  612. package/src/styles/sothebys.css +0 -1677
  613. package/src/styles/sothebys.ts +0 -1678
  614. package/styles/anywhere.d.ts +0 -2
  615. package/styles/anywhere.js +0 -1697
  616. package/styles/anywhere.js.map +0 -1
  617. package/styles/base.d.ts +0 -2
  618. package/styles/base.js +0 -164
  619. package/styles/base.js.map +0 -1
  620. package/styles/better-homes-gardens.d.ts +0 -2
  621. package/styles/better-homes-gardens.js +0 -1697
  622. package/styles/better-homes-gardens.js.map +0 -1
  623. package/styles/cartus.d.ts +0 -2
  624. package/styles/cartus.js +0 -1695
  625. package/styles/cartus.js.map +0 -1
  626. package/styles/century-21.d.ts +0 -2
  627. package/styles/century-21.js +0 -1693
  628. package/styles/century-21.js.map +0 -1
  629. package/styles/coldwell-banker.d.ts +0 -2
  630. package/styles/coldwell-banker.js +0 -1695
  631. package/styles/coldwell-banker.js.map +0 -1
  632. package/styles/corcoran.d.ts +0 -2
  633. package/styles/corcoran.js +0 -1689
  634. package/styles/corcoran.js.map +0 -1
  635. package/styles/denali-boss.d.ts +0 -2
  636. package/styles/denali-boss.js +0 -1685
  637. package/styles/denali-boss.js.map +0 -1
  638. package/styles/era.d.ts +0 -2
  639. package/styles/era.js +0 -1689
  640. package/styles/era.js.map +0 -1
  641. package/styles/sothebys.d.ts +0 -2
  642. package/styles/sothebys.js +0 -1681
  643. package/styles/sothebys.js.map +0 -1
  644. package/utils/children.js.map +0 -1
  645. package/utils/colorVariants.d.ts +0 -5
  646. package/utils/colorVariants.js +0 -61
  647. package/utils/colorVariants.js.map +0 -1
  648. package/utils/errors.js.map +0 -1
  649. package/utils/getValidNode.js.map +0 -1
  650. package/utils/keyboard.js.map +0 -1
  651. package/utils/ref.js.map +0 -1
  652. package/utils/scrollElementIntoView.js.map +0 -1
  653. package/utils/srOnly.js.map +0 -1
  654. package/utils/tryIntPsrse.js.map +0 -1
  655. package/utils/txtVariants.d.ts +0 -2
  656. package/utils/txtVariants.js.map +0 -1
  657. /package/{Portal.d.ts → dist/Portal.d.ts} +0 -0
  658. /package/{hooks → dist/hooks}/useCheckboxState.d.ts +0 -0
  659. /package/{hooks → dist/hooks}/useFloating.d.ts +0 -0
  660. /package/{hooks → dist/hooks}/useFloatingMenu.d.ts +0 -0
  661. /package/{hooks → dist/hooks}/useId.d.ts +0 -0
  662. /package/{hooks → dist/hooks}/useKeyboardNavigation.d.ts +0 -0
  663. /package/{hooks → dist/hooks}/useLongPress.d.ts +0 -0
  664. /package/{hooks → dist/hooks}/useModalState.d.ts +0 -0
  665. /package/{hooks → dist/hooks}/useNavOptions.d.ts +0 -0
  666. /package/{hooks → dist/hooks}/useOutsideClick.d.ts +0 -0
  667. /package/{hooks → dist/hooks}/useRadioState.d.ts +0 -0
  668. /package/{hooks → dist/hooks}/useTimeout.d.ts +0 -0
  669. /package/{hooks → dist/hooks}/useValidChildren.d.ts +0 -0
  670. /package/{index.d.ts → dist/index.d.ts} +0 -0
  671. /package/{utils → dist/utils}/children.d.ts +0 -0
  672. /package/{utils → dist/utils}/getValidNode.d.ts +0 -0
  673. /package/{utils → dist/utils}/keyboard.d.ts +0 -0
  674. /package/{utils → dist/utils}/ref.d.ts +0 -0
  675. /package/{utils → dist/utils}/scrollElementIntoView.d.ts +0 -0
  676. /package/{utils → dist/utils}/srOnly.d.ts +0 -0
  677. /package/{utils → dist/utils}/tryIntPsrse.d.ts +0 -0
package/README.md CHANGED
@@ -10,4 +10,9 @@ https://bspk.anywhere.re
10
10
  npm install @bspk/ui
11
11
  ```
12
12
 
13
+ ```bash
14
+ npm install --peer @bspk/icons react react-dom
15
+ ```
16
+
17
+
13
18
  <!--- Copyright 2025 Anywhere Real Estate - CC BY 4.0 -->
@@ -1,3 +1,4 @@
1
+ import './avatar.scss';
1
2
  import { ReactNode } from 'react';
2
3
  import { ColorVariant } from './utils/colorVariants';
3
4
  import { CommonProps } from '.';
@@ -30,10 +31,9 @@ export type AvatarProps = CommonProps<'aria-label'> & {
30
31
  *
31
32
  * @name Avatar
32
33
  */
33
- declare function Avatar({ initials, color, size, icon, image, 'aria-label': ariaLabel, overflowCount, }: AvatarProps): import("@emotion/react/jsx-runtime").JSX.Element;
34
+ declare function Avatar({ initials, color, size, icon, image, 'aria-label': ariaLabel, overflowCount, }: AvatarProps): import("react/jsx-runtime").JSX.Element;
34
35
  declare namespace Avatar {
35
36
  var bspkName: string;
36
37
  }
37
38
  export { Avatar };
38
- export declare const style: import("@emotion/react").SerializedStyles;
39
39
  /** Copyright 2025 Anywhere Real Estate - CC BY 4.0 */
package/dist/Avatar.js ADDED
@@ -0,0 +1,27 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { styleAdd } from './utils/styleAdd';
3
+ styleAdd(`[data-bspk=avatar]{--height: var(--spacing-sizing-10);--font: var(--labels-base);--foreground: var(--foreground-neutral-on-surface);--background: var(--surface-neutral-t3-low);display:flex;flex-direction:column;justify-content:center;align-items:center;padding:0;height:var(--height);width:var(--height);aspect-ratio:1/1;border-radius:999px;background-color:var(--background);color:var(--foreground);font:var(--font)}[data-bspk=avatar]:has(img){overflow:hidden}[data-bspk=avatar] img{max-width:100%}[data-bspk=avatar][data-size=x-small]{--height: var(--spacing-sizing-06);--font: var(--labels-x-small)}[data-bspk=avatar][data-size=small]{--height: var(--spacing-sizing-08);--font: var(--labels-small)}[data-bspk=avatar][data-size=medium]{--height: var(--spacing-sizing-10);--font: var(--labels-base)}[data-bspk=avatar][data-size=large]{--height: var(--spacing-sizing-12);--font: var(--labels-large)}[data-bspk=avatar][data-size=x-large]{--height: var(--spacing-sizing-14);--font: var(--subheader-x-large)}[data-bspk=avatar][data-size=xx-large]{--height: var(--spacing-sizing-17);--font: var(--subheader-xx-large)}[data-bspk=avatar][data-size=xxx-large]{--height: var(--spacing-sizing-19);--font: var(--display-regular-small)}[data-bspk=avatar][data-size=xxxx-large]{--height: var(--spacing-sizing-21);--font: var(--display-regular-medium)}[data-bspk=avatar][data-size=xxxxx-large]{--height: var(--spacing-sizing-23);--font: var(--display-regular-large)}`);;
4
+ import { useMemo } from 'react';
5
+ /**
6
+ * An avatar is a visual representation of a user or entity. It can be used to display an initials, icon, image, or an
7
+ * overflowCount.
8
+ *
9
+ * @name Avatar
10
+ */
11
+ function Avatar({ initials, color = 'grey', size = 'small', icon, image, 'aria-label': ariaLabel, overflowCount, }) {
12
+ const children = useMemo(() => {
13
+ if (initials)
14
+ return _jsx("span", { "data-initials": true, children: initials });
15
+ if (icon)
16
+ return _jsx("span", { "data-icon": true, children: icon });
17
+ if (image)
18
+ return _jsx("img", { alt: ariaLabel, src: image });
19
+ if (overflowCount)
20
+ return _jsxs("span", { "data-overflow-count": true, children: ["+", overflowCount] });
21
+ return null;
22
+ }, [ariaLabel, icon, image, initials, overflowCount]);
23
+ return (_jsx(_Fragment, { children: children && (_jsx("div", { "aria-label": ariaLabel, "data-bspk": "avatar", "data-color": color, "data-size": size, children: children })) }));
24
+ }
25
+ Avatar.bspkName = 'Avatar';
26
+ export { Avatar };
27
+ //# sourceMappingURL=Avatar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Avatar.js","sourceRoot":"","sources":["../src/Avatar.tsx"],"names":[],"mappings":";AAAA,OAAO,eAAe,CAAC;AACvB,OAAO,EAAa,OAAO,EAAE,MAAM,OAAO,CAAC;AAwC3C;;;;;GAKG;AACH,SAAS,MAAM,CAAC,EACZ,QAAQ,EACR,KAAK,GAAG,MAAM,EACd,IAAI,GAAG,OAAO,EACd,IAAI,EACJ,KAAK,EACL,YAAY,EAAE,SAAS,EACvB,aAAa,GACH;IACV,MAAM,QAAQ,GAAG,OAAO,CAAC,GAAG,EAAE;QAC1B,IAAI,QAAQ;YAAE,OAAO,gDAAqB,QAAQ,GAAQ,CAAC;QAC3D,IAAI,IAAI;YAAE,OAAO,4CAAiB,IAAI,GAAQ,CAAC;QAC/C,IAAI,KAAK;YAAE,OAAO,cAAK,GAAG,EAAE,SAAS,EAAE,GAAG,EAAE,KAAK,GAAI,CAAC;QACtD,IAAI,aAAa;YAAE,OAAO,6DAA4B,aAAa,IAAQ,CAAC;QAC5E,OAAO,IAAI,CAAC;IAChB,CAAC,EAAE,CAAC,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,QAAQ,EAAE,aAAa,CAAC,CAAC,CAAC;IAEtD,OAAO,CACH,4BACK,QAAQ,IAAI,CACT,4BAAiB,SAAS,eAAY,QAAQ,gBAAa,KAAK,eAAa,IAAI,YAC5E,QAAQ,GACP,CACT,GACF,CACN,CAAC;AACN,CAAC;AAED,MAAM,CAAC,QAAQ,GAAG,QAAQ,CAAC;AAE3B,OAAO,EAAE,MAAM,EAAE,CAAC"}
@@ -1,3 +1,4 @@
1
+ import './badge.scss';
1
2
  export type BadgeProps = {
2
3
  /**
3
4
  * The content of the badge. If larger than 99, the badge will display '99+'. If null or undefined, the badge will
@@ -24,10 +25,9 @@ export type BadgeProps = {
24
25
  *
25
26
  * @name Badge
26
27
  */
27
- declare function Badge({ count: countProp, size, variant }: BadgeProps): false | import("@emotion/react/jsx-runtime").JSX.Element;
28
+ declare function Badge({ count: countProp, size, variant }: BadgeProps): false | import("react/jsx-runtime").JSX.Element;
28
29
  declare namespace Badge {
29
30
  var bspkName: string;
30
31
  }
31
32
  export { Badge };
32
- export declare const style: import("@emotion/react").SerializedStyles;
33
33
  /** Copyright 2025 Anywhere Real Estate - CC BY 4.0 */
package/dist/Badge.js ADDED
@@ -0,0 +1,16 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { styleAdd } from './utils/styleAdd';
3
+ styleAdd(`[data-bspk=badge]{--size: var(--spacing-sizing-06);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-circular);height:var(--size);min-width:var(--size);padding:0 var(--spacing-sizing-02);font:var(--labels-x-small);color:var(--foreground-brand-on-primary);background:var(--surface-brand-primary)}[data-bspk=badge][data-size=x-small]{--size: var(--spacing-sizing-05);padding:2px var(--spacing-sizing-01)}[data-bspk=badge][data-variant=secondary]{color:var(--foreground-brand-on-secondary);background:var(--surface-brand-secondary)}`);;
4
+ import { tryIntParse } from './utils/tryIntPsrse';
5
+ /**
6
+ * Visual indicator for new items within a parent page represented with a numerical count of new items.
7
+ *
8
+ * @name Badge
9
+ */
10
+ function Badge({ count: countProp, size = 'small', variant = 'primary' }) {
11
+ const count = tryIntParse(countProp);
12
+ return (count !== null && (_jsx("div", { "data-bspk": "badge", "data-size": size, "data-variant": variant, children: count > 99 ? '99+' : count })));
13
+ }
14
+ Badge.bspkName = 'Badge';
15
+ export { Badge };
16
+ //# sourceMappingURL=Badge.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Badge.js","sourceRoot":"","sources":["../src/Badge.tsx"],"names":[],"mappings":";AAAA,OAAO,cAAc,CAAC;AACtB,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAwBlD;;;;GAIG;AACH,SAAS,KAAK,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,IAAI,GAAG,OAAO,EAAE,OAAO,GAAG,SAAS,EAAc;IAChF,MAAM,KAAK,GAAkB,WAAW,CAAC,SAAS,CAAC,CAAC;IAEpD,OAAO,CACH,KAAK,KAAK,IAAI,IAAI,CACd,2BAAe,OAAO,eAAY,IAAI,kBAAgB,OAAO,YACxD,KAAK,GAAG,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,GACzB,CACT,CACJ,CAAC;AACN,CAAC;AAED,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC;AAEzB,OAAO,EAAE,KAAK,EAAE,CAAC"}
@@ -1,3 +1,4 @@
1
+ import './banner-alert.scss';
1
2
  import { ElementProps, AlertVariant, CallToActionButton } from './';
2
3
  export type BannerAlertProps = {
3
4
  /**
@@ -19,12 +20,12 @@ export type BannerAlertProps = {
19
20
  */
20
21
  header: string;
21
22
  /**
22
- * The children of the banner alert.
23
+ * The body of the banner alert.
23
24
  *
24
25
  * @type multiline
25
26
  * @required
26
27
  */
27
- children: string;
28
+ body: string;
28
29
  /**
29
30
  * This property may be undefined or an object containing required CallToActionButton properties.
30
31
  *
@@ -44,10 +45,9 @@ export type BannerAlertProps = {
44
45
  *
45
46
  * @name BannerAlert
46
47
  */
47
- declare function BannerAlert({ variant, onClose, header, callToAction, children, elevated, }: ElementProps<BannerAlertProps, 'div'>): import("@emotion/react/jsx-runtime").JSX.Element;
48
+ declare function BannerAlert({ variant, onClose, header, callToAction, body, elevated, }: ElementProps<BannerAlertProps, 'div'>): import("react/jsx-runtime").JSX.Element;
48
49
  declare namespace BannerAlert {
49
50
  var bspkName: string;
50
51
  }
51
52
  export { BannerAlert };
52
- export declare const style: import("@emotion/react").SerializedStyles;
53
53
  /** Copyright 2025 Anywhere Real Estate - CC BY 4.0 */
@@ -0,0 +1,20 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { SvgCheckCircleFill } from '@bspk/icons/CheckCircleFill';
3
+ import { SvgClose } from '@bspk/icons/Close';
4
+ import { SvgErrorFill } from '@bspk/icons/ErrorFill';
5
+ import { SvgInfoFill } from '@bspk/icons/InfoFill';
6
+ import { SvgWarningFill } from '@bspk/icons/WarningFill';
7
+ import { styleAdd } from './utils/styleAdd';
8
+ styleAdd(`[data-bspk=banner-alert]{--color: var(--status-information);--on-color: var(--status-on-information);display:flex;flex-direction:row;border:2px solid var(--color);border-radius:var(--radius-medium);box-sizing:border-box;background-color:var(--surface-neutral-t1-base);width:100%}[data-bspk=banner-alert][data-variant=error]{--color: var(--status-error);--on-color: var(--status-on-error)}[data-bspk=banner-alert][data-variant=success]{--color: var(--status-success);--on-color: var(--status-on-success)}[data-bspk=banner-alert][data-variant=warning]{--color: var(--status-warning);--on-color: var(--status-on-warning)}[data-bspk=banner-alert][data-elevated]{box-shadow:var(--drop-shadow-raise)}[data-bspk=banner-alert] [data-icon-bar]{flex:1;padding:var(--spacing-sizing-04) var(--spacing-sizing-03);background:var(--color);color:var(--on-color)}[data-bspk=banner-alert] [data-icon-bar] svg{width:var(--spacing-sizing-06);height:var(--spacing-sizing-06)}[data-bspk=banner-alert] [data-content]{flex:100%;display:flex;flex-direction:column;padding:var(--spacing-sizing-02) var(--spacing-sizing-02) var(--spacing-sizing-02) var(--spacing-sizing-04)}[data-bspk=banner-alert] [data-content] header{display:flex;flex-direction:row;gap:var(--spacing-sizing-03);height:var(--spacing-sizing-12);align-items:center}[data-bspk=banner-alert] [data-content] header span{flex:1;display:flex;align-items:center;color:var(--foreground-neutral-on-surface);font:var(--heading-h6)}@media(any-pointer: coarse){[data-bspk=banner-alert] [data-content] header span{font:var(--heading-h6)}}[data-bspk=banner-alert] [data-content] header button{background:none;border:none;cursor:pointer;padding:0;margin:0 0 0 auto;color:var(--foreground-neutral-on-surface-variant-01);height:var(--spacing-sizing-08);width:var(--spacing-sizing-08)}@media(any-pointer: coarse){[data-bspk=banner-alert] [data-content] header button{height:var(--spacing-sizing-12);width:var(--spacing-sizing-12)}}[data-bspk=banner-alert] [data-content] header button svg{width:var(--spacing-sizing-04);height:var(--spacing-sizing-04)}[data-bspk=banner-alert] [data-content] [data-body]{display:flex;flex-direction:column;gap:var(--spacing-sizing-02);padding:0 var(--spacing-sizing-02) var(--spacing-sizing-02) 0}[data-bspk=banner-alert] [data-content] [data-body] span{font:var(--body-base)}[data-bspk=banner-alert] [data-content] [data-body] button{margin-left:auto;background:none;border:none;cursor:pointer;padding:0 var(--spacing-sizing-03);height:var(--spacing-sizing-12);font:var(--labels-small)}`);;
9
+ /**
10
+ * A visual and contextual message used to communicate an important message or notification to users relating to a
11
+ * status or the body content of a page.
12
+ *
13
+ * @name BannerAlert
14
+ */
15
+ function BannerAlert({ variant = 'informational', onClose, header, callToAction, body, elevated = false, }) {
16
+ return (_jsxs("article", { "data-bspk": "banner-alert", "data-elevated": elevated || undefined, "data-variant": variant, children: [_jsxs("div", { "data-icon-bar": true, children: [variant === 'error' && _jsx(SvgErrorFill, {}), variant === 'informational' && _jsx(SvgInfoFill, {}), variant === 'success' && _jsx(SvgCheckCircleFill, {}), variant === 'warning' && _jsx(SvgWarningFill, {})] }), _jsxs("div", { "data-content": true, children: [(header || onClose) && (_jsxs("header", { children: [_jsx("span", { children: header }), typeof onClose === 'function' && (_jsx("button", { "aria-label": "Close", onClick: onClose, type: "button", children: _jsx(SvgClose, {}) }))] })), _jsxs("div", { "data-body": true, children: [_jsx("span", { children: body }), callToAction?.label && callToAction?.onClick && (_jsx("button", { onClick: callToAction.onClick, children: callToAction.label }))] })] })] }));
17
+ }
18
+ BannerAlert.bspkName = 'BannerAlert';
19
+ export { BannerAlert };
20
+ //# sourceMappingURL=BannerAlert.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BannerAlert.js","sourceRoot":"","sources":["../src/BannerAlert.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AACjE,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAEzD,OAAO,qBAAqB,CAAC;AA2C7B;;;;;GAKG;AACH,SAAS,WAAW,CAAC,EACjB,OAAO,GAAG,eAAe,EACzB,OAAO,EACP,MAAM,EACN,YAAY,EACZ,IAAI,EACJ,QAAQ,GAAG,KAAK,GACoB;IACpC,OAAO,CACH,gCAAmB,cAAc,mBAAgB,QAAQ,IAAI,SAAS,kBAAgB,OAAO,aACzF,iDACK,OAAO,KAAK,OAAO,IAAI,KAAC,YAAY,KAAG,EACvC,OAAO,KAAK,eAAe,IAAI,KAAC,WAAW,KAAG,EAC9C,OAAO,KAAK,SAAS,IAAI,KAAC,kBAAkB,KAAG,EAC/C,OAAO,KAAK,SAAS,IAAI,KAAC,cAAc,KAAG,IAC1C,EACN,gDACK,CAAC,MAAM,IAAI,OAAO,CAAC,IAAI,CACpB,6BACI,yBAAO,MAAM,GAAQ,EACpB,OAAO,OAAO,KAAK,UAAU,IAAI,CAC9B,+BAAmB,OAAO,EAAC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAC,QAAQ,YACtD,KAAC,QAAQ,KAAG,GACP,CACZ,IACI,CACZ,EACD,6CACI,yBAAO,IAAI,GAAQ,EAClB,YAAY,EAAE,KAAK,IAAI,YAAY,EAAE,OAAO,IAAI,CAC7C,iBAAQ,OAAO,EAAE,YAAY,CAAC,OAAO,YAAG,YAAY,CAAC,KAAK,GAAU,CACvE,IACC,IACJ,IACA,CACb,CAAC;AACN,CAAC;AAED,WAAW,CAAC,QAAQ,GAAG,aAAa,CAAC;AAErC,OAAO,EAAE,WAAW,EAAE,CAAC"}
@@ -1,3 +1,4 @@
1
+ import './button.scss';
1
2
  import { ElementType, ReactNode } from 'react';
2
3
  import { ButtonSize, CommonProps, ElementProps } from './';
3
4
  export type ButtonVariant = 'primary' | 'secondary' | 'tertiary';
@@ -62,5 +63,4 @@ declare namespace Button {
62
63
  var bspkName: string;
63
64
  }
64
65
  export { Button };
65
- export declare const style: import("@emotion/react").SerializedStyles;
66
66
  /** Copyright 2025 Anywhere Real Estate - CC BY 4.0 */
package/dist/Button.js ADDED
@@ -0,0 +1,30 @@
1
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { styleAdd } from './utils/styleAdd';
3
+ styleAdd(`[data-bspk=button]{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:var(--spacing-sizing-02);border:none;cursor:pointer;box-sizing:border-box;background:rgba(0,0,0,0);text-decoration:none;width:fit-content;position:relative}[data-bspk=button] [data-touch-target]{min-width:var(--spacing-sizing-12);min-height:var(--spacing-sizing-12)}[data-bspk=button][data-width=hug]{width:fit-content}[data-bspk=button][data-width=fill]{width:100%}[data-bspk=button][data-size=x-small]{font-size:var(--typography-size-xs);line-height:var(--typography-line-height-lh-1);height:var(--spacing-sizing-06);min-width:var(--spacing-sizing-06);gap:var(--spacing-sizing-02)}[data-bspk=button][data-size=x-small]:has([data-button-label]),[data-bspk=button][data-size=x-small][data-override]{padding:0 var(--spacing-sizing-02)}[data-bspk=button][data-size=x-small] [data-button-icon]{width:var(--spacing-sizing-04);height:var(--spacing-sizing-04)}[data-bspk=button][data-size=small]{font-size:var(--typography-size-sm);line-height:var(--typography-line-height-lh-2);height:var(--spacing-sizing-08);min-width:var(--spacing-sizing-08)}[data-bspk=button][data-size=small]:has([data-button-label]),[data-bspk=button][data-size=small][data-override]{padding:6px var(--spacing-sizing-04)}[data-bspk=button][data-size=small] [data-button-icon]{width:var(--spacing-sizing-05);height:var(--spacing-sizing-05)}[data-bspk=button][data-size=medium]{font-size:var(--typography-size-base);line-height:var(--typography-line-height-lh-2);height:var(--spacing-sizing-10);min-width:var(--spacing-sizing-10)}[data-bspk=button][data-size=medium]:has([data-button-label]),[data-bspk=button][data-size=medium][data-override]{padding:var(--spacing-sizing-02) var(--spacing-sizing-04)}[data-bspk=button][data-size=medium] [data-button-icon]{width:var(--spacing-sizing-05);height:var(--spacing-sizing-05)}[data-bspk=button][data-size=large]{font-size:var(--typography-size-bp-md);line-height:var(--typography-line-height-lh-4);height:var(--spacing-sizing-12);min-width:var(--spacing-sizing-12)}[data-bspk=button][data-size=large]:has([data-button-label]),[data-bspk=button][data-size=large][data-override]{padding:var(--spacing-sizing-03) var(--spacing-sizing-04)}[data-bspk=button][data-size=large] [data-button-icon]{width:var(--spacing-sizing-06);height:var(--spacing-sizing-06)}[data-bspk=button][disabled]{cursor:not-allowed}[data-bspk=button] [data-button-icon]{display:flex;flex-direction:column;align-items:center}[data-bspk=button] [data-button-label]{display:flex;flex-direction:row;align-items:center}[data-bspk=button][data-variant=primary]{--primary-background: var(--surface-brand-primary);background:linear-gradient(var(--primary-background), var(--primary-background));color:var(--foreground-brand-on-primary);border-radius:var(--radius-small)}[data-bspk=button][data-variant=primary][disabled]{color:var(--foreground-neutral-disabled-on-surface);background:var(--interactions-disabled-opacity)}[data-pseudo=hover]>[data-bspk=button][data-variant=primary]:not([disabled]),[data-bspk=button][data-variant=primary]:not([disabled]):hover{background:linear-gradient(var(--interactions-brand-hover-opacity), var(--interactions-brand-hover-opacity)),linear-gradient(var(--primary-background), var(--primary-background))}[data-pseudo=active]>[data-bspk=button][data-variant=primary]:not([disabled]),[data-bspk=button][data-variant=primary]:not([disabled]):active{background:linear-gradient(var(--interactions-brand-press-opacity), var(--interactions-brand-press-opacity)),linear-gradient(var(--primary-background), var(--primary-background))}[data-pseudo=focus]>[data-bspk=button][data-variant=primary]:not([disabled]),[data-bspk=button][data-variant=primary]:not([disabled]):focus-visible{outline:solid 2px var(--stroke-neutral-focus)}[data-bspk=button][data-variant=primary][data-destructive]{--primary-background: var(--status-error);color:var(--foreground-brand-on-primary)}[data-bspk=button][data-variant=secondary]{border:solid 1px var(--stroke-neutral-base);border-radius:var(--radius-small);color:var(--foreground-neutral-on-surface-variant-01)}[data-bspk=button][data-variant=secondary][disabled]{color:var(--foreground-neutral-disabled-on-surface);border:solid 1px var(--stroke-neutral-disabled-light)}[data-pseudo=hover]>[data-bspk=button][data-variant=secondary]:not([disabled]),[data-bspk=button][data-variant=secondary]:not([disabled]):hover{background-color:var(--interactions-neutral-hover-opacity)}[data-pseudo=active]>[data-bspk=button][data-variant=secondary]:not([disabled]),[data-bspk=button][data-variant=secondary]:not([disabled]):active{background-color:var(--interactions-neutral-press-opacity)}[data-pseudo=focus]>[data-bspk=button][data-variant=secondary]:not([disabled]),[data-bspk=button][data-variant=secondary]:not([disabled]):focus-visible{outline:solid 2px var(--stroke-neutral-focus)}[data-bspk=button][data-variant=secondary][data-destructive]{background:rgba(0,0,0,0);color:var(--status-error);border:solid 1px var(--status-error)}[data-bspk=button][data-variant=tertiary]{background:rgba(0,0,0,0);color:var(--foreground-neutral-on-surface-variant-01)}[data-bspk=button][data-variant=tertiary][disabled]{color:var(--foreground-neutral-disabled-on-surface)}[data-pseudo=hover]>[data-bspk=button][data-variant=tertiary]:not([disabled]),[data-bspk=button][data-variant=tertiary]:not([disabled]):hover{background:var(--interactions-neutral-hover-opacity)}[data-pseudo=active]>[data-bspk=button][data-variant=tertiary]:not([disabled]),[data-bspk=button][data-variant=tertiary]:not([disabled]):active{background:var(--interactions-neutral-press-opacity)}[data-pseudo=focus]>[data-bspk=button][data-variant=tertiary]:not([disabled]),[data-bspk=button][data-variant=tertiary]:not([disabled]):focus-visible{outline:solid 2px var(--stroke-neutral-focus)}[data-bspk=button][data-variant=tertiary][data-destructive]{color:var(--status-error)}`);;
4
+ import { isValidElement } from 'react';
5
+ import { Tooltip } from './Tooltip';
6
+ import { isValidIcon } from './utils/children';
7
+ import { useErrorLogger } from './utils/errors';
8
+ /**
9
+ * A clickable component that allows users to perform an action, make a choice or trigger a change in state.
10
+ *
11
+ * @name Button
12
+ */
13
+ function Button(props) {
14
+ const { size = 'medium', variant = 'primary', destructive = false, width = 'hug', as: As = 'button', disabled = false, label: labelProp, icon, showLabel: showLabelProp = true, toolTip: toolTipProp, children, ...containerProps } = props;
15
+ const label = typeof children === 'string' ? children : labelProp || '';
16
+ // ignore showLabel=false if there is no icon
17
+ const hideLabel = showLabelProp === false && icon;
18
+ const toolTip = toolTipProp || hideLabel ? label : undefined;
19
+ const { logError } = useErrorLogger();
20
+ logError(!!icon && !isValidIcon(icon), 'Button - The icon prop must be a valid icon element.');
21
+ logError(!label, 'Button - The button must have a label.');
22
+ const button = (_jsx(As, { ...containerProps, "aria-label": label, "data-bspk": "button", "data-destructive": destructive || undefined, "data-size": size, "data-variant": variant, "data-width": width, disabled: disabled || undefined, children: children && typeof children !== 'string' ? (children) : (_jsxs(_Fragment, { children: [_jsx("span", { "data-touch-target": true }), !!icon && isValidElement(icon) && _jsx("span", { "data-button-icon": true, children: icon }), !hideLabel && _jsx("span", { "data-button-label": true, children: label })] })) }));
23
+ if (toolTip) {
24
+ return (_jsx(Tooltip, { label: toolTip, placement: "top", children: button }));
25
+ }
26
+ return button;
27
+ }
28
+ Button.bspkName = 'Button';
29
+ export { Button };
30
+ //# sourceMappingURL=Button.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Button.js","sourceRoot":"","sources":["../src/Button.tsx"],"names":[],"mappings":";AAAA,OAAO,eAAe,CAAC;AACvB,OAAO,EAA0B,cAAc,EAAE,MAAM,OAAO,CAAC;AAE/D,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AA0DhD;;;;GAIG;AACH,SAAS,MAAM,CAAoC,KAAwC;IACvF,MAAM,EACF,IAAI,GAAG,QAAQ,EACf,OAAO,GAAG,SAAS,EACnB,WAAW,GAAG,KAAK,EACnB,KAAK,GAAG,KAAK,EACb,EAAE,EAAE,EAAE,GAAG,QAAQ,EACjB,QAAQ,GAAG,KAAK,EAChB,KAAK,EAAE,SAAS,EAChB,IAAI,EACJ,SAAS,EAAE,aAAa,GAAG,IAAI,EAC/B,OAAO,EAAE,WAAW,EACpB,QAAQ,EACR,GAAG,cAAc,EACpB,GAAG,KAAK,CAAC;IACV,MAAM,KAAK,GAAG,OAAO,QAAQ,KAAK,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,IAAI,EAAE,CAAC;IAExE,6CAA6C;IAC7C,MAAM,SAAS,GAAG,aAAa,KAAK,KAAK,IAAI,IAAI,CAAC;IAElD,MAAM,OAAO,GAAG,WAAW,IAAI,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC;IAE7D,MAAM,EAAE,QAAQ,EAAE,GAAG,cAAc,EAAE,CAAC;IACtC,QAAQ,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,sDAAsD,CAAC,CAAC;IAC/F,QAAQ,CAAC,CAAC,KAAK,EAAE,wCAAwC,CAAC,CAAC;IAE3D,MAAM,MAAM,GAAG,CACX,KAAC,EAAE,OACK,cAAc,gBACN,KAAK,eACP,QAAQ,sBACA,WAAW,IAAI,SAAS,eAC/B,IAAI,kBACD,OAAO,gBACT,KAAK,EACjB,QAAQ,EAAE,QAAQ,IAAI,SAAS,YAE9B,QAAQ,IAAI,OAAO,QAAQ,KAAK,QAAQ,CAAC,CAAC,CAAC,CACxC,QAAQ,CACX,CAAC,CAAC,CAAC,CACA,8BACI,2CAA0B,EACzB,CAAC,CAAC,IAAI,IAAI,cAAc,CAAC,IAAI,CAAC,IAAI,mDAAwB,IAAI,GAAQ,EACtE,CAAC,SAAS,IAAI,oDAAyB,KAAK,GAAQ,IACtD,CACN,GACA,CACR,CAAC;IAEF,IAAI,OAAO,EAAE,CAAC;QACV,OAAO,CACH,KAAC,OAAO,IAAC,KAAK,EAAE,OAAO,EAAE,SAAS,EAAC,KAAK,YACnC,MAAM,GACD,CACb,CAAC;IACN,CAAC;IAED,OAAO,MAAM,CAAC;AAClB,CAAC;AAED,MAAM,CAAC,QAAQ,GAAG,QAAQ,CAAC;AAE3B,OAAO,EAAE,MAAM,EAAE,CAAC"}
@@ -1,3 +1,4 @@
1
+ import './card.scss';
1
2
  import { ReactNode } from 'react';
2
3
  export type CardProps = {
3
4
  /**
@@ -28,10 +29,9 @@ export type CardProps = {
28
29
  *
29
30
  * @name Card
30
31
  */
31
- declare function Card({ children, showPadding, variant }: CardProps): import("@emotion/react/jsx-runtime").JSX.Element;
32
+ declare function Card({ children, showPadding, variant }: CardProps): import("react/jsx-runtime").JSX.Element;
32
33
  declare namespace Card {
33
34
  var bspkName: string;
34
35
  }
35
36
  export { Card };
36
- export declare const style: import("@emotion/react").SerializedStyles;
37
37
  /** Copyright 2025 Anywhere Real Estate - CC BY 4.0 */
package/dist/Card.js ADDED
@@ -0,0 +1,18 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { styleAdd } from './utils/styleAdd';
3
+ styleAdd(`[data-bspk=card]{display:block;background:var(--surface-neutral-t1-base);padding:var(--spacing-sizing-03);border-radius:var(--radius-medium);overflow:hidden}[data-bspk=card][data-hide-padding]{padding:0}[data-bspk=card][data-variant=outlined]{border:solid 1px var(--stroke-neutral-low)}[data-bspk=card][data-variant=elevated]{box-shadow:0 1px 2px 0 var(--shadow-32),0 1px 3px 1px var(--shadow-15)}`);;
4
+ /**
5
+ * Cards are often rectangular and contain various content, such as text, images, icons, multimedia, and interactive
6
+ * elements.
7
+ *
8
+ * They are similar in size and shape to playing cards and are intended to encourage users to click or tap to view more
9
+ * details.
10
+ *
11
+ * @name Card
12
+ */
13
+ function Card({ children, showPadding, variant = 'elevated' }) {
14
+ return (_jsx("div", { "data-bspk": "card", "data-hide-padding": showPadding === false || undefined, "data-variant": variant, children: children }));
15
+ }
16
+ Card.bspkName = 'Card';
17
+ export { Card };
18
+ //# sourceMappingURL=Card.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Card.js","sourceRoot":"","sources":["../src/Card.tsx"],"names":[],"mappings":";AAAA,OAAO,aAAa,CAAC;AAwBrB;;;;;;;;GAQG;AACH,SAAS,IAAI,CAAC,EAAE,QAAQ,EAAE,WAAW,EAAE,OAAO,GAAG,UAAU,EAAa;IACpE,OAAO,CACH,2BAAe,MAAM,uBAAoB,WAAW,KAAK,KAAK,IAAI,SAAS,kBAAgB,OAAO,YAC7F,QAAQ,GACP,CACT,CAAC;AACN,CAAC;AAED,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC;AAEvB,OAAO,EAAE,IAAI,EAAE,CAAC"}
@@ -1,3 +1,4 @@
1
+ import './checkbox.scss';
1
2
  import { ToggleControlProps, ElementProps } from './';
2
3
  export type CheckboxProps = ToggleControlProps<HTMLInputElement> & {
3
4
  /**
@@ -17,10 +18,9 @@ export type CheckboxProps = ToggleControlProps<HTMLInputElement> & {
17
18
  *
18
19
  * @name Checkbox
19
20
  */
20
- declare function Checkbox({ checked: checkedProp, indeterminate: indeterminateProp, invalid, disabled, ...props }: ElementProps<CheckboxProps, 'input'>): import("@emotion/react/jsx-runtime").JSX.Element;
21
+ declare function Checkbox({ checked: checkedProp, indeterminate: indeterminateProp, invalid, disabled, ...props }: ElementProps<CheckboxProps, 'input'>): import("react/jsx-runtime").JSX.Element;
21
22
  declare namespace Checkbox {
22
23
  var bspkName: string;
23
24
  }
24
25
  export { Checkbox };
25
- export declare const style: import("@emotion/react").SerializedStyles;
26
26
  /** Copyright 2025 Anywhere Real Estate - CC BY 4.0 */
@@ -0,0 +1,32 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { styleAdd } from './utils/styleAdd';
3
+ styleAdd(`[data-bspk=checkbox]{display:block;position:relative;width:var(--spacing-sizing-06);aspect-ratio:1/1;padding:2px}[data-bspk=checkbox] input[type=checkbox]{position:absolute;opacity:0;z-index:2;width:100%;height:100%;top:0;left:0;cursor:pointer}[data-bspk=checkbox] span{--stroke: var(--stroke-neutral-base);--inner: none;--background: none;--color: var(--foreground-brand-on-primary);box-sizing:border-box;display:flex;width:20px;aspect-ratio:1/1;cursor:pointer;border-radius:2px;border:2px solid var(--stroke);align-items:center;flex-direction:column;justify-content:center;position:relative;background:var(--background);color:var(--color)}[data-bspk=checkbox] span svg[data-checked]{width:14px;display:none}[data-bspk=checkbox] span svg[data-indeterminate]{width:12px;display:none}[data-bspk=checkbox] input[type=checkbox]:not(:checked,:indeterminate,:disabled):hover+span{background-color:var(--interactions-neutral-hover-opacity)}[data-bspk=checkbox] input[type=checkbox]:not(:checked,:indeterminate,:disabled):active+span{background-color:var(--interactions-neutral-press-opacity)}[data-bspk=checkbox] input[type=checkbox]:checked+span svg[data-checked],[data-bspk=checkbox] input[type=checkbox]:indeterminate+span svg[data-indeterminate]{display:block}[data-bspk=checkbox] input[type=checkbox]:checked+span,[data-bspk=checkbox] input[type=checkbox]:indeterminate+span{--stroke: var(--stroke-brand-primary);--background: var(--surface-brand-primary)}[data-bspk=checkbox] input[type=checkbox]:disabled{pointer-events:none}[data-bspk=checkbox] input[type=checkbox]:disabled+span{--stroke: var(--stroke-neutral-interactions-disabled-light)}[data-bspk=checkbox] input[type=checkbox]:disabled:is(:checked,:indeterminate)+span{--stroke: transparent;--background: var(--interactions-disabled-opacity);--color: var(--foreground-neutral-disabled-on-surface)}[data-bspk=checkbox] input[type=checkbox][aria-invalid]:not(:disabled):checked+span,[data-bspk=checkbox] input[type=checkbox][aria-invalid]:not(:disabled):indeterminate+span{--background: var(--status-error)}[data-bspk=checkbox] input[type=checkbox][aria-invalid]:not(:disabled)+span{--stroke: var(--status-error)}`);;
4
+ import { useEffect, useRef } from 'react';
5
+ /**
6
+ * A control that allows users to choose one or more items from a list or turn an feature on or off. This is the base
7
+ * element and if used directly you must wrap it with a label. This will more often be used in the CheckboxOption or
8
+ * CheckboxGroup component.
9
+ *
10
+ * @element
11
+ *
12
+ * @name Checkbox
13
+ */
14
+ function Checkbox({ checked: checkedProp = false, indeterminate: indeterminateProp, invalid, disabled, ...props }) {
15
+ const indeterminate = !!indeterminateProp;
16
+ const checked = !!checkedProp && !indeterminate;
17
+ const inputRef = useRef();
18
+ useEffect(() => {
19
+ if (!inputRef.current)
20
+ return;
21
+ inputRef.current.indeterminate = indeterminate;
22
+ }, [indeterminate]);
23
+ return (_jsxs("span", { "data-bspk": "checkbox", children: [_jsx("input", { ...props, "aria-invalid": invalid || undefined, checked: checked, disabled: disabled || undefined, onChange: (event) => props.onChange(!!event.target.checked, event), ref: (node) => {
24
+ if (!node)
25
+ return;
26
+ inputRef.current = node;
27
+ node.indeterminate = indeterminate;
28
+ }, type: "checkbox" }), _jsxs("span", { "aria-hidden": true, children: [_jsx("svg", { "data-checked": true, fill: "none", viewBox: "0 0 14 11", xmlns: "http://www.w3.org/2000/svg", children: _jsx("path", { d: "M5.485 10.182a1 1 0 0 1-1.414 0l-3.03-3.03a1 1 0 0 1 0-1.415l.14-.141a1 1 0 0 1 1.415 0l2.182 2.182 6.626-6.627a1 1 0 0 1 1.414 0l.142.142a1 1 0 0 1 0 1.414l-7.475 7.475Z", fill: "currentColor" }) }), _jsx("svg", { "data-indeterminate": true, fill: "none", viewBox: "0 0 12 4", xmlns: "http://www.w3.org/2000/svg", children: _jsx("path", { d: "M1.44444 3.11089C0.892158 3.11089 0.444443 2.66318 0.444443 2.11089V1.88867C0.444443 1.33639 0.892158 0.888672 1.44444 0.888672H10.5556C11.1078 0.888672 11.5556 1.33639 11.5556 1.88867V2.11089C11.5556 2.66318 11.1078 3.11089 10.5556 3.11089H1.44444Z", fill: "currentColor" }) })] })] }));
29
+ }
30
+ Checkbox.bspkName = 'Checkbox';
31
+ export { Checkbox };
32
+ //# sourceMappingURL=Checkbox.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Checkbox.js","sourceRoot":"","sources":["../src/Checkbox.tsx"],"names":[],"mappings":";AAAA,OAAO,iBAAiB,CAAC;AACzB,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AAc1C;;;;;;;;GAQG;AACH,SAAS,QAAQ,CAAC,EACd,OAAO,EAAE,WAAW,GAAG,KAAK,EAC5B,aAAa,EAAE,iBAAiB,EAChC,OAAO,EACP,QAAQ,EACR,GAAG,KAAK,EAC2B;IACnC,MAAM,aAAa,GAAG,CAAC,CAAC,iBAAiB,CAAC;IAC1C,MAAM,OAAO,GAAG,CAAC,CAAC,WAAW,IAAI,CAAC,aAAa,CAAC;IAEhD,MAAM,QAAQ,GAAG,MAAM,EAAoB,CAAC;IAE5C,SAAS,CAAC,GAAG,EAAE;QACX,IAAI,CAAC,QAAQ,CAAC,OAAO;YAAE,OAAO;QAC9B,QAAQ,CAAC,OAAO,CAAC,aAAa,GAAG,aAAa,CAAC;IACnD,CAAC,EAAE,CAAC,aAAa,CAAC,CAAC,CAAC;IAEpB,OAAO,CACH,6BAEc,UAAU,aAEpB,mBACQ,KAAK,kBACK,OAAO,IAAI,SAAS,EAClC,OAAO,EAAE,OAAO,EAChB,QAAQ,EAAE,QAAQ,IAAI,SAAS,EAC/B,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,EAAE,KAAK,CAAC,EAClE,GAAG,EAAE,CAAC,IAAI,EAAE,EAAE;oBACV,IAAI,CAAC,IAAI;wBAAE,OAAO;oBAClB,QAAQ,CAAC,OAAO,GAAG,IAAI,CAAC;oBACxB,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC;gBACvC,CAAC,EACD,IAAI,EAAC,UAAU,GACjB,EACF,gDACI,oCAAkB,IAAI,EAAC,MAAM,EAAC,OAAO,EAAC,WAAW,EAAC,KAAK,EAAC,4BAA4B,YAChF,eACI,CAAC,EAAC,4KAA4K,EAC9K,IAAI,EAAC,cAAc,GACrB,GACA,EACN,0CAAwB,IAAI,EAAC,MAAM,EAAC,OAAO,EAAC,UAAU,EAAC,KAAK,EAAC,4BAA4B,YACrF,eACI,CAAC,EAAC,2PAA2P,EAC7P,IAAI,EAAC,cAAc,GACrB,GACA,IACH,IACJ,CACV,CAAC;AACN,CAAC;AAED,QAAQ,CAAC,QAAQ,GAAG,UAAU,CAAC;AAE/B,OAAO,EAAE,QAAQ,EAAE,CAAC"}
@@ -41,7 +41,7 @@ export type CheckboxGroupProps = CommonProps<'aria-label'> & {
41
41
  *
42
42
  * @name CheckboxGroup
43
43
  */
44
- declare function CheckboxGroup({ onChange, options, name, values, selectAll, selectAllProps, ...props }: ElementProps<CheckboxGroupProps, 'div'>): import("@emotion/react/jsx-runtime").JSX.Element;
44
+ declare function CheckboxGroup({ onChange, options, name, values, selectAll, selectAllProps, ...props }: ElementProps<CheckboxGroupProps, 'div'>): import("react/jsx-runtime").JSX.Element;
45
45
  declare namespace CheckboxGroup {
46
46
  var bspkName: string;
47
47
  }
@@ -0,0 +1,16 @@
1
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Checkbox } from './Checkbox';
3
+ import { ToggleOption } from './ToggleOption';
4
+ /**
5
+ * A group of checkboxes that allows users to choose one or more items from a list or turn an feature on or off.
6
+ *
7
+ * @name CheckboxGroup
8
+ */
9
+ function CheckboxGroup({ onChange, options = [], name, values = [], selectAll, selectAllProps, ...props }) {
10
+ return (_jsxs("div", { ...props, "data-bspk": "checkbox-group", role: "group", children: [selectAll && (_jsx(_Fragment, { children: _jsx(ToggleOption, { label: selectAllProps?.label || 'All', children: _jsx(Checkbox, { "aria-label": selectAllProps?.label || 'All', checked: !!values.length && values.length === options.length, indeterminate: !!values.length && values.length < options.length, name: name, onChange: (checked) => onChange(checked ? options.map((o) => o.value) : []), value: "all" }) }) })), options.map(({ label, description, value }) => (_jsx(ToggleOption, { description: description, label: label, children: _jsx(Checkbox, { "aria-label": label, checked: values.includes(value), name: name, onChange: (checked) => {
11
+ onChange(checked ? [...values, value] : values.filter((v) => v !== value));
12
+ }, value: value }) }, value)))] }));
13
+ }
14
+ CheckboxGroup.bspkName = 'CheckboxGroup';
15
+ export { CheckboxGroup };
16
+ //# sourceMappingURL=CheckboxGroup.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CheckboxGroup.js","sourceRoot":"","sources":["../src/CheckboxGroup.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAqB,YAAY,EAAE,MAAM,gBAAgB,CAAC;AA0CjE;;;;GAIG;AACH,SAAS,aAAa,CAAC,EACnB,QAAQ,EACR,OAAO,GAAG,EAAE,EACZ,IAAI,EACJ,MAAM,GAAG,EAAE,EACX,SAAS,EACT,cAAc,EACd,GAAG,KAAK,EAC8B;IACtC,OAAO,CACH,kBAAS,KAAK,eAAY,gBAAgB,EAAC,IAAI,EAAC,OAAO,aAClD,SAAS,IAAI,CACV,4BACI,KAAC,YAAY,IAAC,KAAK,EAAE,cAAc,EAAE,KAAK,IAAI,KAAK,YAC/C,KAAC,QAAQ,kBACO,cAAc,EAAE,KAAK,IAAI,KAAK,EAC1C,OAAO,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,IAAI,MAAM,CAAC,MAAM,KAAK,OAAO,CAAC,MAAM,EAC5D,aAAa,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,IAAI,MAAM,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,EAChE,IAAI,EAAE,IAAI,EACV,QAAQ,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAC3E,KAAK,EAAC,KAAK,GACb,GACS,GAChB,CACN,EACA,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,WAAW,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAC5C,KAAC,YAAY,IAAC,WAAW,EAAE,WAAW,EAAc,KAAK,EAAE,KAAK,YAC5D,KAAC,QAAQ,kBACO,KAAK,EACjB,OAAO,EAAE,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,EAC/B,IAAI,EAAE,IAAI,EACV,QAAQ,EAAE,CAAC,OAAO,EAAE,EAAE;wBAClB,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC;oBAC/E,CAAC,EACD,KAAK,EAAE,KAAK,GACd,IATuC,KAAK,CAUnC,CAClB,CAAC,IACA,CACT,CAAC;AACN,CAAC;AAED,aAAa,CAAC,QAAQ,GAAG,eAAe,CAAC;AAEzC,OAAO,EAAE,aAAa,EAAE,CAAC"}
@@ -6,7 +6,7 @@ export type CheckboxOptionProps = Pick<CheckboxProps, 'checked' | 'disabled' | '
6
6
  *
7
7
  * @name CheckboxOption
8
8
  */
9
- declare function CheckboxOption({ label, description, ...checkboxProps }: CheckboxOptionProps): import("@emotion/react/jsx-runtime").JSX.Element;
9
+ declare function CheckboxOption({ label, description, ...checkboxProps }: CheckboxOptionProps): import("react/jsx-runtime").JSX.Element;
10
10
  declare namespace CheckboxOption {
11
11
  var bspkName: string;
12
12
  }
@@ -0,0 +1,14 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { Checkbox } from './Checkbox';
3
+ import { ToggleOption } from './ToggleOption';
4
+ /**
5
+ * A control that allows users to choose one or more items from a list or turn an feature on or off.
6
+ *
7
+ * @name CheckboxOption
8
+ */
9
+ function CheckboxOption({ label, description, ...checkboxProps }) {
10
+ return (_jsx(ToggleOption, { "data-bspk": "checkbox-option", description: description, label: label, children: _jsx(Checkbox, { ...checkboxProps, "aria-label": label }) }));
11
+ }
12
+ CheckboxOption.bspkName = 'CheckboxOption';
13
+ export { CheckboxOption };
14
+ //# sourceMappingURL=CheckboxOption.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CheckboxOption.js","sourceRoot":"","sources":["../src/CheckboxOption.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAiB,QAAQ,EAAE,MAAM,YAAY,CAAC;AACrD,OAAO,EAAqB,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAQjE;;;;GAIG;AACH,SAAS,cAAc,CAAC,EAAE,KAAK,EAAE,WAAW,EAAE,GAAG,aAAa,EAAuB;IACjF,OAAO,CACH,KAAC,YAAY,iBAAW,iBAAiB,EAAC,WAAW,EAAE,WAAW,EAAE,KAAK,EAAE,KAAK,YAC5E,KAAC,QAAQ,OAAK,aAAa,gBAAc,KAAK,GAAI,GACvC,CAClB,CAAC;AACN,CAAC;AAED,cAAc,CAAC,QAAQ,GAAG,gBAAgB,CAAC;AAE3C,OAAO,EAAE,cAAc,EAAE,CAAC"}
@@ -1,3 +1,4 @@
1
+ import './chip.scss';
1
2
  import { CSSProperties, ReactNode } from 'react';
2
3
  import { CommonProps } from '.';
3
4
  export type ChipProps = CommonProps<'disabled' | 'onClick'> & {
@@ -41,10 +42,9 @@ export type ChipProps = CommonProps<'disabled' | 'onClick'> & {
41
42
  *
42
43
  * @name Chip
43
44
  */
44
- declare function Chip({ children, wrap, variant, flat, disabled, selected, onClick, style: styleProp, }: ChipProps): import("@emotion/react/jsx-runtime").JSX.Element;
45
+ declare function Chip({ children, wrap, variant, flat, disabled, selected, onClick, style: styleProp, }: ChipProps): import("react/jsx-runtime").JSX.Element;
45
46
  declare namespace Chip {
46
47
  var bspkName: string;
47
48
  }
48
49
  export { Chip };
49
- export declare const style: import("@emotion/react").SerializedStyles;
50
50
  /** Copyright 2025 Anywhere Real Estate - CC BY 4.0 */
package/dist/Chip.js ADDED
@@ -0,0 +1,22 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { styleAdd } from './utils/styleAdd';
3
+ styleAdd(`[data-bspk=chip]{display:flex;flex-direction:column;justify-content:center;width:fit-content;height:var(--spacing-sizing-06);padding:0 var(--spacing-sizing-02);font:var(--labels-small);color:var(--foreground-neutral-on-surface-variant-01);background-color:var(--surface-neutral-t1-base);border:1px solid var(--stroke-neutral-low);border-radius:var(--radius-small)}[data-bspk=chip]:not([data-flat]){box-shadow:var(--drop-shadow-raise)}[data-bspk=chip][data-variant=filter]{cursor:pointer}[data-bspk=chip][data-wrap]{height:auto}[data-bspk=chip][data-disabled]{color:var(--foreground-neutral-disabled-on-surface);cursor:not-allowed;border-color:var(--stroke-neutral-disabled-light);background-image:linear-gradient(var(--interactions-disabled-opacity), var(--interactions-disabled-opacity)),linear-gradient(var(--surface-neutral-t1-base), var(--surface-neutral-t1-base))}[data-bspk=chip]:not([data-disabled]):hover{background-image:linear-gradient(var(--interactions-neutral-hover-opacity), var(--interactions-neutral-hover-opacity)),linear-gradient(var(--surface-neutral-t1-base), var(--surface-neutral-t1-base))}[data-bspk=chip]:not([data-disabled]):active{background-image:linear-gradient(var(--interactions-neutral-press-opacity), var(--interactions-neutral-press-opacity)),linear-gradient(var(--surface-neutral-t1-base), var(--surface-neutral-t1-base))}[data-bspk=chip]:not([data-disabled]):focus{outline:1px solid var(--stroke-neutral-focus);border-color:var(--stroke-neutral-focus)}[data-bspk=chip][data-selected]{background-color:var(--surface-brand-primary-highlight);border-color:var(--stroke-brand-primary)}`);;
4
+ /**
5
+ * Dynamically generated options that are suggested to the user as responses or prompts.
6
+ *
7
+ * @name Chip
8
+ */
9
+ function Chip({ children = '', wrap = false, variant = 'filter', flat = false, disabled = false, selected = false, onClick, style: styleProp, }) {
10
+ let additionalProps = {};
11
+ if (variant === 'filter') {
12
+ additionalProps = {
13
+ onClick,
14
+ role: 'button',
15
+ tabIndex: 0,
16
+ };
17
+ }
18
+ return (_jsx("span", { "data-bspk": "chip", "data-disabled": disabled || undefined, "data-flat": flat || undefined, "data-selected": selected || undefined, "data-variant": variant, "data-wrap": wrap || undefined, style: styleProp, ...additionalProps, children: children }));
19
+ }
20
+ Chip.bspkName = 'Chip';
21
+ export { Chip };
22
+ //# sourceMappingURL=Chip.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Chip.js","sourceRoot":"","sources":["../src/Chip.tsx"],"names":[],"mappings":";AAAA,OAAO,aAAa,CAAC;AA2CrB;;;;GAIG;AACH,SAAS,IAAI,CAAC,EACV,QAAQ,GAAG,EAAE,EACb,IAAI,GAAG,KAAK,EACZ,OAAO,GAAG,QAAQ,EAClB,IAAI,GAAG,KAAK,EACZ,QAAQ,GAAG,KAAK,EAChB,QAAQ,GAAG,KAAK,EAChB,OAAO,EACP,KAAK,EAAE,SAAS,GACR;IACR,IAAI,eAAe,GAAG,EAAE,CAAC;IAEzB,IAAI,OAAO,KAAK,QAAQ,EAAE,CAAC;QACvB,eAAe,GAAG;YACd,OAAO;YACP,IAAI,EAAE,QAAQ;YACd,QAAQ,EAAE,CAAC;SACd,CAAC;IACN,CAAC;IAED,OAAO,CACH,4BACc,MAAM,mBACD,QAAQ,IAAI,SAAS,eACzB,IAAI,IAAI,SAAS,mBACb,QAAQ,IAAI,SAAS,kBACtB,OAAO,eACV,IAAI,IAAI,SAAS,EAC5B,KAAK,EAAE,SAAS,KACZ,eAAe,YAElB,QAAQ,GACN,CACV,CAAC;AACN,CAAC;AAED,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC;AAEvB,OAAO,EAAE,IAAI,EAAE,CAAC"}
@@ -1,3 +1,4 @@
1
+ import './dialog.scss';
1
2
  import { ReactNode, Ref } from 'react';
2
3
  import { CommonProps, ElementProps } from './';
3
4
  export type DialogProps = CommonProps<'id'> & {
@@ -37,10 +38,9 @@ export type DialogProps = CommonProps<'id'> & {
37
38
  *
38
39
  * @name Dialog
39
40
  */
40
- declare function Dialog({ children, innerRef, onClose, open, placement, hideScrim, id: idProp, ...containerProps }: ElementProps<DialogProps, 'div'>): false | import("@emotion/react/jsx-runtime").JSX.Element;
41
+ declare function Dialog({ children, innerRef, onClose, open, placement, hideScrim, id: idProp, ...containerProps }: ElementProps<DialogProps, 'div'>): false | import("react/jsx-runtime").JSX.Element;
41
42
  declare namespace Dialog {
42
43
  var bspkName: string;
43
44
  }
44
45
  export { Dialog };
45
- export declare const style: import("@emotion/react").SerializedStyles;
46
46
  /** Copyright 2025 Anywhere Real Estate - CC BY 4.0 */
package/dist/Dialog.js ADDED
@@ -0,0 +1,70 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { styleAdd } from './utils/styleAdd';
3
+ styleAdd(`[data-bspk=dialog]{position:fixed;inset:0;z-index:var(--z-index-dialog)}[data-bspk=dialog] [data-dialog-box]{text-align:start;position:relative;border-radius:var(--radius-large);box-shadow:var(--drop-shadow-float);background:var(--surface-neutral-t1-base);color:var(--foreground-neutral-on-surface);max-height:calc(100vh - var(--spacing-sizing-24));overflow:scroll;z-index:2}[data-bspk=dialog] [data-dialog-box]>:first-of-type{margin-top:0}[data-bspk=dialog] [data-dialog-box]>:last-child{margin-bottom:0}@media(width >= 640px){[data-bspk=dialog] [data-dialog-box]{width:90%}}@media(width >= 768px){[data-bspk=dialog] [data-dialog-box]{width:80%}}@media(width >= 1024px){[data-bspk=dialog] [data-dialog-box]{width:60%}}@media(width >= 1280px){[data-bspk=dialog] [data-dialog-box]{width:50%}}[data-bspk=dialog] [data-dialog-backdrop]{z-index:1;position:fixed;inset:0;background-color:var(--background-scrim);opacity:0;transition:opacity .3s}[data-bspk=dialog][data-visibility=show] [data-dialog-backdrop]{opacity:1}[data-bspk=dialog][data-placement=center]{display:flex;justify-content:center;align-items:center}[data-bspk=dialog][data-placement=center] [data-dialog-box]{transition:opacity 1s;opacity:0}[data-bspk=dialog][data-placement=center][data-visibility=show] [data-dialog-box]{opacity:1}[data-bspk=dialog][data-placement=bottom] [data-dialog-box]{position:absolute;border-bottom-left-radius:0;border-bottom-right-radius:0;width:600px;left:50%;transform:translateX(-50%);bottom:-100vh;transition:bottom .3s}[data-bspk=dialog][data-placement=bottom][data-visibility=show] [data-dialog-box]{bottom:0}[data-bspk=dialog][data-placement=top] [data-dialog-box]{position:absolute;border-top-left-radius:0;border-top-right-radius:0;width:600px;left:50%;transform:translateX(-50%);top:-100vh;transition:top .3s}[data-bspk=dialog][data-placement=top][data-visibility=show] [data-dialog-box]{top:0}[data-bspk=dialog][data-placement=left] [data-dialog-box]{position:absolute;max-height:unset;width:280px;height:100vh;border-bottom-left-radius:0;border-top-left-radius:0;left:-100vw;transition:left .3s}[data-bspk=dialog][data-placement=left][data-visibility=show] [data-dialog-box]{left:0}[data-bspk=dialog][data-placement=right] [data-dialog-box]{position:absolute;max-height:unset;width:280px;height:100vh;border-bottom-right-radius:0;border-top-right-radius:0;right:-100vw;transition:right .3s}[data-bspk=dialog][data-placement=right][data-visibility=show] [data-dialog-box]{right:0}`);;
4
+ import { FocusTrap } from 'focus-trap-react';
5
+ import { useCallback, useEffect, useRef, useState } from 'react';
6
+ import { Portal } from './Portal';
7
+ import { useId } from './hooks/useId';
8
+ import { useOutsideClick } from './hooks/useOutsideClick';
9
+ /**
10
+ * Dialogs display important information that users need to acknowledge. They appear over the interface and block
11
+ * further interactions until an action is selected.
12
+ *
13
+ * @name Dialog
14
+ */
15
+ function Dialog({
16
+ //
17
+ children, innerRef, onClose, open, placement = 'center', hideScrim, id: idProp, ...containerProps }) {
18
+ const id = useId(idProp);
19
+ const boxRef = useRef(null);
20
+ const [visibility, setVisibilityState] = useState(open ? 'show' : 'hidden');
21
+ const prevVisibility = useRef(visibility);
22
+ const setVisibility = useCallback((next) => {
23
+ setVisibilityState((prev) => {
24
+ prevVisibility.current = prev;
25
+ return next;
26
+ });
27
+ }, []);
28
+ const handleKeyDown = useCallback((e) => e.key === 'Escape' && onClose(), [onClose]);
29
+ useEffect(() => {
30
+ if (open) {
31
+ if (prevVisibility.current.startsWith('show'))
32
+ return;
33
+ setVisibility('showing');
34
+ return;
35
+ }
36
+ if (prevVisibility.current.startsWith('hid'))
37
+ return;
38
+ setVisibility('hiding');
39
+ }, [open, setVisibility]);
40
+ useEffect(() => {
41
+ if (prevVisibility.current === visibility)
42
+ return;
43
+ if (visibility === 'showing') {
44
+ document.body.style.overflow = 'hidden';
45
+ setTimeout(() => setVisibility('show'), 10);
46
+ }
47
+ if (visibility === 'hiding') {
48
+ document.body.style.overflow = '';
49
+ setTimeout(() => setVisibility('hidden'), 10);
50
+ }
51
+ }, [setVisibility, visibility]);
52
+ useEffect(() => {
53
+ if (visibility.startsWith('hid'))
54
+ return;
55
+ document.addEventListener('keydown', handleKeyDown);
56
+ return () => {
57
+ document.removeEventListener('keydown', handleKeyDown);
58
+ };
59
+ }, [handleKeyDown, visibility]);
60
+ useOutsideClick([boxRef.current], onClose, !open);
61
+ return (visibility !== 'hidden' && (_jsx(Portal, { children: _jsxs("div", { ...containerProps, "data-bspk": "dialog", "data-placement": placement, "data-visibility": visibility, id: id, ref: innerRef, role: "presentation", children: [!hideScrim && _jsx("div", { "aria-hidden": "true", "data-dialog-backdrop": true }), _jsx(FocusTrap, { focusTrapOptions: {
62
+ fallbackFocus: () => boxRef.current,
63
+ clickOutsideDeactivates: true,
64
+ }, children: _jsx("div", { "data-dialog-box": true, ref: (node) => {
65
+ boxRef.current = node;
66
+ }, tabIndex: -1, children: children }) })] }) })));
67
+ }
68
+ Dialog.bspkName = 'Dialog';
69
+ export { Dialog };
70
+ //# sourceMappingURL=Dialog.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Dialog.js","sourceRoot":"","sources":["../src/Dialog.tsx"],"names":[],"mappings":";AAAA,OAAO,eAAe,CAAC;AACvB,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC7C,OAAO,EAAkB,WAAW,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAEjF,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAoC1D;;;;;GAKG;AACH,SAAS,MAAM,CAAC;AACZ,EAAE;AACF,QAAQ,EACR,QAAQ,EACR,OAAO,EACP,IAAI,EACJ,SAAS,GAAG,QAAQ,EACpB,SAAS,EACT,EAAE,EAAE,MAAM,EACV,GAAG,cAAc,EACc;IAC/B,MAAM,EAAE,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC;IACzB,MAAM,MAAM,GAAG,MAAM,CAAwB,IAAI,CAAC,CAAC;IACnD,MAAM,CAAC,UAAU,EAAE,kBAAkB,CAAC,GAAG,QAAQ,CAC7C,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,CAC3B,CAAC;IAEF,MAAM,cAAc,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;IAE1C,MAAM,aAAa,GAAG,WAAW,CAAC,CAAC,IAAuB,EAAE,EAAE;QAC1D,kBAAkB,CAAC,CAAC,IAAI,EAAE,EAAE;YACxB,cAAc,CAAC,OAAO,GAAG,IAAI,CAAC;YAC9B,OAAO,IAAI,CAAC;QAChB,CAAC,CAAC,CAAC;IACP,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,MAAM,aAAa,GAAG,WAAW,CAAC,CAAC,CAAgB,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,QAAQ,IAAI,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC;IAEpG,SAAS,CAAC,GAAG,EAAE;QACX,IAAI,IAAI,EAAE,CAAC;YACP,IAAI,cAAc,CAAC,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC;gBAAE,OAAO;YACtD,aAAa,CAAC,SAAS,CAAC,CAAC;YACzB,OAAO;QACX,CAAC;QAED,IAAI,cAAc,CAAC,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC;YAAE,OAAO;QACrD,aAAa,CAAC,QAAQ,CAAC,CAAC;IAC5B,CAAC,EAAE,CAAC,IAAI,EAAE,aAAa,CAAC,CAAC,CAAC;IAE1B,SAAS,CAAC,GAAG,EAAE;QACX,IAAI,cAAc,CAAC,OAAO,KAAK,UAAU;YAAE,OAAO;QAElD,IAAI,UAAU,KAAK,SAAS,EAAE,CAAC;YAC3B,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,QAAQ,CAAC;YACxC,UAAU,CAAC,GAAG,EAAE,CAAC,aAAa,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC;QAChD,CAAC;QAED,IAAI,UAAU,KAAK,QAAQ,EAAE,CAAC;YAC1B,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,EAAE,CAAC;YAClC,UAAU,CAAC,GAAG,EAAE,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC,CAAC;QAClD,CAAC;IACL,CAAC,EAAE,CAAC,aAAa,EAAE,UAAU,CAAC,CAAC,CAAC;IAEhC,SAAS,CAAC,GAAG,EAAE;QACX,IAAI,UAAU,CAAC,UAAU,CAAC,KAAK,CAAC;YAAE,OAAO;QAEzC,QAAQ,CAAC,gBAAgB,CAAC,SAAS,EAAE,aAAa,CAAC,CAAC;QACpD,OAAO,GAAG,EAAE;YACR,QAAQ,CAAC,mBAAmB,CAAC,SAAS,EAAE,aAAa,CAAC,CAAC;QAC3D,CAAC,CAAC;IACN,CAAC,EAAE,CAAC,aAAa,EAAE,UAAU,CAAC,CAAC,CAAC;IAEhC,eAAe,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,CAAC,IAAI,CAAC,CAAC;IAElD,OAAO,CACH,UAAU,KAAK,QAAQ,IAAI,CACvB,KAAC,MAAM,cACH,kBACQ,cAAc,eACR,QAAQ,oBACF,SAAS,qBACR,UAAU,EAC3B,EAAE,EAAE,EAAE,EACN,GAAG,EAAE,QAAQ,EACb,IAAI,EAAC,cAAc,aAElB,CAAC,SAAS,IAAI,6BAAiB,MAAM,iCAAwB,EAC9D,KAAC,SAAS,IACN,gBAAgB,EAAE;wBACd,aAAa,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,OAAQ;wBACpC,uBAAuB,EAAE,IAAI;qBAChC,YAED,uCAEI,GAAG,EAAE,CAAC,IAAI,EAAE,EAAE;4BACV,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC;wBAC1B,CAAC,EACD,QAAQ,EAAE,CAAC,CAAC,YAEX,QAAQ,GACP,GACE,IACV,GACD,CACZ,CACJ,CAAC;AACN,CAAC;AAED,MAAM,CAAC,QAAQ,GAAG,QAAQ,CAAC;AAE3B,OAAO,EAAE,MAAM,EAAE,CAAC"}
@@ -1,3 +1,4 @@
1
+ import './divider.scss';
1
2
  import { ElementProps } from './';
2
3
  export type DividerProps = {
3
4
  /**
@@ -35,10 +36,9 @@ export type DividerProps = {
35
36
  *
36
37
  * @name Divider
37
38
  */
38
- declare function Divider({ padding, orientation, thickness, inset, ...props }: ElementProps<DividerProps, 'div'>): import("@emotion/react/jsx-runtime").JSX.Element;
39
+ declare function Divider({ padding, orientation, thickness, inset, ...props }: ElementProps<DividerProps, 'div'>): import("react/jsx-runtime").JSX.Element;
39
40
  declare namespace Divider {
40
41
  var bspkName: string;
41
42
  }
42
43
  export { Divider };
43
- export declare const style: import("@emotion/react").SerializedStyles;
44
44
  /** Copyright 2025 Anywhere Real Estate - CC BY 4.0 */
@@ -0,0 +1,26 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { styleAdd } from './utils/styleAdd';
3
+ styleAdd(`[data-bspk=divider]{/*! --inset: is set via inline style */display:flex;background-color:var(--stroke-neutral-low);align-self:stretch;place-content:stretch stretch;margin:0;padding:0;content:"hello";--length: calc(100% - var(--inset) * 2)}[data-bspk=divider],[data-bspk=divider][data-thickness=light]{--line-thickness: 1px;--padding: var(--spacing-sizing-02)}[data-bspk=divider][data-thickness=heavy]{--line-thickness: 2px;--padding: var(--spacing-sizing-04)}[data-bspk=divider],[data-bspk=divider][data-orientation=horizontal]{width:unset;min-height:unset;height:var(--line-thickness);min-width:var(--length);margin:var(--padding) var(--inset)}[data-bspk=divider][data-orientation=vertical]{height:unset;min-width:unset;width:var(--line-thickness);min-height:var(--length);margin:var(--inset) var(--padding)}[data-bspk=divider][data-hide-padding]{--padding: 0}`);;
4
+ const insetToVariable = (insetProp) => {
5
+ const inset = Number(insetProp);
6
+ if (inset === undefined || inset === null || inset < 1 || inset > 12)
7
+ return '0px';
8
+ return `var(--spacing-sizing-${inset.toString().padStart(2, '0')})`;
9
+ };
10
+ /**
11
+ * Horizontal thin lines that separates grouped content in a list or other containers with an optional section/group
12
+ * label.
13
+ *
14
+ * Vertical thin lines that separates grouped content or other visual elements within a container.
15
+ *
16
+ * @name Divider
17
+ */
18
+ function Divider({ padding = true, orientation = 'horizontal', thickness = 'light', inset = 0, ...props }) {
19
+ return (_jsx("div", { ...props, "aria-orientation": orientation, "data-bspk": "divider", "data-hide-padding": !padding || undefined, "data-orientation": orientation, "data-thickness": thickness, role: "separator", style: {
20
+ ...props.style,
21
+ '--inset': insetToVariable(inset),
22
+ } }));
23
+ }
24
+ Divider.bspkName = 'Divider';
25
+ export { Divider };
26
+ //# sourceMappingURL=Divider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Divider.js","sourceRoot":"","sources":["../src/Divider.tsx"],"names":[],"mappings":";AAAA,OAAO,gBAAgB,CAAC;AAgCxB,MAAM,eAAe,GAAG,CAAC,SAA0B,EAAE,EAAE;IACnD,MAAM,KAAK,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;IAChC,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,GAAG,CAAC,IAAI,KAAK,GAAG,EAAE;QAAE,OAAO,KAAK,CAAC;IACnF,OAAO,wBAAwB,KAAK,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,GAAG,CAAC;AACxE,CAAC,CAAC;AAEF;;;;;;;GAOG;AACH,SAAS,OAAO,CAAC,EACb,OAAO,GAAG,IAAI,EACd,WAAW,GAAG,YAAY,EAC1B,SAAS,GAAG,OAAO,EACnB,KAAK,GAAG,CAAC,EACT,GAAG,KAAK,EACwB;IAChC,OAAO,CACH,iBACQ,KAAK,sBACS,WAAW,eACnB,SAAS,uBACA,CAAC,OAAO,IAAI,SAAS,sBACtB,WAAW,oBACb,SAAS,EACzB,IAAI,EAAC,WAAW,EAChB,KAAK,EACD;YACI,GAAG,KAAK,CAAC,KAAK;YACd,SAAS,EAAE,eAAe,CAAC,KAAK,CAAC;SACb,GAE9B,CACL,CAAC;AACN,CAAC;AAED,OAAO,CAAC,QAAQ,GAAG,SAAS,CAAC;AAE7B,OAAO,EAAE,OAAO,EAAE,CAAC"}