@dxc-technology/halstack-react 0.0.0-a062293 → 0.0.0-a0fadb7

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 (471) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +5 -22
  3. package/HalstackContext.d.ts +1237 -6
  4. package/HalstackContext.js +123 -111
  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 +41 -112
  10. package/accordion/Accordion.stories.tsx +52 -157
  11. package/accordion/Accordion.test.d.ts +1 -0
  12. package/accordion/Accordion.test.js +18 -33
  13. package/accordion/types.d.ts +6 -18
  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 -19
  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/bleed/Bleed.js +13 -21
  50. package/bleed/Bleed.stories.tsx +1 -0
  51. package/bleed/types.d.ts +2 -2
  52. package/box/Box.accessibility.test.d.ts +1 -0
  53. package/box/Box.accessibility.test.js +33 -0
  54. package/box/Box.d.ts +1 -1
  55. package/box/Box.js +18 -59
  56. package/box/Box.stories.tsx +38 -51
  57. package/box/Box.test.d.ts +1 -0
  58. package/box/Box.test.js +1 -6
  59. package/box/types.d.ts +3 -15
  60. package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
  61. package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
  62. package/breadcrumbs/Breadcrumbs.d.ts +4 -0
  63. package/breadcrumbs/Breadcrumbs.js +79 -0
  64. package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
  65. package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
  66. package/breadcrumbs/Breadcrumbs.test.js +169 -0
  67. package/breadcrumbs/Item.d.ts +4 -0
  68. package/breadcrumbs/Item.js +52 -0
  69. package/breadcrumbs/dropdownTheme.d.ts +53 -0
  70. package/breadcrumbs/dropdownTheme.js +62 -0
  71. package/breadcrumbs/types.d.ts +16 -0
  72. package/bulleted-list/BulletedList.accessibility.test.d.ts +1 -0
  73. package/bulleted-list/BulletedList.accessibility.test.js +119 -0
  74. package/bulleted-list/BulletedList.js +22 -53
  75. package/bulleted-list/BulletedList.stories.tsx +8 -93
  76. package/bulleted-list/types.d.ts +32 -5
  77. package/button/Button.accessibility.test.d.ts +1 -0
  78. package/button/Button.accessibility.test.js +127 -0
  79. package/button/Button.d.ts +1 -1
  80. package/button/Button.js +70 -103
  81. package/button/Button.stories.tsx +107 -116
  82. package/button/Button.test.d.ts +1 -0
  83. package/button/Button.test.js +19 -16
  84. package/button/types.d.ts +9 -5
  85. package/card/Card.accessibility.test.d.ts +1 -0
  86. package/card/Card.accessibility.test.js +36 -0
  87. package/card/Card.d.ts +1 -1
  88. package/card/Card.js +49 -89
  89. package/card/Card.stories.tsx +12 -42
  90. package/card/Card.test.d.ts +1 -0
  91. package/card/Card.test.js +10 -21
  92. package/card/types.d.ts +6 -12
  93. package/checkbox/Checkbox.accessibility.test.d.ts +1 -0
  94. package/checkbox/Checkbox.accessibility.test.js +87 -0
  95. package/checkbox/Checkbox.js +90 -128
  96. package/checkbox/Checkbox.stories.tsx +68 -54
  97. package/checkbox/Checkbox.test.d.ts +1 -0
  98. package/checkbox/Checkbox.test.js +107 -63
  99. package/checkbox/types.d.ts +8 -4
  100. package/chip/Chip.accessibility.test.d.ts +1 -0
  101. package/chip/Chip.accessibility.test.js +69 -0
  102. package/chip/Chip.js +42 -76
  103. package/chip/Chip.stories.tsx +120 -40
  104. package/chip/Chip.test.d.ts +1 -0
  105. package/chip/Chip.test.js +17 -32
  106. package/chip/types.d.ts +38 -15
  107. package/common/coreTokens.d.ts +237 -0
  108. package/common/coreTokens.js +184 -0
  109. package/common/fonts.css +2 -0
  110. package/common/utils.d.ts +1 -0
  111. package/common/utils.js +6 -12
  112. package/common/variables.d.ts +1389 -0
  113. package/common/variables.js +957 -1208
  114. package/container/Container.d.ts +4 -0
  115. package/container/Container.js +194 -0
  116. package/container/Container.stories.tsx +214 -0
  117. package/container/types.d.ts +74 -0
  118. package/contextual-menu/ContextualMenu.accessibility.test.d.ts +1 -0
  119. package/contextual-menu/ContextualMenu.accessibility.test.js +98 -0
  120. package/contextual-menu/ContextualMenu.d.ts +5 -0
  121. package/contextual-menu/ContextualMenu.js +88 -0
  122. package/contextual-menu/ContextualMenu.stories.tsx +232 -0
  123. package/contextual-menu/ContextualMenu.test.d.ts +1 -0
  124. package/contextual-menu/ContextualMenu.test.js +205 -0
  125. package/contextual-menu/GroupItem.d.ts +4 -0
  126. package/contextual-menu/GroupItem.js +67 -0
  127. package/contextual-menu/ItemAction.d.ts +4 -0
  128. package/contextual-menu/ItemAction.js +51 -0
  129. package/contextual-menu/MenuItem.d.ts +4 -0
  130. package/contextual-menu/MenuItem.js +29 -0
  131. package/contextual-menu/SingleItem.d.ts +4 -0
  132. package/contextual-menu/SingleItem.js +38 -0
  133. package/contextual-menu/types.d.ts +58 -0
  134. package/contextual-menu/types.js +5 -0
  135. package/date-input/Calendar.js +38 -70
  136. package/date-input/DateInput.accessibility.test.d.ts +1 -0
  137. package/date-input/DateInput.accessibility.test.js +230 -0
  138. package/date-input/DateInput.js +61 -108
  139. package/date-input/DateInput.stories.tsx +86 -31
  140. package/date-input/DateInput.test.d.ts +1 -0
  141. package/date-input/DateInput.test.js +676 -702
  142. package/date-input/DatePicker.js +46 -57
  143. package/date-input/YearPicker.js +28 -44
  144. package/date-input/types.d.ts +28 -22
  145. package/dialog/Dialog.accessibility.test.d.ts +1 -0
  146. package/dialog/Dialog.accessibility.test.js +69 -0
  147. package/dialog/Dialog.d.ts +1 -1
  148. package/dialog/Dialog.js +51 -120
  149. package/dialog/Dialog.stories.tsx +315 -212
  150. package/dialog/Dialog.test.d.ts +1 -0
  151. package/dialog/Dialog.test.js +333 -32
  152. package/dialog/types.d.ts +18 -26
  153. package/divider/Divider.accessibility.test.d.ts +1 -0
  154. package/divider/Divider.accessibility.test.js +33 -0
  155. package/divider/Divider.d.ts +4 -0
  156. package/divider/Divider.js +36 -0
  157. package/divider/Divider.stories.tsx +223 -0
  158. package/divider/Divider.test.d.ts +1 -0
  159. package/divider/Divider.test.js +38 -0
  160. package/divider/types.d.ts +21 -0
  161. package/divider/types.js +5 -0
  162. package/dropdown/Dropdown.accessibility.test.d.ts +1 -0
  163. package/dropdown/Dropdown.accessibility.test.js +184 -0
  164. package/dropdown/Dropdown.js +69 -138
  165. package/dropdown/Dropdown.stories.tsx +205 -98
  166. package/dropdown/Dropdown.test.d.ts +1 -0
  167. package/dropdown/Dropdown.test.js +434 -390
  168. package/dropdown/DropdownMenu.js +23 -40
  169. package/dropdown/DropdownMenuItem.js +17 -38
  170. package/dropdown/types.d.ts +20 -24
  171. package/file-input/FileInput.accessibility.test.d.ts +1 -0
  172. package/file-input/FileInput.accessibility.test.js +167 -0
  173. package/file-input/FileInput.js +183 -294
  174. package/file-input/FileInput.stories.tsx +86 -3
  175. package/file-input/FileInput.test.d.ts +1 -0
  176. package/file-input/FileInput.test.js +301 -395
  177. package/file-input/FileItem.js +31 -67
  178. package/file-input/types.d.ts +10 -10
  179. package/flex/Flex.js +27 -39
  180. package/flex/Flex.stories.tsx +35 -26
  181. package/flex/types.d.ts +74 -9
  182. package/footer/Footer.accessibility.test.d.ts +1 -0
  183. package/footer/Footer.accessibility.test.js +125 -0
  184. package/footer/Footer.d.ts +1 -1
  185. package/footer/Footer.js +73 -118
  186. package/footer/Footer.stories.tsx +94 -23
  187. package/footer/Footer.test.d.ts +1 -0
  188. package/footer/Footer.test.js +32 -56
  189. package/footer/Icons.d.ts +3 -2
  190. package/footer/Icons.js +53 -22
  191. package/footer/types.d.ts +26 -28
  192. package/grid/Grid.d.ts +7 -0
  193. package/grid/Grid.js +76 -0
  194. package/grid/Grid.stories.tsx +219 -0
  195. package/grid/types.d.ts +115 -0
  196. package/grid/types.js +5 -0
  197. package/header/Header.accessibility.test.d.ts +1 -0
  198. package/header/Header.accessibility.test.js +94 -0
  199. package/header/Header.d.ts +4 -3
  200. package/header/Header.js +55 -150
  201. package/header/Header.stories.tsx +130 -35
  202. package/header/Header.test.d.ts +1 -0
  203. package/header/Header.test.js +12 -25
  204. package/header/Icons.d.ts +2 -2
  205. package/header/Icons.js +3 -13
  206. package/header/types.d.ts +7 -22
  207. package/heading/Heading.accessibility.test.d.ts +1 -0
  208. package/heading/Heading.accessibility.test.js +33 -0
  209. package/heading/Heading.js +10 -32
  210. package/heading/Heading.test.d.ts +1 -0
  211. package/heading/Heading.test.js +64 -94
  212. package/heading/types.d.ts +7 -7
  213. package/icon/Icon.accessibility.test.d.ts +1 -0
  214. package/icon/Icon.accessibility.test.js +30 -0
  215. package/icon/Icon.d.ts +4 -0
  216. package/icon/Icon.js +33 -0
  217. package/icon/Icon.stories.tsx +28 -0
  218. package/icon/types.d.ts +4 -0
  219. package/icon/types.js +5 -0
  220. package/image/Image.accessibility.test.d.ts +1 -0
  221. package/image/Image.accessibility.test.js +56 -0
  222. package/image/Image.d.ts +4 -0
  223. package/image/Image.js +70 -0
  224. package/image/Image.stories.tsx +129 -0
  225. package/image/types.d.ts +72 -0
  226. package/image/types.js +5 -0
  227. package/inset/Inset.js +13 -21
  228. package/inset/Inset.stories.tsx +2 -1
  229. package/inset/types.d.ts +2 -2
  230. package/layout/ApplicationLayout.d.ts +5 -5
  231. package/layout/ApplicationLayout.js +36 -70
  232. package/layout/ApplicationLayout.stories.tsx +1 -1
  233. package/layout/Icons.d.ts +7 -5
  234. package/layout/Icons.js +41 -59
  235. package/layout/types.d.ts +5 -6
  236. package/link/Link.accessibility.test.d.ts +1 -0
  237. package/link/Link.accessibility.test.js +108 -0
  238. package/link/Link.js +31 -50
  239. package/link/Link.stories.tsx +64 -4
  240. package/link/Link.test.d.ts +1 -0
  241. package/link/Link.test.js +23 -43
  242. package/link/types.d.ts +14 -14
  243. package/main.d.ts +12 -5
  244. package/main.js +55 -59
  245. package/nav-tabs/NavTabs.accessibility.test.d.ts +1 -0
  246. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  247. package/nav-tabs/NavTabs.d.ts +7 -0
  248. package/nav-tabs/NavTabs.js +108 -0
  249. package/nav-tabs/NavTabs.stories.tsx +294 -0
  250. package/nav-tabs/NavTabs.test.d.ts +1 -0
  251. package/nav-tabs/NavTabs.test.js +77 -0
  252. package/nav-tabs/NavTabsContext.d.ts +3 -0
  253. package/nav-tabs/NavTabsContext.js +8 -0
  254. package/nav-tabs/Tab.js +117 -0
  255. package/{tabs-nav → nav-tabs}/types.d.ts +15 -16
  256. package/nav-tabs/types.js +5 -0
  257. package/number-input/NumberInput.accessibility.test.d.ts +1 -0
  258. package/number-input/NumberInput.accessibility.test.js +228 -0
  259. package/number-input/NumberInput.js +46 -36
  260. package/number-input/NumberInput.stories.tsx +42 -26
  261. package/number-input/NumberInput.test.d.ts +1 -0
  262. package/number-input/NumberInput.test.js +859 -412
  263. package/number-input/NumberInputContext.d.ts +3 -4
  264. package/number-input/NumberInputContext.js +3 -14
  265. package/number-input/types.d.ts +17 -5
  266. package/package.json +45 -41
  267. package/paginator/Paginator.accessibility.test.d.ts +1 -0
  268. package/paginator/Paginator.accessibility.test.js +79 -0
  269. package/paginator/Paginator.js +29 -56
  270. package/paginator/Paginator.stories.tsx +24 -0
  271. package/paginator/Paginator.test.d.ts +1 -0
  272. package/paginator/Paginator.test.js +234 -214
  273. package/paginator/types.d.ts +3 -3
  274. package/paragraph/Paragraph.accessibility.test.d.ts +1 -0
  275. package/paragraph/Paragraph.accessibility.test.js +28 -0
  276. package/paragraph/Paragraph.d.ts +3 -4
  277. package/paragraph/Paragraph.js +6 -22
  278. package/paragraph/Paragraph.stories.tsx +0 -17
  279. package/password-input/PasswordInput.accessibility.test.d.ts +1 -0
  280. package/password-input/PasswordInput.accessibility.test.js +153 -0
  281. package/password-input/PasswordInput.js +58 -127
  282. package/password-input/PasswordInput.stories.tsx +1 -33
  283. package/password-input/PasswordInput.test.d.ts +1 -0
  284. package/password-input/PasswordInput.test.js +157 -140
  285. package/password-input/types.d.ts +8 -7
  286. package/progress-bar/ProgressBar.accessibility.test.d.ts +1 -0
  287. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  288. package/progress-bar/ProgressBar.d.ts +2 -2
  289. package/progress-bar/ProgressBar.js +28 -58
  290. package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +36 -3
  291. package/progress-bar/ProgressBar.test.d.ts +1 -0
  292. package/progress-bar/ProgressBar.test.js +35 -52
  293. package/progress-bar/types.d.ts +4 -3
  294. package/quick-nav/QuickNav.accessibility.test.d.ts +1 -0
  295. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  296. package/quick-nav/QuickNav.js +4 -27
  297. package/quick-nav/QuickNav.stories.tsx +15 -1
  298. package/quick-nav/types.d.ts +10 -10
  299. package/radio-group/Radio.d.ts +1 -1
  300. package/radio-group/Radio.js +31 -66
  301. package/radio-group/RadioGroup.accessibility.test.d.ts +1 -0
  302. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  303. package/radio-group/RadioGroup.js +48 -98
  304. package/radio-group/RadioGroup.stories.tsx +131 -18
  305. package/radio-group/RadioGroup.test.d.ts +1 -0
  306. package/radio-group/RadioGroup.test.js +506 -474
  307. package/radio-group/types.d.ts +8 -8
  308. package/resultset-table/Icons.d.ts +7 -0
  309. package/{resultsetTable → resultset-table}/Icons.js +1 -5
  310. package/resultset-table/ResultsetTable.accessibility.test.d.ts +1 -0
  311. package/resultset-table/ResultsetTable.accessibility.test.js +285 -0
  312. package/resultset-table/ResultsetTable.d.ts +7 -0
  313. package/{resultsetTable → resultset-table}/ResultsetTable.js +47 -71
  314. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +118 -5
  315. package/resultset-table/ResultsetTable.test.d.ts +1 -0
  316. package/{resultsetTable → resultset-table}/ResultsetTable.test.js +147 -92
  317. package/{resultsetTable → resultset-table}/types.d.ts +44 -11
  318. package/resultset-table/types.js +5 -0
  319. package/select/Listbox.js +36 -54
  320. package/select/Option.js +28 -36
  321. package/select/Select.accessibility.test.d.ts +1 -0
  322. package/select/Select.accessibility.test.js +228 -0
  323. package/select/Select.js +118 -182
  324. package/select/Select.stories.tsx +504 -255
  325. package/select/Select.test.d.ts +1 -0
  326. package/select/Select.test.js +1903 -1863
  327. package/select/types.d.ts +15 -16
  328. package/sidenav/Sidenav.accessibility.test.d.ts +1 -0
  329. package/sidenav/Sidenav.accessibility.test.js +59 -0
  330. package/sidenav/Sidenav.d.ts +2 -2
  331. package/sidenav/Sidenav.js +90 -155
  332. package/sidenav/Sidenav.stories.tsx +113 -25
  333. package/sidenav/Sidenav.test.d.ts +1 -0
  334. package/sidenav/Sidenav.test.js +4 -11
  335. package/{layout → sidenav}/SidenavContext.d.ts +1 -1
  336. package/{layout → sidenav}/SidenavContext.js +3 -9
  337. package/sidenav/types.d.ts +33 -30
  338. package/slider/Slider.accessibility.test.d.ts +1 -0
  339. package/slider/Slider.accessibility.test.js +104 -0
  340. package/slider/Slider.js +68 -128
  341. package/slider/Slider.stories.tsx +57 -60
  342. package/slider/Slider.test.d.ts +1 -0
  343. package/slider/Slider.test.js +118 -111
  344. package/slider/types.d.ts +4 -4
  345. package/spinner/Spinner.accessibility.test.d.ts +1 -0
  346. package/spinner/Spinner.accessibility.test.js +96 -0
  347. package/spinner/Spinner.js +32 -72
  348. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
  349. package/spinner/Spinner.test.d.ts +1 -0
  350. package/spinner/Spinner.test.js +25 -34
  351. package/spinner/types.d.ts +3 -3
  352. package/status-light/StatusLight.accessibility.test.d.ts +1 -0
  353. package/status-light/StatusLight.accessibility.test.js +157 -0
  354. package/status-light/StatusLight.d.ts +4 -0
  355. package/status-light/StatusLight.js +51 -0
  356. package/status-light/StatusLight.stories.tsx +74 -0
  357. package/status-light/StatusLight.test.d.ts +1 -0
  358. package/status-light/StatusLight.test.js +25 -0
  359. package/status-light/types.d.ts +17 -0
  360. package/status-light/types.js +5 -0
  361. package/switch/Switch.accessibility.test.d.ts +1 -0
  362. package/switch/Switch.accessibility.test.js +98 -0
  363. package/switch/Switch.js +51 -102
  364. package/switch/Switch.stories.tsx +45 -34
  365. package/switch/Switch.test.d.ts +1 -0
  366. package/switch/Switch.test.js +51 -96
  367. package/switch/types.d.ts +4 -4
  368. package/table/DropdownTheme.js +62 -0
  369. package/table/Table.accessibility.test.d.ts +1 -0
  370. package/table/Table.accessibility.test.js +93 -0
  371. package/table/Table.d.ts +6 -2
  372. package/table/Table.js +78 -35
  373. package/table/Table.stories.tsx +663 -0
  374. package/table/Table.test.d.ts +1 -0
  375. package/table/Table.test.js +92 -6
  376. package/table/types.d.ts +34 -6
  377. package/tabs/Tab.js +27 -43
  378. package/tabs/Tabs.accessibility.test.d.ts +1 -0
  379. package/tabs/Tabs.accessibility.test.js +56 -0
  380. package/tabs/Tabs.js +69 -163
  381. package/tabs/Tabs.stories.tsx +46 -4
  382. package/tabs/Tabs.test.d.ts +1 -0
  383. package/tabs/Tabs.test.js +60 -135
  384. package/tabs/types.d.ts +21 -21
  385. package/tag/Tag.accessibility.test.d.ts +1 -0
  386. package/tag/Tag.accessibility.test.js +69 -0
  387. package/tag/Tag.js +34 -66
  388. package/tag/Tag.stories.tsx +18 -8
  389. package/tag/Tag.test.d.ts +1 -0
  390. package/tag/Tag.test.js +17 -36
  391. package/tag/types.d.ts +9 -9
  392. package/text-input/Suggestion.js +11 -28
  393. package/text-input/Suggestions.d.ts +1 -1
  394. package/text-input/Suggestions.js +30 -70
  395. package/text-input/TextInput.accessibility.test.d.ts +1 -0
  396. package/text-input/TextInput.accessibility.test.js +321 -0
  397. package/text-input/TextInput.js +224 -328
  398. package/text-input/TextInput.stories.tsx +133 -160
  399. package/text-input/TextInput.test.d.ts +1 -0
  400. package/text-input/TextInput.test.js +1227 -1195
  401. package/text-input/types.d.ts +25 -17
  402. package/textarea/Textarea.accessibility.test.d.ts +1 -0
  403. package/textarea/Textarea.accessibility.test.js +155 -0
  404. package/textarea/Textarea.js +70 -115
  405. package/textarea/Textarea.stories.tsx +174 -0
  406. package/textarea/Textarea.test.d.ts +1 -0
  407. package/textarea/Textarea.test.js +151 -182
  408. package/textarea/types.d.ts +9 -5
  409. package/toggle-group/ToggleGroup.accessibility.test.d.ts +1 -0
  410. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  411. package/toggle-group/ToggleGroup.d.ts +2 -2
  412. package/toggle-group/ToggleGroup.js +92 -108
  413. package/toggle-group/ToggleGroup.stories.tsx +52 -7
  414. package/toggle-group/ToggleGroup.test.d.ts +1 -0
  415. package/toggle-group/ToggleGroup.test.js +68 -87
  416. package/toggle-group/types.d.ts +28 -19
  417. package/typography/Typography.accessibility.test.d.ts +1 -0
  418. package/typography/Typography.accessibility.test.js +339 -0
  419. package/typography/Typography.d.ts +2 -2
  420. package/typography/Typography.js +15 -123
  421. package/typography/Typography.stories.tsx +1 -1
  422. package/typography/types.d.ts +1 -1
  423. package/useTheme.d.ts +1141 -1
  424. package/useTheme.js +2 -9
  425. package/useTranslatedLabels.d.ts +84 -1
  426. package/useTranslatedLabels.js +1 -7
  427. package/utils/BaseTypography.d.ts +21 -0
  428. package/utils/BaseTypography.js +94 -0
  429. package/utils/FocusLock.d.ts +13 -0
  430. package/utils/FocusLock.js +124 -0
  431. package/wizard/Wizard.accessibility.test.d.ts +1 -0
  432. package/wizard/Wizard.accessibility.test.js +55 -0
  433. package/wizard/Wizard.js +29 -75
  434. package/wizard/Wizard.stories.tsx +39 -0
  435. package/wizard/Wizard.test.d.ts +1 -0
  436. package/wizard/Wizard.test.js +53 -80
  437. package/wizard/types.d.ts +10 -11
  438. package/card/ice-cream.jpg +0 -0
  439. package/common/OpenSans.css +0 -81
  440. package/common/fonts/OpenSans-Bold.ttf +0 -0
  441. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  442. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  443. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  444. package/common/fonts/OpenSans-Italic.ttf +0 -0
  445. package/common/fonts/OpenSans-Light.ttf +0 -0
  446. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  447. package/common/fonts/OpenSans-Regular.ttf +0 -0
  448. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  449. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  450. package/date-input/Icons.d.ts +0 -6
  451. package/date-input/Icons.js +0 -75
  452. package/number-input/numberInputContextTypes.d.ts +0 -19
  453. package/paginator/Icons.d.ts +0 -5
  454. package/paginator/Icons.js +0 -54
  455. package/resultsetTable/Icons.d.ts +0 -7
  456. package/resultsetTable/ResultsetTable.d.ts +0 -4
  457. package/select/Icons.d.ts +0 -10
  458. package/select/Icons.js +0 -93
  459. package/table/Table.stories.jsx +0 -277
  460. package/tabs-nav/NavTabs.d.ts +0 -8
  461. package/tabs-nav/NavTabs.js +0 -125
  462. package/tabs-nav/NavTabs.stories.tsx +0 -172
  463. package/tabs-nav/NavTabs.test.js +0 -82
  464. package/tabs-nav/Tab.js +0 -128
  465. package/text-input/Icons.d.ts +0 -8
  466. package/text-input/Icons.js +0 -60
  467. package/textarea/Textarea.stories.jsx +0 -157
  468. /package/{resultsetTable → action-icon}/types.js +0 -0
  469. /package/{tabs-nav → breadcrumbs}/types.js +0 -0
  470. /package/{number-input/numberInputContextTypes.js → container/types.js} +0 -0
  471. /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
@@ -6,19 +6,34 @@ import DxcSelect from "./Select";
6
6
  import Listbox from "./Listbox";
7
7
  import { ThemeProvider } from "styled-components";
8
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";
9
12
 
10
13
  export default {
11
14
  title: "Select",
12
15
  component: DxcSelect,
16
+ parameters: {
17
+ a11y: {
18
+ config: {
19
+ rules: [
20
+ ...disabledRules.map((ruleId) => ({ id: ruleId, reviewOnFail: true })),
21
+ ...preview?.parameters?.a11y?.config?.rules,
22
+ ],
23
+ },
24
+ },
25
+ },
13
26
  };
14
27
 
15
28
  const one_option = [{ label: "Option 01", value: "1" }];
29
+
16
30
  const single_options = [
17
31
  { label: "Option 01", value: "1" },
18
32
  { label: "Option 02", value: "2" },
19
33
  { label: "Option 03", value: "3" },
20
34
  { label: "Option 04", value: "4" },
21
35
  ];
36
+
22
37
  const group_options = [
23
38
  {
24
39
  label: "Group 001",
@@ -61,25 +76,15 @@ const group_options = [
61
76
  ],
62
77
  },
63
78
  ];
64
- const icon_options_grouped = [
79
+
80
+ const icon_options_grouped_material = [
65
81
  {
66
82
  label: "Group 001",
67
83
  options: [
68
84
  {
69
85
  label: "3G Mobile",
70
86
  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
- ),
87
+ icon: "3g_mobiledata",
83
88
  },
84
89
  ],
85
90
  },
@@ -89,12 +94,7 @@ const icon_options_grouped = [
89
94
  {
90
95
  label: "Ethernet",
91
96
  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
- ),
97
+ icon: "settings_ethernet",
98
98
  },
99
99
  ],
100
100
  },
@@ -104,26 +104,17 @@ const icon_options_grouped = [
104
104
  {
105
105
  label: "Wi-fi",
106
106
  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
- ),
107
+ icon: "wifi",
113
108
  },
114
109
  {
115
110
  label: "Settings backup restore (just for previous configuration)",
116
111
  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
- ),
112
+ icon: "settings_backup_restore",
123
113
  },
124
114
  ],
125
115
  },
126
116
  ];
117
+
127
118
  const icon_options = [
128
119
  {
129
120
  label: "3G Mobile",
@@ -172,82 +163,70 @@ const icon_options = [
172
163
  ),
173
164
  },
174
165
  ];
175
- const url_options = [
166
+
167
+ const options_material = [
176
168
  {
177
- label: "Social Media",
169
+ label: "Transport",
178
170
  options: [
179
171
  {
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",
172
+ label: "Electric Car",
173
+ value: "car",
174
+ icon: "electric_car",
183
175
  },
184
176
  {
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",
177
+ label: "Motorcycle",
178
+ value: "motorcycle",
179
+ icon: "Motorcycle",
188
180
  },
189
181
  {
190
- label: "Facebook",
191
- value: "facebook",
192
- icon: (
193
- <svg
194
- version="1.1"
195
- id="Capa_1"
196
- x="0px"
197
- y="0px"
198
- width="438.536px"
199
- height="438.536px"
200
- viewBox="0 0 438.536 438.536"
201
- fill="#4267B2"
202
- >
203
- <g>
204
- <path
205
- d="M414.41,24.123C398.333,8.042,378.963,0,356.315,0H82.228C59.58,0,40.21,8.042,24.126,24.123
206
- C8.045,40.207,0.003,59.576,0.003,82.225v274.084c0,22.647,8.042,42.018,24.123,58.102c16.084,16.084,35.454,24.126,58.102,24.126
207
- h274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225
208
- C438.532,59.576,430.49,40.204,414.41,24.123z M373.155,225.548h-49.963V406.84h-74.802V225.548H210.99V163.02h37.401v-37.402
209
- c0-26.838,6.283-47.107,18.843-60.813c12.559-13.706,33.304-20.555,62.242-20.555h49.963v62.526h-31.401
210
- c-10.663,0-17.467,1.853-20.417,5.568c-2.949,3.711-4.428,10.23-4.428,19.558v31.119h56.534L373.155,225.548z"
211
- />
212
- </g>
213
- </svg>
214
- ),
182
+ label: "Train",
183
+ value: "train",
184
+ icon: "train",
215
185
  },
216
186
  {
217
- label: "Pinterest",
218
- value: "pinterest",
219
- icon: "https://cdn-icons-png.flaticon.com/512/145/145808.png",
187
+ label: "Bike",
188
+ value: "bike",
189
+ icon: "pedal_bike",
220
190
  },
221
191
  ],
222
192
  },
223
193
  {
224
- label: "Design",
194
+ label: "Entertainment",
225
195
  options: [
226
196
  {
227
- label: "Figma",
228
- value: "figma",
229
- icon: "https://logowik.com/content/uploads/images/figma.jpg",
197
+ label: "Movie",
198
+ value: "movie",
199
+ icon: "movie",
230
200
  },
231
201
  {
232
- label: "Adobe XD",
233
- value: "adobexd",
234
- icon: "https://cdn.worldvectorlogo.com/logos/adobe-xd-2.svg",
202
+ label: "Music",
203
+ value: "music",
204
+ icon: "music_note",
235
205
  },
236
206
  {
237
- label: "Sketch",
238
- value: "sketch",
239
- icon: "https://cdn.worldvectorlogo.com/logos/sketch-2.svg",
207
+ label: "Games",
208
+ value: "games",
209
+ icon: "joystick",
240
210
  },
241
211
  ],
242
212
  },
243
213
  ];
214
+
244
215
  const optionsWithEllipsisMedium = [
245
216
  { label: "Optiond1234567890123456789012345678901234", value: "1" },
246
217
  { label: "Optiond12345678901234567890123456789012345", value: "2" },
247
218
  { label: "Option 031111111111111111111111111111222", value: "3" },
248
- { label: "Option 03111111111111111111111111111222", value: "4" },
249
219
  ];
250
220
 
221
+ const opinionatedTheme = {
222
+ select: {
223
+ selectedOptionBackgroundColor: "#e6f4ff",
224
+ fontColor: "#000000",
225
+ optionFontColor: "#000000",
226
+ hoverBorderColor: "#a46ede",
227
+ },
228
+ };
229
+
251
230
  const Select = () => (
252
231
  <>
253
232
  <Title title="States" theme="light" level={2} />
@@ -360,197 +339,345 @@ const Select = () => (
360
339
  <Title title="Multiple selection with ellipsis" theme="light" level={4} />
361
340
  <DxcSelect label="Label" options={single_options} multiple defaultValue={["1", "2", "3", "4"]} />
362
341
  <Title title="Value with ellipsis" theme="light" level={4} />
363
- <DxcSelect label="Label" options={optionsWithEllipsisMedium} defaultValue="1" size="medium" />
342
+ <DxcSelect label="Label" options={optionsWithEllipsisMedium} defaultValue="1" />
364
343
  <Title title="Options with ellipsis" theme="light" level={4} />
365
344
  <DxcSelect
366
345
  label="Label"
367
346
  placeholder="Choose an option"
368
347
  defaultValue="1"
369
348
  options={optionsWithEllipsisMedium}
370
- size="medium"
349
+ margin={{ top: "xxlarge" }}
371
350
  />
372
351
  </ExampleContainer>
352
+ <Title title="Opinionated theme" theme="light" level={2} />
353
+ <ExampleContainer pseudoState="pseudo-hover">
354
+ <Title title="Hovered" theme="light" level={4} />
355
+ <HalstackProvider theme={opinionatedTheme}>
356
+ <DxcSelect label="Hovered" options={single_options} />
357
+ </HalstackProvider>
358
+ </ExampleContainer>
359
+ <ExampleContainer pseudoState="pseudo-focus-within">
360
+ <Title title="Focused" theme="light" level={4} />
361
+ <HalstackProvider theme={opinionatedTheme}>
362
+ <DxcSelect label="Focused" options={single_options} />
363
+ </HalstackProvider>
364
+ </ExampleContainer>
365
+ <ExampleContainer>
366
+ <Title title="Disabled" theme="light" level={4} />
367
+ <HalstackProvider theme={opinionatedTheme}>
368
+ <DxcSelect label="Disabled" placeholder="Placeholder" disabled options={single_options} />
369
+ </HalstackProvider>
370
+ </ExampleContainer>
371
+ <ExampleContainer>
372
+ <Title title="Disabled with value" theme="light" level={4} />
373
+ <HalstackProvider theme={opinionatedTheme}>
374
+ <DxcSelect label="Disabled with value" disabled options={single_options} defaultValue="1" />
375
+ </HalstackProvider>
376
+ </ExampleContainer>
377
+ <ExampleContainer>
378
+ <Title title="Error" theme="light" level={4} />
379
+ <HalstackProvider theme={opinionatedTheme}>
380
+ <DxcSelect
381
+ label="Label"
382
+ options={single_options}
383
+ error="Error message."
384
+ helperText="Helper text"
385
+ placeholder="Placeholder"
386
+ />
387
+ <ExampleContainer>
388
+ <Title title="Multiple selection" theme="light" level={4} />
389
+ <DxcSelect label="Multiple select" searchable options={single_options} multiple defaultValue={["1", "2"]} />
390
+ </ExampleContainer>
391
+ <ExampleContainer pseudoState="pseudo-hover">
392
+ <Title title="Multiple clear hovered" theme="light" level={4} />
393
+ <DxcSelect label="Multiple select" options={single_options} multiple defaultValue={["1", "2"]} />
394
+ </ExampleContainer>
395
+ <ExampleContainer pseudoState="pseudo-active">
396
+ <Title title="Multiple clear actived" theme="light" level={4} />
397
+ <DxcSelect label="Multiple select" options={single_options} multiple defaultValue={["1", "2"]} />
398
+ </ExampleContainer>
399
+ </HalstackProvider>
400
+ </ExampleContainer>
373
401
  </>
374
402
  );
403
+
375
404
  const SelectListbox = () => {
376
405
  const colorsTheme: any = useTheme();
377
406
 
378
407
  return (
379
- <ThemeProvider theme={colorsTheme.select}>
380
- <Title title="Listbox" theme="light" level={2} />
381
- <ExampleContainer>
382
- <Title
383
- title="List dialog uses a Radix Popover to appear over elements with a certain z-index"
384
- theme="light"
385
- level={3}
386
- />
387
- <div
388
- style={{
389
- position: "relative",
390
- display: "flex",
391
- flexDirection: "column",
392
- gap: "20px",
393
- height: "150px",
394
- width: "min-content",
395
- marginBottom: "100px",
396
- padding: "20px",
397
- border: "1px solid black",
398
- borderRadius: "4px",
399
- overflow: "auto",
400
- zIndex: "1300",
401
- }}
402
- >
403
- <DxcSelect label="Label" options={single_options} optional placeholder="Choose an option" />
404
- <button style={{ zIndex: "1", width: "100px" }}>Submit</button>
405
- </div>
406
- </ExampleContainer>
407
- <Title title="Listbox option states" theme="light" level={3} />
408
- <ExampleContainer pseudoState="pseudo-hover">
409
- <Title title="Hovered option" theme="light" level={4} />
410
- <Listbox
411
- id="x"
412
- currentValue=""
413
- options={one_option}
414
- visualFocusIndex={-1}
415
- lastOptionIndex={0}
416
- multiple={false}
417
- optional={false}
418
- optionalItem={{ label: "Empty", value: "" }}
419
- searchable={false}
420
- handleOptionOnClick={() => {}}
421
- styles={{ width: 360 }}
422
- />
423
- </ExampleContainer>
424
- <ExampleContainer pseudoState="pseudo-active">
425
- <Title title="Active option" theme="light" level={4} />
426
- <Listbox
427
- id="x"
428
- currentValue=""
429
- options={one_option}
430
- visualFocusIndex={-1}
431
- lastOptionIndex={0}
432
- multiple={false}
433
- optional={false}
434
- optionalItem={{ label: "Empty", value: "" }}
435
- searchable={false}
436
- handleOptionOnClick={() => {}}
437
- styles={{ width: 360 }}
438
- />
439
- </ExampleContainer>
440
- <ExampleContainer>
441
- <Title title="Focused option" theme="light" level={4} />
442
- <Listbox
443
- id="x"
444
- currentValue=""
445
- options={one_option}
446
- visualFocusIndex={0}
447
- lastOptionIndex={0}
448
- multiple={false}
449
- optional={false}
450
- optionalItem={{ label: "Empty", value: "" }}
451
- searchable={false}
452
- handleOptionOnClick={() => {}}
453
- styles={{ width: 360 }}
454
- />
455
- </ExampleContainer>
456
- <ExampleContainer pseudoState="pseudo-hover">
457
- <Title title="Hovered selected option" theme="light" level={4} />
458
- <Listbox
459
- id="x"
460
- currentValue="1"
461
- options={single_options}
462
- visualFocusIndex={-1}
463
- lastOptionIndex={3}
464
- multiple={false}
465
- optional={false}
466
- optionalItem={{ label: "Empty", value: "" }}
467
- searchable={false}
468
- handleOptionOnClick={() => {}}
469
- styles={{ width: 360 }}
470
- />
471
- </ExampleContainer>
472
- <ExampleContainer pseudoState="pseudo-active">
473
- <Title title="Active selected option" theme="light" level={4} />
474
- <Listbox
475
- id="x"
476
- currentValue="2"
477
- options={single_options}
478
- visualFocusIndex={0}
479
- lastOptionIndex={3}
480
- multiple={false}
481
- optional={false}
482
- optionalItem={{ label: "Empty", value: "" }}
483
- searchable={false}
484
- handleOptionOnClick={() => {}}
485
- styles={{ width: 360 }}
486
- />
487
- </ExampleContainer>
488
- <Title title="Listbox with icons" theme="light" level={3} />
489
- <ExampleContainer>
490
- <Title title="Icons (SVGs)" theme="light" level={4} />
491
- <Listbox
492
- id="x"
493
- currentValue="3"
494
- options={icon_options}
495
- visualFocusIndex={-1}
496
- lastOptionIndex={3}
497
- multiple={false}
498
- optional={false}
499
- optionalItem={{ label: "Empty", value: "" }}
500
- searchable={false}
501
- handleOptionOnClick={() => {}}
502
- styles={{ width: 360 }}
503
- />
504
- </ExampleContainer>
505
- <ExampleContainer>
506
- <Title title="Icons (Images)" theme="light" level={4} />
507
- <Listbox
508
- id="x"
509
- currentValue="facebook"
510
- options={url_options}
511
- visualFocusIndex={-1}
512
- lastOptionIndex={6}
513
- multiple={false}
514
- optional={false}
515
- optionalItem={{ label: "Empty", value: "" }}
516
- searchable={false}
517
- handleOptionOnClick={() => {}}
518
- styles={{ width: 360 }}
519
- />
520
- </ExampleContainer>
521
- <ExampleContainer>
522
- <Title title="Grouped icons (SVGs)" theme="light" level={4} />
523
- <Listbox
524
- id="x"
525
- currentValue={["0", "3"]}
526
- options={icon_options_grouped}
527
- visualFocusIndex={-1}
528
- lastOptionIndex={3}
529
- multiple={false}
530
- optional={false}
531
- optionalItem={{ label: "Empty", value: "" }}
532
- searchable={false}
533
- handleOptionOnClick={() => {}}
534
- styles={{ width: 360 }}
535
- />
536
- </ExampleContainer>
537
- <ExampleContainer>
538
- <Title title="Grouped icons (Images)" theme="light" level={4} />
539
- <Listbox
540
- id="x"
541
- currentValue={["facebook", "figma"]}
542
- options={url_options}
543
- visualFocusIndex={-1}
544
- lastOptionIndex={6}
545
- multiple={true}
546
- optional={false}
547
- optionalItem={{ label: "Empty", value: "" }}
548
- searchable={false}
549
- handleOptionOnClick={() => {}}
550
- styles={{ width: 360 }}
551
- />
552
- </ExampleContainer>
553
- </ThemeProvider>
408
+ <>
409
+ <ThemeProvider theme={colorsTheme.select}>
410
+ <Title title="Listbox" theme="light" level={2} />
411
+ <ExampleContainer>
412
+ <Title
413
+ title="List dialog uses a Radix Popover to appear over elements with a certain z-index"
414
+ theme="light"
415
+ level={3}
416
+ />
417
+ <div
418
+ style={{
419
+ position: "relative",
420
+ display: "flex",
421
+ flexDirection: "column",
422
+ gap: "20px",
423
+ height: "150px",
424
+ width: "min-content",
425
+ marginBottom: "100px",
426
+ padding: "20px",
427
+ border: "1px solid black",
428
+ borderRadius: "4px",
429
+ overflow: "auto",
430
+ zIndex: "1300",
431
+ }}
432
+ >
433
+ <DxcSelect label="Label" options={single_options} optional placeholder="Choose an option" />
434
+ <button style={{ zIndex: "1", width: "100px" }}>Submit</button>
435
+ </div>
436
+ </ExampleContainer>
437
+ <Title title="Listbox option states" theme="light" level={3} />
438
+ <ExampleContainer pseudoState="pseudo-hover">
439
+ <Title title="Hovered option" theme="light" level={4} />
440
+ <Listbox
441
+ id="x8"
442
+ currentValue=""
443
+ options={one_option}
444
+ visualFocusIndex={-1}
445
+ lastOptionIndex={0}
446
+ multiple={false}
447
+ optional={false}
448
+ optionalItem={{ label: "Empty", value: "" }}
449
+ searchable={false}
450
+ handleOptionOnClick={() => {}}
451
+ styles={{ width: 360 }}
452
+ />
453
+ </ExampleContainer>
454
+ <ExampleContainer pseudoState="pseudo-active">
455
+ <Title title="Active option" theme="light" level={4} />
456
+ <Listbox
457
+ id="x9"
458
+ currentValue=""
459
+ options={one_option}
460
+ visualFocusIndex={-1}
461
+ lastOptionIndex={0}
462
+ multiple={false}
463
+ optional={false}
464
+ optionalItem={{ label: "Empty", value: "" }}
465
+ searchable={false}
466
+ handleOptionOnClick={() => {}}
467
+ styles={{ width: 360 }}
468
+ />
469
+ </ExampleContainer>
470
+ <ExampleContainer>
471
+ <Title title="Focused option" theme="light" level={4} />
472
+ <Listbox
473
+ id="x10"
474
+ currentValue=""
475
+ options={one_option}
476
+ visualFocusIndex={0}
477
+ lastOptionIndex={0}
478
+ multiple={false}
479
+ optional={false}
480
+ optionalItem={{ label: "Empty", value: "" }}
481
+ searchable={false}
482
+ handleOptionOnClick={() => {}}
483
+ styles={{ width: 360 }}
484
+ />
485
+ </ExampleContainer>
486
+ <ExampleContainer pseudoState="pseudo-hover">
487
+ <Title title="Hovered selected option" theme="light" level={4} />
488
+ <Listbox
489
+ id="x11"
490
+ currentValue="1"
491
+ options={single_options}
492
+ visualFocusIndex={-1}
493
+ lastOptionIndex={3}
494
+ multiple={false}
495
+ optional={false}
496
+ optionalItem={{ label: "Empty", value: "" }}
497
+ searchable={false}
498
+ handleOptionOnClick={() => {}}
499
+ styles={{ width: 360 }}
500
+ />
501
+ </ExampleContainer>
502
+ <ExampleContainer pseudoState="pseudo-active">
503
+ <Title title="Active selected option" theme="light" level={4} />
504
+ <Listbox
505
+ id="x12"
506
+ currentValue="2"
507
+ options={single_options}
508
+ visualFocusIndex={0}
509
+ lastOptionIndex={3}
510
+ multiple={false}
511
+ optional={false}
512
+ optionalItem={{ label: "Empty", value: "" }}
513
+ searchable={false}
514
+ handleOptionOnClick={() => {}}
515
+ styles={{ width: 360 }}
516
+ />
517
+ </ExampleContainer>
518
+ <Title title="Listbox with icons" theme="light" level={3} />
519
+ <ExampleContainer>
520
+ <Title title="Icons (SVGs)" theme="light" level={4} />
521
+ <Listbox
522
+ id="x13"
523
+ currentValue="3"
524
+ options={icon_options}
525
+ visualFocusIndex={-1}
526
+ lastOptionIndex={3}
527
+ multiple={false}
528
+ optional={false}
529
+ optionalItem={{ label: "Empty", value: "" }}
530
+ searchable={false}
531
+ handleOptionOnClick={() => {}}
532
+ styles={{ width: 360 }}
533
+ />
534
+ </ExampleContainer>
535
+ <ExampleContainer>
536
+ <Title title="Grouped icons (Material Symbols)" theme="light" level={4} />
537
+ <Listbox
538
+ id="x14"
539
+ currentValue={["0", "3"]}
540
+ options={icon_options_grouped_material}
541
+ visualFocusIndex={-1}
542
+ lastOptionIndex={3}
543
+ multiple={false}
544
+ optional={false}
545
+ optionalItem={{ label: "Empty", value: "" }}
546
+ searchable={false}
547
+ handleOptionOnClick={() => {}}
548
+ styles={{ width: 360 }}
549
+ />
550
+ </ExampleContainer>
551
+ <ExampleContainer>
552
+ <Title title="Grouped icons (Material)" theme="light" level={4} />
553
+ <Listbox
554
+ id="x15"
555
+ currentValue={["facebook", "figma"]}
556
+ options={options_material}
557
+ visualFocusIndex={-1}
558
+ lastOptionIndex={6}
559
+ multiple={true}
560
+ optional={false}
561
+ optionalItem={{ label: "Empty", value: "" }}
562
+ searchable={false}
563
+ handleOptionOnClick={() => {}}
564
+ styles={{ width: 360 }}
565
+ />
566
+ </ExampleContainer>
567
+ </ThemeProvider>
568
+ <ThemeProvider theme={colorsTheme.select}>
569
+ <Title title="Opinionated theme" theme="light" level={2} />
570
+ <ExampleContainer pseudoState="pseudo-hover">
571
+ <Title title="Hovered option" theme="light" level={4} />
572
+ <HalstackProvider theme={opinionatedTheme}>
573
+ <Listbox
574
+ id="x16"
575
+ currentValue=""
576
+ options={one_option}
577
+ visualFocusIndex={-1}
578
+ lastOptionIndex={0}
579
+ multiple={false}
580
+ optional={false}
581
+ optionalItem={{ label: "Empty", value: "" }}
582
+ searchable={false}
583
+ handleOptionOnClick={() => {}}
584
+ styles={{ width: 360 }}
585
+ />
586
+ </HalstackProvider>
587
+ </ExampleContainer>
588
+ <ExampleContainer pseudoState="pseudo-active">
589
+ <Title title="Active option" theme="light" level={4} />{" "}
590
+ <HalstackProvider theme={opinionatedTheme}>
591
+ <Listbox
592
+ id="x17"
593
+ currentValue=""
594
+ options={one_option}
595
+ visualFocusIndex={-1}
596
+ lastOptionIndex={0}
597
+ multiple={false}
598
+ optional={false}
599
+ optionalItem={{ label: "Empty", value: "" }}
600
+ searchable={false}
601
+ handleOptionOnClick={() => {}}
602
+ styles={{ width: 360 }}
603
+ />
604
+ </HalstackProvider>
605
+ </ExampleContainer>
606
+ <ExampleContainer>
607
+ <Title title="Focused option" theme="light" level={4} />{" "}
608
+ <HalstackProvider theme={opinionatedTheme}>
609
+ <Listbox
610
+ id="x18"
611
+ currentValue=""
612
+ options={one_option}
613
+ visualFocusIndex={0}
614
+ lastOptionIndex={0}
615
+ multiple={false}
616
+ optional={false}
617
+ optionalItem={{ label: "Empty", value: "" }}
618
+ searchable={false}
619
+ handleOptionOnClick={() => {}}
620
+ styles={{ width: 360 }}
621
+ />
622
+ </HalstackProvider>
623
+ </ExampleContainer>
624
+ <ExampleContainer pseudoState="pseudo-hover">
625
+ <Title title="Hovered selected option" theme="light" level={4} />{" "}
626
+ <HalstackProvider theme={opinionatedTheme}>
627
+ <Listbox
628
+ id="x19"
629
+ currentValue="1"
630
+ options={single_options}
631
+ visualFocusIndex={-1}
632
+ lastOptionIndex={3}
633
+ multiple={false}
634
+ optional={false}
635
+ optionalItem={{ label: "Empty", value: "" }}
636
+ searchable={false}
637
+ handleOptionOnClick={() => {}}
638
+ styles={{ width: 360 }}
639
+ />
640
+ </HalstackProvider>
641
+ </ExampleContainer>
642
+ <ExampleContainer pseudoState="pseudo-active">
643
+ <Title title="Active selected option" theme="light" level={4} />{" "}
644
+ <HalstackProvider theme={opinionatedTheme}>
645
+ <Listbox
646
+ id="x20"
647
+ currentValue="2"
648
+ options={single_options}
649
+ visualFocusIndex={0}
650
+ lastOptionIndex={3}
651
+ multiple={false}
652
+ optional={false}
653
+ optionalItem={{ label: "Empty", value: "" }}
654
+ searchable={false}
655
+ handleOptionOnClick={() => {}}
656
+ styles={{ width: 360 }}
657
+ />
658
+ </HalstackProvider>
659
+ </ExampleContainer>
660
+ <Title title="Listbox with icons" theme="light" level={3} />
661
+ <ExampleContainer>
662
+ <Title title="Icons (SVGs)" theme="light" level={4} />{" "}
663
+ <HalstackProvider theme={opinionatedTheme}>
664
+ <Listbox
665
+ id="x21"
666
+ currentValue="3"
667
+ options={icon_options}
668
+ visualFocusIndex={-1}
669
+ lastOptionIndex={3}
670
+ multiple={false}
671
+ optional={false}
672
+ optionalItem={{ label: "Empty", value: "" }}
673
+ searchable={false}
674
+ handleOptionOnClick={() => {}}
675
+ styles={{ width: 360 }}
676
+ />
677
+ </HalstackProvider>
678
+ </ExampleContainer>
679
+ </ThemeProvider>
680
+ </>
554
681
  );
555
682
  };
556
683
 
@@ -560,6 +687,16 @@ const SearchableSelect = () => (
560
687
  <DxcSelect label="Select Label" searchable options={single_options} placeholder="Choose an option" />
561
688
  </ExampleContainer>
562
689
  );
690
+
691
+ const SearchableSelectOpinionated = () => (
692
+ <ExampleContainer expanded>
693
+ <Title title="Searchable select" theme="light" level={4} />
694
+ <HalstackProvider theme={opinionatedTheme}>
695
+ <DxcSelect label="Select Label" searchable options={single_options} placeholder="Choose an option" />
696
+ </HalstackProvider>
697
+ </ExampleContainer>
698
+ );
699
+
563
700
  const SearchValue = () => (
564
701
  <ExampleContainer expanded>
565
702
  <Title title="Searchable select with value" theme="light" level={4} />
@@ -572,6 +709,22 @@ const SearchValue = () => (
572
709
  />
573
710
  </ExampleContainer>
574
711
  );
712
+
713
+ const SearchValueOpinionated = () => (
714
+ <ExampleContainer expanded>
715
+ <Title title="Searchable select with value" theme="light" level={4} />
716
+ <HalstackProvider theme={opinionatedTheme}>
717
+ <DxcSelect
718
+ label="Select Label"
719
+ searchable
720
+ defaultValue="1"
721
+ options={single_options}
722
+ placeholder="Choose an option"
723
+ />
724
+ </HalstackProvider>
725
+ </ExampleContainer>
726
+ );
727
+
575
728
  const MultipleSelect = () => (
576
729
  <>
577
730
  <ExampleContainer expanded>
@@ -586,12 +739,38 @@ const MultipleSelect = () => (
586
739
  </ExampleContainer>
587
740
  </>
588
741
  );
742
+
743
+ const MultipleSelectOpinioated = () => (
744
+ <ExampleContainer expanded>
745
+ <Title title="Multiple select" theme="light" level={4} />
746
+ <HalstackProvider theme={opinionatedTheme}>
747
+ <DxcSelect
748
+ label="Select label"
749
+ options={single_options}
750
+ defaultValue={["1", "4"]}
751
+ multiple
752
+ placeholder="Choose an option"
753
+ />
754
+ </HalstackProvider>
755
+ </ExampleContainer>
756
+ );
757
+
589
758
  const DefaultGroupedOptionsSelect = () => (
590
759
  <ExampleContainer expanded>
591
760
  <Title title="Grouped options simple select" theme="light" level={4} />
592
761
  <DxcSelect label="Label" options={group_options} defaultValue="9" placeholder="Choose an option" />
593
762
  </ExampleContainer>
594
763
  );
764
+
765
+ const DefaultGroupedOptionsSelectOpinionated = () => (
766
+ <ExampleContainer expanded>
767
+ <Title title="Grouped options simple select" theme="light" level={4} />
768
+ <HalstackProvider theme={opinionatedTheme}>
769
+ <DxcSelect label="Label" options={group_options} defaultValue="9" placeholder="Choose an option" />
770
+ </HalstackProvider>
771
+ </ExampleContainer>
772
+ );
773
+
595
774
  const MultipleGroupedOptionsSelect = () => (
596
775
  <ExampleContainer expanded>
597
776
  <Title title="Grouped options multiple select" theme="light" level={4} />
@@ -604,6 +783,22 @@ const MultipleGroupedOptionsSelect = () => (
604
783
  />
605
784
  </ExampleContainer>
606
785
  );
786
+
787
+ const MultipleGroupedOptionsSelectOpinionated = () => (
788
+ <ExampleContainer expanded>
789
+ <Title title="Grouped options multiple select" theme="light" level={4} />
790
+ <HalstackProvider theme={opinionatedTheme}>
791
+ <DxcSelect
792
+ label="Label"
793
+ options={group_options}
794
+ defaultValue={["0", "2"]}
795
+ multiple
796
+ placeholder="Choose an option"
797
+ />
798
+ </HalstackProvider>
799
+ </ExampleContainer>
800
+ );
801
+
607
802
  const MultipleSearchable = () => (
608
803
  <ExampleContainer expanded>
609
804
  <Title title="Searchable multiple select with value" theme="light" level={4} />
@@ -618,6 +813,22 @@ const MultipleSearchable = () => (
618
813
  </ExampleContainer>
619
814
  );
620
815
 
816
+ const MultipleSearchableOpinionated = () => (
817
+ <ExampleContainer expanded>
818
+ <Title title="Searchable multiple select with value" theme="light" level={4} />
819
+ <HalstackProvider theme={opinionatedTheme}>
820
+ <DxcSelect
821
+ label="Select Label"
822
+ searchable
823
+ multiple
824
+ defaultValue={["1", "4"]}
825
+ options={single_options}
826
+ placeholder="Choose an option"
827
+ />
828
+ </HalstackProvider>
829
+ </ExampleContainer>
830
+ );
831
+
621
832
  export const Chromatic = Select.bind({});
622
833
  Chromatic.play = async ({ canvasElement }) => {
623
834
  const canvas = within(canvasElement);
@@ -637,18 +848,36 @@ Searchable.play = async ({ canvasElement }) => {
637
848
  await userEvent.type(canvas.getByRole("combobox"), "r");
638
849
  };
639
850
 
851
+ export const SearchableOpinionated = SearchableSelectOpinionated.bind({});
852
+ SearchableOpinionated.play = async ({ canvasElement }) => {
853
+ const canvas = within(canvasElement);
854
+ await userEvent.type(canvas.getByRole("combobox"), "r");
855
+ };
856
+
640
857
  export const SearchableWithValue = SearchValue.bind({});
641
858
  SearchableWithValue.play = async ({ canvasElement }) => {
642
859
  const canvas = within(canvasElement);
643
860
  await userEvent.click(canvas.getByRole("combobox"));
644
861
  };
645
862
 
863
+ export const SearchableWithValueOpinionated = SearchValueOpinionated.bind({});
864
+ SearchableWithValueOpinionated.play = async ({ canvasElement }) => {
865
+ const canvas = within(canvasElement);
866
+ await userEvent.click(canvas.getByRole("combobox"));
867
+ };
868
+
646
869
  export const MultipleSearchableWithValue = MultipleSearchable.bind({});
647
870
  MultipleSearchableWithValue.play = async ({ canvasElement }) => {
648
871
  const canvas = within(canvasElement);
649
872
  await userEvent.click(canvas.getAllByRole("combobox")[0]);
650
873
  };
651
874
 
875
+ export const MultipleSearchableWithValueOpinionated = MultipleSearchableOpinionated.bind({});
876
+ MultipleSearchableWithValueOpinionated.play = async ({ canvasElement }) => {
877
+ const canvas = within(canvasElement);
878
+ await userEvent.click(canvas.getAllByRole("combobox")[0]);
879
+ };
880
+
652
881
  export const GroupOptionsDisplayed = DefaultGroupedOptionsSelect.bind({});
653
882
  GroupOptionsDisplayed.play = async ({ canvasElement }) => {
654
883
  const canvas = within(canvasElement);
@@ -656,15 +885,35 @@ GroupOptionsDisplayed.play = async ({ canvasElement }) => {
656
885
  await userEvent.click(select);
657
886
  };
658
887
 
888
+ export const GroupOptionsDisplayedOpinionated = DefaultGroupedOptionsSelectOpinionated.bind({});
889
+ GroupOptionsDisplayedOpinionated.play = async ({ canvasElement }) => {
890
+ const canvas = within(canvasElement);
891
+ const select = canvas.getByRole("combobox");
892
+ await userEvent.click(select);
893
+ };
894
+
659
895
  export const MultipleOptionsDisplayed = MultipleSelect.bind({});
660
896
  MultipleOptionsDisplayed.play = async ({ canvasElement }) => {
661
897
  const canvas = within(canvasElement);
662
898
  await userEvent.click(canvas.getAllByRole("combobox")[0]);
663
899
  };
664
900
 
901
+ export const MultipleOptionsDisplayedOpinionated = MultipleSelectOpinioated.bind({});
902
+ MultipleOptionsDisplayedOpinionated.play = async ({ canvasElement }) => {
903
+ const canvas = within(canvasElement);
904
+ await userEvent.click(canvas.getAllByRole("combobox")[0]);
905
+ };
906
+
665
907
  export const MultipleGroupedOptionsDisplayed = MultipleGroupedOptionsSelect.bind({});
666
908
  MultipleGroupedOptionsDisplayed.play = async ({ canvasElement }) => {
667
909
  const canvas = within(canvasElement);
668
910
  const select = canvas.getByRole("combobox");
669
911
  await userEvent.click(select);
670
912
  };
913
+
914
+ export const MultipleGroupedOptionsDisplayedOpinionated = MultipleGroupedOptionsSelectOpinionated.bind({});
915
+ MultipleGroupedOptionsDisplayedOpinionated.play = async ({ canvasElement }) => {
916
+ const canvas = within(canvasElement);
917
+ const select = canvas.getByRole("combobox");
918
+ await userEvent.click(select);
919
+ };