@dxc-technology/halstack-react 0.0.0-efa7c74 → 0.0.0-eff2879

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