@dxc-technology/halstack-react 0.0.0-ff5083e → 0.0.0-ff6c8bf

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 (403) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +5 -22
  3. package/HalstackContext.d.ts +1240 -6
  4. package/HalstackContext.js +126 -111
  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 +105 -160
  9. package/accordion/Accordion.stories.tsx +82 -148
  10. package/accordion/Accordion.test.js +25 -41
  11. package/accordion/types.d.ts +6 -17
  12. package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
  13. package/accordion-group/AccordionGroup.d.ts +2 -2
  14. package/accordion-group/AccordionGroup.js +31 -98
  15. package/accordion-group/AccordionGroup.stories.tsx +94 -67
  16. package/accordion-group/AccordionGroup.test.js +52 -105
  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 +12 -17
  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 +37 -127
  30. package/alert/Alert.stories.tsx +28 -0
  31. package/alert/Alert.test.js +29 -46
  32. package/alert/types.d.ts +5 -5
  33. package/badge/Badge.accessibility.test.js +129 -0
  34. package/badge/Badge.d.ts +1 -1
  35. package/badge/Badge.js +142 -42
  36. package/badge/Badge.stories.tsx +210 -0
  37. package/badge/Badge.test.js +30 -0
  38. package/badge/types.d.ts +52 -3
  39. package/bleed/Bleed.js +13 -21
  40. package/bleed/Bleed.stories.tsx +64 -63
  41. package/bleed/types.d.ts +2 -2
  42. package/box/Box.accessibility.test.js +33 -0
  43. package/box/Box.d.ts +1 -1
  44. package/box/Box.js +19 -60
  45. package/box/Box.stories.tsx +38 -51
  46. package/box/Box.test.js +2 -7
  47. package/box/types.d.ts +3 -14
  48. package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
  49. package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
  50. package/breadcrumbs/Breadcrumbs.d.ts +4 -0
  51. package/breadcrumbs/Breadcrumbs.js +79 -0
  52. package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
  53. package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
  54. package/breadcrumbs/Breadcrumbs.test.js +169 -0
  55. package/breadcrumbs/Item.d.ts +4 -0
  56. package/breadcrumbs/Item.js +52 -0
  57. package/breadcrumbs/dropdownTheme.d.ts +53 -0
  58. package/breadcrumbs/dropdownTheme.js +62 -0
  59. package/breadcrumbs/types.d.ts +16 -0
  60. package/bulleted-list/BulletedList.accessibility.test.js +119 -0
  61. package/bulleted-list/BulletedList.js +35 -63
  62. package/bulleted-list/BulletedList.stories.tsx +18 -106
  63. package/bulleted-list/types.d.ts +32 -5
  64. package/button/Button.accessibility.test.js +127 -0
  65. package/button/Button.d.ts +1 -1
  66. package/button/Button.js +64 -117
  67. package/button/Button.stories.tsx +151 -100
  68. package/button/Button.test.js +20 -17
  69. package/button/types.d.ts +12 -8
  70. package/card/Card.accessibility.test.js +36 -0
  71. package/card/Card.d.ts +1 -1
  72. package/card/Card.js +49 -89
  73. package/card/Card.stories.tsx +12 -42
  74. package/card/Card.test.js +11 -22
  75. package/card/types.d.ts +6 -11
  76. package/checkbox/Checkbox.accessibility.test.js +87 -0
  77. package/checkbox/Checkbox.d.ts +2 -2
  78. package/checkbox/Checkbox.js +139 -181
  79. package/checkbox/Checkbox.stories.tsx +128 -94
  80. package/checkbox/Checkbox.test.js +160 -39
  81. package/checkbox/types.d.ts +11 -3
  82. package/chip/Chip.accessibility.test.js +67 -0
  83. package/chip/Chip.js +45 -80
  84. package/chip/Chip.stories.tsx +107 -27
  85. package/chip/Chip.test.js +18 -33
  86. package/chip/types.d.ts +4 -4
  87. package/common/coreTokens.d.ts +237 -0
  88. package/common/coreTokens.js +184 -0
  89. package/common/utils.d.ts +1 -0
  90. package/common/utils.js +6 -12
  91. package/common/variables.d.ts +1392 -0
  92. package/common/variables.js +984 -1206
  93. package/container/Container.d.ts +4 -0
  94. package/container/Container.js +194 -0
  95. package/container/Container.stories.tsx +214 -0
  96. package/container/types.d.ts +74 -0
  97. package/contextual-menu/ContextualMenu.accessibility.test.js +97 -0
  98. package/contextual-menu/ContextualMenu.d.ts +5 -0
  99. package/contextual-menu/ContextualMenu.js +88 -0
  100. package/contextual-menu/ContextualMenu.stories.tsx +232 -0
  101. package/contextual-menu/ContextualMenu.test.js +205 -0
  102. package/contextual-menu/GroupItem.d.ts +4 -0
  103. package/contextual-menu/GroupItem.js +67 -0
  104. package/contextual-menu/ItemAction.d.ts +4 -0
  105. package/contextual-menu/ItemAction.js +51 -0
  106. package/contextual-menu/MenuItem.d.ts +4 -0
  107. package/contextual-menu/MenuItem.js +29 -0
  108. package/contextual-menu/SingleItem.d.ts +4 -0
  109. package/contextual-menu/SingleItem.js +38 -0
  110. package/contextual-menu/types.d.ts +58 -0
  111. package/date-input/Calendar.d.ts +4 -0
  112. package/date-input/Calendar.js +214 -0
  113. package/date-input/DateInput.accessibility.test.js +228 -0
  114. package/date-input/DateInput.js +149 -299
  115. package/date-input/DateInput.stories.tsx +210 -56
  116. package/date-input/DateInput.test.js +700 -371
  117. package/date-input/DatePicker.d.ts +4 -0
  118. package/date-input/DatePicker.js +121 -0
  119. package/date-input/YearPicker.d.ts +4 -0
  120. package/date-input/YearPicker.js +100 -0
  121. package/date-input/types.d.ts +72 -15
  122. package/dialog/Dialog.accessibility.test.js +69 -0
  123. package/dialog/Dialog.d.ts +1 -1
  124. package/dialog/Dialog.js +61 -106
  125. package/dialog/Dialog.stories.tsx +326 -167
  126. package/dialog/Dialog.test.js +287 -20
  127. package/dialog/types.d.ts +18 -25
  128. package/divider/Divider.accessibility.test.js +33 -0
  129. package/divider/Divider.d.ts +4 -0
  130. package/divider/Divider.js +36 -0
  131. package/divider/Divider.stories.tsx +223 -0
  132. package/divider/Divider.test.js +38 -0
  133. package/divider/types.d.ts +21 -0
  134. package/dropdown/Dropdown.accessibility.test.js +180 -0
  135. package/dropdown/Dropdown.d.ts +1 -1
  136. package/dropdown/Dropdown.js +233 -303
  137. package/dropdown/Dropdown.stories.tsx +235 -57
  138. package/dropdown/Dropdown.test.js +575 -165
  139. package/dropdown/DropdownMenu.d.ts +4 -0
  140. package/dropdown/DropdownMenu.js +63 -0
  141. package/dropdown/DropdownMenuItem.d.ts +4 -0
  142. package/dropdown/DropdownMenuItem.js +71 -0
  143. package/dropdown/types.d.ts +35 -19
  144. package/file-input/FileInput.accessibility.test.js +160 -0
  145. package/file-input/FileInput.d.ts +2 -2
  146. package/file-input/FileInput.js +241 -391
  147. package/file-input/FileInput.stories.tsx +123 -12
  148. package/file-input/FileInput.test.js +306 -367
  149. package/file-input/FileItem.d.ts +4 -14
  150. package/file-input/FileItem.js +56 -117
  151. package/file-input/types.d.ts +25 -8
  152. package/flex/Flex.d.ts +4 -0
  153. package/flex/Flex.js +57 -0
  154. package/flex/Flex.stories.tsx +112 -0
  155. package/flex/types.d.ts +97 -0
  156. package/footer/Footer.accessibility.test.js +125 -0
  157. package/footer/Footer.d.ts +1 -1
  158. package/footer/Footer.js +73 -118
  159. package/footer/Footer.stories.tsx +99 -21
  160. package/footer/Footer.test.js +33 -57
  161. package/footer/Icons.d.ts +3 -2
  162. package/footer/Icons.js +54 -23
  163. package/footer/types.d.ts +26 -27
  164. package/grid/Grid.d.ts +7 -0
  165. package/grid/Grid.js +76 -0
  166. package/grid/Grid.stories.tsx +219 -0
  167. package/grid/types.d.ts +115 -0
  168. package/grid/types.js +5 -0
  169. package/header/Header.accessibility.test.js +93 -0
  170. package/header/Header.d.ts +4 -3
  171. package/header/Header.js +90 -183
  172. package/header/Header.stories.tsx +133 -38
  173. package/header/Header.test.js +13 -26
  174. package/header/Icons.d.ts +2 -2
  175. package/header/Icons.js +5 -15
  176. package/header/types.d.ts +7 -21
  177. package/heading/Heading.accessibility.test.js +33 -0
  178. package/heading/Heading.js +10 -32
  179. package/heading/Heading.test.js +71 -88
  180. package/heading/types.d.ts +7 -7
  181. package/icon/Icon.accessibility.test.js +30 -0
  182. package/icon/Icon.d.ts +4 -0
  183. package/icon/Icon.js +33 -0
  184. package/icon/Icon.stories.tsx +28 -0
  185. package/icon/types.d.ts +4 -0
  186. package/icon/types.js +5 -0
  187. package/image/Image.accessibility.test.js +56 -0
  188. package/image/Image.d.ts +4 -0
  189. package/image/Image.js +70 -0
  190. package/image/Image.stories.tsx +129 -0
  191. package/image/types.d.ts +72 -0
  192. package/image/types.js +5 -0
  193. package/inset/Inset.js +13 -21
  194. package/inset/Inset.stories.tsx +5 -4
  195. package/inset/types.d.ts +2 -2
  196. package/layout/ApplicationLayout.d.ts +15 -6
  197. package/layout/ApplicationLayout.js +57 -119
  198. package/layout/ApplicationLayout.stories.tsx +81 -45
  199. package/layout/Icons.d.ts +7 -5
  200. package/layout/Icons.js +41 -59
  201. package/layout/types.d.ts +21 -32
  202. package/link/Link.accessibility.test.js +108 -0
  203. package/link/Link.js +32 -51
  204. package/link/Link.stories.tsx +76 -9
  205. package/link/Link.test.js +24 -44
  206. package/link/types.d.ts +14 -14
  207. package/main.d.ts +14 -12
  208. package/main.js +51 -88
  209. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  210. package/nav-tabs/NavTabs.d.ts +7 -0
  211. package/{tabs-nav → nav-tabs}/NavTabs.js +30 -62
  212. package/nav-tabs/NavTabs.stories.tsx +279 -0
  213. package/nav-tabs/NavTabs.test.js +77 -0
  214. package/nav-tabs/NavTabsContext.d.ts +3 -0
  215. package/nav-tabs/NavTabsContext.js +8 -0
  216. package/nav-tabs/Tab.js +117 -0
  217. package/{tabs-nav → nav-tabs}/types.d.ts +15 -16
  218. package/nav-tabs/types.js +5 -0
  219. package/number-input/NumberInput.accessibility.test.js +228 -0
  220. package/number-input/NumberInput.js +46 -36
  221. package/number-input/NumberInput.stories.tsx +42 -26
  222. package/number-input/NumberInput.test.js +860 -377
  223. package/number-input/NumberInputContext.d.ts +3 -4
  224. package/number-input/NumberInputContext.js +3 -14
  225. package/number-input/types.d.ts +17 -5
  226. package/package.json +51 -51
  227. package/paginator/Paginator.accessibility.test.js +79 -0
  228. package/paginator/Paginator.js +35 -68
  229. package/paginator/Paginator.stories.tsx +24 -0
  230. package/paginator/Paginator.test.js +280 -211
  231. package/paginator/types.d.ts +3 -3
  232. package/paragraph/Paragraph.accessibility.test.js +28 -0
  233. package/paragraph/Paragraph.d.ts +3 -4
  234. package/paragraph/Paragraph.js +7 -23
  235. package/paragraph/Paragraph.stories.tsx +1 -18
  236. package/password-input/PasswordInput.accessibility.test.js +153 -0
  237. package/password-input/PasswordInput.js +58 -127
  238. package/password-input/PasswordInput.stories.tsx +1 -33
  239. package/password-input/PasswordInput.test.js +160 -142
  240. package/password-input/types.d.ts +8 -7
  241. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  242. package/progress-bar/ProgressBar.js +68 -92
  243. package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +39 -4
  244. package/progress-bar/ProgressBar.test.js +72 -44
  245. package/progress-bar/types.d.ts +3 -3
  246. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  247. package/quick-nav/QuickNav.js +24 -42
  248. package/quick-nav/QuickNav.stories.tsx +146 -27
  249. package/quick-nav/types.d.ts +10 -10
  250. package/radio-group/Radio.d.ts +1 -1
  251. package/radio-group/Radio.js +59 -76
  252. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  253. package/radio-group/RadioGroup.js +68 -114
  254. package/radio-group/RadioGroup.stories.tsx +132 -18
  255. package/radio-group/RadioGroup.test.js +518 -457
  256. package/radio-group/types.d.ts +10 -10
  257. package/resultset-table/Icons.d.ts +7 -0
  258. package/resultset-table/Icons.js +47 -0
  259. package/resultset-table/ResultsetTable.accessibility.test.js +285 -0
  260. package/resultset-table/ResultsetTable.d.ts +7 -0
  261. package/resultset-table/ResultsetTable.js +171 -0
  262. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +168 -30
  263. package/resultset-table/ResultsetTable.test.js +381 -0
  264. package/{resultsetTable → resultset-table}/types.d.ts +44 -11
  265. package/resultset-table/types.js +5 -0
  266. package/select/Listbox.d.ts +1 -1
  267. package/select/Listbox.js +68 -65
  268. package/select/Option.js +35 -56
  269. package/select/Select.accessibility.test.js +228 -0
  270. package/select/Select.js +171 -214
  271. package/select/Select.stories.tsx +515 -190
  272. package/select/Select.test.js +1934 -1789
  273. package/select/types.d.ts +17 -21
  274. package/sidenav/Sidenav.accessibility.test.js +59 -0
  275. package/sidenav/Sidenav.d.ts +6 -5
  276. package/sidenav/Sidenav.js +132 -78
  277. package/sidenav/Sidenav.stories.tsx +246 -151
  278. package/sidenav/Sidenav.test.js +26 -45
  279. package/{layout → sidenav}/SidenavContext.d.ts +1 -1
  280. package/{layout → sidenav}/SidenavContext.js +3 -9
  281. package/sidenav/types.d.ts +52 -26
  282. package/slider/Slider.accessibility.test.js +104 -0
  283. package/slider/Slider.d.ts +2 -2
  284. package/slider/Slider.js +149 -181
  285. package/slider/Slider.stories.tsx +64 -61
  286. package/slider/Slider.test.js +185 -81
  287. package/slider/types.d.ts +7 -3
  288. package/spinner/Spinner.accessibility.test.js +96 -0
  289. package/spinner/Spinner.js +34 -74
  290. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
  291. package/spinner/Spinner.test.js +26 -35
  292. package/spinner/types.d.ts +3 -3
  293. package/status-light/StatusLight.accessibility.test.js +157 -0
  294. package/status-light/StatusLight.d.ts +4 -0
  295. package/status-light/StatusLight.js +51 -0
  296. package/status-light/StatusLight.stories.tsx +74 -0
  297. package/status-light/StatusLight.test.js +25 -0
  298. package/status-light/types.d.ts +17 -0
  299. package/status-light/types.js +5 -0
  300. package/switch/Switch.accessibility.test.js +98 -0
  301. package/switch/Switch.d.ts +2 -2
  302. package/switch/Switch.js +145 -126
  303. package/switch/Switch.stories.tsx +49 -60
  304. package/switch/Switch.test.js +138 -56
  305. package/switch/types.d.ts +7 -3
  306. package/table/DropdownTheme.js +62 -0
  307. package/table/Table.accessibility.test.js +93 -0
  308. package/table/Table.d.ts +6 -2
  309. package/table/Table.js +78 -35
  310. package/table/Table.stories.tsx +663 -0
  311. package/table/Table.test.js +95 -8
  312. package/table/types.d.ts +34 -6
  313. package/tabs/Tab.d.ts +4 -0
  314. package/tabs/Tab.js +117 -0
  315. package/tabs/Tabs.accessibility.test.js +56 -0
  316. package/tabs/Tabs.js +303 -141
  317. package/tabs/Tabs.stories.tsx +124 -6
  318. package/tabs/Tabs.test.js +213 -77
  319. package/tabs/types.d.ts +30 -20
  320. package/tag/Tag.accessibility.test.js +69 -0
  321. package/tag/Tag.js +35 -67
  322. package/tag/Tag.stories.tsx +18 -8
  323. package/tag/Tag.test.js +18 -37
  324. package/tag/types.d.ts +9 -9
  325. package/text-input/Suggestion.js +40 -28
  326. package/text-input/Suggestions.d.ts +4 -0
  327. package/text-input/Suggestions.js +94 -0
  328. package/text-input/TextInput.accessibility.test.js +321 -0
  329. package/text-input/TextInput.js +316 -515
  330. package/text-input/TextInput.stories.tsx +276 -276
  331. package/text-input/TextInput.test.js +1419 -1375
  332. package/text-input/types.d.ts +43 -16
  333. package/textarea/Textarea.accessibility.test.js +155 -0
  334. package/textarea/Textarea.js +71 -113
  335. package/textarea/Textarea.stories.tsx +174 -0
  336. package/textarea/Textarea.test.js +152 -183
  337. package/textarea/types.d.ts +9 -5
  338. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  339. package/toggle-group/ToggleGroup.d.ts +2 -2
  340. package/toggle-group/ToggleGroup.js +94 -107
  341. package/toggle-group/ToggleGroup.stories.tsx +52 -7
  342. package/toggle-group/ToggleGroup.test.js +69 -88
  343. package/toggle-group/types.d.ts +28 -19
  344. package/typography/Typography.accessibility.test.js +339 -0
  345. package/typography/Typography.d.ts +2 -2
  346. package/typography/Typography.js +16 -124
  347. package/typography/Typography.stories.tsx +185 -162
  348. package/typography/types.d.ts +1 -1
  349. package/useTheme.d.ts +1144 -1
  350. package/useTheme.js +2 -9
  351. package/useTranslatedLabels.d.ts +84 -1
  352. package/useTranslatedLabels.js +1 -7
  353. package/utils/BaseTypography.d.ts +21 -0
  354. package/utils/BaseTypography.js +94 -0
  355. package/utils/FocusLock.d.ts +13 -0
  356. package/utils/FocusLock.js +124 -0
  357. package/wizard/Wizard.accessibility.test.js +55 -0
  358. package/wizard/Wizard.js +34 -87
  359. package/wizard/Wizard.stories.tsx +59 -1
  360. package/wizard/Wizard.test.js +54 -81
  361. package/wizard/types.d.ts +9 -9
  362. package/card/ice-cream.jpg +0 -0
  363. package/common/OpenSans.css +0 -81
  364. package/common/RequiredComponent.js +0 -32
  365. package/common/fonts/OpenSans-Bold.ttf +0 -0
  366. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  367. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  368. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  369. package/common/fonts/OpenSans-Italic.ttf +0 -0
  370. package/common/fonts/OpenSans-Light.ttf +0 -0
  371. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  372. package/common/fonts/OpenSans-Regular.ttf +0 -0
  373. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  374. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  375. package/number-input/numberInputContextTypes.d.ts +0 -19
  376. package/paginator/Icons.js +0 -66
  377. package/resultsetTable/ResultsetTable.d.ts +0 -4
  378. package/resultsetTable/ResultsetTable.js +0 -254
  379. package/resultsetTable/ResultsetTable.test.js +0 -306
  380. package/row/Row.d.ts +0 -3
  381. package/row/Row.js +0 -127
  382. package/row/Row.stories.tsx +0 -237
  383. package/row/types.d.ts +0 -28
  384. package/select/Icons.d.ts +0 -10
  385. package/select/Icons.js +0 -93
  386. package/stack/Stack.d.ts +0 -3
  387. package/stack/Stack.js +0 -97
  388. package/stack/Stack.stories.tsx +0 -164
  389. package/stack/types.d.ts +0 -24
  390. package/table/Table.stories.jsx +0 -277
  391. package/tabs-nav/NavTabs.d.ts +0 -8
  392. package/tabs-nav/NavTabs.stories.tsx +0 -170
  393. package/tabs-nav/NavTabs.test.js +0 -82
  394. package/tabs-nav/Tab.js +0 -132
  395. package/textarea/Textarea.stories.jsx +0 -157
  396. package/typography/typographyContextTypes.d.ts +0 -16
  397. /package/{resultsetTable → action-icon}/types.js +0 -0
  398. /package/{row → breadcrumbs}/types.js +0 -0
  399. /package/{stack → container}/types.js +0 -0
  400. /package/{tabs-nav → contextual-menu}/types.js +0 -0
  401. /package/{number-input/numberInputContextTypes.js → divider/types.js} +0 -0
  402. /package/{typography/typographyContextTypes.js → flex/types.js} +0 -0
  403. /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
@@ -0,0 +1,129 @@
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 _Badge = _interopRequireDefault(require("./Badge.tsx"));
10
+ var _Flex = _interopRequireDefault(require("../flex/Flex.tsx"));
11
+ var icon = /*#__PURE__*/_react["default"].createElement("svg", {
12
+ width: "24",
13
+ height: "24",
14
+ viewBox: "0 0 24 24",
15
+ xmlns: "http://www.w3.org/2000/svg",
16
+ fill: "currentColor"
17
+ }, /*#__PURE__*/_react["default"].createElement("path", {
18
+ d: "M11 17H13V11H11V17ZM12 2C6.48 2 2 6.48 2 12C2 17.52 6.48 22 12 22C17.52 22 22 17.52 22 12C22 6.48 17.52 2 12 2ZM12 20C7.59 20 4 16.41 4 12C4 7.59 7.59 4 12 4C16.41 4 20 7.59 20 12C20 16.41 16.41 20 12 20ZM11 9H13V7H11V9Z"
19
+ }), /*#__PURE__*/_react["default"].createElement("path", {
20
+ d: "M11 7H13V9H11V7ZM11 11H13V17H11V11Z"
21
+ }), /*#__PURE__*/_react["default"].createElement("path", {
22
+ d: "M12 2C6.48 2 2 6.48 2 12C2 17.52 6.48 22 12 22C17.52 22 22 17.52 22 12C22 6.48 17.52 2 12 2ZM12 20C7.59 20 4 16.41 4 12C4 7.59 7.59 4 12 4C16.41 4 20 7.59 20 12C20 16.41 16.41 20 12 20Z"
23
+ }));
24
+ describe("Badge component accessibility tests", function () {
25
+ it("Should not have basic accessibility issues for contextual mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
26
+ var _render, container, results;
27
+ return _regenerator["default"].wrap(function _callee$(_context) {
28
+ while (1) switch (_context.prev = _context.next) {
29
+ case 0:
30
+ _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Flex["default"], null, /*#__PURE__*/_react["default"].createElement(_Badge["default"], {
31
+ color: "blue",
32
+ mode: "contextual",
33
+ label: "Label",
34
+ size: "small",
35
+ icon: icon,
36
+ title: "Badge1"
37
+ }), /*#__PURE__*/_react["default"].createElement(_Badge["default"], {
38
+ color: "green",
39
+ mode: "contextual",
40
+ label: "Label",
41
+ size: "small",
42
+ icon: icon,
43
+ title: "Badge1"
44
+ }), /*#__PURE__*/_react["default"].createElement(_Badge["default"], {
45
+ color: "grey",
46
+ mode: "contextual",
47
+ label: "Label",
48
+ size: "small",
49
+ icon: icon,
50
+ title: "Badge1"
51
+ }), /*#__PURE__*/_react["default"].createElement(_Badge["default"], {
52
+ color: "orange",
53
+ mode: "contextual",
54
+ label: "Label",
55
+ size: "small",
56
+ icon: icon,
57
+ title: "Badge1"
58
+ }), /*#__PURE__*/_react["default"].createElement(_Badge["default"], {
59
+ color: "purple",
60
+ mode: "contextual",
61
+ label: "Label",
62
+ size: "small",
63
+ icon: icon,
64
+ title: "Badge1"
65
+ }), /*#__PURE__*/_react["default"].createElement(_Badge["default"], {
66
+ color: "red",
67
+ mode: "contextual",
68
+ label: "Label",
69
+ size: "small",
70
+ icon: icon,
71
+ title: "Badge1"
72
+ }), /*#__PURE__*/_react["default"].createElement(_Badge["default"], {
73
+ color: "yellow",
74
+ mode: "contextual",
75
+ label: "Label",
76
+ size: "small",
77
+ icon: icon,
78
+ title: "Badge1"
79
+ }))), container = _render.container;
80
+ _context.next = 3;
81
+ return (0, _axeHelper.axe)(container);
82
+ case 3:
83
+ results = _context.sent;
84
+ expect(results).toHaveNoViolations();
85
+ case 5:
86
+ case "end":
87
+ return _context.stop();
88
+ }
89
+ }, _callee);
90
+ })));
91
+ it("Should not have basic accessibility issues for notification mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
92
+ var _render2, container, results;
93
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
94
+ while (1) switch (_context2.prev = _context2.next) {
95
+ case 0:
96
+ _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Flex["default"], null, /*#__PURE__*/_react["default"].createElement(_Badge["default"], {
97
+ mode: "notification",
98
+ label: 100,
99
+ size: "large",
100
+ icon: icon,
101
+ notificationLimit: 99,
102
+ title: "Badge2"
103
+ }), /*#__PURE__*/_react["default"].createElement(_Badge["default"], {
104
+ mode: "notification",
105
+ label: 50,
106
+ size: "large",
107
+ icon: icon,
108
+ notificationLimit: 99,
109
+ title: "Badge2"
110
+ }), /*#__PURE__*/_react["default"].createElement(_Badge["default"], {
111
+ mode: "notification",
112
+ label: 1000000,
113
+ size: "large",
114
+ icon: icon,
115
+ notificationLimit: 99999999,
116
+ title: "Badge2"
117
+ }))), container = _render2.container;
118
+ _context2.next = 3;
119
+ return (0, _axeHelper.axe)(container);
120
+ case 3:
121
+ results = _context2.sent;
122
+ expect(results).toHaveNoViolations();
123
+ case 5:
124
+ case "end":
125
+ return _context2.stop();
126
+ }
127
+ }, _callee2);
128
+ })));
129
+ });
package/badge/Badge.d.ts CHANGED
@@ -1,4 +1,4 @@
1
1
  /// <reference types="react" />
2
2
  import BadgePropsType from "./types";
3
- declare const DxcBadge: ({ notificationText, disabled }: BadgePropsType) => JSX.Element;
3
+ declare const DxcBadge: ({ label, title, mode, color, icon, notificationLimit, size, }: BadgePropsType) => JSX.Element;
4
4
  export default DxcBadge;
package/badge/Badge.js CHANGED
@@ -1,61 +1,161 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- var _typeof = require("@babel/runtime/helpers/typeof");
6
-
7
4
  Object.defineProperty(exports, "__esModule", {
8
5
  value: true
9
6
  });
10
7
  exports["default"] = void 0;
11
-
12
8
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
-
14
9
  var _react = _interopRequireDefault(require("react"));
15
-
16
- var _styledComponents = _interopRequireWildcard(require("styled-components"));
17
-
18
- var _useTheme = _interopRequireDefault(require("../useTheme"));
19
-
20
- var _templateObject;
21
-
22
- 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); }
23
-
24
- function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
25
-
26
- var DxcBadge = function DxcBadge(_ref) {
27
- var notificationText = _ref.notificationText,
28
- disabled = _ref.disabled;
29
- var colorsTheme = (0, _useTheme["default"])();
30
- return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
31
- theme: colorsTheme.tabs
32
- }, /*#__PURE__*/_react["default"].createElement(StyledDxcBadge, {
33
- notificationText: notificationText,
34
- disabled: disabled
35
- }, /*#__PURE__*/_react["default"].createElement("span", null, notificationText)));
10
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
11
+ var _Flex = _interopRequireDefault(require("../flex/Flex"));
12
+ var _coreTokens = _interopRequireDefault(require("../common/coreTokens"));
13
+ var _Icon = _interopRequireDefault(require("../icon/Icon"));
14
+ var _templateObject, _templateObject2, _templateObject3;
15
+ var contextualColorMap = {
16
+ grey: {
17
+ background: _coreTokens["default"].color_grey_200,
18
+ text: _coreTokens["default"].color_grey_900
19
+ },
20
+ blue: {
21
+ background: _coreTokens["default"].color_blue_200,
22
+ text: _coreTokens["default"].color_blue_900
23
+ },
24
+ green: {
25
+ background: _coreTokens["default"].color_green_200,
26
+ text: _coreTokens["default"].color_green_900
27
+ },
28
+ orange: {
29
+ background: _coreTokens["default"].color_orange_200,
30
+ text: _coreTokens["default"].color_orange_900
31
+ },
32
+ red: {
33
+ background: _coreTokens["default"].color_red_200,
34
+ text: _coreTokens["default"].color_red_900
35
+ },
36
+ yellow: {
37
+ background: _coreTokens["default"].color_yellow_200,
38
+ text: _coreTokens["default"].color_yellow_900
39
+ },
40
+ purple: {
41
+ background: _coreTokens["default"].color_purple_200,
42
+ text: _coreTokens["default"].color_purple_900
43
+ }
36
44
  };
37
-
38
- var StyledDxcBadge = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n color: ", ";\n letter-spacing: ", ";\n width: ", ";\n height: ", ";\n border-radius: ", ";\n display: flex;\n padding-bottom: 1px;\n padding-right: 1px;\n flex-wrap: wrap;\n box-sizing: border-box;\n align-items: center;\n line-height: 1;\n align-content: center;\n flex-direction: row;\n justify-content: center;\n"])), function (props) {
39
- return props.disabled ? props.theme.disabledBadgeBackgroundColor : props.theme.badgeBackgroundColor;
40
- }, function (props) {
41
- return props.theme.badgeFontFamily;
45
+ var sizeMap = {
46
+ small: {
47
+ height: "20px",
48
+ width: "20px",
49
+ minWidth: "20px",
50
+ fontSize: _coreTokens["default"].type_scale_01,
51
+ borderRadius: _coreTokens["default"].spacing_12,
52
+ iconSize: "14px",
53
+ padding: {
54
+ contextual: "".concat(_coreTokens["default"].spacing_4),
55
+ notification: "".concat(_coreTokens["default"].spacing_0, " ").concat(_coreTokens["default"].spacing_4)
56
+ }
57
+ },
58
+ medium: {
59
+ height: "24px",
60
+ width: "24px",
61
+ minWidth: "24px",
62
+ fontSize: _coreTokens["default"].type_scale_02,
63
+ borderRadius: _coreTokens["default"].spacing_12,
64
+ iconSize: "16px",
65
+ padding: {
66
+ contextual: "".concat(_coreTokens["default"].spacing_4, " ").concat(_coreTokens["default"].spacing_8),
67
+ notification: "".concat(_coreTokens["default"].spacing_0, " ").concat(_coreTokens["default"].spacing_4)
68
+ }
69
+ },
70
+ large: {
71
+ height: "32px",
72
+ width: "32px",
73
+ minWidth: "32px",
74
+ fontSize: _coreTokens["default"].type_scale_04,
75
+ borderRadius: _coreTokens["default"].spacing_24,
76
+ iconSize: "24px",
77
+ padding: {
78
+ contextual: "".concat(_coreTokens["default"].spacing_4, " ").concat(_coreTokens["default"].spacing_8),
79
+ notification: "".concat(_coreTokens["default"].spacing_0, " ").concat(_coreTokens["default"].spacing_8)
80
+ }
81
+ }
82
+ };
83
+ var Label = function Label(_ref) {
84
+ var label = _ref.label,
85
+ notificationLimit = _ref.notificationLimit,
86
+ size = _ref.size;
87
+ return /*#__PURE__*/_react["default"].createElement(LabelContainer, {
88
+ size: size
89
+ }, typeof label === "number" ? label > notificationLimit ? "+" + notificationLimit : label : label);
90
+ };
91
+ var DxcBadge = function DxcBadge(_ref2) {
92
+ var label = _ref2.label,
93
+ title = _ref2.title,
94
+ _ref2$mode = _ref2.mode,
95
+ mode = _ref2$mode === void 0 ? "contextual" : _ref2$mode,
96
+ _ref2$color = _ref2.color,
97
+ color = _ref2$color === void 0 ? "grey" : _ref2$color,
98
+ icon = _ref2.icon,
99
+ _ref2$notificationLim = _ref2.notificationLimit,
100
+ notificationLimit = _ref2$notificationLim === void 0 ? 99 : _ref2$notificationLim,
101
+ _ref2$size = _ref2.size,
102
+ size = _ref2$size === void 0 ? "medium" : _ref2$size;
103
+ return /*#__PURE__*/_react["default"].createElement(BadgeContainer, {
104
+ label: label,
105
+ mode: mode,
106
+ color: mode === "contextual" && color || undefined,
107
+ size: size,
108
+ title: title,
109
+ "aria-label": title
110
+ }, mode === "contextual" && /*#__PURE__*/_react["default"].createElement(_Flex["default"], {
111
+ gap: "0.125rem",
112
+ alignItems: "center"
113
+ }, icon && /*#__PURE__*/_react["default"].createElement(IconContainer, {
114
+ size: size
115
+ }, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(_Icon["default"], {
116
+ icon: icon
117
+ }) : icon), /*#__PURE__*/_react["default"].createElement(Label, {
118
+ label: label,
119
+ notificationLimit: notificationLimit,
120
+ size: size
121
+ })) || /*#__PURE__*/_react["default"].createElement(Label, {
122
+ label: label,
123
+ notificationLimit: notificationLimit,
124
+ size: size
125
+ }));
126
+ };
127
+ var getColor = function getColor(mode, color) {
128
+ return mode === "contextual" ? contextualColorMap[color].text : _coreTokens["default"].color_white;
129
+ };
130
+ var getBackgroundColor = function getBackgroundColor(mode, color) {
131
+ return mode === "contextual" ? contextualColorMap[color].background : _coreTokens["default"].color_red_700;
132
+ };
133
+ var getPadding = function getPadding(mode, size) {
134
+ return mode === "contextual" ? sizeMap[size].padding.contextual : sizeMap[size].padding.notification;
135
+ };
136
+ var BadgeContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n color: ", ";\n background-color: ", ";\n border-radius: ", ";\n width: ", ";\n min-width: ", ";\n height: ", ";\n padding: ", ";\n align-items: center;\n justify-content: center;\n box-sizing: border-box;\n"])), function (props) {
137
+ return getColor(props.mode, props.color);
42
138
  }, function (props) {
43
- return props.theme.badgeFontSize;
139
+ return getBackgroundColor(props.mode, props.color);
44
140
  }, function (props) {
45
- return props.theme.badgeFontStyle;
141
+ return sizeMap[props.size].borderRadius;
46
142
  }, function (props) {
47
- return props.theme.badgeFontWeight;
143
+ return !props.label && props.mode === "notification" ? sizeMap[props.size].width : "fit-content";
48
144
  }, function (props) {
49
- return props.theme.badgeFontColor;
145
+ return props.mode === "notification" && sizeMap[props.size].minWidth;
50
146
  }, function (props) {
51
- return props.theme.badgeLetterSpacing;
147
+ return sizeMap[props.size].height;
52
148
  }, function (props) {
53
- return props.notificationText === true ? props.theme.badgeWidth : props.theme.badgeWidthWithNotificationNumber;
149
+ return props.label ? getPadding(props.mode, props.size) : "";
150
+ });
151
+ var IconContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n font-size: ", ";\n\n svg {\n height: ", ";\n width: ", ";\n }\n"])), function (props) {
152
+ return sizeMap[props.size].iconSize;
54
153
  }, function (props) {
55
- return props.notificationText === true ? props.theme.badgeHeight : props.theme.badgeHeightWithNotificationNumber;
154
+ return sizeMap[props.size].iconSize;
56
155
  }, function (props) {
57
- return props.notificationText === true ? props.theme.badgeRadius : props.theme.badgeRadiusWithNotificationNumber;
156
+ return sizeMap[props.size].iconSize;
58
157
  });
59
-
60
- var _default = DxcBadge;
61
- exports["default"] = _default;
158
+ var LabelContainer = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n white-space: nowrap;\n"])), _coreTokens["default"].type_sans, function (props) {
159
+ return sizeMap[props.size].fontSize;
160
+ }, _coreTokens["default"].type_semibold);
161
+ var _default = exports["default"] = DxcBadge;
@@ -0,0 +1,210 @@
1
+ import React from "react";
2
+ import DxcBadge from "./Badge";
3
+ import Title from "../../.storybook/components/Title";
4
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
5
+ import DxcFlex from "../flex/Flex";
6
+
7
+ export default {
8
+ title: "Badge",
9
+ component: DxcBadge,
10
+ };
11
+
12
+ const icon = (
13
+ <svg width="24" height="24" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg" fill="currentColor">
14
+ <path d="M11 17H13V11H11V17ZM12 2C6.48 2 2 6.48 2 12C2 17.52 6.48 22 12 22C17.52 22 22 17.52 22 12C22 6.48 17.52 2 12 2ZM12 20C7.59 20 4 16.41 4 12C4 7.59 7.59 4 12 4C16.41 4 20 7.59 20 12C20 16.41 16.41 20 12 20ZM11 9H13V7H11V9Z" />
15
+ <path d="M11 7H13V9H11V7ZM11 11H13V17H11V11Z" />
16
+ <path d="M12 2C6.48 2 2 6.48 2 12C2 17.52 6.48 22 12 22C17.52 22 22 17.52 22 12C22 6.48 17.52 2 12 2ZM12 20C7.59 20 4 16.41 4 12C4 7.59 7.59 4 12 4C16.41 4 20 7.59 20 12C20 16.41 16.41 20 12 20Z" />
17
+ </svg>
18
+ );
19
+
20
+ export const Chromatic = () => (
21
+ <>
22
+ <Title title="Notification" theme="light" level={2} />
23
+ <ExampleContainer>
24
+ <Title title="Small" theme="light" level={4} />
25
+ <DxcFlex gap="3rem" alignItems="center">
26
+ <DxcBadge mode="notification" size="small" />
27
+ <DxcBadge mode="notification" label={1} size="small" />
28
+ <DxcBadge mode="notification" label={10} size="small" />
29
+ <DxcBadge mode="notification" label={1000000} size="small" notificationLimit={99999999} />
30
+ <DxcBadge mode="notification" label={100} size="small" notificationLimit={99} />
31
+ </DxcFlex>
32
+ </ExampleContainer>
33
+ <ExampleContainer>
34
+ <Title title="Medium" theme="light" level={4} />
35
+ <DxcFlex gap="3rem" alignContent="center" alignItems="center">
36
+ <DxcBadge mode="notification" size="medium" />
37
+ <DxcBadge mode="notification" label={1} size="medium" />
38
+ <DxcBadge mode="notification" label={10} size="medium" />
39
+ <DxcBadge mode="notification" label={1000000} size="medium" notificationLimit={99999999} />
40
+ <DxcBadge mode="notification" label={100} size="medium" />
41
+ </DxcFlex>
42
+ </ExampleContainer>
43
+ <ExampleContainer>
44
+ <Title title="Large" theme="light" level={4} />
45
+ <DxcFlex gap="3rem" alignItems="center">
46
+ <DxcBadge mode="notification" size="large" />
47
+ <DxcBadge mode="notification" label={1} size="large" />
48
+ <DxcBadge mode="notification" label={10} size="large" />
49
+ <DxcBadge mode="notification" label={1000000} size="large" notificationLimit={99999999} />
50
+ <DxcBadge mode="notification" label={100} size="large" />
51
+ </DxcFlex>
52
+ </ExampleContainer>
53
+ <Title title="Contextual" theme="light" level={2} />
54
+ <Title title="Grey" theme="light" level={3} />
55
+ <ExampleContainer>
56
+ <Title title="Small" theme="light" level={4} />
57
+ <DxcFlex gap="3rem" alignItems="center">
58
+ <DxcBadge label="Label" size="small" />
59
+ <DxcBadge label="Label" size="small" icon={icon} />
60
+ </DxcFlex>
61
+ </ExampleContainer>
62
+ <ExampleContainer>
63
+ <Title title="Medium" theme="light" level={4} />
64
+ <DxcFlex gap="3rem" alignItems="center">
65
+ <DxcBadge label="Label" />
66
+ <DxcBadge label="Label" icon="done" />
67
+ </DxcFlex>
68
+ </ExampleContainer>
69
+ <ExampleContainer>
70
+ <Title title="Large" theme="light" level={4} />
71
+ <DxcFlex gap="3rem" alignItems="center">
72
+ <DxcBadge label="Label" size="large" />
73
+ <DxcBadge label="Label" size="large" icon="done" />
74
+ </DxcFlex>
75
+ </ExampleContainer>
76
+ <Title title="Blue" theme="light" level={3} />
77
+ <ExampleContainer>
78
+ <Title title="Small" theme="light" level={4} />
79
+ <DxcFlex gap="3rem" alignItems="center">
80
+ <DxcBadge color="blue" label="Label" size="small" />
81
+ <DxcBadge color="blue" label="Label" size="small" icon="done" />
82
+ </DxcFlex>
83
+ </ExampleContainer>
84
+ <ExampleContainer>
85
+ <Title title="Medium" theme="light" level={4} />
86
+ <DxcFlex gap="3rem" alignItems="center">
87
+ <DxcBadge color="blue" label="Label" />
88
+ <DxcBadge color="blue" label="Label" icon={icon} />
89
+ </DxcFlex>
90
+ </ExampleContainer>
91
+ <ExampleContainer>
92
+ <Title title="Large" theme="light" level={4} />
93
+ <DxcFlex gap="3rem" alignItems="center">
94
+ <DxcBadge color="blue" label="Label" size="large" />
95
+ <DxcBadge color="blue" label="Label" size="large" icon={icon} />
96
+ </DxcFlex>
97
+ </ExampleContainer>
98
+ <Title title="Green" theme="light" level={3} />
99
+ <ExampleContainer>
100
+ <Title title="Small" theme="light" level={4} />
101
+ <DxcFlex gap="3rem" alignItems="center">
102
+ <DxcBadge color="green" label="Label" size="small" />
103
+ <DxcBadge color="green" label="Label" size="small" icon="done" />
104
+ </DxcFlex>
105
+ </ExampleContainer>
106
+ <ExampleContainer>
107
+ <Title title="Medium" theme="light" level={4} />
108
+ <DxcFlex gap="3rem" alignItems="center">
109
+ <DxcBadge color="green" label="Label" />
110
+ <DxcBadge color="green" label="Label" icon="done" />
111
+ </DxcFlex>
112
+ </ExampleContainer>
113
+ <ExampleContainer>
114
+ <Title title="Large" theme="light" level={4} />
115
+ <DxcFlex gap="3rem" alignItems="center">
116
+ <DxcBadge color="green" label="Label" size="large" />
117
+ <DxcBadge color="green" label="Label" size="large" icon={icon} />
118
+ </DxcFlex>
119
+ </ExampleContainer>
120
+ <ExampleContainer></ExampleContainer>
121
+ <Title title="Orange" theme="light" level={3} />
122
+ <ExampleContainer>
123
+ <Title title="Small" theme="light" level={4} />
124
+ <DxcFlex gap="3rem" alignItems="center">
125
+ <DxcBadge color="orange" label="Label" size="small" />
126
+ <DxcBadge color="orange" label="Label" size="small" icon="done" />
127
+ </DxcFlex>
128
+ </ExampleContainer>
129
+ <ExampleContainer>
130
+ <Title title="Medium" theme="light" level={4} />
131
+ <DxcFlex gap="3rem" alignItems="center">
132
+ <DxcBadge color="orange" label="Label" />
133
+ <DxcBadge color="orange" label="Label" icon={icon} />
134
+ </DxcFlex>
135
+ </ExampleContainer>
136
+ <ExampleContainer>
137
+ <Title title="Large" theme="light" level={4} />
138
+ <DxcFlex gap="3rem" alignItems="center">
139
+ <DxcBadge color="orange" label="Label" size="large" />
140
+ <DxcBadge color="orange" label="Label" size="large" icon={icon} />
141
+ </DxcFlex>
142
+ </ExampleContainer>
143
+ <Title title="Red" theme="light" level={3} />
144
+ <ExampleContainer>
145
+ <Title title="Small" theme="light" level={4} />
146
+ <DxcFlex gap="3rem" alignItems="center">
147
+ <DxcBadge color="red" label="Label" size="small" />
148
+ <DxcBadge color="red" label="Label" size="small" icon="done" />
149
+ </DxcFlex>
150
+ </ExampleContainer>
151
+ <ExampleContainer>
152
+ <Title title="Medium" theme="light" level={4} />
153
+ <DxcFlex gap="3rem" alignItems="center">
154
+ <DxcBadge color="red" label="Label" />
155
+ <DxcBadge color="red" label="Label" icon="done" />
156
+ </DxcFlex>
157
+ </ExampleContainer>
158
+ <ExampleContainer>
159
+ <Title title="Large" theme="light" level={4} />
160
+ <DxcFlex gap="3rem" alignItems="center">
161
+ <DxcBadge color="red" label="Label" size="large" />
162
+ <DxcBadge color="red" label="Label" size="large" icon={icon} />
163
+ </DxcFlex>
164
+ </ExampleContainer>
165
+ <Title title="Yellow" theme="light" level={3} />
166
+ <ExampleContainer>
167
+ <Title title="Small" theme="light" level={4} />
168
+ <DxcFlex gap="3rem" alignItems="center">
169
+ <DxcBadge color="yellow" label="Label" size="small" />
170
+ <DxcBadge color="yellow" label="Label" size="small" icon="done" />
171
+ </DxcFlex>
172
+ </ExampleContainer>
173
+ <ExampleContainer>
174
+ <Title title="Medium" theme="light" level={4} />
175
+ <DxcFlex gap="3rem" alignItems="center">
176
+ <DxcBadge color="yellow" label="Label" />
177
+ <DxcBadge color="yellow" label="Label" icon={icon} />
178
+ </DxcFlex>
179
+ </ExampleContainer>
180
+ <ExampleContainer>
181
+ <Title title="Large" theme="light" level={4} />
182
+ <DxcFlex gap="3rem" alignItems="center">
183
+ <DxcBadge color="yellow" label="Label" size="large" />
184
+ <DxcBadge color="yellow" label="Label" size="large" icon="done" />
185
+ </DxcFlex>
186
+ </ExampleContainer>
187
+ <Title title="Purple" theme="light" level={3} />
188
+ <ExampleContainer>
189
+ <Title title="Small" theme="light" level={4} />
190
+ <DxcFlex gap="3rem" alignItems="center">
191
+ <DxcBadge color="purple" label="Label" size="small" />
192
+ <DxcBadge color="purple" label="Label" size="small" icon="done" />
193
+ </DxcFlex>
194
+ </ExampleContainer>
195
+ <ExampleContainer>
196
+ <Title title="Medium" theme="light" level={4} />
197
+ <DxcFlex gap="3rem" alignItems="center">
198
+ <DxcBadge color="purple" label="Label" />
199
+ <DxcBadge color="purple" label="Label" icon={icon} />
200
+ </DxcFlex>
201
+ </ExampleContainer>
202
+ <ExampleContainer>
203
+ <Title title="Large" theme="light" level={4} />
204
+ <DxcFlex gap="3rem" alignItems="center">
205
+ <DxcBadge color="purple" label="Label" size="large" />
206
+ <DxcBadge color="purple" label="Label" size="large" icon={icon} />
207
+ </DxcFlex>
208
+ </ExampleContainer>
209
+ </>
210
+ );
@@ -0,0 +1,30 @@
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 _Badge = _interopRequireDefault(require("./Badge.tsx"));
7
+ var _Flex = _interopRequireDefault(require("../flex/Flex.tsx"));
8
+ describe("Badge component tests", function () {
9
+ test("Badge renders with correct label when it is less than notification limit", function () {
10
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Badge["default"], {
11
+ label: 99,
12
+ mode: "notification"
13
+ })),
14
+ getByText = _render.getByText;
15
+ expect(getByText("99")).toBeTruthy();
16
+ });
17
+ test("Badge renders +99 as label when it is greater than notification limit", function () {
18
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Flex["default"], null, /*#__PURE__*/_react["default"].createElement(_Badge["default"], {
19
+ label: 120,
20
+ mode: "notification"
21
+ }), /*#__PURE__*/_react["default"].createElement(_Badge["default"], {
22
+ label: 11,
23
+ mode: "notification",
24
+ notificationLimit: 10
25
+ }))),
26
+ getByText = _render2.getByText;
27
+ expect(getByText("+99")).toBeTruthy();
28
+ expect(getByText("+10")).toBeTruthy();
29
+ });
30
+ });
package/badge/types.d.ts CHANGED
@@ -1,5 +1,54 @@
1
- declare type Props = {
2
- notificationText: boolean | number | string;
3
- disabled?: boolean;
1
+ /// <reference types="react" />
2
+ type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
3
+ export type ContextualProps = {
4
+ /**
5
+ * Text to be placed in the badge.
6
+ */
7
+ label: string;
8
+ /**
9
+ * The available badge modes.
10
+ */
11
+ mode?: "contextual";
12
+ /**
13
+ * In notification mode, if the number entered as label is greater that this notification limit, +99 will be shown. If not, the entered text will be shown as label.
14
+ */
15
+ notificationLimit?: never;
16
+ /**
17
+ * Affects the visual style of the badge. It can be used following semantic purposes or not.
18
+ */
19
+ color?: "grey" | "blue" | "green" | "orange" | "red" | "yellow" | "purple";
4
20
  };
21
+ export type NotificationProps = {
22
+ /**
23
+ * Text to be placed in the badge.
24
+ */
25
+ label?: number;
26
+ /**
27
+ * The available badge modes.
28
+ */
29
+ mode: "notification";
30
+ /**
31
+ * In notification mode, if the number entered as label is greater that this notification limit, +99 will be shown. If not, the entered text will be shown as label.
32
+ */
33
+ notificationLimit?: number;
34
+ /**
35
+ * Affects the visual style of the badge. It can be used following semantic purposes or not.
36
+ */
37
+ color?: never;
38
+ };
39
+ export type CommonProps = {
40
+ /**
41
+ * Text representing advisory information related to the badge. Under the hood, this prop also serves as an accessible label for the component.
42
+ */
43
+ title?: string;
44
+ /**
45
+ * Material Symbol name or SVG element used as the icon that will be placed next to the badge label in contextual mode.
46
+ */
47
+ icon?: string | SVG;
48
+ /**
49
+ * Size of the component.
50
+ */
51
+ size?: "small" | "medium" | "large";
52
+ };
53
+ type Props = (ContextualProps | NotificationProps) & CommonProps;
5
54
  export default Props;