@dxc-technology/halstack-react 0.0.0-c291a0c → 0.0.0-c2b6ec9

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 (511) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +5 -22
  3. package/HalstackContext.d.ts +1240 -6
  4. package/HalstackContext.js +130 -115
  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 +101 -159
  10. package/accordion/Accordion.stories.tsx +82 -148
  11. package/accordion/Accordion.test.d.ts +1 -0
  12. package/accordion/Accordion.test.js +24 -40
  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 +31 -98
  18. package/accordion-group/AccordionGroup.stories.tsx +94 -67
  19. package/accordion-group/AccordionGroup.test.d.ts +1 -0
  20. package/accordion-group/AccordionGroup.test.js +49 -106
  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 +12 -17
  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 +37 -127
  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 +64 -63
  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 +19 -60
  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 -14
  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 +168 -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.d.ts +7 -0
  75. package/bulleted-list/BulletedList.js +92 -0
  76. package/bulleted-list/BulletedList.stories.tsx +115 -0
  77. package/bulleted-list/types.d.ts +38 -0
  78. package/button/Button.accessibility.test.d.ts +1 -0
  79. package/button/Button.accessibility.test.js +127 -0
  80. package/button/Button.d.ts +1 -1
  81. package/button/Button.js +64 -117
  82. package/button/Button.stories.tsx +151 -100
  83. package/button/Button.test.d.ts +1 -0
  84. package/button/Button.test.js +19 -16
  85. package/button/types.d.ts +12 -8
  86. package/card/Card.accessibility.test.d.ts +1 -0
  87. package/card/Card.accessibility.test.js +36 -0
  88. package/card/Card.d.ts +1 -1
  89. package/card/Card.js +49 -89
  90. package/card/Card.stories.tsx +13 -43
  91. package/card/Card.test.d.ts +1 -0
  92. package/card/Card.test.js +10 -21
  93. package/card/types.d.ts +6 -11
  94. package/checkbox/Checkbox.accessibility.test.d.ts +1 -0
  95. package/checkbox/Checkbox.accessibility.test.js +87 -0
  96. package/checkbox/Checkbox.d.ts +2 -2
  97. package/checkbox/Checkbox.js +138 -183
  98. package/checkbox/Checkbox.stories.tsx +128 -94
  99. package/checkbox/Checkbox.test.d.ts +1 -0
  100. package/checkbox/Checkbox.test.js +159 -38
  101. package/checkbox/types.d.ts +11 -3
  102. package/chip/Chip.accessibility.test.d.ts +1 -0
  103. package/chip/Chip.accessibility.test.js +67 -0
  104. package/chip/Chip.js +45 -80
  105. package/chip/Chip.stories.tsx +103 -27
  106. package/chip/Chip.test.d.ts +1 -0
  107. package/chip/Chip.test.js +17 -32
  108. package/chip/types.d.ts +4 -4
  109. package/common/coreTokens.d.ts +237 -0
  110. package/common/coreTokens.js +184 -0
  111. package/common/utils.d.ts +1 -0
  112. package/common/utils.js +6 -12
  113. package/common/variables.d.ts +1392 -0
  114. package/common/variables.js +993 -1199
  115. package/container/Container.d.ts +4 -0
  116. package/container/Container.js +194 -0
  117. package/container/Container.stories.tsx +214 -0
  118. package/container/types.d.ts +74 -0
  119. package/contextual-menu/ContextualMenu.accessibility.test.d.ts +1 -0
  120. package/contextual-menu/ContextualMenu.accessibility.test.js +98 -0
  121. package/contextual-menu/ContextualMenu.d.ts +5 -0
  122. package/contextual-menu/ContextualMenu.js +108 -0
  123. package/contextual-menu/ContextualMenu.stories.tsx +223 -0
  124. package/contextual-menu/ContextualMenu.test.d.ts +1 -0
  125. package/contextual-menu/ContextualMenu.test.js +247 -0
  126. package/contextual-menu/GroupItem.d.ts +4 -0
  127. package/contextual-menu/GroupItem.js +67 -0
  128. package/contextual-menu/ItemAction.d.ts +4 -0
  129. package/contextual-menu/ItemAction.js +50 -0
  130. package/contextual-menu/MenuItem.d.ts +4 -0
  131. package/contextual-menu/MenuItem.js +29 -0
  132. package/contextual-menu/SingleItem.d.ts +4 -0
  133. package/contextual-menu/SingleItem.js +38 -0
  134. package/contextual-menu/types.d.ts +61 -0
  135. package/date-input/Calendar.d.ts +4 -0
  136. package/date-input/Calendar.js +230 -0
  137. package/date-input/DateInput.accessibility.test.d.ts +1 -0
  138. package/date-input/DateInput.accessibility.test.js +229 -0
  139. package/date-input/DateInput.js +156 -300
  140. package/date-input/DateInput.stories.tsx +210 -57
  141. package/date-input/DateInput.test.d.ts +1 -0
  142. package/date-input/DateInput.test.js +699 -370
  143. package/date-input/DatePicker.d.ts +4 -0
  144. package/date-input/DatePicker.js +121 -0
  145. package/date-input/YearPicker.d.ts +4 -0
  146. package/date-input/YearPicker.js +105 -0
  147. package/date-input/types.d.ts +72 -15
  148. package/dialog/Dialog.accessibility.test.d.ts +1 -0
  149. package/dialog/Dialog.accessibility.test.js +69 -0
  150. package/dialog/Dialog.d.ts +1 -1
  151. package/dialog/Dialog.js +61 -106
  152. package/dialog/Dialog.stories.tsx +324 -167
  153. package/dialog/Dialog.test.d.ts +1 -0
  154. package/dialog/Dialog.test.js +349 -19
  155. package/dialog/types.d.ts +18 -25
  156. package/divider/Divider.accessibility.test.d.ts +1 -0
  157. package/divider/Divider.accessibility.test.js +33 -0
  158. package/divider/Divider.d.ts +4 -0
  159. package/divider/Divider.js +36 -0
  160. package/divider/Divider.stories.tsx +223 -0
  161. package/divider/Divider.test.d.ts +1 -0
  162. package/divider/Divider.test.js +38 -0
  163. package/divider/types.d.ts +21 -0
  164. package/dropdown/Dropdown.accessibility.test.d.ts +1 -0
  165. package/dropdown/Dropdown.accessibility.test.js +183 -0
  166. package/dropdown/Dropdown.d.ts +1 -1
  167. package/dropdown/Dropdown.js +232 -303
  168. package/dropdown/Dropdown.stories.tsx +236 -58
  169. package/dropdown/Dropdown.test.d.ts +1 -0
  170. package/dropdown/Dropdown.test.js +603 -164
  171. package/dropdown/DropdownMenu.d.ts +4 -0
  172. package/dropdown/DropdownMenu.js +63 -0
  173. package/dropdown/DropdownMenuItem.d.ts +4 -0
  174. package/dropdown/DropdownMenuItem.js +71 -0
  175. package/dropdown/types.d.ts +35 -19
  176. package/file-input/FileInput.accessibility.test.d.ts +1 -0
  177. package/file-input/FileInput.accessibility.test.js +167 -0
  178. package/file-input/FileInput.d.ts +2 -2
  179. package/file-input/FileInput.js +238 -393
  180. package/file-input/FileInput.stories.tsx +123 -12
  181. package/file-input/FileInput.test.d.ts +1 -0
  182. package/file-input/FileInput.test.js +314 -367
  183. package/file-input/FileItem.d.ts +4 -14
  184. package/file-input/FileItem.js +56 -117
  185. package/file-input/types.d.ts +24 -11
  186. package/flex/Flex.d.ts +4 -0
  187. package/flex/Flex.js +57 -0
  188. package/flex/Flex.stories.tsx +112 -0
  189. package/flex/types.d.ts +97 -0
  190. package/footer/Footer.accessibility.test.d.ts +1 -0
  191. package/footer/Footer.accessibility.test.js +125 -0
  192. package/footer/Footer.d.ts +1 -1
  193. package/footer/Footer.js +73 -118
  194. package/footer/Footer.stories.tsx +99 -21
  195. package/footer/Footer.test.d.ts +1 -0
  196. package/footer/Footer.test.js +32 -56
  197. package/footer/Icons.d.ts +3 -2
  198. package/footer/Icons.js +53 -22
  199. package/footer/types.d.ts +26 -27
  200. package/grid/Grid.d.ts +7 -0
  201. package/grid/Grid.js +76 -0
  202. package/grid/Grid.stories.tsx +221 -0
  203. package/grid/types.d.ts +115 -0
  204. package/grid/types.js +5 -0
  205. package/header/Header.accessibility.test.d.ts +1 -0
  206. package/header/Header.accessibility.test.js +94 -0
  207. package/header/Header.d.ts +4 -3
  208. package/header/Header.js +90 -183
  209. package/header/Header.stories.tsx +134 -39
  210. package/header/Header.test.d.ts +1 -0
  211. package/header/Header.test.js +12 -25
  212. package/header/Icons.d.ts +2 -2
  213. package/header/Icons.js +5 -15
  214. package/header/types.d.ts +7 -21
  215. package/heading/Heading.accessibility.test.d.ts +1 -0
  216. package/heading/Heading.accessibility.test.js +33 -0
  217. package/heading/Heading.js +10 -32
  218. package/heading/Heading.test.d.ts +1 -0
  219. package/heading/Heading.test.js +64 -94
  220. package/heading/types.d.ts +7 -7
  221. package/icon/Icon.accessibility.test.d.ts +1 -0
  222. package/icon/Icon.accessibility.test.js +30 -0
  223. package/icon/Icon.d.ts +4 -0
  224. package/icon/Icon.js +33 -0
  225. package/icon/Icon.stories.tsx +28 -0
  226. package/icon/types.d.ts +4 -0
  227. package/icon/types.js +5 -0
  228. package/image/Image.accessibility.test.d.ts +1 -0
  229. package/image/Image.accessibility.test.js +56 -0
  230. package/image/Image.d.ts +4 -0
  231. package/image/Image.js +70 -0
  232. package/image/Image.stories.tsx +129 -0
  233. package/image/types.d.ts +72 -0
  234. package/image/types.js +5 -0
  235. package/inset/Inset.js +13 -21
  236. package/inset/Inset.stories.tsx +5 -4
  237. package/inset/types.d.ts +2 -2
  238. package/layout/ApplicationLayout.d.ts +15 -6
  239. package/layout/ApplicationLayout.js +56 -118
  240. package/layout/ApplicationLayout.stories.tsx +81 -45
  241. package/layout/Icons.d.ts +7 -5
  242. package/layout/Icons.js +41 -59
  243. package/layout/types.d.ts +21 -32
  244. package/link/Link.accessibility.test.d.ts +1 -0
  245. package/link/Link.accessibility.test.js +108 -0
  246. package/link/Link.js +32 -51
  247. package/link/Link.stories.tsx +76 -9
  248. package/link/Link.test.d.ts +1 -0
  249. package/link/Link.test.js +23 -43
  250. package/link/types.d.ts +14 -14
  251. package/main.d.ts +15 -13
  252. package/main.js +66 -103
  253. package/nav-tabs/NavTabs.accessibility.test.d.ts +1 -0
  254. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  255. package/nav-tabs/NavTabs.d.ts +7 -0
  256. package/nav-tabs/NavTabs.js +108 -0
  257. package/nav-tabs/NavTabs.stories.tsx +294 -0
  258. package/nav-tabs/NavTabs.test.d.ts +1 -0
  259. package/nav-tabs/NavTabs.test.js +77 -0
  260. package/nav-tabs/NavTabsContext.d.ts +3 -0
  261. package/nav-tabs/NavTabsContext.js +8 -0
  262. package/nav-tabs/Tab.js +117 -0
  263. package/{tabs-nav → nav-tabs}/types.d.ts +15 -16
  264. package/nav-tabs/types.js +5 -0
  265. package/number-input/NumberInput.accessibility.test.d.ts +1 -0
  266. package/number-input/NumberInput.accessibility.test.js +227 -0
  267. package/number-input/NumberInput.js +50 -37
  268. package/number-input/NumberInput.stories.tsx +37 -26
  269. package/number-input/NumberInput.test.d.ts +1 -0
  270. package/number-input/NumberInput.test.js +858 -376
  271. package/number-input/NumberInputContext.d.ts +3 -4
  272. package/number-input/NumberInputContext.js +3 -14
  273. package/number-input/types.d.ts +17 -5
  274. package/package.json +56 -54
  275. package/paginator/Paginator.accessibility.test.d.ts +1 -0
  276. package/paginator/Paginator.accessibility.test.js +78 -0
  277. package/paginator/Paginator.js +35 -68
  278. package/paginator/Paginator.stories.tsx +24 -0
  279. package/paginator/Paginator.test.d.ts +1 -0
  280. package/paginator/Paginator.test.js +253 -227
  281. package/paginator/types.d.ts +3 -3
  282. package/paragraph/Paragraph.accessibility.test.d.ts +1 -0
  283. package/paragraph/Paragraph.accessibility.test.js +28 -0
  284. package/paragraph/Paragraph.d.ts +5 -0
  285. package/paragraph/Paragraph.js +22 -0
  286. package/paragraph/Paragraph.stories.tsx +27 -0
  287. package/password-input/PasswordInput.accessibility.test.d.ts +1 -0
  288. package/password-input/PasswordInput.accessibility.test.js +152 -0
  289. package/password-input/PasswordInput.js +62 -128
  290. package/password-input/PasswordInput.stories.tsx +11 -34
  291. package/password-input/PasswordInput.test.d.ts +1 -0
  292. package/password-input/PasswordInput.test.js +158 -141
  293. package/password-input/types.d.ts +8 -7
  294. package/progress-bar/ProgressBar.accessibility.test.d.ts +1 -0
  295. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  296. package/progress-bar/ProgressBar.js +68 -92
  297. package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +39 -4
  298. package/progress-bar/ProgressBar.test.d.ts +1 -0
  299. package/progress-bar/ProgressBar.test.js +71 -43
  300. package/progress-bar/types.d.ts +3 -3
  301. package/quick-nav/QuickNav.accessibility.test.d.ts +1 -0
  302. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  303. package/quick-nav/QuickNav.js +27 -45
  304. package/quick-nav/QuickNav.stories.tsx +146 -27
  305. package/quick-nav/types.d.ts +10 -10
  306. package/radio-group/Radio.d.ts +1 -1
  307. package/radio-group/Radio.js +59 -79
  308. package/radio-group/RadioGroup.accessibility.test.d.ts +1 -0
  309. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  310. package/radio-group/RadioGroup.js +70 -119
  311. package/radio-group/RadioGroup.stories.tsx +132 -18
  312. package/radio-group/RadioGroup.test.d.ts +1 -0
  313. package/radio-group/RadioGroup.test.js +518 -459
  314. package/radio-group/types.d.ts +10 -10
  315. package/resultset-table/Icons.d.ts +7 -0
  316. package/resultset-table/Icons.js +47 -0
  317. package/resultset-table/ResultsetTable.accessibility.test.d.ts +1 -0
  318. package/resultset-table/ResultsetTable.accessibility.test.js +284 -0
  319. package/resultset-table/ResultsetTable.d.ts +7 -0
  320. package/resultset-table/ResultsetTable.js +171 -0
  321. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +169 -31
  322. package/resultset-table/ResultsetTable.test.d.ts +1 -0
  323. package/resultset-table/ResultsetTable.test.js +379 -0
  324. package/{resultsetTable → resultset-table}/types.d.ts +44 -11
  325. package/resultset-table/types.js +5 -0
  326. package/select/Listbox.js +40 -64
  327. package/select/Option.js +35 -56
  328. package/select/Select.accessibility.test.d.ts +1 -0
  329. package/select/Select.accessibility.test.js +227 -0
  330. package/select/Select.js +150 -208
  331. package/select/Select.stories.tsx +505 -203
  332. package/select/Select.test.d.ts +1 -0
  333. package/select/Select.test.js +1909 -1804
  334. package/select/types.d.ts +17 -20
  335. package/sidenav/Sidenav.accessibility.test.d.ts +1 -0
  336. package/sidenav/Sidenav.accessibility.test.js +59 -0
  337. package/sidenav/Sidenav.d.ts +6 -5
  338. package/sidenav/Sidenav.js +132 -78
  339. package/sidenav/Sidenav.stories.tsx +246 -151
  340. package/sidenav/Sidenav.test.d.ts +1 -0
  341. package/sidenav/Sidenav.test.js +25 -44
  342. package/{layout → sidenav}/SidenavContext.d.ts +1 -1
  343. package/{layout → sidenav}/SidenavContext.js +3 -9
  344. package/sidenav/types.d.ts +52 -26
  345. package/slider/Slider.accessibility.test.d.ts +1 -0
  346. package/slider/Slider.accessibility.test.js +103 -0
  347. package/slider/Slider.d.ts +2 -2
  348. package/slider/Slider.js +146 -181
  349. package/slider/Slider.stories.tsx +64 -61
  350. package/slider/Slider.test.d.ts +1 -0
  351. package/slider/Slider.test.js +194 -88
  352. package/slider/types.d.ts +7 -3
  353. package/spinner/Spinner.accessibility.test.d.ts +1 -0
  354. package/spinner/Spinner.accessibility.test.js +96 -0
  355. package/spinner/Spinner.js +34 -74
  356. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
  357. package/spinner/Spinner.test.d.ts +1 -0
  358. package/spinner/Spinner.test.js +25 -34
  359. package/spinner/types.d.ts +3 -3
  360. package/status-light/StatusLight.accessibility.test.d.ts +1 -0
  361. package/status-light/StatusLight.accessibility.test.js +157 -0
  362. package/status-light/StatusLight.d.ts +4 -0
  363. package/status-light/StatusLight.js +51 -0
  364. package/status-light/StatusLight.stories.tsx +74 -0
  365. package/status-light/StatusLight.test.d.ts +1 -0
  366. package/status-light/StatusLight.test.js +25 -0
  367. package/status-light/types.d.ts +17 -0
  368. package/status-light/types.js +5 -0
  369. package/switch/Switch.accessibility.test.d.ts +1 -0
  370. package/switch/Switch.accessibility.test.js +98 -0
  371. package/switch/Switch.d.ts +2 -2
  372. package/switch/Switch.js +145 -129
  373. package/switch/Switch.stories.tsx +49 -60
  374. package/switch/Switch.test.d.ts +1 -0
  375. package/switch/Switch.test.js +137 -55
  376. package/switch/types.d.ts +7 -3
  377. package/table/DropdownTheme.js +62 -0
  378. package/table/Table.accessibility.test.d.ts +1 -0
  379. package/table/Table.accessibility.test.js +92 -0
  380. package/table/Table.d.ts +6 -2
  381. package/table/Table.js +78 -35
  382. package/table/Table.stories.tsx +663 -0
  383. package/table/Table.test.d.ts +1 -0
  384. package/table/Table.test.js +92 -7
  385. package/table/types.d.ts +34 -6
  386. package/tabs/Tab.d.ts +4 -0
  387. package/tabs/Tab.js +117 -0
  388. package/tabs/Tabs.accessibility.test.d.ts +1 -0
  389. package/tabs/Tabs.accessibility.test.js +56 -0
  390. package/tabs/Tabs.js +303 -141
  391. package/tabs/Tabs.stories.tsx +124 -6
  392. package/tabs/Tabs.test.d.ts +1 -0
  393. package/tabs/Tabs.test.js +212 -76
  394. package/tabs/types.d.ts +30 -20
  395. package/tag/Tag.accessibility.test.d.ts +1 -0
  396. package/tag/Tag.accessibility.test.js +69 -0
  397. package/tag/Tag.js +35 -67
  398. package/tag/Tag.stories.tsx +19 -9
  399. package/tag/Tag.test.d.ts +1 -0
  400. package/tag/Tag.test.js +17 -36
  401. package/tag/types.d.ts +9 -9
  402. package/text-input/Suggestion.js +40 -28
  403. package/text-input/Suggestions.d.ts +4 -0
  404. package/text-input/Suggestions.js +94 -0
  405. package/text-input/TextInput.accessibility.test.d.ts +1 -0
  406. package/text-input/TextInput.accessibility.test.js +320 -0
  407. package/text-input/TextInput.js +313 -512
  408. package/text-input/TextInput.stories.tsx +278 -275
  409. package/text-input/TextInput.test.d.ts +1 -0
  410. package/text-input/TextInput.test.js +1417 -1374
  411. package/text-input/types.d.ts +43 -16
  412. package/textarea/Textarea.accessibility.test.d.ts +1 -0
  413. package/textarea/Textarea.accessibility.test.js +155 -0
  414. package/textarea/Textarea.js +67 -109
  415. package/textarea/Textarea.stories.tsx +174 -0
  416. package/textarea/Textarea.test.d.ts +1 -0
  417. package/textarea/Textarea.test.js +151 -182
  418. package/textarea/types.d.ts +9 -5
  419. package/toggle-group/ToggleGroup.accessibility.test.d.ts +1 -0
  420. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  421. package/toggle-group/ToggleGroup.d.ts +2 -2
  422. package/toggle-group/ToggleGroup.js +92 -108
  423. package/toggle-group/ToggleGroup.stories.tsx +53 -8
  424. package/toggle-group/ToggleGroup.test.d.ts +1 -0
  425. package/toggle-group/ToggleGroup.test.js +68 -87
  426. package/toggle-group/types.d.ts +28 -19
  427. package/tooltip/Tooltip.accessibility.test.d.ts +1 -0
  428. package/tooltip/Tooltip.accessibility.test.js +144 -0
  429. package/tooltip/Tooltip.d.ts +4 -0
  430. package/tooltip/Tooltip.js +50 -0
  431. package/tooltip/Tooltip.stories.tsx +111 -0
  432. package/tooltip/Tooltip.test.d.ts +1 -0
  433. package/tooltip/Tooltip.test.js +112 -0
  434. package/tooltip/types.d.ts +16 -0
  435. package/tooltip/types.js +5 -0
  436. package/typography/Typography.accessibility.test.d.ts +1 -0
  437. package/typography/Typography.accessibility.test.js +339 -0
  438. package/typography/Typography.d.ts +4 -0
  439. package/typography/Typography.js +23 -0
  440. package/typography/Typography.stories.tsx +196 -0
  441. package/typography/types.d.ts +18 -0
  442. package/typography/types.js +5 -0
  443. package/useTheme.d.ts +1144 -1
  444. package/useTheme.js +2 -9
  445. package/useTranslatedLabels.d.ts +84 -1
  446. package/useTranslatedLabels.js +1 -7
  447. package/utils/BaseTypography.d.ts +21 -0
  448. package/utils/BaseTypography.js +94 -0
  449. package/utils/FocusLock.d.ts +13 -0
  450. package/utils/FocusLock.js +125 -0
  451. package/wizard/Wizard.accessibility.test.d.ts +1 -0
  452. package/wizard/Wizard.accessibility.test.js +55 -0
  453. package/wizard/Wizard.js +34 -87
  454. package/wizard/Wizard.stories.tsx +60 -2
  455. package/wizard/Wizard.test.d.ts +1 -0
  456. package/wizard/Wizard.test.js +53 -80
  457. package/wizard/types.d.ts +9 -9
  458. package/card/ice-cream.jpg +0 -0
  459. package/common/OpenSans.css +0 -81
  460. package/common/RequiredComponent.js +0 -32
  461. package/common/fonts/OpenSans-Bold.ttf +0 -0
  462. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  463. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  464. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  465. package/common/fonts/OpenSans-Italic.ttf +0 -0
  466. package/common/fonts/OpenSans-Light.ttf +0 -0
  467. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  468. package/common/fonts/OpenSans-Regular.ttf +0 -0
  469. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  470. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  471. package/inline/Inline.d.ts +0 -4
  472. package/inline/Inline.js +0 -54
  473. package/inline/Inline.stories.tsx +0 -264
  474. package/inline/types.d.ts +0 -32
  475. package/list/List.d.ts +0 -4
  476. package/list/List.js +0 -47
  477. package/list/List.stories.tsx +0 -89
  478. package/list/types.d.ts +0 -7
  479. package/number-input/numberInputContextTypes.d.ts +0 -19
  480. package/paginator/Icons.js +0 -66
  481. package/resultsetTable/ResultsetTable.d.ts +0 -4
  482. package/resultsetTable/ResultsetTable.js +0 -254
  483. package/resultsetTable/ResultsetTable.test.js +0 -348
  484. package/row/Row.d.ts +0 -3
  485. package/row/Row.js +0 -127
  486. package/row/Row.stories.tsx +0 -237
  487. package/row/types.d.ts +0 -28
  488. package/select/Icons.d.ts +0 -10
  489. package/select/Icons.js +0 -93
  490. package/stack/Stack.d.ts +0 -4
  491. package/stack/Stack.js +0 -50
  492. package/stack/Stack.stories.tsx +0 -225
  493. package/stack/types.d.ts +0 -28
  494. package/table/Table.stories.jsx +0 -277
  495. package/tabs-nav/NavTabs.d.ts +0 -8
  496. package/tabs-nav/NavTabs.js +0 -125
  497. package/tabs-nav/NavTabs.stories.tsx +0 -170
  498. package/tabs-nav/NavTabs.test.js +0 -82
  499. package/tabs-nav/Tab.js +0 -132
  500. package/text/Text.d.ts +0 -7
  501. package/text/Text.js +0 -30
  502. package/text/Text.stories.tsx +0 -19
  503. package/textarea/Textarea.stories.jsx +0 -157
  504. /package/{inline → action-icon}/types.js +0 -0
  505. /package/{list → breadcrumbs}/types.js +0 -0
  506. /package/{resultsetTable → bulleted-list}/types.js +0 -0
  507. /package/{row → container}/types.js +0 -0
  508. /package/{stack → contextual-menu}/types.js +0 -0
  509. /package/{tabs-nav → divider}/types.js +0 -0
  510. /package/{number-input/numberInputContextTypes.js → flex/types.js} +0 -0
  511. /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,122 +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
- styles={{ width: 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
- styles={{ width: 360 }}
399
- />
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>
400
373
  </ExampleContainer>
401
374
  <ExampleContainer>
402
- <Title title="Focused option" theme="light" level={4} />
403
- <Listbox
404
- id="x"
405
- currentValue=""
406
- options={one_option}
407
- visualFocusIndex={0}
408
- lastOptionIndex={0}
409
- multiple={false}
410
- optional={false}
411
- optionalItem={{ label: "Empty", value: "" }}
412
- searchable={false}
413
- handleOptionOnClick={() => {}}
414
- styles={{ width: 360 }}
415
- />
375
+ <Title title="Disabled" theme="light" level={4} />
376
+ <HalstackProvider theme={opinionatedTheme}>
377
+ <DxcSelect label="Disabled" placeholder="Placeholder" disabled options={single_options} />
378
+ </HalstackProvider>
416
379
  </ExampleContainer>
417
- <ExampleContainer pseudoState="pseudo-hover">
418
- <Title title="Hovered selected option" theme="light" level={4} />
419
- <Listbox
420
- id="x"
421
- currentValue="1"
422
- options={single_options}
423
- visualFocusIndex={-1}
424
- lastOptionIndex={3}
425
- multiple={false}
426
- optional={false}
427
- optionalItem={{ label: "Empty", value: "" }}
428
- searchable={false}
429
- handleOptionOnClick={() => {}}
430
- styles={{ width: 360 }}
431
- />
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>
432
385
  </ExampleContainer>
433
- <ExampleContainer pseudoState="pseudo-active">
434
- <Title title="Active selected option" theme="light" level={4} />
435
- <Listbox
436
- id="x"
437
- currentValue="2"
438
- options={single_options}
439
- visualFocusIndex={0}
440
- lastOptionIndex={3}
441
- multiple={false}
442
- optional={false}
443
- optionalItem={{ label: "Empty", value: "" }}
444
- searchable={false}
445
- handleOptionOnClick={() => {}}
446
- styles={{ width: 360 }}
447
- />
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>
448
409
  </ExampleContainer>
449
410
  </>
450
411
  );
412
+
413
+ const SelectListbox = () => {
414
+ const colorsTheme: any = 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
+
451
693
  const SearchableSelect = () => (
452
694
  <ExampleContainer expanded>
453
695
  <Title title="Searchable select" theme="light" level={4} />
454
696
  <DxcSelect label="Select Label" searchable options={single_options} placeholder="Choose an option" />
455
697
  </ExampleContainer>
456
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
+
457
709
  const SearchValue = () => (
458
710
  <ExampleContainer expanded>
459
711
  <Title title="Searchable select with value" theme="light" level={4} />
@@ -466,6 +718,22 @@ const SearchValue = () => (
466
718
  />
467
719
  </ExampleContainer>
468
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
+
469
737
  const MultipleSelect = () => (
470
738
  <>
471
739
  <ExampleContainer expanded>
@@ -480,12 +748,38 @@ const MultipleSelect = () => (
480
748
  </ExampleContainer>
481
749
  </>
482
750
  );
751
+
752
+ const MultipleSelectOpinioated = () => (
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
+
483
767
  const DefaultGroupedOptionsSelect = () => (
484
768
  <ExampleContainer expanded>
485
769
  <Title title="Grouped options simple select" theme="light" level={4} />
486
770
  <DxcSelect label="Label" options={group_options} defaultValue="9" placeholder="Choose an option" />
487
771
  </ExampleContainer>
488
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
+
489
783
  const MultipleGroupedOptionsSelect = () => (
490
784
  <ExampleContainer expanded>
491
785
  <Title title="Grouped options multiple select" theme="light" level={4} />
@@ -498,34 +792,19 @@ const MultipleGroupedOptionsSelect = () => (
498
792
  />
499
793
  </ExampleContainer>
500
794
  );
501
- const RescaledIcons = () => (
502
- <ExampleContainer expanded>
503
- <Title title="Rescaled icons displayed" theme="light" level={4} />
504
- <DxcSelect label="Label" options={url_options} defaultValue="facebook" placeholder="Choose an option" />
505
- </ExampleContainer>
506
- );
507
- const SelectWithIcons = () => (
508
- <ExampleContainer expanded>
509
- <Title title="Normal icons displayed" theme="light" level={4} />
510
- <DxcSelect label="Label" options={icon_options} defaultValue="3" placeholder="Choose an option" />
511
- </ExampleContainer>
512
- );
513
- const SelectMultipleWithIcons = () => (
514
- <ExampleContainer expanded>
515
- <Title title="Multiple select with icons" theme="light" level={4} />
516
- <DxcSelect label="Label" options={icon_options} multiple defaultValue={["1", "3"]} placeholder="Choose an option" />
517
- </ExampleContainer>
518
- );
519
- const MultipleGroupedOptionsSelectWithIcons = () => (
795
+
796
+ const MultipleGroupedOptionsSelectOpinionated = () => (
520
797
  <ExampleContainer expanded>
521
- <Title title="Multiple grouped options with icons" theme="light" level={4} />
522
- <DxcSelect
523
- label="Label"
524
- options={icon_options_grouped}
525
- multiple
526
- defaultValue={["3", "2"]}
527
- placeholder="Choose an option"
528
- />
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>
529
808
  </ExampleContainer>
530
809
  );
531
810
 
@@ -543,6 +822,22 @@ const MultipleSearchable = () => (
543
822
  </ExampleContainer>
544
823
  );
545
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
+
546
841
  export const Chromatic = Select.bind({});
547
842
  Chromatic.play = async ({ canvasElement }) => {
548
843
  const canvas = within(canvasElement);
@@ -559,10 +854,13 @@ ListboxStates.play = async ({ canvasElement }) => {
559
854
  export const Searchable = SearchableSelect.bind({});
560
855
  Searchable.play = async ({ canvasElement }) => {
561
856
  const canvas = within(canvasElement);
562
- await userEvent.click(canvas.getByRole("combobox"));
563
- await waitFor(async () => {
564
- userEvent.type(canvas.getByRole("combobox"), "r");
565
- });
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");
566
864
  };
567
865
 
568
866
  export const SearchableWithValue = SearchValue.bind({});
@@ -571,12 +869,24 @@ SearchableWithValue.play = async ({ canvasElement }) => {
571
869
  await userEvent.click(canvas.getByRole("combobox"));
572
870
  };
573
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
+
574
878
  export const MultipleSearchableWithValue = MultipleSearchable.bind({});
575
879
  MultipleSearchableWithValue.play = async ({ canvasElement }) => {
576
880
  const canvas = within(canvasElement);
577
881
  await userEvent.click(canvas.getAllByRole("combobox")[0]);
578
882
  };
579
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
+
580
890
  export const GroupOptionsDisplayed = DefaultGroupedOptionsSelect.bind({});
581
891
  GroupOptionsDisplayed.play = async ({ canvasElement }) => {
582
892
  const canvas = within(canvasElement);
@@ -584,42 +894,34 @@ GroupOptionsDisplayed.play = async ({ canvasElement }) => {
584
894
  await userEvent.click(select);
585
895
  };
586
896
 
587
- export const MultipleOptionsDisplayed = MultipleSelect.bind({});
588
- MultipleOptionsDisplayed.play = async ({ canvasElement }) => {
589
- const canvas = within(canvasElement);
590
- await userEvent.click(canvas.getAllByRole("combobox")[0]);
591
- };
592
-
593
- export const MultipleGroupedOptionsDisplayed = MultipleGroupedOptionsSelect.bind({});
594
- MultipleGroupedOptionsDisplayed.play = async ({ canvasElement }) => {
897
+ export const GroupOptionsDisplayedOpinionated = DefaultGroupedOptionsSelectOpinionated.bind({});
898
+ GroupOptionsDisplayedOpinionated.play = async ({ canvasElement }) => {
595
899
  const canvas = within(canvasElement);
596
900
  const select = canvas.getByRole("combobox");
597
901
  await userEvent.click(select);
598
902
  };
599
903
 
600
- export const WithIconsDisplayed = SelectWithIcons.bind({});
601
- WithIconsDisplayed.play = async ({ canvasElement }) => {
904
+ export const MultipleOptionsDisplayed = MultipleSelect.bind({});
905
+ MultipleOptionsDisplayed.play = async ({ canvasElement }) => {
602
906
  const canvas = within(canvasElement);
603
- const select = canvas.getByRole("combobox");
604
- await userEvent.click(select);
907
+ await userEvent.click(canvas.getAllByRole("combobox")[0]);
605
908
  };
606
909
 
607
- export const WithRescaledIconsDisplayed = RescaledIcons.bind({});
608
- WithRescaledIconsDisplayed.play = async ({ canvasElement }) => {
910
+ export const MultipleOptionsDisplayedOpinionated = MultipleSelectOpinioated.bind({});
911
+ MultipleOptionsDisplayedOpinionated.play = async ({ canvasElement }) => {
609
912
  const canvas = within(canvasElement);
610
- const select = canvas.getByRole("combobox");
611
- await userEvent.click(select);
913
+ await userEvent.click(canvas.getAllByRole("combobox")[0]);
612
914
  };
613
915
 
614
- export const MultipleWithIconsDisplayed = SelectMultipleWithIcons.bind({});
615
- MultipleWithIconsDisplayed.play = async ({ canvasElement }) => {
916
+ export const MultipleGroupedOptionsDisplayed = MultipleGroupedOptionsSelect.bind({});
917
+ MultipleGroupedOptionsDisplayed.play = async ({ canvasElement }) => {
616
918
  const canvas = within(canvasElement);
617
919
  const select = canvas.getByRole("combobox");
618
920
  await userEvent.click(select);
619
921
  };
620
922
 
621
- export const MultipleGroupedWithIconsDisplayed = MultipleGroupedOptionsSelectWithIcons.bind({});
622
- MultipleGroupedWithIconsDisplayed.play = async ({ canvasElement }) => {
923
+ export const MultipleGroupedOptionsDisplayedOpinionated = MultipleGroupedOptionsSelectOpinionated.bind({});
924
+ MultipleGroupedOptionsDisplayedOpinionated.play = async ({ canvasElement }) => {
623
925
  const canvas = within(canvasElement);
624
926
  const select = canvas.getByRole("combobox");
625
927
  await userEvent.click(select);