@dxc-technology/halstack-react 0.0.0-f0d662d → 0.0.0-f18281d

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 (361) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +5 -22
  3. package/HalstackContext.d.ts +1237 -0
  4. package/HalstackContext.js +310 -0
  5. package/README.md +47 -0
  6. package/accordion/Accordion.d.ts +1 -1
  7. package/accordion/Accordion.js +117 -193
  8. package/accordion/Accordion.stories.tsx +103 -127
  9. package/accordion/Accordion.test.js +56 -0
  10. package/accordion/types.d.ts +11 -22
  11. package/accordion-group/AccordionGroup.d.ts +5 -4
  12. package/accordion-group/AccordionGroup.js +38 -107
  13. package/accordion-group/AccordionGroup.stories.tsx +95 -68
  14. package/accordion-group/AccordionGroup.test.js +98 -0
  15. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  16. package/accordion-group/AccordionGroupAccordion.js +31 -0
  17. package/accordion-group/types.d.ts +17 -22
  18. package/action-icon/ActionIcon.d.ts +4 -0
  19. package/action-icon/ActionIcon.js +47 -0
  20. package/action-icon/ActionIcon.stories.tsx +41 -0
  21. package/action-icon/ActionIcon.test.js +64 -0
  22. package/action-icon/types.d.ts +26 -0
  23. package/alert/Alert.js +23 -59
  24. package/alert/Alert.stories.tsx +28 -0
  25. package/alert/Alert.test.js +75 -0
  26. package/alert/types.d.ts +5 -5
  27. package/badge/Badge.d.ts +4 -0
  28. package/badge/Badge.js +142 -40
  29. package/badge/Badge.stories.tsx +210 -0
  30. package/badge/Badge.test.js +30 -0
  31. package/badge/types.d.ts +54 -0
  32. package/bleed/Bleed.js +14 -55
  33. package/bleed/Bleed.stories.tsx +95 -95
  34. package/bleed/types.d.ts +26 -2
  35. package/box/Box.d.ts +1 -1
  36. package/box/Box.js +30 -81
  37. package/box/Box.stories.tsx +38 -51
  38. package/box/Box.test.js +13 -0
  39. package/box/types.d.ts +3 -14
  40. package/bulleted-list/BulletedList.d.ts +7 -0
  41. package/bulleted-list/BulletedList.js +89 -0
  42. package/bulleted-list/BulletedList.stories.tsx +115 -0
  43. package/bulleted-list/types.d.ts +38 -0
  44. package/button/Button.d.ts +1 -1
  45. package/button/Button.js +62 -113
  46. package/button/Button.stories.tsx +160 -90
  47. package/button/Button.test.js +38 -0
  48. package/button/types.d.ts +12 -8
  49. package/card/Card.d.ts +1 -1
  50. package/card/Card.js +58 -102
  51. package/card/Card.stories.tsx +12 -42
  52. package/card/Card.test.js +39 -0
  53. package/card/types.d.ts +6 -11
  54. package/checkbox/Checkbox.d.ts +2 -2
  55. package/checkbox/Checkbox.js +144 -182
  56. package/checkbox/Checkbox.stories.tsx +166 -136
  57. package/checkbox/Checkbox.test.js +199 -0
  58. package/checkbox/types.d.ts +18 -6
  59. package/chip/Chip.d.ts +1 -1
  60. package/chip/Chip.js +46 -124
  61. package/chip/Chip.stories.tsx +123 -30
  62. package/chip/Chip.test.js +41 -0
  63. package/chip/types.d.ts +8 -16
  64. package/common/OpenSans.css +68 -80
  65. package/common/coreTokens.d.ts +237 -0
  66. package/common/coreTokens.js +184 -0
  67. package/common/utils.d.ts +1 -0
  68. package/common/utils.js +6 -12
  69. package/common/variables.d.ts +1383 -0
  70. package/common/variables.js +1017 -1374
  71. package/container/Container.d.ts +4 -0
  72. package/container/Container.js +194 -0
  73. package/container/Container.stories.tsx +214 -0
  74. package/container/types.d.ts +74 -0
  75. package/date-input/Calendar.d.ts +4 -0
  76. package/date-input/Calendar.js +214 -0
  77. package/date-input/DateInput.js +171 -306
  78. package/date-input/DateInput.stories.tsx +203 -56
  79. package/date-input/DateInput.test.js +808 -0
  80. package/date-input/DatePicker.d.ts +4 -0
  81. package/date-input/DatePicker.js +115 -0
  82. package/date-input/Icons.d.ts +6 -0
  83. package/date-input/Icons.js +58 -0
  84. package/date-input/YearPicker.d.ts +4 -0
  85. package/date-input/YearPicker.js +100 -0
  86. package/date-input/types.d.ts +86 -22
  87. package/dialog/Dialog.d.ts +1 -1
  88. package/dialog/Dialog.js +68 -130
  89. package/dialog/Dialog.stories.tsx +320 -167
  90. package/dialog/Dialog.test.js +307 -0
  91. package/dialog/types.d.ts +18 -25
  92. package/dropdown/Dropdown.d.ts +1 -1
  93. package/dropdown/Dropdown.js +249 -330
  94. package/dropdown/Dropdown.stories.tsx +255 -64
  95. package/dropdown/Dropdown.test.js +599 -0
  96. package/dropdown/DropdownMenu.d.ts +4 -0
  97. package/dropdown/DropdownMenu.js +63 -0
  98. package/dropdown/DropdownMenuItem.d.ts +4 -0
  99. package/dropdown/DropdownMenuItem.js +67 -0
  100. package/dropdown/types.d.ts +36 -27
  101. package/file-input/FileInput.d.ts +2 -2
  102. package/file-input/FileInput.js +246 -357
  103. package/file-input/FileInput.stories.tsx +123 -12
  104. package/file-input/FileInput.test.js +459 -0
  105. package/file-input/FileItem.d.ts +4 -14
  106. package/file-input/FileItem.js +50 -99
  107. package/file-input/types.d.ts +25 -8
  108. package/flex/Flex.d.ts +4 -0
  109. package/flex/Flex.js +57 -0
  110. package/flex/Flex.stories.tsx +112 -0
  111. package/flex/types.d.ts +97 -0
  112. package/footer/Footer.d.ts +1 -1
  113. package/footer/Footer.js +70 -190
  114. package/footer/Footer.stories.tsx +60 -19
  115. package/footer/Footer.test.js +85 -0
  116. package/footer/Icons.d.ts +3 -2
  117. package/footer/Icons.js +67 -8
  118. package/footer/types.d.ts +25 -26
  119. package/grid/Grid.d.ts +7 -0
  120. package/grid/Grid.js +76 -0
  121. package/grid/Grid.stories.tsx +219 -0
  122. package/grid/types.d.ts +115 -0
  123. package/header/Header.d.ts +4 -3
  124. package/header/Header.js +99 -203
  125. package/header/Header.stories.tsx +152 -63
  126. package/header/Header.test.js +66 -0
  127. package/header/Icons.d.ts +2 -2
  128. package/header/Icons.js +4 -9
  129. package/header/types.d.ts +5 -19
  130. package/heading/Heading.js +10 -32
  131. package/heading/Heading.test.js +169 -0
  132. package/heading/types.d.ts +7 -7
  133. package/image/Image.d.ts +4 -0
  134. package/image/Image.js +70 -0
  135. package/image/Image.stories.tsx +127 -0
  136. package/image/types.d.ts +72 -0
  137. package/image/types.js +5 -0
  138. package/inset/Inset.js +14 -55
  139. package/inset/Inset.stories.tsx +37 -36
  140. package/inset/types.d.ts +26 -2
  141. package/layout/ApplicationLayout.d.ts +16 -6
  142. package/layout/ApplicationLayout.js +83 -174
  143. package/layout/ApplicationLayout.stories.tsx +85 -94
  144. package/layout/Icons.d.ts +8 -0
  145. package/layout/Icons.js +51 -48
  146. package/layout/SidenavContext.d.ts +5 -0
  147. package/layout/SidenavContext.js +13 -0
  148. package/layout/types.d.ts +19 -35
  149. package/link/Link.d.ts +3 -2
  150. package/link/Link.js +64 -110
  151. package/link/Link.stories.tsx +159 -52
  152. package/link/Link.test.js +63 -0
  153. package/link/types.d.ts +15 -35
  154. package/main.d.ts +17 -18
  155. package/main.js +68 -120
  156. package/nav-tabs/NavTabs.d.ts +8 -0
  157. package/nav-tabs/NavTabs.js +93 -0
  158. package/nav-tabs/NavTabs.stories.tsx +276 -0
  159. package/nav-tabs/NavTabs.test.js +76 -0
  160. package/nav-tabs/Tab.d.ts +4 -0
  161. package/nav-tabs/Tab.js +118 -0
  162. package/nav-tabs/types.d.ts +52 -0
  163. package/nav-tabs/types.js +5 -0
  164. package/number-input/NumberInput.d.ts +7 -0
  165. package/number-input/NumberInput.js +27 -43
  166. package/number-input/NumberInput.stories.tsx +44 -28
  167. package/number-input/NumberInput.test.js +830 -0
  168. package/number-input/types.d.ts +28 -15
  169. package/package.json +46 -47
  170. package/paginator/Icons.d.ts +5 -0
  171. package/paginator/Icons.js +21 -47
  172. package/paginator/Paginator.js +34 -91
  173. package/paginator/Paginator.stories.tsx +24 -0
  174. package/paginator/Paginator.test.js +335 -0
  175. package/paginator/types.d.ts +3 -3
  176. package/paragraph/Paragraph.d.ts +5 -0
  177. package/paragraph/Paragraph.js +22 -0
  178. package/paragraph/Paragraph.stories.tsx +27 -0
  179. package/password-input/Icons.d.ts +6 -0
  180. package/password-input/Icons.js +35 -0
  181. package/password-input/PasswordInput.js +57 -123
  182. package/password-input/PasswordInput.stories.tsx +1 -33
  183. package/password-input/PasswordInput.test.js +198 -0
  184. package/password-input/types.d.ts +21 -17
  185. package/progress-bar/ProgressBar.js +65 -91
  186. package/progress-bar/ProgressBar.stories.tsx +93 -0
  187. package/progress-bar/ProgressBar.test.js +93 -0
  188. package/progress-bar/types.d.ts +3 -3
  189. package/quick-nav/QuickNav.d.ts +4 -0
  190. package/quick-nav/QuickNav.js +94 -0
  191. package/quick-nav/QuickNav.stories.tsx +356 -0
  192. package/quick-nav/types.d.ts +21 -0
  193. package/quick-nav/types.js +5 -0
  194. package/radio-group/Radio.d.ts +1 -1
  195. package/radio-group/Radio.js +64 -80
  196. package/radio-group/RadioGroup.js +101 -139
  197. package/radio-group/RadioGroup.stories.tsx +171 -36
  198. package/radio-group/RadioGroup.test.js +691 -183
  199. package/radio-group/types.d.ts +89 -11
  200. package/resultset-table/Icons.d.ts +7 -0
  201. package/resultset-table/Icons.js +47 -0
  202. package/resultset-table/ResultsetTable.d.ts +7 -0
  203. package/resultset-table/ResultsetTable.js +167 -0
  204. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +136 -30
  205. package/resultset-table/ResultsetTable.test.js +371 -0
  206. package/{resultsetTable → resultset-table}/types.d.ts +13 -7
  207. package/resultset-table/types.js +5 -0
  208. package/select/Icons.d.ts +10 -0
  209. package/select/Icons.js +89 -0
  210. package/select/Listbox.d.ts +4 -0
  211. package/select/Listbox.js +143 -0
  212. package/select/Option.d.ts +4 -0
  213. package/select/Option.js +87 -0
  214. package/select/Select.js +229 -502
  215. package/select/Select.stories.tsx +603 -204
  216. package/select/Select.test.js +2370 -0
  217. package/select/types.d.ts +64 -25
  218. package/sidenav/Icons.d.ts +7 -0
  219. package/sidenav/Icons.js +47 -0
  220. package/sidenav/Sidenav.d.ts +6 -5
  221. package/sidenav/Sidenav.js +131 -71
  222. package/sidenav/Sidenav.stories.tsx +251 -151
  223. package/sidenav/Sidenav.test.js +37 -0
  224. package/sidenav/types.d.ts +52 -26
  225. package/slider/Slider.d.ts +2 -2
  226. package/slider/Slider.js +148 -180
  227. package/slider/Slider.test.js +254 -0
  228. package/slider/types.d.ts +11 -3
  229. package/spinner/Spinner.js +31 -75
  230. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
  231. package/spinner/Spinner.test.js +55 -0
  232. package/spinner/types.d.ts +3 -3
  233. package/status-light/StatusLight.d.ts +4 -0
  234. package/status-light/StatusLight.js +51 -0
  235. package/status-light/StatusLight.stories.tsx +74 -0
  236. package/status-light/StatusLight.test.js +25 -0
  237. package/status-light/types.d.ts +17 -0
  238. package/status-light/types.js +5 -0
  239. package/switch/Switch.d.ts +2 -2
  240. package/switch/Switch.js +149 -114
  241. package/switch/Switch.stories.tsx +44 -67
  242. package/switch/Switch.test.js +180 -0
  243. package/switch/types.d.ts +13 -5
  244. package/table/ActionsCell.d.ts +4 -0
  245. package/table/ActionsCell.js +54 -0
  246. package/table/DropdownTheme.js +57 -0
  247. package/table/Table.d.ts +4 -1
  248. package/table/Table.js +27 -32
  249. package/table/Table.stories.tsx +615 -0
  250. package/table/Table.test.js +113 -0
  251. package/table/types.d.ts +45 -6
  252. package/tabs/Tab.d.ts +4 -0
  253. package/tabs/Tab.js +116 -0
  254. package/tabs/Tabs.d.ts +1 -1
  255. package/tabs/Tabs.js +316 -145
  256. package/tabs/Tabs.stories.tsx +120 -14
  257. package/tabs/Tabs.test.js +294 -0
  258. package/tabs/types.d.ts +29 -15
  259. package/tag/Tag.d.ts +1 -1
  260. package/tag/Tag.js +43 -85
  261. package/tag/Tag.stories.tsx +37 -27
  262. package/tag/Tag.test.js +49 -0
  263. package/tag/types.d.ts +25 -16
  264. package/text-input/Icons.d.ts +8 -0
  265. package/text-input/Icons.js +56 -0
  266. package/text-input/Suggestion.d.ts +4 -0
  267. package/text-input/Suggestion.js +67 -0
  268. package/text-input/Suggestions.d.ts +4 -0
  269. package/text-input/Suggestions.js +84 -0
  270. package/text-input/TextInput.js +326 -548
  271. package/text-input/TextInput.stories.tsx +281 -272
  272. package/text-input/TextInput.test.js +1739 -0
  273. package/text-input/types.d.ts +70 -24
  274. package/textarea/Textarea.js +85 -135
  275. package/textarea/Textarea.stories.tsx +174 -0
  276. package/textarea/Textarea.test.js +406 -0
  277. package/textarea/types.d.ts +27 -16
  278. package/toggle-group/ToggleGroup.d.ts +2 -2
  279. package/toggle-group/ToggleGroup.js +92 -105
  280. package/toggle-group/ToggleGroup.stories.tsx +53 -8
  281. package/toggle-group/ToggleGroup.test.js +137 -0
  282. package/toggle-group/types.d.ts +34 -17
  283. package/typography/Typography.d.ts +4 -0
  284. package/typography/Typography.js +23 -0
  285. package/typography/Typography.stories.tsx +198 -0
  286. package/typography/types.d.ts +18 -0
  287. package/typography/types.js +5 -0
  288. package/useTheme.d.ts +1135 -1
  289. package/useTheme.js +4 -11
  290. package/useTranslatedLabels.d.ts +85 -0
  291. package/useTranslatedLabels.js +14 -0
  292. package/utils/BaseTypography.d.ts +21 -0
  293. package/utils/BaseTypography.js +94 -0
  294. package/utils/FocusLock.d.ts +13 -0
  295. package/utils/FocusLock.js +124 -0
  296. package/wizard/Wizard.d.ts +1 -1
  297. package/wizard/Wizard.js +70 -101
  298. package/wizard/Wizard.stories.tsx +48 -19
  299. package/wizard/Wizard.test.js +114 -0
  300. package/wizard/types.d.ts +12 -8
  301. package/ThemeContext.d.ts +0 -15
  302. package/ThemeContext.js +0 -243
  303. package/V3Select/V3Select.js +0 -455
  304. package/V3Select/index.d.ts +0 -27
  305. package/V3Textarea/V3Textarea.js +0 -260
  306. package/V3Textarea/index.d.ts +0 -27
  307. package/card/ice-cream.jpg +0 -0
  308. package/common/RequiredComponent.js +0 -32
  309. package/date/Date.js +0 -373
  310. package/date/index.d.ts +0 -27
  311. package/input-text/Icons.js +0 -22
  312. package/input-text/InputText.js +0 -611
  313. package/input-text/index.d.ts +0 -36
  314. package/list/List.d.ts +0 -4
  315. package/list/List.js +0 -47
  316. package/list/List.stories.tsx +0 -95
  317. package/list/types.d.ts +0 -7
  318. package/number-input/NumberInputContext.d.ts +0 -4
  319. package/number-input/NumberInputContext.js +0 -19
  320. package/number-input/numberInputContextTypes.d.ts +0 -19
  321. package/progress-bar/ProgressBar.stories.jsx +0 -58
  322. package/radio/Radio.d.ts +0 -4
  323. package/radio/Radio.js +0 -174
  324. package/radio/Radio.stories.tsx +0 -192
  325. package/radio/types.d.ts +0 -54
  326. package/resultsetTable/ResultsetTable.d.ts +0 -4
  327. package/resultsetTable/ResultsetTable.js +0 -251
  328. package/row/Row.d.ts +0 -3
  329. package/row/Row.js +0 -127
  330. package/row/Row.stories.tsx +0 -237
  331. package/row/types.d.ts +0 -10
  332. package/slider/Slider.stories.tsx +0 -177
  333. package/stack/Stack.d.ts +0 -3
  334. package/stack/Stack.js +0 -97
  335. package/stack/Stack.stories.tsx +0 -164
  336. package/stack/types.d.ts +0 -9
  337. package/table/Table.stories.jsx +0 -277
  338. package/text/Text.d.ts +0 -7
  339. package/text/Text.js +0 -30
  340. package/text/Text.stories.tsx +0 -19
  341. package/textarea/Textarea.stories.jsx +0 -136
  342. package/toggle/Toggle.js +0 -186
  343. package/toggle/index.d.ts +0 -21
  344. package/upload/Upload.js +0 -201
  345. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  346. package/upload/buttons-upload/Icons.js +0 -40
  347. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  348. package/upload/dragAndDropArea/Icons.js +0 -39
  349. package/upload/file-upload/FileToUpload.js +0 -115
  350. package/upload/file-upload/Icons.js +0 -66
  351. package/upload/files-upload/FilesToUpload.js +0 -109
  352. package/upload/index.d.ts +0 -15
  353. package/upload/transaction/Icons.js +0 -160
  354. package/upload/transaction/Transaction.js +0 -104
  355. package/upload/transactions/Transactions.js +0 -94
  356. /package/{list → action-icon}/types.js +0 -0
  357. /package/{radio → badge}/types.js +0 -0
  358. /package/{resultsetTable → bulleted-list}/types.js +0 -0
  359. /package/{row → container}/types.js +0 -0
  360. /package/{stack → flex}/types.js +0 -0
  361. /package/{number-input/numberInputContextTypes.js → grid/types.js} +0 -0
@@ -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="medium" 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={icon} />
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={icon} />
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={icon} />
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={icon} />
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={icon} />
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={icon} />
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={icon} />
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={icon} />
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={icon} />
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={icon} />
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={icon} />
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
+ });
@@ -0,0 +1,54 @@
1
+ /// <reference types="react" />
2
+ type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
3
+ 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";
20
+ };
21
+ 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
+ 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
+ * Element or path 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;
54
+ export default Props;
package/bleed/Bleed.js CHANGED
@@ -1,29 +1,23 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  Object.defineProperty(exports, "__esModule", {
6
5
  value: true
7
6
  });
8
7
  exports["default"] = Bleed;
9
-
10
8
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
11
-
12
9
  var _react = _interopRequireDefault(require("react"));
13
-
14
10
  var _styledComponents = _interopRequireDefault(require("styled-components"));
15
-
16
11
  var _templateObject;
17
-
18
12
  function Bleed(_ref) {
19
13
  var space = _ref.space,
20
- horizontal = _ref.horizontal,
21
- vertical = _ref.vertical,
22
- top = _ref.top,
23
- right = _ref.right,
24
- bottom = _ref.bottom,
25
- left = _ref.left,
26
- children = _ref.children;
14
+ horizontal = _ref.horizontal,
15
+ vertical = _ref.vertical,
16
+ top = _ref.top,
17
+ right = _ref.right,
18
+ bottom = _ref.bottom,
19
+ left = _ref.left,
20
+ children = _ref.children;
27
21
  return /*#__PURE__*/_react["default"].createElement(StyledBleed, {
28
22
  space: space,
29
23
  horizontal: horizontal,
@@ -34,51 +28,16 @@ function Bleed(_ref) {
34
28
  left: left
35
29
  }, children);
36
30
  }
37
-
38
31
  function getSpacingValue(spacingName) {
39
- switch (spacingName) {
40
- case "none":
41
- return "0rem";
42
-
43
- case "xxxsmall":
44
- return "0.125rem";
45
-
46
- case "xxsmall":
47
- return "0.25rem";
48
-
49
- case "xsmall":
50
- return "0.5rem";
51
-
52
- case "small":
53
- return "1rem";
54
-
55
- case "medium":
56
- return "1.5rem";
57
-
58
- case "large":
59
- return "2rem";
60
-
61
- case "xlarge":
62
- return "3rem";
63
-
64
- case "xxlarge":
65
- return "4rem";
66
-
67
- case "xxxlarge":
68
- return "5rem";
69
-
70
- default:
71
- return "0rem";
72
- }
32
+ return spacingName ? spacingName : "0rem";
73
33
  }
74
-
75
34
  var StyledBleed = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n ", "\n"])), function (_ref2) {
76
35
  var space = _ref2.space,
77
- horizontal = _ref2.horizontal,
78
- vertical = _ref2.vertical,
79
- top = _ref2.top,
80
- right = _ref2.right,
81
- bottom = _ref2.bottom,
82
- left = _ref2.left;
36
+ horizontal = _ref2.horizontal,
37
+ vertical = _ref2.vertical,
38
+ top = _ref2.top,
39
+ right = _ref2.right,
40
+ bottom = _ref2.bottom,
41
+ left = _ref2.left;
83
42
  return "\n margin: -".concat(getSpacingValue(top || vertical || space), " -").concat(getSpacingValue(right || horizontal || space), " -").concat(getSpacingValue(bottom || vertical || space), " -").concat(getSpacingValue(left || horizontal || space), ";\n");
84
43
  });