@dxc-technology/halstack-react 0.0.0-a062293 → 0.0.0-a0fadb7

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 (471) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +5 -22
  3. package/HalstackContext.d.ts +1237 -6
  4. package/HalstackContext.js +123 -111
  5. package/README.md +47 -0
  6. package/accordion/Accordion.accessibility.test.d.ts +1 -0
  7. package/accordion/Accordion.accessibility.test.js +71 -0
  8. package/accordion/Accordion.d.ts +1 -1
  9. package/accordion/Accordion.js +41 -112
  10. package/accordion/Accordion.stories.tsx +52 -157
  11. package/accordion/Accordion.test.d.ts +1 -0
  12. package/accordion/Accordion.test.js +18 -33
  13. package/accordion/types.d.ts +6 -18
  14. package/accordion-group/AccordionGroup.accessibility.test.d.ts +1 -0
  15. package/accordion-group/AccordionGroup.accessibility.test.js +82 -0
  16. package/accordion-group/AccordionGroup.d.ts +2 -2
  17. package/accordion-group/AccordionGroup.js +29 -77
  18. package/accordion-group/AccordionGroup.stories.tsx +78 -77
  19. package/accordion-group/AccordionGroup.test.d.ts +1 -0
  20. package/accordion-group/AccordionGroup.test.js +41 -73
  21. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  22. package/accordion-group/AccordionGroupAccordion.js +31 -0
  23. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  24. package/accordion-group/AccordionGroupContext.js +8 -0
  25. package/accordion-group/types.d.ts +7 -19
  26. package/action-icon/ActionIcon.accessibility.test.d.ts +1 -0
  27. package/action-icon/ActionIcon.accessibility.test.js +63 -0
  28. package/action-icon/ActionIcon.d.ts +4 -0
  29. package/action-icon/ActionIcon.js +48 -0
  30. package/action-icon/ActionIcon.stories.tsx +41 -0
  31. package/action-icon/ActionIcon.test.d.ts +1 -0
  32. package/action-icon/ActionIcon.test.js +64 -0
  33. package/action-icon/types.d.ts +26 -0
  34. package/alert/Alert.accessibility.test.d.ts +1 -0
  35. package/alert/Alert.accessibility.test.js +95 -0
  36. package/alert/Alert.js +36 -126
  37. package/alert/Alert.stories.tsx +28 -0
  38. package/alert/Alert.test.d.ts +1 -0
  39. package/alert/Alert.test.js +28 -45
  40. package/alert/types.d.ts +5 -5
  41. package/badge/Badge.accessibility.test.d.ts +1 -0
  42. package/badge/Badge.accessibility.test.js +129 -0
  43. package/badge/Badge.d.ts +1 -1
  44. package/badge/Badge.js +142 -42
  45. package/badge/Badge.stories.tsx +210 -0
  46. package/badge/Badge.test.d.ts +1 -0
  47. package/badge/Badge.test.js +30 -0
  48. package/badge/types.d.ts +52 -3
  49. package/bleed/Bleed.js +13 -21
  50. package/bleed/Bleed.stories.tsx +1 -0
  51. package/bleed/types.d.ts +2 -2
  52. package/box/Box.accessibility.test.d.ts +1 -0
  53. package/box/Box.accessibility.test.js +33 -0
  54. package/box/Box.d.ts +1 -1
  55. package/box/Box.js +18 -59
  56. package/box/Box.stories.tsx +38 -51
  57. package/box/Box.test.d.ts +1 -0
  58. package/box/Box.test.js +1 -6
  59. package/box/types.d.ts +3 -15
  60. package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
  61. package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
  62. package/breadcrumbs/Breadcrumbs.d.ts +4 -0
  63. package/breadcrumbs/Breadcrumbs.js +79 -0
  64. package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
  65. package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
  66. package/breadcrumbs/Breadcrumbs.test.js +169 -0
  67. package/breadcrumbs/Item.d.ts +4 -0
  68. package/breadcrumbs/Item.js +52 -0
  69. package/breadcrumbs/dropdownTheme.d.ts +53 -0
  70. package/breadcrumbs/dropdownTheme.js +62 -0
  71. package/breadcrumbs/types.d.ts +16 -0
  72. package/bulleted-list/BulletedList.accessibility.test.d.ts +1 -0
  73. package/bulleted-list/BulletedList.accessibility.test.js +119 -0
  74. package/bulleted-list/BulletedList.js +22 -53
  75. package/bulleted-list/BulletedList.stories.tsx +8 -93
  76. package/bulleted-list/types.d.ts +32 -5
  77. package/button/Button.accessibility.test.d.ts +1 -0
  78. package/button/Button.accessibility.test.js +127 -0
  79. package/button/Button.d.ts +1 -1
  80. package/button/Button.js +70 -103
  81. package/button/Button.stories.tsx +107 -116
  82. package/button/Button.test.d.ts +1 -0
  83. package/button/Button.test.js +19 -16
  84. package/button/types.d.ts +9 -5
  85. package/card/Card.accessibility.test.d.ts +1 -0
  86. package/card/Card.accessibility.test.js +36 -0
  87. package/card/Card.d.ts +1 -1
  88. package/card/Card.js +49 -89
  89. package/card/Card.stories.tsx +12 -42
  90. package/card/Card.test.d.ts +1 -0
  91. package/card/Card.test.js +10 -21
  92. package/card/types.d.ts +6 -12
  93. package/checkbox/Checkbox.accessibility.test.d.ts +1 -0
  94. package/checkbox/Checkbox.accessibility.test.js +87 -0
  95. package/checkbox/Checkbox.js +90 -128
  96. package/checkbox/Checkbox.stories.tsx +68 -54
  97. package/checkbox/Checkbox.test.d.ts +1 -0
  98. package/checkbox/Checkbox.test.js +107 -63
  99. package/checkbox/types.d.ts +8 -4
  100. package/chip/Chip.accessibility.test.d.ts +1 -0
  101. package/chip/Chip.accessibility.test.js +69 -0
  102. package/chip/Chip.js +42 -76
  103. package/chip/Chip.stories.tsx +120 -40
  104. package/chip/Chip.test.d.ts +1 -0
  105. package/chip/Chip.test.js +17 -32
  106. package/chip/types.d.ts +38 -15
  107. package/common/coreTokens.d.ts +237 -0
  108. package/common/coreTokens.js +184 -0
  109. package/common/fonts.css +2 -0
  110. package/common/utils.d.ts +1 -0
  111. package/common/utils.js +6 -12
  112. package/common/variables.d.ts +1389 -0
  113. package/common/variables.js +957 -1208
  114. package/container/Container.d.ts +4 -0
  115. package/container/Container.js +194 -0
  116. package/container/Container.stories.tsx +214 -0
  117. package/container/types.d.ts +74 -0
  118. package/contextual-menu/ContextualMenu.accessibility.test.d.ts +1 -0
  119. package/contextual-menu/ContextualMenu.accessibility.test.js +98 -0
  120. package/contextual-menu/ContextualMenu.d.ts +5 -0
  121. package/contextual-menu/ContextualMenu.js +88 -0
  122. package/contextual-menu/ContextualMenu.stories.tsx +232 -0
  123. package/contextual-menu/ContextualMenu.test.d.ts +1 -0
  124. package/contextual-menu/ContextualMenu.test.js +205 -0
  125. package/contextual-menu/GroupItem.d.ts +4 -0
  126. package/contextual-menu/GroupItem.js +67 -0
  127. package/contextual-menu/ItemAction.d.ts +4 -0
  128. package/contextual-menu/ItemAction.js +51 -0
  129. package/contextual-menu/MenuItem.d.ts +4 -0
  130. package/contextual-menu/MenuItem.js +29 -0
  131. package/contextual-menu/SingleItem.d.ts +4 -0
  132. package/contextual-menu/SingleItem.js +38 -0
  133. package/contextual-menu/types.d.ts +58 -0
  134. package/contextual-menu/types.js +5 -0
  135. package/date-input/Calendar.js +38 -70
  136. package/date-input/DateInput.accessibility.test.d.ts +1 -0
  137. package/date-input/DateInput.accessibility.test.js +230 -0
  138. package/date-input/DateInput.js +61 -108
  139. package/date-input/DateInput.stories.tsx +86 -31
  140. package/date-input/DateInput.test.d.ts +1 -0
  141. package/date-input/DateInput.test.js +676 -702
  142. package/date-input/DatePicker.js +46 -57
  143. package/date-input/YearPicker.js +28 -44
  144. package/date-input/types.d.ts +28 -22
  145. package/dialog/Dialog.accessibility.test.d.ts +1 -0
  146. package/dialog/Dialog.accessibility.test.js +69 -0
  147. package/dialog/Dialog.d.ts +1 -1
  148. package/dialog/Dialog.js +51 -120
  149. package/dialog/Dialog.stories.tsx +315 -212
  150. package/dialog/Dialog.test.d.ts +1 -0
  151. package/dialog/Dialog.test.js +333 -32
  152. package/dialog/types.d.ts +18 -26
  153. package/divider/Divider.accessibility.test.d.ts +1 -0
  154. package/divider/Divider.accessibility.test.js +33 -0
  155. package/divider/Divider.d.ts +4 -0
  156. package/divider/Divider.js +36 -0
  157. package/divider/Divider.stories.tsx +223 -0
  158. package/divider/Divider.test.d.ts +1 -0
  159. package/divider/Divider.test.js +38 -0
  160. package/divider/types.d.ts +21 -0
  161. package/divider/types.js +5 -0
  162. package/dropdown/Dropdown.accessibility.test.d.ts +1 -0
  163. package/dropdown/Dropdown.accessibility.test.js +184 -0
  164. package/dropdown/Dropdown.js +69 -138
  165. package/dropdown/Dropdown.stories.tsx +205 -98
  166. package/dropdown/Dropdown.test.d.ts +1 -0
  167. package/dropdown/Dropdown.test.js +434 -390
  168. package/dropdown/DropdownMenu.js +23 -40
  169. package/dropdown/DropdownMenuItem.js +17 -38
  170. package/dropdown/types.d.ts +20 -24
  171. package/file-input/FileInput.accessibility.test.d.ts +1 -0
  172. package/file-input/FileInput.accessibility.test.js +167 -0
  173. package/file-input/FileInput.js +183 -294
  174. package/file-input/FileInput.stories.tsx +86 -3
  175. package/file-input/FileInput.test.d.ts +1 -0
  176. package/file-input/FileInput.test.js +301 -395
  177. package/file-input/FileItem.js +31 -67
  178. package/file-input/types.d.ts +10 -10
  179. package/flex/Flex.js +27 -39
  180. package/flex/Flex.stories.tsx +35 -26
  181. package/flex/types.d.ts +74 -9
  182. package/footer/Footer.accessibility.test.d.ts +1 -0
  183. package/footer/Footer.accessibility.test.js +125 -0
  184. package/footer/Footer.d.ts +1 -1
  185. package/footer/Footer.js +73 -118
  186. package/footer/Footer.stories.tsx +94 -23
  187. package/footer/Footer.test.d.ts +1 -0
  188. package/footer/Footer.test.js +32 -56
  189. package/footer/Icons.d.ts +3 -2
  190. package/footer/Icons.js +53 -22
  191. package/footer/types.d.ts +26 -28
  192. package/grid/Grid.d.ts +7 -0
  193. package/grid/Grid.js +76 -0
  194. package/grid/Grid.stories.tsx +219 -0
  195. package/grid/types.d.ts +115 -0
  196. package/grid/types.js +5 -0
  197. package/header/Header.accessibility.test.d.ts +1 -0
  198. package/header/Header.accessibility.test.js +94 -0
  199. package/header/Header.d.ts +4 -3
  200. package/header/Header.js +55 -150
  201. package/header/Header.stories.tsx +130 -35
  202. package/header/Header.test.d.ts +1 -0
  203. package/header/Header.test.js +12 -25
  204. package/header/Icons.d.ts +2 -2
  205. package/header/Icons.js +3 -13
  206. package/header/types.d.ts +7 -22
  207. package/heading/Heading.accessibility.test.d.ts +1 -0
  208. package/heading/Heading.accessibility.test.js +33 -0
  209. package/heading/Heading.js +10 -32
  210. package/heading/Heading.test.d.ts +1 -0
  211. package/heading/Heading.test.js +64 -94
  212. package/heading/types.d.ts +7 -7
  213. package/icon/Icon.accessibility.test.d.ts +1 -0
  214. package/icon/Icon.accessibility.test.js +30 -0
  215. package/icon/Icon.d.ts +4 -0
  216. package/icon/Icon.js +33 -0
  217. package/icon/Icon.stories.tsx +28 -0
  218. package/icon/types.d.ts +4 -0
  219. package/icon/types.js +5 -0
  220. package/image/Image.accessibility.test.d.ts +1 -0
  221. package/image/Image.accessibility.test.js +56 -0
  222. package/image/Image.d.ts +4 -0
  223. package/image/Image.js +70 -0
  224. package/image/Image.stories.tsx +129 -0
  225. package/image/types.d.ts +72 -0
  226. package/image/types.js +5 -0
  227. package/inset/Inset.js +13 -21
  228. package/inset/Inset.stories.tsx +2 -1
  229. package/inset/types.d.ts +2 -2
  230. package/layout/ApplicationLayout.d.ts +5 -5
  231. package/layout/ApplicationLayout.js +36 -70
  232. package/layout/ApplicationLayout.stories.tsx +1 -1
  233. package/layout/Icons.d.ts +7 -5
  234. package/layout/Icons.js +41 -59
  235. package/layout/types.d.ts +5 -6
  236. package/link/Link.accessibility.test.d.ts +1 -0
  237. package/link/Link.accessibility.test.js +108 -0
  238. package/link/Link.js +31 -50
  239. package/link/Link.stories.tsx +64 -4
  240. package/link/Link.test.d.ts +1 -0
  241. package/link/Link.test.js +23 -43
  242. package/link/types.d.ts +14 -14
  243. package/main.d.ts +12 -5
  244. package/main.js +55 -59
  245. package/nav-tabs/NavTabs.accessibility.test.d.ts +1 -0
  246. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  247. package/nav-tabs/NavTabs.d.ts +7 -0
  248. package/nav-tabs/NavTabs.js +108 -0
  249. package/nav-tabs/NavTabs.stories.tsx +294 -0
  250. package/nav-tabs/NavTabs.test.d.ts +1 -0
  251. package/nav-tabs/NavTabs.test.js +77 -0
  252. package/nav-tabs/NavTabsContext.d.ts +3 -0
  253. package/nav-tabs/NavTabsContext.js +8 -0
  254. package/nav-tabs/Tab.js +117 -0
  255. package/{tabs-nav → nav-tabs}/types.d.ts +15 -16
  256. package/nav-tabs/types.js +5 -0
  257. package/number-input/NumberInput.accessibility.test.d.ts +1 -0
  258. package/number-input/NumberInput.accessibility.test.js +228 -0
  259. package/number-input/NumberInput.js +46 -36
  260. package/number-input/NumberInput.stories.tsx +42 -26
  261. package/number-input/NumberInput.test.d.ts +1 -0
  262. package/number-input/NumberInput.test.js +859 -412
  263. package/number-input/NumberInputContext.d.ts +3 -4
  264. package/number-input/NumberInputContext.js +3 -14
  265. package/number-input/types.d.ts +17 -5
  266. package/package.json +45 -41
  267. package/paginator/Paginator.accessibility.test.d.ts +1 -0
  268. package/paginator/Paginator.accessibility.test.js +79 -0
  269. package/paginator/Paginator.js +29 -56
  270. package/paginator/Paginator.stories.tsx +24 -0
  271. package/paginator/Paginator.test.d.ts +1 -0
  272. package/paginator/Paginator.test.js +234 -214
  273. package/paginator/types.d.ts +3 -3
  274. package/paragraph/Paragraph.accessibility.test.d.ts +1 -0
  275. package/paragraph/Paragraph.accessibility.test.js +28 -0
  276. package/paragraph/Paragraph.d.ts +3 -4
  277. package/paragraph/Paragraph.js +6 -22
  278. package/paragraph/Paragraph.stories.tsx +0 -17
  279. package/password-input/PasswordInput.accessibility.test.d.ts +1 -0
  280. package/password-input/PasswordInput.accessibility.test.js +153 -0
  281. package/password-input/PasswordInput.js +58 -127
  282. package/password-input/PasswordInput.stories.tsx +1 -33
  283. package/password-input/PasswordInput.test.d.ts +1 -0
  284. package/password-input/PasswordInput.test.js +157 -140
  285. package/password-input/types.d.ts +8 -7
  286. package/progress-bar/ProgressBar.accessibility.test.d.ts +1 -0
  287. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  288. package/progress-bar/ProgressBar.d.ts +2 -2
  289. package/progress-bar/ProgressBar.js +28 -58
  290. package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +36 -3
  291. package/progress-bar/ProgressBar.test.d.ts +1 -0
  292. package/progress-bar/ProgressBar.test.js +35 -52
  293. package/progress-bar/types.d.ts +4 -3
  294. package/quick-nav/QuickNav.accessibility.test.d.ts +1 -0
  295. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  296. package/quick-nav/QuickNav.js +4 -27
  297. package/quick-nav/QuickNav.stories.tsx +15 -1
  298. package/quick-nav/types.d.ts +10 -10
  299. package/radio-group/Radio.d.ts +1 -1
  300. package/radio-group/Radio.js +31 -66
  301. package/radio-group/RadioGroup.accessibility.test.d.ts +1 -0
  302. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  303. package/radio-group/RadioGroup.js +48 -98
  304. package/radio-group/RadioGroup.stories.tsx +131 -18
  305. package/radio-group/RadioGroup.test.d.ts +1 -0
  306. package/radio-group/RadioGroup.test.js +506 -474
  307. package/radio-group/types.d.ts +8 -8
  308. package/resultset-table/Icons.d.ts +7 -0
  309. package/{resultsetTable → resultset-table}/Icons.js +1 -5
  310. package/resultset-table/ResultsetTable.accessibility.test.d.ts +1 -0
  311. package/resultset-table/ResultsetTable.accessibility.test.js +285 -0
  312. package/resultset-table/ResultsetTable.d.ts +7 -0
  313. package/{resultsetTable → resultset-table}/ResultsetTable.js +47 -71
  314. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +118 -5
  315. package/resultset-table/ResultsetTable.test.d.ts +1 -0
  316. package/{resultsetTable → resultset-table}/ResultsetTable.test.js +147 -92
  317. package/{resultsetTable → resultset-table}/types.d.ts +44 -11
  318. package/resultset-table/types.js +5 -0
  319. package/select/Listbox.js +36 -54
  320. package/select/Option.js +28 -36
  321. package/select/Select.accessibility.test.d.ts +1 -0
  322. package/select/Select.accessibility.test.js +228 -0
  323. package/select/Select.js +118 -182
  324. package/select/Select.stories.tsx +504 -255
  325. package/select/Select.test.d.ts +1 -0
  326. package/select/Select.test.js +1903 -1863
  327. package/select/types.d.ts +15 -16
  328. package/sidenav/Sidenav.accessibility.test.d.ts +1 -0
  329. package/sidenav/Sidenav.accessibility.test.js +59 -0
  330. package/sidenav/Sidenav.d.ts +2 -2
  331. package/sidenav/Sidenav.js +90 -155
  332. package/sidenav/Sidenav.stories.tsx +113 -25
  333. package/sidenav/Sidenav.test.d.ts +1 -0
  334. package/sidenav/Sidenav.test.js +4 -11
  335. package/{layout → sidenav}/SidenavContext.d.ts +1 -1
  336. package/{layout → sidenav}/SidenavContext.js +3 -9
  337. package/sidenav/types.d.ts +33 -30
  338. package/slider/Slider.accessibility.test.d.ts +1 -0
  339. package/slider/Slider.accessibility.test.js +104 -0
  340. package/slider/Slider.js +68 -128
  341. package/slider/Slider.stories.tsx +57 -60
  342. package/slider/Slider.test.d.ts +1 -0
  343. package/slider/Slider.test.js +118 -111
  344. package/slider/types.d.ts +4 -4
  345. package/spinner/Spinner.accessibility.test.d.ts +1 -0
  346. package/spinner/Spinner.accessibility.test.js +96 -0
  347. package/spinner/Spinner.js +32 -72
  348. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
  349. package/spinner/Spinner.test.d.ts +1 -0
  350. package/spinner/Spinner.test.js +25 -34
  351. package/spinner/types.d.ts +3 -3
  352. package/status-light/StatusLight.accessibility.test.d.ts +1 -0
  353. package/status-light/StatusLight.accessibility.test.js +157 -0
  354. package/status-light/StatusLight.d.ts +4 -0
  355. package/status-light/StatusLight.js +51 -0
  356. package/status-light/StatusLight.stories.tsx +74 -0
  357. package/status-light/StatusLight.test.d.ts +1 -0
  358. package/status-light/StatusLight.test.js +25 -0
  359. package/status-light/types.d.ts +17 -0
  360. package/status-light/types.js +5 -0
  361. package/switch/Switch.accessibility.test.d.ts +1 -0
  362. package/switch/Switch.accessibility.test.js +98 -0
  363. package/switch/Switch.js +51 -102
  364. package/switch/Switch.stories.tsx +45 -34
  365. package/switch/Switch.test.d.ts +1 -0
  366. package/switch/Switch.test.js +51 -96
  367. package/switch/types.d.ts +4 -4
  368. package/table/DropdownTheme.js +62 -0
  369. package/table/Table.accessibility.test.d.ts +1 -0
  370. package/table/Table.accessibility.test.js +93 -0
  371. package/table/Table.d.ts +6 -2
  372. package/table/Table.js +78 -35
  373. package/table/Table.stories.tsx +663 -0
  374. package/table/Table.test.d.ts +1 -0
  375. package/table/Table.test.js +92 -6
  376. package/table/types.d.ts +34 -6
  377. package/tabs/Tab.js +27 -43
  378. package/tabs/Tabs.accessibility.test.d.ts +1 -0
  379. package/tabs/Tabs.accessibility.test.js +56 -0
  380. package/tabs/Tabs.js +69 -163
  381. package/tabs/Tabs.stories.tsx +46 -4
  382. package/tabs/Tabs.test.d.ts +1 -0
  383. package/tabs/Tabs.test.js +60 -135
  384. package/tabs/types.d.ts +21 -21
  385. package/tag/Tag.accessibility.test.d.ts +1 -0
  386. package/tag/Tag.accessibility.test.js +69 -0
  387. package/tag/Tag.js +34 -66
  388. package/tag/Tag.stories.tsx +18 -8
  389. package/tag/Tag.test.d.ts +1 -0
  390. package/tag/Tag.test.js +17 -36
  391. package/tag/types.d.ts +9 -9
  392. package/text-input/Suggestion.js +11 -28
  393. package/text-input/Suggestions.d.ts +1 -1
  394. package/text-input/Suggestions.js +30 -70
  395. package/text-input/TextInput.accessibility.test.d.ts +1 -0
  396. package/text-input/TextInput.accessibility.test.js +321 -0
  397. package/text-input/TextInput.js +224 -328
  398. package/text-input/TextInput.stories.tsx +133 -160
  399. package/text-input/TextInput.test.d.ts +1 -0
  400. package/text-input/TextInput.test.js +1227 -1195
  401. package/text-input/types.d.ts +25 -17
  402. package/textarea/Textarea.accessibility.test.d.ts +1 -0
  403. package/textarea/Textarea.accessibility.test.js +155 -0
  404. package/textarea/Textarea.js +70 -115
  405. package/textarea/Textarea.stories.tsx +174 -0
  406. package/textarea/Textarea.test.d.ts +1 -0
  407. package/textarea/Textarea.test.js +151 -182
  408. package/textarea/types.d.ts +9 -5
  409. package/toggle-group/ToggleGroup.accessibility.test.d.ts +1 -0
  410. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  411. package/toggle-group/ToggleGroup.d.ts +2 -2
  412. package/toggle-group/ToggleGroup.js +92 -108
  413. package/toggle-group/ToggleGroup.stories.tsx +52 -7
  414. package/toggle-group/ToggleGroup.test.d.ts +1 -0
  415. package/toggle-group/ToggleGroup.test.js +68 -87
  416. package/toggle-group/types.d.ts +28 -19
  417. package/typography/Typography.accessibility.test.d.ts +1 -0
  418. package/typography/Typography.accessibility.test.js +339 -0
  419. package/typography/Typography.d.ts +2 -2
  420. package/typography/Typography.js +15 -123
  421. package/typography/Typography.stories.tsx +1 -1
  422. package/typography/types.d.ts +1 -1
  423. package/useTheme.d.ts +1141 -1
  424. package/useTheme.js +2 -9
  425. package/useTranslatedLabels.d.ts +84 -1
  426. package/useTranslatedLabels.js +1 -7
  427. package/utils/BaseTypography.d.ts +21 -0
  428. package/utils/BaseTypography.js +94 -0
  429. package/utils/FocusLock.d.ts +13 -0
  430. package/utils/FocusLock.js +124 -0
  431. package/wizard/Wizard.accessibility.test.d.ts +1 -0
  432. package/wizard/Wizard.accessibility.test.js +55 -0
  433. package/wizard/Wizard.js +29 -75
  434. package/wizard/Wizard.stories.tsx +39 -0
  435. package/wizard/Wizard.test.d.ts +1 -0
  436. package/wizard/Wizard.test.js +53 -80
  437. package/wizard/types.d.ts +10 -11
  438. package/card/ice-cream.jpg +0 -0
  439. package/common/OpenSans.css +0 -81
  440. package/common/fonts/OpenSans-Bold.ttf +0 -0
  441. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  442. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  443. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  444. package/common/fonts/OpenSans-Italic.ttf +0 -0
  445. package/common/fonts/OpenSans-Light.ttf +0 -0
  446. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  447. package/common/fonts/OpenSans-Regular.ttf +0 -0
  448. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  449. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  450. package/date-input/Icons.d.ts +0 -6
  451. package/date-input/Icons.js +0 -75
  452. package/number-input/numberInputContextTypes.d.ts +0 -19
  453. package/paginator/Icons.d.ts +0 -5
  454. package/paginator/Icons.js +0 -54
  455. package/resultsetTable/Icons.d.ts +0 -7
  456. package/resultsetTable/ResultsetTable.d.ts +0 -4
  457. package/select/Icons.d.ts +0 -10
  458. package/select/Icons.js +0 -93
  459. package/table/Table.stories.jsx +0 -277
  460. package/tabs-nav/NavTabs.d.ts +0 -8
  461. package/tabs-nav/NavTabs.js +0 -125
  462. package/tabs-nav/NavTabs.stories.tsx +0 -172
  463. package/tabs-nav/NavTabs.test.js +0 -82
  464. package/tabs-nav/Tab.js +0 -128
  465. package/text-input/Icons.d.ts +0 -8
  466. package/text-input/Icons.js +0 -60
  467. package/textarea/Textarea.stories.jsx +0 -157
  468. /package/{resultsetTable → action-icon}/types.js +0 -0
  469. /package/{tabs-nav → breadcrumbs}/types.js +0 -0
  470. /package/{number-input/numberInputContextTypes.js → container/types.js} +0 -0
  471. /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
@@ -1,12 +1,11 @@
1
1
  import React from "react";
2
2
  import styled from "styled-components";
3
3
  import Title from "../../.storybook/components/Title";
4
- import { BackgroundColorProvider } from "../BackgroundColorContext";
5
4
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
5
  import DxcBulletedList from "./BulletedList";
7
6
 
8
7
  export default {
9
- title: "BulletedList",
8
+ title: "Bulleted List",
10
9
  component: DxcBulletedList,
11
10
  };
12
11
 
@@ -20,12 +19,18 @@ const icon = (
20
19
  export const Chromatic = () => (
21
20
  <>
22
21
  <ExampleContainer>
23
- <Title title="Icon list" level={4} />
22
+ <Title title="Icon list (SVG)" level={4} />
24
23
  <DxcBulletedList type="icon" icon={icon}>
25
24
  <DxcBulletedList.Item>Code</DxcBulletedList.Item>
26
25
  <DxcBulletedList.Item>Usage</DxcBulletedList.Item>
27
26
  <DxcBulletedList.Item>Specifications</DxcBulletedList.Item>
28
27
  </DxcBulletedList>
28
+ <Title title="Icon list (path)" level={4} />
29
+ <DxcBulletedList type="icon" icon="filled_check_circle">
30
+ <DxcBulletedList.Item>Code</DxcBulletedList.Item>
31
+ <DxcBulletedList.Item>Usage</DxcBulletedList.Item>
32
+ <DxcBulletedList.Item>Specifications</DxcBulletedList.Item>
33
+ </DxcBulletedList>
29
34
  <Title title="Number list" level={4} />
30
35
  <DxcBulletedList type="number">
31
36
  <DxcBulletedList.Item>Code</DxcBulletedList.Item>
@@ -102,99 +107,9 @@ export const Chromatic = () => (
102
107
  </DxcBulletedList>
103
108
  </Container>
104
109
  </ExampleContainer>
105
- <BackgroundColorProvider color="#333333">
106
- <DarkContainerForBulletedList>
107
- <Title title="Icon list" theme="dark" level={4} />
108
- <DxcBulletedList type="icon" icon={icon}>
109
- <DxcBulletedList.Item>Code</DxcBulletedList.Item>
110
- <DxcBulletedList.Item>Usage</DxcBulletedList.Item>
111
- <DxcBulletedList.Item>Specifications</DxcBulletedList.Item>
112
- </DxcBulletedList>
113
- <Title title="Number list" theme="dark" level={4} />
114
- <DxcBulletedList type="number">
115
- <DxcBulletedList.Item>Code</DxcBulletedList.Item>
116
- <DxcBulletedList.Item>Usage</DxcBulletedList.Item>
117
- <DxcBulletedList.Item>Specifications</DxcBulletedList.Item>
118
- </DxcBulletedList>
119
- <Title title="Square" theme="dark" level={4} />
120
- <DxcBulletedList type="square">
121
- <DxcBulletedList.Item>Code</DxcBulletedList.Item>
122
- <DxcBulletedList.Item>Usage</DxcBulletedList.Item>
123
- <DxcBulletedList.Item>Specifications</DxcBulletedList.Item>
124
- </DxcBulletedList>
125
- <Title title="Circle" theme="dark" level={4} />
126
- <DxcBulletedList type="circle">
127
- <DxcBulletedList.Item>Code</DxcBulletedList.Item>
128
- <DxcBulletedList.Item>Usage</DxcBulletedList.Item>
129
- <DxcBulletedList.Item>Specifications</DxcBulletedList.Item>
130
- </DxcBulletedList>
131
- <Title title="Disc" theme="dark" level={4} />
132
- <DxcBulletedList>
133
- <DxcBulletedList.Item>Code</DxcBulletedList.Item>
134
- <DxcBulletedList.Item>Usage</DxcBulletedList.Item>
135
- <DxcBulletedList.Item>Specifications</DxcBulletedList.Item>
136
- </DxcBulletedList>
137
- <Title title="Multiple lines" theme="dark" level={4} />
138
- <Container>
139
- <Title title="Number" theme="dark" level={4} />
140
- <DxcBulletedList type="number">
141
- <DxcBulletedList.Item>
142
- Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et
143
- dolore magna aliqua.
144
- </DxcBulletedList.Item>
145
- <DxcBulletedList.Item>Text 2.</DxcBulletedList.Item>
146
- </DxcBulletedList>
147
- </Container>
148
- <Container>
149
- <Title title="Square" theme="dark" level={4} />
150
- <DxcBulletedList type="square">
151
- <DxcBulletedList.Item>
152
- Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et
153
- dolore magna aliqua.
154
- </DxcBulletedList.Item>
155
- <DxcBulletedList.Item>Text 2.</DxcBulletedList.Item>
156
- </DxcBulletedList>
157
- </Container>
158
- <Container>
159
- <Title title="Circle" theme="dark" level={4} />
160
- <DxcBulletedList type="circle">
161
- <DxcBulletedList.Item>
162
- Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et
163
- dolore magna aliqua.
164
- </DxcBulletedList.Item>
165
- <DxcBulletedList.Item>Text 2.</DxcBulletedList.Item>
166
- </DxcBulletedList>
167
- </Container>
168
- <Title title="Disc" theme="dark" level={4} />
169
- <Container>
170
- <DxcBulletedList>
171
- <DxcBulletedList.Item>
172
- Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et
173
- dolore magna aliqua.
174
- </DxcBulletedList.Item>
175
- <DxcBulletedList.Item>Text 2.</DxcBulletedList.Item>
176
- </DxcBulletedList>
177
- </Container>
178
- <Container>
179
- <Title title="Icon" theme="dark" level={4} />
180
- <DxcBulletedList type="icon" icon={icon}>
181
- <DxcBulletedList.Item>
182
- Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et
183
- dolore magna aliqua.
184
- </DxcBulletedList.Item>
185
- <DxcBulletedList.Item>Text 2.</DxcBulletedList.Item>
186
- </DxcBulletedList>
187
- </Container>
188
- </DarkContainerForBulletedList>
189
- </BackgroundColorProvider>
190
110
  </>
191
111
  );
192
112
 
193
113
  const Container = styled.div`
194
114
  width: 400px;
195
115
  `;
196
-
197
- const DarkContainerForBulletedList = styled.div`
198
- background-color: #333333;
199
- padding: 5px;
200
- `;
@@ -1,11 +1,38 @@
1
1
  /// <reference types="react" />
2
- declare type SVG = React.ReactNode & (React.SVGProps<SVGSVGElement> | React.FunctionComponent<React.SVGProps<SVGSVGElement>>);
3
- declare type Props = {
2
+ type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
3
+ type IconProps = {
4
+ /**
5
+ * Defines the style of the bullet point in the list.
6
+ */
7
+ type: "icon";
8
+ /**
9
+ * Icon to display as bullet.
10
+ */
11
+ icon: string | SVG;
12
+ /**
13
+ * Text to be shown in the list.
14
+ */
4
15
  children: React.ReactNode;
5
- type?: "disc" | "circle" | "square" | "number" | "icon";
6
- icon?: string | SVG;
7
16
  };
17
+ type OtherProps = {
18
+ /**
19
+ * Defines the style of the bullet point in the list.
20
+ */
21
+ type?: "disc" | "circle" | "square" | "number";
22
+ /**
23
+ * Icon to display as bullet.
24
+ */
25
+ icon?: never;
26
+ /**
27
+ * Text to be shown in the list.
28
+ */
29
+ children: React.ReactNode;
30
+ };
31
+ type Props = IconProps | OtherProps;
8
32
  export default Props;
9
- export declare type BulletedListItemPropsType = {
33
+ export type BulletedListItemPropsType = {
34
+ /**
35
+ * Text to be shown in the list.
36
+ */
10
37
  children?: React.ReactNode;
11
38
  };
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,127 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
5
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
6
+ var _react = _interopRequireDefault(require("react"));
7
+ var _react2 = require("@testing-library/react");
8
+ var _axeHelper = require("../../test/accessibility/axe-helper.js");
9
+ var _Button = _interopRequireDefault(require("./Button"));
10
+ var iconSVG = /*#__PURE__*/_react["default"].createElement("svg", {
11
+ width: "24px",
12
+ height: "24px",
13
+ viewBox: "0 0 24 24",
14
+ fill: "currentColor"
15
+ }, /*#__PURE__*/_react["default"].createElement("path", {
16
+ d: "M0 0h24v24H0z",
17
+ fill: "none"
18
+ }), /*#__PURE__*/_react["default"].createElement("path", {
19
+ d: "M12 21.35l-1.45-1.32C5.4 15.36 2 12.28 2 8.5 2 5.42 4.42 3 7.5 3c1.74 0 3.41.81 4.5 2.09C13.09 3.81 14.76 3 16.5 3 19.58 3 22 5.42 22 8.5c0 3.78-3.4 6.86-8.55 11.54L12 21.35z"
20
+ }));
21
+ describe("Button component accessibility tests", function () {
22
+ it("Should not have basic accessibility issues", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
23
+ var _render, container, results;
24
+ return _regenerator["default"].wrap(function _callee$(_context) {
25
+ while (1) switch (_context.prev = _context.next) {
26
+ case 0:
27
+ _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Button["default"], {
28
+ label: "Primary",
29
+ icon: iconSVG,
30
+ iconPosition: "after",
31
+ margin: "small",
32
+ mode: "primary",
33
+ title: "Button Title",
34
+ size: "fitContent",
35
+ type: "button"
36
+ })), container = _render.container;
37
+ _context.next = 3;
38
+ return (0, _axeHelper.axe)(container);
39
+ case 3:
40
+ results = _context.sent;
41
+ expect(results).toHaveNoViolations();
42
+ case 5:
43
+ case "end":
44
+ return _context.stop();
45
+ }
46
+ }, _callee);
47
+ })));
48
+ it("Should not have basic accessibility issues for disabled mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
49
+ var _render2, container, results;
50
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
51
+ while (1) switch (_context2.prev = _context2.next) {
52
+ case 0:
53
+ _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Button["default"], {
54
+ label: "Primary",
55
+ icon: iconSVG,
56
+ iconPosition: "after",
57
+ margin: "small",
58
+ mode: "primary",
59
+ title: "Button Title",
60
+ size: "fitContent",
61
+ type: "button",
62
+ disabled: true
63
+ })), container = _render2.container;
64
+ _context2.next = 3;
65
+ return (0, _axeHelper.axe)(container);
66
+ case 3:
67
+ results = _context2.sent;
68
+ expect(results).toHaveNoViolations();
69
+ case 5:
70
+ case "end":
71
+ return _context2.stop();
72
+ }
73
+ }, _callee2);
74
+ })));
75
+ it("Should not have basic accessibility issues for secondary mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() {
76
+ var _render3, container, results;
77
+ return _regenerator["default"].wrap(function _callee3$(_context3) {
78
+ while (1) switch (_context3.prev = _context3.next) {
79
+ case 0:
80
+ _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Button["default"], {
81
+ label: "Primary",
82
+ icon: iconSVG,
83
+ iconPosition: "after",
84
+ margin: "small",
85
+ mode: "secondary",
86
+ title: "Button Title",
87
+ size: "fitContent",
88
+ type: "button"
89
+ })), container = _render3.container;
90
+ _context3.next = 3;
91
+ return (0, _axeHelper.axe)(container);
92
+ case 3:
93
+ results = _context3.sent;
94
+ expect(results).toHaveNoViolations();
95
+ case 5:
96
+ case "end":
97
+ return _context3.stop();
98
+ }
99
+ }, _callee3);
100
+ })));
101
+ it("Should not have basic accessibility issues for text mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee4() {
102
+ var _render4, container, results;
103
+ return _regenerator["default"].wrap(function _callee4$(_context4) {
104
+ while (1) switch (_context4.prev = _context4.next) {
105
+ case 0:
106
+ _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Button["default"], {
107
+ label: "Primary",
108
+ icon: iconSVG,
109
+ iconPosition: "after",
110
+ margin: "small",
111
+ mode: "text",
112
+ title: "Button Title",
113
+ size: "fitContent",
114
+ type: "button"
115
+ })), container = _render4.container;
116
+ _context4.next = 3;
117
+ return (0, _axeHelper.axe)(container);
118
+ case 3:
119
+ results = _context4.sent;
120
+ expect(results).toHaveNoViolations();
121
+ case 5:
122
+ case "end":
123
+ return _context4.stop();
124
+ }
125
+ }, _callee4);
126
+ })));
127
+ });
@@ -1,4 +1,4 @@
1
1
  /// <reference types="react" />
2
2
  import ButtonPropsType from "./types";
3
- declare const DxcButton: ({ label, mode, disabled, iconPosition, type, icon, onClick, margin, size, tabIndex, }: ButtonPropsType) => JSX.Element;
3
+ declare const DxcButton: ({ label, mode, disabled, iconPosition, title, type, icon, onClick, margin, size, tabIndex, }: ButtonPropsType) => JSX.Element;
4
4
  export default DxcButton;
package/button/Button.js CHANGED
@@ -1,103 +1,85 @@
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
9
  var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
13
-
14
10
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
-
16
- var _react = _interopRequireWildcard(require("react"));
17
-
11
+ var _react = _interopRequireDefault(require("react"));
18
12
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
19
-
20
- var _variables = require("../common/variables.js");
21
-
22
- var _utils = require("../common/utils.js");
23
-
13
+ var _variables = require("../common/variables");
14
+ var _utils = require("../common/utils");
24
15
  var _useTheme = _interopRequireDefault(require("../useTheme"));
25
-
26
- var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext"));
27
-
16
+ var _Icon = _interopRequireDefault(require("../icon/Icon"));
28
17
  var _templateObject, _templateObject2, _templateObject3;
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
-
34
- var sizes = {
35
- small: "42px",
36
- medium: "120px",
37
- large: "240px",
38
- fillParent: "100%",
39
- fitContent: "fit-content"
40
- };
41
-
42
- var calculateWidth = function calculateWidth(margin, size) {
43
- if (size === "fillParent") {
44
- return "calc(".concat(sizes[size], " - ").concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")");
45
- }
46
-
47
- return sizes[size];
48
- };
49
-
18
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
19
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _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 && {}.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; }
50
20
  var DxcButton = function DxcButton(_ref) {
51
21
  var _ref$label = _ref.label,
52
- label = _ref$label === void 0 ? "" : _ref$label,
53
- _ref$mode = _ref.mode,
54
- mode = _ref$mode === void 0 ? "primary" : _ref$mode,
55
- _ref$disabled = _ref.disabled,
56
- disabled = _ref$disabled === void 0 ? false : _ref$disabled,
57
- _ref$iconPosition = _ref.iconPosition,
58
- iconPosition = _ref$iconPosition === void 0 ? "before" : _ref$iconPosition,
59
- _ref$type = _ref.type,
60
- type = _ref$type === void 0 ? "button" : _ref$type,
61
- icon = _ref.icon,
62
- _ref$onClick = _ref.onClick,
63
- _onClick = _ref$onClick === void 0 ? function () {} : _ref$onClick,
64
- margin = _ref.margin,
65
- _ref$size = _ref.size,
66
- size = _ref$size === void 0 ? "fitContent" : _ref$size,
67
- _ref$tabIndex = _ref.tabIndex,
68
- tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
69
-
22
+ label = _ref$label === void 0 ? "" : _ref$label,
23
+ _ref$mode = _ref.mode,
24
+ mode = _ref$mode === void 0 ? "primary" : _ref$mode,
25
+ _ref$disabled = _ref.disabled,
26
+ disabled = _ref$disabled === void 0 ? false : _ref$disabled,
27
+ _ref$iconPosition = _ref.iconPosition,
28
+ iconPosition = _ref$iconPosition === void 0 ? "before" : _ref$iconPosition,
29
+ title = _ref.title,
30
+ _ref$type = _ref.type,
31
+ type = _ref$type === void 0 ? "button" : _ref$type,
32
+ icon = _ref.icon,
33
+ _ref$onClick = _ref.onClick,
34
+ _onClick = _ref$onClick === void 0 ? function () {} : _ref$onClick,
35
+ margin = _ref.margin,
36
+ _ref$size = _ref.size,
37
+ size = _ref$size === void 0 ? "fitContent" : _ref$size,
38
+ _ref$tabIndex = _ref.tabIndex,
39
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
70
40
  var colorsTheme = (0, _useTheme["default"])();
71
- var backgroundType = (0, _react.useContext)(_BackgroundColorContext["default"]);
72
41
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
73
42
  theme: colorsTheme.button
74
43
  }, /*#__PURE__*/_react["default"].createElement(Button, {
75
- type: type,
76
- mode: mode !== "primary" && mode !== "secondary" && mode !== "text" ? "primary" : mode,
44
+ "aria-label": title,
77
45
  disabled: disabled,
78
- "aria-disabled": disabled,
79
- tabIndex: disabled ? -1 : tabIndex,
80
- backgroundType: backgroundType,
81
- size: size,
82
- margin: margin,
83
46
  onClick: function onClick() {
84
47
  _onClick();
85
- }
86
- }, label && iconPosition === "after" && /*#__PURE__*/_react["default"].createElement(LabelContainer, {
87
- icon: icon,
88
- iconPosition: iconPosition
89
- }, label), icon && /*#__PURE__*/_react["default"].createElement(IconContainer, {
90
- label: label,
91
- iconPosition: iconPosition
92
- }, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement("img", {
93
- src: icon
94
- }) : icon), label && iconPosition === "before" && /*#__PURE__*/_react["default"].createElement(LabelContainer, {
95
- icon: icon,
96
- iconPosition: iconPosition
97
- }, label)));
48
+ },
49
+ tabIndex: disabled ? -1 : tabIndex,
50
+ title: title,
51
+ type: type,
52
+ $mode: mode !== "primary" && mode !== "secondary" && mode !== "text" ? "primary" : mode,
53
+ hasLabel: label ? true : false,
54
+ hasIcon: icon ? true : false,
55
+ iconPosition: iconPosition,
56
+ size: size,
57
+ margin: margin
58
+ }, label && /*#__PURE__*/_react["default"].createElement(LabelContainer, null, label), icon && /*#__PURE__*/_react["default"].createElement(IconContainer, null, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(_Icon["default"], {
59
+ icon: icon
60
+ }) : icon)));
98
61
  };
99
-
100
- var Button = _styledComponents["default"].button(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n display: inline-flex;\n width: ", ";\n height: 40px;\n padding-left: ", ";\n padding-right: ", ";\n padding-top: ", ";\n padding-bottom: ", ";\n align-items: center;\n justify-content: center;\n box-shadow: 0 0 0 2px transparent;\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n letter-spacing: ", ";\n cursor: pointer;\n &:focus {\n outline: none;\n box-shadow: 0 0 0 2px\n ", ";\n }\n ", "\n"])), function (props) {
62
+ var sizes = {
63
+ small: "42px",
64
+ medium: "120px",
65
+ large: "240px",
66
+ fillParent: "100%",
67
+ fitContent: "fit-content"
68
+ };
69
+ var calculateWidth = function calculateWidth(margin, size) {
70
+ return size === "fillParent" ? "calc(".concat(sizes[size], " - ").concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")") : sizes[size];
71
+ };
72
+ var getButtonStyles = function getButtonStyles($mode, theme) {
73
+ return "\n border-color: ".concat($mode === "secondary" ? theme.secondaryBorderColor : "", ";\n border-radius: ").concat($mode === "primary" ? theme.primaryBorderRadius : $mode === "secondary" ? theme.secondaryBorderRadius : theme.textBorderRadius, ";\n border-width: ").concat($mode === "primary" ? theme.primaryBorderThickness : $mode === "secondary" ? theme.secondaryBorderThickness : theme.textBorderThickness, ";\n border-style: ").concat($mode === "primary" ? theme.primaryBorderStyle : $mode === "secondary" ? theme.secondaryBorderStyle : theme.textBorderStyle, ";\n font-family: ").concat($mode === "primary" ? theme.primaryFontFamily : $mode === "secondary" ? theme.secondaryFontFamily : theme.textFontFamily, ";\n font-size: ").concat($mode === "primary" ? theme.primaryFontSize : $mode === "secondary" ? theme.secondaryFontSize : theme.textFontSize, ";\n font-weight: ").concat($mode === "primary" ? theme.primaryFontWeight : $mode === "secondary" ? theme.secondaryFontWeight : theme.textFontWeight, ";\n background-color: ").concat($mode === "primary" ? theme.primaryBackgroundColor : $mode === "secondary" ? theme.secondaryBackgroundColor : theme.textBackgroundColor, ";\n color: ").concat($mode === "primary" ? theme.primaryFontColor : $mode === "secondary" ? theme.secondaryFontColor : theme.textFontColor, ";\n ");
74
+ };
75
+ var getButtonStates = function getButtonStates(disabled, $mode, theme) {
76
+ return "\n &:hover {\n background-color: ".concat($mode === "primary" ? theme.primaryHoverBackgroundColor : $mode === "secondary" ? theme.secondaryHoverBackgroundColor : theme.textHoverBackgroundColor, ";\n color: ").concat($mode === "secondary" ? theme.secondaryHoverFontColor : "", ";\n }\n &:focus {\n border-color: ").concat($mode === "secondary" ? "transparent" : "", ";\n }\n &:active {\n background-color: ").concat($mode === "primary" ? theme.primaryActiveBackgroundColor : $mode === "secondary" ? theme.secondaryActiveBackgroundColor : theme.textActiveBackgroundColor, ";\n color: ").concat($mode === "secondary" ? theme.secondaryHoverFontColor : "", ";\n border-color: ").concat($mode === "secondary" ? "transparent" : "", ";\n outline: none;\n box-shadow: ").concat(!disabled ? "0 0 0 2px ".concat(theme.focusBorderColor) : "", ";\n }\n &:disabled {\n cursor: not-allowed;\n background-color: ").concat($mode === "primary" ? theme.primaryDisabledBackgroundColor : $mode === "secondary" ? theme.secondaryDisabledBackgroundColor : theme.textDisabledBackgroundColor, ";\n color: ").concat($mode === "primary" ? theme.primaryDisabledFontColor : $mode === "secondary" ? theme.secondaryDisabledFontColor : theme.textDisabledFontColor, ";\n border-color: ").concat($mode === "secondary" ? theme.secondaryDisabledBorderColor : "", ";\n }\n");
77
+ };
78
+ var Button = _styledComponents["default"].button(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n flex-direction: ", ";\n gap: 0.5rem;\n align-items: center;\n justify-content: center;\n width: ", ";\n height: 40px;\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n padding-top: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n padding-right: ", ";\n box-shadow: 0 0 0 2px transparent;\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n letter-spacing: ", ";\n cursor: pointer;\n\n &:focus {\n outline: none;\n box-shadow: 0 0 0 2px ", ";\n }\n\n ", "\n ", "\n"])), function (props) {
79
+ return props.iconPosition === "after" ? "row" : "row-reverse";
80
+ }, function (props) {
81
+ return calculateWidth(props.margin, props.size);
82
+ }, function (props) {
101
83
  return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
102
84
  }, function (props) {
103
85
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
@@ -107,16 +89,14 @@ var Button = _styledComponents["default"].button(_templateObject || (_templateOb
107
89
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
108
90
  }, function (props) {
109
91
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
110
- }, function (props) {
111
- return calculateWidth(props.margin, props.size);
112
- }, function (props) {
113
- return props.theme.paddingLeft;
114
- }, function (props) {
115
- return props.theme.paddingRight;
116
92
  }, function (props) {
117
93
  return props.theme.paddingTop;
118
94
  }, function (props) {
119
95
  return props.theme.paddingBottom;
96
+ }, function (props) {
97
+ return props.hasIcon && !props.hasLabel ? props.theme.paddingLeft : "calc(".concat(props.theme.paddingLeft, " + 8px)");
98
+ }, function (props) {
99
+ return props.hasIcon && !props.hasLabel ? props.theme.paddingRight : "calc(".concat(props.theme.paddingRight, " + 8px)");
120
100
  }, function (props) {
121
101
  return props.theme.fontFamily;
122
102
  }, function (props) {
@@ -126,29 +106,16 @@ var Button = _styledComponents["default"].button(_templateObject || (_templateOb
126
106
  }, function (props) {
127
107
  return props.theme.labelLetterSpacing;
128
108
  }, function (props) {
129
- return props.backgroundType === "dark" ? props.theme.focusBorderColorOnDark : props.theme.focusBorderColor;
109
+ return props.theme.focusBorderColor;
110
+ }, function (props) {
111
+ return getButtonStyles(props.$mode, props.theme);
130
112
  }, function (props) {
131
- var mode = props.mode,
132
- backgroundType = props.backgroundType,
133
- disabled = props.disabled;
134
- return "\n border-radius: ".concat(props.mode === "primary" ? props.theme.primaryBorderRadius : props.mode === "secondary" ? props.theme.secondaryBorderRadius : props.theme.textBorderRadius, ";\n border-width: ").concat(props.mode === "primary" ? props.theme.primaryBorderThickness : props.mode === "secondary" ? props.theme.secondaryBorderThickness : props.theme.textBorderThickness, ";\n border-style: ").concat(mode === "primary" ? props.theme.primaryBorderStyle : mode === "secondary" ? props.theme.secondaryBorderStyle : props.theme.textBorderStyle, ";\n font-family: ").concat(mode === "primary" ? props.theme.primaryFontFamily : mode === "secondary" ? props.theme.secondaryFontFamily : props.theme.textFontFamily, ";\n font-size: ").concat(mode === "primary" ? props.theme.primaryFontSize : mode === "secondary" ? props.theme.secondaryFontSize : props.theme.textFontSize, ";\n font-weight: ").concat(mode === "primary" ? props.theme.primaryFontWeight : mode === "secondary" ? props.theme.secondaryFontWeight : props.theme.textFontWeight, ";\n background-color: ").concat(mode === "primary" ? backgroundType === "dark" ? props.theme.primaryBackgroundColorOnDark : props.theme.primaryBackgroundColor : mode === "secondary" ? backgroundType === "dark" ? props.theme.secondaryBackgroundColorOnDark : props.theme.secondaryBackgroundColor : backgroundType === "dark" ? props.theme.textBackgroundColorOnDark : props.theme.textBackgroundColor, ";\n color: ").concat(mode === "primary" ? backgroundType === "dark" ? props.theme.primaryFontColorOnDark : props.theme.primaryFontColor : mode === "secondary" ? backgroundType === "dark" ? props.theme.secondaryFontColorOnDark : props.theme.secondaryFontColor : backgroundType === "dark" ? props.theme.textFontColorOnDark : props.theme.textFontColor, ";\n border-color: ").concat(mode === "secondary" ? backgroundType === "dark" ? props.theme.secondaryBorderColorOnDark : props.theme.secondaryBorderColor : "", ";\n &:hover {\n background-color: ").concat(mode === "primary" ? backgroundType === "dark" ? props.theme.primaryHoverBackgroundColorOnDark : props.theme.primaryHoverBackgroundColor : mode === "secondary" ? backgroundType === "dark" ? props.theme.secondaryHoverBackgroundColorOnDark : props.theme.secondaryHoverBackgroundColor : backgroundType === "dark" ? props.theme.textHoverBackgroundColorOnDark : props.theme.textHoverBackgroundColor, ";\n color: ").concat(mode === "secondary" ? backgroundType === "dark" ? props.theme.secondaryHoverFontColorOnDark : props.theme.secondaryHoverFontColor : "", ";\n }\n &:focus {\n border-color: ").concat(mode === "secondary" ? "transparent" : "", ";\n }\n &:active {\n background-color: ").concat(mode === "primary" ? backgroundType === "dark" ? props.theme.primaryActiveBackgroundColorOnDark : props.theme.primaryActiveBackgroundColor : mode === "secondary" ? backgroundType === "dark" ? props.theme.secondaryActiveBackgroundColorOnDark : props.theme.secondaryActiveBackgroundColor : backgroundType === "dark" ? props.theme.textActiveBackgroundColorOnDark : props.theme.textActiveBackgroundColor, ";\n color: ").concat(mode === "secondary" ? backgroundType === "dark" ? props.theme.secondaryHoverFontColorOnDark : props.theme.secondaryHoverFontColor : "", ";\n border-color: ").concat(mode === "secondary" ? "transparent" : "", ";\n outline: none;\n box-shadow: ").concat(!disabled ? "0 0 0 2px ".concat(backgroundType === "dark" ? props.theme.focusBorderColorOnDark : props.theme.focusBorderColor) : "", ";\n }\n &:disabled {\n cursor: not-allowed;\n background-color: ").concat(mode === "primary" ? backgroundType === "dark" ? props.theme.primaryDisabledBackgroundColorOnDark : props.theme.primaryDisabledBackgroundColor : mode === "secondary" ? backgroundType === "dark" ? props.theme.secondaryDisabledBackgroundColorOnDark : props.theme.secondaryDisabledBackgroundColor : backgroundType === "dark" ? props.theme.textDisabledBackgroundColorOnDark : props.theme.textDisabledBackgroundColor, ";\n color: ").concat(mode === "primary" ? backgroundType === "dark" ? props.theme.primaryDisabledFontColorOnDark : props.theme.primaryDisabledFontColor : mode === "secondary" ? backgroundType === "dark" ? props.theme.secondaryDisabledFontColorOnDark : props.theme.secondaryDisabledFontColor : backgroundType === "dark" ? props.theme.textDisabledFontColorOnDark : props.theme.textDisabledFontColor, ";\n border-color: ").concat(mode === "secondary" ? backgroundType === "dark" ? props.theme.secondaryDisabledBorderColorOnDark : props.theme.secondaryDisabledBorderColor : "", ";\n }\n ");
113
+ return getButtonStates(props.disabled, props.$mode, props.theme);
135
114
  });
136
-
137
- var LabelContainer = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n line-height: ", ";\n font-size: ", ";\n text-overflow: ellipsis;\n overflow: hidden;\n text-transform: none;\n white-space: nowrap;\n margin-right: ", ";\n margin-left: ", ";\n"])), function (props) {
115
+ var LabelContainer = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n line-height: ", ";\n font-size: ", ";\n text-overflow: ellipsis;\n overflow: hidden;\n text-transform: none;\n white-space: nowrap;\n"])), function (props) {
138
116
  return props.theme.labelFontLineHeight;
139
117
  }, function (props) {
140
118
  return props.theme.fontSize;
141
- }, function (props) {
142
- return !props.icon || props.iconPosition === "before" ? "8px" : "0px";
143
- }, function (props) {
144
- return !props.icon || props.iconPosition === "after" ? "8px" : "0px";
145
119
  });
146
-
147
- var IconContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n margin-left: ", ";\n margin-right: ", ";\n\n img,\n svg {\n height: 24px;\n width: 24px;\n }\n"])), function (props) {
148
- return !props.label ? "0px" : props.iconPosition === "after" && props.label !== "" && "8px" || "8px";
149
- }, function (props) {
150
- return !props.label ? "0px" : props.iconPosition === "before" && props.label !== "" && "8px" || "8px";
151
- });
152
-
153
- var _default = DxcButton;
154
- exports["default"] = _default;
120
+ var IconContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n font-size: 24px;\n\n svg {\n height: 24px;\n width: 24px;\n }\n"])));
121
+ var _default = exports["default"] = DxcButton;