@dxc-technology/halstack-react 0.0.0-8c5a0f7 → 0.0.0-8d625da

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 (508) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +5 -22
  3. package/HalstackContext.d.ts +1246 -0
  4. package/HalstackContext.js +310 -0
  5. package/README.md +47 -0
  6. package/accordion/Accordion.accessibility.test.d.ts +1 -0
  7. package/accordion/Accordion.accessibility.test.js +71 -0
  8. package/accordion/Accordion.d.ts +1 -1
  9. package/accordion/Accordion.js +102 -181
  10. package/accordion/Accordion.stories.tsx +83 -149
  11. package/accordion/Accordion.test.d.ts +1 -0
  12. package/accordion/Accordion.test.js +31 -32
  13. package/accordion/types.d.ts +10 -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 +3 -3
  17. package/accordion-group/AccordionGroup.js +38 -107
  18. package/accordion-group/AccordionGroup.stories.tsx +95 -68
  19. package/accordion-group/AccordionGroup.test.d.ts +1 -0
  20. package/accordion-group/AccordionGroup.test.js +52 -91
  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 +16 -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 +40 -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 -40
  45. package/badge/Badge.stories.tsx +210 -0
  46. package/badge/Badge.test.d.ts +1 -0
  47. package/badge/Badge.test.js +30 -0
  48. package/badge/types.d.ts +52 -2
  49. package/bleed/Bleed.js +14 -55
  50. package/bleed/Bleed.stories.tsx +95 -95
  51. package/bleed/types.d.ts +26 -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 +30 -81
  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 +169 -0
  67. package/breadcrumbs/Item.d.ts +4 -0
  68. package/breadcrumbs/Item.js +52 -0
  69. package/breadcrumbs/dropdownTheme.d.ts +53 -0
  70. package/breadcrumbs/dropdownTheme.js +62 -0
  71. package/breadcrumbs/types.d.ts +16 -0
  72. package/bulleted-list/BulletedList.accessibility.test.d.ts +1 -0
  73. package/bulleted-list/BulletedList.accessibility.test.js +119 -0
  74. package/bulleted-list/BulletedList.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 +63 -113
  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 +59 -102
  90. package/card/Card.stories.tsx +12 -42
  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 +140 -181
  98. package/checkbox/Checkbox.stories.tsx +166 -136
  99. package/checkbox/Checkbox.test.d.ts +1 -0
  100. package/checkbox/Checkbox.test.js +162 -28
  101. package/checkbox/types.d.ts +18 -6
  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 +107 -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 +1081 -1190
  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 +88 -0
  123. package/contextual-menu/ContextualMenu.stories.tsx +232 -0
  124. package/contextual-menu/ContextualMenu.test.d.ts +1 -0
  125. package/contextual-menu/ContextualMenu.test.js +205 -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 +51 -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 +58 -0
  135. package/date-input/Calendar.d.ts +4 -0
  136. package/date-input/Calendar.js +214 -0
  137. package/date-input/DateInput.accessibility.test.d.ts +1 -0
  138. package/date-input/DateInput.accessibility.test.js +230 -0
  139. package/date-input/DateInput.js +170 -306
  140. package/date-input/DateInput.stories.tsx +210 -56
  141. package/date-input/DateInput.test.d.ts +1 -0
  142. package/date-input/DateInput.test.js +708 -368
  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 +100 -0
  147. package/date-input/types.d.ts +86 -22
  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 +56 -129
  152. package/dialog/Dialog.stories.tsx +325 -167
  153. package/dialog/Dialog.test.d.ts +1 -0
  154. package/dialog/Dialog.test.js +350 -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 +184 -0
  166. package/dropdown/Dropdown.d.ts +1 -1
  167. package/dropdown/Dropdown.js +232 -307
  168. package/dropdown/Dropdown.stories.tsx +235 -57
  169. package/dropdown/Dropdown.test.d.ts +1 -0
  170. package/dropdown/Dropdown.test.js +604 -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 +245 -395
  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 +61 -120
  185. package/file-input/types.d.ts +25 -8
  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/flex/types.js +5 -0
  191. package/footer/Footer.accessibility.test.d.ts +1 -0
  192. package/footer/Footer.accessibility.test.js +125 -0
  193. package/footer/Footer.d.ts +1 -1
  194. package/footer/Footer.js +73 -191
  195. package/footer/Footer.stories.tsx +99 -21
  196. package/footer/Footer.test.d.ts +1 -0
  197. package/footer/Footer.test.js +32 -56
  198. package/footer/Icons.d.ts +3 -2
  199. package/footer/Icons.js +54 -23
  200. package/footer/types.d.ts +26 -27
  201. package/grid/Grid.d.ts +7 -0
  202. package/grid/Grid.js +76 -0
  203. package/grid/Grid.stories.tsx +219 -0
  204. package/grid/types.d.ts +115 -0
  205. package/grid/types.js +5 -0
  206. package/header/Header.accessibility.test.d.ts +1 -0
  207. package/header/Header.accessibility.test.js +94 -0
  208. package/header/Header.d.ts +4 -3
  209. package/header/Header.js +104 -218
  210. package/header/Header.stories.tsx +168 -63
  211. package/header/Header.test.d.ts +1 -0
  212. package/header/Header.test.js +30 -27
  213. package/header/Icons.d.ts +2 -2
  214. package/header/Icons.js +5 -15
  215. package/header/types.d.ts +7 -21
  216. package/heading/Heading.accessibility.test.d.ts +1 -0
  217. package/heading/Heading.accessibility.test.js +33 -0
  218. package/heading/Heading.js +10 -32
  219. package/heading/Heading.test.d.ts +1 -0
  220. package/heading/Heading.test.js +64 -94
  221. package/heading/types.d.ts +7 -7
  222. package/icon/Icon.accessibility.test.d.ts +1 -0
  223. package/icon/Icon.accessibility.test.js +30 -0
  224. package/icon/Icon.d.ts +4 -0
  225. package/icon/Icon.js +33 -0
  226. package/icon/Icon.stories.tsx +28 -0
  227. package/icon/types.d.ts +4 -0
  228. package/icon/types.js +5 -0
  229. package/image/Image.accessibility.test.d.ts +1 -0
  230. package/image/Image.accessibility.test.js +56 -0
  231. package/image/Image.d.ts +4 -0
  232. package/image/Image.js +70 -0
  233. package/image/Image.stories.tsx +129 -0
  234. package/image/types.d.ts +72 -0
  235. package/image/types.js +5 -0
  236. package/inset/Inset.js +14 -55
  237. package/inset/Inset.stories.tsx +37 -36
  238. package/inset/types.d.ts +26 -2
  239. package/layout/ApplicationLayout.d.ts +16 -6
  240. package/layout/ApplicationLayout.js +88 -182
  241. package/layout/ApplicationLayout.stories.tsx +85 -94
  242. package/layout/Icons.d.ts +7 -0
  243. package/layout/Icons.js +41 -48
  244. package/layout/types.d.ts +19 -35
  245. package/link/Link.accessibility.test.d.ts +1 -0
  246. package/link/Link.accessibility.test.js +108 -0
  247. package/link/Link.d.ts +3 -2
  248. package/link/Link.js +65 -101
  249. package/link/Link.stories.tsx +157 -55
  250. package/link/Link.test.d.ts +1 -0
  251. package/link/Link.test.js +24 -52
  252. package/link/types.d.ts +15 -31
  253. package/main.d.ts +17 -13
  254. package/main.js +86 -101
  255. package/nav-tabs/NavTabs.accessibility.test.d.ts +1 -0
  256. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  257. package/nav-tabs/NavTabs.d.ts +7 -0
  258. package/nav-tabs/NavTabs.js +108 -0
  259. package/nav-tabs/NavTabs.stories.tsx +294 -0
  260. package/nav-tabs/NavTabs.test.d.ts +1 -0
  261. package/nav-tabs/NavTabs.test.js +77 -0
  262. package/nav-tabs/NavTabsContext.d.ts +3 -0
  263. package/nav-tabs/NavTabsContext.js +8 -0
  264. package/nav-tabs/Tab.d.ts +4 -0
  265. package/nav-tabs/Tab.js +117 -0
  266. package/nav-tabs/types.d.ts +52 -0
  267. package/nav-tabs/types.js +5 -0
  268. package/number-input/NumberInput.accessibility.test.d.ts +1 -0
  269. package/number-input/NumberInput.accessibility.test.js +228 -0
  270. package/number-input/NumberInput.js +47 -44
  271. package/number-input/NumberInput.stories.tsx +44 -28
  272. package/number-input/NumberInput.test.d.ts +1 -0
  273. package/number-input/NumberInput.test.js +861 -380
  274. package/number-input/NumberInputContext.d.ts +3 -4
  275. package/number-input/NumberInputContext.js +3 -14
  276. package/number-input/types.d.ts +34 -15
  277. package/package.json +55 -54
  278. package/paginator/Paginator.accessibility.test.d.ts +1 -0
  279. package/paginator/Paginator.accessibility.test.js +79 -0
  280. package/paginator/Paginator.js +46 -100
  281. package/paginator/Paginator.stories.tsx +24 -0
  282. package/paginator/Paginator.test.d.ts +1 -0
  283. package/paginator/Paginator.test.js +279 -210
  284. package/paginator/types.d.ts +3 -3
  285. package/paragraph/Paragraph.accessibility.test.d.ts +1 -0
  286. package/paragraph/Paragraph.accessibility.test.js +28 -0
  287. package/paragraph/Paragraph.d.ts +5 -0
  288. package/paragraph/Paragraph.js +22 -0
  289. package/paragraph/Paragraph.stories.tsx +27 -0
  290. package/password-input/PasswordInput.accessibility.test.d.ts +1 -0
  291. package/password-input/PasswordInput.accessibility.test.js +153 -0
  292. package/password-input/PasswordInput.js +58 -124
  293. package/password-input/PasswordInput.stories.tsx +1 -33
  294. package/password-input/PasswordInput.test.d.ts +1 -0
  295. package/password-input/PasswordInput.test.js +161 -146
  296. package/password-input/types.d.ts +21 -17
  297. package/progress-bar/ProgressBar.accessibility.test.d.ts +1 -0
  298. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  299. package/progress-bar/ProgressBar.js +68 -92
  300. package/progress-bar/ProgressBar.stories.tsx +93 -0
  301. package/progress-bar/ProgressBar.test.d.ts +1 -0
  302. package/progress-bar/ProgressBar.test.js +71 -43
  303. package/progress-bar/types.d.ts +3 -3
  304. package/quick-nav/QuickNav.accessibility.test.d.ts +1 -0
  305. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  306. package/quick-nav/QuickNav.d.ts +4 -0
  307. package/quick-nav/QuickNav.js +94 -0
  308. package/quick-nav/QuickNav.stories.tsx +356 -0
  309. package/quick-nav/types.d.ts +21 -0
  310. package/quick-nav/types.js +5 -0
  311. package/radio-group/Radio.d.ts +1 -1
  312. package/radio-group/Radio.js +59 -79
  313. package/radio-group/RadioGroup.accessibility.test.d.ts +1 -0
  314. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  315. package/radio-group/RadioGroup.js +74 -121
  316. package/radio-group/RadioGroup.stories.tsx +132 -18
  317. package/radio-group/RadioGroup.test.d.ts +1 -0
  318. package/radio-group/RadioGroup.test.js +518 -459
  319. package/radio-group/types.d.ts +10 -10
  320. package/resultset-table/Icons.d.ts +7 -0
  321. package/resultset-table/Icons.js +47 -0
  322. package/resultset-table/ResultsetTable.accessibility.test.d.ts +1 -0
  323. package/resultset-table/ResultsetTable.accessibility.test.js +285 -0
  324. package/resultset-table/ResultsetTable.d.ts +7 -0
  325. package/resultset-table/ResultsetTable.js +171 -0
  326. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +168 -30
  327. package/resultset-table/ResultsetTable.test.d.ts +1 -0
  328. package/resultset-table/ResultsetTable.test.js +380 -0
  329. package/{resultsetTable → resultset-table}/types.d.ts +44 -11
  330. package/resultset-table/types.js +5 -0
  331. package/select/Listbox.d.ts +4 -0
  332. package/select/Listbox.js +151 -0
  333. package/select/Option.js +35 -56
  334. package/select/Select.accessibility.test.d.ts +1 -0
  335. package/select/Select.accessibility.test.js +228 -0
  336. package/select/Select.js +225 -365
  337. package/select/Select.stories.tsx +533 -196
  338. package/select/Select.test.d.ts +1 -0
  339. package/select/Select.test.js +1956 -1588
  340. package/select/types.d.ts +54 -28
  341. package/sidenav/Sidenav.accessibility.test.d.ts +1 -0
  342. package/sidenav/Sidenav.accessibility.test.js +59 -0
  343. package/sidenav/Sidenav.d.ts +6 -5
  344. package/sidenav/Sidenav.js +136 -71
  345. package/sidenav/Sidenav.stories.tsx +246 -151
  346. package/sidenav/Sidenav.test.d.ts +1 -0
  347. package/sidenav/Sidenav.test.js +25 -44
  348. package/sidenav/SidenavContext.d.ts +5 -0
  349. package/sidenav/SidenavContext.js +13 -0
  350. package/sidenav/types.d.ts +52 -26
  351. package/slider/Slider.accessibility.test.d.ts +1 -0
  352. package/slider/Slider.accessibility.test.js +104 -0
  353. package/slider/Slider.d.ts +2 -2
  354. package/slider/Slider.js +147 -181
  355. package/slider/Slider.stories.tsx +68 -65
  356. package/slider/Slider.test.d.ts +1 -0
  357. package/slider/Slider.test.js +205 -77
  358. package/slider/types.d.ts +11 -3
  359. package/spinner/Spinner.accessibility.test.d.ts +1 -0
  360. package/spinner/Spinner.accessibility.test.js +96 -0
  361. package/spinner/Spinner.js +34 -74
  362. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
  363. package/spinner/Spinner.test.d.ts +1 -0
  364. package/spinner/Spinner.test.js +25 -34
  365. package/spinner/types.d.ts +3 -3
  366. package/status-light/StatusLight.accessibility.test.d.ts +1 -0
  367. package/status-light/StatusLight.accessibility.test.js +157 -0
  368. package/status-light/StatusLight.d.ts +4 -0
  369. package/status-light/StatusLight.js +51 -0
  370. package/status-light/StatusLight.stories.tsx +74 -0
  371. package/status-light/StatusLight.test.d.ts +1 -0
  372. package/status-light/StatusLight.test.js +25 -0
  373. package/status-light/types.d.ts +17 -0
  374. package/status-light/types.js +5 -0
  375. package/switch/Switch.accessibility.test.d.ts +1 -0
  376. package/switch/Switch.accessibility.test.js +98 -0
  377. package/switch/Switch.d.ts +2 -2
  378. package/switch/Switch.js +146 -114
  379. package/switch/Switch.stories.tsx +56 -67
  380. package/switch/Switch.test.d.ts +1 -0
  381. package/switch/Switch.test.js +145 -38
  382. package/switch/types.d.ts +13 -5
  383. package/table/DropdownTheme.js +62 -0
  384. package/table/Table.accessibility.test.d.ts +1 -0
  385. package/table/Table.accessibility.test.js +93 -0
  386. package/table/Table.d.ts +6 -2
  387. package/table/Table.js +78 -35
  388. package/table/Table.stories.tsx +663 -0
  389. package/table/Table.test.d.ts +1 -0
  390. package/table/Table.test.js +93 -7
  391. package/table/types.d.ts +34 -6
  392. package/tabs/Tab.d.ts +4 -0
  393. package/tabs/Tab.js +117 -0
  394. package/tabs/Tabs.accessibility.test.d.ts +1 -0
  395. package/tabs/Tabs.accessibility.test.js +56 -0
  396. package/tabs/Tabs.d.ts +1 -1
  397. package/tabs/Tabs.js +305 -145
  398. package/tabs/Tabs.stories.tsx +124 -14
  399. package/tabs/Tabs.test.d.ts +1 -0
  400. package/tabs/Tabs.test.js +219 -66
  401. package/tabs/types.d.ts +31 -17
  402. package/tag/Tag.accessibility.test.d.ts +1 -0
  403. package/tag/Tag.accessibility.test.js +69 -0
  404. package/tag/Tag.js +38 -73
  405. package/tag/Tag.stories.tsx +18 -8
  406. package/tag/Tag.test.d.ts +1 -0
  407. package/tag/Tag.test.js +17 -36
  408. package/tag/types.d.ts +9 -9
  409. package/text-input/Suggestion.d.ts +4 -0
  410. package/text-input/Suggestion.js +67 -0
  411. package/text-input/Suggestions.d.ts +4 -0
  412. package/text-input/Suggestions.js +94 -0
  413. package/text-input/TextInput.accessibility.test.d.ts +1 -0
  414. package/text-input/TextInput.accessibility.test.js +321 -0
  415. package/text-input/TextInput.js +327 -556
  416. package/text-input/TextInput.stories.tsx +276 -276
  417. package/text-input/TextInput.test.d.ts +1 -0
  418. package/text-input/TextInput.test.js +1429 -1398
  419. package/text-input/types.d.ts +66 -24
  420. package/textarea/Textarea.accessibility.test.d.ts +1 -0
  421. package/textarea/Textarea.accessibility.test.js +155 -0
  422. package/textarea/Textarea.js +78 -131
  423. package/textarea/Textarea.stories.tsx +174 -0
  424. package/textarea/Textarea.test.d.ts +1 -0
  425. package/textarea/Textarea.test.js +161 -202
  426. package/textarea/types.d.ts +23 -16
  427. package/toggle-group/ToggleGroup.accessibility.test.d.ts +1 -0
  428. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  429. package/toggle-group/ToggleGroup.d.ts +2 -2
  430. package/toggle-group/ToggleGroup.js +92 -107
  431. package/toggle-group/ToggleGroup.stories.tsx +56 -11
  432. package/toggle-group/ToggleGroup.test.d.ts +1 -0
  433. package/toggle-group/ToggleGroup.test.js +77 -65
  434. package/toggle-group/types.d.ts +36 -19
  435. package/typography/Typography.accessibility.test.d.ts +1 -0
  436. package/typography/Typography.accessibility.test.js +339 -0
  437. package/typography/Typography.d.ts +4 -0
  438. package/typography/Typography.js +23 -0
  439. package/typography/Typography.stories.tsx +198 -0
  440. package/typography/types.d.ts +18 -0
  441. package/typography/types.js +5 -0
  442. package/useTheme.d.ts +1144 -1
  443. package/useTheme.js +4 -11
  444. package/useTranslatedLabels.d.ts +85 -0
  445. package/useTranslatedLabels.js +14 -0
  446. package/utils/BaseTypography.d.ts +21 -0
  447. package/utils/BaseTypography.js +94 -0
  448. package/utils/FocusLock.d.ts +13 -0
  449. package/utils/FocusLock.js +124 -0
  450. package/wizard/Wizard.accessibility.test.d.ts +1 -0
  451. package/wizard/Wizard.accessibility.test.js +55 -0
  452. package/wizard/Wizard.d.ts +1 -1
  453. package/wizard/Wizard.js +78 -120
  454. package/wizard/Wizard.stories.tsx +67 -19
  455. package/wizard/Wizard.test.d.ts +1 -0
  456. package/wizard/Wizard.test.js +72 -86
  457. package/wizard/types.d.ts +14 -10
  458. package/ThemeContext.d.ts +0 -10
  459. package/ThemeContext.js +0 -243
  460. package/card/ice-cream.jpg +0 -0
  461. package/common/OpenSans.css +0 -81
  462. package/common/RequiredComponent.js +0 -32
  463. package/common/fonts/OpenSans-Bold.ttf +0 -0
  464. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  465. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  466. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  467. package/common/fonts/OpenSans-Italic.ttf +0 -0
  468. package/common/fonts/OpenSans-Light.ttf +0 -0
  469. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  470. package/common/fonts/OpenSans-Regular.ttf +0 -0
  471. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  472. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  473. package/list/List.d.ts +0 -4
  474. package/list/List.js +0 -47
  475. package/list/List.stories.tsx +0 -95
  476. package/list/types.d.ts +0 -7
  477. package/number-input/numberInputContextTypes.d.ts +0 -19
  478. package/paginator/Icons.js +0 -66
  479. package/progress-bar/ProgressBar.stories.jsx +0 -58
  480. package/radio/Radio.d.ts +0 -4
  481. package/radio/Radio.js +0 -174
  482. package/radio/Radio.stories.tsx +0 -192
  483. package/radio/Radio.test.js +0 -71
  484. package/radio/types.d.ts +0 -54
  485. package/resultsetTable/ResultsetTable.d.ts +0 -4
  486. package/resultsetTable/ResultsetTable.js +0 -254
  487. package/resultsetTable/ResultsetTable.test.js +0 -306
  488. package/row/Row.d.ts +0 -3
  489. package/row/Row.js +0 -127
  490. package/row/Row.stories.tsx +0 -237
  491. package/row/types.d.ts +0 -10
  492. package/select/Icons.d.ts +0 -10
  493. package/select/Icons.js +0 -93
  494. package/stack/Stack.d.ts +0 -3
  495. package/stack/Stack.js +0 -97
  496. package/stack/Stack.stories.tsx +0 -164
  497. package/stack/types.d.ts +0 -9
  498. package/table/Table.stories.jsx +0 -277
  499. package/text/Text.d.ts +0 -7
  500. package/text/Text.js +0 -30
  501. package/text/Text.stories.tsx +0 -19
  502. package/textarea/Textarea.stories.jsx +0 -157
  503. /package/{list → action-icon}/types.js +0 -0
  504. /package/{radio → breadcrumbs}/types.js +0 -0
  505. /package/{resultsetTable → bulleted-list}/types.js +0 -0
  506. /package/{row → container}/types.js +0 -0
  507. /package/{stack → contextual-menu}/types.js +0 -0
  508. /package/{number-input/numberInputContextTypes.js → divider/types.js} +0 -0
@@ -3,6 +3,12 @@ import { userEvent, within } from "@storybook/testing-library";
3
3
  import DxcDropdown from "./Dropdown";
4
4
  import Title from "../../.storybook/components/Title";
5
5
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
+ import DropdownMenu from "./DropdownMenu";
7
+ import { Option } from "./types";
8
+ import useTheme from "../useTheme";
9
+ import DxcFlex from "../flex/Flex";
10
+ import { HalstackProvider } from "../HalstackContext";
11
+ import { ThemeProvider } from "styled-components";
6
12
 
7
13
  export default {
8
14
  title: "Dropdown",
@@ -10,28 +16,22 @@ export default {
10
16
  };
11
17
 
12
18
  const iconSVG = (
13
- <svg viewBox="0 0 24 24" fill="currentColor">
19
+ <svg viewBox="0 0 24 24" height="24" width="24" fill="currentColor">
14
20
  <path d="M0 0h24v24H0z" fill="none" />
15
21
  <path d="M12 21.35l-1.45-1.32C5.4 15.36 2 12.28 2 8.5 2 5.42 4.42 3 7.5 3c1.74 0 3.41.81 4.5 2.09C13.09 3.81 14.76 3 16.5 3 19.58 3 22 5.42 22 8.5c0 3.78-3.4 6.86-8.55 11.54L12 21.35z" />
16
22
  </svg>
17
23
  );
18
-
19
24
  const iconSVGLarge = (
20
- <svg enable-background="new 0 0 24 24" height="48px" viewBox="0 0 24 24" width="48px" fill="currentColor">
21
- <g>
22
- <path d="M0,0h24v24H0V0z" fill="none" />
23
- <path d="M0,0h24v24H0V0z" fill="none" />
24
- </g>
25
- <g>
26
- <path d="M12,17.27L18.18,21l-1.64-7.03L22,9.24l-7.19-0.61L12,2L9.19,8.63L2,9.24l5.46,4.73L5.82,21L12,17.27z" />
27
- </g>
25
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 48 48" height="48" width="48">
26
+ <path d="M11 44q-1.2 0-2.1-.9Q8 42.2 8 41V15q0-1.2.9-2.1.9-.9 2.1-.9h5.5v-.5q0-3.15 2.175-5.325Q20.85 4 24 4q3.15 0 5.325 2.175Q31.5 8.35 31.5 11.5v.5H37q1.2 0 2.1.9.9.9.9 2.1v26q0 1.2-.9 2.1-.9.9-2.1.9Zm0-3h26V15h-5.5v4.5q0 .65-.425 1.075Q30.65 21 30 21q-.65 0-1.075-.425-.425-.425-.425-1.075V15h-9v4.5q0 .65-.425 1.075Q18.65 21 18 21q-.65 0-1.075-.425-.425-.425-.425-1.075V15H11v26Zm8.5-29h9v-.5q0-1.9-1.3-3.2Q25.9 7 24 7q-1.9 0-3.2 1.3-1.3 1.3-1.3 3.2ZM11 41V15v26Z" />
28
27
  </svg>
29
28
  );
29
+ const icons = [iconSVG, iconSVGLarge, "nutrition"];
30
30
 
31
- const options: any = [
31
+ const defaultOptions: Option[] = [
32
32
  {
33
33
  value: "1",
34
- label: "Amazon with a very long text",
34
+ label: "Amazon",
35
35
  },
36
36
  {
37
37
  value: "2",
@@ -41,24 +41,60 @@ const options: any = [
41
41
  value: "3",
42
42
  label: "Apple",
43
43
  },
44
+ {
45
+ value: "4",
46
+ label: "Wallapop",
47
+ },
48
+ {
49
+ value: "5",
50
+ label: "Aliexpress",
51
+ },
52
+ {
53
+ value: "6",
54
+ label: "Etsy",
55
+ },
56
+ {
57
+ value: "7",
58
+ label: "Alibaba",
59
+ },
60
+ {
61
+ value: "8",
62
+ label: "Gearbest shop",
63
+ },
44
64
  ];
45
-
46
- const option: any = [
65
+ const options: Option[] = [
47
66
  {
48
67
  value: "1",
68
+ label: "Amazon with a very long text",
69
+ },
70
+ {
71
+ value: "2",
49
72
  label: "Ebay",
50
73
  },
74
+ {
75
+ value: "3",
76
+ label: "Apple",
77
+ },
51
78
  ];
52
-
53
- const icons = [
54
- iconSVG,
55
- iconSVGLarge,
56
- "https://iconape.com/wp-content/files/yd/367773/svg/logo-linkedin-logo-icon-png-svg.png",
79
+ const optionWithIcon: Option[] = [
80
+ {
81
+ value: "1",
82
+ label: "Ebay",
83
+ icon: "shopping_cart",
84
+ },
57
85
  ];
58
86
 
59
87
  const optionsIcon: any = options.map((op, i) => ({ ...op, icon: icons[i] }));
60
88
 
61
- export const Chromatic = () => (
89
+ const opinionatedTheme = {
90
+ dropdown: {
91
+ baseColor: "#ffffff",
92
+ fontColor: "#000000",
93
+ optionFontColor: "#000000",
94
+ },
95
+ };
96
+
97
+ const Dropdown = () => (
62
98
  <>
63
99
  <ExampleContainer>
64
100
  <Title title="Default" theme="light" level={4} />
@@ -68,7 +104,7 @@ export const Chromatic = () => (
68
104
  <Title title="Hovered" theme="light" level={4} />
69
105
  <DxcDropdown label="Hovered" options={options} onSelectOption={(value) => {}} />
70
106
  </ExampleContainer>
71
- <ExampleContainer pseudoState="pseudo-focus-visible">
107
+ <ExampleContainer pseudoState="pseudo-focus">
72
108
  <Title title="Focused" theme="light" level={4} />
73
109
  <DxcDropdown label="Focused" options={options} onSelectOption={(value) => {}} />
74
110
  </ExampleContainer>
@@ -94,7 +130,7 @@ export const Chromatic = () => (
94
130
  label="Icon after"
95
131
  options={options}
96
132
  onSelectOption={(value) => {}}
97
- icon="https://iconape.com/wp-content/files/yd/367773/svg/logo-linkedin-logo-icon-png-svg.png"
133
+ icon="shopping_cart"
98
134
  iconPosition="after"
99
135
  />
100
136
  </ExampleContainer>
@@ -103,9 +139,17 @@ export const Chromatic = () => (
103
139
  <DxcDropdown options={options} onSelectOption={(value) => {}} icon={iconSVG} />
104
140
  </ExampleContainer>
105
141
  <ExampleContainer>
106
- <Title title="Large icon" theme="light" level={4} />
142
+ <Title title="Only icon without caret" theme="light" level={4} />
143
+ <DxcDropdown options={options} onSelectOption={(value) => {}} icon="menu" caretHidden />
144
+ </ExampleContainer>
145
+ <ExampleContainer>
146
+ <Title title="Large icon (SVG)" theme="light" level={4} />
107
147
  <DxcDropdown label="Large icon" options={options} onSelectOption={(value) => {}} icon={iconSVGLarge} />
108
148
  </ExampleContainer>
149
+ <ExampleContainer>
150
+ <Title title="Large icon (image)" theme="light" level={4} />
151
+ <DxcDropdown label="Large icon" options={options} onSelectOption={(value) => {}} icon="menu" />
152
+ </ExampleContainer>
109
153
  <ExampleContainer>
110
154
  <Title title="Disabled with icon" theme="light" level={4} />
111
155
  <DxcDropdown
@@ -188,62 +232,196 @@ export const Chromatic = () => (
188
232
  size="fillParent"
189
233
  />
190
234
  </ExampleContainer>
235
+ <ExampleContainer expanded>
236
+ <Title title="Opened menu" theme="light" level={4} />
237
+ <DxcDropdown label="Label" options={options} onSelectOption={(value) => {}} margin={{ top: "xxlarge" }} />
238
+ </ExampleContainer>
191
239
  </>
192
240
  );
193
241
 
194
- const DropdownWithOptions = () => (
195
- <ExampleContainer expanded>
196
- <Title title="Options" theme="light" level={4} />
197
- <DxcDropdown label="Options with icon" options={optionsIcon} onSelectOption={(value) => {}} />
198
- </ExampleContainer>
199
- );
242
+ const DropdownListStates = () => {
243
+ const colorsTheme: any = useTheme();
200
244
 
201
- const DropdownHoverOption = () => (
202
- <ExampleContainer pseudoState="pseudo-hover" expanded>
203
- <Title title="Hovered option" theme="light" level={4} />
204
- <DxcDropdown label="Hovered options" options={option} onSelectOption={(value) => {}} />
205
- </ExampleContainer>
206
- );
245
+ return (
246
+ <>
247
+ <Title title="Dropdown Menu" theme="light" level={2} />
248
+ <ExampleContainer>
249
+ <Title
250
+ title="List dialog uses a Radix Popover to appear over elements with a certain z-index"
251
+ theme="light"
252
+ level={3}
253
+ />
254
+ <div
255
+ style={{
256
+ position: "relative",
257
+ display: "flex",
258
+ flexDirection: "column",
259
+ gap: "20px",
260
+ height: "150px",
261
+ width: "min-content",
262
+ marginBottom: "100px",
263
+ padding: "20px",
264
+ border: "1px solid black",
265
+ borderRadius: "4px",
266
+ overflow: "auto",
267
+ zIndex: "1300",
268
+ }}
269
+ >
270
+ <DxcDropdown
271
+ label="Select a platform"
272
+ options={defaultOptions}
273
+ onSelectOption={(option) => {}}
274
+ size="medium"
275
+ />
276
+ <button style={{ zIndex: "1", width: "100px" }}>Submit</button>
277
+ </div>
278
+ </ExampleContainer>
279
+ <ThemeProvider theme={colorsTheme.dropdown}>
280
+ <Title title="Option states" theme="light" level={3} />
281
+ <ExampleContainer pseudoState="pseudo-hover">
282
+ <Title title="Hovered option" theme="light" level={4} />
283
+ <DropdownMenu
284
+ id="x1"
285
+ dropdownTriggerId="dtx1"
286
+ iconsPosition="before"
287
+ visualFocusIndex={-1}
288
+ menuItemOnClick={(value) => {}}
289
+ onKeyDown={(e) => {}}
290
+ options={optionWithIcon}
291
+ styles={{ width: 240 }}
292
+ />
293
+ </ExampleContainer>
294
+ <ExampleContainer pseudoState="pseudo-active">
295
+ <Title title="Active option" theme="light" level={4} />
296
+ <DropdownMenu
297
+ id="x2"
298
+ dropdownTriggerId="dtx2"
299
+ iconsPosition="before"
300
+ visualFocusIndex={-1}
301
+ menuItemOnClick={(value) => {}}
302
+ onKeyDown={(e) => {}}
303
+ options={optionWithIcon}
304
+ styles={{ width: 240 }}
305
+ />
306
+ </ExampleContainer>
307
+ <ExampleContainer>
308
+ <Title title="Focused option" theme="light" level={4} />
309
+ <DropdownMenu
310
+ id="x3"
311
+ dropdownTriggerId="dtx3"
312
+ iconsPosition="before"
313
+ visualFocusIndex={0}
314
+ menuItemOnClick={(value) => {}}
315
+ onKeyDown={(e) => {}}
316
+ options={options}
317
+ styles={{ width: 240 }}
318
+ />
319
+ </ExampleContainer>
320
+ <Title title="Icons" theme="light" level={3} />
321
+ <ExampleContainer>
322
+ <Title title="Before" theme="light" level={4} />
323
+ <DropdownMenu
324
+ id="x4"
325
+ dropdownTriggerId="dtx4"
326
+ iconsPosition="before"
327
+ visualFocusIndex={-1}
328
+ menuItemOnClick={(value) => {}}
329
+ onKeyDown={(e) => {}}
330
+ options={optionsIcon}
331
+ styles={{ width: 240 }}
332
+ />
333
+ <Title title="After" theme="light" level={4} />
334
+ <DropdownMenu
335
+ id="x5"
336
+ dropdownTriggerId="dtx5"
337
+ iconsPosition="after"
338
+ visualFocusIndex={-1}
339
+ menuItemOnClick={(value) => {}}
340
+ onKeyDown={(e) => {}}
341
+ options={optionsIcon}
342
+ styles={{ width: 240 }}
343
+ />
344
+ </ExampleContainer>
345
+ </ThemeProvider>
346
+ </>
347
+ );
348
+ };
207
349
 
208
- const DropdownActiveOption = () => (
209
- <ExampleContainer pseudoState="pseudo-active" expanded>
210
- <Title title="Actived option" theme="light" level={4} />
211
- <DxcDropdown label="Actived options" options={option} onSelectOption={(value) => {}} />
350
+ const DropdownRightAlignment = () => (
351
+ <ExampleContainer expanded>
352
+ <Title title="Dropdown collisions on the right boundary (right)" theme="light" level={4} />
353
+ <DxcFlex justifyContent="flex-end">
354
+ <DxcDropdown label="Label" options={options} onSelectOption={(value) => {}} />
355
+ </DxcFlex>
212
356
  </ExampleContainer>
213
357
  );
214
358
 
215
- const DropdownWithOptionsIconAfter = () => (
359
+ const DropdownCenterAlignment = () => (
216
360
  <ExampleContainer expanded>
217
- <Title title="Icon after options" theme="light" level={4} />
218
- <DxcDropdown
219
- label="Icon after options"
220
- options={optionsIcon}
221
- onSelectOption={(value) => {}}
222
- optionsIconPosition="after"
223
- />
361
+ <Title title="Dropdown collisions on the right boundary (centered)" theme="light" level={4} />
362
+ <DxcFlex justifyContent="flex-end">
363
+ <DxcDropdown label="Label" options={defaultOptions} onSelectOption={(value) => {}} margin="small" />
364
+ </DxcFlex>
224
365
  </ExampleContainer>
225
366
  );
226
367
 
227
- export const DropdownOptions = DropdownWithOptions.bind({});
228
- DropdownOptions.play = async ({ canvasElement }) => {
368
+ export const Chromatic = Dropdown.bind({});
369
+ Chromatic.play = async ({ canvasElement }) => {
229
370
  const canvas = within(canvasElement);
230
- await userEvent.click(canvas.getByRole("button"));
371
+ const buttonList = canvas.getAllByRole("button");
372
+ await userEvent.click(buttonList[buttonList.length - 1]);
231
373
  };
232
374
 
233
- export const DropdownHoveredOption = DropdownHoverOption.bind({});
234
- DropdownHoveredOption.play = async ({ canvasElement }) => {
375
+ export const OpinionatedTheme = () => (
376
+ <>
377
+ <Title title="Opinionated theme" theme="light" level={2} />
378
+ <ExampleContainer>
379
+ <Title title="Default" theme="light" level={4} />
380
+ <HalstackProvider theme={opinionatedTheme}>
381
+ <DxcDropdown label="Default" options={options} onSelectOption={(value) => {}} icon={iconSVG} />
382
+ </HalstackProvider>
383
+ </ExampleContainer>
384
+ <ExampleContainer pseudoState="pseudo-hover">
385
+ <Title title="Hovered" theme="light" level={4} />
386
+ <HalstackProvider theme={opinionatedTheme}>
387
+ <DxcDropdown label="Hovered" options={options} onSelectOption={(value) => {}} icon={iconSVG} />
388
+ </HalstackProvider>
389
+ </ExampleContainer>
390
+ <ExampleContainer pseudoState="pseudo-active">
391
+ <Title title="Actived" theme="light" level={4} />
392
+ <HalstackProvider theme={opinionatedTheme}>
393
+ <DxcDropdown label="Actived" options={options} onSelectOption={(value) => {}} icon={iconSVG} />
394
+ </HalstackProvider>
395
+ </ExampleContainer>
396
+ <ExampleContainer pseudoState="pseudo-focus">
397
+ <Title title="Focused" theme="light" level={4} />
398
+ <HalstackProvider theme={opinionatedTheme}>
399
+ <DxcDropdown label="Focused" options={options} onSelectOption={(value) => {}} icon={iconSVG} />
400
+ </HalstackProvider>
401
+ </ExampleContainer>
402
+ <ExampleContainer>
403
+ <Title title="Disabled" theme="light" level={4} />
404
+ <HalstackProvider theme={opinionatedTheme}>
405
+ <DxcDropdown label="Disabled" options={options} onSelectOption={(value) => {}} icon={iconSVG} disabled />
406
+ </HalstackProvider>
407
+ </ExampleContainer>
408
+ </>
409
+ );
410
+
411
+ export const DropdownMenuStates = DropdownListStates.bind({});
412
+ DropdownMenuStates.play = async ({ canvasElement }) => {
235
413
  const canvas = within(canvasElement);
236
- await userEvent.click(canvas.getByRole("button"));
414
+ await userEvent.click(canvas.getAllByRole("button")[0]);
237
415
  };
238
416
 
239
- export const DropdownActivedOption = DropdownActiveOption.bind({});
240
- DropdownActivedOption.play = async ({ canvasElement }) => {
417
+ export const DropdownMenuAlignedRight = DropdownRightAlignment.bind({});
418
+ DropdownMenuAlignedRight.play = async ({ canvasElement }) => {
241
419
  const canvas = within(canvasElement);
242
420
  await userEvent.click(canvas.getByRole("button"));
243
421
  };
244
422
 
245
- export const DropdownOptionsIconAfter = DropdownWithOptionsIconAfter.bind({});
246
- DropdownOptionsIconAfter.play = async ({ canvasElement }) => {
423
+ export const DropdownMenuAlignedCenter = DropdownCenterAlignment.bind({});
424
+ DropdownMenuAlignedCenter.play = async ({ canvasElement }) => {
247
425
  const canvas = within(canvasElement);
248
426
  await userEvent.click(canvas.getByRole("button"));
249
427
  };
@@ -0,0 +1 @@
1
+ export {};