@dxc-technology/halstack-react 0.0.0-b92e300 → 0.0.0-b94d9fc

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 (393) hide show
  1. package/BackgroundColorContext.d.ts +1 -0
  2. package/BackgroundColorContext.js +6 -26
  3. package/HalstackContext.d.ts +1249 -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 +118 -194
  8. package/accordion/Accordion.stories.tsx +283 -0
  9. package/accordion/Accordion.test.js +56 -0
  10. package/accordion/types.d.ts +12 -23
  11. package/accordion-group/AccordionGroup.d.ts +5 -4
  12. package/accordion-group/AccordionGroup.js +39 -108
  13. package/accordion-group/AccordionGroup.stories.tsx +252 -0
  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 +18 -23
  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 +24 -60
  24. package/alert/Alert.stories.tsx +198 -0
  25. package/alert/Alert.test.js +75 -0
  26. package/alert/types.d.ts +6 -6
  27. package/badge/Badge.d.ts +4 -0
  28. package/badge/Badge.js +141 -41
  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/badge/types.js +5 -0
  33. package/bleed/Bleed.d.ts +3 -0
  34. package/bleed/Bleed.js +43 -0
  35. package/bleed/Bleed.stories.tsx +342 -0
  36. package/bleed/types.d.ts +37 -0
  37. package/bleed/types.js +5 -0
  38. package/box/Box.d.ts +4 -0
  39. package/box/Box.js +32 -109
  40. package/box/Box.stories.tsx +119 -0
  41. package/box/Box.test.js +13 -0
  42. package/box/types.d.ts +32 -0
  43. package/box/types.js +5 -0
  44. package/bulleted-list/BulletedList.d.ts +7 -0
  45. package/bulleted-list/BulletedList.js +89 -0
  46. package/bulleted-list/BulletedList.stories.tsx +115 -0
  47. package/bulleted-list/types.d.ts +38 -0
  48. package/bulleted-list/types.js +5 -0
  49. package/button/Button.d.ts +1 -1
  50. package/button/Button.js +65 -127
  51. package/button/Button.stories.tsx +329 -278
  52. package/button/Button.test.js +38 -0
  53. package/button/types.d.ts +18 -18
  54. package/card/Card.d.ts +1 -1
  55. package/card/Card.js +59 -104
  56. package/card/Card.stories.tsx +171 -0
  57. package/card/Card.test.js +39 -0
  58. package/card/types.d.ts +8 -15
  59. package/checkbox/Checkbox.d.ts +2 -2
  60. package/checkbox/Checkbox.js +145 -183
  61. package/checkbox/Checkbox.stories.tsx +222 -0
  62. package/checkbox/Checkbox.test.js +199 -0
  63. package/checkbox/types.d.ts +20 -8
  64. package/chip/Chip.d.ts +4 -0
  65. package/chip/Chip.js +48 -148
  66. package/chip/Chip.stories.tsx +214 -0
  67. package/chip/Chip.test.js +41 -0
  68. package/chip/types.d.ts +45 -0
  69. package/chip/types.js +5 -0
  70. package/common/OpenSans.css +68 -80
  71. package/common/coreTokens.d.ts +237 -0
  72. package/common/coreTokens.js +184 -0
  73. package/common/utils.d.ts +1 -0
  74. package/common/utils.js +6 -12
  75. package/common/variables.d.ts +1395 -0
  76. package/common/variables.js +1033 -1335
  77. package/container/Container.d.ts +4 -0
  78. package/container/Container.js +194 -0
  79. package/container/Container.stories.tsx +214 -0
  80. package/container/types.d.ts +74 -0
  81. package/container/types.js +5 -0
  82. package/date-input/Calendar.d.ts +4 -0
  83. package/date-input/Calendar.js +214 -0
  84. package/date-input/DateInput.js +175 -313
  85. package/date-input/DateInput.stories.tsx +285 -0
  86. package/date-input/DateInput.test.js +808 -0
  87. package/date-input/DatePicker.d.ts +4 -0
  88. package/date-input/DatePicker.js +115 -0
  89. package/date-input/Icons.d.ts +6 -0
  90. package/date-input/Icons.js +58 -0
  91. package/date-input/YearPicker.d.ts +4 -0
  92. package/date-input/YearPicker.js +100 -0
  93. package/date-input/types.d.ts +86 -22
  94. package/dialog/Dialog.d.ts +4 -0
  95. package/dialog/Dialog.js +69 -149
  96. package/dialog/Dialog.stories.tsx +365 -0
  97. package/dialog/Dialog.test.js +307 -0
  98. package/dialog/types.d.ts +36 -0
  99. package/dialog/types.js +5 -0
  100. package/dropdown/Dropdown.d.ts +4 -0
  101. package/dropdown/Dropdown.js +251 -365
  102. package/dropdown/Dropdown.stories.tsx +438 -0
  103. package/dropdown/Dropdown.test.js +599 -0
  104. package/dropdown/DropdownMenu.d.ts +4 -0
  105. package/dropdown/DropdownMenu.js +63 -0
  106. package/dropdown/DropdownMenuItem.d.ts +4 -0
  107. package/dropdown/DropdownMenuItem.js +67 -0
  108. package/dropdown/types.d.ts +98 -0
  109. package/dropdown/types.js +5 -0
  110. package/file-input/FileInput.d.ts +4 -0
  111. package/file-input/FileInput.js +274 -327
  112. package/file-input/FileInput.stories.tsx +618 -0
  113. package/file-input/FileInput.test.js +459 -0
  114. package/file-input/FileItem.d.ts +4 -0
  115. package/file-input/FileItem.js +54 -112
  116. package/file-input/types.d.ts +129 -0
  117. package/file-input/types.js +5 -0
  118. package/flex/Flex.d.ts +4 -0
  119. package/flex/Flex.js +57 -0
  120. package/flex/Flex.stories.tsx +112 -0
  121. package/flex/types.d.ts +97 -0
  122. package/flex/types.js +5 -0
  123. package/footer/Footer.d.ts +4 -0
  124. package/footer/Footer.js +74 -233
  125. package/footer/Footer.stories.tsx +171 -0
  126. package/footer/Footer.test.js +85 -0
  127. package/footer/Icons.d.ts +3 -0
  128. package/footer/Icons.js +67 -8
  129. package/footer/types.d.ts +64 -0
  130. package/footer/types.js +5 -0
  131. package/grid/Grid.d.ts +7 -0
  132. package/grid/Grid.js +76 -0
  133. package/grid/Grid.stories.tsx +219 -0
  134. package/grid/types.d.ts +115 -0
  135. package/grid/types.js +5 -0
  136. package/header/Header.d.ts +8 -0
  137. package/header/Header.js +115 -221
  138. package/header/Header.stories.tsx +251 -0
  139. package/header/Header.test.js +66 -0
  140. package/header/Icons.d.ts +2 -0
  141. package/header/Icons.js +5 -35
  142. package/header/types.d.ts +33 -0
  143. package/header/types.js +5 -0
  144. package/heading/Heading.d.ts +4 -0
  145. package/heading/Heading.js +16 -55
  146. package/heading/Heading.stories.tsx +54 -0
  147. package/heading/Heading.test.js +169 -0
  148. package/heading/types.d.ts +33 -0
  149. package/heading/types.js +5 -0
  150. package/image/Image.d.ts +4 -0
  151. package/image/Image.js +70 -0
  152. package/image/Image.stories.tsx +129 -0
  153. package/image/types.d.ts +72 -0
  154. package/image/types.js +5 -0
  155. package/inset/Inset.d.ts +3 -0
  156. package/inset/Inset.js +43 -0
  157. package/inset/Inset.stories.tsx +230 -0
  158. package/inset/types.d.ts +37 -0
  159. package/inset/types.js +5 -0
  160. package/layout/ApplicationLayout.d.ts +20 -0
  161. package/layout/ApplicationLayout.js +83 -184
  162. package/layout/ApplicationLayout.stories.tsx +162 -0
  163. package/layout/Icons.d.ts +8 -0
  164. package/layout/Icons.js +51 -48
  165. package/layout/SidenavContext.d.ts +5 -0
  166. package/layout/SidenavContext.js +13 -0
  167. package/layout/types.d.ts +41 -0
  168. package/layout/types.js +5 -0
  169. package/link/Link.d.ts +4 -0
  170. package/link/Link.js +65 -133
  171. package/link/Link.stories.tsx +253 -0
  172. package/link/Link.test.js +63 -0
  173. package/link/types.d.ts +54 -0
  174. package/link/types.js +5 -0
  175. package/main.d.ts +17 -14
  176. package/main.js +78 -98
  177. package/nav-tabs/NavTabs.d.ts +8 -0
  178. package/nav-tabs/NavTabs.js +93 -0
  179. package/nav-tabs/NavTabs.stories.tsx +276 -0
  180. package/nav-tabs/NavTabs.test.js +76 -0
  181. package/nav-tabs/Tab.d.ts +4 -0
  182. package/nav-tabs/Tab.js +118 -0
  183. package/nav-tabs/types.d.ts +52 -0
  184. package/nav-tabs/types.js +5 -0
  185. package/number-input/NumberInput.d.ts +11 -0
  186. package/number-input/NumberInput.js +49 -91
  187. package/number-input/NumberInput.stories.tsx +131 -0
  188. package/number-input/NumberInput.test.js +989 -0
  189. package/number-input/types.d.ts +130 -0
  190. package/number-input/types.js +5 -0
  191. package/package.json +46 -45
  192. package/paginator/Icons.d.ts +5 -0
  193. package/paginator/Icons.js +21 -47
  194. package/paginator/Paginator.js +35 -98
  195. package/paginator/Paginator.stories.tsx +87 -0
  196. package/paginator/Paginator.test.js +335 -0
  197. package/paginator/types.d.ts +3 -3
  198. package/paragraph/Paragraph.d.ts +5 -0
  199. package/paragraph/Paragraph.js +22 -0
  200. package/paragraph/Paragraph.stories.tsx +27 -0
  201. package/password-input/Icons.d.ts +6 -0
  202. package/password-input/Icons.js +35 -0
  203. package/password-input/PasswordInput.d.ts +4 -0
  204. package/password-input/PasswordInput.js +60 -162
  205. package/password-input/{PasswordInput.stories.jsx → PasswordInput.stories.tsx} +3 -35
  206. package/password-input/PasswordInput.test.js +198 -0
  207. package/password-input/types.d.ts +111 -0
  208. package/password-input/types.js +5 -0
  209. package/progress-bar/ProgressBar.js +67 -93
  210. package/progress-bar/ProgressBar.stories.tsx +93 -0
  211. package/progress-bar/ProgressBar.test.js +93 -0
  212. package/progress-bar/types.d.ts +3 -3
  213. package/quick-nav/QuickNav.d.ts +4 -0
  214. package/quick-nav/QuickNav.js +94 -0
  215. package/quick-nav/QuickNav.stories.tsx +356 -0
  216. package/quick-nav/types.d.ts +21 -0
  217. package/quick-nav/types.js +5 -0
  218. package/radio-group/Radio.d.ts +4 -0
  219. package/radio-group/Radio.js +124 -0
  220. package/radio-group/RadioGroup.d.ts +4 -0
  221. package/radio-group/RadioGroup.js +235 -0
  222. package/radio-group/RadioGroup.stories.tsx +214 -0
  223. package/radio-group/RadioGroup.test.js +756 -0
  224. package/radio-group/types.d.ts +114 -0
  225. package/radio-group/types.js +5 -0
  226. package/resultset-table/Icons.d.ts +7 -0
  227. package/resultset-table/Icons.js +47 -0
  228. package/resultset-table/ResultsetTable.d.ts +7 -0
  229. package/resultset-table/ResultsetTable.js +166 -0
  230. package/resultset-table/ResultsetTable.stories.tsx +397 -0
  231. package/resultset-table/ResultsetTable.test.js +371 -0
  232. package/resultset-table/types.d.ts +73 -0
  233. package/resultset-table/types.js +5 -0
  234. package/select/Icons.d.ts +10 -0
  235. package/select/Icons.js +89 -0
  236. package/select/Listbox.d.ts +4 -0
  237. package/select/Listbox.js +143 -0
  238. package/select/Option.d.ts +4 -0
  239. package/select/Option.js +87 -0
  240. package/select/Select.d.ts +4 -0
  241. package/select/Select.js +240 -515
  242. package/select/Select.stories.tsx +971 -0
  243. package/select/Select.test.js +2370 -0
  244. package/select/types.d.ts +209 -0
  245. package/select/types.js +5 -0
  246. package/sidenav/Icons.d.ts +7 -0
  247. package/sidenav/Icons.js +47 -0
  248. package/sidenav/Sidenav.d.ts +10 -0
  249. package/sidenav/Sidenav.js +132 -81
  250. package/sidenav/Sidenav.stories.tsx +282 -0
  251. package/sidenav/Sidenav.test.js +37 -0
  252. package/sidenav/types.d.ts +76 -0
  253. package/sidenav/types.js +5 -0
  254. package/slider/Slider.d.ts +2 -2
  255. package/slider/Slider.js +162 -183
  256. package/slider/Slider.test.js +254 -0
  257. package/slider/types.d.ts +13 -10
  258. package/spinner/Spinner.d.ts +4 -0
  259. package/spinner/Spinner.js +38 -99
  260. package/spinner/Spinner.stories.tsx +129 -0
  261. package/spinner/Spinner.test.js +55 -0
  262. package/spinner/types.d.ts +32 -0
  263. package/spinner/types.js +5 -0
  264. package/status-light/StatusLight.d.ts +4 -0
  265. package/status-light/StatusLight.js +51 -0
  266. package/status-light/StatusLight.stories.tsx +74 -0
  267. package/status-light/StatusLight.test.js +25 -0
  268. package/status-light/types.d.ts +17 -0
  269. package/status-light/types.js +5 -0
  270. package/switch/Switch.d.ts +2 -2
  271. package/switch/Switch.js +150 -115
  272. package/switch/Switch.stories.tsx +137 -0
  273. package/switch/Switch.test.js +180 -0
  274. package/switch/types.d.ts +13 -5
  275. package/table/DropdownTheme.js +62 -0
  276. package/table/Table.d.ts +8 -0
  277. package/table/Table.js +89 -37
  278. package/table/Table.stories.tsx +658 -0
  279. package/table/Table.test.js +113 -0
  280. package/table/types.d.ts +63 -0
  281. package/table/types.js +5 -0
  282. package/tabs/Tab.d.ts +4 -0
  283. package/tabs/Tab.js +116 -0
  284. package/tabs/Tabs.d.ts +4 -0
  285. package/tabs/Tabs.js +319 -194
  286. package/tabs/Tabs.stories.tsx +226 -0
  287. package/tabs/Tabs.test.js +294 -0
  288. package/tabs/types.d.ts +92 -0
  289. package/tabs/types.js +5 -0
  290. package/tag/Tag.d.ts +4 -0
  291. package/tag/Tag.js +55 -112
  292. package/tag/Tag.stories.tsx +155 -0
  293. package/tag/Tag.test.js +49 -0
  294. package/tag/types.d.ts +69 -0
  295. package/tag/types.js +5 -0
  296. package/text-input/Icons.d.ts +8 -0
  297. package/text-input/Icons.js +56 -0
  298. package/text-input/Suggestion.d.ts +4 -0
  299. package/text-input/Suggestion.js +67 -0
  300. package/text-input/Suggestions.d.ts +4 -0
  301. package/text-input/Suggestions.js +84 -0
  302. package/text-input/TextInput.d.ts +4 -0
  303. package/text-input/TextInput.js +333 -593
  304. package/text-input/TextInput.stories.tsx +465 -0
  305. package/text-input/TextInput.test.js +1756 -0
  306. package/text-input/types.d.ts +205 -0
  307. package/text-input/types.js +5 -0
  308. package/textarea/Textarea.d.ts +4 -0
  309. package/textarea/Textarea.js +98 -181
  310. package/textarea/Textarea.stories.tsx +174 -0
  311. package/textarea/Textarea.test.js +406 -0
  312. package/textarea/types.d.ts +141 -0
  313. package/textarea/types.js +5 -0
  314. package/toggle-group/ToggleGroup.d.ts +4 -0
  315. package/toggle-group/ToggleGroup.js +100 -142
  316. package/toggle-group/ToggleGroup.stories.tsx +218 -0
  317. package/toggle-group/ToggleGroup.test.js +137 -0
  318. package/toggle-group/types.d.ts +114 -0
  319. package/toggle-group/types.js +5 -0
  320. package/typography/Typography.d.ts +4 -0
  321. package/typography/Typography.js +23 -0
  322. package/typography/Typography.stories.tsx +198 -0
  323. package/typography/types.d.ts +18 -0
  324. package/typography/types.js +5 -0
  325. package/useTheme.d.ts +1148 -0
  326. package/useTheme.js +4 -11
  327. package/useTranslatedLabels.d.ts +85 -0
  328. package/useTranslatedLabels.js +14 -0
  329. package/utils/BaseTypography.d.ts +21 -0
  330. package/utils/BaseTypography.js +94 -0
  331. package/utils/FocusLock.d.ts +13 -0
  332. package/utils/FocusLock.js +124 -0
  333. package/wizard/Wizard.d.ts +4 -0
  334. package/wizard/Wizard.js +130 -151
  335. package/wizard/Wizard.stories.tsx +253 -0
  336. package/wizard/Wizard.test.js +114 -0
  337. package/wizard/types.d.ts +64 -0
  338. package/wizard/types.js +5 -0
  339. package/ThemeContext.js +0 -246
  340. package/V3Select/V3Select.js +0 -455
  341. package/V3Select/index.d.ts +0 -27
  342. package/V3Textarea/V3Textarea.js +0 -260
  343. package/V3Textarea/index.d.ts +0 -27
  344. package/box/index.d.ts +0 -25
  345. package/chip/index.d.ts +0 -22
  346. package/common/RequiredComponent.js +0 -32
  347. package/date/Date.js +0 -373
  348. package/date/index.d.ts +0 -27
  349. package/dialog/index.d.ts +0 -18
  350. package/dropdown/index.d.ts +0 -26
  351. package/file-input/index.d.ts +0 -81
  352. package/footer/index.d.ts +0 -25
  353. package/header/index.d.ts +0 -25
  354. package/heading/index.d.ts +0 -17
  355. package/input-text/Icons.js +0 -22
  356. package/input-text/InputText.js +0 -611
  357. package/input-text/index.d.ts +0 -36
  358. package/link/index.d.ts +0 -23
  359. package/number-input/NumberInputContext.js +0 -16
  360. package/number-input/index.d.ts +0 -113
  361. package/password-input/index.d.ts +0 -94
  362. package/radio/Radio.d.ts +0 -4
  363. package/radio/Radio.js +0 -174
  364. package/radio/types.d.ts +0 -54
  365. package/resultsetTable/ResultsetTable.js +0 -274
  366. package/resultsetTable/index.d.ts +0 -19
  367. package/select/index.d.ts +0 -131
  368. package/sidenav/index.d.ts +0 -13
  369. package/spinner/index.d.ts +0 -17
  370. package/table/index.d.ts +0 -13
  371. package/tabs/index.d.ts +0 -19
  372. package/tag/index.d.ts +0 -24
  373. package/text-input/index.d.ts +0 -135
  374. package/textarea/Textarea.stories.jsx +0 -135
  375. package/textarea/index.d.ts +0 -117
  376. package/toggle/Toggle.js +0 -186
  377. package/toggle/index.d.ts +0 -21
  378. package/toggle-group/index.d.ts +0 -21
  379. package/upload/Upload.js +0 -201
  380. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  381. package/upload/buttons-upload/Icons.js +0 -40
  382. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  383. package/upload/dragAndDropArea/Icons.js +0 -39
  384. package/upload/file-upload/FileToUpload.js +0 -115
  385. package/upload/file-upload/Icons.js +0 -66
  386. package/upload/files-upload/FilesToUpload.js +0 -109
  387. package/upload/index.d.ts +0 -15
  388. package/upload/transaction/Icons.js +0 -160
  389. package/upload/transaction/Transaction.js +0 -104
  390. package/upload/transactions/Transactions.js +0 -94
  391. package/wizard/Icons.js +0 -65
  392. package/wizard/index.d.ts +0 -18
  393. /package/{radio → action-icon}/types.js +0 -0
package/badge/Badge.js CHANGED
@@ -1,59 +1,159 @@
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.js"));
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
- var colorsTheme = (0, _useTheme["default"])();
29
- return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
30
- theme: colorsTheme.tabs
31
- }, /*#__PURE__*/_react["default"].createElement(StyledDxcBadge, {
32
- notificationText: notificationText
33
- }, /*#__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 _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
+ }
34
43
  };
35
-
36
- 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) {
37
- return props.theme.badgeBackgroundColor;
38
- }, function (props) {
39
- return props.theme.badgeFontFamily;
40
- }, function (props) {
41
- return props.theme.badgeFontSize;
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);
42
138
  }, function (props) {
43
- return props.theme.badgeFontStyle;
139
+ return getBackgroundColor(props.mode, props.color);
44
140
  }, function (props) {
45
- return props.theme.badgeFontWeight;
141
+ return sizeMap[props.size].borderRadius;
46
142
  }, function (props) {
47
- return props.theme.badgeFontColor;
143
+ return !props.label && props.mode === "notification" ? sizeMap[props.size].width : "fit-content";
48
144
  }, function (props) {
49
- return props.theme.badgeLetterSpacing;
145
+ return props.mode === "notification" && sizeMap[props.size].minWidth;
50
146
  }, function (props) {
51
- return props.notificationText === true ? props.theme.badgeWidth : props.theme.badgeWidthWithNotificationNumber;
147
+ return sizeMap[props.size].height;
52
148
  }, function (props) {
53
- return props.notificationText === true ? props.theme.badgeHeight : props.theme.badgeHeightWithNotificationNumber;
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;
54
153
  }, function (props) {
55
- return props.notificationText === true ? props.theme.badgeRadius : props.theme.badgeRadiusWithNotificationNumber;
154
+ return sizeMap[props.size].iconSize;
56
155
  });
57
-
58
- var _default = DxcBadge;
59
- exports["default"] = _default;
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
+ 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/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
+ });