@bspk/ui 1.0.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 (506) hide show
  1. package/Accordion.d.ts +20 -0
  2. package/Accordion.js +18 -0
  3. package/Accordion.js.map +1 -0
  4. package/Badge.d.ts +33 -0
  5. package/Badge.js +43 -0
  6. package/Badge.js.map +1 -0
  7. package/BannerAlert.d.ts +53 -0
  8. package/BannerAlert.js +133 -0
  9. package/BannerAlert.js.map +1 -0
  10. package/BottomNavigation.d.ts +20 -0
  11. package/BottomNavigation.js +18 -0
  12. package/BottomNavigation.js.map +1 -0
  13. package/BottomSheet.d.ts +20 -0
  14. package/BottomSheet.js +18 -0
  15. package/BottomSheet.js.map +1 -0
  16. package/Breadcrumb.d.ts +20 -0
  17. package/Breadcrumb.js +18 -0
  18. package/Breadcrumb.js.map +1 -0
  19. package/Button.d.ts +66 -0
  20. package/Button.js +254 -0
  21. package/Button.js.map +1 -0
  22. package/ButtonDock.d.ts +20 -0
  23. package/ButtonDock.js +18 -0
  24. package/ButtonDock.js.map +1 -0
  25. package/CODE_OF_CONDUCT.md +137 -0
  26. package/CONTRIBUTING.md +42 -0
  27. package/Card.d.ts +37 -0
  28. package/Card.js +38 -0
  29. package/Card.js.map +1 -0
  30. package/Chart.d.ts +20 -0
  31. package/Chart.js +18 -0
  32. package/Chart.js.map +1 -0
  33. package/Checkbox.d.ts +26 -0
  34. package/Checkbox.js +123 -0
  35. package/Checkbox.js.map +1 -0
  36. package/CheckboxGroup.d.ts +49 -0
  37. package/CheckboxGroup.js +18 -0
  38. package/CheckboxGroup.js.map +1 -0
  39. package/CheckboxOption.d.ts +14 -0
  40. package/CheckboxOption.js +16 -0
  41. package/CheckboxOption.js.map +1 -0
  42. package/Chip.d.ts +50 -0
  43. package/Chip.js +87 -0
  44. package/Chip.js.map +1 -0
  45. package/DatePicker.d.ts +20 -0
  46. package/DatePicker.js +18 -0
  47. package/DatePicker.js.map +1 -0
  48. package/Dialog.d.ts +46 -0
  49. package/Dialog.js +221 -0
  50. package/Dialog.js.map +1 -0
  51. package/Divider.d.ts +44 -0
  52. package/Divider.js +76 -0
  53. package/Divider.js.map +1 -0
  54. package/Drawer.d.ts +20 -0
  55. package/Drawer.js +18 -0
  56. package/Drawer.js.map +1 -0
  57. package/Dropdown.d.ts +50 -0
  58. package/Dropdown.js +153 -0
  59. package/Dropdown.js.map +1 -0
  60. package/DropdownField.d.ts +16 -0
  61. package/DropdownField.js +19 -0
  62. package/DropdownField.js.map +1 -0
  63. package/EmptyState.d.ts +35 -0
  64. package/EmptyState.js +20 -0
  65. package/EmptyState.js.map +1 -0
  66. package/Fab.d.ts +43 -0
  67. package/Fab.js +146 -0
  68. package/Fab.js.map +1 -0
  69. package/FileUpload.d.ts +20 -0
  70. package/FileUpload.js +18 -0
  71. package/FileUpload.js.map +1 -0
  72. package/FormField.d.ts +48 -0
  73. package/FormField.js +39 -0
  74. package/FormField.js.map +1 -0
  75. package/GUIDELINES.md +41 -0
  76. package/Image.d.ts +20 -0
  77. package/Image.js +18 -0
  78. package/Image.js.map +1 -0
  79. package/Img.d.ts +26 -0
  80. package/Img.js +20 -0
  81. package/Img.js.map +1 -0
  82. package/InlineAlert.d.ts +31 -0
  83. package/InlineAlert.js +73 -0
  84. package/InlineAlert.js.map +1 -0
  85. package/LICENSE +395 -0
  86. package/Layout.d.ts +48 -0
  87. package/Layout.js +24 -0
  88. package/Layout.js.map +1 -0
  89. package/Link.d.ts +38 -0
  90. package/Link.js +37 -0
  91. package/Link.js.map +1 -0
  92. package/ListItem.d.ts +68 -0
  93. package/ListItem.js +207 -0
  94. package/ListItem.js.map +1 -0
  95. package/Menu.d.ts +86 -0
  96. package/Menu.js +98 -0
  97. package/Menu.js.map +1 -0
  98. package/MenuButton.d.ts +16 -0
  99. package/MenuButton.js +30 -0
  100. package/MenuButton.js.map +1 -0
  101. package/Modal.d.ts +31 -0
  102. package/Modal.js +53 -0
  103. package/Modal.js.map +1 -0
  104. package/MultiSelection.d.ts +20 -0
  105. package/MultiSelection.js +18 -0
  106. package/MultiSelection.js.map +1 -0
  107. package/NavigationRail.d.ts +20 -0
  108. package/NavigationRail.js +18 -0
  109. package/NavigationRail.js.map +1 -0
  110. package/NumberField.d.ts +17 -0
  111. package/NumberField.js +20 -0
  112. package/NumberField.js.map +1 -0
  113. package/NumberInput.d.ts +34 -0
  114. package/NumberInput.js +188 -0
  115. package/NumberInput.js.map +1 -0
  116. package/OTPInput.d.ts +20 -0
  117. package/OTPInput.js +18 -0
  118. package/OTPInput.js.map +1 -0
  119. package/PageControl.d.ts +20 -0
  120. package/PageControl.js +18 -0
  121. package/PageControl.js.map +1 -0
  122. package/PasswordInput.d.ts +20 -0
  123. package/PasswordInput.js +18 -0
  124. package/PasswordInput.js.map +1 -0
  125. package/PhoneNumberInput.d.ts +20 -0
  126. package/PhoneNumberInput.js +18 -0
  127. package/PhoneNumberInput.js.map +1 -0
  128. package/Popover.d.ts +44 -0
  129. package/Popover.js +152 -0
  130. package/Popover.js.map +1 -0
  131. package/Portal.d.ts +24 -0
  132. package/Portal.js +23 -0
  133. package/Portal.js.map +1 -0
  134. package/Profile.d.ts +41 -0
  135. package/Profile.js +83 -0
  136. package/Profile.js.map +1 -0
  137. package/ProgressBar.d.ts +38 -0
  138. package/ProgressBar.js +64 -0
  139. package/ProgressBar.js.map +1 -0
  140. package/ProgressCircle.d.ts +31 -0
  141. package/ProgressCircle.js +82 -0
  142. package/ProgressCircle.js.map +1 -0
  143. package/ProgressionStepper.d.ts +66 -0
  144. package/ProgressionStepper.js +197 -0
  145. package/ProgressionStepper.js.map +1 -0
  146. package/ProgressionStepperBar.d.ts +31 -0
  147. package/ProgressionStepperBar.js +51 -0
  148. package/ProgressionStepperBar.js.map +1 -0
  149. package/README.md +13 -0
  150. package/Radio.d.ts +17 -0
  151. package/Radio.js +97 -0
  152. package/Radio.js.map +1 -0
  153. package/RadioGroup.d.ts +31 -0
  154. package/RadioGroup.js +18 -0
  155. package/RadioGroup.js.map +1 -0
  156. package/RadioOption.d.ts +14 -0
  157. package/RadioOption.js +16 -0
  158. package/RadioOption.js.map +1 -0
  159. package/Rating.d.ts +16 -0
  160. package/Rating.js +18 -0
  161. package/Rating.js.map +1 -0
  162. package/SearchBar.d.ts +26 -0
  163. package/SearchBar.js +49 -0
  164. package/SearchBar.js.map +1 -0
  165. package/SegmentedControl.d.ts +69 -0
  166. package/SegmentedControl.js +136 -0
  167. package/SegmentedControl.js.map +1 -0
  168. package/Skeleton.d.ts +28 -0
  169. package/Skeleton.js +57 -0
  170. package/Skeleton.js.map +1 -0
  171. package/SliderInput.d.ts +16 -0
  172. package/SliderInput.js +18 -0
  173. package/SliderInput.js.map +1 -0
  174. package/Snackbar.d.ts +16 -0
  175. package/Snackbar.js +18 -0
  176. package/Snackbar.js.map +1 -0
  177. package/StylesProviderAnywhere.d.ts +10 -0
  178. package/StylesProviderAnywhere.js +29 -0
  179. package/StylesProviderAnywhere.js.map +1 -0
  180. package/StylesProviderBetterHomesGardens.d.ts +10 -0
  181. package/StylesProviderBetterHomesGardens.js +29 -0
  182. package/StylesProviderBetterHomesGardens.js.map +1 -0
  183. package/StylesProviderCartus.d.ts +10 -0
  184. package/StylesProviderCartus.js +29 -0
  185. package/StylesProviderCartus.js.map +1 -0
  186. package/StylesProviderCentury21.d.ts +10 -0
  187. package/StylesProviderCentury21.js +29 -0
  188. package/StylesProviderCentury21.js.map +1 -0
  189. package/StylesProviderColdwellBanker.d.ts +10 -0
  190. package/StylesProviderColdwellBanker.js +29 -0
  191. package/StylesProviderColdwellBanker.js.map +1 -0
  192. package/StylesProviderCorcoran.d.ts +10 -0
  193. package/StylesProviderCorcoran.js +29 -0
  194. package/StylesProviderCorcoran.js.map +1 -0
  195. package/StylesProviderDenaliBoss.d.ts +10 -0
  196. package/StylesProviderDenaliBoss.js +29 -0
  197. package/StylesProviderDenaliBoss.js.map +1 -0
  198. package/StylesProviderEra.d.ts +10 -0
  199. package/StylesProviderEra.js +29 -0
  200. package/StylesProviderEra.js.map +1 -0
  201. package/StylesProviderSothebys.d.ts +10 -0
  202. package/StylesProviderSothebys.js +29 -0
  203. package/StylesProviderSothebys.js.map +1 -0
  204. package/Switch.d.ts +33 -0
  205. package/Switch.js +85 -0
  206. package/Switch.js.map +1 -0
  207. package/SwitchGroup.d.ts +35 -0
  208. package/SwitchGroup.js +18 -0
  209. package/SwitchGroup.js.map +1 -0
  210. package/SwitchOption.d.ts +14 -0
  211. package/SwitchOption.js +16 -0
  212. package/SwitchOption.js.map +1 -0
  213. package/TabGroup.d.ts +73 -0
  214. package/TabGroup.js +119 -0
  215. package/TabGroup.js.map +1 -0
  216. package/Table.d.ts +45 -0
  217. package/Table.js +66 -0
  218. package/Table.js.map +1 -0
  219. package/Tag.d.ts +56 -0
  220. package/Tag.js +77 -0
  221. package/Tag.js.map +1 -0
  222. package/TextField.d.ts +16 -0
  223. package/TextField.js +19 -0
  224. package/TextField.js.map +1 -0
  225. package/TextInput.d.ts +45 -0
  226. package/TextInput.js +172 -0
  227. package/TextInput.js.map +1 -0
  228. package/Textarea.d.ts +63 -0
  229. package/Textarea.js +113 -0
  230. package/Textarea.js.map +1 -0
  231. package/TextareaField.d.ts +16 -0
  232. package/TextareaField.js +26 -0
  233. package/TextareaField.js.map +1 -0
  234. package/TimePicker.d.ts +16 -0
  235. package/TimePicker.js +18 -0
  236. package/TimePicker.js.map +1 -0
  237. package/ToggleOption.d.ts +27 -0
  238. package/ToggleOption.js +91 -0
  239. package/ToggleOption.js.map +1 -0
  240. package/Tooltip.d.ts +39 -0
  241. package/Tooltip.js +104 -0
  242. package/Tooltip.js.map +1 -0
  243. package/TopNavigation.d.ts +16 -0
  244. package/TopNavigation.js +18 -0
  245. package/TopNavigation.js.map +1 -0
  246. package/Txt.d.ts +38 -0
  247. package/Txt.js +21 -0
  248. package/Txt.js.map +1 -0
  249. package/hooks/useCheckboxGroupState.d.ts +37 -0
  250. package/hooks/useCheckboxGroupState.js +61 -0
  251. package/hooks/useCheckboxGroupState.js.map +1 -0
  252. package/hooks/useCheckboxState.d.ts +23 -0
  253. package/hooks/useCheckboxState.js +40 -0
  254. package/hooks/useCheckboxState.js.map +1 -0
  255. package/hooks/useFloating.d.ts +38 -0
  256. package/hooks/useFloating.js +156 -0
  257. package/hooks/useFloating.js.map +1 -0
  258. package/hooks/useFloatingMenu.d.ts +35 -0
  259. package/hooks/useFloatingMenu.js +71 -0
  260. package/hooks/useFloatingMenu.js.map +1 -0
  261. package/hooks/useId.d.ts +8 -0
  262. package/hooks/useId.js +16 -0
  263. package/hooks/useId.js.map +1 -0
  264. package/hooks/useKeyboardNavigation.d.ts +35 -0
  265. package/hooks/useKeyboardNavigation.js +79 -0
  266. package/hooks/useKeyboardNavigation.js.map +1 -0
  267. package/hooks/useLongPress.d.ts +11 -0
  268. package/hooks/useLongPress.js +49 -0
  269. package/hooks/useLongPress.js.map +1 -0
  270. package/hooks/useModalState.d.ts +22 -0
  271. package/hooks/useModalState.js +37 -0
  272. package/hooks/useModalState.js.map +1 -0
  273. package/hooks/useNavOptions.d.ts +28 -0
  274. package/hooks/useNavOptions.js +46 -0
  275. package/hooks/useNavOptions.js.map +1 -0
  276. package/hooks/useOutsideClick.d.ts +31 -0
  277. package/hooks/useOutsideClick.js +50 -0
  278. package/hooks/useOutsideClick.js.map +1 -0
  279. package/hooks/useRadioState.d.ts +23 -0
  280. package/hooks/useRadioState.js +38 -0
  281. package/hooks/useRadioState.js.map +1 -0
  282. package/hooks/useSwitchGroupState.d.ts +37 -0
  283. package/hooks/useSwitchGroupState.js +60 -0
  284. package/hooks/useSwitchGroupState.js.map +1 -0
  285. package/hooks/useTimeout.d.ts +26 -0
  286. package/hooks/useTimeout.js +45 -0
  287. package/hooks/useTimeout.js.map +1 -0
  288. package/hooks/useValidChildren.d.ts +6 -0
  289. package/hooks/useValidChildren.js +33 -0
  290. package/hooks/useValidChildren.js.map +1 -0
  291. package/index.d.ts +125 -0
  292. package/index.js +20 -0
  293. package/index.js.map +1 -0
  294. package/meta.d.ts +44 -0
  295. package/meta.js +5789 -0
  296. package/meta.js.map +1 -0
  297. package/package.json +73 -0
  298. package/src/Accordion.tsx +33 -0
  299. package/src/Badge.tsx +75 -0
  300. package/src/BannerAlert.tsx +211 -0
  301. package/src/BottomNavigation.tsx +33 -0
  302. package/src/BottomSheet.tsx +33 -0
  303. package/src/Breadcrumb.tsx +33 -0
  304. package/src/Button.tsx +358 -0
  305. package/src/ButtonDock.tsx +33 -0
  306. package/src/Card.tsx +66 -0
  307. package/src/Chart.tsx +33 -0
  308. package/src/Checkbox.tsx +174 -0
  309. package/src/CheckboxGroup.tsx +95 -0
  310. package/src/CheckboxOption.tsx +27 -0
  311. package/src/Chip.tsx +155 -0
  312. package/src/DatePicker.tsx +33 -0
  313. package/src/Dialog.tsx +304 -0
  314. package/src/Divider.tsx +129 -0
  315. package/src/Drawer.tsx +33 -0
  316. package/src/Dropdown.tsx +251 -0
  317. package/src/DropdownField.tsx +57 -0
  318. package/src/EmptyState.tsx +73 -0
  319. package/src/Fab.tsx +222 -0
  320. package/src/FileUpload.tsx +33 -0
  321. package/src/FormField.tsx +107 -0
  322. package/src/Image.tsx +33 -0
  323. package/src/Img.tsx +39 -0
  324. package/src/InlineAlert.tsx +119 -0
  325. package/src/Layout.tsx +82 -0
  326. package/src/Link.tsx +82 -0
  327. package/src/ListItem.tsx +316 -0
  328. package/src/Menu.tsx +263 -0
  329. package/src/MenuButton.tsx +45 -0
  330. package/src/Modal.tsx +104 -0
  331. package/src/MultiSelection.tsx +33 -0
  332. package/src/NavigationRail.tsx +33 -0
  333. package/src/NumberField.tsx +47 -0
  334. package/src/NumberInput.tsx +282 -0
  335. package/src/OTPInput.tsx +33 -0
  336. package/src/PageControl.tsx +33 -0
  337. package/src/PasswordInput.tsx +33 -0
  338. package/src/PhoneNumberInput.tsx +33 -0
  339. package/src/Popover.tsx +237 -0
  340. package/src/Portal.tsx +36 -0
  341. package/src/Profile.tsx +140 -0
  342. package/src/ProgressBar.tsx +110 -0
  343. package/src/ProgressCircle.tsx +153 -0
  344. package/src/ProgressionStepper.tsx +294 -0
  345. package/src/ProgressionStepperBar.tsx +95 -0
  346. package/src/Radio.tsx +119 -0
  347. package/src/RadioGroup.tsx +62 -0
  348. package/src/RadioOption.tsx +24 -0
  349. package/src/Rating.tsx +29 -0
  350. package/src/SearchBar.tsx +121 -0
  351. package/src/SegmentedControl.tsx +233 -0
  352. package/src/Skeleton.tsx +90 -0
  353. package/src/SliderInput.tsx +29 -0
  354. package/src/Snackbar.tsx +29 -0
  355. package/src/StylesProviderAnywhere.tsx +31 -0
  356. package/src/StylesProviderBetterHomesGardens.tsx +31 -0
  357. package/src/StylesProviderCartus.tsx +31 -0
  358. package/src/StylesProviderCentury21.tsx +31 -0
  359. package/src/StylesProviderColdwellBanker.tsx +31 -0
  360. package/src/StylesProviderCorcoran.tsx +31 -0
  361. package/src/StylesProviderDenaliBoss.tsx +31 -0
  362. package/src/StylesProviderEra.tsx +31 -0
  363. package/src/StylesProviderSothebys.tsx +31 -0
  364. package/src/Switch.tsx +122 -0
  365. package/src/SwitchGroup.tsx +60 -0
  366. package/src/SwitchOption.tsx +24 -0
  367. package/src/TabGroup.tsx +219 -0
  368. package/src/Table.tsx +126 -0
  369. package/src/Tag.tsx +149 -0
  370. package/src/TextField.tsx +61 -0
  371. package/src/TextInput.tsx +265 -0
  372. package/src/Textarea.tsx +205 -0
  373. package/src/TextareaField.tsx +67 -0
  374. package/src/TimePicker.tsx +29 -0
  375. package/src/ToggleOption.tsx +117 -0
  376. package/src/Tooltip.tsx +170 -0
  377. package/src/TopNavigation.tsx +29 -0
  378. package/src/Txt.tsx +69 -0
  379. package/src/hooks/useCheckboxGroupState.ts +79 -0
  380. package/src/hooks/useCheckboxState.ts +48 -0
  381. package/src/hooks/useFloating.ts +202 -0
  382. package/src/hooks/useFloatingMenu.ts +110 -0
  383. package/src/hooks/useId.ts +14 -0
  384. package/src/hooks/useKeyboardNavigation.ts +98 -0
  385. package/src/hooks/useLongPress.ts +53 -0
  386. package/src/hooks/useModalState.ts +37 -0
  387. package/src/hooks/useNavOptions.ts +76 -0
  388. package/src/hooks/useOutsideClick.ts +51 -0
  389. package/src/hooks/useRadioState.ts +42 -0
  390. package/src/hooks/useSwitchGroupState.ts +75 -0
  391. package/src/hooks/useTimeout.ts +45 -0
  392. package/src/hooks/useValidChildren.ts +54 -0
  393. package/src/index.ts +160 -0
  394. package/src/meta.ts +6238 -0
  395. package/src/package.json +3 -0
  396. package/src/styles/anywhere.css +1693 -0
  397. package/src/styles/anywhere.ts +1694 -0
  398. package/src/styles/base.css +160 -0
  399. package/src/styles/base.ts +161 -0
  400. package/src/styles/better-homes-gardens.css +1693 -0
  401. package/src/styles/better-homes-gardens.ts +1694 -0
  402. package/src/styles/cartus.css +1691 -0
  403. package/src/styles/cartus.ts +1692 -0
  404. package/src/styles/century-21.css +1689 -0
  405. package/src/styles/century-21.ts +1690 -0
  406. package/src/styles/coldwell-banker.css +1691 -0
  407. package/src/styles/coldwell-banker.ts +1692 -0
  408. package/src/styles/corcoran.css +1685 -0
  409. package/src/styles/corcoran.ts +1686 -0
  410. package/src/styles/denali-boss.css +1681 -0
  411. package/src/styles/denali-boss.ts +1682 -0
  412. package/src/styles/era.css +1685 -0
  413. package/src/styles/era.ts +1686 -0
  414. package/src/styles/sothebys.css +1677 -0
  415. package/src/styles/sothebys.ts +1678 -0
  416. package/src/utils/children.ts +80 -0
  417. package/src/utils/colorVariants.ts +74 -0
  418. package/src/utils/errors.tsx +104 -0
  419. package/src/utils/getValidNode.ts +7 -0
  420. package/src/utils/keyboard.ts +382 -0
  421. package/src/utils/placeholder.test.ts +7 -0
  422. package/src/utils/ref.ts +11 -0
  423. package/src/utils/scrollElementIntoView.ts +29 -0
  424. package/src/utils/srOnly.ts +14 -0
  425. package/src/utils/tryIntPsrse.ts +7 -0
  426. package/src/utils/txtVariants.ts +53 -0
  427. package/styles/anywhere.css +1693 -0
  428. package/styles/anywhere.d.ts +2 -0
  429. package/styles/anywhere.js +1697 -0
  430. package/styles/anywhere.js.map +1 -0
  431. package/styles/anywhere.ts +1694 -0
  432. package/styles/base.css +160 -0
  433. package/styles/base.d.ts +2 -0
  434. package/styles/base.js +164 -0
  435. package/styles/base.js.map +1 -0
  436. package/styles/base.ts +161 -0
  437. package/styles/better-homes-gardens.css +1693 -0
  438. package/styles/better-homes-gardens.d.ts +2 -0
  439. package/styles/better-homes-gardens.js +1697 -0
  440. package/styles/better-homes-gardens.js.map +1 -0
  441. package/styles/better-homes-gardens.ts +1694 -0
  442. package/styles/cartus.css +1691 -0
  443. package/styles/cartus.d.ts +2 -0
  444. package/styles/cartus.js +1695 -0
  445. package/styles/cartus.js.map +1 -0
  446. package/styles/cartus.ts +1692 -0
  447. package/styles/century-21.css +1689 -0
  448. package/styles/century-21.d.ts +2 -0
  449. package/styles/century-21.js +1693 -0
  450. package/styles/century-21.js.map +1 -0
  451. package/styles/century-21.ts +1690 -0
  452. package/styles/coldwell-banker.css +1691 -0
  453. package/styles/coldwell-banker.d.ts +2 -0
  454. package/styles/coldwell-banker.js +1695 -0
  455. package/styles/coldwell-banker.js.map +1 -0
  456. package/styles/coldwell-banker.ts +1692 -0
  457. package/styles/corcoran.css +1685 -0
  458. package/styles/corcoran.d.ts +2 -0
  459. package/styles/corcoran.js +1689 -0
  460. package/styles/corcoran.js.map +1 -0
  461. package/styles/corcoran.ts +1686 -0
  462. package/styles/denali-boss.css +1681 -0
  463. package/styles/denali-boss.d.ts +2 -0
  464. package/styles/denali-boss.js +1685 -0
  465. package/styles/denali-boss.js.map +1 -0
  466. package/styles/denali-boss.ts +1682 -0
  467. package/styles/era.css +1685 -0
  468. package/styles/era.d.ts +2 -0
  469. package/styles/era.js +1689 -0
  470. package/styles/era.js.map +1 -0
  471. package/styles/era.ts +1686 -0
  472. package/styles/sothebys.css +1677 -0
  473. package/styles/sothebys.d.ts +2 -0
  474. package/styles/sothebys.js +1681 -0
  475. package/styles/sothebys.js.map +1 -0
  476. package/styles/sothebys.ts +1678 -0
  477. package/utils/children.d.ts +29 -0
  478. package/utils/children.js +70 -0
  479. package/utils/children.js.map +1 -0
  480. package/utils/colorVariants.d.ts +5 -0
  481. package/utils/colorVariants.js +61 -0
  482. package/utils/colorVariants.js.map +1 -0
  483. package/utils/errors.d.ts +36 -0
  484. package/utils/errors.js +65 -0
  485. package/utils/errors.js.map +1 -0
  486. package/utils/getValidNode.d.ts +2 -0
  487. package/utils/getValidNode.js +9 -0
  488. package/utils/getValidNode.js.map +1 -0
  489. package/utils/keyboard.d.ts +4 -0
  490. package/utils/keyboard.js +140 -0
  491. package/utils/keyboard.js.map +1 -0
  492. package/utils/ref.d.ts +5 -0
  493. package/utils/ref.js +10 -0
  494. package/utils/ref.js.map +1 -0
  495. package/utils/scrollElementIntoView.d.ts +8 -0
  496. package/utils/scrollElementIntoView.js +30 -0
  497. package/utils/scrollElementIntoView.js.map +1 -0
  498. package/utils/srOnly.d.ts +14 -0
  499. package/utils/srOnly.js +15 -0
  500. package/utils/srOnly.js.map +1 -0
  501. package/utils/tryIntPsrse.d.ts +2 -0
  502. package/utils/tryIntPsrse.js +10 -0
  503. package/utils/tryIntPsrse.js.map +1 -0
  504. package/utils/txtVariants.d.ts +2 -0
  505. package/utils/txtVariants.js +30 -0
  506. package/utils/txtVariants.js.map +1 -0
package/Portal.js ADDED
@@ -0,0 +1,23 @@
1
+ import { useState, useEffect } from 'react';
2
+ import { createPortal } from 'react-dom';
3
+
4
+ /**
5
+ * Utility component to render children in the portals container provided by the BaseProvider.
6
+ *
7
+ * Initial SRR is supported.
8
+ *
9
+ * @name Portal
10
+ */
11
+ function Portal({ children, container }) {
12
+ const [portalContainer, setPortalContainer] = useState(container || null);
13
+ useEffect(() => {
14
+ if (!portalContainer && typeof window !== 'undefined')
15
+ setPortalContainer(document.body);
16
+ }, [portalContainer]);
17
+ return portalContainer && createPortal(children, portalContainer);
18
+ }
19
+ Portal.bspkName = 'Portal';
20
+ /** Copyright 2025 Anywhere Real Estate - CC BY 4.0 */
21
+
22
+ export { Portal };
23
+ //# sourceMappingURL=Portal.js.map
package/Portal.js.map ADDED
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Portal.js","sources":["src/Portal.tsx"],"sourcesContent":[null],"names":[],"mappings":";;;AAcA;;;;;;AAMG;AACH,SAAS,MAAM,CAAC,EAAE,QAAQ,EAAE,SAAS,EAAe,EAAA;AAChD,IAAA,MAAM,CAAC,eAAe,EAAE,kBAAkB,CAAC,GAAG,QAAQ,CAAqB,SAAS,IAAI,IAAI,CAAC,CAAC;IAE9F,SAAS,CAAC,MAAK;AACX,QAAA,IAAI,CAAC,eAAe,IAAI,OAAO,MAAM,KAAK,WAAW;AAAE,YAAA,kBAAkB,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;AAC7F,KAAC,EAAE,CAAC,eAAe,CAAC,CAAC,CAAC;IAEtB,OAAO,eAAe,IAAI,YAAY,CAAC,QAAQ,EAAE,eAAe,CAAC,CAAC;AACtE,CAAC;AAED,MAAM,CAAC,QAAQ,GAAG,QAAQ,CAAC;AAI3B;;;;"}
package/Profile.d.ts ADDED
@@ -0,0 +1,41 @@
1
+ import { ReactNode } from 'react';
2
+ import { ColorVariant } from './utils/colorVariants';
3
+ import { CommonProps } from '.';
4
+ export type SizeVariant = 'large' | 'medium' | 'small' | 'x-large' | 'x-small' | 'xx-large' | 'xxx-large' | 'xxxx-large' | 'xxxxx-large';
5
+ export type ProfileProps = CommonProps<'aria-label'> & {
6
+ /**
7
+ * The size of the profile.
8
+ *
9
+ * @default small
10
+ */
11
+ size?: SizeVariant;
12
+ /**
13
+ * The color of the profile.
14
+ *
15
+ * @default grey
16
+ */
17
+ color?: ColorVariant;
18
+ /** The initials to display in the profile limited to 2 characters. */
19
+ initials?: string;
20
+ /** The icon to display in the profile. */
21
+ icon?: ReactNode;
22
+ /** The url to the image to display in the profile. */
23
+ image?: string;
24
+ /** The number of notifications not displayed in a list. */
25
+ overflowCount?: number;
26
+ };
27
+ /**
28
+ * A profile component.
29
+ *
30
+ * A profile is a visual representation of a user or entity. It can be used to display an initials, icon, image, or an
31
+ * overflowCount.
32
+ *
33
+ * @name Profile
34
+ */
35
+ declare function Profile({ initials, color, size, icon, image, 'aria-label': ariaLabel, overflowCount, }: ProfileProps): import("@emotion/react/jsx-runtime").JSX.Element;
36
+ declare namespace Profile {
37
+ var bspkName: string;
38
+ }
39
+ export { Profile };
40
+ export declare const style: import("@emotion/react").SerializedStyles;
41
+ /** Copyright 2025 Anywhere Real Estate - CC BY 4.0 */
package/Profile.js ADDED
@@ -0,0 +1,83 @@
1
+ import { jsx, jsxs, Fragment } from '@emotion/react/jsx-runtime';
2
+ import { css } from '@emotion/react';
3
+ import { useMemo } from 'react';
4
+ import { COLOR_VARIABLES } from './utils/colorVariants.js';
5
+
6
+ const SIZE_VARIANTS = {
7
+ 'x-small': { font: '--labels-x-small', height: '--spacing-sizing-06' }, // 24
8
+ small: { font: '--labels-small', height: '--spacing-sizing-08' }, // 32,
9
+ medium: { font: '--labels-base', height: '--spacing-sizing-10' }, // 40
10
+ large: { font: '--labels-large', height: '--spacing-sizing-12' }, //48,
11
+ 'x-large': { font: '--desktop-subheader-x-large', height: '--spacing-sizing-14' }, // 56,
12
+ 'xx-large': { font: '--desktop-subheader-xx-large', height: '--spacing-sizing-17' }, // 72,
13
+ 'xxx-large': { font: '--desktop-display-regular-small', height: '--spacing-sizing-19' }, //96,
14
+ 'xxxx-large': { font: '--desktop-display-regular-medium', height: '--spacing-sizing-21' }, // 120,
15
+ 'xxxxx-large': { font: '--desktop-display-regular-large', height: '--spacing-sizing-23' }, //144,
16
+ };
17
+ /**
18
+ * A profile component.
19
+ *
20
+ * A profile is a visual representation of a user or entity. It can be used to display an initials, icon, image, or an
21
+ * overflowCount.
22
+ *
23
+ * @name Profile
24
+ */
25
+ function Profile({ initials, color = 'grey', size = 'small', icon, image, 'aria-label': ariaLabel, overflowCount, }) {
26
+ const children = useMemo(() => {
27
+ if (initials)
28
+ return jsx("span", { "data-initials": true, children: initials });
29
+ if (icon)
30
+ return jsx("span", { "data-icon": true, children: icon });
31
+ if (image)
32
+ return jsx("img", { alt: ariaLabel, src: image });
33
+ if (overflowCount)
34
+ return jsxs("span", { "data-overflow-count": true, children: ["+", overflowCount] });
35
+ return null;
36
+ }, [ariaLabel, icon, image, initials, overflowCount]);
37
+ return (jsx(Fragment, { children: children && (jsx("div", { "aria-label": ariaLabel, css: style, "data-color": color, "data-profile": "", "data-size": size, children: children })) }));
38
+ }
39
+ Profile.bspkName = 'Profile';
40
+ const style = css `
41
+ --height: var(--spacing-sizing-10);
42
+ --font: var(--labels-base);
43
+ --foreground: var(--foreground-neutral-on-surface);
44
+ --background: var(--surface-neutral-t3-low);
45
+
46
+ display: flex;
47
+ flex-direction: column;
48
+ justify-content: center;
49
+ align-items: center;
50
+ padding: 0;
51
+ height: var(--height);
52
+ width: var(--height);
53
+ aspect-ratio: 1 / 1;
54
+ border-radius: 999px;
55
+ background-color: var(--background);
56
+ color: var(--foreground);
57
+ font: var(--font);
58
+
59
+ &:has(img) {
60
+ overflow: hidden;
61
+ }
62
+
63
+ img {
64
+ max-width: 100%;
65
+ }
66
+
67
+ ${Object.entries(SIZE_VARIANTS).map(([variant, { height, font }]) => css `
68
+ &[data-size='${variant}'] {
69
+ --height: var(${height});
70
+ --font: var(${font});
71
+ }
72
+ `)}
73
+
74
+ ${Object.entries(COLOR_VARIABLES).map(([variant, { foreground, surface }]) => css `
75
+ &[data-color='${variant}'] {
76
+ --foreground: var(${foreground});
77
+ --background: var(${surface});
78
+ }
79
+ `)};
80
+ `;
81
+
82
+ export { Profile, style };
83
+ //# sourceMappingURL=Profile.js.map
package/Profile.js.map ADDED
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Profile.js","sources":["src/Profile.tsx"],"sourcesContent":[null],"names":["_jsx","_jsxs"],"mappings":"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"}
@@ -0,0 +1,38 @@
1
+ export type ProgressBarProps = {
2
+ /**
3
+ * The size of the progressbar.
4
+ *
5
+ * @default large
6
+ */
7
+ size?: 'large' | 'small';
8
+ /**
9
+ * The current progress of the progressbar.
10
+ *
11
+ * @default 0
12
+ * @minimum 0
13
+ * @maximum 100
14
+ * @required
15
+ */
16
+ completion: number;
17
+ /**
18
+ * The label alignment of the progressbar.
19
+ *
20
+ * @default center
21
+ */
22
+ align?: 'center' | 'left';
23
+ /** The label of the progressbar. */
24
+ label: string;
25
+ };
26
+ /**
27
+ * A progress bar is a horizontal visual indicator that let’s the user know the progression of a task or operation
28
+ * occurring in the background.
29
+ *
30
+ * @name ProgressBar
31
+ */
32
+ declare function ProgressBar({ size, completion, align, label }: ProgressBarProps): import("@emotion/react/jsx-runtime").JSX.Element;
33
+ declare namespace ProgressBar {
34
+ var bspkName: string;
35
+ }
36
+ export { ProgressBar };
37
+ export declare const style: import("@emotion/react").SerializedStyles;
38
+ /** Copyright 2025 Anywhere Real Estate - CC BY 4.0 */
package/ProgressBar.js ADDED
@@ -0,0 +1,64 @@
1
+ import { jsxs, jsx } from '@emotion/react/jsx-runtime';
2
+ import { css } from '@emotion/react';
3
+ import { useId } from 'react';
4
+
5
+ /**
6
+ * A progress bar is a horizontal visual indicator that let’s the user know the progression of a task or operation
7
+ * occurring in the background.
8
+ *
9
+ * @name ProgressBar
10
+ */
11
+ function ProgressBar({ size = 'large', completion = 0, align = 'center', label }) {
12
+ const id = useId();
13
+ return (jsxs("div", { css: style, "data-align": align, "data-progress-bar": true, "data-size": size, children: [jsxs("progress", { "aria-busy": completion < 100, "aria-label": "A bounded progress bar from 0 to 100", "aria-valuemax": 100, "aria-valuemin": 0, "aria-valuenow": completion, id: id, max: "100", value: completion, children: [completion, "%"] }), jsx("div", { "aria-hidden": true, "data-bar": true, style: { '--width': `${completion}%` } }), jsx("label", { htmlFor: id, children: label })] }));
14
+ }
15
+ ProgressBar.bspkName = 'ProgressBar';
16
+ const style = css `
17
+ display: flex;
18
+ flex-direction: column;
19
+ width: 100%;
20
+ gap: var(--spacing-sizing-01);
21
+
22
+ progress {
23
+ opacity: 0;
24
+ position: absolute;
25
+ }
26
+
27
+ [data-bar] {
28
+ width: 100%;
29
+ height: var(--spacing-sizing-02);
30
+ background-color: var(--surface-neutral-t3-low);
31
+ border-radius: var(--radius-small);
32
+
33
+ &::after {
34
+ content: '';
35
+ display: block;
36
+ height: 100%;
37
+ background-color: var(--foreground-brand-primary);
38
+ border-radius: var(--radius-small);
39
+ width: var(--width);
40
+ transition: width 0.3s;
41
+ }
42
+ }
43
+
44
+ &[data-size='small'] {
45
+ max-width: 248px;
46
+
47
+ [data-bar] {
48
+ height: var(--spacing-sizing-01);
49
+ }
50
+ }
51
+
52
+ label {
53
+ font-size: var(--labels-small);
54
+ width: 100%;
55
+ text-align: center;
56
+ }
57
+
58
+ &[data-align='left'] label {
59
+ text-align: left;
60
+ }
61
+ `;
62
+
63
+ export { ProgressBar, style };
64
+ //# sourceMappingURL=ProgressBar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ProgressBar.js","sources":["src/ProgressBar.tsx"],"sourcesContent":[null],"names":["_jsxs","_jsx"],"mappings":";;;;AA6BA;;;;;AAKG;AACH,SAAS,WAAW,CAAC,EAAE,IAAI,GAAG,OAAO,EAAE,UAAU,GAAG,CAAC,EAAE,KAAK,GAAG,QAAQ,EAAE,KAAK,EAAoB,EAAA;AAC9F,IAAA,MAAM,EAAE,GAAG,KAAK,EAAE,CAAC;IAEnB,QACIA,IAAK,CAAA,KAAA,EAAA,EAAA,GAAG,EAAE,KAAK,EAAc,YAAA,EAAA,KAAK,EAA+B,mBAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAI,EACjE,QAAA,EAAA,CAAAA,IAAA,CAAA,UAAA,EAAA,EAAA,WAAA,EACe,UAAU,GAAG,GAAG,EAAA,YAAA,EAChB,sCAAsC,EAAA,eAAA,EAClC,GAAG,EAAA,eAAA,EACH,CAAC,EAAA,eAAA,EACD,UAAU,EACzB,EAAE,EAAE,EAAE,EACN,GAAG,EAAC,KAAK,EACT,KAAK,EAAE,UAAU,EAAA,QAAA,EAAA,CAEhB,UAAU,EAAA,GAAA,CAAA,EAAA,CACJ,EACXC,GAAA,CAAA,KAAA,EAAA,EAAA,aAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,EAA0B,KAAK,EAAE,EAAE,SAAS,EAAE,CAAA,EAAG,UAAU,CAAA,CAAA,CAAG,EAAmB,EAAA,CAAI,EACrFA,GAAA,CAAA,OAAA,EAAA,EAAO,OAAO,EAAE,EAAE,EAAA,QAAA,EAAG,KAAK,EAAA,CAAS,CACjC,EAAA,CAAA,EACR;AACN,CAAC;AAED,WAAW,CAAC,QAAQ,GAAG,aAAa,CAAC;AAI9B,MAAM,KAAK,GAAG,GAAG,CAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,31 @@
1
+ export type ProgressCircleProps = {
2
+ /** The label of the progress circle. */
3
+ label: string;
4
+ /**
5
+ * The size of the label and progress circle.
6
+ *
7
+ * @default medium
8
+ */
9
+ size?: 'large' | 'medium' | 'small';
10
+ /**
11
+ * The position of the label in relation to the progress circle.
12
+ *
13
+ * @default bottom
14
+ */
15
+ labelPosition?: 'bottom' | 'left' | 'right' | 'top';
16
+ };
17
+ /**
18
+ * Rotating circle or pill that indicates the status or state of completion for a process that’s part of a user flow.
19
+ *
20
+ * @name ProgressCircle
21
+ */
22
+ declare function ProgressCircle({ label, labelPosition, size }: ProgressCircleProps): import("@emotion/react/jsx-runtime").JSX.Element;
23
+ declare namespace ProgressCircle {
24
+ var bspkName: string;
25
+ var SVG: (props: {
26
+ strokeWidth?: number;
27
+ }) => import("@emotion/react/jsx-runtime").JSX.Element;
28
+ }
29
+ export { ProgressCircle };
30
+ export declare const style: import("@emotion/react").SerializedStyles;
31
+ /** Copyright 2025 Anywhere Real Estate - CC BY 4.0 */
@@ -0,0 +1,82 @@
1
+ import { jsxs, jsx } from '@emotion/react/jsx-runtime';
2
+ import { css } from '@emotion/react';
3
+ import { useId } from 'react';
4
+ import { Txt } from './Txt.js';
5
+
6
+ const ANIMATION_SPEED = 1.5;
7
+ /**
8
+ * Rotating circle or pill that indicates the status or state of completion for a process that’s part of a user flow.
9
+ *
10
+ * @name ProgressCircle
11
+ */
12
+ function ProgressCircle({ label, labelPosition, size = 'medium' }) {
13
+ let variant = 'labels-base';
14
+ if (size === 'small')
15
+ variant = 'labels-small';
16
+ else if (size === 'large')
17
+ variant = 'labels-large';
18
+ const labelId = useId();
19
+ return (jsxs("div", { "aria-labelledby": labelId, css: style, "data-label-position": labelPosition, "data-progress-circle": true, "data-size": size, role: "progressbar", children: [jsx(ProgressCircle.SVG, {}), jsx(Txt, { id: labelId, variant: variant, children: label || 'Loading ...' })] }));
20
+ }
21
+ ProgressCircle.bspkName = 'ProgressCircle';
22
+ const style = css `
23
+ display: flex;
24
+ flex-direction: column;
25
+ gap: var(--spacing-sizing-02);
26
+ align-items: center;
27
+ justify-content: center;
28
+
29
+ &[data-label-position='top'] {
30
+ flex-direction: column-reverse;
31
+ }
32
+
33
+ &[data-label-position='left'] {
34
+ flex-direction: row-reverse;
35
+ }
36
+
37
+ &[data-label-position='right'] {
38
+ flex-direction: row;
39
+ }
40
+
41
+ svg {
42
+ color: var(--foreground-brand-secondary);
43
+ animation: spin ${ANIMATION_SPEED}s linear infinite;
44
+ }
45
+
46
+ @keyframes spin {
47
+ 100% {
48
+ transform: rotate(360deg);
49
+ }
50
+ 0% {
51
+ transform: rotate(0deg);
52
+ }
53
+ }
54
+
55
+ &[data-size='small'] {
56
+ svg {
57
+ width: 32px;
58
+ }
59
+ }
60
+
61
+ &[data-size='medium'] {
62
+ svg {
63
+ width: 40px;
64
+ }
65
+ }
66
+
67
+ &[data-size='large'] {
68
+ svg {
69
+ width: 48px;
70
+ }
71
+ }
72
+ `;
73
+ const ProgressCircleSVG = (props) => {
74
+ const strokeWidth = props.strokeWidth || 10;
75
+ const width = 100;
76
+ const id = useId();
77
+ return (jsxs("svg", { ...props, "data-animated": true, fill: "none", viewBox: `0 0 ${width * 2} ${width * 2}`, children: [jsxs("defs", { children: [jsxs("linearGradient", { id: `${id}spinner-secondHalf`, children: [jsx("stop", { offset: "50%", stopColor: "currentColor", stopOpacity: 0 }), jsx("stop", { offset: "100%", stopColor: "currentColor", stopOpacity: "0.375" })] }), jsxs("linearGradient", { id: `${id}spinner-firstHalf`, children: [jsx("stop", { offset: "0%", stopColor: "currentColor", stopOpacity: 1 }), jsx("stop", { offset: "100%", stopColor: "currentColor", stopOpacity: "0.375" })] })] }), jsxs("g", { strokeWidth: strokeWidth * 2, children: [jsx("path", { d: `M ${strokeWidth} ${width} A ${width - strokeWidth} ${width - strokeWidth} 0 0 1 ${width + (width - strokeWidth)} ${width}`, stroke: `url(#${id}spinner-secondHalf)` }), jsx("path", { d: `M ${width + (width - strokeWidth)} ${width} A ${width - strokeWidth} ${width - strokeWidth} 0 0 1 ${strokeWidth} ${width}`, stroke: `url(#${id}spinner-firstHalf)` }), jsx("path", { d: `M ${strokeWidth} ${width} A ${width - strokeWidth} ${width - strokeWidth} 0 0 1 ${strokeWidth} ${width - 2}`, stroke: "currentColor", strokeLinecap: "round" })] })] }));
78
+ };
79
+ ProgressCircle.SVG = ProgressCircleSVG;
80
+
81
+ export { ProgressCircle, style };
82
+ //# sourceMappingURL=ProgressCircle.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ProgressCircle.js","sources":["src/ProgressCircle.tsx"],"sourcesContent":[null],"names":["_jsxs","_jsx"],"mappings":"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"}
@@ -0,0 +1,66 @@
1
+ import { ElementProps } from '.';
2
+ /** A progress stepper item is a single step in the progress bar. */
3
+ export type ProgressionStepperItem = {
4
+ /**
5
+ * The name of the step.
6
+ *
7
+ * @type string
8
+ * @required
9
+ */
10
+ name: string;
11
+ /**
12
+ * The subtext of the step.
13
+ *
14
+ * @type multiline
15
+ */
16
+ subtext?: string;
17
+ /**
18
+ * The link to navigate to when the step is clicked.
19
+ *
20
+ * @type {label: string; onClick: () => void}
21
+ */
22
+ touchLink?: {
23
+ label: string;
24
+ onClick: () => void;
25
+ };
26
+ };
27
+ export type ProgressionStepperProps = {
28
+ /**
29
+ * The steps to display in the progress bar.
30
+ *
31
+ * @type ProgressionStepperItem[]
32
+ * @required
33
+ */
34
+ steps: ProgressionStepperItem[];
35
+ /**
36
+ * The current step in the progress bar.
37
+ *
38
+ * If the current step is greater than the number of steps, all steps with be completed.
39
+ *
40
+ * If the current step is less than 1, all steps will be incomplete.
41
+ *
42
+ * @default 0
43
+ * @minimum 0
44
+ */
45
+ currentStep?: number;
46
+ /**
47
+ * The variant of the progress bar. Can be either horizontal, vertical, or widget.
48
+ *
49
+ * When on small width screens, the default will automatically switch to widget.
50
+ *
51
+ * @default horizontal
52
+ */
53
+ variant?: 'horizontal' | 'vertical' | 'widget';
54
+ };
55
+ /**
56
+ * A progress stepper is a horizontal visual indicator that let’s the user know the progression of the current process.
57
+ *
58
+ * @name ProgressionStepper
59
+ */
60
+ declare function ProgressionStepper({ steps, currentStep: currentStepProp, variant, ...containerProps }: ElementProps<ProgressionStepperProps, 'div'>): import("@emotion/react/jsx-runtime").JSX.Element;
61
+ declare namespace ProgressionStepper {
62
+ var bspkName: string;
63
+ }
64
+ export { ProgressionStepper };
65
+ export declare const style: import("@emotion/react").SerializedStyles;
66
+ /** Copyright 2025 Anywhere Real Estate - CC BY 4.0 */
@@ -0,0 +1,197 @@
1
+ import { jsxs, jsx, Fragment } from '@emotion/react/jsx-runtime';
2
+ import { SvgCheck } from '@bspk/icons/Check';
3
+ import { css } from '@emotion/react';
4
+
5
+ /**
6
+ * A progress stepper is a horizontal visual indicator that let’s the user know the progression of the current process.
7
+ *
8
+ * @name ProgressionStepper
9
+ */
10
+ function ProgressionStepper({ steps = [], currentStep: currentStepProp = 0, variant = 'horizontal', ...containerProps }) {
11
+ const currentStep = Math.max(0, Math.min(currentStepProp, steps.length + 1));
12
+ return (jsxs("div", { ...containerProps, css: style, "data-progress-stepper": "", "data-variant": variant, children: [variant === 'widget' && (jsxs("label", { children: [jsx("span", { "data-title": true, children: steps[Math.max(0, Math.min(currentStep - 1, steps.length - 1))].name }), jsx("span", { "data-subtitle": true, children: currentStep >= steps.length ? ('Completed') : (jsxs(Fragment, { children: ["Step ", currentStep, " of ", steps.length] })) })] })), jsx("ol", { children: steps.flatMap(({ name, subtext }, index) => {
13
+ const stepNum = index + 1;
14
+ let status = 'incomplete';
15
+ if (stepNum < currentStep)
16
+ status = 'complete';
17
+ else if (stepNum === currentStep)
18
+ status = 'current';
19
+ return (jsxs("li", { "data-status": status, "data-step": stepNum, children: [jsxs("span", { "aria-hidden": true, "data-line-circle": true, children: [jsx("span", { "data-line": "before" }), jsxs("span", { "data-circle": true, children: [jsx("span", { children: stepNum }), status === 'complete' && jsx(SvgCheck, {})] }), jsx("span", { "data-line": "after" })] }), variant !== 'widget' && (jsxs("span", { "data-content": true, children: [jsx("span", { "data-name": true, children: name }), subtext && jsx("span", { "data-subtext": true, children: subtext })] }))] }, `step-${index}`));
20
+ }) })] }));
21
+ }
22
+ ProgressionStepper.bspkName = 'ProgressionStepper';
23
+ const style = css `
24
+ width: 100%;
25
+ --circle-width: var(--spacing-sizing-09);
26
+
27
+ --active-background-color: var(--surface-brand-primary);
28
+ --active-foreground-color: var(--foreground-brand-on-primary);
29
+ --inactive-background-color: var(--surface-neutral-t3-low);
30
+ --inactive-foreground-color: var(--foreground-neutral-on-surface);
31
+
32
+ ol {
33
+ display: flex;
34
+ width: 100%;
35
+ margin: 0;
36
+ padding: 0;
37
+
38
+ li {
39
+ display: flex;
40
+ flex-direction: column;
41
+ list-style: none;
42
+ margin: 0;
43
+ padding: 0;
44
+ gap: var(--spacing-sizing-02);
45
+ [data-line-circle] {
46
+ display: flex;
47
+ justify-content: center;
48
+ align-items: center;
49
+ flex-direction: row;
50
+
51
+ [data-line] {
52
+ background-color: var(--inactive-background-color);
53
+ height: 2px;
54
+ flex-grow: 1;
55
+ }
56
+
57
+ [data-circle] {
58
+ display: flex;
59
+ justify-content: center;
60
+ align-items: center;
61
+ width: var(--circle-width);
62
+ height: var(--circle-width);
63
+ border-radius: 50%;
64
+ background-color: none;
65
+ border: 2px solid var(--inactive-background-color);
66
+ font: var(--labels-large);
67
+
68
+ svg {
69
+ display: none;
70
+ width: var(--spacing-sizing-06);
71
+ height: var(--spacing-sizing-06);
72
+ }
73
+ }
74
+ }
75
+
76
+ [data-content] {
77
+ display: flex;
78
+ padding: 0 var(--spacing-sizing-10);
79
+ font: var(--body-small);
80
+ }
81
+
82
+ &:first-of-type {
83
+ [data-line='before'] {
84
+ visibility: hidden;
85
+ }
86
+ }
87
+
88
+ &:last-of-type {
89
+ [data-line='after'] {
90
+ visibility: hidden;
91
+ }
92
+ }
93
+
94
+ &[data-status='complete'] {
95
+ [data-line] {
96
+ background-color: var(--active-background-color);
97
+ }
98
+ [data-circle] {
99
+ background-color: var(--active-background-color);
100
+ border: 1px solid var(--active-background-color);
101
+ color: var(--active-foreground-color);
102
+
103
+ span {
104
+ display: none;
105
+ }
106
+ svg {
107
+ display: block;
108
+ }
109
+ }
110
+ }
111
+
112
+ &[data-status='current'] {
113
+ [data-line='before'] {
114
+ background-color: var(--active-background-color);
115
+ }
116
+
117
+ [data-circle] {
118
+ border-color: var(--active-background-color);
119
+ }
120
+ }
121
+ }
122
+ }
123
+
124
+ &[data-variant='vertical'] {
125
+ ol {
126
+ flex-direction: column;
127
+ }
128
+
129
+ li {
130
+ flex-direction: row;
131
+
132
+ [data-line-circle] {
133
+ flex-direction: column;
134
+ width: var(--circle-width);
135
+
136
+ [data-line] {
137
+ width: 2px;
138
+ height: auto;
139
+ }
140
+ }
141
+ [data-content] {
142
+ flex-direction: column;
143
+ padding: var(--spacing-sizing-10) 0;
144
+ }
145
+ }
146
+ }
147
+
148
+ &[data-variant='widget'] {
149
+ --circle-width: var(--spacing-sizing-05);
150
+
151
+ label {
152
+ display: flex;
153
+ flex-direction: column;
154
+ gap: var(--spacing-sizing-02);
155
+ margin-bottom: var(--spacing-sizing-03);
156
+ font: var(--body-small);
157
+
158
+ [data-title] {
159
+ font: var(--labels-base);
160
+ color: var(--foreground-neutral-on-surface);
161
+ }
162
+
163
+ [data-subtitle] {
164
+ font: var(--body-x-small);
165
+ color: var(--foreground-neutral-on-surface-variant-02);
166
+ }
167
+ }
168
+
169
+ ol {
170
+ align-items: center;
171
+ min-height: var(--spacing-sizing-09);
172
+
173
+ li {
174
+ [data-line-circle] {
175
+ [data-line] {
176
+ width: 10px;
177
+ }
178
+ }
179
+
180
+ &[data-status='current'] {
181
+ --circle-width: var(--spacing-sizing-09);
182
+ }
183
+
184
+ &[data-status='incomplete'] {
185
+ [data-circle] {
186
+ span {
187
+ display: none;
188
+ }
189
+ }
190
+ }
191
+ }
192
+ }
193
+ }
194
+ `;
195
+
196
+ export { ProgressionStepper, style };
197
+ //# sourceMappingURL=ProgressionStepper.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ProgressionStepper.js","sources":["src/ProgressionStepper.tsx"],"sourcesContent":[null],"names":["_jsxs","_jsx","_Fragment"],"mappings":"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"}