@dxc-technology/halstack-react 0.0.0-a45812e → 0.0.0-a4bef7b

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 (281) hide show
  1. package/BackgroundColorContext.js +50 -0
  2. package/ThemeContext.js +246 -0
  3. package/V3Select/V3Select.js +455 -0
  4. package/V3Select/index.d.ts +27 -0
  5. package/V3Textarea/V3Textarea.js +260 -0
  6. package/V3Textarea/index.d.ts +27 -0
  7. package/accordion/Accordion.js +289 -0
  8. package/accordion/index.d.ts +28 -0
  9. package/accordion-group/AccordionGroup.js +184 -0
  10. package/accordion-group/index.d.ts +16 -0
  11. package/alert/Alert.js +309 -0
  12. package/alert/index.d.ts +51 -0
  13. package/badge/Badge.js +59 -0
  14. package/{dist/box → box}/Box.js +42 -26
  15. package/box/index.d.ts +25 -0
  16. package/button/Button.d.ts +4 -0
  17. package/button/Button.js +182 -0
  18. package/button/Button.stories.tsx +10 -0
  19. package/button/types.d.ts +22 -0
  20. package/button/types.js +5 -0
  21. package/card/Card.js +200 -0
  22. package/card/index.d.ts +22 -0
  23. package/checkbox/Checkbox.js +275 -0
  24. package/checkbox/index.d.ts +24 -0
  25. package/chip/Chip.js +221 -0
  26. package/chip/index.d.ts +22 -0
  27. package/{dist/common → common}/OpenSans.css +0 -0
  28. package/common/RequiredComponent.js +32 -0
  29. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  30. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  31. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  32. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  33. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  34. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  35. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  36. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  37. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  38. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  39. package/{dist/common → common}/utils.js +0 -0
  40. package/common/variables.js +1567 -0
  41. package/{dist/date → date}/Date.js +121 -93
  42. package/date/index.d.ts +27 -0
  43. package/date-input/DateInput.js +396 -0
  44. package/date-input/index.d.ts +95 -0
  45. package/dialog/Dialog.js +184 -0
  46. package/dialog/index.d.ts +18 -0
  47. package/dropdown/Dropdown.js +450 -0
  48. package/dropdown/index.d.ts +26 -0
  49. package/file-input/FileInput.js +532 -0
  50. package/file-input/FileItem.js +193 -0
  51. package/file-input/index.d.ts +81 -0
  52. package/footer/Footer.js +297 -0
  53. package/footer/Icons.js +77 -0
  54. package/footer/index.d.ts +25 -0
  55. package/header/Header.js +326 -0
  56. package/header/Icons.js +59 -0
  57. package/header/index.d.ts +25 -0
  58. package/heading/Heading.js +176 -0
  59. package/heading/index.d.ts +17 -0
  60. package/input-text/Icons.js +22 -0
  61. package/input-text/InputText.js +611 -0
  62. package/input-text/index.d.ts +36 -0
  63. package/layout/ApplicationLayout.js +235 -0
  64. package/layout/Icons.js +55 -0
  65. package/link/Link.js +183 -0
  66. package/link/index.d.ts +23 -0
  67. package/main.d.ts +44 -0
  68. package/{dist/main.js → main.js} +147 -47
  69. package/number-input/NumberInput.js +128 -0
  70. package/{dist/ThemeContext.js → number-input/NumberInputContext.js} +3 -2
  71. package/number-input/index.d.ts +113 -0
  72. package/package.json +40 -24
  73. package/paginator/Icons.js +66 -0
  74. package/paginator/Paginator.js +221 -0
  75. package/paginator/index.d.ts +20 -0
  76. package/password-input/PasswordInput.js +199 -0
  77. package/password-input/index.d.ts +94 -0
  78. package/progress-bar/ProgressBar.js +188 -0
  79. package/progress-bar/index.d.ts +18 -0
  80. package/{dist/radio → radio}/Radio.js +47 -56
  81. package/radio/index.d.ts +23 -0
  82. package/resultsetTable/ResultsetTable.js +274 -0
  83. package/resultsetTable/index.d.ts +19 -0
  84. package/select/Select.js +864 -0
  85. package/select/index.d.ts +131 -0
  86. package/sidenav/Sidenav.js +145 -0
  87. package/sidenav/index.d.ts +13 -0
  88. package/slider/Slider.js +340 -0
  89. package/slider/index.d.ts +29 -0
  90. package/spinner/Spinner.js +267 -0
  91. package/spinner/index.d.ts +17 -0
  92. package/switch/Switch.js +208 -0
  93. package/switch/index.d.ts +24 -0
  94. package/table/Table.js +118 -0
  95. package/table/index.d.ts +13 -0
  96. package/tabs/Tabs.js +259 -0
  97. package/tabs/index.d.ts +19 -0
  98. package/tag/Tag.js +208 -0
  99. package/tag/index.d.ts +24 -0
  100. package/text-input/TextInput.js +818 -0
  101. package/text-input/index.d.ts +135 -0
  102. package/textarea/Textarea.js +315 -0
  103. package/textarea/index.d.ts +117 -0
  104. package/{dist/toggle → toggle}/Toggle.js +30 -67
  105. package/toggle/index.d.ts +21 -0
  106. package/toggle-group/ToggleGroup.js +243 -0
  107. package/toggle-group/index.d.ts +21 -0
  108. package/{dist/upload → upload}/Upload.js +23 -22
  109. package/upload/buttons-upload/ButtonsUpload.js +111 -0
  110. package/upload/buttons-upload/Icons.js +40 -0
  111. package/upload/dragAndDropArea/DragAndDropArea.js +225 -0
  112. package/upload/dragAndDropArea/Icons.js +39 -0
  113. package/upload/file-upload/FileToUpload.js +115 -0
  114. package/upload/file-upload/Icons.js +66 -0
  115. package/upload/files-upload/FilesToUpload.js +109 -0
  116. package/upload/index.d.ts +15 -0
  117. package/upload/transaction/Icons.js +160 -0
  118. package/upload/transaction/Transaction.js +104 -0
  119. package/upload/transactions/Transactions.js +94 -0
  120. package/useTheme.js +22 -0
  121. package/wizard/Icons.js +65 -0
  122. package/wizard/Wizard.js +271 -0
  123. package/wizard/index.d.ts +18 -0
  124. package/babel.config.js +0 -4
  125. package/dist/accordion/Accordion.js +0 -264
  126. package/dist/accordion/Accordion.stories.js +0 -207
  127. package/dist/accordion/readme.md +0 -96
  128. package/dist/alert/Alert.js +0 -302
  129. package/dist/alert/Alert.stories.js +0 -158
  130. package/dist/alert/close.svg +0 -4
  131. package/dist/alert/error.svg +0 -4
  132. package/dist/alert/info.svg +0 -4
  133. package/dist/alert/readme.md +0 -43
  134. package/dist/alert/success.svg +0 -4
  135. package/dist/alert/warning.svg +0 -4
  136. package/dist/button/Button.js +0 -187
  137. package/dist/button/Button.stories.js +0 -224
  138. package/dist/button/readme.md +0 -93
  139. package/dist/card/Card.js +0 -246
  140. package/dist/checkbox/Checkbox.js +0 -221
  141. package/dist/checkbox/Checkbox.stories.js +0 -144
  142. package/dist/checkbox/readme.md +0 -116
  143. package/dist/common/RequiredComponent.js +0 -50
  144. package/dist/common/services/example-service.js +0 -10
  145. package/dist/common/services/example-service.test.js +0 -12
  146. package/dist/common/variables.js +0 -77
  147. package/dist/date/Date.stories.js +0 -205
  148. package/dist/date/calendar.svg +0 -1
  149. package/dist/date/calendar_dark.svg +0 -1
  150. package/dist/date/readme.md +0 -73
  151. package/dist/dialog/Dialog.js +0 -164
  152. package/dist/dialog/Dialog.stories.js +0 -217
  153. package/dist/dialog/readme.md +0 -32
  154. package/dist/dropdown/Dropdown.js +0 -412
  155. package/dist/dropdown/Dropdown.stories.js +0 -249
  156. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  157. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  158. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  159. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  160. package/dist/dropdown/readme.md +0 -69
  161. package/dist/footer/Footer.js +0 -341
  162. package/dist/footer/Footer.stories.js +0 -94
  163. package/dist/footer/dxc_logo_wht.png +0 -0
  164. package/dist/footer/readme.md +0 -41
  165. package/dist/header/Header.js +0 -343
  166. package/dist/header/Header.stories.js +0 -176
  167. package/dist/header/close_icon.svg +0 -1
  168. package/dist/header/dxc_logo_black.png +0 -0
  169. package/dist/header/dxc_logo_white.png +0 -0
  170. package/dist/header/hamb_menu_black.svg +0 -1
  171. package/dist/header/hamb_menu_white.svg +0 -1
  172. package/dist/header/readme.md +0 -33
  173. package/dist/heading/Heading.js +0 -159
  174. package/dist/input-text/InputText.js +0 -510
  175. package/dist/input-text/InputText.stories.js +0 -209
  176. package/dist/input-text/error.svg +0 -1
  177. package/dist/input-text/readme.md +0 -91
  178. package/dist/link/Link.js +0 -129
  179. package/dist/link/readme.md +0 -51
  180. package/dist/paginator/Paginator.js +0 -178
  181. package/dist/paginator/images/next.svg +0 -3
  182. package/dist/paginator/images/nextPage.svg +0 -3
  183. package/dist/paginator/images/previous.svg +0 -3
  184. package/dist/paginator/images/previousPage.svg +0 -3
  185. package/dist/paginator/readme.md +0 -50
  186. package/dist/progress-bar/ProgressBar.js +0 -189
  187. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  188. package/dist/progress-bar/readme.md +0 -63
  189. package/dist/radio/Radio.stories.js +0 -166
  190. package/dist/radio/readme.md +0 -70
  191. package/dist/resultsetTable/ResultsetTable.js +0 -334
  192. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  193. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  194. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  195. package/dist/select/Select.js +0 -425
  196. package/dist/select/Select.stories.js +0 -235
  197. package/dist/select/readme.md +0 -72
  198. package/dist/sidenav/Sidenav.js +0 -217
  199. package/dist/sidenav/arrow_icon.svg +0 -3
  200. package/dist/slider/Slider.js +0 -268
  201. package/dist/slider/Slider.stories.js +0 -241
  202. package/dist/slider/readme.md +0 -64
  203. package/dist/spinner/Spinner.js +0 -196
  204. package/dist/spinner/Spinner.stories.js +0 -183
  205. package/dist/spinner/readme.md +0 -65
  206. package/dist/switch/Switch.js +0 -219
  207. package/dist/switch/Switch.stories.js +0 -134
  208. package/dist/switch/readme.md +0 -133
  209. package/dist/table/Table.js +0 -84
  210. package/dist/tabs/Tabs.js +0 -183
  211. package/dist/tabs/Tabs.stories.js +0 -130
  212. package/dist/tabs/readme.md +0 -78
  213. package/dist/tabs-for-sections/TabsForSections.js +0 -107
  214. package/dist/tabs-for-sections/readme.md +0 -78
  215. package/dist/tag/Tag.js +0 -217
  216. package/dist/textarea/Textarea.js +0 -226
  217. package/dist/toggle/Toggle.stories.js +0 -297
  218. package/dist/toggle/readme.md +0 -80
  219. package/dist/upload/Upload.stories.js +0 -72
  220. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -125
  221. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  222. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  223. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -282
  224. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  225. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  226. package/dist/upload/file-upload/FileToUpload.js +0 -158
  227. package/dist/upload/file-upload/audio-icon.svg +0 -4
  228. package/dist/upload/file-upload/close.svg +0 -4
  229. package/dist/upload/file-upload/file-icon.svg +0 -4
  230. package/dist/upload/file-upload/video-icon.svg +0 -4
  231. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  232. package/dist/upload/readme.md +0 -37
  233. package/dist/upload/transaction/Transaction.js +0 -155
  234. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  235. package/dist/upload/transaction/audio-icon.svg +0 -4
  236. package/dist/upload/transaction/error-icon.svg +0 -4
  237. package/dist/upload/transaction/file-icon-err.svg +0 -4
  238. package/dist/upload/transaction/file-icon.svg +0 -4
  239. package/dist/upload/transaction/image-icon-err.svg +0 -4
  240. package/dist/upload/transaction/image-icon.svg +0 -4
  241. package/dist/upload/transaction/success-icon.svg +0 -4
  242. package/dist/upload/transaction/video-icon-err.svg +0 -4
  243. package/dist/upload/transaction/video-icon.svg +0 -4
  244. package/dist/upload/transactions/Transactions.js +0 -120
  245. package/dist/wizard/Wizard.js +0 -310
  246. package/dist/wizard/invalid_icon.svg +0 -6
  247. package/dist/wizard/valid_icon.svg +0 -6
  248. package/dist/wizard/validation-wrong.svg +0 -6
  249. package/test/Accordion.test.js +0 -33
  250. package/test/Alert.test.js +0 -53
  251. package/test/Box.test.js +0 -10
  252. package/test/Button.test.js +0 -18
  253. package/test/Card.test.js +0 -30
  254. package/test/Checkbox.test.js +0 -45
  255. package/test/Date.test.js +0 -393
  256. package/test/Dialog.test.js +0 -23
  257. package/test/Dropdown.test.js +0 -130
  258. package/test/Footer.test.js +0 -99
  259. package/test/Header.test.js +0 -39
  260. package/test/Heading.test.js +0 -35
  261. package/test/InputText.test.js +0 -236
  262. package/test/Link.test.js +0 -25
  263. package/test/Paginator.test.js +0 -165
  264. package/test/ProgressBar.test.js +0 -35
  265. package/test/Radio.test.js +0 -37
  266. package/test/ResultsetTable.test.js +0 -282
  267. package/test/Select.test.js +0 -191
  268. package/test/Sidenav.test.js +0 -87
  269. package/test/Slider.test.js +0 -65
  270. package/test/Spinner.test.js +0 -27
  271. package/test/Switch.test.js +0 -45
  272. package/test/Table.test.js +0 -36
  273. package/test/Tabs.test.js +0 -88
  274. package/test/TabsForSections.test.js +0 -34
  275. package/test/Tag.test.js +0 -32
  276. package/test/TextArea.test.js +0 -52
  277. package/test/Toggle.test.js +0 -43
  278. package/test/Upload.test.js +0 -60
  279. package/test/Wizard.test.js +0 -130
  280. package/test/mocks/pngMock.js +0 -1
  281. package/test/mocks/svgMock.js +0 -1
@@ -1,69 +0,0 @@
1
- # DXC Dropdown Component
2
-
3
- ## Props
4
-
5
- <table>
6
- <tr style="background-color: grey">
7
- <td>Name</td>
8
- <td>Default</td>
9
- <td>Description</td>
10
- </tr>
11
- <tr>
12
- <td>options: object[]</td>
13
- <td><code>[]</code></td>
14
- <td>An array of objects representing the options. Each object has the following properties:
15
- <ul>
16
- <li><b>label</b>: Option display value</li>
17
- <li><b>iconSrc</b>: URL of the icon that will be placed next to the option label (Optional)</li>
18
- <li><b>value</b>: Option inner value</li>
19
- <li><b>options</b>: array for nested</li>
20
- </ul>
21
- </td>
22
- </tr>
23
- <tr>
24
- <td>optionsIconPosition: 'before' | 'after'</td>
25
- <td><code>'before'</code></td>
26
- <td>In case options include an icon, whether the icon should appear after or before the label.</td>
27
- </tr>
28
- <tr>
29
- <td>iconSrc: string</td>
30
- <td><code></code></td>
31
- <td>URL of the icon that will be placed next to the option label (Optional)</td>
32
- </tr>
33
- <tr>
34
- <td>iconPosition: 'before' | 'after'</td>
35
- <td><code>'before'</code></td>
36
- <td>Whether the icon should appear after or before the label.</td>
37
- </tr>
38
- <tr>
39
- <td>label: string</td>
40
- <td></td>
41
- <td>Text to be placed within the dropdown.</td>
42
- </tr>
43
- <tr>
44
- <td>theme: 'light' | 'dark'</td>
45
- <td><code>'light'</code></td>
46
- <td>Uses one of the available component themes.</td>
47
- </tr>
48
- <tr>
49
- <td>mode: 'basic' | 'outlined'</td>
50
- <td><code>'basic'</code></td>
51
- <td>Uses one of the available component modes.</td>
52
- </tr>
53
- <tr>
54
- <td>showCaret: boolean</td>
55
- <td><code>true</code></td>
56
- <td>Whether the arrow next to the labe must be displayed or not.</td>
57
- </tr>
58
- <tr>
59
- <td>disableRipple: boolean</td>
60
- <td><code>false</code></td>
61
- <td>If true, the ripple effect will be disabled.</td>
62
- </tr>
63
- <tr>
64
- <td>onSelectOption: function</td>
65
- <td></td>
66
- <td>This function will be called every time the selection changes. The string with the key of the selected value will be passed as a parameter to this function.</td>
67
- </tr>
68
- </table>
69
-
@@ -1,341 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
-
5
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
6
-
7
- Object.defineProperty(exports, "__esModule", {
8
- value: true
9
- });
10
- exports["default"] = void 0;
11
-
12
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
13
-
14
- var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
15
-
16
- var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
17
-
18
- var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
19
-
20
- var _react = _interopRequireWildcard(require("react"));
21
-
22
- var _styledComponents = _interopRequireWildcard(require("styled-components"));
23
-
24
- var _propTypes = _interopRequireDefault(require("prop-types"));
25
-
26
- var _dxc_logo_wht = _interopRequireDefault(require("./dxc_logo_wht.png"));
27
-
28
- require("../common/OpenSans.css");
29
-
30
- var _variables = require("../common/variables.js");
31
-
32
- var _ThemeContext = _interopRequireDefault(require("../ThemeContext.js"));
33
-
34
- function _templateObject11() {
35
- var data = (0, _taggedTemplateLiteral2["default"])(["\n text-decoration: none;\n color: ", ";\n font-size: 12px;\n"]);
36
-
37
- _templateObject11 = function _templateObject11() {
38
- return data;
39
- };
40
-
41
- return data;
42
- }
43
-
44
- function _templateObject10() {
45
- var data = (0, _taggedTemplateLiteral2["default"])(["\n margin: 0px 10px;\n color: ", ";\n"]);
46
-
47
- _templateObject10 = function _templateObject10() {
48
- return data;
49
- };
50
-
51
- return data;
52
- }
53
-
54
- function _templateObject9() {
55
- var data = (0, _taggedTemplateLiteral2["default"])(["\n & {\n display: inline-flex;\n height: 25px;\n width: 25px;\n fill: ", ";\n }\n"]);
56
-
57
- _templateObject9 = function _templateObject9() {
58
- return data;
59
- };
60
-
61
- return data;
62
- }
63
-
64
- function _templateObject8() {
65
- var data = (0, _taggedTemplateLiteral2["default"])(["\n & {\n display: inline-flex;\n margin-left: ", ";\n }\n"]);
66
-
67
- _templateObject8 = function _templateObject8() {
68
- return data;
69
- };
70
-
71
- return data;
72
- }
73
-
74
- function _templateObject7() {
75
- var data = (0, _taggedTemplateLiteral2["default"])(["\n height: 34px;\n width: auto;\n"]);
76
-
77
- _templateObject7 = function _templateObject7() {
78
- return data;
79
- };
80
-
81
- return data;
82
- }
83
-
84
- function _templateObject6() {
85
- var data = (0, _taggedTemplateLiteral2["default"])(["\n font-size: 12px;\n color: ", ";\n max-width: ", ";\n width: ", ";\n text-align: ", ";\n"]);
86
-
87
- _templateObject6 = function _templateObject6() {
88
- return data;
89
- };
90
-
91
- return data;
92
- }
93
-
94
- function _templateObject5() {
95
- var data = (0, _taggedTemplateLiteral2["default"])(["\n min-height: 15px;\n padding: ", ";\n padding-top: ", ";\n padding-right: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n color: ", ";\n overflow: hidden;\n"]);
96
-
97
- _templateObject5 = function _templateObject5() {
98
- return data;
99
- };
100
-
101
- return data;
102
- }
103
-
104
- function _templateObject4() {
105
- var data = (0, _taggedTemplateLiteral2["default"])(["\n padding-top: 6px;\n border-top: 2px solid ", ";\n display: inline-flex;\n flex-wrap: wrap;\n max-width: ", ";\n width: ", ";\n & > span:last-child span {\n display: none;\n }\n margin: ", ";\n"]);
106
-
107
- _templateObject4 = function _templateObject4() {
108
- return data;
109
- };
110
-
111
- return data;
112
- }
113
-
114
- function _templateObject3() {
115
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: space-between;\n align-items: flex-end;\n flex-direction: ", ";\n align-items: ", ";\n"]);
116
-
117
- _templateObject3 = function _templateObject3() {
118
- return data;
119
- };
120
-
121
- return data;
122
- }
123
-
124
- function _templateObject2() {
125
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: space-between;\n"]);
126
-
127
- _templateObject2 = function _templateObject2() {
128
- return data;
129
- };
130
-
131
- return data;
132
- }
133
-
134
- function _templateObject() {
135
- var data = (0, _taggedTemplateLiteral2["default"])(["\n & {\n padding: ", ";\n font-family: \"Open Sans\", sans-serif;\n background-color: ", ";\n margin-top: ", ";\n }\n"]);
136
-
137
- _templateObject = function _templateObject() {
138
- return data;
139
- };
140
-
141
- return data;
142
- }
143
-
144
- var DxcFooter = function DxcFooter(_ref) {
145
- var _ref$socialLinks = _ref.socialLinks,
146
- socialLinks = _ref$socialLinks === void 0 ? [] : _ref$socialLinks,
147
- _ref$bottomLinks = _ref.bottomLinks,
148
- bottomLinks = _ref$bottomLinks === void 0 ? [] : _ref$bottomLinks,
149
- _ref$copyright = _ref.copyright,
150
- copyright = _ref$copyright === void 0 ? "" : _ref$copyright,
151
- _ref$logoSrc = _ref.logoSrc,
152
- logoSrc = _ref$logoSrc === void 0 ? "default" : _ref$logoSrc,
153
- children = _ref.children,
154
- padding = _ref.padding,
155
- margin = _ref.margin;
156
- var ref = (0, _react.useRef)(null);
157
-
158
- var _useState = (0, _react.useState)(),
159
- _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
160
- refSize = _useState2[0],
161
- setRefSize = _useState2[1];
162
-
163
- var _useState3 = (0, _react.useState)(false),
164
- _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
165
- isResponsiveTablet = _useState4[0],
166
- setIsResponsiveTablet = _useState4[1];
167
-
168
- var _useState5 = (0, _react.useState)(false),
169
- _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
170
- isResponsivePhone = _useState6[0],
171
- setIsResponsivePhone = _useState6[1];
172
-
173
- var colorsTheme = (0, _react.useContext)(_ThemeContext["default"]) || _variables.colors;
174
-
175
- var handleResize = function handleResize(refWidth) {
176
- if (ref.current) {
177
- setRefSize(refWidth);
178
-
179
- if (refWidth <= _variables.responsiveSizes.tablet && refWidth > _variables.responsiveSizes.mobileLarge) {
180
- setIsResponsiveTablet(true);
181
- setIsResponsivePhone(false);
182
- } else if (refWidth <= _variables.responsiveSizes.tablet && refWidth <= _variables.responsiveSizes.mobileLarge) {
183
- setIsResponsivePhone(true);
184
- setIsResponsiveTablet(false);
185
- } else {
186
- setIsResponsiveTablet(false);
187
- setIsResponsivePhone(false);
188
- }
189
- }
190
- };
191
-
192
- var handleEventListener = function handleEventListener() {
193
- handleResize(ref.current.offsetWidth);
194
- };
195
-
196
- (0, _react.useEffect)(function () {
197
- window.addEventListener("resize", handleEventListener);
198
- handleResize(ref.current.offsetWidth);
199
- return function () {
200
- window.removeEventListener("resize", handleEventListener);
201
- };
202
- }, []);
203
- var socialLink = socialLinks.map(function (link, index) {
204
- return _react["default"].createElement(SocialAnchor, {
205
- key: "social".concat(index).concat(link.href),
206
- index: index,
207
- href: link && link.href ? link.href : ""
208
- }, link && link.logoSrc && _react["default"].createElement(SocialIcon, {
209
- src: link.logoSrc
210
- }));
211
- });
212
- var bottomLink = bottomLinks.map(function (link, index) {
213
- return _react["default"].createElement("span", {
214
- key: "bottom".concat(index).concat(link.text)
215
- }, _react["default"].createElement(BottomLink, {
216
- href: link && link.href ? link.href : ""
217
- }, link && link.text ? link.text : ""), _react["default"].createElement(Point, {
218
- index: index
219
- }, "\xB7"));
220
- });
221
- return _react["default"].createElement(_styledComponents.ThemeProvider, {
222
- theme: colorsTheme
223
- }, _react["default"].createElement(FooterContainer, {
224
- margin: margin,
225
- refSize: refSize,
226
- ref: ref
227
- }, _react["default"].createElement(FooterHeader, null, _react["default"].createElement(LogoIcon, {
228
- logoSrc: logoSrc,
229
- src: logoSrc === "default" ? _dxc_logo_wht["default"] : logoSrc
230
- }), _react["default"].createElement("div", null, socialLink)), isResponsivePhone && _react["default"].createElement("div", null, _react["default"].createElement(FooterFooter, {
231
- className: "footerFooter",
232
- refSize: refSize
233
- }, _react["default"].createElement(BottomLinks, {
234
- refSize: refSize
235
- }, bottomLink), _react["default"].createElement(Copyright, {
236
- refSize: refSize
237
- }, copyright))), (!isResponsiveTablet && !isResponsivePhone || isResponsiveTablet) && _react["default"].createElement("div", null, _react["default"].createElement(ChildComponents, {
238
- padding: padding
239
- }, children), _react["default"].createElement(FooterFooter, {
240
- className: "footerFooter"
241
- }, _react["default"].createElement(BottomLinks, {
242
- refSize: refSize
243
- }, bottomLink), _react["default"].createElement(Copyright, {
244
- refSize: refSize
245
- }, copyright)))));
246
- };
247
-
248
- var FooterContainer = _styledComponents["default"].div(_templateObject(), function (props) {
249
- return props.refSize <= _variables.responsiveSizes.mobileLarge ? "20px 20px 20px 20px" : "20px 60px 20px 20px";
250
- }, function (props) {
251
- return props.theme.black;
252
- }, function (props) {
253
- return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
254
- });
255
-
256
- var FooterHeader = _styledComponents["default"].div(_templateObject2());
257
-
258
- var FooterFooter = _styledComponents["default"].div(_templateObject3(), function (props) {
259
- return props.refSize <= _variables.responsiveSizes.mobileLarge ? "column" : "row";
260
- }, function (props) {
261
- return props.refSize <= _variables.responsiveSizes.mobileLarge ? "center" : "";
262
- });
263
-
264
- var BottomLinks = _styledComponents["default"].div(_templateObject4(), function (props) {
265
- return props.theme.yellow;
266
- }, function (props) {
267
- return props.refSize <= _variables.responsiveSizes.mobileLarge ? "100%" : "60%";
268
- }, function (props) {
269
- return props.refSize <= _variables.responsiveSizes.mobileLarge ? "100%" : "";
270
- }, function (props) {
271
- return props.refSize <= _variables.responsiveSizes.mobileLarge ? "40px 0 40px 0" : "";
272
- });
273
-
274
- var ChildComponents = _styledComponents["default"].div(_templateObject5(), function (props) {
275
- return props.padding && (0, _typeof2["default"])(props.padding) !== "object" ? _variables.spaces[props.padding] : "0px";
276
- }, function (props) {
277
- return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.top ? _variables.spaces[props.padding.top] : "";
278
- }, function (props) {
279
- return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.right ? _variables.spaces[props.padding.right] : "";
280
- }, function (props) {
281
- return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.bottom ? _variables.spaces[props.padding.bottom] : "";
282
- }, function (props) {
283
- return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.left ? _variables.spaces[props.padding.left] : "";
284
- }, function (props) {
285
- return props.theme.white;
286
- });
287
-
288
- var Copyright = _styledComponents["default"].div(_templateObject6(), function (props) {
289
- return props.theme.white;
290
- }, function (props) {
291
- return props.refSize <= _variables.responsiveSizes.mobileLarge ? "100%" : "40%";
292
- }, function (props) {
293
- return props.refSize <= _variables.responsiveSizes.mobileLarge ? "100%" : "";
294
- }, function (props) {
295
- return props.refSize <= _variables.responsiveSizes.mobileLarge ? "center" : "right";
296
- });
297
-
298
- var LogoIcon = _styledComponents["default"].img(_templateObject7());
299
-
300
- var SocialAnchor = _styledComponents["default"].a(_templateObject8(), function (props) {
301
- return props.index === 0 ? "0px" : "15px";
302
- });
303
-
304
- var SocialIcon = _styledComponents["default"].img(_templateObject9(), function (props) {
305
- return props.theme.white;
306
- });
307
-
308
- var Point = _styledComponents["default"].span(_templateObject10(), function (props) {
309
- return props.theme.white;
310
- });
311
-
312
- var BottomLink = _styledComponents["default"].a(_templateObject11(), function (props) {
313
- return props.theme.white;
314
- });
315
-
316
- DxcFooter.propTypes = {
317
- logoSrc: _propTypes["default"].string,
318
- socialLinks: _propTypes["default"].arrayOf(_propTypes["default"].shape({
319
- logoSrc: _propTypes["default"].string.isRequired,
320
- href: _propTypes["default"].string
321
- })),
322
- bottomLinks: _propTypes["default"].arrayOf(_propTypes["default"].shape({
323
- text: _propTypes["default"].string.isRequired,
324
- href: _propTypes["default"].string
325
- })),
326
- copyright: _propTypes["default"].string,
327
- margin: _propTypes["default"].oneOfType([_propTypes["default"].shape({
328
- top: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
329
- bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
330
- left: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
331
- right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
332
- }), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))]),
333
- padding: _propTypes["default"].oneOfType([_propTypes["default"].shape({
334
- top: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
335
- bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
336
- left: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
337
- right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
338
- }), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))])
339
- };
340
- var _default = DxcFooter;
341
- exports["default"] = _default;
@@ -1,94 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- var _react = _interopRequireDefault(require("react"));
6
-
7
- var _react2 = require("@storybook/react");
8
-
9
- var _addonActions = require("@storybook/addon-actions");
10
-
11
- require("../common/OpenSans.css");
12
-
13
- var _addonKnobs = require("@storybook/addon-knobs");
14
-
15
- var _linkedin = _interopRequireDefault(require("../../.storybook/public/linkedin.svg"));
16
-
17
- var _facebook = _interopRequireDefault(require("../../.storybook/public/facebook.svg"));
18
-
19
- var _twitter = _interopRequireDefault(require("../../.storybook/public/twitter.svg"));
20
-
21
- var _InputText = _interopRequireDefault(require("../input-text/InputText"));
22
-
23
- var _readme = _interopRequireDefault(require("./readme.md"));
24
-
25
- var _Footer = _interopRequireDefault(require("./Footer"));
26
-
27
- var social = [{
28
- href: "https://www.linkedin.com/company/dxctechnology",
29
- logoSrc: _linkedin["default"]
30
- }, {
31
- href: "https://twitter.com/dxctechnology",
32
- logoSrc: _twitter["default"]
33
- }, {
34
- href: "https://www.facebook.com/DXCTechnology/",
35
- logoSrc: _facebook["default"]
36
- }];
37
- var bottom = [{
38
- href: "https://www.linkedin.com/company/dxctechnology",
39
- text: "Linkedin"
40
- }, {
41
- href: "https://twitter.com/dxctechnology",
42
- text: "Twitter"
43
- }, {
44
- href: "https://www.facebook.com/DXCTechnology/",
45
- text: "Facebook"
46
- }];
47
- (0, _react2.storiesOf)("Form Components|Footer", module).add("Component", function () {
48
- return _react["default"].createElement("div", null, _react["default"].createElement(_Footer["default"], {
49
- copyright: "\xA9 DXC Technology 2019. All rights reserved.",
50
- bottomLinks: bottom,
51
- socialLinks: social
52
- }), _react["default"].createElement("div", {
53
- style: {
54
- marginTop: "20px"
55
- }
56
- }, _react["default"].createElement(_Footer["default"], {
57
- copyright: "\xA9 DXC Technology 2019. All rights reserved.",
58
- bottomLinks: bottom,
59
- socialLinks: social
60
- }, _react["default"].createElement(_InputText["default"], {
61
- assistiveText: "text input component",
62
- label: "Footer Child",
63
- theme: "dark"
64
- }), _react["default"].createElement(_InputText["default"], {
65
- assistiveText: "text input component",
66
- label: "Footer Child",
67
- theme: "dark"
68
- }), _react["default"].createElement(_InputText["default"], {
69
- assistiveText: "text input component",
70
- label: "Footer Child",
71
- theme: "dark"
72
- }), _react["default"].createElement(_InputText["default"], {
73
- assistiveText: "text input component",
74
- label: "Footer Child",
75
- theme: "dark"
76
- }))));
77
- }, {
78
- notes: {
79
- markdown: _readme["default"]
80
- }
81
- });
82
-
83
- var knobProps = function knobProps() {
84
- return {};
85
- };
86
-
87
- (0, _react2.storiesOf)("Form Components|Footer", module).add("Knobs example", function () {
88
- var props = knobProps();
89
- return _react["default"].createElement("div", null);
90
- }, {
91
- notes: {
92
- markdown: _readme["default"]
93
- }
94
- });
Binary file
@@ -1,41 +0,0 @@
1
- # DXC Footer Component
2
-
3
- ## Props
4
-
5
- <table>
6
- <tr style="background-color: grey">
7
- <td>Name</td>
8
- <td>Default</td>
9
- <td>Description</td>
10
- </tr>
11
- <tr>
12
- <td>logoSrc: string</td>
13
- <td></td>
14
- <td>The path of an icon to replace the default dxc logo.</td>
15
- </tr>
16
- <tr>
17
- <td>socialLinks: object[]</td>
18
- <td><code>[]</code></td>
19
- <td>An array of objects representing the links that will be rendered at the bottom part of the footer. Each object has the following properties:
20
- <ul>
21
- <li><b>logoSrc</b>: The path of an icon for the link</li>
22
- <li><b>href</b>: URL of the page the link goes to</li>
23
- </ul>
24
- </td>
25
- </tr>
26
- <tr>
27
- <td>bottomLinks: object[]</td>
28
- <td><code>[]</code></td>
29
- <td>An array of objects representing the incon links that will be rendered at the top-right side of the footer. Each object has the following properties:
30
- <ul>
31
- <li><b>text</b>: Text for the link</li>
32
- <li><b>href</b>: URL of the page the link goes to</li>
33
- </ul>
34
- </td>
35
- </tr>
36
- <tr>
37
- <td>copyright: string</td>
38
- <td></td>
39
- <td>The text that will be displayed as copyright disclaimer.</td>
40
- </tr>
41
- </table>