@dxc-technology/halstack-react 0.0.0-f64ebd5 → 0.0.0-f70a97e

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 (551) hide show
  1. package/BackgroundColorContext.d.ts +1 -0
  2. package/BackgroundColorContext.js +30 -0
  3. package/HalstackContext.d.ts +1249 -0
  4. package/HalstackContext.js +310 -0
  5. package/README.md +28 -47
  6. package/accordion/Accordion.d.ts +4 -0
  7. package/accordion/Accordion.js +182 -0
  8. package/accordion/Accordion.stories.tsx +283 -0
  9. package/accordion/Accordion.test.js +56 -0
  10. package/accordion/types.d.ts +57 -0
  11. package/accordion/types.js +5 -0
  12. package/accordion-group/AccordionGroup.d.ts +8 -0
  13. package/accordion-group/AccordionGroup.js +101 -0
  14. package/accordion-group/AccordionGroup.stories.tsx +252 -0
  15. package/accordion-group/AccordionGroup.test.js +98 -0
  16. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  17. package/accordion-group/AccordionGroupAccordion.js +31 -0
  18. package/accordion-group/types.d.ts +67 -0
  19. package/accordion-group/types.js +5 -0
  20. package/action-icon/ActionIcon.d.ts +4 -0
  21. package/action-icon/ActionIcon.js +47 -0
  22. package/action-icon/ActionIcon.stories.tsx +41 -0
  23. package/action-icon/ActionIcon.test.js +64 -0
  24. package/action-icon/types.d.ts +26 -0
  25. package/action-icon/types.js +5 -0
  26. package/alert/Alert.d.ts +4 -0
  27. package/alert/Alert.js +254 -0
  28. package/alert/Alert.stories.tsx +198 -0
  29. package/alert/Alert.test.js +75 -0
  30. package/alert/types.d.ts +49 -0
  31. package/alert/types.js +5 -0
  32. package/badge/Badge.d.ts +4 -0
  33. package/badge/Badge.js +159 -0
  34. package/badge/Badge.stories.tsx +210 -0
  35. package/badge/Badge.test.js +30 -0
  36. package/badge/types.d.ts +54 -0
  37. package/badge/types.js +5 -0
  38. package/bleed/Bleed.d.ts +3 -0
  39. package/bleed/Bleed.js +43 -0
  40. package/bleed/Bleed.stories.tsx +342 -0
  41. package/bleed/types.d.ts +37 -0
  42. package/bleed/types.js +5 -0
  43. package/box/Box.d.ts +4 -0
  44. package/box/Box.js +75 -0
  45. package/box/Box.stories.tsx +119 -0
  46. package/box/Box.test.js +13 -0
  47. package/box/types.d.ts +32 -0
  48. package/box/types.js +5 -0
  49. package/bulleted-list/BulletedList.d.ts +7 -0
  50. package/bulleted-list/BulletedList.js +89 -0
  51. package/bulleted-list/BulletedList.stories.tsx +115 -0
  52. package/bulleted-list/types.d.ts +38 -0
  53. package/bulleted-list/types.js +5 -0
  54. package/button/Button.d.ts +4 -0
  55. package/button/Button.js +121 -0
  56. package/button/Button.stories.tsx +326 -0
  57. package/button/Button.test.js +38 -0
  58. package/button/types.d.ts +57 -0
  59. package/button/types.js +5 -0
  60. package/card/Card.d.ts +4 -0
  61. package/card/Card.js +120 -0
  62. package/card/Card.stories.tsx +171 -0
  63. package/card/Card.test.js +39 -0
  64. package/card/types.d.ts +62 -0
  65. package/card/types.js +5 -0
  66. package/checkbox/Checkbox.d.ts +4 -0
  67. package/checkbox/Checkbox.js +215 -0
  68. package/checkbox/Checkbox.stories.tsx +222 -0
  69. package/checkbox/Checkbox.test.js +199 -0
  70. package/checkbox/types.d.ts +72 -0
  71. package/checkbox/types.js +5 -0
  72. package/chip/Chip.d.ts +4 -0
  73. package/chip/Chip.js +121 -0
  74. package/chip/Chip.stories.tsx +214 -0
  75. package/chip/Chip.test.js +41 -0
  76. package/chip/types.d.ts +45 -0
  77. package/chip/types.js +5 -0
  78. package/common/coreTokens.d.ts +237 -0
  79. package/common/coreTokens.js +184 -0
  80. package/common/utils.d.ts +1 -0
  81. package/common/utils.js +16 -0
  82. package/common/variables.d.ts +1395 -0
  83. package/common/variables.js +1267 -0
  84. package/container/Container.d.ts +4 -0
  85. package/container/Container.js +194 -0
  86. package/container/Container.stories.tsx +214 -0
  87. package/container/types.d.ts +74 -0
  88. package/container/types.js +5 -0
  89. package/contextual-menu/ContextualMenu.d.ts +7 -0
  90. package/contextual-menu/ContextualMenu.js +71 -0
  91. package/contextual-menu/ContextualMenu.stories.tsx +182 -0
  92. package/contextual-menu/ContextualMenu.test.js +71 -0
  93. package/contextual-menu/MenuItemAction.d.ts +4 -0
  94. package/contextual-menu/MenuItemAction.js +46 -0
  95. package/contextual-menu/types.d.ts +22 -0
  96. package/contextual-menu/types.js +5 -0
  97. package/date-input/Calendar.d.ts +4 -0
  98. package/date-input/Calendar.js +214 -0
  99. package/date-input/DateInput.d.ts +4 -0
  100. package/date-input/DateInput.js +223 -0
  101. package/date-input/DateInput.stories.tsx +285 -0
  102. package/date-input/DateInput.test.js +808 -0
  103. package/date-input/DatePicker.d.ts +4 -0
  104. package/date-input/DatePicker.js +115 -0
  105. package/date-input/Icons.d.ts +6 -0
  106. package/date-input/Icons.js +58 -0
  107. package/date-input/YearPicker.d.ts +4 -0
  108. package/date-input/YearPicker.js +100 -0
  109. package/date-input/types.d.ts +164 -0
  110. package/date-input/types.js +5 -0
  111. package/dialog/Dialog.d.ts +4 -0
  112. package/dialog/Dialog.js +104 -0
  113. package/dialog/Dialog.stories.tsx +365 -0
  114. package/dialog/Dialog.test.js +307 -0
  115. package/dialog/types.d.ts +36 -0
  116. package/dialog/types.js +5 -0
  117. package/divider/Divider.d.ts +4 -0
  118. package/divider/Divider.js +36 -0
  119. package/divider/Divider.stories.tsx +223 -0
  120. package/divider/Divider.test.js +38 -0
  121. package/divider/types.d.ts +19 -0
  122. package/divider/types.js +5 -0
  123. package/dropdown/Dropdown.d.ts +4 -0
  124. package/dropdown/Dropdown.js +336 -0
  125. package/dropdown/Dropdown.stories.tsx +438 -0
  126. package/dropdown/Dropdown.test.js +599 -0
  127. package/dropdown/DropdownMenu.d.ts +4 -0
  128. package/dropdown/DropdownMenu.js +63 -0
  129. package/dropdown/DropdownMenuItem.d.ts +4 -0
  130. package/dropdown/DropdownMenuItem.js +67 -0
  131. package/dropdown/types.d.ts +98 -0
  132. package/dropdown/types.js +5 -0
  133. package/file-input/FileInput.d.ts +4 -0
  134. package/file-input/FileInput.js +479 -0
  135. package/file-input/FileInput.stories.tsx +618 -0
  136. package/file-input/FileInput.test.js +459 -0
  137. package/file-input/FileItem.d.ts +4 -0
  138. package/file-input/FileItem.js +135 -0
  139. package/file-input/types.d.ts +129 -0
  140. package/file-input/types.js +5 -0
  141. package/flex/Flex.d.ts +4 -0
  142. package/flex/Flex.js +57 -0
  143. package/flex/Flex.stories.tsx +112 -0
  144. package/flex/types.d.ts +97 -0
  145. package/flex/types.js +5 -0
  146. package/footer/Footer.d.ts +4 -0
  147. package/footer/Footer.js +138 -0
  148. package/footer/Footer.stories.tsx +171 -0
  149. package/footer/Footer.test.js +85 -0
  150. package/footer/Icons.d.ts +3 -0
  151. package/footer/Icons.js +136 -0
  152. package/footer/types.d.ts +64 -0
  153. package/footer/types.js +5 -0
  154. package/grid/Grid.d.ts +7 -0
  155. package/grid/Grid.js +76 -0
  156. package/grid/Grid.stories.tsx +219 -0
  157. package/grid/types.d.ts +115 -0
  158. package/grid/types.js +5 -0
  159. package/header/Header.d.ts +8 -0
  160. package/header/Header.js +220 -0
  161. package/header/Header.stories.tsx +251 -0
  162. package/header/Header.test.js +66 -0
  163. package/header/Icons.d.ts +2 -0
  164. package/header/Icons.js +29 -0
  165. package/header/types.d.ts +33 -0
  166. package/header/types.js +5 -0
  167. package/heading/Heading.d.ts +4 -0
  168. package/heading/Heading.js +137 -0
  169. package/heading/Heading.stories.tsx +54 -0
  170. package/heading/Heading.test.js +169 -0
  171. package/heading/types.d.ts +33 -0
  172. package/heading/types.js +5 -0
  173. package/icon/Icon.d.ts +4 -0
  174. package/icon/Icon.js +33 -0
  175. package/icon/Icon.stories.tsx +26 -0
  176. package/icon/types.d.ts +4 -0
  177. package/icon/types.js +5 -0
  178. package/image/Image.d.ts +4 -0
  179. package/image/Image.js +70 -0
  180. package/image/Image.stories.tsx +129 -0
  181. package/image/types.d.ts +72 -0
  182. package/image/types.js +5 -0
  183. package/inset/Inset.d.ts +3 -0
  184. package/inset/Inset.js +43 -0
  185. package/inset/Inset.stories.tsx +230 -0
  186. package/inset/types.d.ts +37 -0
  187. package/inset/types.js +5 -0
  188. package/layout/ApplicationLayout.d.ts +20 -0
  189. package/layout/ApplicationLayout.js +134 -0
  190. package/layout/ApplicationLayout.stories.tsx +162 -0
  191. package/layout/Icons.d.ts +8 -0
  192. package/layout/Icons.js +58 -0
  193. package/layout/SidenavContext.d.ts +5 -0
  194. package/layout/SidenavContext.js +13 -0
  195. package/layout/types.d.ts +41 -0
  196. package/layout/types.js +5 -0
  197. package/link/Link.d.ts +4 -0
  198. package/link/Link.js +115 -0
  199. package/link/Link.stories.tsx +253 -0
  200. package/link/Link.test.js +63 -0
  201. package/link/types.d.ts +54 -0
  202. package/link/types.js +5 -0
  203. package/main.d.ts +49 -0
  204. package/main.js +357 -0
  205. package/nav-tabs/NavTabs.d.ts +8 -0
  206. package/nav-tabs/NavTabs.js +93 -0
  207. package/nav-tabs/NavTabs.stories.tsx +276 -0
  208. package/nav-tabs/NavTabs.test.js +76 -0
  209. package/nav-tabs/Tab.d.ts +4 -0
  210. package/nav-tabs/Tab.js +118 -0
  211. package/nav-tabs/types.d.ts +52 -0
  212. package/nav-tabs/types.js +5 -0
  213. package/number-input/NumberInput.d.ts +11 -0
  214. package/number-input/NumberInput.js +86 -0
  215. package/number-input/NumberInput.stories.tsx +131 -0
  216. package/number-input/NumberInput.test.js +989 -0
  217. package/number-input/types.d.ts +130 -0
  218. package/number-input/types.js +5 -0
  219. package/package.json +60 -44
  220. package/paginator/Icons.d.ts +5 -0
  221. package/paginator/Icons.js +40 -0
  222. package/paginator/Paginator.d.ts +4 -0
  223. package/paginator/Paginator.js +135 -0
  224. package/paginator/Paginator.stories.tsx +87 -0
  225. package/paginator/Paginator.test.js +335 -0
  226. package/paginator/types.d.ts +38 -0
  227. package/paginator/types.js +5 -0
  228. package/paragraph/Paragraph.d.ts +5 -0
  229. package/paragraph/Paragraph.js +22 -0
  230. package/paragraph/Paragraph.stories.tsx +27 -0
  231. package/password-input/Icons.d.ts +6 -0
  232. package/password-input/Icons.js +35 -0
  233. package/password-input/PasswordInput.d.ts +4 -0
  234. package/password-input/PasswordInput.js +97 -0
  235. package/password-input/PasswordInput.stories.tsx +99 -0
  236. package/password-input/PasswordInput.test.js +198 -0
  237. package/password-input/types.d.ts +111 -0
  238. package/password-input/types.js +5 -0
  239. package/progress-bar/ProgressBar.d.ts +4 -0
  240. package/progress-bar/ProgressBar.js +144 -0
  241. package/progress-bar/ProgressBar.stories.tsx +93 -0
  242. package/progress-bar/ProgressBar.test.js +93 -0
  243. package/progress-bar/types.d.ts +37 -0
  244. package/progress-bar/types.js +5 -0
  245. package/quick-nav/QuickNav.d.ts +4 -0
  246. package/quick-nav/QuickNav.js +94 -0
  247. package/quick-nav/QuickNav.stories.tsx +356 -0
  248. package/quick-nav/types.d.ts +21 -0
  249. package/quick-nav/types.js +5 -0
  250. package/radio-group/Radio.d.ts +4 -0
  251. package/radio-group/Radio.js +124 -0
  252. package/radio-group/RadioGroup.d.ts +4 -0
  253. package/radio-group/RadioGroup.js +235 -0
  254. package/radio-group/RadioGroup.stories.tsx +214 -0
  255. package/radio-group/RadioGroup.test.js +756 -0
  256. package/radio-group/types.d.ts +114 -0
  257. package/radio-group/types.js +5 -0
  258. package/resultset-table/Icons.d.ts +7 -0
  259. package/resultset-table/Icons.js +47 -0
  260. package/resultset-table/ResultsetTable.d.ts +7 -0
  261. package/resultset-table/ResultsetTable.js +166 -0
  262. package/resultset-table/ResultsetTable.stories.tsx +397 -0
  263. package/resultset-table/ResultsetTable.test.js +371 -0
  264. package/resultset-table/types.d.ts +73 -0
  265. package/resultset-table/types.js +5 -0
  266. package/select/Icons.d.ts +10 -0
  267. package/select/Icons.js +89 -0
  268. package/select/Listbox.d.ts +4 -0
  269. package/select/Listbox.js +143 -0
  270. package/select/Option.d.ts +4 -0
  271. package/select/Option.js +87 -0
  272. package/select/Select.d.ts +4 -0
  273. package/select/Select.js +590 -0
  274. package/select/Select.stories.tsx +971 -0
  275. package/select/Select.test.js +2370 -0
  276. package/select/types.d.ts +209 -0
  277. package/select/types.js +5 -0
  278. package/sidenav/Icons.d.ts +7 -0
  279. package/sidenav/Icons.js +47 -0
  280. package/sidenav/Sidenav.d.ts +10 -0
  281. package/sidenav/Sidenav.js +197 -0
  282. package/sidenav/Sidenav.stories.tsx +282 -0
  283. package/sidenav/Sidenav.test.js +37 -0
  284. package/sidenav/types.d.ts +76 -0
  285. package/sidenav/types.js +5 -0
  286. package/slider/Slider.d.ts +4 -0
  287. package/slider/Slider.js +285 -0
  288. package/slider/Slider.test.js +254 -0
  289. package/slider/types.d.ts +86 -0
  290. package/slider/types.js +5 -0
  291. package/spinner/Spinner.d.ts +4 -0
  292. package/spinner/Spinner.js +206 -0
  293. package/spinner/Spinner.stories.tsx +129 -0
  294. package/spinner/Spinner.test.js +55 -0
  295. package/spinner/types.d.ts +32 -0
  296. package/spinner/types.js +5 -0
  297. package/status-light/StatusLight.d.ts +4 -0
  298. package/status-light/StatusLight.js +51 -0
  299. package/status-light/StatusLight.stories.tsx +74 -0
  300. package/status-light/StatusLight.test.js +25 -0
  301. package/status-light/types.d.ts +17 -0
  302. package/status-light/types.js +5 -0
  303. package/switch/Switch.d.ts +4 -0
  304. package/switch/Switch.js +214 -0
  305. package/switch/Switch.stories.tsx +137 -0
  306. package/switch/Switch.test.js +180 -0
  307. package/switch/types.d.ts +66 -0
  308. package/switch/types.js +5 -0
  309. package/table/DropdownTheme.js +62 -0
  310. package/table/Table.d.ts +8 -0
  311. package/table/Table.js +170 -0
  312. package/table/Table.stories.tsx +658 -0
  313. package/table/Table.test.js +113 -0
  314. package/table/types.d.ts +63 -0
  315. package/table/types.js +5 -0
  316. package/tabs/Tab.d.ts +4 -0
  317. package/tabs/Tab.js +116 -0
  318. package/tabs/Tabs.d.ts +4 -0
  319. package/tabs/Tabs.js +384 -0
  320. package/tabs/Tabs.stories.tsx +226 -0
  321. package/tabs/Tabs.test.js +294 -0
  322. package/tabs/types.d.ts +92 -0
  323. package/tabs/types.js +5 -0
  324. package/tag/Tag.d.ts +4 -0
  325. package/tag/Tag.js +151 -0
  326. package/tag/Tag.stories.tsx +155 -0
  327. package/tag/Tag.test.js +49 -0
  328. package/tag/types.d.ts +69 -0
  329. package/tag/types.js +5 -0
  330. package/text-input/Icons.d.ts +8 -0
  331. package/text-input/Icons.js +56 -0
  332. package/text-input/Suggestion.d.ts +4 -0
  333. package/text-input/Suggestion.js +67 -0
  334. package/text-input/Suggestions.d.ts +4 -0
  335. package/text-input/Suggestions.js +84 -0
  336. package/text-input/TextInput.d.ts +4 -0
  337. package/text-input/TextInput.js +565 -0
  338. package/text-input/TextInput.stories.tsx +465 -0
  339. package/text-input/TextInput.test.js +1756 -0
  340. package/text-input/types.d.ts +205 -0
  341. package/text-input/types.js +5 -0
  342. package/textarea/Textarea.d.ts +4 -0
  343. package/textarea/Textarea.js +234 -0
  344. package/textarea/Textarea.stories.tsx +174 -0
  345. package/textarea/Textarea.test.js +406 -0
  346. package/textarea/types.d.ts +141 -0
  347. package/textarea/types.js +5 -0
  348. package/toggle-group/ToggleGroup.d.ts +4 -0
  349. package/toggle-group/ToggleGroup.js +201 -0
  350. package/toggle-group/ToggleGroup.stories.tsx +218 -0
  351. package/toggle-group/ToggleGroup.test.js +137 -0
  352. package/toggle-group/types.d.ts +114 -0
  353. package/toggle-group/types.js +5 -0
  354. package/typography/Typography.d.ts +4 -0
  355. package/typography/Typography.js +23 -0
  356. package/typography/Typography.stories.tsx +198 -0
  357. package/typography/types.d.ts +18 -0
  358. package/typography/types.js +5 -0
  359. package/useTheme.d.ts +1148 -0
  360. package/useTheme.js +15 -0
  361. package/useTranslatedLabels.d.ts +85 -0
  362. package/useTranslatedLabels.js +14 -0
  363. package/utils/BaseTypography.d.ts +21 -0
  364. package/utils/BaseTypography.js +94 -0
  365. package/utils/FocusLock.d.ts +13 -0
  366. package/utils/FocusLock.js +124 -0
  367. package/wizard/Wizard.d.ts +4 -0
  368. package/wizard/Wizard.js +250 -0
  369. package/wizard/Wizard.stories.tsx +253 -0
  370. package/wizard/Wizard.test.js +114 -0
  371. package/wizard/types.d.ts +64 -0
  372. package/wizard/types.js +5 -0
  373. package/babel.config.js +0 -4
  374. package/dist/ThemeContext.js +0 -15
  375. package/dist/accordion/Accordion.js +0 -242
  376. package/dist/accordion/Accordion.stories.js +0 -207
  377. package/dist/accordion/readme.md +0 -96
  378. package/dist/alert/Alert.js +0 -304
  379. package/dist/alert/Alert.stories.js +0 -158
  380. package/dist/alert/close.svg +0 -4
  381. package/dist/alert/error.svg +0 -4
  382. package/dist/alert/info.svg +0 -4
  383. package/dist/alert/readme.md +0 -43
  384. package/dist/alert/success.svg +0 -4
  385. package/dist/alert/warning.svg +0 -4
  386. package/dist/box/Box.js +0 -148
  387. package/dist/button/Button.js +0 -181
  388. package/dist/button/Button.stories.js +0 -224
  389. package/dist/button/readme.md +0 -93
  390. package/dist/card/Card.js +0 -217
  391. package/dist/checkbox/Checkbox.js +0 -224
  392. package/dist/checkbox/Checkbox.stories.js +0 -144
  393. package/dist/checkbox/readme.md +0 -116
  394. package/dist/chip/Chip.js +0 -173
  395. package/dist/common/OpenSans.css +0 -81
  396. package/dist/common/RequiredComponent.js +0 -46
  397. package/dist/common/fonts/OpenSans-Bold.ttf +0 -0
  398. package/dist/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  399. package/dist/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  400. package/dist/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  401. package/dist/common/fonts/OpenSans-Italic.ttf +0 -0
  402. package/dist/common/fonts/OpenSans-Light.ttf +0 -0
  403. package/dist/common/fonts/OpenSans-LightItalic.ttf +0 -0
  404. package/dist/common/fonts/OpenSans-Regular.ttf +0 -0
  405. package/dist/common/fonts/OpenSans-SemiBold.ttf +0 -0
  406. package/dist/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  407. package/dist/common/services/example-service.js +0 -10
  408. package/dist/common/services/example-service.test.js +0 -12
  409. package/dist/common/utils.js +0 -42
  410. package/dist/common/variables.js +0 -400
  411. package/dist/date/Date.js +0 -357
  412. package/dist/date/Date.stories.js +0 -205
  413. package/dist/date/calendar.svg +0 -1
  414. package/dist/date/calendar_dark.svg +0 -1
  415. package/dist/date/readme.md +0 -73
  416. package/dist/dialog/Dialog.js +0 -197
  417. package/dist/dialog/Dialog.stories.js +0 -217
  418. package/dist/dialog/readme.md +0 -32
  419. package/dist/dropdown/Dropdown.js +0 -424
  420. package/dist/dropdown/Dropdown.stories.js +0 -249
  421. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  422. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  423. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  424. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  425. package/dist/dropdown/readme.md +0 -69
  426. package/dist/footer/Footer.js +0 -346
  427. package/dist/footer/Footer.stories.js +0 -94
  428. package/dist/footer/dxc_logo_wht.png +0 -0
  429. package/dist/footer/readme.md +0 -41
  430. package/dist/header/Header.js +0 -372
  431. package/dist/header/Header.stories.js +0 -176
  432. package/dist/header/close_icon.svg +0 -1
  433. package/dist/header/dxc_logo_black.png +0 -0
  434. package/dist/header/dxc_logo_white.png +0 -0
  435. package/dist/header/hamb_menu_black.svg +0 -1
  436. package/dist/header/hamb_menu_white.svg +0 -1
  437. package/dist/header/readme.md +0 -33
  438. package/dist/heading/Heading.js +0 -153
  439. package/dist/input-text/InputText.js +0 -519
  440. package/dist/input-text/InputText.stories.js +0 -209
  441. package/dist/input-text/error.svg +0 -1
  442. package/dist/input-text/readme.md +0 -91
  443. package/dist/link/Link.js +0 -136
  444. package/dist/link/readme.md +0 -51
  445. package/dist/main.js +0 -263
  446. package/dist/paginator/Paginator.js +0 -196
  447. package/dist/paginator/images/next.svg +0 -3
  448. package/dist/paginator/images/nextPage.svg +0 -3
  449. package/dist/paginator/images/previous.svg +0 -3
  450. package/dist/paginator/images/previousPage.svg +0 -3
  451. package/dist/paginator/readme.md +0 -50
  452. package/dist/progress-bar/ProgressBar.js +0 -185
  453. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  454. package/dist/progress-bar/readme.md +0 -63
  455. package/dist/radio/Radio.js +0 -187
  456. package/dist/radio/Radio.stories.js +0 -166
  457. package/dist/radio/readme.md +0 -70
  458. package/dist/resultsetTable/ResultsetTable.js +0 -333
  459. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  460. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  461. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  462. package/dist/select/Select.js +0 -445
  463. package/dist/select/Select.stories.js +0 -235
  464. package/dist/select/readme.md +0 -72
  465. package/dist/sidenav/Sidenav.js +0 -236
  466. package/dist/sidenav/arrow_icon.svg +0 -3
  467. package/dist/slider/Slider.js +0 -258
  468. package/dist/slider/Slider.stories.js +0 -241
  469. package/dist/slider/readme.md +0 -64
  470. package/dist/spinner/Spinner.js +0 -193
  471. package/dist/spinner/Spinner.stories.js +0 -183
  472. package/dist/spinner/readme.md +0 -65
  473. package/dist/switch/Switch.js +0 -199
  474. package/dist/switch/Switch.stories.js +0 -134
  475. package/dist/switch/readme.md +0 -133
  476. package/dist/table/Table.js +0 -87
  477. package/dist/tabs/Tabs.js +0 -172
  478. package/dist/tabs/Tabs.stories.js +0 -130
  479. package/dist/tabs/readme.md +0 -78
  480. package/dist/tabs-for-sections/TabsForSections.js +0 -107
  481. package/dist/tabs-for-sections/readme.md +0 -78
  482. package/dist/tag/Tag.js +0 -217
  483. package/dist/textarea/Textarea.js +0 -227
  484. package/dist/toggle/Toggle.js +0 -223
  485. package/dist/toggle/Toggle.stories.js +0 -297
  486. package/dist/toggle/readme.md +0 -80
  487. package/dist/upload/Upload.js +0 -200
  488. package/dist/upload/Upload.stories.js +0 -72
  489. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -122
  490. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  491. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  492. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -279
  493. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  494. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  495. package/dist/upload/file-upload/FileToUpload.js +0 -158
  496. package/dist/upload/file-upload/audio-icon.svg +0 -4
  497. package/dist/upload/file-upload/close.svg +0 -4
  498. package/dist/upload/file-upload/file-icon.svg +0 -4
  499. package/dist/upload/file-upload/video-icon.svg +0 -4
  500. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  501. package/dist/upload/readme.md +0 -37
  502. package/dist/upload/transaction/Transaction.js +0 -155
  503. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  504. package/dist/upload/transaction/audio-icon.svg +0 -4
  505. package/dist/upload/transaction/error-icon.svg +0 -4
  506. package/dist/upload/transaction/file-icon-err.svg +0 -4
  507. package/dist/upload/transaction/file-icon.svg +0 -4
  508. package/dist/upload/transaction/image-icon-err.svg +0 -4
  509. package/dist/upload/transaction/image-icon.svg +0 -4
  510. package/dist/upload/transaction/success-icon.svg +0 -4
  511. package/dist/upload/transaction/video-icon-err.svg +0 -4
  512. package/dist/upload/transaction/video-icon.svg +0 -4
  513. package/dist/upload/transactions/Transactions.js +0 -120
  514. package/dist/wizard/Wizard.js +0 -327
  515. package/dist/wizard/invalid_icon.svg +0 -6
  516. package/dist/wizard/valid_icon.svg +0 -6
  517. package/dist/wizard/validation-wrong.svg +0 -6
  518. package/test/Accordion.test.js +0 -33
  519. package/test/Alert.test.js +0 -53
  520. package/test/Box.test.js +0 -10
  521. package/test/Button.test.js +0 -18
  522. package/test/Card.test.js +0 -30
  523. package/test/Checkbox.test.js +0 -45
  524. package/test/Chip.test.js +0 -25
  525. package/test/Date.test.js +0 -393
  526. package/test/Dialog.test.js +0 -23
  527. package/test/Dropdown.test.js +0 -130
  528. package/test/Footer.test.js +0 -99
  529. package/test/Header.test.js +0 -39
  530. package/test/Heading.test.js +0 -35
  531. package/test/InputText.test.js +0 -236
  532. package/test/Link.test.js +0 -25
  533. package/test/Paginator.test.js +0 -165
  534. package/test/ProgressBar.test.js +0 -35
  535. package/test/Radio.test.js +0 -37
  536. package/test/ResultsetTable.test.js +0 -282
  537. package/test/Select.test.js +0 -191
  538. package/test/Sidenav.test.js +0 -87
  539. package/test/Slider.test.js +0 -65
  540. package/test/Spinner.test.js +0 -27
  541. package/test/Switch.test.js +0 -45
  542. package/test/Table.test.js +0 -36
  543. package/test/Tabs.test.js +0 -88
  544. package/test/TabsForSections.test.js +0 -34
  545. package/test/Tag.test.js +0 -32
  546. package/test/TextArea.test.js +0 -52
  547. package/test/Toggle.test.js +0 -43
  548. package/test/Upload.test.js +0 -60
  549. package/test/Wizard.test.js +0 -130
  550. package/test/mocks/pngMock.js +0 -1
  551. package/test/mocks/svgMock.js +0 -1
@@ -0,0 +1,75 @@
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 _Alert = _interopRequireDefault(require("./Alert.tsx"));
7
+ describe("Alert component tests", function () {
8
+ test("Info alert renders with correct text", function () {
9
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Alert["default"], {
10
+ type: "info",
11
+ inlineText: "info-alert-text"
12
+ })),
13
+ getByText = _render.getByText;
14
+ expect(getByText("information")).toBeTruthy();
15
+ expect(getByText("info-alert-text")).toBeTruthy();
16
+ });
17
+ test("Confirm alert renders with correct text", function () {
18
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Alert["default"], {
19
+ type: "confirm",
20
+ inlineText: "confirm-alert-text"
21
+ })),
22
+ getByText = _render2.getByText;
23
+ expect(getByText("success")).toBeTruthy();
24
+ expect(getByText("confirm-alert-text")).toBeTruthy();
25
+ });
26
+ test("Warning alert renders with correct text", function () {
27
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Alert["default"], {
28
+ type: "warning",
29
+ inlineText: "warning-alert-text"
30
+ })),
31
+ getByText = _render3.getByText;
32
+ expect(getByText("warning")).toBeTruthy();
33
+ expect(getByText("warning-alert-text")).toBeTruthy();
34
+ });
35
+ test("Error alert renders with correct text", function () {
36
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Alert["default"], {
37
+ type: "error",
38
+ inlineText: "error-alert-text"
39
+ })),
40
+ getByText = _render4.getByText;
41
+ expect(getByText("error")).toBeTruthy();
42
+ expect(getByText("error-alert-text")).toBeTruthy();
43
+ });
44
+ test("Alert renders with correct children", function () {
45
+ var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Alert["default"], {
46
+ inlineText: "alert-text"
47
+ }, /*#__PURE__*/_react["default"].createElement("p", null, "sample-children"))),
48
+ getByText = _render5.getByText;
49
+ expect(getByText("alert-text")).toBeTruthy();
50
+ expect(getByText("sample-children")).toBeTruthy();
51
+ });
52
+ test("Calls correct function on close", function () {
53
+ var onClose = jest.fn();
54
+ var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Alert["default"], {
55
+ onClose: onClose,
56
+ inlineText: "info-alert-text"
57
+ })),
58
+ getByRole = _render6.getByRole;
59
+ var closeButton = getByRole("button");
60
+ _react2.fireEvent.click(closeButton);
61
+ expect(onClose).toHaveBeenCalled();
62
+ });
63
+ test("Modal alert calls correct function on close", function () {
64
+ var onClose = jest.fn();
65
+ var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Alert["default"], {
66
+ onClose: onClose,
67
+ mode: "modal",
68
+ inlineText: "info-alert-text"
69
+ })),
70
+ getByRole = _render7.getByRole;
71
+ var closeButton = getByRole("button");
72
+ _react2.fireEvent.click(closeButton);
73
+ expect(onClose).toHaveBeenCalled();
74
+ });
75
+ });
@@ -0,0 +1,49 @@
1
+ /// <reference types="react" />
2
+ type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ type Margin = {
4
+ top?: Space;
5
+ bottom?: Space;
6
+ left?: Space;
7
+ right?: Space;
8
+ };
9
+ type Props = {
10
+ /**
11
+ * Uses on of the available alert types.
12
+ */
13
+ type?: "info" | "confirm" | "warning" | "error";
14
+ /**
15
+ * Uses on of the available alert modes:
16
+ * 'inline': If onClose function is received, close button will be visible and the function will be executed when it's clicked.
17
+ * There is no overlay layer. Position should be decided by the user.
18
+ * 'modal': The alert will be displayed in the middle of the screen with an overlay layer behind.
19
+ * The onClose function will be executed when the X button or the overlay is clicked. d
20
+ * The user has the responsibility of hiding the modal in the onClose function, otherwise the modal will remain visible.
21
+ */
22
+ mode?: "inline" | "modal";
23
+ /**
24
+ * Text to display after icon and alert type and before content.
25
+ */
26
+ inlineText?: string;
27
+ /**
28
+ * This function will be called when the user clicks the close button. If there is no function we should close the alert by default.
29
+ */
30
+ onClose?: () => void;
31
+ /**
32
+ * The details section of the alert. Can be used to render custom content in this area.
33
+ */
34
+ children?: React.ReactNode;
35
+ /**
36
+ * Size of the margin to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
37
+ * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
38
+ */
39
+ margin?: Space | Margin;
40
+ /**
41
+ * Size of the component.
42
+ */
43
+ size?: "small" | "medium" | "large" | "fillParent" | "fitContent";
44
+ /**
45
+ * Value of the tabindex attribute applied to the close button.
46
+ */
47
+ tabIndex?: number;
48
+ };
49
+ export default Props;
package/alert/types.js ADDED
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ import BadgePropsType from "./types";
3
+ declare const DxcBadge: ({ label, title, mode, color, icon, notificationLimit, size, }: BadgePropsType) => JSX.Element;
4
+ export default DxcBadge;
package/badge/Badge.js ADDED
@@ -0,0 +1,159 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports["default"] = void 0;
8
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
9
+ var _react = _interopRequireDefault(require("react"));
10
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
11
+ var _Flex = _interopRequireDefault(require("../flex/Flex"));
12
+ var _coreTokens = _interopRequireDefault(require("../common/coreTokens"));
13
+ var _templateObject, _templateObject2, _templateObject3;
14
+ var contextualColorMap = {
15
+ grey: {
16
+ background: _coreTokens["default"].color_grey_200,
17
+ text: _coreTokens["default"].color_grey_900
18
+ },
19
+ blue: {
20
+ background: _coreTokens["default"].color_blue_200,
21
+ text: _coreTokens["default"].color_blue_900
22
+ },
23
+ green: {
24
+ background: _coreTokens["default"].color_green_200,
25
+ text: _coreTokens["default"].color_green_900
26
+ },
27
+ orange: {
28
+ background: _coreTokens["default"].color_orange_200,
29
+ text: _coreTokens["default"].color_orange_900
30
+ },
31
+ red: {
32
+ background: _coreTokens["default"].color_red_200,
33
+ text: _coreTokens["default"].color_red_900
34
+ },
35
+ yellow: {
36
+ background: _coreTokens["default"].color_yellow_200,
37
+ text: _coreTokens["default"].color_yellow_900
38
+ },
39
+ purple: {
40
+ background: _coreTokens["default"].color_purple_200,
41
+ text: _coreTokens["default"].color_purple_900
42
+ }
43
+ };
44
+ var sizeMap = {
45
+ small: {
46
+ height: "20px",
47
+ width: "20px",
48
+ minWidth: "20px",
49
+ fontSize: _coreTokens["default"].type_scale_01,
50
+ borderRadius: _coreTokens["default"].spacing_12,
51
+ iconSize: "14px",
52
+ padding: {
53
+ contextual: "".concat(_coreTokens["default"].spacing_4),
54
+ notification: "".concat(_coreTokens["default"].spacing_0, " ").concat(_coreTokens["default"].spacing_4)
55
+ }
56
+ },
57
+ medium: {
58
+ height: "24px",
59
+ width: "24px",
60
+ minWidth: "24px",
61
+ fontSize: _coreTokens["default"].type_scale_02,
62
+ borderRadius: _coreTokens["default"].spacing_12,
63
+ iconSize: "16px",
64
+ padding: {
65
+ contextual: "".concat(_coreTokens["default"].spacing_4, " ").concat(_coreTokens["default"].spacing_8),
66
+ notification: "".concat(_coreTokens["default"].spacing_0, " ").concat(_coreTokens["default"].spacing_4)
67
+ }
68
+ },
69
+ large: {
70
+ height: "32px",
71
+ width: "32px",
72
+ minWidth: "32px",
73
+ fontSize: _coreTokens["default"].type_scale_04,
74
+ borderRadius: _coreTokens["default"].spacing_24,
75
+ iconSize: "24px",
76
+ padding: {
77
+ contextual: "".concat(_coreTokens["default"].spacing_4, " ").concat(_coreTokens["default"].spacing_8),
78
+ notification: "".concat(_coreTokens["default"].spacing_0, " ").concat(_coreTokens["default"].spacing_8)
79
+ }
80
+ }
81
+ };
82
+ var Label = function Label(_ref) {
83
+ var label = _ref.label,
84
+ notificationLimit = _ref.notificationLimit,
85
+ size = _ref.size;
86
+ return /*#__PURE__*/_react["default"].createElement(LabelContainer, {
87
+ size: size
88
+ }, typeof label === "number" ? label > notificationLimit ? "+" + notificationLimit : label : label);
89
+ };
90
+ var DxcBadge = function DxcBadge(_ref2) {
91
+ var label = _ref2.label,
92
+ title = _ref2.title,
93
+ _ref2$mode = _ref2.mode,
94
+ mode = _ref2$mode === void 0 ? "contextual" : _ref2$mode,
95
+ _ref2$color = _ref2.color,
96
+ color = _ref2$color === void 0 ? "grey" : _ref2$color,
97
+ icon = _ref2.icon,
98
+ _ref2$notificationLim = _ref2.notificationLimit,
99
+ notificationLimit = _ref2$notificationLim === void 0 ? 99 : _ref2$notificationLim,
100
+ _ref2$size = _ref2.size,
101
+ size = _ref2$size === void 0 ? "medium" : _ref2$size;
102
+ return /*#__PURE__*/_react["default"].createElement(BadgeContainer, {
103
+ label: label,
104
+ mode: mode,
105
+ color: mode === "contextual" && color || undefined,
106
+ size: size,
107
+ title: title,
108
+ "aria-label": title
109
+ }, mode === "contextual" && /*#__PURE__*/_react["default"].createElement(_Flex["default"], {
110
+ gap: "0.125rem",
111
+ alignItems: "center"
112
+ }, icon && /*#__PURE__*/_react["default"].createElement(IconContainer, {
113
+ size: size
114
+ }, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement("img", {
115
+ src: icon,
116
+ alt: title
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);
138
+ }, function (props) {
139
+ return getBackgroundColor(props.mode, props.color);
140
+ }, function (props) {
141
+ return sizeMap[props.size].borderRadius;
142
+ }, function (props) {
143
+ return !props.label && props.mode === "notification" ? sizeMap[props.size].width : "fit-content";
144
+ }, function (props) {
145
+ return props.mode === "notification" && sizeMap[props.size].minWidth;
146
+ }, function (props) {
147
+ return sizeMap[props.size].height;
148
+ }, function (props) {
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 img,\n svg {\n height: ", ";\n width: ", ";\n }\n"])), function (props) {
152
+ return sizeMap[props.size].iconSize;
153
+ }, function (props) {
154
+ return sizeMap[props.size].iconSize;
155
+ });
156
+ 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) {
157
+ return sizeMap[props.size].fontSize;
158
+ }, _coreTokens["default"].type_semibold);
159
+ 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={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
+ 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";
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
+ * 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/badge/types.js ADDED
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
@@ -0,0 +1,3 @@
1
+ /// <reference types="react" />
2
+ import BleedPropsType from "./types";
3
+ export default function Bleed({ space, horizontal, vertical, top, right, bottom, left, children, }: BleedPropsType): JSX.Element;
package/bleed/Bleed.js ADDED
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports["default"] = Bleed;
8
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
9
+ var _react = _interopRequireDefault(require("react"));
10
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
11
+ var _templateObject;
12
+ function Bleed(_ref) {
13
+ var space = _ref.space,
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;
21
+ return /*#__PURE__*/_react["default"].createElement(StyledBleed, {
22
+ space: space,
23
+ horizontal: horizontal,
24
+ vertical: vertical,
25
+ top: top,
26
+ right: right,
27
+ bottom: bottom,
28
+ left: left
29
+ }, children);
30
+ }
31
+ function getSpacingValue(spacingName) {
32
+ return spacingName ? spacingName : "0rem";
33
+ }
34
+ var StyledBleed = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n ", "\n"])), function (_ref2) {
35
+ var space = _ref2.space,
36
+ horizontal = _ref2.horizontal,
37
+ vertical = _ref2.vertical,
38
+ top = _ref2.top,
39
+ right = _ref2.right,
40
+ bottom = _ref2.bottom,
41
+ left = _ref2.left;
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");
43
+ });