@dxc-technology/halstack-react 0.0.0-f4755a1 → 0.0.0-f4dcdd7

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 (534) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +5 -22
  3. package/HalstackContext.d.ts +1244 -0
  4. package/HalstackContext.js +306 -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 -192
  10. package/accordion/Accordion.stories.tsx +83 -142
  11. package/accordion/Accordion.test.d.ts +1 -0
  12. package/accordion/Accordion.test.js +56 -0
  13. package/accordion/types.d.ts +11 -22
  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 +94 -0
  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 +17 -22
  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 +75 -0
  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 +4 -0
  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 +54 -0
  49. package/bleed/Bleed.d.ts +3 -0
  50. package/bleed/Bleed.js +43 -0
  51. package/bleed/Bleed.stories.tsx +342 -0
  52. package/bleed/types.d.ts +37 -0
  53. package/box/Box.accessibility.test.d.ts +1 -0
  54. package/box/Box.accessibility.test.js +33 -0
  55. package/box/Box.d.ts +1 -1
  56. package/box/Box.js +30 -81
  57. package/box/Box.stories.tsx +38 -51
  58. package/box/Box.test.d.ts +1 -0
  59. package/box/Box.test.js +13 -0
  60. package/box/types.d.ts +3 -14
  61. package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
  62. package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
  63. package/breadcrumbs/Breadcrumbs.d.ts +4 -0
  64. package/breadcrumbs/Breadcrumbs.js +79 -0
  65. package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
  66. package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
  67. package/breadcrumbs/Breadcrumbs.test.js +169 -0
  68. package/breadcrumbs/Item.d.ts +4 -0
  69. package/breadcrumbs/Item.js +52 -0
  70. package/breadcrumbs/dropdownTheme.d.ts +53 -0
  71. package/breadcrumbs/dropdownTheme.js +62 -0
  72. package/breadcrumbs/types.d.ts +16 -0
  73. package/breadcrumbs/types.js +5 -0
  74. package/bulleted-list/BulletedList.accessibility.test.d.ts +1 -0
  75. package/bulleted-list/BulletedList.accessibility.test.js +119 -0
  76. package/bulleted-list/BulletedList.d.ts +7 -0
  77. package/bulleted-list/BulletedList.js +92 -0
  78. package/bulleted-list/BulletedList.stories.tsx +115 -0
  79. package/bulleted-list/types.d.ts +38 -0
  80. package/bulleted-list/types.js +5 -0
  81. package/button/Button.accessibility.test.d.ts +1 -0
  82. package/button/Button.accessibility.test.js +127 -0
  83. package/button/Button.d.ts +1 -1
  84. package/button/Button.js +64 -122
  85. package/button/Button.stories.tsx +155 -106
  86. package/button/Button.test.d.ts +1 -0
  87. package/button/Button.test.js +38 -0
  88. package/button/types.d.ts +12 -12
  89. package/card/Card.accessibility.test.d.ts +1 -0
  90. package/card/Card.accessibility.test.js +36 -0
  91. package/card/Card.d.ts +1 -1
  92. package/card/Card.js +59 -102
  93. package/card/Card.stories.tsx +13 -43
  94. package/card/Card.test.d.ts +1 -0
  95. package/card/Card.test.js +39 -0
  96. package/card/types.d.ts +6 -11
  97. package/checkbox/Checkbox.accessibility.test.d.ts +1 -0
  98. package/checkbox/Checkbox.accessibility.test.js +87 -0
  99. package/checkbox/Checkbox.d.ts +2 -2
  100. package/checkbox/Checkbox.js +140 -181
  101. package/checkbox/Checkbox.stories.tsx +166 -136
  102. package/checkbox/Checkbox.test.d.ts +1 -0
  103. package/checkbox/Checkbox.test.js +199 -0
  104. package/checkbox/types.d.ts +18 -6
  105. package/chip/Chip.accessibility.test.d.ts +1 -0
  106. package/chip/Chip.accessibility.test.js +69 -0
  107. package/chip/Chip.d.ts +1 -1
  108. package/chip/Chip.js +45 -129
  109. package/chip/Chip.stories.tsx +142 -32
  110. package/chip/Chip.test.d.ts +1 -0
  111. package/chip/Chip.test.js +41 -0
  112. package/chip/types.d.ts +38 -23
  113. package/common/coreTokens.d.ts +237 -0
  114. package/common/coreTokens.js +184 -0
  115. package/common/fonts.css +2 -0
  116. package/common/utils.d.ts +1 -0
  117. package/common/utils.js +6 -12
  118. package/common/variables.d.ts +1390 -0
  119. package/common/variables.js +1078 -1421
  120. package/container/Container.d.ts +4 -0
  121. package/container/Container.js +194 -0
  122. package/container/Container.stories.tsx +214 -0
  123. package/container/types.d.ts +74 -0
  124. package/container/types.js +5 -0
  125. package/contextual-menu/ContextualMenu.accessibility.test.d.ts +1 -0
  126. package/contextual-menu/ContextualMenu.accessibility.test.js +98 -0
  127. package/contextual-menu/ContextualMenu.d.ts +5 -0
  128. package/contextual-menu/ContextualMenu.js +88 -0
  129. package/contextual-menu/ContextualMenu.stories.tsx +232 -0
  130. package/contextual-menu/ContextualMenu.test.d.ts +1 -0
  131. package/contextual-menu/ContextualMenu.test.js +205 -0
  132. package/contextual-menu/GroupItem.d.ts +4 -0
  133. package/contextual-menu/GroupItem.js +67 -0
  134. package/contextual-menu/ItemAction.d.ts +4 -0
  135. package/contextual-menu/ItemAction.js +51 -0
  136. package/contextual-menu/MenuItem.d.ts +4 -0
  137. package/contextual-menu/MenuItem.js +29 -0
  138. package/contextual-menu/SingleItem.d.ts +4 -0
  139. package/contextual-menu/SingleItem.js +38 -0
  140. package/contextual-menu/types.d.ts +58 -0
  141. package/contextual-menu/types.js +5 -0
  142. package/date-input/Calendar.d.ts +4 -0
  143. package/date-input/Calendar.js +214 -0
  144. package/date-input/DateInput.accessibility.test.d.ts +1 -0
  145. package/date-input/DateInput.accessibility.test.js +230 -0
  146. package/date-input/DateInput.js +172 -308
  147. package/date-input/DateInput.stories.tsx +210 -56
  148. package/date-input/DateInput.test.d.ts +1 -0
  149. package/date-input/DateInput.test.js +809 -0
  150. package/date-input/DatePicker.d.ts +4 -0
  151. package/date-input/DatePicker.js +121 -0
  152. package/date-input/YearPicker.d.ts +4 -0
  153. package/date-input/YearPicker.js +100 -0
  154. package/date-input/types.d.ts +86 -22
  155. package/dialog/Dialog.accessibility.test.d.ts +1 -0
  156. package/dialog/Dialog.accessibility.test.js +69 -0
  157. package/dialog/Dialog.d.ts +1 -1
  158. package/dialog/Dialog.js +56 -129
  159. package/dialog/Dialog.stories.tsx +325 -167
  160. package/dialog/Dialog.test.d.ts +1 -0
  161. package/dialog/Dialog.test.js +371 -0
  162. package/dialog/types.d.ts +18 -25
  163. package/divider/Divider.accessibility.test.d.ts +1 -0
  164. package/divider/Divider.accessibility.test.js +33 -0
  165. package/divider/Divider.d.ts +4 -0
  166. package/divider/Divider.js +36 -0
  167. package/divider/Divider.stories.tsx +223 -0
  168. package/divider/Divider.test.d.ts +1 -0
  169. package/divider/Divider.test.js +38 -0
  170. package/divider/types.d.ts +21 -0
  171. package/divider/types.js +5 -0
  172. package/dropdown/Dropdown.accessibility.test.d.ts +1 -0
  173. package/dropdown/Dropdown.accessibility.test.js +184 -0
  174. package/dropdown/Dropdown.d.ts +1 -1
  175. package/dropdown/Dropdown.js +232 -329
  176. package/dropdown/Dropdown.stories.tsx +244 -64
  177. package/dropdown/Dropdown.test.d.ts +1 -0
  178. package/dropdown/Dropdown.test.js +629 -0
  179. package/dropdown/DropdownMenu.d.ts +4 -0
  180. package/dropdown/DropdownMenu.js +63 -0
  181. package/dropdown/DropdownMenuItem.d.ts +4 -0
  182. package/dropdown/DropdownMenuItem.js +71 -0
  183. package/dropdown/types.d.ts +37 -30
  184. package/file-input/FileInput.accessibility.test.d.ts +1 -0
  185. package/file-input/FileInput.accessibility.test.js +167 -0
  186. package/file-input/FileInput.d.ts +2 -2
  187. package/file-input/FileInput.js +245 -395
  188. package/file-input/FileInput.stories.tsx +123 -11
  189. package/file-input/FileInput.test.d.ts +1 -0
  190. package/file-input/FileInput.test.js +404 -0
  191. package/file-input/FileItem.d.ts +4 -14
  192. package/file-input/FileItem.js +61 -120
  193. package/file-input/types.d.ts +25 -8
  194. package/flex/Flex.d.ts +4 -0
  195. package/flex/Flex.js +57 -0
  196. package/flex/Flex.stories.tsx +112 -0
  197. package/flex/types.d.ts +97 -0
  198. package/flex/types.js +5 -0
  199. package/footer/Footer.accessibility.test.d.ts +1 -0
  200. package/footer/Footer.accessibility.test.js +125 -0
  201. package/footer/Footer.d.ts +1 -1
  202. package/footer/Footer.js +73 -193
  203. package/footer/Footer.stories.tsx +99 -21
  204. package/footer/Footer.test.d.ts +1 -0
  205. package/footer/Footer.test.js +85 -0
  206. package/footer/Icons.d.ts +3 -2
  207. package/footer/Icons.js +54 -23
  208. package/footer/types.d.ts +26 -27
  209. package/grid/Grid.d.ts +7 -0
  210. package/grid/Grid.js +76 -0
  211. package/grid/Grid.stories.tsx +219 -0
  212. package/grid/types.d.ts +115 -0
  213. package/grid/types.js +5 -0
  214. package/header/Header.accessibility.test.d.ts +1 -0
  215. package/header/Header.accessibility.test.js +94 -0
  216. package/header/Header.d.ts +4 -3
  217. package/header/Header.js +104 -218
  218. package/header/Header.stories.tsx +168 -63
  219. package/header/Header.test.d.ts +1 -0
  220. package/header/Header.test.js +66 -0
  221. package/header/Icons.d.ts +2 -2
  222. package/header/Icons.js +5 -15
  223. package/header/types.d.ts +7 -21
  224. package/heading/Heading.accessibility.test.d.ts +1 -0
  225. package/heading/Heading.accessibility.test.js +33 -0
  226. package/heading/Heading.js +10 -32
  227. package/heading/Heading.stories.tsx +3 -2
  228. package/heading/Heading.test.d.ts +1 -0
  229. package/heading/Heading.test.js +156 -0
  230. package/heading/types.d.ts +7 -7
  231. package/icon/Icon.accessibility.test.d.ts +1 -0
  232. package/icon/Icon.accessibility.test.js +30 -0
  233. package/icon/Icon.d.ts +4 -0
  234. package/icon/Icon.js +33 -0
  235. package/icon/Icon.stories.tsx +28 -0
  236. package/icon/types.d.ts +4 -0
  237. package/icon/types.js +5 -0
  238. package/image/Image.accessibility.test.d.ts +1 -0
  239. package/image/Image.accessibility.test.js +56 -0
  240. package/image/Image.d.ts +4 -0
  241. package/image/Image.js +70 -0
  242. package/image/Image.stories.tsx +129 -0
  243. package/image/types.d.ts +72 -0
  244. package/image/types.js +5 -0
  245. package/inset/Inset.d.ts +3 -0
  246. package/inset/Inset.js +43 -0
  247. package/inset/Inset.stories.tsx +230 -0
  248. package/inset/types.d.ts +37 -0
  249. package/inset/types.js +5 -0
  250. package/layout/ApplicationLayout.d.ts +16 -6
  251. package/layout/ApplicationLayout.js +88 -176
  252. package/layout/ApplicationLayout.stories.tsx +85 -94
  253. package/layout/Icons.d.ts +7 -0
  254. package/layout/Icons.js +41 -48
  255. package/layout/types.d.ts +19 -35
  256. package/link/Link.accessibility.test.d.ts +1 -0
  257. package/link/Link.accessibility.test.js +108 -0
  258. package/link/Link.d.ts +3 -2
  259. package/link/Link.js +64 -108
  260. package/link/Link.stories.tsx +161 -54
  261. package/link/Link.test.d.ts +1 -0
  262. package/link/Link.test.js +63 -0
  263. package/link/types.d.ts +15 -35
  264. package/main.d.ts +21 -18
  265. package/main.js +90 -120
  266. package/nav-tabs/NavTabs.accessibility.test.d.ts +1 -0
  267. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  268. package/nav-tabs/NavTabs.d.ts +7 -0
  269. package/nav-tabs/NavTabs.js +108 -0
  270. package/nav-tabs/NavTabs.stories.tsx +294 -0
  271. package/nav-tabs/NavTabs.test.d.ts +1 -0
  272. package/nav-tabs/NavTabs.test.js +77 -0
  273. package/nav-tabs/NavTabsContext.d.ts +3 -0
  274. package/nav-tabs/NavTabsContext.js +8 -0
  275. package/nav-tabs/Tab.d.ts +4 -0
  276. package/nav-tabs/Tab.js +117 -0
  277. package/nav-tabs/types.d.ts +52 -0
  278. package/nav-tabs/types.js +5 -0
  279. package/number-input/NumberInput.accessibility.test.d.ts +1 -0
  280. package/number-input/NumberInput.accessibility.test.js +228 -0
  281. package/number-input/NumberInput.js +47 -44
  282. package/number-input/NumberInput.stories.tsx +44 -28
  283. package/number-input/NumberInput.test.d.ts +1 -0
  284. package/number-input/NumberInput.test.js +989 -0
  285. package/number-input/NumberInputContext.d.ts +3 -4
  286. package/number-input/NumberInputContext.js +3 -14
  287. package/number-input/types.d.ts +34 -15
  288. package/package.json +55 -54
  289. package/paginator/Paginator.accessibility.test.d.ts +1 -0
  290. package/paginator/Paginator.accessibility.test.js +79 -0
  291. package/paginator/Paginator.js +46 -100
  292. package/paginator/Paginator.stories.tsx +24 -0
  293. package/paginator/Paginator.test.d.ts +1 -0
  294. package/paginator/Paginator.test.js +335 -0
  295. package/paginator/types.d.ts +3 -3
  296. package/paragraph/Paragraph.accessibility.test.d.ts +1 -0
  297. package/paragraph/Paragraph.accessibility.test.js +28 -0
  298. package/paragraph/Paragraph.d.ts +5 -0
  299. package/paragraph/Paragraph.js +22 -0
  300. package/paragraph/Paragraph.stories.tsx +27 -0
  301. package/password-input/PasswordInput.accessibility.test.d.ts +1 -0
  302. package/password-input/PasswordInput.accessibility.test.js +153 -0
  303. package/password-input/PasswordInput.js +58 -124
  304. package/password-input/PasswordInput.stories.tsx +3 -35
  305. package/password-input/PasswordInput.test.d.ts +1 -0
  306. package/password-input/PasswordInput.test.js +198 -0
  307. package/password-input/types.d.ts +21 -17
  308. package/progress-bar/ProgressBar.accessibility.test.d.ts +1 -0
  309. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  310. package/progress-bar/ProgressBar.js +68 -92
  311. package/progress-bar/ProgressBar.stories.tsx +93 -0
  312. package/progress-bar/ProgressBar.test.d.ts +1 -0
  313. package/progress-bar/ProgressBar.test.js +93 -0
  314. package/progress-bar/types.d.ts +3 -3
  315. package/quick-nav/QuickNav.accessibility.test.d.ts +1 -0
  316. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  317. package/quick-nav/QuickNav.d.ts +4 -0
  318. package/quick-nav/QuickNav.js +94 -0
  319. package/quick-nav/QuickNav.stories.tsx +356 -0
  320. package/quick-nav/types.d.ts +21 -0
  321. package/quick-nav/types.js +5 -0
  322. package/radio-group/Radio.d.ts +1 -1
  323. package/radio-group/Radio.js +77 -65
  324. package/radio-group/RadioGroup.accessibility.test.d.ts +1 -0
  325. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  326. package/radio-group/RadioGroup.js +156 -89
  327. package/radio-group/RadioGroup.stories.tsx +178 -20
  328. package/radio-group/RadioGroup.test.d.ts +1 -0
  329. package/radio-group/RadioGroup.test.js +754 -0
  330. package/radio-group/types.d.ts +93 -16
  331. package/resultset-table/Icons.d.ts +7 -0
  332. package/resultset-table/Icons.js +47 -0
  333. package/resultset-table/ResultsetTable.accessibility.test.d.ts +1 -0
  334. package/resultset-table/ResultsetTable.accessibility.test.js +285 -0
  335. package/resultset-table/ResultsetTable.d.ts +7 -0
  336. package/resultset-table/ResultsetTable.js +171 -0
  337. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +173 -36
  338. package/resultset-table/ResultsetTable.test.d.ts +1 -0
  339. package/resultset-table/ResultsetTable.test.js +380 -0
  340. package/{resultsetTable → resultset-table}/types.d.ts +44 -11
  341. package/resultset-table/types.js +5 -0
  342. package/select/Listbox.d.ts +4 -0
  343. package/select/Listbox.js +151 -0
  344. package/select/Option.d.ts +4 -0
  345. package/select/Option.js +89 -0
  346. package/select/Select.accessibility.test.d.ts +1 -0
  347. package/select/Select.accessibility.test.js +228 -0
  348. package/select/Select.js +239 -502
  349. package/select/Select.stories.tsx +602 -255
  350. package/select/Select.test.d.ts +1 -0
  351. package/select/Select.test.js +2268 -0
  352. package/select/types.d.ts +65 -26
  353. package/sidenav/Sidenav.accessibility.test.d.ts +1 -0
  354. package/sidenav/Sidenav.accessibility.test.js +59 -0
  355. package/sidenav/Sidenav.d.ts +6 -5
  356. package/sidenav/Sidenav.js +136 -71
  357. package/sidenav/Sidenav.stories.tsx +246 -134
  358. package/sidenav/Sidenav.test.d.ts +1 -0
  359. package/sidenav/Sidenav.test.js +37 -0
  360. package/sidenav/SidenavContext.d.ts +5 -0
  361. package/sidenav/SidenavContext.js +13 -0
  362. package/sidenav/types.d.ts +52 -26
  363. package/slider/Slider.accessibility.test.d.ts +1 -0
  364. package/slider/Slider.accessibility.test.js +104 -0
  365. package/slider/Slider.d.ts +2 -2
  366. package/slider/Slider.js +147 -181
  367. package/slider/Slider.stories.tsx +68 -65
  368. package/slider/Slider.test.d.ts +1 -0
  369. package/slider/Slider.test.js +257 -0
  370. package/slider/types.d.ts +11 -3
  371. package/spinner/Spinner.accessibility.test.d.ts +1 -0
  372. package/spinner/Spinner.accessibility.test.js +96 -0
  373. package/spinner/Spinner.js +34 -74
  374. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -26
  375. package/spinner/Spinner.test.d.ts +1 -0
  376. package/spinner/Spinner.test.js +55 -0
  377. package/spinner/types.d.ts +3 -3
  378. package/status-light/StatusLight.accessibility.test.d.ts +1 -0
  379. package/status-light/StatusLight.accessibility.test.js +157 -0
  380. package/status-light/StatusLight.d.ts +4 -0
  381. package/status-light/StatusLight.js +51 -0
  382. package/status-light/StatusLight.stories.tsx +74 -0
  383. package/status-light/StatusLight.test.d.ts +1 -0
  384. package/status-light/StatusLight.test.js +25 -0
  385. package/status-light/types.d.ts +17 -0
  386. package/status-light/types.js +5 -0
  387. package/switch/Switch.accessibility.test.d.ts +1 -0
  388. package/switch/Switch.accessibility.test.js +98 -0
  389. package/switch/Switch.d.ts +2 -2
  390. package/switch/Switch.js +146 -114
  391. package/switch/Switch.stories.tsx +57 -68
  392. package/switch/Switch.test.d.ts +1 -0
  393. package/switch/Switch.test.js +180 -0
  394. package/switch/types.d.ts +13 -5
  395. package/table/DropdownTheme.js +62 -0
  396. package/table/Table.accessibility.test.d.ts +1 -0
  397. package/table/Table.accessibility.test.js +93 -0
  398. package/table/Table.d.ts +6 -2
  399. package/table/Table.js +78 -35
  400. package/table/Table.stories.tsx +663 -0
  401. package/table/Table.test.d.ts +1 -0
  402. package/table/Table.test.js +112 -0
  403. package/table/types.d.ts +34 -6
  404. package/tabs/Tab.d.ts +4 -0
  405. package/tabs/Tab.js +117 -0
  406. package/tabs/Tabs.accessibility.test.d.ts +1 -0
  407. package/tabs/Tabs.accessibility.test.js +56 -0
  408. package/tabs/Tabs.d.ts +1 -1
  409. package/tabs/Tabs.js +306 -146
  410. package/tabs/Tabs.stories.tsx +127 -18
  411. package/tabs/Tabs.test.d.ts +1 -0
  412. package/tabs/Tabs.test.js +276 -0
  413. package/tabs/types.d.ts +46 -24
  414. package/tag/Tag.accessibility.test.d.ts +1 -0
  415. package/tag/Tag.accessibility.test.js +69 -0
  416. package/tag/Tag.d.ts +1 -1
  417. package/tag/Tag.js +43 -85
  418. package/tag/Tag.stories.tsx +37 -30
  419. package/tag/Tag.test.d.ts +1 -0
  420. package/tag/Tag.test.js +41 -0
  421. package/tag/types.d.ts +25 -16
  422. package/text-input/Suggestion.d.ts +4 -0
  423. package/text-input/Suggestion.js +67 -0
  424. package/text-input/Suggestions.d.ts +4 -0
  425. package/text-input/Suggestions.js +94 -0
  426. package/text-input/TextInput.accessibility.test.d.ts +1 -0
  427. package/text-input/TextInput.accessibility.test.js +321 -0
  428. package/text-input/TextInput.js +329 -546
  429. package/text-input/TextInput.stories.tsx +290 -272
  430. package/text-input/TextInput.test.d.ts +1 -0
  431. package/text-input/TextInput.test.js +1756 -0
  432. package/text-input/types.d.ts +71 -25
  433. package/textarea/Textarea.accessibility.test.d.ts +1 -0
  434. package/textarea/Textarea.accessibility.test.js +155 -0
  435. package/textarea/Textarea.js +85 -137
  436. package/textarea/Textarea.stories.tsx +174 -0
  437. package/textarea/Textarea.test.d.ts +1 -0
  438. package/textarea/Textarea.test.js +406 -0
  439. package/textarea/types.d.ts +27 -16
  440. package/toggle-group/ToggleGroup.accessibility.test.d.ts +1 -0
  441. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  442. package/toggle-group/ToggleGroup.d.ts +2 -2
  443. package/toggle-group/ToggleGroup.js +92 -107
  444. package/toggle-group/ToggleGroup.stories.tsx +56 -11
  445. package/toggle-group/ToggleGroup.test.d.ts +1 -0
  446. package/toggle-group/ToggleGroup.test.js +137 -0
  447. package/toggle-group/types.d.ts +36 -19
  448. package/typography/Typography.accessibility.test.d.ts +1 -0
  449. package/typography/Typography.accessibility.test.js +339 -0
  450. package/typography/Typography.d.ts +4 -0
  451. package/typography/Typography.js +23 -0
  452. package/typography/Typography.stories.tsx +198 -0
  453. package/typography/types.d.ts +18 -0
  454. package/typography/types.js +5 -0
  455. package/useTheme.d.ts +1142 -1
  456. package/useTheme.js +4 -11
  457. package/useTranslatedLabels.d.ts +85 -0
  458. package/useTranslatedLabels.js +14 -0
  459. package/utils/BaseTypography.d.ts +21 -0
  460. package/utils/BaseTypography.js +94 -0
  461. package/utils/FocusLock.d.ts +13 -0
  462. package/utils/FocusLock.js +124 -0
  463. package/wizard/Wizard.accessibility.test.d.ts +1 -0
  464. package/wizard/Wizard.accessibility.test.js +55 -0
  465. package/wizard/Wizard.d.ts +1 -1
  466. package/wizard/Wizard.js +78 -120
  467. package/wizard/Wizard.stories.tsx +67 -19
  468. package/wizard/Wizard.test.d.ts +1 -0
  469. package/wizard/Wizard.test.js +114 -0
  470. package/wizard/types.d.ts +14 -10
  471. package/ThemeContext.d.ts +0 -15
  472. package/ThemeContext.js +0 -243
  473. package/V3Select/V3Select.js +0 -455
  474. package/V3Select/index.d.ts +0 -27
  475. package/V3Textarea/V3Textarea.js +0 -260
  476. package/V3Textarea/index.d.ts +0 -27
  477. package/card/ice-cream.jpg +0 -0
  478. package/common/OpenSans.css +0 -81
  479. package/common/RequiredComponent.js +0 -32
  480. package/common/fonts/OpenSans-Bold.ttf +0 -0
  481. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  482. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  483. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  484. package/common/fonts/OpenSans-Italic.ttf +0 -0
  485. package/common/fonts/OpenSans-Light.ttf +0 -0
  486. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  487. package/common/fonts/OpenSans-Regular.ttf +0 -0
  488. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  489. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  490. package/date/Date.js +0 -373
  491. package/date/index.d.ts +0 -27
  492. package/input-text/Icons.js +0 -22
  493. package/input-text/InputText.js +0 -611
  494. package/input-text/index.d.ts +0 -36
  495. package/list/List.d.ts +0 -8
  496. package/list/List.js +0 -47
  497. package/list/List.stories.tsx +0 -95
  498. package/number-input/numberInputContextTypes.d.ts +0 -19
  499. package/paginator/Icons.js +0 -66
  500. package/progress-bar/ProgressBar.stories.jsx +0 -58
  501. package/radio/Radio.d.ts +0 -4
  502. package/radio/Radio.js +0 -174
  503. package/radio/Radio.stories.tsx +0 -192
  504. package/radio/types.d.ts +0 -54
  505. package/resultsetTable/ResultsetTable.d.ts +0 -4
  506. package/resultsetTable/ResultsetTable.js +0 -251
  507. package/row/Row.d.ts +0 -11
  508. package/row/Row.js +0 -127
  509. package/row/Row.stories.tsx +0 -239
  510. package/stack/Stack.d.ts +0 -10
  511. package/stack/Stack.js +0 -97
  512. package/stack/Stack.stories.tsx +0 -166
  513. package/table/Table.stories.jsx +0 -276
  514. package/text/Text.d.ts +0 -7
  515. package/text/Text.js +0 -30
  516. package/text/Text.stories.tsx +0 -19
  517. package/textarea/Textarea.stories.jsx +0 -135
  518. package/toggle/Toggle.js +0 -186
  519. package/toggle/index.d.ts +0 -21
  520. package/upload/Upload.js +0 -201
  521. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  522. package/upload/buttons-upload/Icons.js +0 -40
  523. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  524. package/upload/dragAndDropArea/Icons.js +0 -39
  525. package/upload/file-upload/FileToUpload.js +0 -115
  526. package/upload/file-upload/Icons.js +0 -66
  527. package/upload/files-upload/FilesToUpload.js +0 -109
  528. package/upload/index.d.ts +0 -15
  529. package/upload/transaction/Icons.js +0 -160
  530. package/upload/transaction/Transaction.js +0 -104
  531. package/upload/transactions/Transactions.js +0 -94
  532. /package/{radio → action-icon}/types.js +0 -0
  533. /package/{resultsetTable → badge}/types.js +0 -0
  534. /package/{number-input/numberInputContextTypes.js → bleed/types.js} +0 -0
@@ -0,0 +1,97 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
5
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
6
+ var _react = _interopRequireDefault(require("react"));
7
+ var _react2 = require("@testing-library/react");
8
+ var _axeHelper = require("../../test/accessibility/axe-helper.js");
9
+ var _RadioGroup = _interopRequireDefault(require("./RadioGroup"));
10
+ var options = [{
11
+ label: "Option 01",
12
+ value: "1"
13
+ }, {
14
+ label: "Option 02",
15
+ value: "2"
16
+ }, {
17
+ label: "Option 03",
18
+ value: "3"
19
+ }, {
20
+ label: "Option 04",
21
+ value: "4"
22
+ }, {
23
+ label: "Option 05",
24
+ value: "5",
25
+ disabled: true
26
+ }, {
27
+ label: "Option 06",
28
+ value: "6",
29
+ disabled: true
30
+ }, {
31
+ label: "Option 07",
32
+ value: "7",
33
+ disabled: true
34
+ }, {
35
+ label: "Option 08",
36
+ value: "8",
37
+ disabled: true
38
+ }, {
39
+ label: "Option 09",
40
+ value: "9"
41
+ }];
42
+ describe("Radio Group component accessibility tests", function () {
43
+ it("Should not have basic accessibility issues", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
44
+ var _render, container, results;
45
+ return _regenerator["default"].wrap(function _callee$(_context) {
46
+ while (1) switch (_context.prev = _context.next) {
47
+ case 0:
48
+ _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
49
+ label: "test-radioGroup-label",
50
+ options: options,
51
+ error: "Error",
52
+ defaultValue: "3",
53
+ helperText: "Helper Text",
54
+ name: "Name",
55
+ stacking: "row",
56
+ optionalItemLabel: "Optional",
57
+ optional: true
58
+ })), container = _render.container;
59
+ _context.next = 3;
60
+ return (0, _axeHelper.axe)(container);
61
+ case 3:
62
+ results = _context.sent;
63
+ expect(results).toHaveNoViolations();
64
+ case 5:
65
+ case "end":
66
+ return _context.stop();
67
+ }
68
+ }, _callee);
69
+ })));
70
+ it("Should not have basic accessibility issues for read-only mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
71
+ var _render2, container, results;
72
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
73
+ while (1) switch (_context2.prev = _context2.next) {
74
+ case 0:
75
+ _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
76
+ label: "test-radioGroup-label",
77
+ options: options,
78
+ error: "Error",
79
+ defaultValue: "3",
80
+ helperText: "Helper Text",
81
+ name: "Name",
82
+ stacking: "row",
83
+ optionalItemLabel: "Optional",
84
+ readOnly: true
85
+ })), container = _render2.container;
86
+ _context2.next = 3;
87
+ return (0, _axeHelper.axe)(container);
88
+ case 3:
89
+ results = _context2.sent;
90
+ expect(results).toHaveNoViolations();
91
+ case 5:
92
+ case "end":
93
+ return _context2.stop();
94
+ }
95
+ }, _callee2);
96
+ })));
97
+ });
@@ -1,76 +1,139 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  var _typeof = require("@babel/runtime/helpers/typeof");
6
-
7
5
  Object.defineProperty(exports, "__esModule", {
8
6
  value: true
9
7
  });
10
8
  exports["default"] = void 0;
11
-
12
9
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
-
10
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
14
11
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
15
-
16
12
  var _react = _interopRequireWildcard(require("react"));
17
-
18
13
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
19
-
20
- var _uuid = require("uuid");
21
-
22
14
  var _useTheme = _interopRequireDefault(require("../useTheme"));
23
-
15
+ var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
24
16
  var _Radio = _interopRequireDefault(require("./Radio"));
25
-
26
17
  var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7;
27
-
28
- function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
29
-
30
- function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
31
-
18
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
19
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
20
+ var getInitialFocusIndex = function getInitialFocusIndex(innerOptions, value) {
21
+ var initialSelectedOptionIndex = innerOptions.findIndex(function (option) {
22
+ return option.value === value;
23
+ });
24
+ return initialSelectedOptionIndex !== -1 ? initialSelectedOptionIndex : 0;
25
+ };
32
26
  var DxcRadioGroup = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
27
+ var _ref2;
33
28
  var label = _ref.label,
34
- name = _ref.name,
35
- helperText = _ref.helperText,
36
- options = _ref.options,
37
- _ref$disabled = _ref.disabled,
38
- disabled = _ref$disabled === void 0 ? false : _ref$disabled,
39
- _ref$optional = _ref.optional,
40
- optional = _ref$optional === void 0 ? false : _ref$optional,
41
- _ref$optionalItemLabe = _ref.optionalItemLabel,
42
- optionalItemLabel = _ref$optionalItemLabe === void 0 ? "None" : _ref$optionalItemLabe,
43
- _ref$readonly = _ref.readonly,
44
- readonly = _ref$readonly === void 0 ? false : _ref$readonly,
45
- _ref$stacking = _ref.stacking,
46
- stacking = _ref$stacking === void 0 ? "column" : _ref$stacking,
47
- defaultValue = _ref.defaultValue,
48
- value = _ref.value,
49
- onChange = _ref.onChange,
50
- error = _ref.error;
51
-
52
- var _useState = (0, _react.useState)("select-".concat((0, _uuid.v4)())),
53
- _useState2 = (0, _slicedToArray2["default"])(_useState, 1),
54
- radioGroupId = _useState2[0];
55
-
29
+ name = _ref.name,
30
+ helperText = _ref.helperText,
31
+ options = _ref.options,
32
+ _ref$disabled = _ref.disabled,
33
+ disabled = _ref$disabled === void 0 ? false : _ref$disabled,
34
+ _ref$optional = _ref.optional,
35
+ optional = _ref$optional === void 0 ? false : _ref$optional,
36
+ optionalItemLabel = _ref.optionalItemLabel,
37
+ _ref$readOnly = _ref.readOnly,
38
+ readOnly = _ref$readOnly === void 0 ? false : _ref$readOnly,
39
+ _ref$stacking = _ref.stacking,
40
+ stacking = _ref$stacking === void 0 ? "column" : _ref$stacking,
41
+ defaultValue = _ref.defaultValue,
42
+ value = _ref.value,
43
+ onChange = _ref.onChange,
44
+ onBlur = _ref.onBlur,
45
+ error = _ref.error,
46
+ _ref$tabIndex = _ref.tabIndex,
47
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
48
+ var radioGroupId = "radio-group-".concat((0, _react.useId)());
56
49
  var radioGroupLabelId = "label-".concat(radioGroupId);
57
-
58
- var _useState3 = (0, _react.useState)(defaultValue),
59
- _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
60
- innerValue = _useState4[0],
61
- setInnerValue = _useState4[1];
62
-
50
+ var errorId = "error-".concat(radioGroupId);
51
+ var _useState = (0, _react.useState)(defaultValue),
52
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
53
+ innerValue = _useState2[0],
54
+ setInnerValue = _useState2[1];
55
+ var _useState3 = (0, _react.useState)(true),
56
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
57
+ firstTimeFocus = _useState4[0],
58
+ setFirstTimeFocus = _useState4[1];
63
59
  var colorsTheme = (0, _useTheme["default"])();
64
- var handleOnChange = (0, _react.useCallback)(function (optionValue) {
65
- var val = value !== null && value !== void 0 ? value : innerValue;
66
-
67
- if (optionValue !== val) {
68
- value !== null && value !== void 0 ? value : setInnerValue(optionValue);
69
- onChange === null || onChange === void 0 ? void 0 : onChange({
70
- value: optionValue
60
+ var translatedLabels = (0, _useTranslatedLabels["default"])();
61
+ var innerOptions = (0, _react.useMemo)(function () {
62
+ return optional ? [].concat((0, _toConsumableArray2["default"])(options), [{
63
+ label: optionalItemLabel !== null && optionalItemLabel !== void 0 ? optionalItemLabel : translatedLabels.radioGroup.optionalItemLabelDefault,
64
+ value: "",
65
+ disabled: disabled
66
+ }]) : options;
67
+ }, [optional, options, optionalItemLabel, translatedLabels]);
68
+ var _useState5 = (0, _react.useState)(getInitialFocusIndex(innerOptions, value !== null && value !== void 0 ? value : innerValue)),
69
+ _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
70
+ currentFocusIndex = _useState6[0],
71
+ setCurrentFocusIndex = _useState6[1];
72
+ var handleOnChange = (0, _react.useCallback)(function (newValue) {
73
+ var currentValue = value !== null && value !== void 0 ? value : innerValue;
74
+ if (newValue !== currentValue && !readOnly) {
75
+ value !== null && value !== void 0 ? value : setInnerValue(newValue);
76
+ onChange === null || onChange === void 0 ? void 0 : onChange(newValue);
77
+ }
78
+ }, [value, innerValue, onChange]);
79
+ var handleOnBlur = function handleOnBlur(event) {
80
+ // If the radio group loses the focus to an element not contained inside it...
81
+ if (!event.currentTarget.contains(event.relatedTarget)) {
82
+ setFirstTimeFocus(true);
83
+ var currentValue = value !== null && value !== void 0 ? value : innerValue;
84
+ !optional && !Boolean(currentValue) ? onBlur === null || onBlur === void 0 ? void 0 : onBlur({
85
+ value: currentValue,
86
+ error: translatedLabels.formFields.requiredSelectionErrorMessage
87
+ }) : onBlur === null || onBlur === void 0 ? void 0 : onBlur({
88
+ value: currentValue
71
89
  });
72
90
  }
73
- }, [value, innerValue, setInnerValue, onChange]);
91
+ };
92
+ var handleOnFocus = function handleOnFocus() {
93
+ firstTimeFocus && setFirstTimeFocus(false);
94
+ };
95
+ var setPreviousRadioChecked = function setPreviousRadioChecked() {
96
+ setCurrentFocusIndex(function (currentFocusIndex) {
97
+ var index = currentFocusIndex === 0 ? innerOptions.length - 1 : currentFocusIndex - 1;
98
+ while (innerOptions[index].disabled) {
99
+ index = index === 0 ? innerOptions.length - 1 : index - 1;
100
+ }
101
+ handleOnChange(innerOptions[index].value);
102
+ return index;
103
+ });
104
+ };
105
+ var setNextRadioChecked = function setNextRadioChecked() {
106
+ setCurrentFocusIndex(function (currentFocusIndex) {
107
+ var index = currentFocusIndex === innerOptions.length - 1 ? 0 : currentFocusIndex + 1;
108
+ while (innerOptions[index].disabled) {
109
+ index = index === innerOptions.length - 1 ? 0 : index + 1;
110
+ }
111
+ handleOnChange(innerOptions[index].value);
112
+ return index;
113
+ });
114
+ };
115
+ var handleOnKeyDown = function handleOnKeyDown(event) {
116
+ switch (event.key) {
117
+ case "Left":
118
+ case "ArrowLeft":
119
+ case "Up":
120
+ case "ArrowUp":
121
+ event.preventDefault();
122
+ setPreviousRadioChecked();
123
+ break;
124
+ case "Right":
125
+ case "ArrowRight":
126
+ case "Down":
127
+ case "ArrowDown":
128
+ event.preventDefault();
129
+ setNextRadioChecked();
130
+ break;
131
+ case " ":
132
+ event.preventDefault();
133
+ handleOnChange(innerOptions[currentFocusIndex].value);
134
+ break;
135
+ }
136
+ };
74
137
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
75
138
  theme: colorsTheme.radioGroup
76
139
  }, /*#__PURE__*/_react["default"].createElement(RadioGroupContainer, {
@@ -79,41 +142,48 @@ var DxcRadioGroup = /*#__PURE__*/_react["default"].forwardRef(function (_ref, re
79
142
  id: radioGroupLabelId,
80
143
  helperText: helperText,
81
144
  disabled: disabled
82
- }, label, " ", optional && /*#__PURE__*/_react["default"].createElement(OptionalLabel, null, "(Optional)")), helperText && /*#__PURE__*/_react["default"].createElement(HelperText, {
145
+ }, label, optional && /*#__PURE__*/_react["default"].createElement(OptionalLabel, null, " ".concat(translatedLabels.formFields.optionalLabel))), helperText && /*#__PURE__*/_react["default"].createElement(HelperText, {
83
146
  disabled: disabled
84
147
  }, helperText), /*#__PURE__*/_react["default"].createElement(RadioGroup, {
148
+ onBlur: handleOnBlur,
149
+ onFocus: handleOnFocus,
150
+ onKeyDown: handleOnKeyDown,
85
151
  stacking: stacking,
86
152
  role: "radiogroup",
87
- "aria-labelledby": radioGroupLabelId
153
+ "aria-disabled": disabled,
154
+ "aria-labelledby": radioGroupLabelId,
155
+ "aria-invalid": error ? true : false,
156
+ "aria-errormessage": error ? errorId : undefined,
157
+ "aria-required": !disabled && !readOnly && !optional,
158
+ "aria-readonly": readOnly,
159
+ "aria-orientation": stacking === "column" ? "vertical" : "horizontal"
88
160
  }, /*#__PURE__*/_react["default"].createElement(ValueInput, {
89
161
  name: name,
90
- value: value !== null && value !== void 0 ? value : innerValue,
91
- readOnly: true,
92
- "aria-hidden": "true"
93
- }), options.map(function (option, index) {
162
+ disabled: disabled,
163
+ value: (_ref2 = value !== null && value !== void 0 ? value : innerValue) !== null && _ref2 !== void 0 ? _ref2 : "",
164
+ readOnly: true
165
+ }), innerOptions.map(function (option, index) {
94
166
  return /*#__PURE__*/_react["default"].createElement(_Radio["default"], {
95
- option: option,
96
- currentValue: value !== null && value !== void 0 ? value : innerValue,
97
- onChange: handleOnChange,
98
- disabledRadioGroup: disabled,
167
+ key: "radio-".concat(index),
168
+ label: option.label,
169
+ checked: (value !== null && value !== void 0 ? value : innerValue) === option.value,
170
+ onClick: function onClick() {
171
+ handleOnChange(option.value);
172
+ setCurrentFocusIndex(index);
173
+ },
99
174
  error: error,
100
- first: !value && !innerValue && index === 0
175
+ disabled: option.disabled || disabled,
176
+ focused: currentFocusIndex === index,
177
+ readOnly: readOnly,
178
+ tabIndex: tabIndex
101
179
  });
102
- }), optional && /*#__PURE__*/_react["default"].createElement(_Radio["default"], {
103
- option: {
104
- label: optionalItemLabel,
105
- value: "",
106
- disabled: disabled
107
- },
108
- currentValue: value !== null && value !== void 0 ? value : innerValue,
109
- onChange: handleOnChange,
110
- disabledRadioGroup: disabled,
111
- error: error
112
- })), !disabled && typeof error === "string" && /*#__PURE__*/_react["default"].createElement(Error, null, error)));
180
+ })), !disabled && typeof error === "string" && /*#__PURE__*/_react["default"].createElement(Error, {
181
+ id: errorId,
182
+ role: "alert",
183
+ "aria-live": error ? "assertive" : "off"
184
+ }, error)));
113
185
  });
114
-
115
- var RadioGroupContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n box-sizing: border-box;\n"])));
116
-
186
+ var RadioGroupContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: inline-flex;\n flex-direction: column;\n"])));
117
187
  var Label = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: ", ";\n ", "\n"])), function (props) {
118
188
  return props.disabled ? props.theme.disabledLabelFontColor : props.theme.labelFontColor;
119
189
  }, function (props) {
@@ -127,14 +197,12 @@ var Label = _styledComponents["default"].span(_templateObject2 || (_templateObje
127
197
  }, function (props) {
128
198
  return props.theme.labelLineHeight;
129
199
  }, function (props) {
130
- return !props.helperText && "margin-bottom: 0.25rem;";
200
+ return !props.helperText && "margin-bottom: ".concat(props.theme.groupLabelMargin);
131
201
  });
132
-
133
202
  var OptionalLabel = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n font-weight: ", ";\n"])), function (props) {
134
203
  return props.theme.optionalLabelFontWeight;
135
204
  });
136
-
137
- var HelperText = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: ", ";\n margin-bottom: 0.5rem;\n"])), function (props) {
205
+ var HelperText = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: ", ";\n margin-bottom: ", ";\n"])), function (props) {
138
206
  return props.disabled ? props.theme.disabledHelperTextFontColor : props.theme.helperTextFontColor;
139
207
  }, function (props) {
140
208
  return props.theme.fontFamily;
@@ -146,21 +214,20 @@ var HelperText = _styledComponents["default"].span(_templateObject4 || (_templat
146
214
  return props.theme.helperTextFontWeight;
147
215
  }, function (props) {
148
216
  return props.theme.helperTextLineHeight;
217
+ }, function (props) {
218
+ return props.theme.groupLabelMargin;
149
219
  });
150
-
151
- var RadioGroup = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-wrap: wrap;\n flex-direction: ", ";\n\n div + div {\n ", ";\n }\n"])), function (props) {
220
+ var RadioGroup = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-wrap: wrap;\n flex-direction: ", ";\n row-gap: ", ";\n column-gap: ", ";\n"])), function (props) {
152
221
  return props.stacking;
153
222
  }, function (props) {
154
- return props.stacking === "column" ? "margin-top: 0.25rem;" : "margin-left: 2rem;";
223
+ return props.theme.groupVerticalGutter;
224
+ }, function (props) {
225
+ return props.theme.groupHorizontalGutter;
155
226
  });
156
-
157
227
  var ValueInput = _styledComponents["default"].input(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n display: none;\n"])));
158
-
159
228
  var Error = _styledComponents["default"].span(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n min-height: 1.5em;\n color: ", ";\n font-family: ", ";\n font-size: 0.75rem;\n font-weight: 400;\n line-height: 1.5em;\n margin-top: 0.5rem;\n"])), function (props) {
160
229
  return props.theme.errorMessageColor;
161
230
  }, function (props) {
162
231
  return props.theme.fontFamily;
163
232
  });
164
-
165
- var _default = DxcRadioGroup;
166
- exports["default"] = _default;
233
+ var _default = exports["default"] = DxcRadioGroup;
@@ -1,56 +1,214 @@
1
+ import React from "react";
1
2
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
2
3
  import Title from "../../.storybook/components/Title";
3
4
  import DxcRadioGroup from "./RadioGroup";
5
+ import { HalstackProvider } from "../HalstackContext";
4
6
 
5
7
  export default {
6
8
  title: "Radio Group",
7
9
  component: DxcRadioGroup,
8
10
  };
9
11
 
12
+ const single_option = [{ label: "Option A", value: "A" }];
13
+
10
14
  const options = [
11
15
  { label: "Option 1", value: "1" },
12
16
  { label: "Option 2", value: "2" },
13
17
  { label: "Option 3", value: "3" },
18
+ { label: "Option 4", value: "4" },
14
19
  ];
15
20
 
16
- const single_disabled_options = [
17
- { label: "Option 1", value: "1" },
18
- { label: "Option 2", value: "2", disabled: true },
19
- { label: "Option 3", value: "3" },
20
- ];
21
+ const single_disabled_options = [{ label: "Option A", value: "A", disabled: true }];
22
+
23
+ const opinionatedTheme = {
24
+ radioGroup: {
25
+ baseColor: "#0086e6",
26
+ fontColor: "#000000",
27
+ },
28
+ };
21
29
 
22
30
  export const Chromatic = () => (
23
31
  <>
32
+ <Title title="Radio input states" theme="light" level={2} />
24
33
  <ExampleContainer>
25
- <Title title="Default (column)" theme="light" level={4} />
26
- <DxcRadioGroup label="Example" helperText="Helper text" options={options} />
34
+ <Title title="Enabled" theme="light" level={4} />
35
+ <DxcRadioGroup label="Label" helperText="Helper text" defaultValue="A" options={single_option} />
27
36
  </ExampleContainer>
28
- <ExampleContainer>
29
- <Title title="Row" theme="light" level={4} />
30
- <DxcRadioGroup label="Example" helperText="Helper text" options={options} stacking="row" />
37
+ <ExampleContainer pseudoState="pseudo-hover">
38
+ <Title title="Hovered" theme="light" level={4} />
39
+ <DxcRadioGroup label="Label" helperText="Helper text" defaultValue="A" options={single_option} />
40
+ </ExampleContainer>
41
+ <ExampleContainer pseudoState="pseudo-active">
42
+ <Title title="Active" theme="light" level={4} />
43
+ <DxcRadioGroup label="Label" helperText="Helper text" defaultValue="A" options={single_option} />
44
+ </ExampleContainer>
45
+ <ExampleContainer pseudoState="pseudo-focus">
46
+ <Title title="Focused" theme="light" level={4} />
47
+ <DxcRadioGroup label="Label" helperText="Helper text" defaultValue="A" options={single_option} />
31
48
  </ExampleContainer>
32
49
  <ExampleContainer>
33
50
  <Title title="Disabled" theme="light" level={4} />
34
- <DxcRadioGroup label="Disabled" error="Error message" helperText="Helper text" options={options} disabled optional defaultValue="2" />
51
+ <DxcRadioGroup label="Label" helperText="Helper text" options={single_disabled_options} defaultValue="A" />
35
52
  </ExampleContainer>
53
+ <Title title="Readonly radio input sub-states" theme="light" level={3} />
36
54
  <ExampleContainer>
37
- <Title title="Single disabled" theme="light" level={4} />
38
- <DxcRadioGroup label="Disabled" helperText="Helper text" options={single_disabled_options} optional defaultValue="3" />
55
+ <Title title="Enabled" theme="light" level={4} />
56
+ <DxcRadioGroup label="Label" helperText="Helper text" options={single_option} defaultValue="A" readOnly />
57
+ </ExampleContainer>
58
+ <ExampleContainer pseudoState="pseudo-hover">
59
+ <Title title="Hovered" theme="light" level={4} />
60
+ <DxcRadioGroup label="Label" helperText="Helper text" options={single_option} defaultValue="A" readOnly />
61
+ </ExampleContainer>
62
+ <ExampleContainer pseudoState="pseudo-active">
63
+ <Title title="Active" theme="light" level={4} />
64
+ <DxcRadioGroup label="Label" helperText="Helper text" options={single_option} defaultValue="A" readOnly />
39
65
  </ExampleContainer>
66
+ <Title title="Error radio input sub-states" theme="light" level={3} />
40
67
  <ExampleContainer>
41
- <Title title="Optional" theme="light" level={4} />
68
+ <Title title="Enabled" theme="light" level={4} />
42
69
  <DxcRadioGroup
43
- label="Example"
44
- optionalOptionLabel="No selection"
45
- optional
70
+ label="Label"
46
71
  helperText="Helper text"
47
- options={options}
48
- stacking="row"
72
+ options={single_option}
73
+ defaultValue="A"
74
+ error="Error message"
49
75
  />
50
76
  </ExampleContainer>
77
+ <ExampleContainer pseudoState="pseudo-hover">
78
+ <Title title="Hovered" theme="light" level={4} />
79
+ <DxcRadioGroup
80
+ label="Label"
81
+ helperText="Helper text"
82
+ options={single_option}
83
+ defaultValue="A"
84
+ readOnly
85
+ error="Error message"
86
+ />
87
+ </ExampleContainer>
88
+ <ExampleContainer pseudoState="pseudo-active">
89
+ <Title title="Active" theme="light" level={4} />
90
+ <DxcRadioGroup
91
+ label="Label"
92
+ helperText="Helper text"
93
+ options={single_option}
94
+ defaultValue="A"
95
+ readOnly
96
+ error="Error message"
97
+ />
98
+ </ExampleContainer>
99
+ <Title title="Variants" theme="light" level={2} />
100
+ <ExampleContainer>
101
+ <Title title="Column" theme="light" level={4} />
102
+ <DxcRadioGroup label="Label" helperText="Helper text" options={options} />
103
+ </ExampleContainer>
104
+ <ExampleContainer>
105
+ <Title title="Row" theme="light" level={4} />
106
+ <DxcRadioGroup label="Label" helperText="Helper text" options={options} stacking="row" />
107
+ </ExampleContainer>
108
+ <ExampleContainer>
109
+ <Title title="Optional" theme="light" level={4} />
110
+ <DxcRadioGroup label="Label" optional helperText="Helper text" options={options} stacking="row" />
111
+ </ExampleContainer>
112
+ <ExampleContainer>
113
+ <Title title="Disabled" theme="light" level={4} />
114
+ <DxcRadioGroup label="Label" helperText="Helper text" options={options} disabled />
115
+ </ExampleContainer>
116
+ <ExampleContainer>
117
+ <Title title="Readonly" theme="light" level={4} />
118
+ <DxcRadioGroup label="Label" readOnly helperText="Helper text" options={options} />
119
+ </ExampleContainer>
120
+ <ExampleContainer>
121
+ <Title title="Error space reserved" theme="light" level={4} />
122
+ <DxcRadioGroup label="Label" error="" helperText="Helper text" options={options} />
123
+ </ExampleContainer>
51
124
  <ExampleContainer>
52
125
  <Title title="Error" theme="light" level={4} />
53
- <DxcRadioGroup label="Example" error="Error message" helperText="Helper text" options={options} defaultValue="2" />
126
+ <DxcRadioGroup label="Label" error="Error message" helperText="Helper text" options={options} />
127
+ </ExampleContainer>
128
+ <Title title="Opinionated theme" theme="light" level={2} />
129
+ <ExampleContainer>
130
+ <Title title="Enabled" theme="light" level={4} />
131
+ <HalstackProvider theme={opinionatedTheme}>
132
+ <DxcRadioGroup label="Label" helperText="Helper text" defaultValue="A" options={single_option} />
133
+ </HalstackProvider>
134
+ </ExampleContainer>
135
+ <ExampleContainer pseudoState="pseudo-hover">
136
+ <Title title="Hovered" theme="light" level={4} />
137
+ <HalstackProvider theme={opinionatedTheme}>
138
+ <DxcRadioGroup label="Label" helperText="Helper text" defaultValue="A" options={single_option} />
139
+ </HalstackProvider>
140
+ </ExampleContainer>
141
+ <ExampleContainer pseudoState="pseudo-active">
142
+ <Title title="Active" theme="light" level={4} />
143
+ <HalstackProvider theme={opinionatedTheme}>
144
+ <DxcRadioGroup label="Label" helperText="Helper text" defaultValue="A" options={single_option} />
145
+ </HalstackProvider>
146
+ </ExampleContainer>
147
+ <ExampleContainer pseudoState="pseudo-focus">
148
+ <Title title="Focused" theme="light" level={4} />
149
+ <HalstackProvider theme={opinionatedTheme}>
150
+ <DxcRadioGroup label="Label" helperText="Helper text" defaultValue="A" options={single_option} />
151
+ </HalstackProvider>
152
+ </ExampleContainer>
153
+ <ExampleContainer>
154
+ <Title title="Disabled" theme="light" level={4} />
155
+ <HalstackProvider theme={opinionatedTheme}>
156
+ <DxcRadioGroup label="Label" helperText="Helper text" options={single_disabled_options} defaultValue="A" />
157
+ </HalstackProvider>
158
+ </ExampleContainer>
159
+ <ExampleContainer>
160
+ <Title title="Readonly enabled" theme="light" level={4} />
161
+ <HalstackProvider theme={opinionatedTheme}>
162
+ <DxcRadioGroup label="Label" options={single_option} defaultValue="A" readOnly />
163
+ </HalstackProvider>
164
+ </ExampleContainer>
165
+ <ExampleContainer pseudoState="pseudo-hover">
166
+ <Title title="Readonly hovered" theme="light" level={4} />
167
+ <HalstackProvider theme={opinionatedTheme}>
168
+ <DxcRadioGroup label="Label" options={single_option} defaultValue="A" readOnly />
169
+ </HalstackProvider>
170
+ </ExampleContainer>
171
+ <ExampleContainer pseudoState="pseudo-active">
172
+ <Title title="Readonly active" theme="light" level={4} />
173
+ <HalstackProvider theme={opinionatedTheme}>
174
+ <DxcRadioGroup label="Label" options={single_option} defaultValue="A" readOnly />
175
+ </HalstackProvider>
176
+ </ExampleContainer>
177
+ <ExampleContainer pseudoState="pseudo-focus">
178
+ <Title title="Readonly focused" theme="light" level={4} />
179
+ <HalstackProvider theme={opinionatedTheme}>
180
+ <DxcRadioGroup label="Label" options={single_option} defaultValue="A" readOnly />
181
+ </HalstackProvider>
182
+ </ExampleContainer>
183
+ <ExampleContainer>
184
+ <Title title="Enabled" theme="light" level={4} />
185
+ <HalstackProvider theme={opinionatedTheme}>
186
+ <DxcRadioGroup label="Label" options={single_option} defaultValue="A" error="Error message" />
187
+ </HalstackProvider>
188
+ </ExampleContainer>
189
+ <ExampleContainer pseudoState="pseudo-hover">
190
+ <Title title="Hovered" theme="light" level={4} />
191
+ <HalstackProvider theme={opinionatedTheme}>
192
+ <DxcRadioGroup label="Label" options={single_option} defaultValue="A" error="Error message" />
193
+ </HalstackProvider>
194
+ </ExampleContainer>
195
+ <ExampleContainer pseudoState="pseudo-active">
196
+ <Title title="Active" theme="light" level={4} />
197
+ <HalstackProvider theme={opinionatedTheme}>
198
+ <DxcRadioGroup label="Label" options={single_option} defaultValue="A" error="Error message" />
199
+ </HalstackProvider>
200
+ </ExampleContainer>
201
+ <ExampleContainer pseudoState="pseudo-focus">
202
+ <Title title="Focused" theme="light" level={4} />
203
+ <HalstackProvider theme={opinionatedTheme}>
204
+ <DxcRadioGroup label="Label" options={single_option} defaultValue="A" error="Error message" />
205
+ </HalstackProvider>
206
+ </ExampleContainer>
207
+ <ExampleContainer>
208
+ <Title title="Disabled" theme="light" level={4} />
209
+ <HalstackProvider theme={opinionatedTheme}>
210
+ <DxcRadioGroup label="Label" helperText="Helper text" options={options} disabled defaultValue="A" />
211
+ </HalstackProvider>
54
212
  </ExampleContainer>
55
213
  </>
56
214
  );
@@ -0,0 +1 @@
1
+ export {};