@dxc-technology/halstack-react 0.0.0-b461ccd → 0.0.0-b4aec06

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 (570) hide show
  1. package/BackgroundColorContext.d.ts +1 -0
  2. package/BackgroundColorContext.js +30 -0
  3. package/HalstackContext.d.ts +1249 -0
  4. package/HalstackContext.js +310 -0
  5. package/README.md +28 -47
  6. package/accordion/Accordion.d.ts +4 -0
  7. package/accordion/Accordion.js +169 -0
  8. package/accordion/Accordion.stories.tsx +252 -0
  9. package/accordion/Accordion.test.js +56 -0
  10. package/accordion/types.d.ts +57 -0
  11. package/accordion/types.js +5 -0
  12. package/accordion-group/AccordionGroup.d.ts +7 -0
  13. package/accordion-group/AccordionGroup.js +101 -0
  14. package/accordion-group/AccordionGroup.stories.tsx +252 -0
  15. package/accordion-group/AccordionGroup.test.js +98 -0
  16. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  17. package/accordion-group/AccordionGroupAccordion.js +31 -0
  18. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  19. package/accordion-group/AccordionGroupContext.js +8 -0
  20. package/accordion-group/types.d.ts +67 -0
  21. package/accordion-group/types.js +5 -0
  22. package/action-icon/ActionIcon.d.ts +4 -0
  23. package/action-icon/ActionIcon.js +48 -0
  24. package/action-icon/ActionIcon.stories.tsx +41 -0
  25. package/action-icon/ActionIcon.test.js +64 -0
  26. package/action-icon/types.d.ts +26 -0
  27. package/action-icon/types.js +5 -0
  28. package/alert/Alert.d.ts +4 -0
  29. package/alert/Alert.js +200 -0
  30. package/alert/Alert.stories.tsx +198 -0
  31. package/alert/Alert.test.js +75 -0
  32. package/alert/types.d.ts +49 -0
  33. package/alert/types.js +5 -0
  34. package/badge/Badge.d.ts +4 -0
  35. package/badge/Badge.js +159 -0
  36. package/badge/Badge.stories.tsx +210 -0
  37. package/badge/Badge.test.js +30 -0
  38. package/badge/types.d.ts +54 -0
  39. package/badge/types.js +5 -0
  40. package/bleed/Bleed.d.ts +3 -0
  41. package/bleed/Bleed.js +43 -0
  42. package/bleed/Bleed.stories.tsx +342 -0
  43. package/bleed/types.d.ts +37 -0
  44. package/bleed/types.js +5 -0
  45. package/box/Box.d.ts +4 -0
  46. package/box/Box.js +75 -0
  47. package/box/Box.stories.tsx +119 -0
  48. package/box/Box.test.js +13 -0
  49. package/box/types.d.ts +32 -0
  50. package/box/types.js +5 -0
  51. package/bulleted-list/BulletedList.d.ts +7 -0
  52. package/bulleted-list/BulletedList.js +89 -0
  53. package/bulleted-list/BulletedList.stories.tsx +115 -0
  54. package/bulleted-list/types.d.ts +38 -0
  55. package/bulleted-list/types.js +5 -0
  56. package/button/Button.d.ts +4 -0
  57. package/button/Button.js +121 -0
  58. package/button/Button.stories.tsx +326 -0
  59. package/button/Button.test.js +38 -0
  60. package/button/types.d.ts +57 -0
  61. package/button/types.js +5 -0
  62. package/card/Card.d.ts +4 -0
  63. package/card/Card.js +120 -0
  64. package/card/Card.stories.tsx +171 -0
  65. package/card/Card.test.js +39 -0
  66. package/card/types.d.ts +62 -0
  67. package/card/types.js +5 -0
  68. package/checkbox/Checkbox.d.ts +4 -0
  69. package/checkbox/Checkbox.js +215 -0
  70. package/checkbox/Checkbox.stories.tsx +222 -0
  71. package/checkbox/Checkbox.test.js +199 -0
  72. package/checkbox/types.d.ts +72 -0
  73. package/checkbox/types.js +5 -0
  74. package/chip/Chip.d.ts +4 -0
  75. package/chip/Chip.js +121 -0
  76. package/chip/Chip.stories.tsx +214 -0
  77. package/chip/Chip.test.js +41 -0
  78. package/chip/types.d.ts +45 -0
  79. package/chip/types.js +5 -0
  80. package/common/coreTokens.d.ts +237 -0
  81. package/common/coreTokens.js +184 -0
  82. package/common/utils.d.ts +1 -0
  83. package/{dist/common → common}/utils.js +6 -12
  84. package/common/variables.d.ts +1395 -0
  85. package/common/variables.js +1267 -0
  86. package/container/Container.d.ts +4 -0
  87. package/container/Container.js +194 -0
  88. package/container/Container.stories.tsx +214 -0
  89. package/container/types.d.ts +74 -0
  90. package/container/types.js +5 -0
  91. package/contextual-menu/ContextualMenu.d.ts +7 -0
  92. package/contextual-menu/ContextualMenu.js +71 -0
  93. package/contextual-menu/ContextualMenu.stories.tsx +182 -0
  94. package/contextual-menu/ContextualMenu.test.js +71 -0
  95. package/contextual-menu/MenuItemAction.d.ts +4 -0
  96. package/contextual-menu/MenuItemAction.js +46 -0
  97. package/contextual-menu/types.d.ts +22 -0
  98. package/contextual-menu/types.js +5 -0
  99. package/date-input/Calendar.d.ts +4 -0
  100. package/date-input/Calendar.js +214 -0
  101. package/date-input/DateInput.d.ts +4 -0
  102. package/date-input/DateInput.js +223 -0
  103. package/date-input/DateInput.stories.tsx +285 -0
  104. package/date-input/DateInput.test.js +808 -0
  105. package/date-input/DatePicker.d.ts +4 -0
  106. package/date-input/DatePicker.js +115 -0
  107. package/date-input/Icons.d.ts +6 -0
  108. package/date-input/Icons.js +58 -0
  109. package/date-input/YearPicker.d.ts +4 -0
  110. package/date-input/YearPicker.js +100 -0
  111. package/date-input/types.d.ts +164 -0
  112. package/date-input/types.js +5 -0
  113. package/dialog/Dialog.d.ts +4 -0
  114. package/dialog/Dialog.js +104 -0
  115. package/dialog/Dialog.stories.tsx +365 -0
  116. package/dialog/Dialog.test.js +307 -0
  117. package/dialog/types.d.ts +36 -0
  118. package/dialog/types.js +5 -0
  119. package/divider/Divider.d.ts +4 -0
  120. package/divider/Divider.js +36 -0
  121. package/divider/Divider.stories.tsx +223 -0
  122. package/divider/Divider.test.js +38 -0
  123. package/divider/types.d.ts +21 -0
  124. package/divider/types.js +5 -0
  125. package/dropdown/Dropdown.d.ts +4 -0
  126. package/dropdown/Dropdown.js +319 -0
  127. package/dropdown/Dropdown.stories.tsx +427 -0
  128. package/dropdown/Dropdown.test.js +599 -0
  129. package/dropdown/DropdownMenu.d.ts +4 -0
  130. package/dropdown/DropdownMenu.js +63 -0
  131. package/dropdown/DropdownMenuItem.d.ts +4 -0
  132. package/dropdown/DropdownMenuItem.js +70 -0
  133. package/dropdown/types.d.ts +96 -0
  134. package/dropdown/types.js +5 -0
  135. package/file-input/FileInput.d.ts +4 -0
  136. package/file-input/FileInput.js +479 -0
  137. package/file-input/FileInput.stories.tsx +618 -0
  138. package/file-input/FileInput.test.js +459 -0
  139. package/file-input/FileItem.d.ts +4 -0
  140. package/file-input/FileItem.js +135 -0
  141. package/file-input/types.d.ts +129 -0
  142. package/file-input/types.js +5 -0
  143. package/flex/Flex.d.ts +4 -0
  144. package/flex/Flex.js +57 -0
  145. package/flex/Flex.stories.tsx +112 -0
  146. package/flex/types.d.ts +97 -0
  147. package/flex/types.js +5 -0
  148. package/footer/Footer.d.ts +4 -0
  149. package/footer/Footer.js +138 -0
  150. package/footer/Footer.stories.tsx +171 -0
  151. package/footer/Footer.test.js +85 -0
  152. package/footer/Icons.d.ts +3 -0
  153. package/footer/Icons.js +136 -0
  154. package/footer/types.d.ts +64 -0
  155. package/footer/types.js +5 -0
  156. package/grid/Grid.d.ts +7 -0
  157. package/grid/Grid.js +76 -0
  158. package/grid/Grid.stories.tsx +219 -0
  159. package/grid/types.d.ts +115 -0
  160. package/grid/types.js +5 -0
  161. package/header/Header.d.ts +8 -0
  162. package/header/Header.js +220 -0
  163. package/header/Header.stories.tsx +251 -0
  164. package/header/Header.test.js +66 -0
  165. package/header/Icons.d.ts +2 -0
  166. package/header/Icons.js +29 -0
  167. package/header/types.d.ts +33 -0
  168. package/header/types.js +5 -0
  169. package/heading/Heading.d.ts +4 -0
  170. package/{dist/heading → heading}/Heading.js +34 -115
  171. package/heading/Heading.stories.tsx +54 -0
  172. package/heading/Heading.test.js +169 -0
  173. package/heading/types.d.ts +33 -0
  174. package/heading/types.js +5 -0
  175. package/icon/Icon.d.ts +4 -0
  176. package/icon/Icon.js +33 -0
  177. package/icon/Icon.stories.tsx +28 -0
  178. package/icon/types.d.ts +4 -0
  179. package/icon/types.js +5 -0
  180. package/image/Image.d.ts +4 -0
  181. package/image/Image.js +70 -0
  182. package/image/Image.stories.tsx +129 -0
  183. package/image/types.d.ts +72 -0
  184. package/image/types.js +5 -0
  185. package/inset/Inset.d.ts +3 -0
  186. package/inset/Inset.js +43 -0
  187. package/inset/Inset.stories.tsx +230 -0
  188. package/inset/types.d.ts +37 -0
  189. package/inset/types.js +5 -0
  190. package/layout/ApplicationLayout.d.ts +20 -0
  191. package/layout/ApplicationLayout.js +134 -0
  192. package/layout/ApplicationLayout.stories.tsx +162 -0
  193. package/layout/Icons.d.ts +8 -0
  194. package/layout/Icons.js +58 -0
  195. package/layout/types.d.ts +41 -0
  196. package/layout/types.js +5 -0
  197. package/link/Link.d.ts +4 -0
  198. package/link/Link.js +115 -0
  199. package/link/Link.stories.tsx +253 -0
  200. package/link/Link.test.js +63 -0
  201. package/link/types.d.ts +54 -0
  202. package/link/types.js +5 -0
  203. package/main.d.ts +49 -0
  204. package/{dist/main.js → main.js} +147 -141
  205. package/nav-tabs/NavTabs.d.ts +7 -0
  206. package/nav-tabs/NavTabs.js +93 -0
  207. package/nav-tabs/NavTabs.stories.tsx +276 -0
  208. package/nav-tabs/NavTabs.test.js +76 -0
  209. package/nav-tabs/NavTabsContext.d.ts +3 -0
  210. package/nav-tabs/NavTabsContext.js +8 -0
  211. package/nav-tabs/Tab.d.ts +4 -0
  212. package/nav-tabs/Tab.js +118 -0
  213. package/nav-tabs/types.d.ts +52 -0
  214. package/nav-tabs/types.js +5 -0
  215. package/number-input/NumberInput.d.ts +4 -0
  216. package/number-input/NumberInput.js +86 -0
  217. package/number-input/NumberInput.stories.tsx +131 -0
  218. package/number-input/NumberInput.test.js +989 -0
  219. package/number-input/NumberInputContext.d.ts +3 -0
  220. package/number-input/NumberInputContext.js +8 -0
  221. package/number-input/types.d.ts +136 -0
  222. package/number-input/types.js +5 -0
  223. package/package.json +58 -49
  224. package/paginator/Icons.d.ts +5 -0
  225. package/paginator/Icons.js +40 -0
  226. package/paginator/Paginator.d.ts +4 -0
  227. package/paginator/Paginator.js +135 -0
  228. package/paginator/Paginator.stories.tsx +87 -0
  229. package/paginator/Paginator.test.js +335 -0
  230. package/paginator/types.d.ts +38 -0
  231. package/paginator/types.js +5 -0
  232. package/paragraph/Paragraph.d.ts +5 -0
  233. package/paragraph/Paragraph.js +22 -0
  234. package/paragraph/Paragraph.stories.tsx +27 -0
  235. package/password-input/Icons.d.ts +6 -0
  236. package/password-input/Icons.js +35 -0
  237. package/password-input/PasswordInput.d.ts +4 -0
  238. package/password-input/PasswordInput.js +97 -0
  239. package/password-input/PasswordInput.stories.tsx +99 -0
  240. package/password-input/PasswordInput.test.js +198 -0
  241. package/password-input/types.d.ts +111 -0
  242. package/password-input/types.js +5 -0
  243. package/progress-bar/ProgressBar.d.ts +4 -0
  244. package/progress-bar/ProgressBar.js +144 -0
  245. package/progress-bar/ProgressBar.stories.tsx +93 -0
  246. package/progress-bar/ProgressBar.test.js +93 -0
  247. package/progress-bar/types.d.ts +37 -0
  248. package/progress-bar/types.js +5 -0
  249. package/quick-nav/QuickNav.d.ts +4 -0
  250. package/quick-nav/QuickNav.js +94 -0
  251. package/quick-nav/QuickNav.stories.tsx +356 -0
  252. package/quick-nav/types.d.ts +21 -0
  253. package/quick-nav/types.js +5 -0
  254. package/radio-group/Radio.d.ts +4 -0
  255. package/radio-group/Radio.js +124 -0
  256. package/radio-group/RadioGroup.d.ts +4 -0
  257. package/radio-group/RadioGroup.js +235 -0
  258. package/radio-group/RadioGroup.stories.tsx +214 -0
  259. package/radio-group/RadioGroup.test.js +756 -0
  260. package/radio-group/types.d.ts +114 -0
  261. package/radio-group/types.js +5 -0
  262. package/resultset-table/Icons.d.ts +7 -0
  263. package/resultset-table/Icons.js +47 -0
  264. package/resultset-table/ResultsetTable.d.ts +7 -0
  265. package/resultset-table/ResultsetTable.js +170 -0
  266. package/resultset-table/ResultsetTable.stories.tsx +401 -0
  267. package/resultset-table/ResultsetTable.test.js +381 -0
  268. package/resultset-table/types.d.ts +100 -0
  269. package/resultset-table/types.js +5 -0
  270. package/select/Icons.d.ts +10 -0
  271. package/select/Icons.js +89 -0
  272. package/select/Listbox.d.ts +4 -0
  273. package/select/Listbox.js +143 -0
  274. package/select/Option.d.ts +4 -0
  275. package/select/Option.js +87 -0
  276. package/select/Select.d.ts +4 -0
  277. package/select/Select.js +590 -0
  278. package/select/Select.stories.tsx +971 -0
  279. package/select/Select.test.js +2370 -0
  280. package/select/types.d.ts +209 -0
  281. package/select/types.js +5 -0
  282. package/sidenav/Icons.d.ts +7 -0
  283. package/sidenav/Icons.js +47 -0
  284. package/sidenav/Sidenav.d.ts +10 -0
  285. package/sidenav/Sidenav.js +197 -0
  286. package/sidenav/Sidenav.stories.tsx +282 -0
  287. package/sidenav/Sidenav.test.js +37 -0
  288. package/sidenav/SidenavContext.d.ts +5 -0
  289. package/sidenav/SidenavContext.js +13 -0
  290. package/sidenav/types.d.ts +76 -0
  291. package/sidenav/types.js +5 -0
  292. package/slider/Slider.d.ts +4 -0
  293. package/slider/Slider.js +285 -0
  294. package/slider/Slider.test.js +254 -0
  295. package/slider/types.d.ts +86 -0
  296. package/slider/types.js +5 -0
  297. package/spinner/Spinner.d.ts +4 -0
  298. package/spinner/Spinner.js +206 -0
  299. package/spinner/Spinner.stories.tsx +129 -0
  300. package/spinner/Spinner.test.js +55 -0
  301. package/spinner/types.d.ts +32 -0
  302. package/spinner/types.js +5 -0
  303. package/status-light/StatusLight.d.ts +4 -0
  304. package/status-light/StatusLight.js +51 -0
  305. package/status-light/StatusLight.stories.tsx +74 -0
  306. package/status-light/StatusLight.test.js +25 -0
  307. package/status-light/types.d.ts +17 -0
  308. package/status-light/types.js +5 -0
  309. package/switch/Switch.d.ts +4 -0
  310. package/switch/Switch.js +214 -0
  311. package/switch/Switch.stories.tsx +137 -0
  312. package/switch/Switch.test.js +180 -0
  313. package/switch/types.d.ts +66 -0
  314. package/switch/types.js +5 -0
  315. package/table/DropdownTheme.js +62 -0
  316. package/table/Table.d.ts +8 -0
  317. package/table/Table.js +161 -0
  318. package/table/Table.stories.tsx +651 -0
  319. package/table/Table.test.js +113 -0
  320. package/table/types.d.ts +49 -0
  321. package/table/types.js +5 -0
  322. package/tabs/Tab.d.ts +4 -0
  323. package/tabs/Tab.js +116 -0
  324. package/tabs/Tabs.d.ts +4 -0
  325. package/tabs/Tabs.js +384 -0
  326. package/tabs/Tabs.stories.tsx +226 -0
  327. package/tabs/Tabs.test.js +294 -0
  328. package/tabs/types.d.ts +92 -0
  329. package/tabs/types.js +5 -0
  330. package/tag/Tag.d.ts +4 -0
  331. package/tag/Tag.js +151 -0
  332. package/tag/Tag.stories.tsx +155 -0
  333. package/tag/Tag.test.js +49 -0
  334. package/tag/types.d.ts +69 -0
  335. package/tag/types.js +5 -0
  336. package/text-input/Suggestion.d.ts +4 -0
  337. package/text-input/Suggestion.js +67 -0
  338. package/text-input/Suggestions.d.ts +4 -0
  339. package/text-input/Suggestions.js +86 -0
  340. package/text-input/TextInput.d.ts +4 -0
  341. package/text-input/TextInput.js +567 -0
  342. package/text-input/TextInput.stories.tsx +465 -0
  343. package/text-input/TextInput.test.js +1756 -0
  344. package/text-input/types.d.ts +205 -0
  345. package/text-input/types.js +5 -0
  346. package/textarea/Textarea.d.ts +4 -0
  347. package/textarea/Textarea.js +234 -0
  348. package/textarea/Textarea.stories.tsx +174 -0
  349. package/textarea/Textarea.test.js +406 -0
  350. package/textarea/types.d.ts +141 -0
  351. package/textarea/types.js +5 -0
  352. package/toggle-group/ToggleGroup.d.ts +4 -0
  353. package/toggle-group/ToggleGroup.js +201 -0
  354. package/toggle-group/ToggleGroup.stories.tsx +218 -0
  355. package/toggle-group/ToggleGroup.test.js +137 -0
  356. package/toggle-group/types.d.ts +114 -0
  357. package/toggle-group/types.js +5 -0
  358. package/typography/Typography.d.ts +4 -0
  359. package/typography/Typography.js +23 -0
  360. package/typography/Typography.stories.tsx +198 -0
  361. package/typography/types.d.ts +18 -0
  362. package/typography/types.js +5 -0
  363. package/useTheme.d.ts +1148 -0
  364. package/{dist/useTheme.js → useTheme.js} +4 -11
  365. package/useTranslatedLabels.d.ts +85 -0
  366. package/useTranslatedLabels.js +14 -0
  367. package/utils/BaseTypography.d.ts +21 -0
  368. package/utils/BaseTypography.js +94 -0
  369. package/utils/FocusLock.d.ts +13 -0
  370. package/utils/FocusLock.js +124 -0
  371. package/wizard/Wizard.d.ts +4 -0
  372. package/wizard/Wizard.js +250 -0
  373. package/wizard/Wizard.stories.tsx +253 -0
  374. package/wizard/Wizard.test.js +114 -0
  375. package/wizard/types.d.ts +64 -0
  376. package/wizard/types.js +5 -0
  377. package/babel.config.js +0 -8
  378. package/dist/BackgroundColorContext.js +0 -46
  379. package/dist/ThemeContext.js +0 -216
  380. package/dist/accordion/Accordion.js +0 -348
  381. package/dist/accordion/Accordion.stories.js +0 -207
  382. package/dist/accordion/readme.md +0 -96
  383. package/dist/accordion-group/AccordionGroup.js +0 -188
  384. package/dist/accordion-group/AccordionGroup.stories.js +0 -207
  385. package/dist/accordion-group/readme.md +0 -70
  386. package/dist/alert/Alert.js +0 -392
  387. package/dist/alert/Alert.stories.js +0 -158
  388. package/dist/alert/close.svg +0 -4
  389. package/dist/alert/error.svg +0 -4
  390. package/dist/alert/info.svg +0 -4
  391. package/dist/alert/readme.md +0 -43
  392. package/dist/alert/success.svg +0 -4
  393. package/dist/alert/warning.svg +0 -4
  394. package/dist/badge/Badge.js +0 -63
  395. package/dist/box/Box.js +0 -156
  396. package/dist/button/Button.js +0 -232
  397. package/dist/button/Button.stories.js +0 -224
  398. package/dist/button/readme.md +0 -93
  399. package/dist/card/Card.js +0 -254
  400. package/dist/checkbox/Checkbox.js +0 -294
  401. package/dist/checkbox/Checkbox.stories.js +0 -144
  402. package/dist/checkbox/readme.md +0 -116
  403. package/dist/chip/Chip.js +0 -265
  404. package/dist/common/OpenSans.css +0 -81
  405. package/dist/common/RequiredComponent.js +0 -40
  406. package/dist/common/fonts/OpenSans-Bold.ttf +0 -0
  407. package/dist/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  408. package/dist/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  409. package/dist/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  410. package/dist/common/fonts/OpenSans-Italic.ttf +0 -0
  411. package/dist/common/fonts/OpenSans-Light.ttf +0 -0
  412. package/dist/common/fonts/OpenSans-LightItalic.ttf +0 -0
  413. package/dist/common/fonts/OpenSans-Regular.ttf +0 -0
  414. package/dist/common/fonts/OpenSans-SemiBold.ttf +0 -0
  415. package/dist/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  416. package/dist/common/variables.js +0 -1365
  417. package/dist/date/Date.js +0 -381
  418. package/dist/date/Date.stories.js +0 -205
  419. package/dist/date/readme.md +0 -73
  420. package/dist/dialog/Dialog.js +0 -240
  421. package/dist/dialog/Dialog.stories.js +0 -217
  422. package/dist/dialog/readme.md +0 -32
  423. package/dist/dropdown/Dropdown.js +0 -504
  424. package/dist/dropdown/Dropdown.stories.js +0 -249
  425. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  426. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  427. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  428. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  429. package/dist/dropdown/readme.md +0 -69
  430. package/dist/footer/Footer.js +0 -395
  431. package/dist/footer/Footer.stories.js +0 -94
  432. package/dist/footer/dxc_logo.svg +0 -15
  433. package/dist/footer/readme.md +0 -41
  434. package/dist/header/Header.js +0 -423
  435. package/dist/header/Header.stories.js +0 -176
  436. package/dist/header/close_icon.svg +0 -1
  437. package/dist/header/dxc_logo_black.svg +0 -8
  438. package/dist/header/hamb_menu_black.svg +0 -1
  439. package/dist/header/hamb_menu_white.svg +0 -1
  440. package/dist/header/readme.md +0 -33
  441. package/dist/input-text/InputText.js +0 -707
  442. package/dist/input-text/InputText.stories.js +0 -209
  443. package/dist/input-text/error.svg +0 -1
  444. package/dist/input-text/readme.md +0 -91
  445. package/dist/layout/ApplicationLayout.js +0 -331
  446. package/dist/layout/facebook.svg +0 -45
  447. package/dist/layout/linkedin.svg +0 -50
  448. package/dist/layout/twitter.svg +0 -53
  449. package/dist/link/Link.js +0 -241
  450. package/dist/link/readme.md +0 -51
  451. package/dist/new-date/NewDate.js +0 -399
  452. package/dist/new-input-text/NewInputText.js +0 -957
  453. package/dist/new-textarea/NewTextarea.js +0 -342
  454. package/dist/number/Number.js +0 -134
  455. package/dist/number/NumberContext.js +0 -16
  456. package/dist/paginator/Paginator.js +0 -289
  457. package/dist/paginator/images/next.svg +0 -3
  458. package/dist/paginator/images/nextPage.svg +0 -3
  459. package/dist/paginator/images/previous.svg +0 -3
  460. package/dist/paginator/images/previousPage.svg +0 -3
  461. package/dist/paginator/readme.md +0 -50
  462. package/dist/password/Password.js +0 -196
  463. package/dist/password/styles.css +0 -3
  464. package/dist/progress-bar/ProgressBar.js +0 -206
  465. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  466. package/dist/progress-bar/readme.md +0 -63
  467. package/dist/radio/Radio.js +0 -209
  468. package/dist/radio/Radio.stories.js +0 -166
  469. package/dist/radio/readme.md +0 -70
  470. package/dist/resultsetTable/ResultsetTable.js +0 -358
  471. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  472. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  473. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  474. package/dist/select/Select.js +0 -585
  475. package/dist/select/Select.stories.js +0 -235
  476. package/dist/select/readme.md +0 -72
  477. package/dist/sidenav/Sidenav.js +0 -177
  478. package/dist/slider/Slider.js +0 -315
  479. package/dist/slider/Slider.stories.js +0 -241
  480. package/dist/slider/readme.md +0 -64
  481. package/dist/spinner/Spinner.js +0 -218
  482. package/dist/spinner/Spinner.stories.js +0 -183
  483. package/dist/spinner/readme.md +0 -65
  484. package/dist/switch/Switch.js +0 -222
  485. package/dist/switch/Switch.stories.js +0 -134
  486. package/dist/switch/readme.md +0 -133
  487. package/dist/table/Table.js +0 -132
  488. package/dist/tabs/Tabs.js +0 -343
  489. package/dist/tabs/Tabs.stories.js +0 -130
  490. package/dist/tabs/readme.md +0 -78
  491. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  492. package/dist/tabs-for-sections/readme.md +0 -78
  493. package/dist/tag/Tag.js +0 -288
  494. package/dist/textarea/Textarea.js +0 -264
  495. package/dist/toggle/Toggle.js +0 -220
  496. package/dist/toggle/Toggle.stories.js +0 -297
  497. package/dist/toggle/readme.md +0 -80
  498. package/dist/toggle-group/ToggleGroup.js +0 -241
  499. package/dist/toggle-group/readme.md +0 -82
  500. package/dist/upload/Upload.js +0 -205
  501. package/dist/upload/Upload.stories.js +0 -72
  502. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -139
  503. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  504. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  505. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -329
  506. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  507. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  508. package/dist/upload/file-upload/FileToUpload.js +0 -184
  509. package/dist/upload/file-upload/audio-icon.svg +0 -4
  510. package/dist/upload/file-upload/close.svg +0 -4
  511. package/dist/upload/file-upload/file-icon.svg +0 -4
  512. package/dist/upload/file-upload/video-icon.svg +0 -4
  513. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  514. package/dist/upload/readme.md +0 -37
  515. package/dist/upload/transaction/Transaction.js +0 -175
  516. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  517. package/dist/upload/transaction/audio-icon.svg +0 -4
  518. package/dist/upload/transaction/error-icon.svg +0 -4
  519. package/dist/upload/transaction/file-icon-err.svg +0 -4
  520. package/dist/upload/transaction/file-icon.svg +0 -4
  521. package/dist/upload/transaction/image-icon-err.svg +0 -4
  522. package/dist/upload/transaction/image-icon.svg +0 -4
  523. package/dist/upload/transaction/success-icon.svg +0 -4
  524. package/dist/upload/transaction/video-icon-err.svg +0 -4
  525. package/dist/upload/transaction/video-icon.svg +0 -4
  526. package/dist/upload/transactions/Transactions.js +0 -138
  527. package/dist/wizard/Wizard.js +0 -411
  528. package/dist/wizard/invalid_icon.svg +0 -5
  529. package/dist/wizard/valid_icon.svg +0 -5
  530. package/dist/wizard/validation-wrong.svg +0 -6
  531. package/test/Accordion.test.js +0 -33
  532. package/test/AccordionGroup.test.js +0 -125
  533. package/test/Alert.test.js +0 -53
  534. package/test/Box.test.js +0 -10
  535. package/test/Button.test.js +0 -18
  536. package/test/Card.test.js +0 -30
  537. package/test/Checkbox.test.js +0 -45
  538. package/test/Chip.test.js +0 -25
  539. package/test/Date.test.js +0 -393
  540. package/test/Dialog.test.js +0 -23
  541. package/test/Dropdown.test.js +0 -145
  542. package/test/Footer.test.js +0 -99
  543. package/test/Header.test.js +0 -39
  544. package/test/Heading.test.js +0 -35
  545. package/test/InputText.test.js +0 -240
  546. package/test/Link.test.js +0 -43
  547. package/test/NewDate.test.js +0 -203
  548. package/test/NewInputText.test.js +0 -817
  549. package/test/NewTextarea.test.js +0 -201
  550. package/test/Number.test.js +0 -241
  551. package/test/Paginator.test.js +0 -177
  552. package/test/Password.test.js +0 -76
  553. package/test/ProgressBar.test.js +0 -35
  554. package/test/Radio.test.js +0 -37
  555. package/test/ResultsetTable.test.js +0 -330
  556. package/test/Select.test.js +0 -189
  557. package/test/Sidenav.test.js +0 -45
  558. package/test/Slider.test.js +0 -82
  559. package/test/Spinner.test.js +0 -27
  560. package/test/Switch.test.js +0 -45
  561. package/test/Table.test.js +0 -36
  562. package/test/Tabs.test.js +0 -109
  563. package/test/TabsForSections.test.js +0 -34
  564. package/test/Tag.test.js +0 -32
  565. package/test/TextArea.test.js +0 -52
  566. package/test/ToggleGroup.test.js +0 -81
  567. package/test/Upload.test.js +0 -60
  568. package/test/Wizard.test.js +0 -130
  569. package/test/mocks/pngMock.js +0 -1
  570. package/test/mocks/svgMock.js +0 -1
@@ -0,0 +1,124 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
10
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
11
+ var _react = _interopRequireWildcard(require("react"));
12
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
13
+ var _uuid = require("uuid");
14
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
15
+ var _Flex = _interopRequireDefault(require("../flex/Flex"));
16
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5;
17
+ 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); }
18
+ 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 && Object.prototype.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; }
19
+ var DxcRadio = function DxcRadio(_ref) {
20
+ var label = _ref.label,
21
+ checked = _ref.checked,
22
+ onClick = _ref.onClick,
23
+ error = _ref.error,
24
+ disabled = _ref.disabled,
25
+ focused = _ref.focused,
26
+ readOnly = _ref.readOnly,
27
+ tabIndex = _ref.tabIndex;
28
+ var _useState = (0, _react.useState)("radio-".concat((0, _uuid.v4)())),
29
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 1),
30
+ radioLabelId = _useState2[0];
31
+ var ref = (0, _react.useRef)(null);
32
+ var colorsTheme = (0, _useTheme["default"])();
33
+ var handleOnClick = function handleOnClick() {
34
+ var _ref$current;
35
+ onClick();
36
+ document.activeElement !== (ref === null || ref === void 0 ? void 0 : ref.current) && (ref === null || ref === void 0 ? void 0 : (_ref$current = ref.current) === null || _ref$current === void 0 ? void 0 : _ref$current.focus());
37
+ };
38
+ var _useState3 = (0, _react.useState)(true),
39
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
40
+ firstUpdate = _useState4[0],
41
+ setFirstUpdate = _useState4[1];
42
+ (0, _react.useEffect)(function () {
43
+ var _ref$current2;
44
+ // Don't apply in the first render
45
+ if (firstUpdate) {
46
+ setFirstUpdate(false);
47
+ return;
48
+ }
49
+ focused && (ref === null || ref === void 0 ? void 0 : (_ref$current2 = ref.current) === null || _ref$current2 === void 0 ? void 0 : _ref$current2.focus());
50
+ }, [focused]);
51
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
52
+ theme: colorsTheme.radioGroup
53
+ }, /*#__PURE__*/_react["default"].createElement(_Flex["default"], null, /*#__PURE__*/_react["default"].createElement(RadioContainer, {
54
+ error: error,
55
+ disabled: disabled,
56
+ readOnly: readOnly,
57
+ onClick: disabled ? undefined : handleOnClick
58
+ }, /*#__PURE__*/_react["default"].createElement(RadioInputContainer, null, /*#__PURE__*/_react["default"].createElement(RadioInput, {
59
+ error: error,
60
+ disabled: disabled,
61
+ readOnly: readOnly,
62
+ role: "radio",
63
+ "aria-checked": checked,
64
+ "aria-disabled": disabled,
65
+ "aria-labelledby": radioLabelId,
66
+ tabIndex: disabled ? -1 : focused ? tabIndex : -1,
67
+ ref: ref
68
+ }, checked && /*#__PURE__*/_react["default"].createElement(Dot, {
69
+ disabled: disabled,
70
+ readOnly: readOnly,
71
+ error: error
72
+ }))), /*#__PURE__*/_react["default"].createElement(Label, {
73
+ id: radioLabelId,
74
+ disabled: disabled
75
+ }, label))));
76
+ };
77
+ var getRadioInputStateColor = function getRadioInputStateColor(props, state) {
78
+ switch (state) {
79
+ case "enabled":
80
+ return props.disabled ? props.theme.disabledRadioInputColor : props.error ? props.theme.errorRadioInputColor : props.readOnly ? props.theme.readOnlyRadioInputColor : props.theme.radioInputColor;
81
+ case "hover":
82
+ return props.error ? props.theme.hoverErrorRadioInputColor : props.readOnly ? props.theme.hoverReadOnlyRadioInputColor : props.theme.hoverRadioInputColor;
83
+ case "active":
84
+ return props.error ? props.theme.activeErrorRadioInputColor : props.readOnly ? props.theme.activeReadOnlyRadioInputColor : props.theme.activeRadioInputColor;
85
+ }
86
+ };
87
+ var RadioInputContainer = _styledComponents["default"].span(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: center;\n height: 24px;\n width: 24px;\n"])));
88
+ var RadioInput = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: flex;\n align-items: center;\n justify-content: center;\n width: 18px;\n height: 18px;\n border: 2px solid ", ";\n border-radius: 50%;\n\n &:focus {\n outline: 2px solid ", ";\n outline-offset: 1px;\n }\n ", "\n"])), function (props) {
89
+ return getRadioInputStateColor(props, "enabled");
90
+ }, function (props) {
91
+ return props.theme.focusBorderColor;
92
+ }, function (props) {
93
+ return props.disabled && "pointer-events: none;";
94
+ });
95
+ var Dot = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n height: 10px;\n width: 10px;\n border-radius: 50%;\n background-color: ", ";\n"])), function (props) {
96
+ return getRadioInputStateColor(props, "enabled");
97
+ });
98
+ var Label = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n margin-left: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: ", ";\n ", "\n"])), function (props) {
99
+ return props.theme.radioInputLabelMargin;
100
+ }, function (props) {
101
+ return props.theme.fontFamily;
102
+ }, function (props) {
103
+ return props.theme.radioInputLabelFontSize;
104
+ }, function (props) {
105
+ return props.theme.radioInputLabelFontStyle;
106
+ }, function (props) {
107
+ return props.theme.radioInputLabelFontWeight;
108
+ }, function (props) {
109
+ return props.theme.radioInputLabelLineHeight;
110
+ }, function (props) {
111
+ return props.disabled ? "color: ".concat(props.theme.disabledRadioInputLabelFontColor, ";") : "color: ".concat(props.theme.radioInputLabelFontColor);
112
+ });
113
+ var RadioContainer = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n align-items: center;\n cursor: ", ";\n\n &:hover {\n ", " {\n border-color: ", ";\n }\n ", " {\n background-color: ", ";\n }\n }\n &:active {\n ", " {\n border-color: ", ";\n }\n ", " {\n background-color: ", ";\n }\n }\n"])), function (props) {
114
+ return props.disabled ? "not-allowed" : props.readOnly ? "default" : "pointer";
115
+ }, RadioInput, function (props) {
116
+ return !props.disabled && getRadioInputStateColor(props, "hover");
117
+ }, Dot, function (props) {
118
+ return !props.disabled && getRadioInputStateColor(props, "hover");
119
+ }, RadioInput, function (props) {
120
+ return !props.disabled && getRadioInputStateColor(props, "active");
121
+ }, Dot, function (props) {
122
+ return !props.disabled && getRadioInputStateColor(props, "active");
123
+ });
124
+ var _default = exports["default"] = /*#__PURE__*/_react["default"].memo(DxcRadio);
@@ -0,0 +1,4 @@
1
+ import React from "react";
2
+ import RadioGroupPropsType from "./types";
3
+ declare const DxcRadioGroup: React.ForwardRefExoticComponent<RadioGroupPropsType & React.RefAttributes<HTMLDivElement>>;
4
+ export default DxcRadioGroup;
@@ -0,0 +1,235 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
10
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
11
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
12
+ var _react = _interopRequireWildcard(require("react"));
13
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
14
+ var _uuid = require("uuid");
15
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
16
+ var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
17
+ var _Radio = _interopRequireDefault(require("./Radio"));
18
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7;
19
+ 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); }
20
+ 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 && Object.prototype.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; }
21
+ var getInitialFocusIndex = function getInitialFocusIndex(innerOptions, value) {
22
+ var initialSelectedOptionIndex = innerOptions.findIndex(function (option) {
23
+ return option.value === value;
24
+ });
25
+ return initialSelectedOptionIndex !== -1 ? initialSelectedOptionIndex : 0;
26
+ };
27
+ var DxcRadioGroup = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
28
+ var _ref2;
29
+ var label = _ref.label,
30
+ name = _ref.name,
31
+ helperText = _ref.helperText,
32
+ options = _ref.options,
33
+ _ref$disabled = _ref.disabled,
34
+ disabled = _ref$disabled === void 0 ? false : _ref$disabled,
35
+ _ref$optional = _ref.optional,
36
+ optional = _ref$optional === void 0 ? false : _ref$optional,
37
+ optionalItemLabel = _ref.optionalItemLabel,
38
+ _ref$readOnly = _ref.readOnly,
39
+ readOnly = _ref$readOnly === void 0 ? false : _ref$readOnly,
40
+ _ref$stacking = _ref.stacking,
41
+ stacking = _ref$stacking === void 0 ? "column" : _ref$stacking,
42
+ defaultValue = _ref.defaultValue,
43
+ value = _ref.value,
44
+ onChange = _ref.onChange,
45
+ onBlur = _ref.onBlur,
46
+ error = _ref.error,
47
+ _ref$tabIndex = _ref.tabIndex,
48
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
49
+ var _useState = (0, _react.useState)("radio-group-".concat((0, _uuid.v4)())),
50
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 1),
51
+ radioGroupId = _useState2[0];
52
+ var radioGroupLabelId = "label-".concat(radioGroupId);
53
+ var errorId = "error-".concat(radioGroupId);
54
+ var _useState3 = (0, _react.useState)(defaultValue),
55
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
56
+ innerValue = _useState4[0],
57
+ setInnerValue = _useState4[1];
58
+ var _useState5 = (0, _react.useState)(true),
59
+ _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
60
+ firstTimeFocus = _useState6[0],
61
+ setFirstTimeFocus = _useState6[1];
62
+ var colorsTheme = (0, _useTheme["default"])();
63
+ var translatedLabels = (0, _useTranslatedLabels["default"])();
64
+ var innerOptions = (0, _react.useMemo)(function () {
65
+ return optional ? [].concat((0, _toConsumableArray2["default"])(options), [{
66
+ label: optionalItemLabel !== null && optionalItemLabel !== void 0 ? optionalItemLabel : translatedLabels.radioGroup.optionalItemLabelDefault,
67
+ value: "",
68
+ disabled: disabled
69
+ }]) : options;
70
+ }, [optional, options, optionalItemLabel, translatedLabels]);
71
+ var _useState7 = (0, _react.useState)(getInitialFocusIndex(innerOptions, value !== null && value !== void 0 ? value : innerValue)),
72
+ _useState8 = (0, _slicedToArray2["default"])(_useState7, 2),
73
+ currentFocusIndex = _useState8[0],
74
+ setCurrentFocusIndex = _useState8[1];
75
+ var handleOnChange = (0, _react.useCallback)(function (newValue) {
76
+ var currentValue = value !== null && value !== void 0 ? value : innerValue;
77
+ if (newValue !== currentValue && !readOnly) {
78
+ value !== null && value !== void 0 ? value : setInnerValue(newValue);
79
+ onChange === null || onChange === void 0 ? void 0 : onChange(newValue);
80
+ }
81
+ }, [value, innerValue, onChange]);
82
+ var handleOnBlur = function handleOnBlur(event) {
83
+ // If the radio group loses the focus to an element not contained inside it...
84
+ if (!event.currentTarget.contains(event.relatedTarget)) {
85
+ setFirstTimeFocus(true);
86
+ var currentValue = value !== null && value !== void 0 ? value : innerValue;
87
+ !optional && !Boolean(currentValue) ? onBlur === null || onBlur === void 0 ? void 0 : onBlur({
88
+ value: currentValue,
89
+ error: translatedLabels.formFields.requiredSelectionErrorMessage
90
+ }) : onBlur === null || onBlur === void 0 ? void 0 : onBlur({
91
+ value: currentValue
92
+ });
93
+ }
94
+ };
95
+ var handleOnFocus = function handleOnFocus() {
96
+ firstTimeFocus && setFirstTimeFocus(false);
97
+ };
98
+ var setPreviousRadioChecked = function setPreviousRadioChecked() {
99
+ setCurrentFocusIndex(function (currentFocusIndex) {
100
+ var index = currentFocusIndex === 0 ? innerOptions.length - 1 : currentFocusIndex - 1;
101
+ while (innerOptions[index].disabled) {
102
+ index = index === 0 ? innerOptions.length - 1 : index - 1;
103
+ }
104
+ handleOnChange(innerOptions[index].value);
105
+ return index;
106
+ });
107
+ };
108
+ var setNextRadioChecked = function setNextRadioChecked() {
109
+ setCurrentFocusIndex(function (currentFocusIndex) {
110
+ var index = currentFocusIndex === innerOptions.length - 1 ? 0 : currentFocusIndex + 1;
111
+ while (innerOptions[index].disabled) {
112
+ index = index === innerOptions.length - 1 ? 0 : index + 1;
113
+ }
114
+ handleOnChange(innerOptions[index].value);
115
+ return index;
116
+ });
117
+ };
118
+ var handleOnKeyDown = function handleOnKeyDown(event) {
119
+ switch (event.key) {
120
+ case "Left":
121
+ case "ArrowLeft":
122
+ case "Up":
123
+ case "ArrowUp":
124
+ event.preventDefault();
125
+ setPreviousRadioChecked();
126
+ break;
127
+ case "Right":
128
+ case "ArrowRight":
129
+ case "Down":
130
+ case "ArrowDown":
131
+ event.preventDefault();
132
+ setNextRadioChecked();
133
+ break;
134
+ case " ":
135
+ event.preventDefault();
136
+ handleOnChange(innerOptions[currentFocusIndex].value);
137
+ break;
138
+ }
139
+ };
140
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
141
+ theme: colorsTheme.radioGroup
142
+ }, /*#__PURE__*/_react["default"].createElement(RadioGroupContainer, {
143
+ ref: ref
144
+ }, label && /*#__PURE__*/_react["default"].createElement(Label, {
145
+ id: radioGroupLabelId,
146
+ helperText: helperText,
147
+ disabled: disabled
148
+ }, label, optional && /*#__PURE__*/_react["default"].createElement(OptionalLabel, null, " ".concat(translatedLabels.formFields.optionalLabel))), helperText && /*#__PURE__*/_react["default"].createElement(HelperText, {
149
+ disabled: disabled
150
+ }, helperText), /*#__PURE__*/_react["default"].createElement(RadioGroup, {
151
+ onBlur: handleOnBlur,
152
+ onFocus: handleOnFocus,
153
+ onKeyDown: handleOnKeyDown,
154
+ stacking: stacking,
155
+ role: "radiogroup",
156
+ "aria-disabled": disabled,
157
+ "aria-labelledby": radioGroupLabelId,
158
+ "aria-invalid": error ? true : false,
159
+ "aria-errormessage": error ? errorId : undefined,
160
+ "aria-required": !disabled && !readOnly && !optional,
161
+ "aria-readonly": readOnly,
162
+ "aria-orientation": stacking === "column" ? "vertical" : "horizontal"
163
+ }, /*#__PURE__*/_react["default"].createElement(ValueInput, {
164
+ name: name,
165
+ disabled: disabled,
166
+ value: (_ref2 = value !== null && value !== void 0 ? value : innerValue) !== null && _ref2 !== void 0 ? _ref2 : "",
167
+ readOnly: true
168
+ }), innerOptions.map(function (option, index) {
169
+ return /*#__PURE__*/_react["default"].createElement(_Radio["default"], {
170
+ key: "radio-".concat(index),
171
+ label: option.label,
172
+ checked: (value !== null && value !== void 0 ? value : innerValue) === option.value,
173
+ onClick: function onClick() {
174
+ handleOnChange(option.value);
175
+ setCurrentFocusIndex(index);
176
+ },
177
+ error: error,
178
+ disabled: option.disabled || disabled,
179
+ focused: currentFocusIndex === index,
180
+ readOnly: readOnly,
181
+ tabIndex: tabIndex
182
+ });
183
+ })), !disabled && typeof error === "string" && /*#__PURE__*/_react["default"].createElement(Error, {
184
+ id: errorId,
185
+ "aria-live": error ? "assertive" : "off"
186
+ }, error)));
187
+ });
188
+ var RadioGroupContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: inline-flex;\n flex-direction: column;\n"])));
189
+ 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) {
190
+ return props.disabled ? props.theme.disabledLabelFontColor : props.theme.labelFontColor;
191
+ }, function (props) {
192
+ return props.theme.fontFamily;
193
+ }, function (props) {
194
+ return props.theme.labelFontSize;
195
+ }, function (props) {
196
+ return props.theme.labelFontStyle;
197
+ }, function (props) {
198
+ return props.theme.labelFontWeight;
199
+ }, function (props) {
200
+ return props.theme.labelLineHeight;
201
+ }, function (props) {
202
+ return !props.helperText && "margin-bottom: ".concat(props.theme.groupLabelMargin);
203
+ });
204
+ var OptionalLabel = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n font-weight: ", ";\n"])), function (props) {
205
+ return props.theme.optionalLabelFontWeight;
206
+ });
207
+ 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) {
208
+ return props.disabled ? props.theme.disabledHelperTextFontColor : props.theme.helperTextFontColor;
209
+ }, function (props) {
210
+ return props.theme.fontFamily;
211
+ }, function (props) {
212
+ return props.theme.helperTextFontSize;
213
+ }, function (props) {
214
+ return props.theme.helperTextFontStyle;
215
+ }, function (props) {
216
+ return props.theme.helperTextFontWeight;
217
+ }, function (props) {
218
+ return props.theme.helperTextLineHeight;
219
+ }, function (props) {
220
+ return props.theme.groupLabelMargin;
221
+ });
222
+ 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) {
223
+ return props.stacking;
224
+ }, function (props) {
225
+ return props.theme.groupVerticalGutter;
226
+ }, function (props) {
227
+ return props.theme.groupHorizontalGutter;
228
+ });
229
+ var ValueInput = _styledComponents["default"].input(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n display: none;\n"])));
230
+ 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) {
231
+ return props.theme.errorMessageColor;
232
+ }, function (props) {
233
+ return props.theme.fontFamily;
234
+ });
235
+ var _default = exports["default"] = DxcRadioGroup;
@@ -0,0 +1,214 @@
1
+ import React from "react";
2
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
3
+ import Title from "../../.storybook/components/Title";
4
+ import DxcRadioGroup from "./RadioGroup";
5
+ import { HalstackProvider } from "../HalstackContext";
6
+
7
+ export default {
8
+ title: "Radio Group",
9
+ component: DxcRadioGroup,
10
+ };
11
+
12
+ const single_option = [{ label: "Option A", value: "A" }];
13
+
14
+ const options = [
15
+ { label: "Option 1", value: "1" },
16
+ { label: "Option 2", value: "2" },
17
+ { label: "Option 3", value: "3" },
18
+ { label: "Option 4", value: "4" },
19
+ ];
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
+ };
29
+
30
+ export const Chromatic = () => (
31
+ <>
32
+ <Title title="Radio input states" theme="light" level={2} />
33
+ <ExampleContainer>
34
+ <Title title="Enabled" theme="light" level={4} />
35
+ <DxcRadioGroup label="Label" helperText="Helper text" defaultValue="A" options={single_option} />
36
+ </ExampleContainer>
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} />
48
+ </ExampleContainer>
49
+ <ExampleContainer>
50
+ <Title title="Disabled" theme="light" level={4} />
51
+ <DxcRadioGroup label="Label" helperText="Helper text" options={single_disabled_options} defaultValue="A" />
52
+ </ExampleContainer>
53
+ <Title title="Readonly radio input sub-states" theme="light" level={3} />
54
+ <ExampleContainer>
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 />
65
+ </ExampleContainer>
66
+ <Title title="Error radio input sub-states" theme="light" level={3} />
67
+ <ExampleContainer>
68
+ <Title title="Enabled" theme="light" level={4} />
69
+ <DxcRadioGroup
70
+ label="Label"
71
+ helperText="Helper text"
72
+ options={single_option}
73
+ defaultValue="A"
74
+ error="Error message"
75
+ />
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>
124
+ <ExampleContainer>
125
+ <Title title="Error" theme="light" level={4} />
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>
212
+ </ExampleContainer>
213
+ </>
214
+ );