@dxc-technology/halstack-react 0.0.0-b0616f2 → 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 (498) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +5 -22
  3. package/HalstackContext.d.ts +1274 -6
  4. package/HalstackContext.js +135 -110
  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 +44 -121
  10. package/accordion/Accordion.stories.tsx +82 -147
  11. package/accordion/Accordion.test.d.ts +1 -0
  12. package/accordion/Accordion.test.js +18 -33
  13. package/accordion/types.d.ts +6 -17
  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 +2 -2
  17. package/accordion-group/AccordionGroup.js +29 -77
  18. package/accordion-group/AccordionGroup.stories.tsx +78 -77
  19. package/accordion-group/AccordionGroup.test.d.ts +1 -0
  20. package/accordion-group/AccordionGroup.test.js +41 -73
  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 +7 -18
  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 +36 -126
  37. package/alert/Alert.stories.tsx +28 -0
  38. package/alert/Alert.test.d.ts +1 -0
  39. package/alert/Alert.test.js +28 -45
  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 +1 -1
  44. package/badge/Badge.js +142 -42
  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 +52 -3
  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.js +13 -21
  58. package/bleed/Bleed.stories.tsx +1 -1
  59. package/bleed/types.d.ts +2 -2
  60. package/box/Box.accessibility.test.d.ts +1 -0
  61. package/box/Box.accessibility.test.js +33 -0
  62. package/box/Box.d.ts +1 -1
  63. package/box/Box.js +18 -59
  64. package/box/Box.stories.tsx +38 -51
  65. package/box/Box.test.d.ts +1 -0
  66. package/box/Box.test.js +1 -6
  67. package/box/types.d.ts +3 -14
  68. package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
  69. package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
  70. package/breadcrumbs/Breadcrumbs.d.ts +4 -0
  71. package/breadcrumbs/Breadcrumbs.js +79 -0
  72. package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
  73. package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
  74. package/breadcrumbs/Breadcrumbs.test.js +168 -0
  75. package/breadcrumbs/Item.d.ts +4 -0
  76. package/breadcrumbs/Item.js +52 -0
  77. package/breadcrumbs/dropdownTheme.d.ts +53 -0
  78. package/breadcrumbs/dropdownTheme.js +62 -0
  79. package/breadcrumbs/types.d.ts +40 -0
  80. package/bulleted-list/BulletedList.accessibility.test.d.ts +1 -0
  81. package/bulleted-list/BulletedList.accessibility.test.js +119 -0
  82. package/bulleted-list/BulletedList.js +22 -53
  83. package/bulleted-list/BulletedList.stories.tsx +8 -93
  84. package/bulleted-list/types.d.ts +32 -5
  85. package/button/Button.accessibility.test.d.ts +1 -0
  86. package/button/Button.accessibility.test.js +127 -0
  87. package/button/Button.d.ts +1 -1
  88. package/button/Button.js +71 -106
  89. package/button/Button.stories.tsx +143 -101
  90. package/button/Button.test.d.ts +1 -0
  91. package/button/Button.test.js +19 -16
  92. package/button/types.d.ts +9 -5
  93. package/card/Card.accessibility.test.d.ts +1 -0
  94. package/card/Card.accessibility.test.js +36 -0
  95. package/card/Card.d.ts +1 -1
  96. package/card/Card.js +49 -89
  97. package/card/Card.stories.tsx +13 -43
  98. package/card/Card.test.d.ts +1 -0
  99. package/card/Card.test.js +10 -21
  100. package/card/types.d.ts +6 -11
  101. package/checkbox/Checkbox.accessibility.test.d.ts +1 -0
  102. package/checkbox/Checkbox.accessibility.test.js +87 -0
  103. package/checkbox/Checkbox.d.ts +2 -2
  104. package/checkbox/Checkbox.js +98 -134
  105. package/checkbox/Checkbox.stories.tsx +128 -94
  106. package/checkbox/Checkbox.test.d.ts +1 -0
  107. package/checkbox/Checkbox.test.js +107 -63
  108. package/checkbox/types.d.ts +11 -3
  109. package/chip/Chip.accessibility.test.d.ts +1 -0
  110. package/chip/Chip.accessibility.test.js +67 -0
  111. package/chip/Chip.js +45 -80
  112. package/chip/Chip.stories.tsx +103 -27
  113. package/chip/Chip.test.d.ts +1 -0
  114. package/chip/Chip.test.js +17 -32
  115. package/chip/types.d.ts +4 -4
  116. package/common/coreTokens.d.ts +236 -0
  117. package/common/coreTokens.js +183 -0
  118. package/common/utils.d.ts +1 -0
  119. package/common/utils.js +6 -12
  120. package/common/variables.d.ts +1432 -0
  121. package/common/variables.js +1010 -1220
  122. package/container/Container.d.ts +4 -0
  123. package/container/Container.js +194 -0
  124. package/container/Container.stories.tsx +214 -0
  125. package/container/types.d.ts +176 -0
  126. package/container/types.js +5 -0
  127. package/contextual-menu/ContextualMenu.accessibility.test.d.ts +1 -0
  128. package/contextual-menu/ContextualMenu.accessibility.test.js +98 -0
  129. package/contextual-menu/ContextualMenu.d.ts +5 -0
  130. package/contextual-menu/ContextualMenu.js +136 -0
  131. package/contextual-menu/ContextualMenu.stories.tsx +231 -0
  132. package/contextual-menu/ContextualMenu.test.d.ts +1 -0
  133. package/contextual-menu/ContextualMenu.test.js +247 -0
  134. package/contextual-menu/GroupItem.d.ts +4 -0
  135. package/contextual-menu/GroupItem.js +67 -0
  136. package/contextual-menu/ItemAction.d.ts +4 -0
  137. package/contextual-menu/ItemAction.js +88 -0
  138. package/contextual-menu/MenuItem.d.ts +4 -0
  139. package/contextual-menu/MenuItem.js +29 -0
  140. package/contextual-menu/SingleItem.d.ts +4 -0
  141. package/contextual-menu/SingleItem.js +38 -0
  142. package/contextual-menu/types.d.ts +65 -0
  143. package/contextual-menu/types.js +5 -0
  144. package/date-input/Calendar.d.ts +4 -0
  145. package/date-input/Calendar.js +230 -0
  146. package/date-input/DateInput.accessibility.test.d.ts +1 -0
  147. package/date-input/DateInput.accessibility.test.js +229 -0
  148. package/date-input/DateInput.js +156 -300
  149. package/date-input/DateInput.stories.tsx +210 -57
  150. package/date-input/DateInput.test.d.ts +1 -0
  151. package/date-input/DateInput.test.js +699 -370
  152. package/date-input/DatePicker.d.ts +4 -0
  153. package/date-input/DatePicker.js +121 -0
  154. package/date-input/YearPicker.d.ts +4 -0
  155. package/date-input/YearPicker.js +105 -0
  156. package/date-input/types.d.ts +72 -15
  157. package/dialog/Dialog.accessibility.test.d.ts +1 -0
  158. package/dialog/Dialog.accessibility.test.js +69 -0
  159. package/dialog/Dialog.d.ts +1 -1
  160. package/dialog/Dialog.js +50 -119
  161. package/dialog/Dialog.stories.tsx +324 -166
  162. package/dialog/Dialog.test.d.ts +1 -0
  163. package/dialog/Dialog.test.js +332 -32
  164. package/dialog/types.d.ts +18 -25
  165. package/divider/Divider.accessibility.test.d.ts +1 -0
  166. package/divider/Divider.accessibility.test.js +33 -0
  167. package/divider/Divider.d.ts +4 -0
  168. package/divider/Divider.js +36 -0
  169. package/divider/Divider.stories.tsx +224 -0
  170. package/divider/Divider.test.d.ts +1 -0
  171. package/divider/Divider.test.js +38 -0
  172. package/divider/types.d.ts +21 -0
  173. package/divider/types.js +5 -0
  174. package/dropdown/Dropdown.accessibility.test.d.ts +1 -0
  175. package/dropdown/Dropdown.accessibility.test.js +183 -0
  176. package/dropdown/Dropdown.js +93 -160
  177. package/dropdown/Dropdown.stories.tsx +210 -95
  178. package/dropdown/Dropdown.test.d.ts +1 -0
  179. package/dropdown/Dropdown.test.js +450 -413
  180. package/dropdown/DropdownMenu.js +23 -40
  181. package/dropdown/DropdownMenuItem.js +18 -39
  182. package/dropdown/types.d.ts +20 -24
  183. package/file-input/FileInput.accessibility.test.d.ts +1 -0
  184. package/file-input/FileInput.accessibility.test.js +167 -0
  185. package/file-input/FileInput.d.ts +2 -2
  186. package/file-input/FileInput.js +238 -393
  187. package/file-input/FileInput.stories.tsx +123 -12
  188. package/file-input/FileInput.test.d.ts +1 -0
  189. package/file-input/FileInput.test.js +314 -367
  190. package/file-input/FileItem.d.ts +4 -14
  191. package/file-input/FileItem.js +56 -117
  192. package/file-input/types.d.ts +24 -11
  193. package/flex/Flex.d.ts +1 -1
  194. package/flex/Flex.js +40 -40
  195. package/flex/Flex.stories.tsx +35 -26
  196. package/flex/types.d.ts +84 -8
  197. package/footer/Footer.accessibility.test.d.ts +1 -0
  198. package/footer/Footer.accessibility.test.js +125 -0
  199. package/footer/Footer.d.ts +1 -1
  200. package/footer/Footer.js +73 -118
  201. package/footer/Footer.stories.tsx +94 -23
  202. package/footer/Footer.test.d.ts +1 -0
  203. package/footer/Footer.test.js +32 -56
  204. package/footer/Icons.d.ts +3 -2
  205. package/footer/Icons.js +53 -22
  206. package/footer/types.d.ts +26 -27
  207. package/grid/Grid.d.ts +7 -0
  208. package/grid/Grid.js +76 -0
  209. package/grid/Grid.stories.tsx +221 -0
  210. package/grid/types.d.ts +115 -0
  211. package/grid/types.js +5 -0
  212. package/header/Header.accessibility.test.d.ts +1 -0
  213. package/header/Header.accessibility.test.js +94 -0
  214. package/header/Header.d.ts +4 -3
  215. package/header/Header.js +55 -150
  216. package/header/Header.stories.tsx +131 -36
  217. package/header/Header.test.d.ts +1 -0
  218. package/header/Header.test.js +12 -25
  219. package/header/Icons.d.ts +2 -2
  220. package/header/Icons.js +3 -13
  221. package/header/types.d.ts +7 -21
  222. package/heading/Heading.accessibility.test.d.ts +1 -0
  223. package/heading/Heading.accessibility.test.js +33 -0
  224. package/heading/Heading.js +10 -32
  225. package/heading/Heading.test.d.ts +1 -0
  226. package/heading/Heading.test.js +64 -94
  227. package/heading/types.d.ts +7 -7
  228. package/icon/Icon.accessibility.test.d.ts +1 -0
  229. package/icon/Icon.accessibility.test.js +30 -0
  230. package/icon/Icon.d.ts +4 -0
  231. package/icon/Icon.js +33 -0
  232. package/icon/Icon.stories.tsx +28 -0
  233. package/icon/types.d.ts +4 -0
  234. package/icon/types.js +5 -0
  235. package/image/Image.accessibility.test.d.ts +1 -0
  236. package/image/Image.accessibility.test.js +56 -0
  237. package/image/Image.d.ts +4 -0
  238. package/image/Image.js +70 -0
  239. package/image/Image.stories.tsx +129 -0
  240. package/image/types.d.ts +72 -0
  241. package/image/types.js +5 -0
  242. package/inset/Inset.js +13 -21
  243. package/inset/Inset.stories.tsx +2 -1
  244. package/inset/types.d.ts +2 -2
  245. package/layout/ApplicationLayout.d.ts +5 -5
  246. package/layout/ApplicationLayout.js +36 -70
  247. package/layout/ApplicationLayout.stories.tsx +1 -1
  248. package/layout/Icons.d.ts +7 -5
  249. package/layout/Icons.js +41 -59
  250. package/layout/types.d.ts +5 -6
  251. package/link/Link.accessibility.test.d.ts +1 -0
  252. package/link/Link.accessibility.test.js +108 -0
  253. package/link/Link.js +32 -51
  254. package/link/Link.stories.tsx +64 -4
  255. package/link/Link.test.d.ts +1 -0
  256. package/link/Link.test.js +23 -43
  257. package/link/types.d.ts +14 -14
  258. package/main.d.ts +12 -5
  259. package/main.js +61 -59
  260. package/nav-tabs/NavTabs.accessibility.test.d.ts +1 -0
  261. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  262. package/nav-tabs/NavTabs.d.ts +7 -0
  263. package/nav-tabs/NavTabs.js +108 -0
  264. package/nav-tabs/NavTabs.stories.tsx +294 -0
  265. package/nav-tabs/NavTabs.test.d.ts +1 -0
  266. package/nav-tabs/NavTabs.test.js +77 -0
  267. package/nav-tabs/NavTabsContext.d.ts +3 -0
  268. package/nav-tabs/NavTabsContext.js +8 -0
  269. package/nav-tabs/Tab.js +117 -0
  270. package/{tabs-nav → nav-tabs}/types.d.ts +15 -16
  271. package/nav-tabs/types.js +5 -0
  272. package/number-input/NumberInput.accessibility.test.d.ts +1 -0
  273. package/number-input/NumberInput.accessibility.test.js +227 -0
  274. package/number-input/NumberInput.js +50 -37
  275. package/number-input/NumberInput.stories.tsx +37 -26
  276. package/number-input/NumberInput.test.d.ts +1 -0
  277. package/number-input/NumberInput.test.js +858 -376
  278. package/number-input/NumberInputContext.d.ts +3 -4
  279. package/number-input/NumberInputContext.js +3 -14
  280. package/number-input/types.d.ts +17 -5
  281. package/package.json +52 -49
  282. package/paginator/Paginator.accessibility.test.d.ts +1 -0
  283. package/paginator/Paginator.accessibility.test.js +78 -0
  284. package/paginator/Paginator.js +35 -68
  285. package/paginator/Paginator.stories.tsx +24 -0
  286. package/paginator/Paginator.test.d.ts +1 -0
  287. package/paginator/Paginator.test.js +253 -227
  288. package/paginator/types.d.ts +3 -3
  289. package/paragraph/Paragraph.accessibility.test.d.ts +1 -0
  290. package/paragraph/Paragraph.accessibility.test.js +28 -0
  291. package/paragraph/Paragraph.d.ts +3 -4
  292. package/paragraph/Paragraph.js +6 -22
  293. package/paragraph/Paragraph.stories.tsx +0 -17
  294. package/password-input/PasswordInput.accessibility.test.d.ts +1 -0
  295. package/password-input/PasswordInput.accessibility.test.js +152 -0
  296. package/password-input/PasswordInput.js +62 -128
  297. package/password-input/PasswordInput.stories.tsx +11 -34
  298. package/password-input/PasswordInput.test.d.ts +1 -0
  299. package/password-input/PasswordInput.test.js +158 -141
  300. package/password-input/types.d.ts +8 -7
  301. package/progress-bar/ProgressBar.accessibility.test.d.ts +1 -0
  302. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  303. package/progress-bar/ProgressBar.d.ts +2 -2
  304. package/progress-bar/ProgressBar.js +28 -58
  305. package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +36 -3
  306. package/progress-bar/ProgressBar.test.d.ts +1 -0
  307. package/progress-bar/ProgressBar.test.js +35 -52
  308. package/progress-bar/types.d.ts +4 -3
  309. package/quick-nav/QuickNav.accessibility.test.d.ts +1 -0
  310. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  311. package/quick-nav/QuickNav.js +15 -39
  312. package/quick-nav/QuickNav.stories.tsx +112 -20
  313. package/quick-nav/types.d.ts +10 -10
  314. package/radio-group/Radio.d.ts +1 -1
  315. package/radio-group/Radio.js +59 -79
  316. package/radio-group/RadioGroup.accessibility.test.d.ts +1 -0
  317. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  318. package/radio-group/RadioGroup.js +62 -110
  319. package/radio-group/RadioGroup.stories.tsx +132 -18
  320. package/radio-group/RadioGroup.test.d.ts +1 -0
  321. package/radio-group/RadioGroup.test.js +518 -459
  322. package/radio-group/types.d.ts +10 -10
  323. package/resultset-table/Icons.d.ts +7 -0
  324. package/{text-input → resultset-table}/Icons.js +13 -26
  325. package/resultset-table/ResultsetTable.accessibility.test.d.ts +1 -0
  326. package/resultset-table/ResultsetTable.accessibility.test.js +284 -0
  327. package/resultset-table/ResultsetTable.d.ts +7 -0
  328. package/resultset-table/ResultsetTable.js +195 -0
  329. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +169 -31
  330. package/resultset-table/ResultsetTable.test.d.ts +1 -0
  331. package/resultset-table/ResultsetTable.test.js +450 -0
  332. package/{resultsetTable → resultset-table}/types.d.ts +46 -12
  333. package/resultset-table/types.js +5 -0
  334. package/select/Listbox.d.ts +1 -1
  335. package/select/Listbox.js +40 -87
  336. package/select/Option.js +35 -56
  337. package/select/Select.accessibility.test.d.ts +1 -0
  338. package/select/Select.accessibility.test.js +227 -0
  339. package/select/Select.js +141 -182
  340. package/select/Select.stories.tsx +505 -204
  341. package/select/Select.test.d.ts +1 -0
  342. package/select/Select.test.js +1916 -1923
  343. package/select/types.d.ts +17 -18
  344. package/sidenav/Sidenav.accessibility.test.d.ts +1 -0
  345. package/sidenav/Sidenav.accessibility.test.js +59 -0
  346. package/sidenav/Sidenav.d.ts +2 -2
  347. package/sidenav/Sidenav.js +90 -157
  348. package/sidenav/Sidenav.stories.tsx +161 -64
  349. package/sidenav/Sidenav.test.d.ts +1 -0
  350. package/sidenav/Sidenav.test.js +4 -11
  351. package/{layout → sidenav}/SidenavContext.d.ts +1 -1
  352. package/{layout → sidenav}/SidenavContext.js +3 -9
  353. package/sidenav/types.d.ts +33 -30
  354. package/slider/Slider.accessibility.test.d.ts +1 -0
  355. package/slider/Slider.accessibility.test.js +103 -0
  356. package/slider/Slider.d.ts +2 -2
  357. package/slider/Slider.js +79 -135
  358. package/slider/Slider.stories.tsx +57 -60
  359. package/slider/Slider.test.d.ts +1 -0
  360. package/slider/Slider.test.js +117 -111
  361. package/slider/types.d.ts +7 -3
  362. package/spinner/Spinner.accessibility.test.d.ts +1 -0
  363. package/spinner/Spinner.accessibility.test.js +96 -0
  364. package/spinner/Spinner.d.ts +1 -1
  365. package/spinner/Spinner.js +50 -109
  366. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
  367. package/spinner/Spinner.test.d.ts +1 -0
  368. package/spinner/Spinner.test.js +25 -34
  369. package/spinner/types.d.ts +3 -3
  370. package/status-light/StatusLight.accessibility.test.d.ts +1 -0
  371. package/status-light/StatusLight.accessibility.test.js +157 -0
  372. package/status-light/StatusLight.d.ts +4 -0
  373. package/status-light/StatusLight.js +51 -0
  374. package/status-light/StatusLight.stories.tsx +74 -0
  375. package/status-light/StatusLight.test.d.ts +1 -0
  376. package/status-light/StatusLight.test.js +25 -0
  377. package/status-light/types.d.ts +17 -0
  378. package/status-light/types.js +5 -0
  379. package/switch/Switch.accessibility.test.d.ts +1 -0
  380. package/switch/Switch.accessibility.test.js +98 -0
  381. package/switch/Switch.d.ts +3 -3
  382. package/switch/Switch.js +112 -152
  383. package/switch/Switch.stories.tsx +45 -34
  384. package/switch/Switch.test.d.ts +1 -0
  385. package/switch/Switch.test.js +69 -101
  386. package/switch/types.d.ts +8 -3
  387. package/table/DropdownTheme.js +62 -0
  388. package/table/Table.accessibility.test.d.ts +1 -0
  389. package/table/Table.accessibility.test.js +92 -0
  390. package/table/Table.d.ts +6 -2
  391. package/table/Table.js +78 -35
  392. package/table/Table.stories.tsx +663 -0
  393. package/table/Table.test.d.ts +1 -0
  394. package/table/Table.test.js +92 -7
  395. package/table/types.d.ts +34 -6
  396. package/tabs/Tab.js +28 -46
  397. package/tabs/Tabs.accessibility.test.d.ts +1 -0
  398. package/tabs/Tabs.accessibility.test.js +56 -0
  399. package/tabs/Tabs.js +69 -163
  400. package/tabs/Tabs.stories.tsx +50 -6
  401. package/tabs/Tabs.test.d.ts +1 -0
  402. package/tabs/Tabs.test.js +60 -135
  403. package/tabs/types.d.ts +21 -21
  404. package/tag/Tag.accessibility.test.d.ts +1 -0
  405. package/tag/Tag.accessibility.test.js +69 -0
  406. package/tag/Tag.js +34 -66
  407. package/tag/Tag.stories.tsx +19 -9
  408. package/tag/Tag.test.d.ts +1 -0
  409. package/tag/Tag.test.js +17 -36
  410. package/tag/types.d.ts +9 -9
  411. package/text-input/Suggestion.js +35 -25
  412. package/text-input/Suggestions.d.ts +1 -1
  413. package/text-input/Suggestions.js +30 -70
  414. package/text-input/TextInput.accessibility.test.d.ts +1 -0
  415. package/text-input/TextInput.accessibility.test.js +320 -0
  416. package/text-input/TextInput.js +285 -377
  417. package/text-input/TextInput.stories.tsx +158 -162
  418. package/text-input/TextInput.test.d.ts +1 -0
  419. package/text-input/TextInput.test.js +1389 -1347
  420. package/text-input/types.d.ts +29 -16
  421. package/textarea/Textarea.accessibility.test.d.ts +1 -0
  422. package/textarea/Textarea.accessibility.test.js +155 -0
  423. package/textarea/Textarea.js +67 -109
  424. package/textarea/Textarea.stories.tsx +174 -0
  425. package/textarea/Textarea.test.d.ts +1 -0
  426. package/textarea/Textarea.test.js +151 -182
  427. package/textarea/types.d.ts +9 -5
  428. package/toggle-group/ToggleGroup.accessibility.test.d.ts +1 -0
  429. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  430. package/toggle-group/ToggleGroup.d.ts +2 -2
  431. package/toggle-group/ToggleGroup.js +92 -108
  432. package/toggle-group/ToggleGroup.stories.tsx +53 -8
  433. package/toggle-group/ToggleGroup.test.d.ts +1 -0
  434. package/toggle-group/ToggleGroup.test.js +68 -87
  435. package/toggle-group/types.d.ts +28 -19
  436. package/tooltip/Tooltip.accessibility.test.d.ts +1 -0
  437. package/tooltip/Tooltip.accessibility.test.js +144 -0
  438. package/tooltip/Tooltip.d.ts +4 -0
  439. package/tooltip/Tooltip.js +50 -0
  440. package/tooltip/Tooltip.stories.tsx +111 -0
  441. package/tooltip/Tooltip.test.d.ts +1 -0
  442. package/tooltip/Tooltip.test.js +112 -0
  443. package/tooltip/types.d.ts +16 -0
  444. package/tooltip/types.js +5 -0
  445. package/typography/Typography.accessibility.test.d.ts +1 -0
  446. package/typography/Typography.accessibility.test.js +339 -0
  447. package/typography/Typography.d.ts +2 -2
  448. package/typography/Typography.js +15 -123
  449. package/typography/Typography.stories.tsx +1 -3
  450. package/typography/Typography.test.js +23 -0
  451. package/typography/types.d.ts +1 -1
  452. package/useTheme.d.ts +1167 -1
  453. package/useTheme.js +2 -9
  454. package/useTranslatedLabels.d.ts +95 -1
  455. package/useTranslatedLabels.js +1 -7
  456. package/utils/BaseTypography.d.ts +21 -0
  457. package/utils/BaseTypography.js +98 -0
  458. package/utils/FocusLock.d.ts +13 -0
  459. package/utils/FocusLock.js +125 -0
  460. package/wizard/Wizard.accessibility.test.d.ts +1 -0
  461. package/wizard/Wizard.accessibility.test.js +55 -0
  462. package/wizard/Wizard.js +29 -75
  463. package/wizard/Wizard.stories.tsx +40 -1
  464. package/wizard/Wizard.test.d.ts +1 -0
  465. package/wizard/Wizard.test.js +53 -80
  466. package/wizard/types.d.ts +10 -11
  467. package/card/ice-cream.jpg +0 -0
  468. package/common/OpenSans.css +0 -81
  469. package/common/RequiredComponent.js +0 -32
  470. package/common/fonts/OpenSans-Bold.ttf +0 -0
  471. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  472. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  473. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  474. package/common/fonts/OpenSans-Italic.ttf +0 -0
  475. package/common/fonts/OpenSans-Light.ttf +0 -0
  476. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  477. package/common/fonts/OpenSans-Regular.ttf +0 -0
  478. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  479. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  480. package/number-input/numberInputContextTypes.d.ts +0 -19
  481. package/paginator/Icons.js +0 -66
  482. package/resultsetTable/ResultsetTable.d.ts +0 -4
  483. package/resultsetTable/ResultsetTable.js +0 -254
  484. package/resultsetTable/ResultsetTable.test.js +0 -348
  485. package/select/Icons.d.ts +0 -10
  486. package/select/Icons.js +0 -93
  487. package/table/Table.stories.jsx +0 -277
  488. package/tabs-nav/NavTabs.d.ts +0 -8
  489. package/tabs-nav/NavTabs.js +0 -125
  490. package/tabs-nav/NavTabs.stories.tsx +0 -170
  491. package/tabs-nav/NavTabs.test.js +0 -82
  492. package/tabs-nav/Tab.js +0 -130
  493. package/text-input/Icons.d.ts +0 -8
  494. package/textarea/Textarea.stories.jsx +0 -157
  495. /package/{resultsetTable → action-icon}/types.js +0 -0
  496. /package/{tabs-nav → bar-chart}/types.js +0 -0
  497. /package/{number-input/numberInputContextTypes.js → breadcrumbs/types.js} +0 -0
  498. /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
@@ -1,24 +1,40 @@
1
1
  import React from "react";
2
- import { userEvent, within, waitFor } from "@storybook/testing-library";
2
+ import { userEvent, within } from "@storybook/test";
3
3
  import Title from "../../.storybook/components/Title";
4
4
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
5
5
  import DxcSelect from "./Select";
6
6
  import Listbox from "./Listbox";
7
- import DxcButton from "../button/Button";
8
- import DxcCheckbox from "../checkbox/Checkbox";
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";
9
13
 
10
14
  export default {
11
15
  title: "Select",
12
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
+ },
13
27
  };
14
28
 
15
29
  const one_option = [{ label: "Option 01", value: "1" }];
30
+
16
31
  const single_options = [
17
32
  { label: "Option 01", value: "1" },
18
33
  { label: "Option 02", value: "2" },
19
34
  { label: "Option 03", value: "3" },
20
35
  { label: "Option 04", value: "4" },
21
36
  ];
37
+
22
38
  const group_options = [
23
39
  {
24
40
  label: "Group 001",
@@ -61,25 +77,15 @@ const group_options = [
61
77
  ],
62
78
  },
63
79
  ];
64
- const icon_options_grouped = [
80
+
81
+ const icon_options_grouped_material = [
65
82
  {
66
83
  label: "Group 001",
67
84
  options: [
68
85
  {
69
86
  label: "3G Mobile",
70
87
  value: "1",
71
- icon: (
72
- <svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">
73
- <g>
74
- <path d="M0,0h24v24H0V0z" fill="none" />
75
- </g>
76
- <g>
77
- <g>
78
- <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" />
79
- </g>
80
- </g>
81
- </svg>
82
- ),
88
+ icon: "3g_mobiledata",
83
89
  },
84
90
  ],
85
91
  },
@@ -89,12 +95,7 @@ const icon_options_grouped = [
89
95
  {
90
96
  label: "Ethernet",
91
97
  value: "2",
92
- icon: (
93
- <svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">
94
- <path d="M0 0h24v24H0V0z" fill="none" />
95
- <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" />
96
- </svg>
97
- ),
98
+ icon: "settings_ethernet",
98
99
  },
99
100
  ],
100
101
  },
@@ -104,26 +105,17 @@ const icon_options_grouped = [
104
105
  {
105
106
  label: "Wi-fi",
106
107
  value: "3",
107
- icon: (
108
- <svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">
109
- <path d="M0 0h24v24H0V0zm0 0h24v24H0V0z" fill="none" />
110
- <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" />
111
- </svg>
112
- ),
108
+ icon: "wifi",
113
109
  },
114
110
  {
115
111
  label: "Settings backup restore (just for previous configuration)",
116
112
  value: "4",
117
- icon: (
118
- <svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">
119
- <path d="M0 0h24v24H0V0z" fill="none" />
120
- <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" />
121
- </svg>
122
- ),
113
+ icon: "settings_backup_restore",
123
114
  },
124
115
  ],
125
116
  },
126
117
  ];
118
+
127
119
  const icon_options = [
128
120
  {
129
121
  label: "3G Mobile",
@@ -172,60 +164,70 @@ const icon_options = [
172
164
  ),
173
165
  },
174
166
  ];
175
- const url_options = [
167
+
168
+ const options_material = [
176
169
  {
177
- label: "Social Media",
170
+ label: "Transport",
178
171
  options: [
179
172
  {
180
- label: "Instagram",
181
- value: "instagram",
182
- 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",
183
176
  },
184
177
  {
185
- label: "Twitter",
186
- value: "twitter",
187
- 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",
188
181
  },
189
182
  {
190
- label: "Facebook",
191
- value: "facebook",
192
- 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",
193
186
  },
194
187
  {
195
- label: "Pinterest",
196
- value: "pinterest",
197
- icon: "https://cdn-icons-png.flaticon.com/512/145/145808.png",
188
+ label: "Bike",
189
+ value: "bike",
190
+ icon: "pedal_bike",
198
191
  },
199
192
  ],
200
193
  },
201
194
  {
202
- label: "Design",
195
+ label: "Entertainment",
203
196
  options: [
204
197
  {
205
- label: "Figma",
206
- value: "figma",
207
- icon: "https://logowik.com/content/uploads/images/figma.jpg",
198
+ label: "Movie",
199
+ value: "movie",
200
+ icon: "movie",
208
201
  },
209
202
  {
210
- label: "Adobe XD",
211
- value: "adobexd",
212
- icon: "https://cdn.worldvectorlogo.com/logos/adobe-xd-2.svg",
203
+ label: "Music",
204
+ value: "music",
205
+ icon: "music_note",
213
206
  },
214
207
  {
215
- label: "Sketch",
216
- value: "sketch",
217
- icon: "https://cdn.worldvectorlogo.com/logos/sketch-2.svg",
208
+ label: "Games",
209
+ value: "games",
210
+ icon: "joystick",
218
211
  },
219
212
  ],
220
213
  },
221
214
  ];
215
+
222
216
  const optionsWithEllipsisMedium = [
223
217
  { label: "Optiond1234567890123456789012345678901234", value: "1" },
224
218
  { label: "Optiond12345678901234567890123456789012345", value: "2" },
225
219
  { label: "Option 031111111111111111111111111111222", value: "3" },
226
- { label: "Option 03111111111111111111111111111222", value: "4" },
227
220
  ];
228
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
  <>
231
233
  <Title title="States" theme="light" level={2} />
@@ -304,6 +306,14 @@ const Select = () => (
304
306
  <Title title="Fillparent size" theme="light" level={4} />
305
307
  <DxcSelect label="Fillparent" options={single_options} size="fillParent" />
306
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>
307
317
  <Title title="Margins" theme="light" level={2} />
308
318
  <ExampleContainer>
309
319
  <Title title="xxsmall margin" theme="light" level={4} />
@@ -338,123 +348,364 @@ const Select = () => (
338
348
  <Title title="Multiple selection with ellipsis" theme="light" level={4} />
339
349
  <DxcSelect label="Label" options={single_options} multiple defaultValue={["1", "2", "3", "4"]} />
340
350
  <Title title="Value with ellipsis" theme="light" level={4} />
341
- <DxcSelect label="Label" options={optionsWithEllipsisMedium} defaultValue="1" size="medium" />
351
+ <DxcSelect label="Label" options={optionsWithEllipsisMedium} defaultValue="1" />
342
352
  <Title title="Options with ellipsis" theme="light" level={4} />
343
353
  <DxcSelect
344
354
  label="Label"
345
355
  placeholder="Choose an option"
346
356
  defaultValue="1"
347
357
  options={optionsWithEllipsisMedium}
348
- size="medium"
358
+ margin={{ top: "xxlarge" }}
349
359
  />
350
360
  </ExampleContainer>
351
- </>
352
- );
353
- const SelectListbox = () => (
354
- <>
355
- <Title title="Listbox" theme="light" level={2} />
356
- <Title title="Default with opened listbox" theme="light" level={3} />
357
- <ExampleContainer>
358
- <div style={{ display: "flex", gap: "30px", flexDirection: "column", marginBottom: "80px" }}>
359
- <DxcSelect label="Label" options={single_options} optional placeholder="Choose an option" />
360
- <DxcCheckbox
361
- label="You understand the selection and give your consent"
362
- onChange={() => {}}
363
- labelPosition="after"
364
- />
365
- <DxcButton label="Submit" onClick={() => {}} size="medium" />
366
- </div>
367
- </ExampleContainer>
368
- <Title title="Listbox option states" theme="light" level={3} />
361
+ <Title title="Opinionated theme" theme="light" level={2} />
369
362
  <ExampleContainer pseudoState="pseudo-hover">
370
- <Title title="Hovered option" theme="light" level={4} />
371
- <Listbox
372
- id="x"
373
- currentValue=""
374
- options={one_option}
375
- visualFocusIndex={-1}
376
- lastOptionIndex={0}
377
- multiple={false}
378
- optional={false}
379
- optionalItem={{ label: "Empty", value: "" }}
380
- searchable={false}
381
- handleOptionOnClick={() => {}}
382
- getSelectWidth={() => 360}
383
- />
363
+ <Title title="Hovered" theme="light" level={4} />
364
+ <HalstackProvider theme={opinionatedTheme}>
365
+ <DxcSelect label="Hovered" options={single_options} />
366
+ </HalstackProvider>
384
367
  </ExampleContainer>
385
- <ExampleContainer pseudoState="pseudo-active">
386
- <Title title="Active option" theme="light" level={4} />
387
- <Listbox
388
- id="x"
389
- currentValue=""
390
- options={one_option}
391
- visualFocusIndex={-1}
392
- lastOptionIndex={0}
393
- multiple={false}
394
- optional={false}
395
- optionalItem={{ label: "Empty", value: "" }}
396
- searchable={false}
397
- handleOptionOnClick={() => {}}
398
- getSelectWidth={() => 360}
399
-
400
- />
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>
401
373
  </ExampleContainer>
402
374
  <ExampleContainer>
403
- <Title title="Focused option" theme="light" level={4} />
404
- <Listbox
405
- id="x"
406
- currentValue=""
407
- options={one_option}
408
- visualFocusIndex={0}
409
- lastOptionIndex={0}
410
- multiple={false}
411
- optional={false}
412
- optionalItem={{ label: "Empty", value: "" }}
413
- searchable={false}
414
- handleOptionOnClick={() => {}}
415
- getSelectWidth={() => 360}
416
- />
375
+ <Title title="Disabled" theme="light" level={4} />
376
+ <HalstackProvider theme={opinionatedTheme}>
377
+ <DxcSelect label="Disabled" placeholder="Placeholder" disabled options={single_options} />
378
+ </HalstackProvider>
417
379
  </ExampleContainer>
418
- <ExampleContainer pseudoState="pseudo-hover">
419
- <Title title="Hovered selected option" theme="light" level={4} />
420
- <Listbox
421
- id="x"
422
- currentValue="1"
423
- options={single_options}
424
- visualFocusIndex={-1}
425
- lastOptionIndex={3}
426
- multiple={false}
427
- optional={false}
428
- optionalItem={{ label: "Empty", value: "" }}
429
- searchable={false}
430
- handleOptionOnClick={() => {}}
431
- getSelectWidth={() => 360}
432
- />
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>
433
385
  </ExampleContainer>
434
- <ExampleContainer pseudoState="pseudo-active">
435
- <Title title="Active selected option" theme="light" level={4} />
436
- <Listbox
437
- id="x"
438
- currentValue="2"
439
- options={single_options}
440
- visualFocusIndex={0}
441
- lastOptionIndex={3}
442
- multiple={false}
443
- optional={false}
444
- optionalItem={{ label: "Empty", value: "" }}
445
- searchable={false}
446
- handleOptionOnClick={() => {}}
447
- getSelectWidth={() => 360}
448
- />
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>
449
409
  </ExampleContainer>
450
410
  </>
451
411
  );
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
+ );
691
+ };
692
+
452
693
  const SearchableSelect = () => (
453
694
  <ExampleContainer expanded>
454
695
  <Title title="Searchable select" theme="light" level={4} />
455
696
  <DxcSelect label="Select Label" searchable options={single_options} placeholder="Choose an option" />
456
697
  </ExampleContainer>
457
698
  );
699
+
700
+ const SearchableSelectOpinionated = () => (
701
+ <ExampleContainer expanded>
702
+ <Title title="Searchable select" theme="light" level={4} />
703
+ <HalstackProvider theme={opinionatedTheme}>
704
+ <DxcSelect label="Select Label" searchable options={single_options} placeholder="Choose an option" />
705
+ </HalstackProvider>
706
+ </ExampleContainer>
707
+ );
708
+
458
709
  const SearchValue = () => (
459
710
  <ExampleContainer expanded>
460
711
  <Title title="Searchable select with value" theme="light" level={4} />
@@ -467,6 +718,22 @@ const SearchValue = () => (
467
718
  />
468
719
  </ExampleContainer>
469
720
  );
721
+
722
+ const SearchValueOpinionated = () => (
723
+ <ExampleContainer expanded>
724
+ <Title title="Searchable select with value" theme="light" level={4} />
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>
734
+ </ExampleContainer>
735
+ );
736
+
470
737
  const MultipleSelect = () => (
471
738
  <>
472
739
  <ExampleContainer expanded>
@@ -481,12 +748,38 @@ const MultipleSelect = () => (
481
748
  </ExampleContainer>
482
749
  </>
483
750
  );
751
+
752
+ const MultipleSelectOpinionated = () => (
753
+ <ExampleContainer expanded>
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>
764
+ </ExampleContainer>
765
+ );
766
+
484
767
  const DefaultGroupedOptionsSelect = () => (
485
768
  <ExampleContainer expanded>
486
769
  <Title title="Grouped options simple select" theme="light" level={4} />
487
770
  <DxcSelect label="Label" options={group_options} defaultValue="9" placeholder="Choose an option" />
488
771
  </ExampleContainer>
489
772
  );
773
+
774
+ const DefaultGroupedOptionsSelectOpinionated = () => (
775
+ <ExampleContainer expanded>
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>
780
+ </ExampleContainer>
781
+ );
782
+
490
783
  const MultipleGroupedOptionsSelect = () => (
491
784
  <ExampleContainer expanded>
492
785
  <Title title="Grouped options multiple select" theme="light" level={4} />
@@ -499,34 +792,19 @@ const MultipleGroupedOptionsSelect = () => (
499
792
  />
500
793
  </ExampleContainer>
501
794
  );
502
- const RescaledIcons = () => (
503
- <ExampleContainer expanded>
504
- <Title title="Rescaled icons displayed" theme="light" level={4} />
505
- <DxcSelect label="Label" options={url_options} defaultValue="facebook" placeholder="Choose an option" />
506
- </ExampleContainer>
507
- );
508
- const SelectWithIcons = () => (
509
- <ExampleContainer expanded>
510
- <Title title="Normal icons displayed" theme="light" level={4} />
511
- <DxcSelect label="Label" options={icon_options} defaultValue="3" placeholder="Choose an option" />
512
- </ExampleContainer>
513
- );
514
- const SelectMultipleWithIcons = () => (
515
- <ExampleContainer expanded>
516
- <Title title="Multiple select with icons" theme="light" level={4} />
517
- <DxcSelect label="Label" options={icon_options} multiple defaultValue={["1", "3"]} placeholder="Choose an option" />
518
- </ExampleContainer>
519
- );
520
- const MultipleGroupedOptionsSelectWithIcons = () => (
795
+
796
+ const MultipleGroupedOptionsSelectOpinionated = () => (
521
797
  <ExampleContainer expanded>
522
- <Title title="Multiple grouped options with icons" theme="light" level={4} />
523
- <DxcSelect
524
- label="Label"
525
- options={icon_options_grouped}
526
- multiple
527
- defaultValue={["3", "2"]}
528
- placeholder="Choose an option"
529
- />
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>
530
808
  </ExampleContainer>
531
809
  );
532
810
 
@@ -544,6 +822,22 @@ const MultipleSearchable = () => (
544
822
  </ExampleContainer>
545
823
  );
546
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
+
547
841
  export const Chromatic = Select.bind({});
548
842
  Chromatic.play = async ({ canvasElement }) => {
549
843
  const canvas = within(canvasElement);
@@ -560,10 +854,13 @@ ListboxStates.play = async ({ canvasElement }) => {
560
854
  export const Searchable = SearchableSelect.bind({});
561
855
  Searchable.play = async ({ canvasElement }) => {
562
856
  const canvas = within(canvasElement);
563
- await userEvent.click(canvas.getByRole("combobox"));
564
- await waitFor(async () => {
565
- userEvent.type(canvas.getByRole("combobox"), "r");
566
- });
857
+ await userEvent.type(canvas.getByRole("combobox"), "r");
858
+ };
859
+
860
+ export const SearchableOpinionated = SearchableSelectOpinionated.bind({});
861
+ SearchableOpinionated.play = async ({ canvasElement }) => {
862
+ const canvas = within(canvasElement);
863
+ await userEvent.type(canvas.getByRole("combobox"), "r");
567
864
  };
568
865
 
569
866
  export const SearchableWithValue = SearchValue.bind({});
@@ -572,12 +869,24 @@ SearchableWithValue.play = async ({ canvasElement }) => {
572
869
  await userEvent.click(canvas.getByRole("combobox"));
573
870
  };
574
871
 
872
+ export const SearchableWithValueOpinionated = SearchValueOpinionated.bind({});
873
+ SearchableWithValueOpinionated.play = async ({ canvasElement }) => {
874
+ const canvas = within(canvasElement);
875
+ await userEvent.click(canvas.getByRole("combobox"));
876
+ };
877
+
575
878
  export const MultipleSearchableWithValue = MultipleSearchable.bind({});
576
879
  MultipleSearchableWithValue.play = async ({ canvasElement }) => {
577
880
  const canvas = within(canvasElement);
578
881
  await userEvent.click(canvas.getAllByRole("combobox")[0]);
579
882
  };
580
883
 
884
+ export const MultipleSearchableWithValueOpinionated = MultipleSearchableOpinionated.bind({});
885
+ MultipleSearchableWithValueOpinionated.play = async ({ canvasElement }) => {
886
+ const canvas = within(canvasElement);
887
+ await userEvent.click(canvas.getAllByRole("combobox")[0]);
888
+ };
889
+
581
890
  export const GroupOptionsDisplayed = DefaultGroupedOptionsSelect.bind({});
582
891
  GroupOptionsDisplayed.play = async ({ canvasElement }) => {
583
892
  const canvas = within(canvasElement);
@@ -585,42 +894,34 @@ GroupOptionsDisplayed.play = async ({ canvasElement }) => {
585
894
  await userEvent.click(select);
586
895
  };
587
896
 
588
- export const MultipleOptionsDisplayed = MultipleSelect.bind({});
589
- MultipleOptionsDisplayed.play = async ({ canvasElement }) => {
590
- const canvas = within(canvasElement);
591
- await userEvent.click(canvas.getAllByRole("combobox")[0]);
592
- };
593
-
594
- export const MultipleGroupedOptionsDisplayed = MultipleGroupedOptionsSelect.bind({});
595
- MultipleGroupedOptionsDisplayed.play = async ({ canvasElement }) => {
897
+ export const GroupOptionsDisplayedOpinionated = DefaultGroupedOptionsSelectOpinionated.bind({});
898
+ GroupOptionsDisplayedOpinionated.play = async ({ canvasElement }) => {
596
899
  const canvas = within(canvasElement);
597
900
  const select = canvas.getByRole("combobox");
598
901
  await userEvent.click(select);
599
902
  };
600
903
 
601
- export const WithIconsDisplayed = SelectWithIcons.bind({});
602
- WithIconsDisplayed.play = async ({ canvasElement }) => {
904
+ export const MultipleOptionsDisplayed = MultipleSelect.bind({});
905
+ MultipleOptionsDisplayed.play = async ({ canvasElement }) => {
603
906
  const canvas = within(canvasElement);
604
- const select = canvas.getByRole("combobox");
605
- await userEvent.click(select);
907
+ await userEvent.click(canvas.getAllByRole("combobox")[0]);
606
908
  };
607
909
 
608
- export const WithRescaledIconsDisplayed = RescaledIcons.bind({});
609
- WithRescaledIconsDisplayed.play = async ({ canvasElement }) => {
910
+ export const MultipleOptionsDisplayedOpinionated = MultipleSelectOpinionated.bind({});
911
+ MultipleOptionsDisplayedOpinionated.play = async ({ canvasElement }) => {
610
912
  const canvas = within(canvasElement);
611
- const select = canvas.getByRole("combobox");
612
- await userEvent.click(select);
913
+ await userEvent.click(canvas.getAllByRole("combobox")[0]);
613
914
  };
614
915
 
615
- export const MultipleWithIconsDisplayed = SelectMultipleWithIcons.bind({});
616
- MultipleWithIconsDisplayed.play = async ({ canvasElement }) => {
916
+ export const MultipleGroupedOptionsDisplayed = MultipleGroupedOptionsSelect.bind({});
917
+ MultipleGroupedOptionsDisplayed.play = async ({ canvasElement }) => {
617
918
  const canvas = within(canvasElement);
618
919
  const select = canvas.getByRole("combobox");
619
920
  await userEvent.click(select);
620
921
  };
621
922
 
622
- export const MultipleGroupedWithIconsDisplayed = MultipleGroupedOptionsSelectWithIcons.bind({});
623
- MultipleGroupedWithIconsDisplayed.play = async ({ canvasElement }) => {
923
+ export const MultipleGroupedOptionsDisplayedOpinionated = MultipleGroupedOptionsSelectOpinionated.bind({});
924
+ MultipleGroupedOptionsDisplayedOpinionated.play = async ({ canvasElement }) => {
624
925
  const canvas = within(canvasElement);
625
926
  const select = canvas.getByRole("combobox");
626
927
  await userEvent.click(select);