@dxc-technology/halstack-react 0.0.0-951bb80 → 0.0.0-95b953e

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 (359) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +5 -22
  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 +116 -181
  8. package/accordion/Accordion.stories.tsx +103 -127
  9. package/accordion/Accordion.test.js +56 -0
  10. package/accordion/types.d.ts +9 -16
  11. package/accordion-group/AccordionGroup.d.ts +5 -4
  12. package/accordion-group/AccordionGroup.js +38 -107
  13. package/accordion-group/AccordionGroup.stories.tsx +95 -68
  14. package/accordion-group/AccordionGroup.test.js +98 -0
  15. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  16. package/accordion-group/AccordionGroupAccordion.js +31 -0
  17. package/accordion-group/types.d.ts +15 -16
  18. package/action-icon/ActionIcon.d.ts +4 -0
  19. package/action-icon/ActionIcon.js +47 -0
  20. package/action-icon/ActionIcon.stories.tsx +41 -0
  21. package/action-icon/ActionIcon.test.js +64 -0
  22. package/action-icon/types.d.ts +26 -0
  23. package/alert/Alert.js +23 -59
  24. package/alert/Alert.stories.tsx +28 -0
  25. package/alert/Alert.test.js +75 -0
  26. package/alert/types.d.ts +5 -5
  27. package/badge/Badge.d.ts +4 -0
  28. package/badge/Badge.js +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/bleed/Bleed.js +14 -55
  33. package/bleed/Bleed.stories.tsx +95 -95
  34. package/bleed/types.d.ts +26 -2
  35. package/box/Box.d.ts +1 -1
  36. package/box/Box.js +30 -81
  37. package/box/Box.stories.tsx +38 -51
  38. package/box/Box.test.js +13 -0
  39. package/box/types.d.ts +3 -14
  40. package/bulleted-list/BulletedList.d.ts +7 -0
  41. package/bulleted-list/BulletedList.js +89 -0
  42. package/bulleted-list/BulletedList.stories.tsx +115 -0
  43. package/bulleted-list/types.d.ts +38 -0
  44. package/button/Button.d.ts +1 -1
  45. package/button/Button.js +62 -113
  46. package/button/Button.stories.tsx +160 -90
  47. package/button/Button.test.js +38 -0
  48. package/button/types.d.ts +12 -8
  49. package/card/Card.d.ts +1 -1
  50. package/card/Card.js +58 -102
  51. package/card/Card.stories.tsx +12 -42
  52. package/card/Card.test.js +39 -0
  53. package/card/types.d.ts +6 -11
  54. package/checkbox/Checkbox.d.ts +2 -2
  55. package/checkbox/Checkbox.js +144 -182
  56. package/checkbox/Checkbox.stories.tsx +166 -136
  57. package/checkbox/Checkbox.test.js +199 -0
  58. package/checkbox/types.d.ts +18 -6
  59. package/chip/Chip.js +39 -79
  60. package/chip/Chip.stories.tsx +121 -26
  61. package/chip/Chip.test.js +41 -0
  62. package/chip/types.d.ts +4 -4
  63. package/common/OpenSans.css +68 -80
  64. package/common/coreTokens.d.ts +237 -0
  65. package/common/coreTokens.js +184 -0
  66. package/common/utils.d.ts +1 -0
  67. package/common/utils.js +6 -12
  68. package/common/variables.d.ts +1395 -0
  69. package/common/variables.js +1029 -1373
  70. package/container/Container.d.ts +4 -0
  71. package/container/Container.js +194 -0
  72. package/container/Container.stories.tsx +214 -0
  73. package/container/types.d.ts +74 -0
  74. package/date-input/Calendar.d.ts +4 -0
  75. package/date-input/Calendar.js +214 -0
  76. package/date-input/DateInput.js +171 -306
  77. package/date-input/DateInput.stories.tsx +203 -56
  78. package/date-input/DateInput.test.js +808 -0
  79. package/date-input/DatePicker.d.ts +4 -0
  80. package/date-input/DatePicker.js +115 -0
  81. package/date-input/Icons.d.ts +6 -0
  82. package/date-input/Icons.js +58 -0
  83. package/date-input/YearPicker.d.ts +4 -0
  84. package/date-input/YearPicker.js +100 -0
  85. package/date-input/types.d.ts +86 -22
  86. package/dialog/Dialog.d.ts +1 -1
  87. package/dialog/Dialog.js +68 -130
  88. package/dialog/Dialog.stories.tsx +320 -167
  89. package/dialog/Dialog.test.js +307 -0
  90. package/dialog/types.d.ts +18 -25
  91. package/dropdown/Dropdown.d.ts +1 -1
  92. package/dropdown/Dropdown.js +248 -307
  93. package/dropdown/Dropdown.stories.tsx +245 -56
  94. package/dropdown/Dropdown.test.js +599 -0
  95. package/dropdown/DropdownMenu.d.ts +4 -0
  96. package/dropdown/DropdownMenu.js +63 -0
  97. package/dropdown/DropdownMenuItem.d.ts +4 -0
  98. package/dropdown/DropdownMenuItem.js +67 -0
  99. package/dropdown/types.d.ts +32 -14
  100. package/file-input/FileInput.d.ts +2 -2
  101. package/file-input/FileInput.js +246 -357
  102. package/file-input/FileInput.stories.tsx +123 -12
  103. package/file-input/FileInput.test.js +459 -0
  104. package/file-input/FileItem.d.ts +4 -14
  105. package/file-input/FileItem.js +50 -99
  106. package/file-input/types.d.ts +25 -8
  107. package/flex/Flex.d.ts +4 -0
  108. package/flex/Flex.js +57 -0
  109. package/flex/Flex.stories.tsx +112 -0
  110. package/flex/types.d.ts +97 -0
  111. package/footer/Footer.d.ts +1 -1
  112. package/footer/Footer.js +70 -190
  113. package/footer/Footer.stories.tsx +60 -19
  114. package/footer/Footer.test.js +85 -0
  115. package/footer/Icons.d.ts +3 -2
  116. package/footer/Icons.js +67 -8
  117. package/footer/types.d.ts +25 -26
  118. package/grid/Grid.d.ts +7 -0
  119. package/grid/Grid.js +76 -0
  120. package/grid/Grid.stories.tsx +219 -0
  121. package/grid/types.d.ts +115 -0
  122. package/header/Header.d.ts +4 -3
  123. package/header/Header.js +99 -203
  124. package/header/Header.stories.tsx +152 -63
  125. package/header/Header.test.js +66 -0
  126. package/header/Icons.d.ts +2 -2
  127. package/header/Icons.js +4 -9
  128. package/header/types.d.ts +5 -19
  129. package/heading/Heading.js +10 -32
  130. package/heading/Heading.test.js +169 -0
  131. package/heading/types.d.ts +7 -7
  132. package/image/Image.d.ts +4 -0
  133. package/image/Image.js +70 -0
  134. package/image/Image.stories.tsx +127 -0
  135. package/image/types.d.ts +72 -0
  136. package/image/types.js +5 -0
  137. package/inset/Inset.js +14 -55
  138. package/inset/Inset.stories.tsx +37 -36
  139. package/inset/types.d.ts +26 -2
  140. package/layout/ApplicationLayout.d.ts +16 -6
  141. package/layout/ApplicationLayout.js +83 -174
  142. package/layout/ApplicationLayout.stories.tsx +85 -94
  143. package/layout/Icons.d.ts +8 -0
  144. package/layout/Icons.js +51 -48
  145. package/layout/SidenavContext.d.ts +5 -0
  146. package/layout/SidenavContext.js +13 -0
  147. package/layout/types.d.ts +19 -35
  148. package/link/Link.d.ts +3 -2
  149. package/link/Link.js +61 -99
  150. package/link/Link.stories.tsx +155 -53
  151. package/link/Link.test.js +63 -0
  152. package/link/types.d.ts +15 -31
  153. package/main.d.ts +16 -18
  154. package/main.js +63 -123
  155. package/nav-tabs/NavTabs.d.ts +8 -0
  156. package/nav-tabs/NavTabs.js +93 -0
  157. package/nav-tabs/NavTabs.stories.tsx +276 -0
  158. package/nav-tabs/NavTabs.test.js +76 -0
  159. package/nav-tabs/Tab.d.ts +4 -0
  160. package/nav-tabs/Tab.js +118 -0
  161. package/nav-tabs/types.d.ts +52 -0
  162. package/nav-tabs/types.js +5 -0
  163. package/number-input/NumberInput.d.ts +7 -0
  164. package/number-input/NumberInput.js +48 -45
  165. package/number-input/NumberInput.stories.tsx +44 -28
  166. package/number-input/NumberInput.test.js +989 -0
  167. package/number-input/types.d.ts +28 -15
  168. package/package.json +46 -47
  169. package/paginator/Icons.d.ts +5 -0
  170. package/paginator/Icons.js +21 -47
  171. package/paginator/Paginator.js +34 -91
  172. package/paginator/Paginator.stories.tsx +24 -0
  173. package/paginator/Paginator.test.js +335 -0
  174. package/paginator/types.d.ts +3 -3
  175. package/paragraph/Paragraph.d.ts +5 -0
  176. package/paragraph/Paragraph.js +22 -0
  177. package/paragraph/Paragraph.stories.tsx +27 -0
  178. package/password-input/Icons.d.ts +6 -0
  179. package/password-input/Icons.js +35 -0
  180. package/password-input/PasswordInput.js +57 -123
  181. package/password-input/PasswordInput.stories.tsx +1 -33
  182. package/password-input/PasswordInput.test.js +198 -0
  183. package/password-input/types.d.ts +21 -17
  184. package/progress-bar/ProgressBar.js +65 -91
  185. package/progress-bar/ProgressBar.stories.tsx +93 -0
  186. package/progress-bar/ProgressBar.test.js +93 -0
  187. package/progress-bar/types.d.ts +3 -3
  188. package/quick-nav/QuickNav.d.ts +4 -0
  189. package/quick-nav/QuickNav.js +94 -0
  190. package/quick-nav/QuickNav.stories.tsx +356 -0
  191. package/quick-nav/types.d.ts +21 -0
  192. package/quick-nav/types.js +5 -0
  193. package/radio-group/Radio.d.ts +1 -1
  194. package/radio-group/Radio.js +64 -80
  195. package/radio-group/RadioGroup.js +101 -139
  196. package/radio-group/RadioGroup.stories.tsx +171 -36
  197. package/radio-group/RadioGroup.test.js +691 -183
  198. package/radio-group/types.d.ts +89 -11
  199. package/resultset-table/Icons.d.ts +7 -0
  200. package/resultset-table/Icons.js +47 -0
  201. package/resultset-table/ResultsetTable.d.ts +7 -0
  202. package/resultset-table/ResultsetTable.js +167 -0
  203. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +152 -30
  204. package/resultset-table/ResultsetTable.test.js +371 -0
  205. package/{resultsetTable → resultset-table}/types.d.ts +13 -7
  206. package/resultset-table/types.js +5 -0
  207. package/select/Icons.d.ts +10 -0
  208. package/select/Icons.js +89 -0
  209. package/select/Listbox.d.ts +4 -0
  210. package/select/Listbox.js +143 -0
  211. package/select/Option.d.ts +4 -0
  212. package/select/Option.js +87 -0
  213. package/select/Select.js +229 -502
  214. package/select/Select.stories.tsx +603 -204
  215. package/select/Select.test.js +2370 -0
  216. package/select/types.d.ts +64 -25
  217. package/sidenav/Icons.d.ts +7 -0
  218. package/sidenav/Icons.js +47 -0
  219. package/sidenav/Sidenav.d.ts +6 -5
  220. package/sidenav/Sidenav.js +131 -71
  221. package/sidenav/Sidenav.stories.tsx +251 -151
  222. package/sidenav/Sidenav.test.js +37 -0
  223. package/sidenav/types.d.ts +52 -26
  224. package/slider/Slider.d.ts +2 -2
  225. package/slider/Slider.js +148 -180
  226. package/slider/Slider.test.js +254 -0
  227. package/slider/types.d.ts +11 -3
  228. package/spinner/Spinner.js +31 -75
  229. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
  230. package/spinner/Spinner.test.js +55 -0
  231. package/spinner/types.d.ts +3 -3
  232. package/status-light/StatusLight.d.ts +4 -0
  233. package/status-light/StatusLight.js +51 -0
  234. package/status-light/StatusLight.stories.tsx +74 -0
  235. package/status-light/StatusLight.test.js +25 -0
  236. package/status-light/types.d.ts +17 -0
  237. package/status-light/types.js +5 -0
  238. package/switch/Switch.d.ts +2 -2
  239. package/switch/Switch.js +149 -114
  240. package/switch/Switch.stories.tsx +44 -67
  241. package/switch/Switch.test.js +180 -0
  242. package/switch/types.d.ts +13 -5
  243. package/table/ActionsCell.d.ts +4 -0
  244. package/table/ActionsCell.js +67 -0
  245. package/table/DropdownTheme.js +62 -0
  246. package/table/Table.d.ts +4 -1
  247. package/table/Table.js +26 -32
  248. package/table/Table.stories.tsx +658 -0
  249. package/table/Table.test.js +113 -0
  250. package/table/types.d.ts +45 -6
  251. package/tabs/Tab.d.ts +4 -0
  252. package/tabs/Tab.js +116 -0
  253. package/tabs/Tabs.d.ts +1 -1
  254. package/tabs/Tabs.js +316 -145
  255. package/tabs/Tabs.stories.tsx +120 -14
  256. package/tabs/Tabs.test.js +294 -0
  257. package/tabs/types.d.ts +29 -15
  258. package/tag/Tag.js +41 -78
  259. package/tag/Tag.stories.tsx +25 -8
  260. package/tag/Tag.test.js +49 -0
  261. package/tag/types.d.ts +7 -7
  262. package/text-input/Icons.d.ts +8 -0
  263. package/text-input/Icons.js +56 -0
  264. package/text-input/Suggestion.d.ts +4 -0
  265. package/text-input/Suggestion.js +67 -0
  266. package/text-input/Suggestions.d.ts +4 -0
  267. package/text-input/Suggestions.js +84 -0
  268. package/text-input/TextInput.js +327 -556
  269. package/text-input/TextInput.stories.tsx +281 -272
  270. package/text-input/TextInput.test.js +1756 -0
  271. package/text-input/types.d.ts +70 -24
  272. package/textarea/Textarea.js +85 -135
  273. package/textarea/Textarea.stories.tsx +174 -0
  274. package/textarea/Textarea.test.js +406 -0
  275. package/textarea/types.d.ts +27 -16
  276. package/toggle-group/ToggleGroup.d.ts +2 -2
  277. package/toggle-group/ToggleGroup.js +92 -105
  278. package/toggle-group/ToggleGroup.stories.tsx +53 -8
  279. package/toggle-group/ToggleGroup.test.js +137 -0
  280. package/toggle-group/types.d.ts +34 -17
  281. package/typography/Typography.d.ts +4 -0
  282. package/typography/Typography.js +23 -0
  283. package/typography/Typography.stories.tsx +198 -0
  284. package/typography/types.d.ts +18 -0
  285. package/typography/types.js +5 -0
  286. package/useTheme.d.ts +1147 -1
  287. package/useTheme.js +4 -11
  288. package/useTranslatedLabels.d.ts +85 -0
  289. package/useTranslatedLabels.js +14 -0
  290. package/utils/BaseTypography.d.ts +21 -0
  291. package/utils/BaseTypography.js +94 -0
  292. package/utils/FocusLock.d.ts +13 -0
  293. package/utils/FocusLock.js +124 -0
  294. package/wizard/Wizard.d.ts +1 -1
  295. package/wizard/Wizard.js +70 -101
  296. package/wizard/Wizard.stories.tsx +48 -19
  297. package/wizard/Wizard.test.js +114 -0
  298. package/wizard/types.d.ts +12 -8
  299. package/ThemeContext.d.ts +0 -15
  300. package/ThemeContext.js +0 -243
  301. package/V3Select/V3Select.js +0 -455
  302. package/V3Select/index.d.ts +0 -27
  303. package/V3Textarea/V3Textarea.js +0 -260
  304. package/V3Textarea/index.d.ts +0 -27
  305. package/card/ice-cream.jpg +0 -0
  306. package/common/RequiredComponent.js +0 -32
  307. package/date/Date.js +0 -373
  308. package/date/index.d.ts +0 -27
  309. package/input-text/Icons.js +0 -22
  310. package/input-text/InputText.js +0 -611
  311. package/input-text/index.d.ts +0 -36
  312. package/list/List.d.ts +0 -4
  313. package/list/List.js +0 -47
  314. package/list/List.stories.tsx +0 -95
  315. package/list/types.d.ts +0 -7
  316. package/number-input/NumberInputContext.d.ts +0 -4
  317. package/number-input/NumberInputContext.js +0 -19
  318. package/number-input/numberInputContextTypes.d.ts +0 -19
  319. package/progress-bar/ProgressBar.stories.jsx +0 -58
  320. package/radio/Radio.d.ts +0 -4
  321. package/radio/Radio.js +0 -174
  322. package/radio/Radio.stories.tsx +0 -192
  323. package/radio/types.d.ts +0 -54
  324. package/resultsetTable/ResultsetTable.d.ts +0 -4
  325. package/resultsetTable/ResultsetTable.js +0 -251
  326. package/row/Row.d.ts +0 -3
  327. package/row/Row.js +0 -127
  328. package/row/Row.stories.tsx +0 -237
  329. package/row/types.d.ts +0 -10
  330. package/slider/Slider.stories.tsx +0 -177
  331. package/stack/Stack.d.ts +0 -3
  332. package/stack/Stack.js +0 -97
  333. package/stack/Stack.stories.tsx +0 -164
  334. package/stack/types.d.ts +0 -9
  335. package/table/Table.stories.jsx +0 -277
  336. package/text/Text.d.ts +0 -7
  337. package/text/Text.js +0 -30
  338. package/text/Text.stories.tsx +0 -19
  339. package/textarea/Textarea.stories.jsx +0 -136
  340. package/toggle/Toggle.js +0 -186
  341. package/toggle/index.d.ts +0 -21
  342. package/upload/Upload.js +0 -201
  343. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  344. package/upload/buttons-upload/Icons.js +0 -40
  345. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  346. package/upload/dragAndDropArea/Icons.js +0 -39
  347. package/upload/file-upload/FileToUpload.js +0 -115
  348. package/upload/file-upload/Icons.js +0 -66
  349. package/upload/files-upload/FilesToUpload.js +0 -109
  350. package/upload/index.d.ts +0 -15
  351. package/upload/transaction/Icons.js +0 -160
  352. package/upload/transaction/Transaction.js +0 -104
  353. package/upload/transactions/Transactions.js +0 -94
  354. /package/{list → action-icon}/types.js +0 -0
  355. /package/{radio → badge}/types.js +0 -0
  356. /package/{resultsetTable → bulleted-list}/types.js +0 -0
  357. /package/{row → container}/types.js +0 -0
  358. /package/{stack → flex}/types.js +0 -0
  359. /package/{number-input/numberInputContextTypes.js → grid/types.js} +0 -0
package/footer/Footer.js CHANGED
@@ -1,194 +1,94 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- var _typeof3 = require("@babel/runtime/helpers/typeof");
6
-
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
7
5
  Object.defineProperty(exports, "__esModule", {
8
6
  value: true
9
7
  });
10
8
  exports["default"] = void 0;
11
-
12
- var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
13
-
14
9
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
-
16
- var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
17
-
18
10
  var _react = _interopRequireWildcard(require("react"));
19
-
20
11
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
21
-
22
- var _variables = require("../common/variables.js");
23
-
12
+ var _variables = require("../common/variables");
24
13
  var _useTheme = _interopRequireDefault(require("../useTheme"));
25
-
26
- var _BackgroundColorContext = require("../BackgroundColorContext");
27
-
14
+ var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
28
15
  var _Icons = require("./Icons");
29
-
30
- var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10, _templateObject11, _templateObject12, _templateObject13, _templateObject14;
31
-
32
- 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); }
33
-
34
- function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
35
-
16
+ var _Flex = _interopRequireDefault(require("../flex/Flex"));
17
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10;
18
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
19
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
36
20
  var DxcFooter = function DxcFooter(_ref) {
37
21
  var socialLinks = _ref.socialLinks,
38
- bottomLinks = _ref.bottomLinks,
39
- _ref$copyright = _ref.copyright,
40
- copyright = _ref$copyright === void 0 ? "\xA9 DXC Technology ".concat(new Date().getFullYear(), ". All rights reserved.") : _ref$copyright,
41
- children = _ref.children,
42
- padding = _ref.padding,
43
- margin = _ref.margin,
44
- _ref$tabIndex = _ref.tabIndex,
45
- tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
46
- var ref = (0, _react.useRef)(null);
47
-
48
- var _useState = (0, _react.useState)(),
49
- _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
50
- refSize = _useState2[0],
51
- setRefSize = _useState2[1];
52
-
53
- var _useState3 = (0, _react.useState)(false),
54
- _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
55
- isResponsiveTablet = _useState4[0],
56
- setIsResponsiveTablet = _useState4[1];
57
-
58
- var _useState5 = (0, _react.useState)(false),
59
- _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
60
- isResponsivePhone = _useState6[0],
61
- setIsResponsivePhone = _useState6[1];
62
-
22
+ bottomLinks = _ref.bottomLinks,
23
+ copyright = _ref.copyright,
24
+ children = _ref.children,
25
+ margin = _ref.margin,
26
+ _ref$tabIndex = _ref.tabIndex,
27
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex,
28
+ _ref$mode = _ref.mode,
29
+ mode = _ref$mode === void 0 ? "default" : _ref$mode;
63
30
  var colorsTheme = (0, _useTheme["default"])();
31
+ var translatedLabels = (0, _useTranslatedLabels["default"])();
64
32
  var footerLogo = (0, _react.useMemo)(function () {
65
- if (!colorsTheme.footer.logo) {
66
- return _Icons.dxcLogo;
67
- }
68
-
69
- if (typeof colorsTheme.footer.logo === "string") {
70
- return /*#__PURE__*/_react["default"].createElement(LogoImg, {
71
- alt: "Logo",
72
- src: colorsTheme.footer.logo
73
- });
74
- }
75
-
76
- return colorsTheme.footer.logo;
77
- }, [colorsTheme.footer.logo]);
78
-
79
- var handleResize = function handleResize(refWidth) {
80
- if (ref.current) {
81
- setRefSize(refWidth);
82
-
83
- if (refWidth <= _variables.responsiveSizes.tablet && refWidth > _variables.responsiveSizes.mobileLarge) {
84
- setIsResponsiveTablet(true);
85
- setIsResponsivePhone(false);
86
- } else if (refWidth <= _variables.responsiveSizes.tablet && refWidth <= _variables.responsiveSizes.mobileLarge) {
87
- setIsResponsivePhone(true);
88
- setIsResponsiveTablet(false);
89
- } else {
90
- setIsResponsiveTablet(false);
91
- setIsResponsivePhone(false);
92
- }
93
- }
94
- };
95
-
96
- var handleEventListener = function handleEventListener() {
97
- handleResize(ref.current.offsetWidth);
98
- };
99
-
100
- (0, _react.useEffect)(function () {
101
- window.addEventListener("resize", handleEventListener);
102
- handleResize(ref.current.offsetWidth);
103
- return function () {
104
- window.removeEventListener("resize", handleEventListener);
105
- };
106
- }, []);
107
- var socialLink = socialLinks === null || socialLinks === void 0 ? void 0 : socialLinks.map(function (link, index) {
33
+ return !colorsTheme.footer.logo ? mode === "default" ? _Icons.dxcLogo : _Icons.dxcSmallLogo : typeof colorsTheme.footer.logo === "string" ? /*#__PURE__*/_react["default"].createElement(LogoImg, {
34
+ mode: mode,
35
+ alt: translatedLabels.formFields.logoAlternativeText,
36
+ src: colorsTheme.footer.logo
37
+ }) : colorsTheme.footer.logo;
38
+ }, [colorsTheme]);
39
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
40
+ theme: colorsTheme.footer
41
+ }, /*#__PURE__*/_react["default"].createElement(FooterContainer, {
42
+ margin: margin,
43
+ mode: mode
44
+ }, /*#__PURE__*/_react["default"].createElement(_Flex["default"], {
45
+ justifyContent: "space-between",
46
+ alignItems: "center",
47
+ wrap: "wrap",
48
+ gap: "1.5rem"
49
+ }, /*#__PURE__*/_react["default"].createElement(LogoContainer, {
50
+ mode: mode
51
+ }, footerLogo), mode === "default" && /*#__PURE__*/_react["default"].createElement(_Flex["default"], null, socialLinks === null || socialLinks === void 0 ? void 0 : socialLinks.map(function (link, index) {
108
52
  return /*#__PURE__*/_react["default"].createElement(SocialAnchor, {
53
+ href: link.href,
109
54
  tabIndex: tabIndex,
55
+ title: link.title,
56
+ "aria-label": link.title,
110
57
  key: "social".concat(index).concat(link.href),
111
- index: index,
112
- href: link && link.href ? link.href : ""
113
- }, /*#__PURE__*/_react["default"].createElement(SocialIconContainer, null, typeof link.logo === "string" ? /*#__PURE__*/_react["default"].createElement(SocialIconImg, {
114
- src: link.logo
58
+ index: index
59
+ }, /*#__PURE__*/_react["default"].createElement(SocialIconContainer, null, typeof link.logo === "string" ? /*#__PURE__*/_react["default"].createElement("img", {
60
+ src: link.logo,
61
+ alt: link.title
115
62
  }) : link.logo));
116
- });
117
- var bottomLink = bottomLinks === null || bottomLinks === void 0 ? void 0 : bottomLinks.map(function (link, index) {
63
+ }))), /*#__PURE__*/_react["default"].createElement(ChildComponents, null, children), mode === "default" && /*#__PURE__*/_react["default"].createElement(BottomContainer, null, /*#__PURE__*/_react["default"].createElement(BottomLinks, null, bottomLinks === null || bottomLinks === void 0 ? void 0 : bottomLinks.map(function (link, index) {
118
64
  return /*#__PURE__*/_react["default"].createElement("span", {
119
65
  key: "bottom".concat(index).concat(link.text)
120
66
  }, /*#__PURE__*/_react["default"].createElement(BottomLink, {
121
- tabIndex: tabIndex,
122
- href: link && link.href ? link.href : ""
123
- }, link && link.text ? link.text : ""), /*#__PURE__*/_react["default"].createElement(Point, {
124
- index: index
125
- }, "\xB7"));
126
- });
127
- return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
128
- theme: colorsTheme.footer
129
- }, /*#__PURE__*/_react["default"].createElement(FooterContainer, {
130
- margin: margin,
131
- refSize: refSize,
132
- ref: ref
133
- }, /*#__PURE__*/_react["default"].createElement(FooterHeader, {
134
- refSize: refSize
135
- }, /*#__PURE__*/_react["default"].createElement(LogoContainer, null, footerLogo), /*#__PURE__*/_react["default"].createElement(SocialLinkContainer, {
136
- refSize: refSize
137
- }, socialLink)), /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(ChildComponents, {
138
- padding: padding
139
- }, /*#__PURE__*/_react["default"].createElement(_BackgroundColorContext.BackgroundColorProvider, {
140
- color: colorsTheme.footer.backgroundColor
141
- }, children)), /*#__PURE__*/_react["default"].createElement(FooterFooter, {
142
- className: "footerFooter",
143
- refSize: refSize
144
- }, /*#__PURE__*/_react["default"].createElement(BottomLinks, {
145
- refSize: refSize
146
- }, bottomLink), /*#__PURE__*/_react["default"].createElement(Copyright, {
147
- refSize: refSize
148
- }, copyright)))));
67
+ href: link.href,
68
+ tabIndex: tabIndex
69
+ }, link.text));
70
+ })), /*#__PURE__*/_react["default"].createElement(Copyright, null, copyright || translatedLabels.footer.copyrightText(new Date().getFullYear())))));
149
71
  };
150
-
151
- var FooterContainer = _styledComponents["default"].footer(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n padding: ", ";\n background-color: ", ";\n margin-top: ", ";\n width: 100%;\n box-sizing: border-box;\n min-height: ", ";\n display: flex;\n flex-direction: column;\n justify-content: space-between;\n"])), function (props) {
152
- return props.refSize <= _variables.responsiveSizes.mobileLarge ? "20px 20px 20px 20px" : "24px 36px 24px 36px";
153
- }, function (props) {
72
+ var FooterContainer = _styledComponents["default"].footer(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n box-sizing: border-box;\n display: flex;\n flex-direction: ", ";\n justify-content: space-between;\n margin-top: ", ";\n min-height: ", ";\n width: 100%;\n gap: ", ";\n @media (min-width: ", "rem) {\n padding: ", ";\n }\n @media (max-width: ", "rem) {\n padding: 20px;\n flex-direction: column;\n }\n"])), function (props) {
154
73
  return props.theme.backgroundColor;
155
74
  }, function (props) {
156
- return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
75
+ return (props === null || props === void 0 ? void 0 : props.mode) === "default" ? "column" : "row";
157
76
  }, function (props) {
158
- return props.theme.height;
159
- });
160
-
161
- var FooterHeader = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: space-between;\n flex-wrap: wrap;\n row-gap: 24px;\n"])));
162
-
163
- var FooterFooter = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: space-between;\n align-items: flex-end;\n flex-direction: ", ";\n align-items: ", ";\n border-top: ", ";\n margin-top: 16px;\n"])), function (props) {
164
- return props.refSize <= _variables.responsiveSizes.mobileLarge ? "column" : "row";
77
+ return props.margin ? _variables.spaces[props.margin] : "0px";
165
78
  }, function (props) {
166
- return props.refSize <= _variables.responsiveSizes.mobileLarge ? "center" : "";
79
+ return (props === null || props === void 0 ? void 0 : props.mode) === "default" ? props.theme.height : "40px";
167
80
  }, function (props) {
81
+ return (props === null || props === void 0 ? void 0 : props.mode) === "default" ? "0px" : "32px";
82
+ }, _variables.responsiveSizes.small, function (props) {
83
+ return (props === null || props === void 0 ? void 0 : props.mode) === "default" ? "24px 32px" : "12px 32px";
84
+ }, _variables.responsiveSizes.small);
85
+ var BottomContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: space-between;\n align-items: flex-end;\n\n @media (min-width: ", "rem) {\n flex-direction: row;\n }\n @media (max-width: ", "rem) {\n flex-direction: column;\n align-items: center;\n }\n\n border-top: ", ";\n margin-top: 16px;\n"])), _variables.responsiveSizes.small, _variables.responsiveSizes.small, function (props) {
168
86
  return "".concat(props.theme.bottomLinksDividerThickness, " ").concat(props.theme.bottomLinksDividerStyle, " ").concat(props.theme.bottomLinksDividerColor);
169
87
  });
170
-
171
- var BottomLinks = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n padding-top: ", ";\n display: inline-flex;\n flex-wrap: wrap;\n max-width: ", ";\n width: ", ";\n & > span:last-child span {\n display: none;\n }\n align-self: center;\n"])), function (props) {
88
+ var ChildComponents = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n min-height: 16px;\n overflow: hidden;\n"])));
89
+ var Copyright = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n padding-top: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n color: ", ";\n\n @media (min-width: ", "rem) {\n max-width: 40%;\n text-align: right;\n }\n\n @media (max-width: ", "rem) {\n max-width: 100%;\n width: 100%;\n text-align: left;\n }\n"])), function (props) {
172
90
  return props.theme.bottomLinksDividerSpacing;
173
91
  }, function (props) {
174
- return props.refSize <= _variables.responsiveSizes.mobileLarge ? "100%" : "60%";
175
- }, function (props) {
176
- return props.refSize <= _variables.responsiveSizes.mobileLarge ? "100%" : "";
177
- });
178
-
179
- var ChildComponents = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n min-height: 16px;\n padding: ", ";\n padding-top: ", ";\n padding-right: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n overflow: hidden;\n"])), function (props) {
180
- return props.padding && (0, _typeof2["default"])(props.padding) !== "object" ? _variables.spaces[props.padding] : "0px";
181
- }, function (props) {
182
- return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.top ? _variables.spaces[props.padding.top] : "";
183
- }, function (props) {
184
- return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.right ? _variables.spaces[props.padding.right] : "";
185
- }, function (props) {
186
- return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.bottom ? _variables.spaces[props.padding.bottom] : "";
187
- }, function (props) {
188
- return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.left ? _variables.spaces[props.padding.left] : "";
189
- });
190
-
191
- var Copyright = _styledComponents["default"].div(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n color: ", ";\n max-width: ", ";\n width: ", ";\n text-align: ", ";\n padding-top: ", ";\n"])), function (props) {
192
92
  return props.theme.copyrightFontFamily;
193
93
  }, function (props) {
194
94
  return props.theme.copyrightFontSize;
@@ -198,49 +98,31 @@ var Copyright = _styledComponents["default"].div(_templateObject6 || (_templateO
198
98
  return props.theme.copyrightFontWeight;
199
99
  }, function (props) {
200
100
  return props.theme.copyrightFontColor;
201
- }, function (props) {
202
- return props.refSize <= _variables.responsiveSizes.mobileLarge ? "100%" : "40%";
203
- }, function (props) {
204
- return props.refSize <= _variables.responsiveSizes.mobileLarge ? "100%" : "";
205
- }, function (props) {
206
- return props.refSize <= _variables.responsiveSizes.mobileLarge ? "left" : "right";
207
- }, function (props) {
208
- return props.theme.bottomLinksDividerSpacing;
209
- });
210
-
211
- var LogoContainer = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n max-height: ", ";\n width: ", ";\n"])), function (props) {
212
- return props.theme.logoHeight;
101
+ }, _variables.responsiveSizes.small, _variables.responsiveSizes.small);
102
+ var LogoContainer = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n max-height: ", ";\n width: ", ";\n"])), function (props) {
103
+ return (props === null || props === void 0 ? void 0 : props.mode) === "default" ? props.theme.logoHeight : "16px";
213
104
  }, function (props) {
214
105
  return props.theme.logoWidth;
215
106
  });
216
-
217
- var LogoImg = _styledComponents["default"].img(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n max-height: ", ";\n width: ", ";\n"])), function (props) {
218
- return props.theme.logoHeight;
107
+ var LogoImg = _styledComponents["default"].img(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n max-height: ", ";\n width: ", ";\n"])), function (props) {
108
+ return (props === null || props === void 0 ? void 0 : props.mode) === "default" ? props.theme.logoHeight : "16px";
219
109
  }, function (props) {
220
110
  return props.theme.logoWidth;
221
111
  });
222
-
223
- var SocialLinkContainer = _styledComponents["default"].div(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-self: center;\n"])));
224
-
225
- var SocialAnchor = _styledComponents["default"].a(_templateObject10 || (_templateObject10 = (0, _taggedTemplateLiteral2["default"])(["\n & {\n display: inline-flex;\n margin-left: ", ";\n }\n"])), function (props) {
112
+ var SocialAnchor = _styledComponents["default"].a(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n margin-left: ", ";\n border-radius: 4px;\n\n &:focus {\n outline: 2px solid #0095ff;\n outline-offset: 2px;\n }\n"])), function (props) {
226
113
  return props.index === 0 ? "0px" : props.theme.socialLinksGutter;
227
114
  });
228
-
229
- var SocialIconImg = _styledComponents["default"].img(_templateObject11 || (_templateObject11 = (0, _taggedTemplateLiteral2["default"])([""])));
230
-
231
- var SocialIconContainer = _styledComponents["default"].div(_templateObject12 || (_templateObject12 = (0, _taggedTemplateLiteral2["default"])(["\n & {\n display: inline-flex;\n height: ", ";\n width: ", ";\n color: ", ";\n }\n\n overflow: hidden;\n img,\n svg {\n height: 100%;\n width: 100%;\n }\n"])), function (props) {
115
+ var SocialIconContainer = _styledComponents["default"].div(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n height: ", ";\n width: ", ";\n color: ", ";\n overflow: hidden;\n\n img,\n svg {\n height: 100%;\n width: 100%;\n }\n"])), function (props) {
232
116
  return props.theme.socialLinksSize;
233
117
  }, function (props) {
234
118
  return props.theme.socialLinksSize;
235
119
  }, function (props) {
236
120
  return props.theme.socialLinksColor;
237
121
  });
238
-
239
- var Point = _styledComponents["default"].span(_templateObject13 || (_templateObject13 = (0, _taggedTemplateLiteral2["default"])(["\n margin: 0px 10px;\n color: ", ";\n"])), function (props) {
240
- return props.theme.bottomLinksFontColor;
241
- });
242
-
243
- var BottomLink = _styledComponents["default"].a(_templateObject14 || (_templateObject14 = (0, _taggedTemplateLiteral2["default"])(["\n text-decoration: ", ";\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n"])), function (props) {
122
+ var BottomLinks = _styledComponents["default"].div(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n flex-wrap: wrap;\n align-self: center;\n padding-top: ", ";\n color: #fff;\n\n @media (min-width: ", "rem) {\n max-width: 60%;\n }\n @media (max-width: ", "rem) {\n max-width: 100%;\n width: 100%;\n }\n\n & > span:not(:first-child):before {\n content: \"\xB7\";\n padding: 0 0.5rem;\n }\n"])), function (props) {
123
+ return props.theme.bottomLinksDividerSpacing;
124
+ }, _variables.responsiveSizes.small, _variables.responsiveSizes.small);
125
+ var BottomLink = _styledComponents["default"].a(_templateObject10 || (_templateObject10 = (0, _taggedTemplateLiteral2["default"])(["\n text-decoration: ", ";\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n border-radius: 2px;\n\n &:focus {\n outline: 2px solid #0095ff;\n }\n"])), function (props) {
244
126
  return props.theme.bottomLinksTextDecoration;
245
127
  }, function (props) {
246
128
  return props.theme.bottomLinksFontColor;
@@ -253,6 +135,4 @@ var BottomLink = _styledComponents["default"].a(_templateObject14 || (_templateO
253
135
  }, function (props) {
254
136
  return props.theme.bottomLinksFontWeight;
255
137
  });
256
-
257
- var _default = DxcFooter;
258
- exports["default"] = _default;
138
+ var _default = exports["default"] = DxcFooter;
@@ -2,6 +2,9 @@ import React from "react";
2
2
  import DxcFooter from "./Footer";
3
3
  import Title from "../../.storybook/components/Title";
4
4
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
5
+ import { HalstackProvider } from "../HalstackContext";
6
+ import DxcFlex from "../flex/Flex";
7
+ import DxcTypography from "../typography/Typography";
5
8
 
6
9
  const social = [
7
10
  {
@@ -25,10 +28,20 @@ const social = [
25
28
  </g>
26
29
  </svg>
27
30
  ),
31
+ title: "Linkedin",
28
32
  },
29
33
  {
30
- href: "https://twitter.com/dxctechnology",
31
- logo: "http://assets.stickpng.com/images/580b57fcd9996e24bc43c53e.png",
34
+ href: "https://x.com/dxctechnology",
35
+ logo: (
36
+ <svg width="256" height="256" viewBox="0 0 256 256" fill="none" xmlns="http://www.w3.org/2000/svg">
37
+ <rect width="256" height="256" rx="40" fill="white" />
38
+ <path
39
+ d="M140.192 118.205L187.848 64H176.556L135.158 111.056L102.117 64H64L113.975 135.163L64 192H75.2914L118.982 142.296L153.883 192H192L140.192 118.205ZM124.722 135.787L119.65 128.697L79.3634 72.3294H96.7094L129.232 117.837L134.282 124.927L176.551 184.076H159.205L124.722 135.787Z"
40
+ fill="#0F1419"
41
+ />
42
+ </svg>
43
+ ),
44
+ title: "X",
32
45
  },
33
46
  {
34
47
  href: "https://www.facebook.com/DXCTechnology/",
@@ -55,6 +68,7 @@ const social = [
55
68
  </g>
56
69
  </svg>
57
70
  ),
71
+ title: "Facebook",
58
72
  },
59
73
  ];
60
74
 
@@ -64,8 +78,8 @@ const bottom = [
64
78
  text: "Linkedin",
65
79
  },
66
80
  {
67
- href: "https://twitter.com/dxctechnology",
68
- text: "Twitter",
81
+ href: "https://x.com/dxctechnology",
82
+ text: "X",
69
83
  },
70
84
  {
71
85
  href: "https://www.facebook.com/DXCTechnology/",
@@ -78,6 +92,20 @@ export default {
78
92
  component: DxcFooter,
79
93
  };
80
94
 
95
+ const opinionatedTheme = {
96
+ footer: {
97
+ baseColor: "#000000",
98
+ fontColor: "#ffffff",
99
+ accentColor: "#0095ff",
100
+ logo: "https://upload.wikimedia.org/wikipedia/commons/thumb/b/b8/2021_Facebook_icon.svg/2048px-2021_Facebook_icon.svg.png",
101
+ },
102
+ };
103
+
104
+ const info = [
105
+ { label: "Example Label", text: "Example" },
106
+ { label: "Example Label", text: "Example" },
107
+ ];
108
+
81
109
  export const Chromatic = () => (
82
110
  <>
83
111
  <ExampleContainer>
@@ -92,6 +120,26 @@ export const Chromatic = () => (
92
120
  </div>
93
121
  </DxcFooter>
94
122
  </ExampleContainer>
123
+ <ExampleContainer pseudoState="pseudo-focus">
124
+ <Title title="Focused bottom and social links" theme="light" level={4} />
125
+ <DxcFooter copyright="Copyright" socialLinks={social} bottomLinks={bottom}>
126
+ <div>
127
+ <a href="https://www.linkedin.com/company/dxctechnology">Linkedin</a>
128
+ </div>
129
+ </DxcFooter>
130
+ </ExampleContainer>
131
+ <ExampleContainer>
132
+ <Title title="Reduced" theme="light" level={4} />
133
+ <DxcFooter mode="reduced">
134
+ <DxcFlex justifyContent="center" alignItems="center" gap={"1rem"}>
135
+ {info.map((tag, index) => (
136
+ <DxcTypography color="white" key={`tag${index}${tag.label}${tag.text}`} >
137
+ {tag.label}: {tag.text}
138
+ </DxcTypography>
139
+ ))}
140
+ </DxcFlex>
141
+ </DxcFooter>
142
+ </ExampleContainer>
95
143
  <Title title="Margins" theme="light" level={2} />
96
144
  <ExampleContainer>
97
145
  <Title title="Xxsmall margin" theme="light" level={4} />
@@ -109,22 +157,15 @@ export const Chromatic = () => (
109
157
  <Title title="Xxlarge margin" theme="light" level={4} />
110
158
  <DxcFooter margin="xxlarge"></DxcFooter>
111
159
  </ExampleContainer>
112
- <Title title="Padding" theme="light" level={2} />
160
+ <Title title="Opinionated theme" theme="light" level={2} />
113
161
  <ExampleContainer>
114
- <Title title="Xxsmall padding" theme="light" level={4} />
115
- <DxcFooter padding="xxsmall"></DxcFooter>
116
- <Title title="Xsmall padding" theme="light" level={4} />
117
- <DxcFooter padding="xsmall"></DxcFooter>
118
- <Title title="Small padding" theme="light" level={4} />
119
- <DxcFooter padding="small"></DxcFooter>
120
- <Title title="Medium padding" theme="light" level={4} />
121
- <DxcFooter padding="medium"></DxcFooter>
122
- <Title title="Large padding" theme="light" level={4} />
123
- <DxcFooter padding="large"></DxcFooter>
124
- <Title title="Xlarge padding" theme="light" level={4} />
125
- <DxcFooter padding="xlarge"></DxcFooter>
126
- <Title title="Xxlarge padding" theme="light" level={4} />
127
- <DxcFooter padding="xxlarge"></DxcFooter>
162
+ <HalstackProvider theme={opinionatedTheme}>
163
+ <DxcFooter copyright="Copyright" socialLinks={social} bottomLinks={bottom}>
164
+ <div>
165
+ <a href="https://www.linkedin.com/company/dxctechnology">Linkedin</a>
166
+ </div>
167
+ </DxcFooter>
168
+ </HalstackProvider>
128
169
  </ExampleContainer>
129
170
  </>
130
171
  );
@@ -0,0 +1,85 @@
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 _Footer = _interopRequireDefault(require("./Footer.tsx"));
7
+ var social = [{
8
+ href: "https://www.test.com/social",
9
+ logo: "https://developer.apple.com/design/human-interface-guidelines/foundations/app-icons/images/icon-and-image-large-icon-settings_2x.png",
10
+ title: "test"
11
+ }];
12
+ var bottom = [{
13
+ href: "https://www.test.com/bottom",
14
+ text: "bottom-link-text"
15
+ }];
16
+ describe("Footer component tests", function () {
17
+ test("Footer renders with default logo", function () {
18
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Footer["default"], null)),
19
+ getByTitle = _render.getByTitle;
20
+ expect(getByTitle("DXC Logo")).toBeTruthy();
21
+ });
22
+ test("Footer renders with social links", function () {
23
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Footer["default"], {
24
+ socialLinks: social
25
+ })),
26
+ getByRole = _render2.getByRole;
27
+ var socialIcon = getByRole("link");
28
+ expect(socialIcon.getAttribute("href")).toBe("https://www.test.com/social");
29
+ });
30
+ test("Footer renders with bottom links", function () {
31
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Footer["default"], {
32
+ bottomLinks: bottom
33
+ })),
34
+ getByText = _render3.getByText;
35
+ var link = getByText("bottom-link-text");
36
+ expect(link.getAttribute("href")).toBe("https://www.test.com/bottom");
37
+ });
38
+ test("Footer renders with copyright text", function () {
39
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Footer["default"], {
40
+ copyright: "test-copyright"
41
+ })),
42
+ getByText = _render4.getByText;
43
+ expect(getByText("test-copyright")).toBeTruthy();
44
+ });
45
+ test("Footer renders with correct children", function () {
46
+ // We need to force the offsetWidth value
47
+ Object.defineProperty(HTMLElement.prototype, "offsetWidth", {
48
+ configurable: true,
49
+ value: 1024
50
+ });
51
+ var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Footer["default"], null, /*#__PURE__*/_react["default"].createElement("p", null, "footer-child-text"))),
52
+ getByText = _render5.getByText;
53
+ expect(getByText("footer-child-text")).toBeTruthy();
54
+ });
55
+ test("Footer renders with children in mobile", function () {
56
+ // 425 is mobile width
57
+ Object.defineProperty(HTMLElement.prototype, "offsetWidth", {
58
+ configurable: true,
59
+ value: 425
60
+ });
61
+ var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Footer["default"], null, /*#__PURE__*/_react["default"].createElement("p", null, "footer-child-text"))),
62
+ queryByText = _render6.queryByText;
63
+ expect(queryByText("footer-child-text")).toBeTruthy();
64
+ });
65
+ test("Footer is fully rendered", function () {
66
+ Object.defineProperty(HTMLElement.prototype, "offsetWidth", {
67
+ configurable: true,
68
+ value: 1024
69
+ });
70
+ var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Footer["default"], {
71
+ socialLinks: social,
72
+ bottomLinks: bottom,
73
+ copyright: "test-copyright"
74
+ }, /*#__PURE__*/_react["default"].createElement("p", null, "footer-child-text"))),
75
+ getAllByRole = _render7.getAllByRole,
76
+ getByText = _render7.getByText;
77
+ var socialIcon = getAllByRole("link")[0];
78
+ expect(socialIcon.getAttribute("href")).toBe("https://www.test.com/social");
79
+ expect(socialIcon.getAttribute("aria-label")).toBe("test");
80
+ var bottomLink = getByText("bottom-link-text");
81
+ expect(bottomLink.getAttribute("href")).toBe("https://www.test.com/bottom");
82
+ expect(getByText("test-copyright")).toBeTruthy();
83
+ expect(getByText("footer-child-text")).toBeTruthy();
84
+ });
85
+ });
package/footer/Icons.d.ts CHANGED
@@ -1,2 +1,3 @@
1
- /// <reference types="react" />
2
- export declare const dxcLogo: JSX.Element;
1
+ import React from "react";
2
+ export declare const dxcLogo: React.JSX.Element;
3
+ export declare const dxcSmallLogo: React.JSX.Element;