@dxc-technology/halstack-react 0.0.0-b061aa1 → 0.0.0-b063530

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 (549) hide show
  1. package/BackgroundColorContext.d.ts +1 -0
  2. package/BackgroundColorContext.js +6 -26
  3. package/HalstackContext.d.ts +1280 -0
  4. package/HalstackContext.js +320 -0
  5. package/README.md +47 -0
  6. package/accordion/Accordion.accessibility.test.d.ts +1 -0
  7. package/accordion/Accordion.accessibility.test.js +71 -0
  8. package/accordion/Accordion.d.ts +1 -1
  9. package/accordion/Accordion.js +103 -193
  10. package/accordion/Accordion.stories.tsx +241 -0
  11. package/accordion/Accordion.test.d.ts +1 -0
  12. package/accordion/Accordion.test.js +56 -0
  13. package/accordion/types.d.ts +12 -23
  14. package/accordion-group/AccordionGroup.accessibility.test.d.ts +1 -0
  15. package/accordion-group/AccordionGroup.accessibility.test.js +82 -0
  16. package/accordion-group/AccordionGroup.d.ts +3 -3
  17. package/accordion-group/AccordionGroup.js +39 -108
  18. package/accordion-group/AccordionGroup.stories.tsx +95 -68
  19. package/accordion-group/AccordionGroup.test.d.ts +1 -0
  20. package/accordion-group/AccordionGroup.test.js +94 -0
  21. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  22. package/accordion-group/AccordionGroupAccordion.js +31 -0
  23. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  24. package/accordion-group/AccordionGroupContext.js +8 -0
  25. package/accordion-group/types.d.ts +18 -23
  26. package/action-icon/ActionIcon.accessibility.test.d.ts +1 -0
  27. package/action-icon/ActionIcon.accessibility.test.js +63 -0
  28. package/action-icon/ActionIcon.d.ts +4 -0
  29. package/action-icon/ActionIcon.js +48 -0
  30. package/action-icon/ActionIcon.stories.tsx +41 -0
  31. package/action-icon/ActionIcon.test.d.ts +1 -0
  32. package/action-icon/ActionIcon.test.js +64 -0
  33. package/action-icon/types.d.ts +26 -0
  34. package/alert/Alert.accessibility.test.d.ts +1 -0
  35. package/alert/Alert.accessibility.test.js +95 -0
  36. package/alert/Alert.js +41 -128
  37. package/alert/Alert.stories.tsx +28 -0
  38. package/alert/Alert.test.d.ts +1 -0
  39. package/alert/Alert.test.js +75 -0
  40. package/alert/types.d.ts +5 -5
  41. package/badge/Badge.accessibility.test.d.ts +1 -0
  42. package/badge/Badge.accessibility.test.js +129 -0
  43. package/badge/Badge.d.ts +4 -0
  44. package/badge/Badge.js +142 -40
  45. package/badge/Badge.stories.tsx +210 -0
  46. package/badge/Badge.test.d.ts +1 -0
  47. package/badge/Badge.test.js +30 -0
  48. package/badge/types.d.ts +54 -0
  49. package/bar-chart/BarChart.d.ts +4 -0
  50. package/bar-chart/BarChart.js +152 -0
  51. package/bar-chart/BarChart.stories.tsx +281 -0
  52. package/bar-chart/BarChart.test.d.ts +1 -0
  53. package/bar-chart/BarChart.test.js +194 -0
  54. package/bar-chart/theme.d.ts +3 -0
  55. package/bar-chart/theme.js +31 -0
  56. package/bar-chart/types.d.ts +118 -0
  57. package/bleed/Bleed.d.ts +3 -0
  58. package/bleed/Bleed.js +43 -0
  59. package/bleed/Bleed.stories.tsx +341 -0
  60. package/bleed/types.d.ts +37 -0
  61. package/bleed/types.js +5 -0
  62. package/box/Box.accessibility.test.d.ts +1 -0
  63. package/box/Box.accessibility.test.js +33 -0
  64. package/box/Box.d.ts +1 -1
  65. package/box/Box.js +31 -82
  66. package/box/Box.stories.tsx +38 -51
  67. package/box/Box.test.d.ts +1 -0
  68. package/box/Box.test.js +13 -0
  69. package/box/types.d.ts +3 -14
  70. package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
  71. package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
  72. package/breadcrumbs/Breadcrumbs.d.ts +4 -0
  73. package/breadcrumbs/Breadcrumbs.js +79 -0
  74. package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
  75. package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
  76. package/breadcrumbs/Breadcrumbs.test.js +168 -0
  77. package/breadcrumbs/Item.d.ts +4 -0
  78. package/breadcrumbs/Item.js +52 -0
  79. package/breadcrumbs/dropdownTheme.d.ts +53 -0
  80. package/breadcrumbs/dropdownTheme.js +62 -0
  81. package/breadcrumbs/types.d.ts +40 -0
  82. package/breadcrumbs/types.js +5 -0
  83. package/bulleted-list/BulletedList.accessibility.test.d.ts +1 -0
  84. package/bulleted-list/BulletedList.accessibility.test.js +119 -0
  85. package/bulleted-list/BulletedList.d.ts +7 -0
  86. package/bulleted-list/BulletedList.js +92 -0
  87. package/bulleted-list/BulletedList.stories.tsx +115 -0
  88. package/bulleted-list/types.d.ts +38 -0
  89. package/bulleted-list/types.js +5 -0
  90. package/button/Button.accessibility.test.d.ts +1 -0
  91. package/button/Button.accessibility.test.js +127 -0
  92. package/button/Button.d.ts +1 -1
  93. package/button/Button.js +65 -123
  94. package/button/Button.stories.tsx +155 -106
  95. package/button/Button.test.d.ts +1 -0
  96. package/button/Button.test.js +38 -0
  97. package/button/types.d.ts +12 -12
  98. package/card/Card.accessibility.test.d.ts +1 -0
  99. package/card/Card.accessibility.test.js +36 -0
  100. package/card/Card.d.ts +1 -1
  101. package/card/Card.js +60 -103
  102. package/card/Card.stories.tsx +14 -44
  103. package/card/Card.test.d.ts +1 -0
  104. package/card/Card.test.js +39 -0
  105. package/card/types.d.ts +6 -11
  106. package/checkbox/Checkbox.accessibility.test.d.ts +1 -0
  107. package/checkbox/Checkbox.accessibility.test.js +87 -0
  108. package/checkbox/Checkbox.d.ts +2 -2
  109. package/checkbox/Checkbox.js +141 -182
  110. package/checkbox/Checkbox.stories.tsx +166 -136
  111. package/checkbox/Checkbox.test.d.ts +1 -0
  112. package/checkbox/Checkbox.test.js +199 -0
  113. package/checkbox/types.d.ts +19 -7
  114. package/chip/Chip.accessibility.test.d.ts +1 -0
  115. package/chip/Chip.accessibility.test.js +67 -0
  116. package/chip/Chip.d.ts +1 -1
  117. package/chip/Chip.js +51 -124
  118. package/chip/Chip.stories.tsx +105 -31
  119. package/chip/Chip.test.d.ts +1 -0
  120. package/chip/Chip.test.js +41 -0
  121. package/chip/types.d.ts +10 -18
  122. package/common/coreTokens.d.ts +236 -0
  123. package/common/coreTokens.js +183 -0
  124. package/common/utils.d.ts +1 -0
  125. package/common/utils.js +6 -12
  126. package/common/variables.d.ts +1432 -0
  127. package/common/variables.js +1117 -1397
  128. package/container/Container.d.ts +4 -0
  129. package/container/Container.js +194 -0
  130. package/container/Container.stories.tsx +214 -0
  131. package/container/types.d.ts +176 -0
  132. package/container/types.js +5 -0
  133. package/contextual-menu/ContextualMenu.accessibility.test.d.ts +1 -0
  134. package/contextual-menu/ContextualMenu.accessibility.test.js +98 -0
  135. package/contextual-menu/ContextualMenu.d.ts +5 -0
  136. package/contextual-menu/ContextualMenu.js +136 -0
  137. package/contextual-menu/ContextualMenu.stories.tsx +231 -0
  138. package/contextual-menu/ContextualMenu.test.d.ts +1 -0
  139. package/contextual-menu/ContextualMenu.test.js +247 -0
  140. package/contextual-menu/GroupItem.d.ts +4 -0
  141. package/contextual-menu/GroupItem.js +67 -0
  142. package/contextual-menu/ItemAction.d.ts +4 -0
  143. package/contextual-menu/ItemAction.js +88 -0
  144. package/contextual-menu/MenuItem.d.ts +4 -0
  145. package/contextual-menu/MenuItem.js +29 -0
  146. package/contextual-menu/SingleItem.d.ts +4 -0
  147. package/contextual-menu/SingleItem.js +38 -0
  148. package/contextual-menu/types.d.ts +65 -0
  149. package/contextual-menu/types.js +5 -0
  150. package/date-input/Calendar.d.ts +4 -0
  151. package/date-input/Calendar.js +230 -0
  152. package/date-input/DateInput.accessibility.test.d.ts +1 -0
  153. package/date-input/DateInput.accessibility.test.js +229 -0
  154. package/date-input/DateInput.js +181 -314
  155. package/date-input/DateInput.stories.tsx +210 -57
  156. package/date-input/DateInput.test.d.ts +1 -0
  157. package/date-input/DateInput.test.js +808 -0
  158. package/date-input/DatePicker.d.ts +4 -0
  159. package/date-input/DatePicker.js +121 -0
  160. package/date-input/YearPicker.d.ts +4 -0
  161. package/date-input/YearPicker.js +105 -0
  162. package/date-input/types.d.ts +86 -22
  163. package/dialog/Dialog.accessibility.test.d.ts +1 -0
  164. package/dialog/Dialog.accessibility.test.js +69 -0
  165. package/dialog/Dialog.d.ts +1 -1
  166. package/dialog/Dialog.js +57 -129
  167. package/dialog/Dialog.stories.tsx +324 -167
  168. package/dialog/Dialog.test.d.ts +1 -0
  169. package/dialog/Dialog.test.js +370 -0
  170. package/dialog/types.d.ts +18 -25
  171. package/divider/Divider.accessibility.test.d.ts +1 -0
  172. package/divider/Divider.accessibility.test.js +33 -0
  173. package/divider/Divider.d.ts +4 -0
  174. package/divider/Divider.js +36 -0
  175. package/divider/Divider.stories.tsx +224 -0
  176. package/divider/Divider.test.d.ts +1 -0
  177. package/divider/Divider.test.js +38 -0
  178. package/divider/types.d.ts +21 -0
  179. package/divider/types.js +5 -0
  180. package/dropdown/Dropdown.accessibility.test.d.ts +1 -0
  181. package/dropdown/Dropdown.accessibility.test.js +183 -0
  182. package/dropdown/Dropdown.d.ts +1 -1
  183. package/dropdown/Dropdown.js +233 -330
  184. package/dropdown/Dropdown.stories.tsx +427 -0
  185. package/dropdown/Dropdown.test.d.ts +1 -0
  186. package/dropdown/Dropdown.test.js +628 -0
  187. package/dropdown/DropdownMenu.d.ts +4 -0
  188. package/dropdown/DropdownMenu.js +63 -0
  189. package/dropdown/DropdownMenuItem.d.ts +4 -0
  190. package/dropdown/DropdownMenuItem.js +71 -0
  191. package/dropdown/types.d.ts +37 -30
  192. package/file-input/FileInput.accessibility.test.d.ts +1 -0
  193. package/file-input/FileInput.accessibility.test.js +167 -0
  194. package/file-input/FileInput.d.ts +2 -2
  195. package/file-input/FileInput.js +264 -337
  196. package/file-input/FileInput.stories.tsx +618 -0
  197. package/file-input/FileInput.test.d.ts +1 -0
  198. package/file-input/FileInput.test.js +404 -0
  199. package/file-input/FileItem.d.ts +4 -14
  200. package/file-input/FileItem.js +63 -122
  201. package/file-input/types.d.ts +52 -14
  202. package/flex/Flex.d.ts +4 -0
  203. package/flex/Flex.js +57 -0
  204. package/flex/Flex.stories.tsx +112 -0
  205. package/flex/types.d.ts +97 -0
  206. package/flex/types.js +5 -0
  207. package/footer/Footer.accessibility.test.d.ts +1 -0
  208. package/footer/Footer.accessibility.test.js +125 -0
  209. package/footer/Footer.d.ts +1 -1
  210. package/footer/Footer.js +74 -200
  211. package/footer/{Footer.stories.jsx → Footer.stories.tsx} +96 -39
  212. package/footer/Footer.test.d.ts +1 -0
  213. package/footer/Footer.test.js +85 -0
  214. package/footer/Icons.d.ts +3 -0
  215. package/footer/Icons.js +54 -23
  216. package/footer/types.d.ts +26 -31
  217. package/grid/Grid.d.ts +7 -0
  218. package/grid/Grid.js +76 -0
  219. package/grid/Grid.stories.tsx +221 -0
  220. package/grid/types.d.ts +115 -0
  221. package/grid/types.js +5 -0
  222. package/header/Header.accessibility.test.d.ts +1 -0
  223. package/header/Header.accessibility.test.js +94 -0
  224. package/header/Header.d.ts +4 -3
  225. package/header/Header.js +105 -219
  226. package/header/Header.stories.tsx +169 -64
  227. package/header/Header.test.d.ts +1 -0
  228. package/header/Header.test.js +66 -0
  229. package/header/Icons.d.ts +2 -0
  230. package/header/Icons.js +5 -15
  231. package/header/types.d.ts +7 -21
  232. package/heading/Heading.accessibility.test.d.ts +1 -0
  233. package/heading/Heading.accessibility.test.js +33 -0
  234. package/heading/Heading.js +11 -33
  235. package/heading/Heading.stories.tsx +3 -2
  236. package/heading/Heading.test.d.ts +1 -0
  237. package/heading/Heading.test.js +156 -0
  238. package/heading/types.d.ts +7 -7
  239. package/icon/Icon.accessibility.test.d.ts +1 -0
  240. package/icon/Icon.accessibility.test.js +30 -0
  241. package/icon/Icon.d.ts +4 -0
  242. package/icon/Icon.js +33 -0
  243. package/icon/Icon.stories.tsx +28 -0
  244. package/icon/types.d.ts +4 -0
  245. package/icon/types.js +5 -0
  246. package/image/Image.accessibility.test.d.ts +1 -0
  247. package/image/Image.accessibility.test.js +56 -0
  248. package/image/Image.d.ts +4 -0
  249. package/image/Image.js +70 -0
  250. package/image/Image.stories.tsx +129 -0
  251. package/image/types.d.ts +72 -0
  252. package/image/types.js +5 -0
  253. package/inset/Inset.d.ts +3 -0
  254. package/inset/Inset.js +43 -0
  255. package/inset/Inset.stories.tsx +230 -0
  256. package/inset/types.d.ts +37 -0
  257. package/inset/types.js +5 -0
  258. package/layout/ApplicationLayout.d.ts +16 -6
  259. package/layout/ApplicationLayout.js +88 -175
  260. package/layout/ApplicationLayout.stories.tsx +162 -0
  261. package/layout/Icons.d.ts +7 -0
  262. package/layout/Icons.js +41 -48
  263. package/layout/types.d.ts +19 -35
  264. package/link/Link.accessibility.test.d.ts +1 -0
  265. package/link/Link.accessibility.test.js +108 -0
  266. package/link/Link.d.ts +3 -2
  267. package/link/Link.js +65 -109
  268. package/link/Link.stories.tsx +161 -54
  269. package/link/Link.test.d.ts +1 -0
  270. package/link/Link.test.js +63 -0
  271. package/link/types.d.ts +15 -35
  272. package/main.d.ts +21 -14
  273. package/main.js +106 -98
  274. package/nav-tabs/NavTabs.accessibility.test.d.ts +1 -0
  275. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  276. package/nav-tabs/NavTabs.d.ts +7 -0
  277. package/nav-tabs/NavTabs.js +108 -0
  278. package/nav-tabs/NavTabs.stories.tsx +294 -0
  279. package/nav-tabs/NavTabs.test.d.ts +1 -0
  280. package/nav-tabs/NavTabs.test.js +77 -0
  281. package/nav-tabs/NavTabsContext.d.ts +3 -0
  282. package/nav-tabs/NavTabsContext.js +8 -0
  283. package/nav-tabs/Tab.d.ts +4 -0
  284. package/nav-tabs/Tab.js +117 -0
  285. package/nav-tabs/types.d.ts +52 -0
  286. package/nav-tabs/types.js +5 -0
  287. package/number-input/NumberInput.accessibility.test.d.ts +1 -0
  288. package/number-input/NumberInput.accessibility.test.js +227 -0
  289. package/number-input/NumberInput.js +52 -49
  290. package/number-input/NumberInput.stories.tsx +39 -28
  291. package/number-input/NumberInput.test.d.ts +1 -0
  292. package/number-input/NumberInput.test.js +988 -0
  293. package/number-input/NumberInputContext.d.ts +3 -4
  294. package/number-input/NumberInputContext.js +3 -14
  295. package/number-input/types.d.ts +34 -15
  296. package/package.json +59 -52
  297. package/paginator/Paginator.accessibility.test.d.ts +1 -0
  298. package/paginator/Paginator.accessibility.test.js +78 -0
  299. package/paginator/Paginator.js +47 -107
  300. package/paginator/Paginator.stories.tsx +24 -0
  301. package/paginator/Paginator.test.d.ts +1 -0
  302. package/paginator/Paginator.test.js +334 -0
  303. package/paginator/types.d.ts +3 -3
  304. package/paragraph/Paragraph.accessibility.test.d.ts +1 -0
  305. package/paragraph/Paragraph.accessibility.test.js +28 -0
  306. package/paragraph/Paragraph.d.ts +5 -0
  307. package/paragraph/Paragraph.js +22 -0
  308. package/paragraph/Paragraph.stories.tsx +27 -0
  309. package/password-input/PasswordInput.accessibility.test.d.ts +1 -0
  310. package/password-input/PasswordInput.accessibility.test.js +152 -0
  311. package/password-input/PasswordInput.js +63 -127
  312. package/password-input/PasswordInput.stories.tsx +13 -36
  313. package/password-input/PasswordInput.test.d.ts +1 -0
  314. package/password-input/PasswordInput.test.js +197 -0
  315. package/password-input/types.d.ts +21 -17
  316. package/progress-bar/ProgressBar.accessibility.test.d.ts +1 -0
  317. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  318. package/progress-bar/ProgressBar.js +69 -93
  319. package/progress-bar/ProgressBar.stories.tsx +93 -0
  320. package/progress-bar/ProgressBar.test.d.ts +1 -0
  321. package/progress-bar/ProgressBar.test.js +93 -0
  322. package/progress-bar/types.d.ts +3 -3
  323. package/quick-nav/QuickNav.accessibility.test.d.ts +1 -0
  324. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  325. package/quick-nav/QuickNav.d.ts +4 -0
  326. package/quick-nav/QuickNav.js +94 -0
  327. package/quick-nav/QuickNav.stories.tsx +356 -0
  328. package/quick-nav/types.d.ts +21 -0
  329. package/quick-nav/types.js +5 -0
  330. package/radio-group/Radio.d.ts +4 -0
  331. package/radio-group/Radio.js +121 -0
  332. package/radio-group/RadioGroup.accessibility.test.d.ts +1 -0
  333. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  334. package/radio-group/RadioGroup.d.ts +4 -0
  335. package/radio-group/RadioGroup.js +233 -0
  336. package/radio-group/RadioGroup.stories.tsx +214 -0
  337. package/radio-group/RadioGroup.test.d.ts +1 -0
  338. package/radio-group/RadioGroup.test.js +754 -0
  339. package/radio-group/types.d.ts +114 -0
  340. package/radio-group/types.js +5 -0
  341. package/resultset-table/Icons.d.ts +7 -0
  342. package/resultset-table/Icons.js +47 -0
  343. package/resultset-table/ResultsetTable.accessibility.test.d.ts +1 -0
  344. package/resultset-table/ResultsetTable.accessibility.test.js +284 -0
  345. package/resultset-table/ResultsetTable.d.ts +7 -0
  346. package/resultset-table/ResultsetTable.js +195 -0
  347. package/resultset-table/ResultsetTable.stories.tsx +413 -0
  348. package/resultset-table/ResultsetTable.test.d.ts +1 -0
  349. package/resultset-table/ResultsetTable.test.js +450 -0
  350. package/{resultsetTable → resultset-table}/types.d.ts +45 -11
  351. package/resultset-table/types.js +5 -0
  352. package/select/Listbox.d.ts +4 -0
  353. package/select/Listbox.js +151 -0
  354. package/select/Option.d.ts +4 -0
  355. package/select/Option.js +89 -0
  356. package/select/Select.accessibility.test.d.ts +1 -0
  357. package/select/Select.accessibility.test.js +227 -0
  358. package/select/Select.d.ts +4 -0
  359. package/select/Select.js +251 -514
  360. package/select/Select.stories.tsx +611 -255
  361. package/select/Select.test.d.ts +1 -0
  362. package/select/Select.test.js +2168 -0
  363. package/select/types.d.ts +209 -0
  364. package/select/types.js +5 -0
  365. package/sidenav/Sidenav.accessibility.test.d.ts +1 -0
  366. package/sidenav/Sidenav.accessibility.test.js +59 -0
  367. package/sidenav/Sidenav.d.ts +6 -5
  368. package/sidenav/Sidenav.js +137 -72
  369. package/sidenav/Sidenav.stories.tsx +246 -134
  370. package/sidenav/Sidenav.test.d.ts +1 -0
  371. package/sidenav/Sidenav.test.js +37 -0
  372. package/sidenav/SidenavContext.d.ts +5 -0
  373. package/sidenav/SidenavContext.js +13 -0
  374. package/sidenav/types.d.ts +52 -26
  375. package/slider/Slider.accessibility.test.d.ts +1 -0
  376. package/slider/Slider.accessibility.test.js +103 -0
  377. package/slider/Slider.d.ts +2 -2
  378. package/slider/Slider.js +148 -182
  379. package/slider/Slider.stories.tsx +68 -65
  380. package/slider/Slider.test.d.ts +1 -0
  381. package/slider/Slider.test.js +256 -0
  382. package/slider/types.d.ts +11 -3
  383. package/spinner/Spinner.accessibility.test.d.ts +1 -0
  384. package/spinner/Spinner.accessibility.test.js +96 -0
  385. package/spinner/Spinner.d.ts +1 -1
  386. package/spinner/Spinner.js +51 -110
  387. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -26
  388. package/spinner/Spinner.test.d.ts +1 -0
  389. package/spinner/Spinner.test.js +55 -0
  390. package/spinner/types.d.ts +3 -3
  391. package/status-light/StatusLight.accessibility.test.d.ts +1 -0
  392. package/status-light/StatusLight.accessibility.test.js +157 -0
  393. package/status-light/StatusLight.d.ts +4 -0
  394. package/status-light/StatusLight.js +51 -0
  395. package/status-light/StatusLight.stories.tsx +74 -0
  396. package/status-light/StatusLight.test.d.ts +1 -0
  397. package/status-light/StatusLight.test.js +25 -0
  398. package/status-light/types.d.ts +17 -0
  399. package/status-light/types.js +5 -0
  400. package/switch/Switch.accessibility.test.d.ts +1 -0
  401. package/switch/Switch.accessibility.test.js +98 -0
  402. package/switch/Switch.d.ts +2 -2
  403. package/switch/Switch.js +147 -115
  404. package/switch/Switch.stories.tsx +57 -68
  405. package/switch/Switch.test.d.ts +1 -0
  406. package/switch/Switch.test.js +180 -0
  407. package/switch/types.d.ts +13 -5
  408. package/table/DropdownTheme.js +62 -0
  409. package/table/Table.accessibility.test.d.ts +1 -0
  410. package/table/Table.accessibility.test.js +92 -0
  411. package/table/Table.d.ts +6 -2
  412. package/table/Table.js +79 -36
  413. package/table/Table.stories.tsx +663 -0
  414. package/table/Table.test.d.ts +1 -0
  415. package/table/Table.test.js +111 -0
  416. package/table/types.d.ts +34 -6
  417. package/tabs/Tab.d.ts +4 -0
  418. package/tabs/Tab.js +117 -0
  419. package/tabs/Tabs.accessibility.test.d.ts +1 -0
  420. package/tabs/Tabs.accessibility.test.js +56 -0
  421. package/tabs/Tabs.d.ts +1 -1
  422. package/tabs/Tabs.js +307 -147
  423. package/tabs/Tabs.stories.tsx +127 -18
  424. package/tabs/Tabs.test.d.ts +1 -0
  425. package/tabs/Tabs.test.js +276 -0
  426. package/tabs/types.d.ts +46 -24
  427. package/tag/Tag.accessibility.test.d.ts +1 -0
  428. package/tag/Tag.accessibility.test.js +69 -0
  429. package/tag/Tag.d.ts +1 -1
  430. package/tag/Tag.js +44 -86
  431. package/tag/Tag.stories.tsx +38 -31
  432. package/tag/Tag.test.d.ts +1 -0
  433. package/tag/Tag.test.js +41 -0
  434. package/tag/types.d.ts +25 -16
  435. package/text-input/Suggestion.d.ts +4 -0
  436. package/text-input/Suggestion.js +67 -0
  437. package/text-input/Suggestions.d.ts +4 -0
  438. package/text-input/Suggestions.js +94 -0
  439. package/text-input/TextInput.accessibility.test.d.ts +1 -0
  440. package/text-input/TextInput.accessibility.test.js +320 -0
  441. package/text-input/TextInput.js +335 -552
  442. package/text-input/TextInput.stories.tsx +292 -271
  443. package/text-input/TextInput.test.d.ts +1 -0
  444. package/text-input/TextInput.test.js +1755 -0
  445. package/text-input/types.d.ts +71 -25
  446. package/textarea/Textarea.accessibility.test.d.ts +1 -0
  447. package/textarea/Textarea.accessibility.test.js +155 -0
  448. package/textarea/Textarea.d.ts +4 -0
  449. package/textarea/Textarea.js +92 -173
  450. package/textarea/Textarea.stories.tsx +174 -0
  451. package/textarea/Textarea.test.d.ts +1 -0
  452. package/textarea/Textarea.test.js +406 -0
  453. package/textarea/types.d.ts +141 -0
  454. package/textarea/types.js +5 -0
  455. package/toggle-group/ToggleGroup.accessibility.test.d.ts +1 -0
  456. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  457. package/toggle-group/ToggleGroup.d.ts +2 -2
  458. package/toggle-group/ToggleGroup.js +96 -114
  459. package/toggle-group/ToggleGroup.stories.tsx +80 -40
  460. package/toggle-group/ToggleGroup.test.d.ts +1 -0
  461. package/toggle-group/ToggleGroup.test.js +137 -0
  462. package/toggle-group/types.d.ts +67 -37
  463. package/tooltip/Tooltip.accessibility.test.d.ts +1 -0
  464. package/tooltip/Tooltip.accessibility.test.js +144 -0
  465. package/tooltip/Tooltip.d.ts +4 -0
  466. package/tooltip/Tooltip.js +50 -0
  467. package/tooltip/Tooltip.stories.tsx +111 -0
  468. package/tooltip/Tooltip.test.d.ts +1 -0
  469. package/tooltip/Tooltip.test.js +112 -0
  470. package/tooltip/types.d.ts +16 -0
  471. package/tooltip/types.js +5 -0
  472. package/typography/Typography.accessibility.test.d.ts +1 -0
  473. package/typography/Typography.accessibility.test.js +339 -0
  474. package/typography/Typography.d.ts +4 -0
  475. package/typography/Typography.js +23 -0
  476. package/typography/Typography.stories.tsx +196 -0
  477. package/typography/Typography.test.js +23 -0
  478. package/typography/types.d.ts +18 -0
  479. package/typography/types.js +5 -0
  480. package/useTheme.d.ts +1168 -0
  481. package/useTheme.js +4 -11
  482. package/useTranslatedLabels.d.ts +96 -0
  483. package/useTranslatedLabels.js +14 -0
  484. package/utils/BaseTypography.d.ts +21 -0
  485. package/utils/BaseTypography.js +98 -0
  486. package/utils/FocusLock.d.ts +13 -0
  487. package/utils/FocusLock.js +125 -0
  488. package/wizard/Wizard.accessibility.test.d.ts +1 -0
  489. package/wizard/Wizard.accessibility.test.js +55 -0
  490. package/wizard/Wizard.d.ts +1 -1
  491. package/wizard/Wizard.js +122 -114
  492. package/wizard/{Wizard.stories.jsx → Wizard.stories.tsx} +68 -20
  493. package/wizard/Wizard.test.d.ts +1 -0
  494. package/wizard/Wizard.test.js +114 -0
  495. package/wizard/types.d.ts +15 -15
  496. package/ThemeContext.js +0 -246
  497. package/V3Select/V3Select.js +0 -455
  498. package/V3Select/index.d.ts +0 -27
  499. package/V3Textarea/V3Textarea.js +0 -260
  500. package/V3Textarea/index.d.ts +0 -27
  501. package/card/ice-cream.jpg +0 -0
  502. package/common/OpenSans.css +0 -81
  503. package/common/RequiredComponent.js +0 -32
  504. package/common/fonts/OpenSans-Bold.ttf +0 -0
  505. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  506. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  507. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  508. package/common/fonts/OpenSans-Italic.ttf +0 -0
  509. package/common/fonts/OpenSans-Light.ttf +0 -0
  510. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  511. package/common/fonts/OpenSans-Regular.ttf +0 -0
  512. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  513. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  514. package/date/Date.js +0 -373
  515. package/date/index.d.ts +0 -27
  516. package/input-text/Icons.js +0 -22
  517. package/input-text/InputText.js +0 -611
  518. package/input-text/index.d.ts +0 -36
  519. package/number-input/numberInputContextTypes.d.ts +0 -19
  520. package/paginator/Icons.js +0 -66
  521. package/progress-bar/ProgressBar.stories.jsx +0 -58
  522. package/radio/Radio.d.ts +0 -4
  523. package/radio/Radio.js +0 -174
  524. package/radio/Radio.stories.tsx +0 -192
  525. package/radio/types.d.ts +0 -54
  526. package/resultsetTable/ResultsetTable.d.ts +0 -4
  527. package/resultsetTable/ResultsetTable.js +0 -251
  528. package/select/index.d.ts +0 -131
  529. package/table/Table.stories.jsx +0 -276
  530. package/textarea/Textarea.stories.jsx +0 -135
  531. package/textarea/index.d.ts +0 -127
  532. package/toggle/Toggle.js +0 -186
  533. package/toggle/index.d.ts +0 -21
  534. package/upload/Upload.js +0 -201
  535. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  536. package/upload/buttons-upload/Icons.js +0 -40
  537. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  538. package/upload/dragAndDropArea/Icons.js +0 -39
  539. package/upload/file-upload/FileToUpload.js +0 -115
  540. package/upload/file-upload/Icons.js +0 -66
  541. package/upload/files-upload/FilesToUpload.js +0 -109
  542. package/upload/index.d.ts +0 -15
  543. package/upload/transaction/Icons.js +0 -160
  544. package/upload/transaction/Transaction.js +0 -104
  545. package/upload/transactions/Transactions.js +0 -94
  546. package/wizard/Icons.js +0 -65
  547. /package/{radio → action-icon}/types.js +0 -0
  548. /package/{resultsetTable → badge}/types.js +0 -0
  549. /package/{number-input/numberInputContextTypes.js → bar-chart/types.js} +0 -0
@@ -1,17 +1,31 @@
1
1
  import React from "react";
2
-
3
- import { userEvent, within, waitFor } from "@storybook/testing-library";
4
- import { fireEvent } from "@testing-library/react";
5
-
2
+ import { userEvent, within } from "@storybook/test";
6
3
  import Title from "../../.storybook/components/Title";
7
4
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
8
-
9
5
  import DxcSelect from "./Select";
6
+ import Listbox from "./Listbox";
7
+ import { ThemeProvider } from "styled-components";
8
+ import useTheme from "../useTheme";
9
+ import { HalstackProvider } from "../HalstackContext";
10
+ import { disabledRules } from "../../test/accessibility/rules/specific/select/disabledRules";
11
+ import preview from "../../.storybook/preview";
12
+ import DxcFlex from "../flex/Flex";
10
13
 
11
14
  export default {
12
15
  title: "Select",
13
16
  component: DxcSelect,
17
+ parameters: {
18
+ a11y: {
19
+ config: {
20
+ rules: [
21
+ ...disabledRules.map((ruleId) => ({ id: ruleId, reviewOnFail: true })),
22
+ ...preview?.parameters?.a11y?.config?.rules,
23
+ ],
24
+ },
25
+ },
26
+ },
14
27
  };
28
+
15
29
  const one_option = [{ label: "Option 01", value: "1" }];
16
30
 
17
31
  const single_options = [
@@ -20,6 +34,7 @@ const single_options = [
20
34
  { label: "Option 03", value: "3" },
21
35
  { label: "Option 04", value: "4" },
22
36
  ];
37
+
23
38
  const group_options = [
24
39
  {
25
40
  label: "Group 001",
@@ -62,25 +77,15 @@ const group_options = [
62
77
  ],
63
78
  },
64
79
  ];
65
- const icon_options_grouped = [
80
+
81
+ const icon_options_grouped_material = [
66
82
  {
67
83
  label: "Group 001",
68
84
  options: [
69
85
  {
70
86
  label: "3G Mobile",
71
87
  value: "1",
72
- icon: (
73
- <svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">
74
- <g>
75
- <path d="M0,0h24v24H0V0z" fill="none" />
76
- </g>
77
- <g>
78
- <g>
79
- <path d="M3,7v2h5v2H4v2h4v2H3v2h5c1.1,0,2-0.9,2-2v-1.5c0-0.83-0.67-1.5-1.5-1.5c0.83,0,1.5-0.67,1.5-1.5V9c0-1.1-0.9-2-2-2H3z M21,11v4c0,1.1-0.9,2-2,2h-5c-1.1,0-2-0.9-2-2V9c0-1.1,0.9-2,2-2h5c1.1,0,2,0.9,2,2h-7v6h5v-2h-2.5v-2H21z" />
80
- </g>
81
- </g>
82
- </svg>
83
- ),
88
+ icon: "3g_mobiledata",
84
89
  },
85
90
  ],
86
91
  },
@@ -90,12 +95,7 @@ const icon_options_grouped = [
90
95
  {
91
96
  label: "Ethernet",
92
97
  value: "2",
93
- icon: (
94
- <svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">
95
- <path d="M0 0h24v24H0V0z" fill="none" />
96
- <path d="M7.77 6.76L6.23 5.48.82 12l5.41 6.52 1.54-1.28L3.42 12l4.35-5.24zM7 13h2v-2H7v2zm10-2h-2v2h2v-2zm-6 2h2v-2h-2v2zm6.77-7.52l-1.54 1.28L20.58 12l-4.35 5.24 1.54 1.28L23.18 12l-5.41-6.52z" />
97
- </svg>
98
- ),
98
+ icon: "settings_ethernet",
99
99
  },
100
100
  ],
101
101
  },
@@ -105,26 +105,17 @@ const icon_options_grouped = [
105
105
  {
106
106
  label: "Wi-fi",
107
107
  value: "3",
108
- icon: (
109
- <svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">
110
- <path d="M0 0h24v24H0V0zm0 0h24v24H0V0z" fill="none" />
111
- <path d="M1 9l2 2c4.97-4.97 13.03-4.97 18 0l2-2C16.93 2.93 7.08 2.93 1 9zm8 8l3 3 3-3c-1.65-1.66-4.34-1.66-6 0zm-4-4l2 2c2.76-2.76 7.24-2.76 10 0l2-2C15.14 9.14 8.87 9.14 5 13z" />
112
- </svg>
113
- ),
108
+ icon: "wifi",
114
109
  },
115
110
  {
116
111
  label: "Settings backup restore (just for previous configuration)",
117
112
  value: "4",
118
- icon: (
119
- <svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">
120
- <path d="M0 0h24v24H0V0z" fill="none" />
121
- <path d="M14 12c0-1.1-.9-2-2-2s-2 .9-2 2 .9 2 2 2 2-.9 2-2zm-2-9c-4.97 0-9 4.03-9 9H0l4 4 4-4H5c0-3.87 3.13-7 7-7s7 3.13 7 7-3.13 7-7 7c-1.51 0-2.91-.49-4.06-1.3l-1.42 1.44C8.04 20.3 9.94 21 12 21c4.97 0 9-4.03 9-9s-4.03-9-9-9z" />
122
- </svg>
123
- ),
113
+ icon: "settings_backup_restore",
124
114
  },
125
115
  ],
126
116
  },
127
117
  ];
118
+
128
119
  const icon_options = [
129
120
  {
130
121
  label: "3G Mobile",
@@ -173,61 +164,73 @@ const icon_options = [
173
164
  ),
174
165
  },
175
166
  ];
176
- const url_options = [
167
+
168
+ const options_material = [
177
169
  {
178
- label: "Social Media",
170
+ label: "Transport",
179
171
  options: [
180
172
  {
181
- label: "Instagram",
182
- value: "instagram",
183
- icon: "https://upload.wikimedia.org/wikipedia/commons/thumb/e/e7/Instagram_logo_2016.svg/800px-Instagram_logo_2016.svg.png",
173
+ label: "Electric Car",
174
+ value: "car",
175
+ icon: "electric_car",
184
176
  },
185
177
  {
186
- label: "Twitter",
187
- value: "twitter",
188
- icon: "https://cdn.computerhoy.com/sites/navi.axelspringer.es/public/styles/480/public/media/image/2013/08/17981-logo-twitter.png?itok=dElA6iAV",
178
+ label: "Motorcycle",
179
+ value: "motorcycle",
180
+ icon: "Motorcycle",
189
181
  },
190
182
  {
191
- label: "Facebook",
192
- value: "facebook",
193
- icon: "https://upload.wikimedia.org/wikipedia/commons/thumb/b/b8/2021_Facebook_icon.svg/2048px-2021_Facebook_icon.svg.png",
183
+ label: "Train",
184
+ value: "train",
185
+ icon: "train",
194
186
  },
195
187
  {
196
- label: "Pinterest",
197
- value: "pinterest",
198
- icon: "https://cdn-icons-png.flaticon.com/512/145/145808.png",
188
+ label: "Bike",
189
+ value: "bike",
190
+ icon: "pedal_bike",
199
191
  },
200
192
  ],
201
193
  },
202
194
  {
203
- label: "Design",
195
+ label: "Entertainment",
204
196
  options: [
205
197
  {
206
- label: "Figma",
207
- value: "figma",
208
- icon: "https://logowik.com/content/uploads/images/figma.jpg",
198
+ label: "Movie",
199
+ value: "movie",
200
+ icon: "movie",
209
201
  },
210
202
  {
211
- label: "Adobe XD",
212
- value: "adobexd",
213
- icon: "https://cdn.worldvectorlogo.com/logos/adobe-xd-2.svg",
203
+ label: "Music",
204
+ value: "music",
205
+ icon: "music_note",
214
206
  },
215
207
  {
216
- label: "Sketch",
217
- value: "sketch",
218
- icon: "https://cdn.worldvectorlogo.com/logos/sketch-2.svg",
208
+ label: "Games",
209
+ value: "games",
210
+ icon: "joystick",
219
211
  },
220
212
  ],
221
213
  },
222
214
  ];
215
+
223
216
  const optionsWithEllipsisMedium = [
224
217
  { label: "Optiond1234567890123456789012345678901234", value: "1" },
225
218
  { label: "Optiond12345678901234567890123456789012345", value: "2" },
226
219
  { label: "Option 031111111111111111111111111111222", value: "3" },
227
- { label: "Option 03111111111111111111111111111122", value: "4" },
228
220
  ];
221
+
222
+ const opinionatedTheme = {
223
+ select: {
224
+ selectedOptionBackgroundColor: "#e6f4ff",
225
+ fontColor: "#000000",
226
+ optionFontColor: "#000000",
227
+ hoverBorderColor: "#a46ede",
228
+ },
229
+ };
230
+
229
231
  const Select = () => (
230
232
  <>
233
+ <Title title="States" theme="light" level={2} />
231
234
  <ExampleContainer pseudoState="pseudo-hover">
232
235
  <Title title="Hovered" theme="light" level={4} />
233
236
  <DxcSelect label="Hovered" options={single_options} />
@@ -242,126 +245,492 @@ const Select = () => (
242
245
  </ExampleContainer>
243
246
  <ExampleContainer>
244
247
  <Title title="Disabled with value" theme="light" level={4} />
245
- <DxcSelect label="Disabled with value" disabled options={single_options} value="1" />
248
+ <DxcSelect label="Disabled with value" disabled options={single_options} defaultValue="1" />
246
249
  </ExampleContainer>
247
250
  <ExampleContainer>
248
- <Title title="With label" theme="light" level={4} />
249
- <DxcSelect label="Label" options={single_options} />
250
- <Title title="Label and placeholder" theme="light" level={4} />
251
- <DxcSelect label="Label" options={single_options} placeholder="Placeholder" />
252
- <Title title="Label, placeholder and helper text" theme="light" level={4} />
253
- <DxcSelect label="Label" options={single_options} helperText="Helper text" placeholder="Placeholder" />
254
251
  <Title title="Error" theme="light" level={4} />
255
252
  <DxcSelect
256
253
  label="Label"
257
254
  options={single_options}
258
- error="Error message"
255
+ error="Error message."
259
256
  helperText="Helper text"
260
257
  placeholder="Placeholder"
261
258
  />
259
+ </ExampleContainer>
260
+ <ExampleContainer pseudoState="pseudo-hover">
261
+ <Title title="Hovered error" theme="light" level={4} />
262
+ <DxcSelect
263
+ label="Label"
264
+ options={single_options}
265
+ error="Error message."
266
+ helperText="Helper text"
267
+ placeholder="Placeholder"
268
+ />
269
+ </ExampleContainer>
270
+ <Title title="Anatomy" theme="light" level={2} />
271
+ <ExampleContainer>
272
+ <Title title="Label, placeholder and helper text" theme="light" level={4} />
273
+ <DxcSelect label="Label" options={single_options} helperText="Helper text" placeholder="Placeholder" />
274
+ </ExampleContainer>
275
+ <Title title="Variants" theme="light" level={2} />
276
+ <ExampleContainer>
262
277
  <Title title="Simple selection" theme="light" level={4} />
263
- <DxcSelect label="Simple selection" searchable options={single_options} value="2" />
278
+ <DxcSelect label="Simple selection" searchable options={single_options} defaultValue="2" />
279
+ </ExampleContainer>
280
+ <ExampleContainer>
264
281
  <Title title="Multiple selection" theme="light" level={4} />
265
- <DxcSelect label="Multiple select" searchable options={single_options} multiple value={["1", "2"]} />
282
+ <DxcSelect label="Multiple select" searchable options={single_options} multiple defaultValue={["1", "2"]} />
266
283
  </ExampleContainer>
267
-
268
284
  <ExampleContainer pseudoState="pseudo-hover">
269
285
  <Title title="Multiple clear hovered" theme="light" level={4} />
270
- <DxcSelect label="Multiple select" options={single_options} multiple value={["1", "2"]} />
286
+ <DxcSelect label="Multiple select" options={single_options} multiple defaultValue={["1", "2"]} />
271
287
  </ExampleContainer>
272
-
273
288
  <ExampleContainer pseudoState="pseudo-active">
274
289
  <Title title="Multiple clear actived" theme="light" level={4} />
275
- <DxcSelect label="Multiple select" options={single_options} multiple value={["1", "2"]} />
290
+ <DxcSelect label="Multiple select" options={single_options} multiple defaultValue={["1", "2"]} />
291
+ </ExampleContainer>
292
+ <Title title="Sizes" theme="light" level={2} />
293
+ <ExampleContainer>
294
+ <Title title="Small size" theme="light" level={4} />
295
+ <DxcSelect label="Small" options={single_options} size="small" />
296
+ </ExampleContainer>
297
+ <ExampleContainer>
298
+ <Title title="Medium size" theme="light" level={4} />
299
+ <DxcSelect label="Medium" options={single_options} size="medium" />
300
+ </ExampleContainer>
301
+ <ExampleContainer>
302
+ <Title title="Large size" theme="light" level={4} />
303
+ <DxcSelect label="Large" options={single_options} size="large" />
304
+ </ExampleContainer>
305
+ <ExampleContainer>
306
+ <Title title="Fillparent size" theme="light" level={4} />
307
+ <DxcSelect label="Fillparent" options={single_options} size="fillParent" />
308
+ </ExampleContainer>
309
+ <ExampleContainer>
310
+ <Title title="Different sizes inside a flex" theme="light" level={4} />
311
+ <DxcFlex justifyContent="space-between" gap="1rem">
312
+ <DxcSelect label="fillParent" size="fillParent" options={single_options} />
313
+ <DxcSelect label="medium" size="medium" options={single_options} />
314
+ <DxcSelect label="large" size="large" options={single_options} />
315
+ </DxcFlex>
316
+ </ExampleContainer>
317
+ <Title title="Margins" theme="light" level={2} />
318
+ <ExampleContainer>
319
+ <Title title="xxsmall margin" theme="light" level={4} />
320
+ <DxcSelect label="xxSmall" options={single_options} margin="xxsmall" />
321
+ </ExampleContainer>
322
+ <ExampleContainer>
323
+ <Title title="xsmall margin" theme="light" level={4} />
324
+ <DxcSelect label="xSmall" options={single_options} margin="xsmall" />
325
+ </ExampleContainer>
326
+ <ExampleContainer>
327
+ <Title title="small margin" theme="light" level={4} />
328
+ <DxcSelect label="Small" options={single_options} margin="small" />
329
+ </ExampleContainer>
330
+ <ExampleContainer>
331
+ <Title title="medium margin" theme="light" level={4} />
332
+ <DxcSelect label="Medium" options={single_options} margin="medium" />
333
+ </ExampleContainer>
334
+ <ExampleContainer>
335
+ <Title title="large margin" theme="light" level={4} />
336
+ <DxcSelect label="Large" options={single_options} margin="large" />
337
+ </ExampleContainer>
338
+ <ExampleContainer>
339
+ <Title title="xlarge margin" theme="light" level={4} />
340
+ <DxcSelect label="xLarge" options={single_options} margin="xlarge" />
341
+ </ExampleContainer>
342
+ <ExampleContainer>
343
+ <Title title="xxlarge margin" theme="light" level={4} />
344
+ <DxcSelect label="xxLarge" options={single_options} margin="xxlarge" />
276
345
  </ExampleContainer>
277
- <>
278
- <Title title="Sizes" theme="light" level={2} />
279
- <ExampleContainer>
280
- <Title title="Small size" theme="light" level={4} />
281
- <DxcSelect label="Small" options={single_options} size="small" />
282
- </ExampleContainer>
283
- <ExampleContainer>
284
- <Title title="Medium size" theme="light" level={4} />
285
- <DxcSelect label="Medium" options={single_options} size="medium" />
286
- </ExampleContainer>
287
- <ExampleContainer>
288
- <Title title="Large size" theme="light" level={4} />
289
- <DxcSelect label="Large" options={single_options} size="large" />
290
- </ExampleContainer>
291
- <ExampleContainer>
292
- <Title title="Fillparent size" theme="light" level={4} />
293
- <DxcSelect label="Fillparent" options={single_options} size="fillParent" />
294
- </ExampleContainer>
295
- </>
296
- <>
297
- <Title title="Margins" theme="light" level={2} />
298
- <ExampleContainer>
299
- <Title title="xxsmall margin" theme="light" level={4} />
300
- <DxcSelect label="xxSmall" options={single_options} margin="xxsmall" />
301
- </ExampleContainer>
302
- <ExampleContainer>
303
- <Title title="xsmall margin" theme="light" level={4} />
304
- <DxcSelect label="xSmall" options={single_options} margin="xsmall" />
305
- </ExampleContainer>
306
- <ExampleContainer>
307
- <Title title="small margin" theme="light" level={4} />
308
- <DxcSelect label="Small" options={single_options} margin="small" />
309
- </ExampleContainer>
310
- <ExampleContainer>
311
- <Title title="medium margin" theme="light" level={4} />
312
- <DxcSelect label="Medium" options={single_options} margin="medium" />
313
- </ExampleContainer>
314
- <ExampleContainer>
315
- <Title title="large margin" theme="light" level={4} />
316
- <DxcSelect label="Large" options={single_options} margin="large" />
317
- </ExampleContainer>
318
- <ExampleContainer>
319
- <Title title="xlarge margin" theme="light" level={4} />
320
- <DxcSelect label="xLarge" options={single_options} margin="xlarge" />
321
- </ExampleContainer>
322
- <ExampleContainer>
323
- <Title title="xxlarge margin" theme="light" level={4} />
324
- <DxcSelect label="xxLarge" options={single_options} margin="xxlarge" />
325
- </ExampleContainer>
326
- </>
327
346
  <ExampleContainer expanded>
328
347
  <Title title="Ellipsis" theme="light" level={2} />
329
348
  <Title title="Multiple selection with ellipsis" theme="light" level={4} />
330
- <DxcSelect label="Label" options={single_options} multiple value={["1", "2", "3", "4"]} />
349
+ <DxcSelect label="Label" options={single_options} multiple defaultValue={["1", "2", "3", "4"]} />
331
350
  <Title title="Value with ellipsis" theme="light" level={4} />
332
- <DxcSelect label="Label" options={optionsWithEllipsisMedium} value="1" size="medium" />
333
- <Title title="Option with ellipsis" theme="light" level={4} />
351
+ <DxcSelect label="Label" options={optionsWithEllipsisMedium} defaultValue="1" />
352
+ <Title title="Options with ellipsis" theme="light" level={4} />
334
353
  <DxcSelect
335
354
  label="Label"
336
355
  placeholder="Choose an option"
337
- value="1"
356
+ defaultValue="1"
338
357
  options={optionsWithEllipsisMedium}
339
- size="medium"
358
+ margin={{ top: "xxlarge" }}
340
359
  />
341
360
  </ExampleContainer>
361
+ <Title title="Opinionated theme" theme="light" level={2} />
362
+ <ExampleContainer pseudoState="pseudo-hover">
363
+ <Title title="Hovered" theme="light" level={4} />
364
+ <HalstackProvider theme={opinionatedTheme}>
365
+ <DxcSelect label="Hovered" options={single_options} />
366
+ </HalstackProvider>
367
+ </ExampleContainer>
368
+ <ExampleContainer pseudoState="pseudo-focus-within">
369
+ <Title title="Focused" theme="light" level={4} />
370
+ <HalstackProvider theme={opinionatedTheme}>
371
+ <DxcSelect label="Focused" options={single_options} />
372
+ </HalstackProvider>
373
+ </ExampleContainer>
374
+ <ExampleContainer>
375
+ <Title title="Disabled" theme="light" level={4} />
376
+ <HalstackProvider theme={opinionatedTheme}>
377
+ <DxcSelect label="Disabled" placeholder="Placeholder" disabled options={single_options} />
378
+ </HalstackProvider>
379
+ </ExampleContainer>
380
+ <ExampleContainer>
381
+ <Title title="Disabled with value" theme="light" level={4} />
382
+ <HalstackProvider theme={opinionatedTheme}>
383
+ <DxcSelect label="Disabled with value" disabled options={single_options} defaultValue="1" />
384
+ </HalstackProvider>
385
+ </ExampleContainer>
386
+ <ExampleContainer>
387
+ <Title title="Error" theme="light" level={4} />
388
+ <HalstackProvider theme={opinionatedTheme}>
389
+ <DxcSelect
390
+ label="Label"
391
+ options={single_options}
392
+ error="Error message."
393
+ helperText="Helper text"
394
+ placeholder="Placeholder"
395
+ />
396
+ <ExampleContainer>
397
+ <Title title="Multiple selection" theme="light" level={4} />
398
+ <DxcSelect label="Multiple select" searchable options={single_options} multiple defaultValue={["1", "2"]} />
399
+ </ExampleContainer>
400
+ <ExampleContainer pseudoState="pseudo-hover">
401
+ <Title title="Multiple clear hovered" theme="light" level={4} />
402
+ <DxcSelect label="Multiple select" options={single_options} multiple defaultValue={["1", "2"]} />
403
+ </ExampleContainer>
404
+ <ExampleContainer pseudoState="pseudo-active">
405
+ <Title title="Multiple clear actived" theme="light" level={4} />
406
+ <DxcSelect label="Multiple select" options={single_options} multiple defaultValue={["1", "2"]} />
407
+ </ExampleContainer>
408
+ </HalstackProvider>
409
+ </ExampleContainer>
342
410
  </>
343
411
  );
344
- export const Chromatic = Select.bind({});
345
- Chromatic.play = async ({ canvasElement }) => {
346
- const canvas = within(canvasElement);
347
- await userEvent.click(canvas.getAllByRole("combobox")[25]);
412
+
413
+ const SelectListbox = () => {
414
+ const colorsTheme = useTheme();
415
+
416
+ return (
417
+ <>
418
+ <ThemeProvider theme={colorsTheme.select}>
419
+ <Title title="Listbox" theme="light" level={2} />
420
+ <ExampleContainer>
421
+ <Title
422
+ title="List dialog uses a Radix Popover to appear over elements with a certain z-index"
423
+ theme="light"
424
+ level={3}
425
+ />
426
+ <div
427
+ style={{
428
+ position: "relative",
429
+ display: "flex",
430
+ flexDirection: "column",
431
+ gap: "20px",
432
+ height: "150px",
433
+ width: "min-content",
434
+ marginBottom: "100px",
435
+ padding: "20px",
436
+ border: "1px solid black",
437
+ borderRadius: "4px",
438
+ overflow: "auto",
439
+ zIndex: "1300",
440
+ }}
441
+ >
442
+ <DxcSelect label="Label" options={single_options} optional placeholder="Choose an option" />
443
+ <button style={{ zIndex: "1", width: "100px" }}>Submit</button>
444
+ </div>
445
+ </ExampleContainer>
446
+ <Title title="Listbox option states" theme="light" level={3} />
447
+ <ExampleContainer pseudoState="pseudo-hover">
448
+ <Title title="Hovered option" theme="light" level={4} />
449
+ <Listbox
450
+ id="x8"
451
+ currentValue=""
452
+ options={one_option}
453
+ visualFocusIndex={-1}
454
+ lastOptionIndex={0}
455
+ multiple={false}
456
+ optional={false}
457
+ optionalItem={{ label: "Empty", value: "" }}
458
+ searchable={false}
459
+ handleOptionOnClick={() => {}}
460
+ styles={{ width: 360 }}
461
+ />
462
+ </ExampleContainer>
463
+ <ExampleContainer pseudoState="pseudo-active">
464
+ <Title title="Active option" theme="light" level={4} />
465
+ <Listbox
466
+ id="x9"
467
+ currentValue=""
468
+ options={one_option}
469
+ visualFocusIndex={-1}
470
+ lastOptionIndex={0}
471
+ multiple={false}
472
+ optional={false}
473
+ optionalItem={{ label: "Empty", value: "" }}
474
+ searchable={false}
475
+ handleOptionOnClick={() => {}}
476
+ styles={{ width: 360 }}
477
+ />
478
+ </ExampleContainer>
479
+ <ExampleContainer>
480
+ <Title title="Focused option" theme="light" level={4} />
481
+ <Listbox
482
+ id="x10"
483
+ currentValue=""
484
+ options={one_option}
485
+ visualFocusIndex={0}
486
+ lastOptionIndex={0}
487
+ multiple={false}
488
+ optional={false}
489
+ optionalItem={{ label: "Empty", value: "" }}
490
+ searchable={false}
491
+ handleOptionOnClick={() => {}}
492
+ styles={{ width: 360 }}
493
+ />
494
+ </ExampleContainer>
495
+ <ExampleContainer pseudoState="pseudo-hover">
496
+ <Title title="Hovered selected option" theme="light" level={4} />
497
+ <Listbox
498
+ id="x11"
499
+ currentValue="1"
500
+ options={single_options}
501
+ visualFocusIndex={-1}
502
+ lastOptionIndex={3}
503
+ multiple={false}
504
+ optional={false}
505
+ optionalItem={{ label: "Empty", value: "" }}
506
+ searchable={false}
507
+ handleOptionOnClick={() => {}}
508
+ styles={{ width: 360 }}
509
+ />
510
+ </ExampleContainer>
511
+ <ExampleContainer pseudoState="pseudo-active">
512
+ <Title title="Active selected option" theme="light" level={4} />
513
+ <Listbox
514
+ id="x12"
515
+ currentValue="2"
516
+ options={single_options}
517
+ visualFocusIndex={0}
518
+ lastOptionIndex={3}
519
+ multiple={false}
520
+ optional={false}
521
+ optionalItem={{ label: "Empty", value: "" }}
522
+ searchable={false}
523
+ handleOptionOnClick={() => {}}
524
+ styles={{ width: 360 }}
525
+ />
526
+ </ExampleContainer>
527
+ <Title title="Listbox with icons" theme="light" level={3} />
528
+ <ExampleContainer>
529
+ <Title title="Icons (SVGs)" theme="light" level={4} />
530
+ <Listbox
531
+ id="x13"
532
+ currentValue="3"
533
+ options={icon_options}
534
+ visualFocusIndex={-1}
535
+ lastOptionIndex={3}
536
+ multiple={false}
537
+ optional={false}
538
+ optionalItem={{ label: "Empty", value: "" }}
539
+ searchable={false}
540
+ handleOptionOnClick={() => {}}
541
+ styles={{ width: 360 }}
542
+ />
543
+ </ExampleContainer>
544
+ <ExampleContainer>
545
+ <Title title="Grouped icons (Material Symbols)" theme="light" level={4} />
546
+ <Listbox
547
+ id="x14"
548
+ currentValue={["0", "3"]}
549
+ options={icon_options_grouped_material}
550
+ visualFocusIndex={-1}
551
+ lastOptionIndex={3}
552
+ multiple={false}
553
+ optional={false}
554
+ optionalItem={{ label: "Empty", value: "" }}
555
+ searchable={false}
556
+ handleOptionOnClick={() => {}}
557
+ styles={{ width: 360 }}
558
+ />
559
+ </ExampleContainer>
560
+ <ExampleContainer>
561
+ <Title title="Grouped icons (Material)" theme="light" level={4} />
562
+ <Listbox
563
+ id="x15"
564
+ currentValue={["facebook", "figma"]}
565
+ options={options_material}
566
+ visualFocusIndex={-1}
567
+ lastOptionIndex={6}
568
+ multiple={true}
569
+ optional={false}
570
+ optionalItem={{ label: "Empty", value: "" }}
571
+ searchable={false}
572
+ handleOptionOnClick={() => {}}
573
+ styles={{ width: 360 }}
574
+ />
575
+ </ExampleContainer>
576
+ </ThemeProvider>
577
+ <ThemeProvider theme={colorsTheme.select}>
578
+ <Title title="Opinionated theme" theme="light" level={2} />
579
+ <ExampleContainer pseudoState="pseudo-hover">
580
+ <Title title="Hovered option" theme="light" level={4} />
581
+ <HalstackProvider theme={opinionatedTheme}>
582
+ <Listbox
583
+ id="x16"
584
+ currentValue=""
585
+ options={one_option}
586
+ visualFocusIndex={-1}
587
+ lastOptionIndex={0}
588
+ multiple={false}
589
+ optional={false}
590
+ optionalItem={{ label: "Empty", value: "" }}
591
+ searchable={false}
592
+ handleOptionOnClick={() => {}}
593
+ styles={{ width: 360 }}
594
+ />
595
+ </HalstackProvider>
596
+ </ExampleContainer>
597
+ <ExampleContainer pseudoState="pseudo-active">
598
+ <Title title="Active option" theme="light" level={4} />{" "}
599
+ <HalstackProvider theme={opinionatedTheme}>
600
+ <Listbox
601
+ id="x17"
602
+ currentValue=""
603
+ options={one_option}
604
+ visualFocusIndex={-1}
605
+ lastOptionIndex={0}
606
+ multiple={false}
607
+ optional={false}
608
+ optionalItem={{ label: "Empty", value: "" }}
609
+ searchable={false}
610
+ handleOptionOnClick={() => {}}
611
+ styles={{ width: 360 }}
612
+ />
613
+ </HalstackProvider>
614
+ </ExampleContainer>
615
+ <ExampleContainer>
616
+ <Title title="Focused option" theme="light" level={4} />{" "}
617
+ <HalstackProvider theme={opinionatedTheme}>
618
+ <Listbox
619
+ id="x18"
620
+ currentValue=""
621
+ options={one_option}
622
+ visualFocusIndex={0}
623
+ lastOptionIndex={0}
624
+ multiple={false}
625
+ optional={false}
626
+ optionalItem={{ label: "Empty", value: "" }}
627
+ searchable={false}
628
+ handleOptionOnClick={() => {}}
629
+ styles={{ width: 360 }}
630
+ />
631
+ </HalstackProvider>
632
+ </ExampleContainer>
633
+ <ExampleContainer pseudoState="pseudo-hover">
634
+ <Title title="Hovered selected option" theme="light" level={4} />{" "}
635
+ <HalstackProvider theme={opinionatedTheme}>
636
+ <Listbox
637
+ id="x19"
638
+ currentValue="1"
639
+ options={single_options}
640
+ visualFocusIndex={-1}
641
+ lastOptionIndex={3}
642
+ multiple={false}
643
+ optional={false}
644
+ optionalItem={{ label: "Empty", value: "" }}
645
+ searchable={false}
646
+ handleOptionOnClick={() => {}}
647
+ styles={{ width: 360 }}
648
+ />
649
+ </HalstackProvider>
650
+ </ExampleContainer>
651
+ <ExampleContainer pseudoState="pseudo-active">
652
+ <Title title="Active selected option" theme="light" level={4} />{" "}
653
+ <HalstackProvider theme={opinionatedTheme}>
654
+ <Listbox
655
+ id="x20"
656
+ currentValue="2"
657
+ options={single_options}
658
+ visualFocusIndex={0}
659
+ lastOptionIndex={3}
660
+ multiple={false}
661
+ optional={false}
662
+ optionalItem={{ label: "Empty", value: "" }}
663
+ searchable={false}
664
+ handleOptionOnClick={() => {}}
665
+ styles={{ width: 360 }}
666
+ />
667
+ </HalstackProvider>
668
+ </ExampleContainer>
669
+ <Title title="Listbox with icons" theme="light" level={3} />
670
+ <ExampleContainer>
671
+ <Title title="Icons (SVGs)" theme="light" level={4} />{" "}
672
+ <HalstackProvider theme={opinionatedTheme}>
673
+ <Listbox
674
+ id="x21"
675
+ currentValue="3"
676
+ options={icon_options}
677
+ visualFocusIndex={-1}
678
+ lastOptionIndex={3}
679
+ multiple={false}
680
+ optional={false}
681
+ optionalItem={{ label: "Empty", value: "" }}
682
+ searchable={false}
683
+ handleOptionOnClick={() => {}}
684
+ styles={{ width: 360 }}
685
+ />
686
+ </HalstackProvider>
687
+ </ExampleContainer>
688
+ </ThemeProvider>
689
+ </>
690
+ );
348
691
  };
349
- const DefaultSelect = () => (
692
+
693
+ const SearchableSelect = () => (
350
694
  <ExampleContainer expanded>
351
- <Title title="Default select" theme="light" level={4} />
352
- <DxcSelect label="Select label" options={single_options} optional placeholder="Choose an option" />
695
+ <Title title="Searchable select" theme="light" level={4} />
696
+ <DxcSelect label="Select Label" searchable options={single_options} placeholder="Choose an option" />
353
697
  </ExampleContainer>
354
698
  );
355
- const SearchableSelect = () => (
699
+
700
+ const SearchableSelectOpinionated = () => (
356
701
  <ExampleContainer expanded>
357
702
  <Title title="Searchable select" theme="light" level={4} />
358
- <DxcSelect label="Select Label" searchable options={single_options} placeholder="Choose an option" />
703
+ <HalstackProvider theme={opinionatedTheme}>
704
+ <DxcSelect label="Select Label" searchable options={single_options} placeholder="Choose an option" />
705
+ </HalstackProvider>
706
+ </ExampleContainer>
707
+ );
708
+
709
+ const SearchValue = () => (
710
+ <ExampleContainer expanded>
711
+ <Title title="Searchable select with value" theme="light" level={4} />
712
+ <DxcSelect
713
+ label="Select Label"
714
+ searchable
715
+ defaultValue="1"
716
+ options={single_options}
717
+ placeholder="Choose an option"
718
+ />
359
719
  </ExampleContainer>
360
720
  );
361
- const SearchableWithValue = () => (
721
+
722
+ const SearchValueOpinionated = () => (
362
723
  <ExampleContainer expanded>
363
724
  <Title title="Searchable select with value" theme="light" level={4} />
364
- <DxcSelect label="Select Label" searchable value="1" options={single_options} placeholder="Choose an option" />
725
+ <HalstackProvider theme={opinionatedTheme}>
726
+ <DxcSelect
727
+ label="Select Label"
728
+ searchable
729
+ defaultValue="1"
730
+ options={single_options}
731
+ placeholder="Choose an option"
732
+ />
733
+ </HalstackProvider>
365
734
  </ExampleContainer>
366
735
  );
367
736
 
@@ -372,85 +741,73 @@ const MultipleSelect = () => (
372
741
  <DxcSelect
373
742
  label="Select label"
374
743
  options={single_options}
375
- value={["1", "4"]}
744
+ defaultValue={["1", "4"]}
376
745
  multiple
377
746
  placeholder="Choose an option"
378
747
  />
379
748
  </ExampleContainer>
380
749
  </>
381
750
  );
382
- const DefaultGroupedOptionsSelect = () => (
383
- <ExampleContainer expanded>
384
- <Title title="Grouped options simple select" theme="light" level={4} />
385
- <DxcSelect label="Label" options={group_options} value="9" placeholder="Choose an option" />
386
- </ExampleContainer>
387
- );
388
- const MultipleGroupedOptionsSelect = () => (
389
- <ExampleContainer expanded>
390
- <Title title="Grouped options multiple select" theme="light" level={4} />
391
- <DxcSelect label="Label" options={group_options} value={["0", "2"]} multiple placeholder="Choose an option" />
392
- </ExampleContainer>
393
- );
394
- const RescaledIcons = () => (
751
+
752
+ const MultipleSelectOpinionated = () => (
395
753
  <ExampleContainer expanded>
396
- <Title title="Rescaled icons displayed" theme="light" level={4} />
397
- <DxcSelect label="Label" options={url_options} value="facebook" placeholder="Choose an option" />
754
+ <Title title="Multiple select" theme="light" level={4} />
755
+ <HalstackProvider theme={opinionatedTheme}>
756
+ <DxcSelect
757
+ label="Select label"
758
+ options={single_options}
759
+ defaultValue={["1", "4"]}
760
+ multiple
761
+ placeholder="Choose an option"
762
+ />
763
+ </HalstackProvider>
398
764
  </ExampleContainer>
399
765
  );
400
- const SelectWithIcons = () => (
766
+
767
+ const DefaultGroupedOptionsSelect = () => (
401
768
  <ExampleContainer expanded>
402
- <Title title="Normal icons displayed" theme="light" level={4} />
403
- <DxcSelect label="Label" options={icon_options} value="3" placeholder="Choose an option" />
769
+ <Title title="Grouped options simple select" theme="light" level={4} />
770
+ <DxcSelect label="Label" options={group_options} defaultValue="9" placeholder="Choose an option" />
404
771
  </ExampleContainer>
405
772
  );
406
- const SelectMultipleWithIcons = () => (
773
+
774
+ const DefaultGroupedOptionsSelectOpinionated = () => (
407
775
  <ExampleContainer expanded>
408
- <Title title="Multiple select with icons" theme="light" level={4} />
409
- <DxcSelect label="Label" options={icon_options} multiple value={["1", "3"]} placeholder="Choose an option" />
776
+ <Title title="Grouped options simple select" theme="light" level={4} />
777
+ <HalstackProvider theme={opinionatedTheme}>
778
+ <DxcSelect label="Label" options={group_options} defaultValue="9" placeholder="Choose an option" />
779
+ </HalstackProvider>
410
780
  </ExampleContainer>
411
781
  );
412
- const MultipleGroupedOptionsSelectWithIcons = () => (
782
+
783
+ const MultipleGroupedOptionsSelect = () => (
413
784
  <ExampleContainer expanded>
414
- <Title title="Multiple grouped options with icons" theme="light" level={4} />
785
+ <Title title="Grouped options multiple select" theme="light" level={4} />
415
786
  <DxcSelect
416
787
  label="Label"
417
- options={icon_options_grouped}
788
+ options={group_options}
789
+ defaultValue={["0", "2"]}
418
790
  multiple
419
- value={["3", "2"]}
420
791
  placeholder="Choose an option"
421
792
  />
422
793
  </ExampleContainer>
423
794
  );
424
- const OnlyOneOptionHovered = () => (
425
- <ExampleContainer pseudoState="pseudo-hover" expanded>
426
- <Title title="Hovered Option" theme="light" level={4} />
427
- <DxcSelect label="Hovered" options={one_option} placeholder="Choose an option" />
428
- </ExampleContainer>
429
- );
430
- const OnlyOneOptionFocused = () => (
431
- <ExampleContainer pseudoState="pseudo-focus" expanded>
432
- <Title title="Focused Option" theme="light" level={4} />
433
- <DxcSelect label="Focused" options={one_option} placeholder="Choose an option" />
434
- </ExampleContainer>
435
- );
436
- const OnlyOneOptionActived = () => (
437
- <ExampleContainer pseudoState="pseudo-active" expanded>
438
- <Title title="Actived Option" theme="light" level={4} />
439
- <DxcSelect label="Actived" options={one_option} placeholder="Choose an option" />
440
- </ExampleContainer>
441
- );
442
- const SelectedOptionHovered = () => (
443
- <ExampleContainer pseudoState="pseudo-hover" expanded>
444
- <Title title="Hovered Selected Option" theme="light" level={4} />
445
- <DxcSelect label="Hovered" value="1" options={one_option} placeholder="Choose an option" />
446
- </ExampleContainer>
447
- );
448
- const SelectedOptionActived = () => (
449
- <ExampleContainer pseudoState="pseudo-active" expanded>
450
- <Title title="Actived Selected Option" theme="light" level={4} />
451
- <DxcSelect label="Actived" value="1" options={one_option} placeholder="Choose an option" />
795
+
796
+ const MultipleGroupedOptionsSelectOpinionated = () => (
797
+ <ExampleContainer expanded>
798
+ <Title title="Grouped options multiple select" theme="light" level={4} />
799
+ <HalstackProvider theme={opinionatedTheme}>
800
+ <DxcSelect
801
+ label="Label"
802
+ options={group_options}
803
+ defaultValue={["0", "2"]}
804
+ multiple
805
+ placeholder="Choose an option"
806
+ />
807
+ </HalstackProvider>
452
808
  </ExampleContainer>
453
809
  );
810
+
454
811
  const MultipleSearchable = () => (
455
812
  <ExampleContainer expanded>
456
813
  <Title title="Searchable multiple select with value" theme="light" level={4} />
@@ -458,114 +815,113 @@ const MultipleSearchable = () => (
458
815
  label="Select Label"
459
816
  searchable
460
817
  multiple
461
- value={["1", "4"]}
818
+ defaultValue={["1", "4"]}
462
819
  options={single_options}
463
820
  placeholder="Choose an option"
464
821
  />
465
822
  </ExampleContainer>
466
823
  );
467
- export const OptionsDisplayed = DefaultSelect.bind({});
468
- OptionsDisplayed.play = async ({ canvasElement }) => {
824
+
825
+ const MultipleSearchableOpinionated = () => (
826
+ <ExampleContainer expanded>
827
+ <Title title="Searchable multiple select with value" theme="light" level={4} />
828
+ <HalstackProvider theme={opinionatedTheme}>
829
+ <DxcSelect
830
+ label="Select Label"
831
+ searchable
832
+ multiple
833
+ defaultValue={["1", "4"]}
834
+ options={single_options}
835
+ placeholder="Choose an option"
836
+ />
837
+ </HalstackProvider>
838
+ </ExampleContainer>
839
+ );
840
+
841
+ export const Chromatic = Select.bind({});
842
+ Chromatic.play = async ({ canvasElement }) => {
843
+ const canvas = within(canvasElement);
844
+ await userEvent.click(canvas.getAllByRole("combobox")[24]);
845
+ };
846
+
847
+ export const ListboxStates = SelectListbox.bind({});
848
+ ListboxStates.play = async ({ canvasElement }) => {
469
849
  const canvas = within(canvasElement);
470
850
  const select = canvas.getByRole("combobox");
471
851
  await userEvent.click(select);
472
852
  };
853
+
473
854
  export const Searchable = SearchableSelect.bind({});
474
855
  Searchable.play = async ({ canvasElement }) => {
475
856
  const canvas = within(canvasElement);
476
- await userEvent.click(canvas.getByRole("combobox"));
477
- await waitFor(async () => {
478
- userEvent.type(canvas.getByRole("combobox"), "r");
479
- });
857
+ await userEvent.type(canvas.getByRole("combobox"), "r");
480
858
  };
481
- export const SelectSearchableWithValue = SearchableWithValue.bind({});
482
- SelectSearchableWithValue.play = async ({ canvasElement }) => {
859
+
860
+ export const SearchableOpinionated = SearchableSelectOpinionated.bind({});
861
+ SearchableOpinionated.play = async ({ canvasElement }) => {
483
862
  const canvas = within(canvasElement);
484
- await userEvent.click(canvas.getByRole("combobox"));
863
+ await userEvent.type(canvas.getByRole("combobox"), "r");
485
864
  };
486
865
 
487
- export const SelectMultipleSearchableWithValue = MultipleSearchable.bind({});
488
- SelectMultipleSearchableWithValue.play = async ({ canvasElement }) => {
866
+ export const SearchableWithValue = SearchValue.bind({});
867
+ SearchableWithValue.play = async ({ canvasElement }) => {
489
868
  const canvas = within(canvasElement);
490
- await userEvent.click(canvas.getAllByRole("combobox")[0]);
869
+ await userEvent.click(canvas.getByRole("combobox"));
491
870
  };
492
871
 
493
- export const GroupOptionsDisplayed = DefaultGroupedOptionsSelect.bind({});
494
- GroupOptionsDisplayed.play = async ({ canvasElement }) => {
872
+ export const SearchableWithValueOpinionated = SearchValueOpinionated.bind({});
873
+ SearchableWithValueOpinionated.play = async ({ canvasElement }) => {
495
874
  const canvas = within(canvasElement);
496
- const select = canvas.getByRole("combobox");
497
- await userEvent.click(select);
875
+ await userEvent.click(canvas.getByRole("combobox"));
498
876
  };
499
877
 
500
- export const SelectMultipleOptionsDisplayed = MultipleSelect.bind({});
501
- SelectMultipleOptionsDisplayed.play = async ({ canvasElement }) => {
878
+ export const MultipleSearchableWithValue = MultipleSearchable.bind({});
879
+ MultipleSearchableWithValue.play = async ({ canvasElement }) => {
502
880
  const canvas = within(canvasElement);
503
881
  await userEvent.click(canvas.getAllByRole("combobox")[0]);
504
882
  };
505
883
 
506
- export const SelectMultipleGroupedOptionsDisplayed = MultipleGroupedOptionsSelect.bind({});
507
- SelectMultipleGroupedOptionsDisplayed.play = async ({ canvasElement }) => {
884
+ export const MultipleSearchableWithValueOpinionated = MultipleSearchableOpinionated.bind({});
885
+ MultipleSearchableWithValueOpinionated.play = async ({ canvasElement }) => {
508
886
  const canvas = within(canvasElement);
509
- const select = canvas.getByRole("combobox");
510
- await userEvent.click(select);
511
- };
512
- export const SelectWithIconsDisplayed = SelectWithIcons.bind({});
513
- SelectWithIconsDisplayed.play = async ({ canvasElement }) => {
514
- const canvas = within(canvasElement);
515
- const select = canvas.getByRole("combobox");
516
- await userEvent.click(select);
887
+ await userEvent.click(canvas.getAllByRole("combobox")[0]);
517
888
  };
518
889
 
519
- export const SelectWithRescaledIconsDisplayed = RescaledIcons.bind({});
520
- SelectWithRescaledIconsDisplayed.play = async ({ canvasElement }) => {
521
- const canvas = within(canvasElement);
522
- const select = canvas.getByRole("combobox");
523
- await userEvent.click(select);
524
- };
525
- export const SelectMultipleWithIconsDisplayed = SelectMultipleWithIcons.bind({});
526
- SelectMultipleWithIconsDisplayed.play = async ({ canvasElement }) => {
890
+ export const GroupOptionsDisplayed = DefaultGroupedOptionsSelect.bind({});
891
+ GroupOptionsDisplayed.play = async ({ canvasElement }) => {
527
892
  const canvas = within(canvasElement);
528
893
  const select = canvas.getByRole("combobox");
529
894
  await userEvent.click(select);
530
895
  };
531
896
 
532
- export const SelectMultipleGroupedWithIconsDisplayed = MultipleGroupedOptionsSelectWithIcons.bind({});
533
- SelectMultipleGroupedWithIconsDisplayed.play = async ({ canvasElement }) => {
897
+ export const GroupOptionsDisplayedOpinionated = DefaultGroupedOptionsSelectOpinionated.bind({});
898
+ GroupOptionsDisplayedOpinionated.play = async ({ canvasElement }) => {
534
899
  const canvas = within(canvasElement);
535
900
  const select = canvas.getByRole("combobox");
536
901
  await userEvent.click(select);
537
902
  };
538
903
 
539
- export const OptionHovered = OnlyOneOptionHovered.bind({});
540
- OptionHovered.play = async ({ canvasElement }) => {
904
+ export const MultipleOptionsDisplayed = MultipleSelect.bind({});
905
+ MultipleOptionsDisplayed.play = async ({ canvasElement }) => {
541
906
  const canvas = within(canvasElement);
542
- const select = canvas.getByRole("combobox");
543
- await userEvent.click(select);
907
+ await userEvent.click(canvas.getAllByRole("combobox")[0]);
544
908
  };
545
909
 
546
- export const OptionFocused = OnlyOneOptionFocused.bind({});
547
- OptionFocused.play = async ({ canvasElement }) => {
548
- const canvas = within(canvasElement);
549
- const select = canvas.getByRole("combobox");
550
- await userEvent.click(select);
551
- await waitFor(async () => {
552
- fireEvent.keyDown(select, { key: "ArrowDown", code: "ArrowDown", keyCode: 40, charCode: 40 });
553
- });
554
- };
555
- export const OptionActived = OnlyOneOptionActived.bind({});
556
- OptionActived.play = async ({ canvasElement }) => {
910
+ export const MultipleOptionsDisplayedOpinionated = MultipleSelectOpinionated.bind({});
911
+ MultipleOptionsDisplayedOpinionated.play = async ({ canvasElement }) => {
557
912
  const canvas = within(canvasElement);
558
- const select = canvas.getByRole("combobox");
559
- await userEvent.click(select);
913
+ await userEvent.click(canvas.getAllByRole("combobox")[0]);
560
914
  };
561
- export const OptionSelectedHovered = SelectedOptionHovered.bind({});
562
- OptionSelectedHovered.play = async ({ canvasElement }) => {
915
+
916
+ export const MultipleGroupedOptionsDisplayed = MultipleGroupedOptionsSelect.bind({});
917
+ MultipleGroupedOptionsDisplayed.play = async ({ canvasElement }) => {
563
918
  const canvas = within(canvasElement);
564
919
  const select = canvas.getByRole("combobox");
565
920
  await userEvent.click(select);
566
921
  };
567
- export const OptionSelectedActived = SelectedOptionActived.bind({});
568
- OptionSelectedActived.play = async ({ canvasElement }) => {
922
+
923
+ export const MultipleGroupedOptionsDisplayedOpinionated = MultipleGroupedOptionsSelectOpinionated.bind({});
924
+ MultipleGroupedOptionsDisplayedOpinionated.play = async ({ canvasElement }) => {
569
925
  const canvas = within(canvasElement);
570
926
  const select = canvas.getByRole("combobox");
571
927
  await userEvent.click(select);