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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (434) hide show
  1. package/BackgroundColorContext.d.ts +1 -0
  2. package/BackgroundColorContext.js +6 -26
  3. package/HalstackContext.d.ts +1248 -0
  4. package/HalstackContext.js +310 -0
  5. package/README.md +47 -0
  6. package/accordion/Accordion.accessibility.test.js +71 -0
  7. package/accordion/Accordion.d.ts +1 -1
  8. package/accordion/Accordion.js +106 -193
  9. package/accordion/Accordion.stories.tsx +251 -0
  10. package/accordion/Accordion.test.js +56 -0
  11. package/accordion/types.d.ts +12 -23
  12. package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
  13. package/accordion-group/AccordionGroup.d.ts +3 -3
  14. package/accordion-group/AccordionGroup.js +39 -108
  15. package/accordion-group/AccordionGroup.stories.tsx +252 -0
  16. package/accordion-group/AccordionGroup.test.js +98 -0
  17. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  18. package/accordion-group/AccordionGroupAccordion.js +31 -0
  19. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  20. package/accordion-group/AccordionGroupContext.js +8 -0
  21. package/accordion-group/types.d.ts +18 -23
  22. package/action-icon/ActionIcon.accessibility.test.js +63 -0
  23. package/action-icon/ActionIcon.d.ts +4 -0
  24. package/action-icon/ActionIcon.js +48 -0
  25. package/action-icon/ActionIcon.stories.tsx +41 -0
  26. package/action-icon/ActionIcon.test.js +64 -0
  27. package/action-icon/types.d.ts +26 -0
  28. package/alert/Alert.accessibility.test.js +95 -0
  29. package/alert/Alert.js +36 -126
  30. package/alert/Alert.stories.tsx +28 -0
  31. package/alert/Alert.test.js +75 -0
  32. package/alert/types.d.ts +5 -5
  33. package/badge/Badge.accessibility.test.js +129 -0
  34. package/badge/Badge.d.ts +4 -0
  35. package/badge/Badge.js +142 -40
  36. package/badge/Badge.stories.tsx +210 -0
  37. package/badge/Badge.test.js +30 -0
  38. package/badge/types.d.ts +54 -0
  39. package/bleed/Bleed.d.ts +3 -0
  40. package/bleed/Bleed.js +43 -0
  41. package/bleed/Bleed.stories.tsx +342 -0
  42. package/bleed/types.d.ts +37 -0
  43. package/box/Box.accessibility.test.js +33 -0
  44. package/box/Box.d.ts +1 -1
  45. package/box/Box.js +31 -82
  46. package/box/Box.stories.tsx +38 -51
  47. package/box/Box.test.js +13 -0
  48. package/box/types.d.ts +3 -14
  49. package/bulleted-list/BulletedList.accessibility.test.js +107 -0
  50. package/bulleted-list/BulletedList.d.ts +7 -0
  51. package/bulleted-list/BulletedList.js +92 -0
  52. package/bulleted-list/BulletedList.stories.tsx +115 -0
  53. package/bulleted-list/types.d.ts +38 -0
  54. package/bulleted-list/types.js +5 -0
  55. package/button/Button.accessibility.test.js +127 -0
  56. package/button/Button.d.ts +1 -1
  57. package/button/Button.js +65 -123
  58. package/button/Button.stories.tsx +155 -106
  59. package/button/Button.test.js +38 -0
  60. package/button/types.d.ts +12 -12
  61. package/card/Card.accessibility.test.js +36 -0
  62. package/card/Card.d.ts +1 -1
  63. package/card/Card.js +59 -103
  64. package/card/Card.stories.tsx +13 -43
  65. package/card/Card.test.js +39 -0
  66. package/card/types.d.ts +6 -11
  67. package/checkbox/Checkbox.accessibility.test.js +87 -0
  68. package/checkbox/Checkbox.d.ts +2 -2
  69. package/checkbox/Checkbox.js +145 -183
  70. package/checkbox/Checkbox.stories.tsx +166 -136
  71. package/checkbox/Checkbox.test.js +199 -0
  72. package/checkbox/types.d.ts +19 -7
  73. package/chip/Chip.accessibility.test.js +67 -0
  74. package/chip/Chip.d.ts +4 -0
  75. package/chip/Chip.js +49 -146
  76. package/chip/Chip.stories.tsx +104 -30
  77. package/chip/Chip.test.js +41 -0
  78. package/chip/types.d.ts +45 -0
  79. package/chip/types.js +5 -0
  80. package/common/coreTokens.d.ts +237 -0
  81. package/common/coreTokens.js +184 -0
  82. package/common/utils.d.ts +1 -0
  83. package/common/utils.js +6 -12
  84. package/common/variables.d.ts +1394 -0
  85. package/common/variables.js +1035 -1346
  86. package/container/Container.d.ts +4 -0
  87. package/container/Container.js +194 -0
  88. package/container/Container.stories.tsx +214 -0
  89. package/container/types.d.ts +74 -0
  90. package/container/types.js +5 -0
  91. package/contextual-menu/ContextualMenu.accessibility.test.js +86 -0
  92. package/contextual-menu/ContextualMenu.d.ts +5 -0
  93. package/contextual-menu/ContextualMenu.js +88 -0
  94. package/contextual-menu/ContextualMenu.stories.tsx +219 -0
  95. package/contextual-menu/ContextualMenu.test.js +205 -0
  96. package/contextual-menu/GroupItem.d.ts +4 -0
  97. package/contextual-menu/GroupItem.js +67 -0
  98. package/contextual-menu/ItemAction.d.ts +4 -0
  99. package/contextual-menu/ItemAction.js +52 -0
  100. package/contextual-menu/MenuItem.d.ts +4 -0
  101. package/contextual-menu/MenuItem.js +29 -0
  102. package/contextual-menu/SingleItem.d.ts +4 -0
  103. package/contextual-menu/SingleItem.js +38 -0
  104. package/contextual-menu/types.d.ts +58 -0
  105. package/contextual-menu/types.js +5 -0
  106. package/date-input/Calendar.d.ts +4 -0
  107. package/date-input/Calendar.js +214 -0
  108. package/date-input/DateInput.accessibility.test.js +216 -0
  109. package/date-input/DateInput.js +174 -313
  110. package/date-input/DateInput.stories.tsx +203 -56
  111. package/date-input/DateInput.test.js +808 -0
  112. package/date-input/DatePicker.d.ts +4 -0
  113. package/date-input/DatePicker.js +121 -0
  114. package/date-input/YearPicker.d.ts +4 -0
  115. package/date-input/YearPicker.js +100 -0
  116. package/date-input/types.d.ts +86 -22
  117. package/dialog/Dialog.accessibility.test.js +69 -0
  118. package/dialog/Dialog.d.ts +1 -1
  119. package/dialog/Dialog.js +57 -130
  120. package/dialog/Dialog.stories.tsx +320 -167
  121. package/dialog/Dialog.test.js +307 -0
  122. package/dialog/types.d.ts +18 -25
  123. package/divider/Divider.accessibility.test.js +33 -0
  124. package/divider/Divider.d.ts +4 -0
  125. package/divider/Divider.js +36 -0
  126. package/divider/Divider.stories.tsx +223 -0
  127. package/divider/Divider.test.js +38 -0
  128. package/divider/types.d.ts +21 -0
  129. package/divider/types.js +5 -0
  130. package/dropdown/Dropdown.accessibility.test.js +180 -0
  131. package/dropdown/Dropdown.d.ts +1 -1
  132. package/dropdown/Dropdown.js +232 -330
  133. package/dropdown/Dropdown.stories.tsx +427 -0
  134. package/dropdown/Dropdown.test.js +599 -0
  135. package/dropdown/DropdownMenu.d.ts +4 -0
  136. package/dropdown/DropdownMenu.js +63 -0
  137. package/dropdown/DropdownMenuItem.d.ts +4 -0
  138. package/dropdown/DropdownMenuItem.js +70 -0
  139. package/dropdown/types.d.ts +38 -31
  140. package/file-input/FileInput.accessibility.test.js +160 -0
  141. package/file-input/FileInput.d.ts +2 -2
  142. package/file-input/FileInput.js +272 -340
  143. package/file-input/FileInput.stories.tsx +618 -0
  144. package/file-input/FileInput.test.js +382 -0
  145. package/file-input/FileItem.d.ts +4 -14
  146. package/file-input/FileItem.js +60 -121
  147. package/file-input/types.d.ts +53 -11
  148. package/flex/Flex.d.ts +4 -0
  149. package/flex/Flex.js +57 -0
  150. package/flex/Flex.stories.tsx +112 -0
  151. package/flex/types.d.ts +97 -0
  152. package/flex/types.js +5 -0
  153. package/footer/Footer.accessibility.test.js +117 -0
  154. package/footer/Footer.d.ts +1 -1
  155. package/footer/Footer.js +74 -200
  156. package/footer/{Footer.stories.jsx → Footer.stories.tsx} +84 -39
  157. package/footer/Footer.test.js +85 -0
  158. package/footer/Icons.d.ts +3 -0
  159. package/footer/Icons.js +67 -8
  160. package/footer/types.d.ts +40 -37
  161. package/grid/Grid.d.ts +7 -0
  162. package/grid/Grid.js +76 -0
  163. package/grid/Grid.stories.tsx +219 -0
  164. package/grid/types.d.ts +115 -0
  165. package/grid/types.js +5 -0
  166. package/header/Header.accessibility.test.js +84 -0
  167. package/header/Header.d.ts +4 -3
  168. package/header/Header.js +103 -218
  169. package/header/Header.stories.tsx +152 -63
  170. package/header/Header.test.js +66 -0
  171. package/header/Icons.d.ts +2 -0
  172. package/header/Icons.js +4 -9
  173. package/header/types.d.ts +7 -21
  174. package/heading/Heading.accessibility.test.js +33 -0
  175. package/heading/Heading.js +11 -33
  176. package/heading/Heading.stories.tsx +3 -2
  177. package/heading/Heading.test.js +169 -0
  178. package/heading/types.d.ts +7 -7
  179. package/icon/Icon.accessibility.test.js +30 -0
  180. package/icon/Icon.d.ts +4 -0
  181. package/icon/Icon.js +33 -0
  182. package/icon/Icon.stories.tsx +28 -0
  183. package/icon/types.d.ts +4 -0
  184. package/icon/types.js +5 -0
  185. package/image/Image.accessibility.test.js +56 -0
  186. package/image/Image.d.ts +4 -0
  187. package/image/Image.js +70 -0
  188. package/image/Image.stories.tsx +129 -0
  189. package/image/types.d.ts +72 -0
  190. package/image/types.js +5 -0
  191. package/inset/Inset.d.ts +3 -0
  192. package/inset/Inset.js +43 -0
  193. package/inset/Inset.stories.tsx +230 -0
  194. package/inset/types.d.ts +37 -0
  195. package/inset/types.js +5 -0
  196. package/layout/ApplicationLayout.d.ts +20 -0
  197. package/layout/ApplicationLayout.js +86 -184
  198. package/layout/ApplicationLayout.stories.tsx +162 -0
  199. package/layout/Icons.d.ts +7 -0
  200. package/layout/Icons.js +41 -48
  201. package/layout/types.d.ts +41 -0
  202. package/layout/types.js +5 -0
  203. package/link/Link.accessibility.test.js +112 -0
  204. package/link/Link.d.ts +3 -2
  205. package/link/Link.js +65 -109
  206. package/link/Link.stories.tsx +159 -52
  207. package/link/Link.test.js +63 -0
  208. package/link/types.d.ts +15 -35
  209. package/main.d.ts +19 -14
  210. package/main.js +92 -98
  211. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  212. package/nav-tabs/NavTabs.d.ts +7 -0
  213. package/nav-tabs/NavTabs.js +93 -0
  214. package/nav-tabs/NavTabs.stories.tsx +279 -0
  215. package/nav-tabs/NavTabs.test.js +75 -0
  216. package/nav-tabs/NavTabsContext.d.ts +3 -0
  217. package/nav-tabs/NavTabsContext.js +8 -0
  218. package/nav-tabs/Tab.d.ts +4 -0
  219. package/nav-tabs/Tab.js +117 -0
  220. package/nav-tabs/types.d.ts +52 -0
  221. package/nav-tabs/types.js +5 -0
  222. package/number-input/NumberInput.accessibility.test.js +228 -0
  223. package/number-input/NumberInput.js +48 -48
  224. package/number-input/NumberInput.stories.tsx +44 -28
  225. package/number-input/NumberInput.test.js +989 -0
  226. package/number-input/NumberInputContext.d.ts +3 -4
  227. package/number-input/NumberInputContext.js +3 -14
  228. package/number-input/types.d.ts +34 -15
  229. package/package.json +52 -51
  230. package/paginator/Paginator.accessibility.test.js +79 -0
  231. package/paginator/Paginator.js +39 -103
  232. package/paginator/Paginator.stories.tsx +24 -0
  233. package/paginator/Paginator.test.js +335 -0
  234. package/paginator/types.d.ts +3 -3
  235. package/paragraph/Paragraph.accessibility.test.js +28 -0
  236. package/paragraph/Paragraph.d.ts +5 -0
  237. package/paragraph/Paragraph.js +22 -0
  238. package/paragraph/Paragraph.stories.tsx +27 -0
  239. package/password-input/PasswordInput.accessibility.test.js +153 -0
  240. package/password-input/PasswordInput.js +59 -125
  241. package/password-input/PasswordInput.stories.tsx +3 -35
  242. package/password-input/PasswordInput.test.js +198 -0
  243. package/password-input/types.d.ts +32 -26
  244. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  245. package/progress-bar/ProgressBar.js +66 -92
  246. package/progress-bar/ProgressBar.stories.tsx +93 -0
  247. package/progress-bar/ProgressBar.test.js +93 -0
  248. package/progress-bar/types.d.ts +3 -3
  249. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  250. package/quick-nav/QuickNav.d.ts +4 -0
  251. package/quick-nav/QuickNav.js +94 -0
  252. package/quick-nav/QuickNav.stories.tsx +356 -0
  253. package/quick-nav/types.d.ts +21 -0
  254. package/quick-nav/types.js +5 -0
  255. package/radio-group/Radio.d.ts +4 -0
  256. package/radio-group/Radio.js +124 -0
  257. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  258. package/radio-group/RadioGroup.d.ts +4 -0
  259. package/radio-group/RadioGroup.js +235 -0
  260. package/radio-group/RadioGroup.stories.tsx +214 -0
  261. package/radio-group/RadioGroup.test.js +756 -0
  262. package/radio-group/types.d.ts +114 -0
  263. package/radio-group/types.js +5 -0
  264. package/resultset-table/Icons.d.ts +7 -0
  265. package/resultset-table/Icons.js +47 -0
  266. package/resultset-table/ResultsetTable.accessibility.test.js +274 -0
  267. package/resultset-table/ResultsetTable.d.ts +7 -0
  268. package/resultset-table/ResultsetTable.js +170 -0
  269. package/resultset-table/ResultsetTable.stories.tsx +401 -0
  270. package/resultset-table/ResultsetTable.test.js +381 -0
  271. package/resultset-table/types.d.ts +100 -0
  272. package/resultset-table/types.js +5 -0
  273. package/select/Listbox.d.ts +4 -0
  274. package/select/Listbox.js +145 -0
  275. package/select/Option.d.ts +4 -0
  276. package/select/Option.js +88 -0
  277. package/select/Select.accessibility.test.js +217 -0
  278. package/select/Select.d.ts +4 -0
  279. package/select/Select.js +248 -515
  280. package/select/Select.stories.tsx +590 -255
  281. package/select/Select.test.js +2276 -0
  282. package/select/types.d.ts +209 -0
  283. package/select/types.js +5 -0
  284. package/sidenav/Sidenav.accessibility.test.js +59 -0
  285. package/sidenav/Sidenav.d.ts +6 -5
  286. package/sidenav/Sidenav.js +137 -72
  287. package/sidenav/Sidenav.stories.tsx +246 -134
  288. package/sidenav/Sidenav.test.js +37 -0
  289. package/sidenav/SidenavContext.d.ts +5 -0
  290. package/sidenav/SidenavContext.js +13 -0
  291. package/sidenav/types.d.ts +52 -26
  292. package/slider/Slider.accessibility.test.js +104 -0
  293. package/slider/Slider.d.ts +2 -2
  294. package/slider/Slider.js +149 -181
  295. package/slider/Slider.test.js +254 -0
  296. package/slider/types.d.ts +11 -3
  297. package/spinner/Spinner.accessibility.test.js +96 -0
  298. package/spinner/Spinner.js +32 -76
  299. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -26
  300. package/spinner/Spinner.test.js +55 -0
  301. package/spinner/types.d.ts +3 -3
  302. package/status-light/StatusLight.accessibility.test.js +157 -0
  303. package/status-light/StatusLight.d.ts +4 -0
  304. package/status-light/StatusLight.js +51 -0
  305. package/status-light/StatusLight.stories.tsx +74 -0
  306. package/status-light/StatusLight.test.js +25 -0
  307. package/status-light/types.d.ts +17 -0
  308. package/status-light/types.js +5 -0
  309. package/switch/Switch.accessibility.test.js +89 -0
  310. package/switch/Switch.d.ts +2 -2
  311. package/switch/Switch.js +150 -115
  312. package/switch/Switch.stories.tsx +45 -68
  313. package/switch/Switch.test.js +180 -0
  314. package/switch/types.d.ts +13 -5
  315. package/table/DropdownTheme.js +62 -0
  316. package/table/Table.accessibility.test.js +82 -0
  317. package/table/Table.d.ts +6 -2
  318. package/table/Table.js +79 -36
  319. package/table/Table.stories.tsx +651 -0
  320. package/table/Table.test.js +113 -0
  321. package/table/types.d.ts +34 -6
  322. package/tabs/Tab.d.ts +4 -0
  323. package/tabs/Tab.js +117 -0
  324. package/tabs/Tabs.accessibility.test.js +56 -0
  325. package/tabs/Tabs.d.ts +1 -1
  326. package/tabs/Tabs.js +307 -147
  327. package/tabs/Tabs.stories.tsx +121 -18
  328. package/tabs/Tabs.test.js +276 -0
  329. package/tabs/types.d.ts +46 -24
  330. package/tag/Tag.accessibility.test.js +69 -0
  331. package/tag/Tag.d.ts +1 -1
  332. package/tag/Tag.js +44 -86
  333. package/tag/Tag.stories.tsx +37 -30
  334. package/tag/Tag.test.js +41 -0
  335. package/tag/types.d.ts +25 -16
  336. package/text-input/Suggestion.d.ts +4 -0
  337. package/text-input/Suggestion.js +67 -0
  338. package/text-input/Suggestions.d.ts +4 -0
  339. package/text-input/Suggestions.js +86 -0
  340. package/text-input/TextInput.accessibility.test.js +321 -0
  341. package/text-input/TextInput.js +335 -553
  342. package/text-input/TextInput.stories.tsx +465 -0
  343. package/text-input/TextInput.test.js +1756 -0
  344. package/text-input/types.d.ts +82 -34
  345. package/textarea/Textarea.accessibility.test.js +155 -0
  346. package/textarea/Textarea.d.ts +4 -0
  347. package/textarea/Textarea.js +98 -181
  348. package/textarea/Textarea.stories.tsx +174 -0
  349. package/textarea/Textarea.test.js +406 -0
  350. package/textarea/types.d.ts +141 -0
  351. package/textarea/types.js +5 -0
  352. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  353. package/toggle-group/ToggleGroup.d.ts +2 -2
  354. package/toggle-group/ToggleGroup.js +98 -113
  355. package/toggle-group/ToggleGroup.stories.tsx +79 -39
  356. package/toggle-group/ToggleGroup.test.js +137 -0
  357. package/toggle-group/types.d.ts +68 -38
  358. package/typography/Typography.accessibility.test.js +339 -0
  359. package/typography/Typography.d.ts +4 -0
  360. package/typography/Typography.js +23 -0
  361. package/typography/Typography.stories.tsx +198 -0
  362. package/typography/types.d.ts +18 -0
  363. package/typography/types.js +5 -0
  364. package/useTheme.d.ts +1147 -0
  365. package/useTheme.js +4 -11
  366. package/useTranslatedLabels.d.ts +85 -0
  367. package/useTranslatedLabels.js +14 -0
  368. package/utils/BaseTypography.d.ts +21 -0
  369. package/utils/BaseTypography.js +94 -0
  370. package/utils/FocusLock.d.ts +13 -0
  371. package/utils/FocusLock.js +124 -0
  372. package/wizard/Wizard.accessibility.test.js +55 -0
  373. package/wizard/Wizard.d.ts +1 -1
  374. package/wizard/Wizard.js +130 -114
  375. package/wizard/{Wizard.stories.jsx → Wizard.stories.tsx} +67 -19
  376. package/wizard/Wizard.test.js +114 -0
  377. package/wizard/types.d.ts +15 -15
  378. package/ThemeContext.js +0 -246
  379. package/V3Select/V3Select.js +0 -455
  380. package/V3Select/index.d.ts +0 -27
  381. package/V3Textarea/V3Textarea.js +0 -260
  382. package/V3Textarea/index.d.ts +0 -27
  383. package/card/ice-cream.jpg +0 -0
  384. package/chip/index.d.ts +0 -22
  385. package/common/OpenSans.css +0 -81
  386. package/common/RequiredComponent.js +0 -32
  387. package/common/fonts/OpenSans-Bold.ttf +0 -0
  388. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  389. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  390. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  391. package/common/fonts/OpenSans-Italic.ttf +0 -0
  392. package/common/fonts/OpenSans-Light.ttf +0 -0
  393. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  394. package/common/fonts/OpenSans-Regular.ttf +0 -0
  395. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  396. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  397. package/date/Date.js +0 -373
  398. package/date/index.d.ts +0 -27
  399. package/input-text/Icons.js +0 -22
  400. package/input-text/InputText.js +0 -611
  401. package/input-text/index.d.ts +0 -36
  402. package/number-input/numberInputContextTypes.d.ts +0 -19
  403. package/paginator/Icons.js +0 -66
  404. package/progress-bar/ProgressBar.stories.jsx +0 -58
  405. package/radio/Radio.d.ts +0 -4
  406. package/radio/Radio.js +0 -174
  407. package/radio/Radio.stories.tsx +0 -192
  408. package/radio/types.d.ts +0 -54
  409. package/resultsetTable/ResultsetTable.d.ts +0 -4
  410. package/resultsetTable/ResultsetTable.js +0 -249
  411. package/resultsetTable/types.d.ts +0 -63
  412. package/select/index.d.ts +0 -131
  413. package/slider/Slider.stories.tsx +0 -177
  414. package/table/Table.stories.jsx +0 -276
  415. package/textarea/Textarea.stories.jsx +0 -135
  416. package/textarea/index.d.ts +0 -117
  417. package/toggle/Toggle.js +0 -186
  418. package/toggle/index.d.ts +0 -21
  419. package/upload/Upload.js +0 -201
  420. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  421. package/upload/buttons-upload/Icons.js +0 -40
  422. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  423. package/upload/dragAndDropArea/Icons.js +0 -39
  424. package/upload/file-upload/FileToUpload.js +0 -115
  425. package/upload/file-upload/Icons.js +0 -66
  426. package/upload/files-upload/FilesToUpload.js +0 -109
  427. package/upload/index.d.ts +0 -15
  428. package/upload/transaction/Icons.js +0 -160
  429. package/upload/transaction/Transaction.js +0 -104
  430. package/upload/transactions/Transactions.js +0 -94
  431. package/wizard/Icons.js +0 -65
  432. /package/{radio → action-icon}/types.js +0 -0
  433. /package/{resultsetTable → badge}/types.js +0 -0
  434. /package/{number-input/numberInputContextTypes.js → bleed/types.js} +0 -0
@@ -1,139 +1,129 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  var _typeof3 = 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
- var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
-
14
9
  var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
15
-
10
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
16
11
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
17
-
18
12
  var _react = _interopRequireWildcard(require("react"));
19
-
20
13
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
21
-
22
14
  var _uuid = require("uuid");
23
-
24
- var _variables = require("../common/variables.js");
25
-
26
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
27
-
28
- var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9;
29
-
30
- 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); }
31
-
32
- function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(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; }
33
-
15
+ var _variables = require("../common/variables");
16
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
17
+ var _Flex = _interopRequireDefault(require("../flex/Flex"));
18
+ var _Icon = _interopRequireDefault(require("../icon/Icon"));
19
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7;
20
+ 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); }
21
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof3(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; }
34
22
  var DxcToggleGroup = function DxcToggleGroup(_ref) {
35
23
  var label = _ref.label,
36
- helperText = _ref.helperText,
37
- value = _ref.value,
38
- onChange = _ref.onChange,
39
- _ref$disabled = _ref.disabled,
40
- disabled = _ref$disabled === void 0 ? false : _ref$disabled,
41
- options = _ref.options,
42
- margin = _ref.margin,
43
- _ref$multiple = _ref.multiple,
44
- multiple = _ref$multiple === void 0 ? false : _ref$multiple,
45
- _ref$tabIndex = _ref.tabIndex,
46
- tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
24
+ helperText = _ref.helperText,
25
+ defaultValue = _ref.defaultValue,
26
+ value = _ref.value,
27
+ onChange = _ref.onChange,
28
+ _ref$disabled = _ref.disabled,
29
+ disabled = _ref$disabled === void 0 ? false : _ref$disabled,
30
+ options = _ref.options,
31
+ margin = _ref.margin,
32
+ _ref$multiple = _ref.multiple,
33
+ multiple = _ref$multiple === void 0 ? false : _ref$multiple,
34
+ _ref$tabIndex = _ref.tabIndex,
35
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
36
+ var _useState = (0, _react.useState)("label-toggle-group-".concat((0, _uuid.v4)())),
37
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 1),
38
+ toggleGroupLabelId = _useState2[0];
39
+ var _useState3 = (0, _react.useState)(defaultValue !== null && defaultValue !== void 0 ? defaultValue : multiple ? [] : -1),
40
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
41
+ selectedValue = _useState4[0],
42
+ setSelectedValue = _useState4[1];
47
43
  var colorsTheme = (0, _useTheme["default"])();
48
-
49
- var _useState = (0, _react.useState)(multiple ? [] : ""),
50
- _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
51
- selectedValue = _useState2[0],
52
- setSelectedValue = _useState2[1];
53
-
54
- var _useState3 = (0, _react.useState)("toggle-group-".concat((0, _uuid.v4)())),
55
- _useState4 = (0, _slicedToArray2["default"])(_useState3, 1),
56
- toggleGroupId = _useState4[0];
57
-
58
44
  var handleToggleChange = function handleToggleChange(selectedOption) {
59
45
  var newSelectedOptions;
60
-
61
46
  if (value == null) {
62
47
  if (multiple && Array.isArray(selectedValue)) {
63
48
  newSelectedOptions = selectedValue.map(function (value) {
64
49
  return value;
65
50
  });
66
-
67
51
  if (newSelectedOptions.includes(selectedOption)) {
68
52
  var index = newSelectedOptions.indexOf(selectedOption);
69
53
  newSelectedOptions.splice(index, 1);
70
54
  } else {
71
55
  newSelectedOptions.push(selectedOption);
72
56
  }
73
-
74
57
  setSelectedValue(newSelectedOptions);
75
58
  } else setSelectedValue(selectedOption === selectedValue ? null : selectedOption);
76
59
  } else if (multiple) {
77
60
  newSelectedOptions = Array.isArray(value) ? value.map(function (v) {
78
61
  return v;
79
62
  }) : value;
80
-
81
63
  if (newSelectedOptions.includes(selectedOption)) {
82
64
  var _index = newSelectedOptions.indexOf(selectedOption);
83
-
84
65
  newSelectedOptions.splice(_index, 1);
85
66
  } else newSelectedOptions.push(selectedOption);
86
67
  }
87
-
88
- typeof onChange === "function" && onChange(multiple ? newSelectedOptions : selectedOption);
68
+ onChange === null || onChange === void 0 ? void 0 : onChange(multiple ? newSelectedOptions : selectedOption);
89
69
  };
90
-
91
- var handleKeyPress = function handleKeyPress(event, optionValue) {
92
- event.preventDefault();
93
- if (!disabled && (event.nativeEvent.code === "Enter" || event.nativeEvent.code === "Space")) handleToggleChange(optionValue);
70
+ var handleOnKeyDown = function handleOnKeyDown(event, optionValue) {
71
+ switch (event.key) {
72
+ case "Enter":
73
+ case " ":
74
+ event.preventDefault();
75
+ handleToggleChange(optionValue);
76
+ }
94
77
  };
95
-
96
78
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
97
79
  theme: colorsTheme.toggleGroup
98
80
  }, /*#__PURE__*/_react["default"].createElement(ToggleGroup, {
99
- margin: margin,
100
- disabled: disabled
81
+ margin: margin
101
82
  }, /*#__PURE__*/_react["default"].createElement(Label, {
102
- htmlFor: toggleGroupId,
83
+ id: toggleGroupLabelId,
103
84
  disabled: disabled
104
85
  }, label), /*#__PURE__*/_react["default"].createElement(HelperText, {
105
86
  disabled: disabled
106
87
  }, helperText), /*#__PURE__*/_react["default"].createElement(OptionsContainer, {
107
- id: toggleGroupId,
108
- role: multiple ? "group" : "radiogroup"
88
+ "aria-labelledby": toggleGroupLabelId
109
89
  }, options.map(function (option, i) {
110
- return /*#__PURE__*/_react["default"].createElement(ToggleContainer, {
111
- selected: multiple ? value ? value.includes(option.value) : selectedValue.includes(option.value) : value ? option.value === value : option.value === selectedValue,
112
- role: multiple ? "switch" : "radio",
113
- "aria-checked": multiple ? value ? value.includes(option.value) : selectedValue.includes(option.value) : value ? option.value === value : option.value === selectedValue,
114
- tabIndex: !disabled ? tabIndex : -1,
90
+ return /*#__PURE__*/_react["default"].createElement(ToggleButton, {
91
+ key: "toggle-".concat(i, "-").concat(option.label),
92
+ "aria-label": option.title,
93
+ "aria-pressed": multiple ? value ? Array.isArray(value) && value.includes(option.value) : Array.isArray(selectedValue) && selectedValue.includes(option.value) : value ? option.value === value : option.value === selectedValue,
94
+ disabled: disabled,
115
95
  onClick: function onClick() {
116
- return !disabled && handleToggleChange(option.value);
96
+ handleToggleChange(option.value);
117
97
  },
118
- isFirst: i === 0,
119
- isLast: i === options.length - 1,
120
- isIcon: option.iconSrc || option.icon,
121
- optionLabel: option.label,
122
- disabled: disabled,
123
- onKeyPress: function onKeyPress(event) {
124
- handleKeyPress(event, option.value);
98
+ onKeyDown: function onKeyDown(event) {
99
+ handleOnKeyDown(event, option.value);
125
100
  },
126
- key: "toggle-".concat(i, "-").concat(option.label)
127
- }, /*#__PURE__*/_react["default"].createElement(OptionContent, null, option.icon && /*#__PURE__*/_react["default"].createElement(IconContainer, {
128
- optionLabel: option.label
129
- }, (0, _typeof2["default"])(option.icon) === "object" ? option.icon : /*#__PURE__*/_react["default"].createElement(option.icon)), option.iconSrc && /*#__PURE__*/_react["default"].createElement(Icon, {
130
- src: option.iconSrc,
101
+ tabIndex: !disabled ? tabIndex : -1,
102
+ title: option.title,
103
+ hasIcon: option.icon,
104
+ optionLabel: option.label,
105
+ selected: multiple ? value ? Array.isArray(value) && value.includes(option.value) : Array.isArray(selectedValue) && selectedValue.includes(option.value) : value ? option.value === value : option.value === selectedValue
106
+ }, /*#__PURE__*/_react["default"].createElement(_Flex["default"], {
107
+ alignItems: "center"
108
+ }, option.icon && /*#__PURE__*/_react["default"].createElement(IconContainer, {
131
109
  optionLabel: option.label
132
- }), option.label && /*#__PURE__*/_react["default"].createElement(LabelContainer, null, option.label)));
110
+ }, typeof option.icon === "string" ? /*#__PURE__*/_react["default"].createElement(_Icon["default"], {
111
+ icon: option.icon
112
+ }) : option.icon), option.label && /*#__PURE__*/_react["default"].createElement(LabelContainer, null, option.label)));
133
113
  }))));
134
114
  };
135
-
136
- var Label = _styledComponents["default"].label(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: ", ";\n"])), function (props) {
115
+ var ToggleGroup = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n flex-direction: column;\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n"])), function (props) {
116
+ return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
117
+ }, function (props) {
118
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
119
+ }, function (props) {
120
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
121
+ }, function (props) {
122
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
123
+ }, function (props) {
124
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
125
+ });
126
+ var Label = _styledComponents["default"].label(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: ", ";\n"])), function (props) {
137
127
  return props.disabled ? props.theme.disabledLabelFontColor : props.theme.labelFontColor;
138
128
  }, function (props) {
139
129
  return props.theme.labelFontFamily;
@@ -146,8 +136,7 @@ var Label = _styledComponents["default"].label(_templateObject || (_templateObje
146
136
  }, function (props) {
147
137
  return props.theme.labelLineHeight;
148
138
  });
149
-
150
- var HelperText = _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"])), function (props) {
139
+ var HelperText = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: ", ";\n"])), function (props) {
151
140
  return props.disabled ? props.theme.disabledHelperTextFontcolor : props.theme.helperTextFontColor;
152
141
  }, function (props) {
153
142
  return props.theme.helperTextFontFamily;
@@ -160,20 +149,7 @@ var HelperText = _styledComponents["default"].span(_templateObject2 || (_templat
160
149
  }, function (props) {
161
150
  return props.theme.helperTextLineHeight;
162
151
  });
163
-
164
- var ToggleGroup = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n flex-direction: column;\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n"])), function (props) {
165
- return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
166
- }, function (props) {
167
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
168
- }, function (props) {
169
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
170
- }, function (props) {
171
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
172
- }, function (props) {
173
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
174
- });
175
-
176
- var OptionsContainer = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: row;\n opacity: 1;\n height: calc(48px - 4px - 4px);\n border-width: ", ";\n border-style: ", ";\n border-radius: ", ";\n border-color: ", ";\n background-color: ", ";\n padding: 4px;\n margin-top: ", ";\n"])), function (props) {
152
+ var OptionsContainer = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n gap: 0.25rem;\n width: max-content;\n height: calc(48px - 4px - 4px);\n padding: 0.25rem;\n border-width: ", ";\n border-style: ", ";\n border-radius: ", ";\n border-color: ", ";\n margin-top: ", ";\n background-color: ", ";\n"])), function (props) {
177
153
  return props.theme.containerBorderThickness;
178
154
  }, function (props) {
179
155
  return props.theme.containerBorderStyle;
@@ -181,18 +157,36 @@ var OptionsContainer = _styledComponents["default"].div(_templateObject4 || (_te
181
157
  return props.theme.containerBorderRadius;
182
158
  }, function (props) {
183
159
  return props.theme.containerBorderColor;
184
- }, function (props) {
185
- return props.theme.containerBackgroundColor;
186
160
  }, function (props) {
187
161
  return props.theme.containerMarginTop;
162
+ }, function (props) {
163
+ return props.theme.containerBackgroundColor;
188
164
  });
189
-
190
- var ToggleContainer = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n justify-content: center;\n margin-right: ", ";\n\n ", "\n"])), function (props) {
191
- return !props.isLast && "4px";
165
+ var ToggleButton = _styledComponents["default"].button(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n justify-content: center;\n padding-left: ", ";\n padding-right: ", ";\n border-width: ", ";\n border-style: ", ";\n border-radius: ", ";\n background-color: ", ";\n color: ", ";\n cursor: pointer;\n\n &:hover {\n background-color: ", ";\n }\n &:active {\n background-color: ", ";\n color: #ffffff;\n }\n &:focus {\n outline: none;\n box-shadow: ", ";\n }\n &:disabled {\n background-color: ", ";\n color: ", ";\n cursor: not-allowed;\n }\n"])), function (props) {
166
+ return props.optionLabel && props.hasIcon || props.optionLabel && !props.hasIcon ? props.theme.labelPaddingLeft : props.theme.iconPaddingLeft;
167
+ }, function (props) {
168
+ return props.optionLabel && props.hasIcon || props.optionLabel && !props.hasIcon ? props.theme.labelPaddingRight : props.theme.iconPaddingRight;
169
+ }, function (props) {
170
+ return props.theme.optionBorderThickness;
171
+ }, function (props) {
172
+ return props.theme.optionBorderStyle;
173
+ }, function (props) {
174
+ return props.theme.optionBorderRadius;
175
+ }, function (props) {
176
+ return props.selected ? props.theme.selectedBackgroundColor : props.theme.unselectedBackgroundColor;
177
+ }, function (props) {
178
+ return props.selected ? props.theme.selectedFontColor : props.theme.unselectedFontColor;
179
+ }, function (props) {
180
+ return props.selected ? props.theme.selectedHoverBackgroundColor : props.theme.unselectedHoverBackgroundColor;
192
181
  }, function (props) {
193
- return "\n background-color: ".concat(props.selected ? props.disabled ? props.theme.selectedDisabledBackgroundColor : props.theme.selectedBackgroundColor : props.disabled ? props.theme.unselectedDisabledBackgroundColor : props.theme.unselectedBackgroundColor, ";\n border-width: ").concat(props.theme.optionBorderThickness, ";\n border-style: ").concat(props.theme.optionBorderStyle, ";\n border-radius: ").concat(props.theme.optionBorderRadius, ";\n padding-left: ").concat(props.optionLabel && props.isIcon || props.optionLabel && !props.isIcon ? props.theme.labelPaddingLeft : props.theme.iconPaddingLeft, ";\n padding-right: ").concat(props.optionLabel && props.isIcon || props.optionLabel && !props.isIcon ? props.theme.labelPaddingRight : props.theme.iconPaddingRight, ";\n ").concat(!props.disabled ? ":hover {\n background-color: ".concat(props.selected ? props.theme.selectedHoverBackgroundColor : props.theme.unselectedHoverBackgroundColor, ";\n }\n :active {\n background-color: ").concat(props.selected ? props.theme.selectedActiveBackgroundColor : props.theme.unselectedActiveBackgroundColor, ";\n color: #ffffff;\n } \n :focus {\n border-color: transparent;\n box-shadow: 0 0 0 ").concat(props.theme.optionFocusBorderThickness, " ").concat(props.backgroundType === "dark" ? props.theme.focusColorOnDark : props.theme.focusColor, ";\n }\n &:focus-visible {\n outline: none;\n }\n cursor: pointer;\n color: ").concat(props.selected ? props.theme.selectedFontColor : props.theme.unselectedFontColor, ";\n") : "color: ".concat(props.selected ? props.theme.selectedDisabledFontColor : props.theme.unselectedDisabledFontColor, ";\n cursor: not-allowed;"), "\n ");
182
+ return props.selected ? props.theme.selectedActiveBackgroundColor : props.theme.unselectedActiveBackgroundColor;
183
+ }, function (props) {
184
+ return "0 0 0 ".concat(props.theme.optionFocusBorderThickness, " ").concat(props.theme.focusColor);
185
+ }, function (props) {
186
+ return props.selected ? props.theme.selectedDisabledBackgroundColor : props.theme.unselectedDisabledBackgroundColor;
187
+ }, function (props) {
188
+ return props.selected ? props.theme.selectedDisabledFontColor : props.theme.unselectedDisabledFontColor;
194
189
  });
195
-
196
190
  var LabelContainer = _styledComponents["default"].span(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n"])), function (props) {
197
191
  return props.theme.optionLabelFontFamily;
198
192
  }, function (props) {
@@ -202,16 +196,7 @@ var LabelContainer = _styledComponents["default"].span(_templateObject6 || (_tem
202
196
  }, function (props) {
203
197
  return props.theme.optionLabelFontWeight;
204
198
  });
205
-
206
- var OptionContent = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: row;\n"])));
207
-
208
- var Icon = _styledComponents["default"].img(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n height: 24px;\n width: 24px;\n margin-right: ", ";\n"])), function (props) {
209
- return props.optionLabel && props.theme.iconMarginRight;
210
- });
211
-
212
- var IconContainer = _styledComponents["default"].div(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: ", ";\n height: 24px;\n width: 24px;\n overflow: hidden;\n display: flex;\n img,\n svg {\n height: 100%;\n width: 100%;\n }\n"])), function (props) {
199
+ var IconContainer = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n margin-right: ", ";\n overflow: hidden;\n font-size: 24px;\n svg {\n height: 24px;\n width: 24px;\n }\n"])), function (props) {
213
200
  return props.optionLabel && props.theme.iconMarginRight;
214
201
  });
215
-
216
- var _default = DxcToggleGroup;
217
- exports["default"] = _default;
202
+ var _default = exports["default"] = DxcToggleGroup;
@@ -3,42 +3,38 @@ import { userEvent, within } from "@storybook/testing-library";
3
3
  import DxcToggleGroup from "./ToggleGroup";
4
4
  import Title from "../../.storybook/components/Title";
5
5
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
+ import { HalstackProvider } from "../HalstackContext";
6
7
 
7
8
  export default {
8
- title: "ToggleGroup",
9
+ title: "Toggle Group",
9
10
  component: DxcToggleGroup,
10
11
  };
11
12
 
12
- const ethernetSVG = () => {
13
- return (
14
- <svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">
15
- <path d="M0 0h24v24H0V0z" fill="none" />
16
- <path d="M7.77 6.76L6.23 5.48.82 12l5.41 6.52 1.54-1.28L3.42 12l4.35-5.24zM7 13h2v-2H7v2zm10-2h-2v2h2v-2zm-6 2h2v-2h-2v2zm6.77-7.52l-1.54 1.28L20.58 12l-4.35 5.24 1.54 1.28L23.18 12l-5.41-6.52z" />
17
- </svg>
18
- );
19
- };
20
- const gMobileSVG = () => {
21
- return (
22
- <svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">
23
- <g>
24
- <path d="M0,0h24v24H0V0z" fill="none" />
25
- </g>
13
+ const ethernetSVG = (
14
+ <svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">
15
+ <path d="M0 0h24v24H0V0z" fill="none" />
16
+ <path d="M7.77 6.76L6.23 5.48.82 12l5.41 6.52 1.54-1.28L3.42 12l4.35-5.24zM7 13h2v-2H7v2zm10-2h-2v2h2v-2zm-6 2h2v-2h-2v2zm6.77-7.52l-1.54 1.28L20.58 12l-4.35 5.24 1.54 1.28L23.18 12l-5.41-6.52z" />
17
+ </svg>
18
+ );
19
+ const gMobileSVG = (
20
+ <svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">
21
+ <g>
22
+ <path d="M0,0h24v24H0V0z" fill="none" />
23
+ </g>
24
+ <g>
26
25
  <g>
27
- <g>
28
- <path d="M3,7v2h5v2H4v2h4v2H3v2h5c1.1,0,2-0.9,2-2v-1.5c0-0.83-0.67-1.5-1.5-1.5c0.83,0,1.5-0.67,1.5-1.5V9c0-1.1-0.9-2-2-2H3z M21,11v4c0,1.1-0.9,2-2,2h-5c-1.1,0-2-0.9-2-2V9c0-1.1,0.9-2,2-2h5c1.1,0,2,0.9,2,2h-7v6h5v-2h-2.5v-2H21z" />
29
- </g>
26
+ <path d="M3,7v2h5v2H4v2h4v2H3v2h5c1.1,0,2-0.9,2-2v-1.5c0-0.83-0.67-1.5-1.5-1.5c0.83,0,1.5-0.67,1.5-1.5V9c0-1.1-0.9-2-2-2H3z M21,11v4c0,1.1-0.9,2-2,2h-5c-1.1,0-2-0.9-2-2V9c0-1.1,0.9-2,2-2h5c1.1,0,2,0.9,2,2h-7v6h5v-2h-2.5v-2H21z" />
30
27
  </g>
31
- </svg>
32
- );
33
- };
34
- const wifiSVG = () => {
35
- return (
36
- <svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">
37
- <path d="M0 0h24v24H0V0zm0 0h24v24H0V0z" fill="none" />
38
- <path d="M1 9l2 2c4.97-4.97 13.03-4.97 18 0l2-2C16.93 2.93 7.08 2.93 1 9zm8 8l3 3 3-3c-1.65-1.66-4.34-1.66-6 0zm-4-4l2 2c2.76-2.76 7.24-2.76 10 0l2-2C15.14 9.14 8.87 9.14 5 13z" />
39
- </svg>
40
- );
41
- };
28
+ </g>
29
+ </svg>
30
+ );
31
+ const wifiSVG = (
32
+ <svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">
33
+ <path d="M0 0h24v24H0V0zm0 0h24v24H0V0z" fill="none" />
34
+ <path d="M1 9l2 2c4.97-4.97 13.03-4.97 18 0l2-2C16.93 2.93 7.08 2.93 1 9zm8 8l3 3 3-3c-1.65-1.66-4.34-1.66-6 0zm-4-4l2 2c2.76-2.76 7.24-2.76 10 0l2-2C15.14 9.14 8.87 9.14 5 13z" />
35
+ </svg>
36
+ );
37
+
42
38
  const options = [
43
39
  {
44
40
  value: 1,
@@ -46,7 +42,7 @@ const options = [
46
42
  },
47
43
  {
48
44
  value: 2,
49
- label: "Twitter",
45
+ label: "X",
50
46
  },
51
47
  {
52
48
  value: 3,
@@ -56,15 +52,18 @@ const options = [
56
52
  const optionsWithIcon = [
57
53
  {
58
54
  value: 1,
59
- icon: wifiSVG,
55
+ icon: "wifi",
56
+ title: "WiFi connection",
60
57
  },
61
58
  {
62
59
  value: 2,
63
- icon: ethernetSVG,
60
+ icon: "filled_lan",
61
+ title: "Ethernet connection",
64
62
  },
65
63
  {
66
64
  value: 3,
67
- icon: gMobileSVG,
65
+ icon: "5g",
66
+ title: "3G Mobile data connection",
68
67
  },
69
68
  ];
70
69
  const optionsWithIconAndLabel = [
@@ -91,9 +90,19 @@ const twoOptions = [
91
90
  },
92
91
  {
93
92
  value: 2,
94
- label: "Twitter",
93
+ label: "X",
95
94
  },
96
95
  ];
96
+
97
+ const opinionatedTheme = {
98
+ toggleGroup: {
99
+ selectedBaseColor: "#5f249f",
100
+ selectedFontColor: "#ffffff",
101
+ unselectedBaseColor: "#e6e6e6",
102
+ unselectedFontColor: "#000000",
103
+ },
104
+ };
105
+
97
106
  export const Chromatic = () => (
98
107
  <>
99
108
  <ExampleContainer>
@@ -102,7 +111,7 @@ export const Chromatic = () => (
102
111
  </ExampleContainer>
103
112
  <ExampleContainer>
104
113
  <Title title="Selected" theme="light" level={4} />
105
- <DxcToggleGroup label="Selected" helperText="HelperText" value={2} options={options} />
114
+ <DxcToggleGroup label="Selected" helperText="HelperText" defaultValue={2} options={options} />
106
115
  </ExampleContainer>
107
116
  <ExampleContainer>
108
117
  <Title title="Icons toggle group" theme="light" level={4} />
@@ -114,11 +123,11 @@ export const Chromatic = () => (
114
123
  </ExampleContainer>
115
124
  <ExampleContainer>
116
125
  <Title title="Disabled" theme="light" level={4} />
117
- <DxcToggleGroup label="Disabled" value={2} options={options} disabled />
126
+ <DxcToggleGroup label="Disabled" defaultValue={2} options={options} disabled />
118
127
  </ExampleContainer>
119
128
  <ExampleContainer pseudoState="pseudo-hover">
120
129
  <Title title="Hovered" theme="light" level={4} />
121
- <DxcToggleGroup label="Hovered" options={twoOptions} value={2} />
130
+ <DxcToggleGroup label="Hovered" options={twoOptions} defaultValue={2} />
122
131
  </ExampleContainer>
123
132
  <ExampleContainer>
124
133
  <Title title="Multiple toggleGroup" theme="light" level={4} />
@@ -126,7 +135,7 @@ export const Chromatic = () => (
126
135
  label="Toggle group"
127
136
  helperText="Please select one or more"
128
137
  options={options}
129
- value={[1, 3]}
138
+ defaultValue={[1, 3]}
130
139
  multiple
131
140
  ></DxcToggleGroup>
132
141
  </ExampleContainer>
@@ -159,6 +168,37 @@ export const Chromatic = () => (
159
168
  <Title title="xxLarge" theme="light" level={4} />
160
169
  <DxcToggleGroup label="xxLarge margin" options={options} margin="xxlarge" />
161
170
  </ExampleContainer>
171
+ <Title title="Opinionated theme" theme="light" level={2} />
172
+ <ExampleContainer>
173
+ <HalstackProvider theme={opinionatedTheme}>
174
+ <Title title="Selected" theme="light" level={4} />
175
+ <DxcToggleGroup label="Selected" helperText="HelperText" defaultValue={2} options={options} />
176
+ </HalstackProvider>
177
+ </ExampleContainer>
178
+ <ExampleContainer>
179
+ <HalstackProvider theme={opinionatedTheme}>
180
+ <Title title="Icons & label toggle group" theme="light" level={4} />
181
+ <DxcToggleGroup label="Icons & label" options={optionsWithIconAndLabel} />
182
+ </HalstackProvider>
183
+ </ExampleContainer>
184
+ <ExampleContainer>
185
+ <HalstackProvider theme={opinionatedTheme}>
186
+ <Title title="Disabled" theme="light" level={4} />
187
+ <DxcToggleGroup label="Disabled" defaultValue={2} options={options} disabled />
188
+ </HalstackProvider>
189
+ </ExampleContainer>
190
+ <ExampleContainer pseudoState="pseudo-hover">
191
+ <Title title="Hovered" theme="light" level={4} />
192
+ <HalstackProvider theme={opinionatedTheme}>
193
+ <DxcToggleGroup label="Hovered" options={twoOptions} defaultValue={2} />
194
+ </HalstackProvider>
195
+ </ExampleContainer>
196
+ <ExampleContainer pseudoState="pseudo-active">
197
+ <Title title="Actived" theme="light" level={4} />
198
+ <HalstackProvider theme={opinionatedTheme}>
199
+ <DxcToggleGroup label="Actived" options={twoOptions} defaultValue={2} />
200
+ </HalstackProvider>
201
+ </ExampleContainer>
162
202
  </>
163
203
  );
164
204
  const OptionSelected = () => <DxcToggleGroup label="Toggle group" helperText="HelperText" options={options} />;
@@ -172,7 +212,7 @@ ToggleGroupSelectedActived.play = async ({ canvasElement }) => {
172
212
  export const ToggleGroupUnselectedActived = OptionSelected.bind({});
173
213
  ToggleGroupUnselectedActived.play = async ({ canvasElement }) => {
174
214
  const canvas = within(canvasElement);
175
- const option = canvas.getByText("Twitter");
215
+ const option = canvas.getByText("X");
176
216
  await userEvent.click(option);
177
217
  userEvent.tab();
178
218
  };
@@ -0,0 +1,137 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _react = _interopRequireDefault(require("react"));
5
+ var _react2 = require("@testing-library/react");
6
+ var _ToggleGroup = _interopRequireDefault(require("./ToggleGroup.tsx"));
7
+ var options = [{
8
+ value: 1,
9
+ label: "Amazon"
10
+ }, {
11
+ value: 2,
12
+ label: "Ebay"
13
+ }, {
14
+ value: 3,
15
+ label: "Apple"
16
+ }, {
17
+ value: 4,
18
+ label: "Google"
19
+ }];
20
+ describe("Toggle group component tests", function () {
21
+ test("Toggle group renders with correct labels", function () {
22
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ToggleGroup["default"], {
23
+ label: "Toggle group label",
24
+ helperText: "Toggle group helper text",
25
+ options: options
26
+ })),
27
+ getByText = _render.getByText;
28
+ expect(getByText("Toggle group label")).toBeTruthy();
29
+ expect(getByText("Toggle group helper text")).toBeTruthy();
30
+ expect(getByText("Amazon")).toBeTruthy();
31
+ expect(getByText("Ebay")).toBeTruthy();
32
+ expect(getByText("Apple")).toBeTruthy();
33
+ expect(getByText("Google")).toBeTruthy();
34
+ });
35
+ test("Toggle group renders with correct aria-label in only-icon scenario", function () {
36
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ToggleGroup["default"], {
37
+ label: "Toggle group label",
38
+ helperText: "Toggle group helper text",
39
+ options: [{
40
+ value: 1,
41
+ icon: "https://cdn.icon-icons.com/icons2/2645/PNG/512/mic_mute_icon_159965.png",
42
+ title: "Mute"
43
+ }]
44
+ })),
45
+ getByRole = _render2.getByRole;
46
+ expect(getByRole("button").getAttribute("aria-label")).toBe("Mute");
47
+ });
48
+ test("Uncontrolled toggle group calls correct function on change with value", function () {
49
+ var onChange = jest.fn();
50
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ToggleGroup["default"], {
51
+ options: options,
52
+ onChange: onChange
53
+ })),
54
+ getByText = _render3.getByText;
55
+ var option = getByText("Ebay");
56
+ _react2.fireEvent.click(option);
57
+ expect(onChange).toHaveBeenCalledWith(2);
58
+ });
59
+ test("Controlled toggle group calls correct function on change with value", function () {
60
+ var onChange = jest.fn();
61
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ToggleGroup["default"], {
62
+ options: options,
63
+ onChange: onChange,
64
+ value: 1
65
+ })),
66
+ getByText = _render4.getByText;
67
+ var option = getByText("Ebay");
68
+ _react2.fireEvent.click(option);
69
+ expect(onChange).toHaveBeenCalledWith(2);
70
+ });
71
+ test("Function on change is not called when disable", function () {
72
+ var onChange = jest.fn();
73
+ var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ToggleGroup["default"], {
74
+ options: options,
75
+ onChange: onChange,
76
+ disabled: true
77
+ })),
78
+ getByText = _render5.getByText;
79
+ var option = getByText("Ebay");
80
+ _react2.fireEvent.click(option);
81
+ expect(onChange).toHaveBeenCalledTimes(0);
82
+ });
83
+ test("Uncontrolled multiple toggle group calls correct function on change with value when is multiple", function () {
84
+ var onChange = jest.fn();
85
+ var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ToggleGroup["default"], {
86
+ options: options,
87
+ onChange: onChange,
88
+ multiple: true
89
+ })),
90
+ getAllByRole = _render6.getAllByRole;
91
+ var toggleOptions = getAllByRole("button");
92
+ _react2.fireEvent.click(toggleOptions[0]);
93
+ expect(onChange).toHaveBeenCalledWith([1]);
94
+ _react2.fireEvent.click(toggleOptions[1]);
95
+ _react2.fireEvent.click(toggleOptions[3]);
96
+ expect(onChange).toHaveBeenCalledWith([1, 2, 4]);
97
+ expect(toggleOptions[0].getAttribute("aria-pressed")).toBe("true");
98
+ expect(toggleOptions[1].getAttribute("aria-pressed")).toBe("true");
99
+ expect(toggleOptions[3].getAttribute("aria-pressed")).toBe("true");
100
+ });
101
+ test("Controlled multiple toggle returns always same values", function () {
102
+ var onChange = jest.fn();
103
+ var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ToggleGroup["default"], {
104
+ options: options,
105
+ onChange: onChange,
106
+ value: [1],
107
+ multiple: true
108
+ })),
109
+ getByText = _render7.getByText;
110
+ var option = getByText("Ebay");
111
+ _react2.fireEvent.click(option);
112
+ expect(onChange).toHaveBeenCalledWith([1, 2]);
113
+ var option2 = getByText("Google");
114
+ _react2.fireEvent.click(option2);
115
+ expect(onChange).toHaveBeenNthCalledWith(2, [1, 4]);
116
+ });
117
+ test("Single selection: Renders with correct default value", function () {
118
+ var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ToggleGroup["default"], {
119
+ options: options,
120
+ defaultValue: 2
121
+ })),
122
+ getAllByRole = _render8.getAllByRole;
123
+ var toggleOptions = getAllByRole("button");
124
+ expect(toggleOptions[1].getAttribute("aria-pressed")).toBe("true");
125
+ });
126
+ test("Multiple selection: Renders with correct default value", function () {
127
+ var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ToggleGroup["default"], {
128
+ options: options,
129
+ defaultValue: [2, 4],
130
+ multiple: true
131
+ })),
132
+ getAllByRole = _render9.getAllByRole;
133
+ var toggleOptions = getAllByRole("button");
134
+ expect(toggleOptions[1].getAttribute("aria-pressed")).toBe("true");
135
+ expect(toggleOptions[3].getAttribute("aria-pressed")).toBe("true");
136
+ });
137
+ });