@dxc-technology/halstack-react 0.0.0-d205180 → 0.0.0-d20b360

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 (323) 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/{dist/textarea/Textarea.js → V3Textarea/V3Textarea.js} +39 -39
  6. package/V3Textarea/index.d.ts +27 -0
  7. package/accordion/Accordion.d.ts +4 -0
  8. package/accordion/Accordion.js +258 -0
  9. package/accordion/types.d.ts +68 -0
  10. package/accordion/types.js +5 -0
  11. package/accordion-group/AccordionGroup.d.ts +7 -0
  12. package/accordion-group/AccordionGroup.js +170 -0
  13. package/accordion-group/types.d.ts +72 -0
  14. package/accordion-group/types.js +5 -0
  15. package/alert/Alert.d.ts +4 -0
  16. package/alert/Alert.js +290 -0
  17. package/alert/types.d.ts +49 -0
  18. package/alert/types.js +5 -0
  19. package/badge/Badge.js +59 -0
  20. package/{dist/box → box}/Box.js +9 -21
  21. package/box/Box.stories.jsx +132 -0
  22. package/box/index.d.ts +25 -0
  23. package/button/Button.d.ts +4 -0
  24. package/button/Button.js +182 -0
  25. package/button/Button.stories.tsx +293 -0
  26. package/button/types.d.ts +57 -0
  27. package/button/types.js +5 -0
  28. package/card/Card.d.ts +4 -0
  29. package/{dist/card → card}/Card.js +42 -124
  30. package/card/types.d.ts +69 -0
  31. package/card/types.js +5 -0
  32. package/checkbox/Checkbox.d.ts +4 -0
  33. package/{dist/checkbox → checkbox}/Checkbox.js +44 -82
  34. package/checkbox/Checkbox.stories.tsx +192 -0
  35. package/checkbox/types.d.ts +60 -0
  36. package/checkbox/types.js +5 -0
  37. package/{dist/chip → chip}/Chip.js +48 -104
  38. package/chip/index.d.ts +22 -0
  39. package/{dist/common → common}/OpenSans.css +0 -0
  40. package/{dist/common → common}/RequiredComponent.js +3 -11
  41. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  42. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  43. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  44. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  45. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  46. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  47. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  48. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  49. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  50. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  51. package/{dist/common → common}/utils.js +0 -0
  52. package/common/variables.js +1569 -0
  53. package/{dist/date → date}/Date.js +71 -57
  54. package/date/index.d.ts +27 -0
  55. package/date-input/DateInput.d.ts +4 -0
  56. package/date-input/DateInput.js +361 -0
  57. package/date-input/types.d.ts +100 -0
  58. package/date-input/types.js +5 -0
  59. package/dialog/Dialog.d.ts +4 -0
  60. package/{dist/dialog → dialog}/Dialog.js +29 -100
  61. package/dialog/types.d.ts +43 -0
  62. package/dialog/types.js +5 -0
  63. package/dropdown/Dropdown.d.ts +4 -0
  64. package/dropdown/Dropdown.js +417 -0
  65. package/dropdown/types.d.ts +89 -0
  66. package/dropdown/types.js +5 -0
  67. package/file-input/FileInput.js +532 -0
  68. package/file-input/FileItem.js +193 -0
  69. package/file-input/index.d.ts +81 -0
  70. package/footer/Footer.d.ts +4 -0
  71. package/footer/Footer.js +266 -0
  72. package/footer/Footer.stories.jsx +151 -0
  73. package/footer/Icons.js +77 -0
  74. package/footer/types.d.ts +61 -0
  75. package/footer/types.js +5 -0
  76. package/header/Header.d.ts +7 -0
  77. package/header/Header.js +324 -0
  78. package/header/Icons.js +34 -0
  79. package/header/types.d.ts +45 -0
  80. package/header/types.js +5 -0
  81. package/{dist/heading → heading}/Heading.js +30 -76
  82. package/heading/index.d.ts +17 -0
  83. package/input-text/Icons.js +22 -0
  84. package/{dist/input-text → input-text}/InputText.js +120 -178
  85. package/input-text/index.d.ts +36 -0
  86. package/{dist/layout → layout}/ApplicationLayout.js +35 -131
  87. package/layout/Icons.js +55 -0
  88. package/link/Link.js +183 -0
  89. package/link/index.d.ts +23 -0
  90. package/main.d.ts +44 -0
  91. package/{dist/main.js → main.js} +121 -69
  92. package/number-input/NumberInput.js +128 -0
  93. package/number-input/NumberInput.stories.jsx +115 -0
  94. package/number-input/NumberInputContext.js +16 -0
  95. package/number-input/index.d.ts +113 -0
  96. package/package.json +34 -25
  97. package/paginator/Icons.js +66 -0
  98. package/paginator/Paginator.d.ts +4 -0
  99. package/paginator/Paginator.js +198 -0
  100. package/paginator/Paginator.stories.tsx +63 -0
  101. package/paginator/types.d.ts +38 -0
  102. package/paginator/types.js +5 -0
  103. package/password-input/PasswordInput.js +199 -0
  104. package/password-input/PasswordInput.stories.jsx +131 -0
  105. package/password-input/index.d.ts +94 -0
  106. package/progress-bar/ProgressBar.d.ts +4 -0
  107. package/progress-bar/ProgressBar.js +170 -0
  108. package/progress-bar/types.d.ts +37 -0
  109. package/progress-bar/types.js +5 -0
  110. package/radio/Radio.d.ts +4 -0
  111. package/{dist/radio → radio}/Radio.js +17 -52
  112. package/radio/Radio.stories.tsx +192 -0
  113. package/radio/types.d.ts +54 -0
  114. package/radio/types.js +5 -0
  115. package/{dist/resultsetTable → resultsetTable}/ResultsetTable.js +77 -135
  116. package/resultsetTable/index.d.ts +19 -0
  117. package/select/Select.js +865 -0
  118. package/select/index.d.ts +131 -0
  119. package/{dist/sidenav → sidenav}/Sidenav.js +20 -58
  120. package/sidenav/index.d.ts +13 -0
  121. package/slider/Slider.d.ts +4 -0
  122. package/slider/Slider.js +306 -0
  123. package/slider/types.d.ts +83 -0
  124. package/slider/types.js +5 -0
  125. package/spinner/Spinner.js +267 -0
  126. package/spinner/Spinner.stories.jsx +102 -0
  127. package/spinner/index.d.ts +17 -0
  128. package/switch/Switch.d.ts +4 -0
  129. package/{dist/switch → switch}/Switch.js +28 -71
  130. package/switch/types.d.ts +58 -0
  131. package/switch/types.js +5 -0
  132. package/table/Table.js +118 -0
  133. package/table/Table.stories.jsx +276 -0
  134. package/table/index.d.ts +13 -0
  135. package/tabs/Tabs.d.ts +4 -0
  136. package/tabs/Tabs.js +211 -0
  137. package/tabs/types.d.ts +71 -0
  138. package/tabs/types.js +5 -0
  139. package/{dist/tag → tag}/Tag.js +50 -122
  140. package/tag/index.d.ts +24 -0
  141. package/text-input/TextInput.js +825 -0
  142. package/text-input/index.d.ts +135 -0
  143. package/textarea/Textarea.js +317 -0
  144. package/textarea/Textarea.stories.jsx +135 -0
  145. package/textarea/index.d.ts +117 -0
  146. package/{dist/toggle → toggle}/Toggle.js +15 -49
  147. package/toggle/index.d.ts +21 -0
  148. package/toggle-group/ToggleGroup.js +243 -0
  149. package/toggle-group/index.d.ts +21 -0
  150. package/{dist/upload → upload}/Upload.js +11 -15
  151. package/upload/buttons-upload/ButtonsUpload.js +111 -0
  152. package/upload/buttons-upload/Icons.js +40 -0
  153. package/upload/dragAndDropArea/DragAndDropArea.js +225 -0
  154. package/upload/dragAndDropArea/Icons.js +39 -0
  155. package/upload/file-upload/FileToUpload.js +115 -0
  156. package/upload/file-upload/Icons.js +66 -0
  157. package/{dist/upload → upload}/files-upload/FilesToUpload.js +12 -26
  158. package/upload/index.d.ts +15 -0
  159. package/upload/transaction/Icons.js +160 -0
  160. package/upload/transaction/Transaction.js +104 -0
  161. package/upload/transactions/Transactions.js +94 -0
  162. package/{dist/useTheme.js → useTheme.js} +0 -0
  163. package/wizard/Icons.js +65 -0
  164. package/wizard/Wizard.js +271 -0
  165. package/wizard/index.d.ts +18 -0
  166. package/README.md +0 -66
  167. package/babel.config.js +0 -8
  168. package/dist/BackgroundColorContext.js +0 -46
  169. package/dist/ThemeContext.js +0 -216
  170. package/dist/accordion/Accordion.js +0 -356
  171. package/dist/accordion/Accordion.stories.js +0 -207
  172. package/dist/accordion/readme.md +0 -96
  173. package/dist/accordion-group/AccordionGroup.js +0 -188
  174. package/dist/accordion-group/AccordionGroup.stories.js +0 -207
  175. package/dist/accordion-group/readme.md +0 -70
  176. package/dist/alert/Alert.js +0 -388
  177. package/dist/alert/Alert.stories.js +0 -158
  178. package/dist/alert/close.svg +0 -4
  179. package/dist/alert/error.svg +0 -4
  180. package/dist/alert/info.svg +0 -4
  181. package/dist/alert/readme.md +0 -43
  182. package/dist/alert/success.svg +0 -4
  183. package/dist/alert/warning.svg +0 -4
  184. package/dist/badge/Badge.js +0 -61
  185. package/dist/button/Button.js +0 -228
  186. package/dist/button/Button.stories.js +0 -224
  187. package/dist/button/readme.md +0 -93
  188. package/dist/checkbox/Checkbox.stories.js +0 -144
  189. package/dist/checkbox/readme.md +0 -116
  190. package/dist/common/variables.js +0 -1161
  191. package/dist/date/Date.stories.js +0 -205
  192. package/dist/date/calendar.svg +0 -1
  193. package/dist/date/calendar_dark.svg +0 -1
  194. package/dist/date/readme.md +0 -73
  195. package/dist/dialog/Dialog.stories.js +0 -217
  196. package/dist/dialog/readme.md +0 -32
  197. package/dist/dropdown/Dropdown.js +0 -498
  198. package/dist/dropdown/Dropdown.stories.js +0 -249
  199. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  200. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  201. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  202. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  203. package/dist/dropdown/readme.md +0 -69
  204. package/dist/footer/Footer.js +0 -405
  205. package/dist/footer/Footer.stories.js +0 -94
  206. package/dist/footer/dxc_logo_wht.png +0 -0
  207. package/dist/footer/readme.md +0 -41
  208. package/dist/header/Header.js +0 -431
  209. package/dist/header/Header.stories.js +0 -176
  210. package/dist/header/close_icon.svg +0 -1
  211. package/dist/header/dxc_logo_black.png +0 -0
  212. package/dist/header/dxc_logo_blk_rgb.svg +0 -6
  213. package/dist/header/dxc_logo_white.png +0 -0
  214. package/dist/header/hamb_menu_black.svg +0 -1
  215. package/dist/header/hamb_menu_white.svg +0 -1
  216. package/dist/header/readme.md +0 -33
  217. package/dist/input-text/InputText.stories.js +0 -209
  218. package/dist/input-text/error.svg +0 -1
  219. package/dist/input-text/readme.md +0 -91
  220. package/dist/layout/facebook.svg +0 -45
  221. package/dist/layout/linkedin.svg +0 -50
  222. package/dist/layout/twitter.svg +0 -53
  223. package/dist/link/Link.js +0 -212
  224. package/dist/link/readme.md +0 -51
  225. package/dist/paginator/Paginator.js +0 -283
  226. package/dist/paginator/images/next.svg +0 -3
  227. package/dist/paginator/images/nextPage.svg +0 -3
  228. package/dist/paginator/images/previous.svg +0 -3
  229. package/dist/paginator/images/previousPage.svg +0 -3
  230. package/dist/paginator/readme.md +0 -50
  231. package/dist/progress-bar/ProgressBar.js +0 -206
  232. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  233. package/dist/progress-bar/readme.md +0 -63
  234. package/dist/radio/Radio.stories.js +0 -166
  235. package/dist/radio/readme.md +0 -70
  236. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  237. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  238. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  239. package/dist/select/Select.js +0 -525
  240. package/dist/select/Select.stories.js +0 -235
  241. package/dist/select/readme.md +0 -72
  242. package/dist/slider/Slider.js +0 -315
  243. package/dist/slider/Slider.stories.js +0 -241
  244. package/dist/slider/readme.md +0 -64
  245. package/dist/spinner/Spinner.js +0 -214
  246. package/dist/spinner/Spinner.stories.js +0 -183
  247. package/dist/spinner/readme.md +0 -65
  248. package/dist/switch/Switch.stories.js +0 -134
  249. package/dist/switch/readme.md +0 -133
  250. package/dist/table/Table.js +0 -118
  251. package/dist/tabs/Tabs.js +0 -347
  252. package/dist/tabs/Tabs.stories.js +0 -130
  253. package/dist/tabs/readme.md +0 -78
  254. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  255. package/dist/tabs-for-sections/readme.md +0 -78
  256. package/dist/toggle/Toggle.stories.js +0 -297
  257. package/dist/toggle/readme.md +0 -80
  258. package/dist/toggle-group/ToggleGroup.js +0 -241
  259. package/dist/toggle-group/readme.md +0 -82
  260. package/dist/upload/Upload.stories.js +0 -72
  261. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -135
  262. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  263. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  264. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -325
  265. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  266. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  267. package/dist/upload/file-upload/FileToUpload.js +0 -184
  268. package/dist/upload/file-upload/audio-icon.svg +0 -4
  269. package/dist/upload/file-upload/close.svg +0 -4
  270. package/dist/upload/file-upload/file-icon.svg +0 -4
  271. package/dist/upload/file-upload/video-icon.svg +0 -4
  272. package/dist/upload/readme.md +0 -37
  273. package/dist/upload/transaction/Transaction.js +0 -171
  274. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  275. package/dist/upload/transaction/audio-icon.svg +0 -4
  276. package/dist/upload/transaction/error-icon.svg +0 -4
  277. package/dist/upload/transaction/file-icon-err.svg +0 -4
  278. package/dist/upload/transaction/file-icon.svg +0 -4
  279. package/dist/upload/transaction/image-icon-err.svg +0 -4
  280. package/dist/upload/transaction/image-icon.svg +0 -4
  281. package/dist/upload/transaction/success-icon.svg +0 -4
  282. package/dist/upload/transaction/video-icon-err.svg +0 -4
  283. package/dist/upload/transaction/video-icon.svg +0 -4
  284. package/dist/upload/transactions/Transactions.js +0 -138
  285. package/dist/wizard/Wizard.js +0 -383
  286. package/dist/wizard/invalid_icon.svg +0 -6
  287. package/dist/wizard/valid_icon.svg +0 -6
  288. package/dist/wizard/validation-wrong.svg +0 -6
  289. package/test/Accordion.test.js +0 -33
  290. package/test/AccordionGroup.test.js +0 -125
  291. package/test/Alert.test.js +0 -53
  292. package/test/Box.test.js +0 -10
  293. package/test/Button.test.js +0 -18
  294. package/test/Card.test.js +0 -30
  295. package/test/Checkbox.test.js +0 -45
  296. package/test/Chip.test.js +0 -25
  297. package/test/Date.test.js +0 -393
  298. package/test/Dialog.test.js +0 -23
  299. package/test/Dropdown.test.js +0 -130
  300. package/test/Footer.test.js +0 -99
  301. package/test/Header.test.js +0 -39
  302. package/test/Heading.test.js +0 -35
  303. package/test/InputText.test.js +0 -240
  304. package/test/Link.test.js +0 -42
  305. package/test/Paginator.test.js +0 -177
  306. package/test/ProgressBar.test.js +0 -35
  307. package/test/Radio.test.js +0 -37
  308. package/test/ResultsetTable.test.js +0 -330
  309. package/test/Select.test.js +0 -192
  310. package/test/Sidenav.test.js +0 -45
  311. package/test/Slider.test.js +0 -82
  312. package/test/Spinner.test.js +0 -27
  313. package/test/Switch.test.js +0 -45
  314. package/test/Table.test.js +0 -36
  315. package/test/Tabs.test.js +0 -109
  316. package/test/TabsForSections.test.js +0 -34
  317. package/test/Tag.test.js +0 -32
  318. package/test/TextArea.test.js +0 -52
  319. package/test/ToggleGroup.test.js +0 -81
  320. package/test/Upload.test.js +0 -60
  321. package/test/Wizard.test.js +0 -130
  322. package/test/mocks/pngMock.js +0 -1
  323. package/test/mocks/svgMock.js +0 -1
package/dist/tabs/Tabs.js DELETED
@@ -1,347 +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 _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
-
16
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
17
-
18
- var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
19
-
20
- var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
21
-
22
- var _react = _interopRequireDefault(require("react"));
23
-
24
- var _Tabs = _interopRequireDefault(require("@material-ui/core/Tabs"));
25
-
26
- var _Tab = _interopRequireDefault(require("@material-ui/core/Tab"));
27
-
28
- var _styledComponents = _interopRequireWildcard(require("styled-components"));
29
-
30
- var _propTypes = _interopRequireDefault(require("prop-types"));
31
-
32
- var _variables = require("../common/variables.js");
33
-
34
- var _Badge = _interopRequireDefault(require("../badge/Badge"));
35
-
36
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
37
-
38
- function _templateObject9() {
39
- var data = (0, _taggedTemplateLiteral2["default"])(["\n max-height: 22px;\n max-width: 22px;\n margin-bottom: ", ";\n margin-right: ", ";\n overflow: hidden;\n display: flex;\n align-items: center;\n img,\n svg {\n height: 100%;\n width: 100%;\n }\n"]);
40
-
41
- _templateObject9 = function _templateObject9() {
42
- return data;
43
- };
44
-
45
- return data;
46
- }
47
-
48
- function _templateObject8() {
49
- var data = (0, _taggedTemplateLiteral2["default"])(["\n max-height: 22px;\n max-width: 22px;\n"]);
50
-
51
- _templateObject8 = function _templateObject8() {
52
- return data;
53
- };
54
-
55
- return data;
56
- }
57
-
58
- function _templateObject7() {
59
- var data = (0, _taggedTemplateLiteral2["default"])(["\n position: relative;\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n\n .MuiTabs-root {\n background: white;\n min-height: ", ";\n\n .MuiTabs-scroller {\n .MuiTabs-flexContainer + span {\n z-index: 4;\n }\n }\n .MuiTab-root {\n text-transform: ", " !important;\n }\n .MuiButtonBase-root {\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n\n padding: ", ";\n height: ", ";\n min-width: ", ";\n max-width: ", ";\n min-height: ", ";\n\n &:hover {\n background-color: ", ";\n }\n &:active {\n background-color: ", ";\n font-weight: ", ";\n }\n &:not(.Mui-selected) {\n background-color: ", ";\n color: ", ";\n svg {\n color: ", ";\n }\n }\n &.Mui-selected {\n background-color: ", ";\n color: ", ";\n svg {\n color: ", ";\n }\n }\n &.Mui-disabled {\n cursor: not-allowed !important;\n pointer-events: all;\n color: ", ";\n font-style: ", ";\n svg {\n color: ", ";\n }\n }\n &:focus {\n outline: ", " auto 1px;\n }\n }\n .MuiTabs-indicator {\n background-color: ", ";\n height: ", ";\n }\n .MuiTabs-scrollButtons {\n min-width: ", ";\n width: ", ";\n padding: 0;\n }\n @media (max-width: 599.95px) {\n .MuiTabs-scrollButtonsDesktop {\n display: flex;\n }\n }\n }\n"]);
60
-
61
- _templateObject7 = function _templateObject7() {
62
- return data;
63
- };
64
-
65
- return data;
66
- }
67
-
68
- function _templateObject6() {
69
- var data = (0, _taggedTemplateLiteral2["default"])(["\n left: 0px;\n bottom: 0;\n width: 100%;\n height: ", ";\n position: absolute;\n background-color: ", ";\n"]);
70
-
71
- _templateObject6 = function _templateObject6() {
72
- return data;
73
- };
74
-
75
- return data;
76
- }
77
-
78
- function _templateObject5() {
79
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: row;\n margin-left: ", ";\n margin-right: ", ";\n"]);
80
-
81
- _templateObject5 = function _templateObject5() {
82
- return data;
83
- };
84
-
85
- return data;
86
- }
87
-
88
- function _templateObject4() {
89
- var data = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n right: 0;\n top: ", ";\n width: 23px;\n height: 17px;\n"]);
90
-
91
- _templateObject4 = function _templateObject4() {
92
- return data;
93
- };
94
-
95
- return data;
96
- }
97
-
98
- function _templateObject3() {
99
- var data = (0, _taggedTemplateLiteral2["default"])([""]);
100
-
101
- _templateObject3 = function _templateObject3() {
102
- return data;
103
- };
104
-
105
- return data;
106
- }
107
-
108
- function _templateObject2() {
109
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: ", ";\n align-items: center;\n"]);
110
-
111
- _templateObject2 = function _templateObject2() {
112
- return data;
113
- };
114
-
115
- return data;
116
- }
117
-
118
- function _templateObject() {
119
- var data = (0, _taggedTemplateLiteral2["default"])(["\n position: relative;\n"]);
120
-
121
- _templateObject = function _templateObject() {
122
- return data;
123
- };
124
-
125
- return data;
126
- }
127
-
128
- var DxcTabs = function DxcTabs(_ref) {
129
- var activeTabIndex = _ref.activeTabIndex,
130
- _ref$tabs = _ref.tabs,
131
- tabs = _ref$tabs === void 0 ? [] : _ref$tabs,
132
- onTabClick = _ref.onTabClick,
133
- onTabHover = _ref.onTabHover,
134
- margin = _ref.margin,
135
- _ref$iconPosition = _ref.iconPosition,
136
- iconPosition = _ref$iconPosition === void 0 ? "left" : _ref$iconPosition,
137
- _ref$tabIndex = _ref.tabIndex,
138
- tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
139
-
140
- var _React$useState = _react["default"].useState(0),
141
- _React$useState2 = (0, _slicedToArray2["default"])(_React$useState, 2),
142
- innerActiveTabIndex = _React$useState2[0],
143
- setInnerActiveTabIndex = _React$useState2[1];
144
-
145
- var colorsTheme = (0, _useTheme["default"])();
146
- var hasLabelAndIcon = tabs && tabs.filter(function (tab) {
147
- return tab.label && tab.icon;
148
- }).length > 0;
149
-
150
- var handleChange = function handleChange(event, newValue) {
151
- if (activeTabIndex == null) {
152
- setInnerActiveTabIndex(newValue);
153
- }
154
-
155
- if (typeof onTabClick === "function") {
156
- onTabClick(newValue);
157
- }
158
- };
159
-
160
- var getTabIndex = function getTabIndex(index, disabled) {
161
- return (activeTabIndex === index || innerActiveTabIndex === index) && !disabled ? tabIndex : -1;
162
- };
163
-
164
- var getLabelForTab = function getLabelForTab(tab) {
165
- return _react["default"].createElement(ParentLabelSpan, null, _react["default"].createElement(MainLabelContainer, {
166
- hasBadge: tab.notificationNumber
167
- }, _react["default"].createElement(TabLabelContainer, {
168
- hasLabelAndIcon: hasLabelAndIcon,
169
- iconPosition: iconPosition
170
- }, tab.icon ? _react["default"].createElement(TabIconContainer, {
171
- hasLabelAndIcon: hasLabelAndIcon,
172
- iconPosition: iconPosition
173
- }, (0, _typeof2["default"])(tab.icon) === "object" ? tab.icon : _react["default"].createElement(tab.icon)) : tab.iconSrc && _react["default"].createElement(TabIcon, {
174
- src: tab.iconSrc
175
- }), _react["default"].createElement(LabelTextContainer, null, tab.label))), tab.notificationNumber && tab.notificationNumber !== false && _react["default"].createElement(BadgeContainer, {
176
- hasLabelAndIcon: hasLabelAndIcon,
177
- iconPosition: iconPosition
178
- }, _react["default"].createElement(_Badge["default"], {
179
- notificationText: tab.notificationNumber > 99 ? "+99" : tab.notificationNumber
180
- })));
181
- };
182
-
183
- return _react["default"].createElement(_styledComponents.ThemeProvider, {
184
- theme: colorsTheme.tabs
185
- }, _react["default"].createElement(DxCTabs, {
186
- margin: margin,
187
- hasLabelAndIcon: hasLabelAndIcon,
188
- iconPosition: iconPosition
189
- }, _react["default"].createElement(Underline, null), _react["default"].createElement(_Tabs["default"], {
190
- value: activeTabIndex != null ? activeTabIndex : innerActiveTabIndex,
191
- onChange: handleChange,
192
- variant: "scrollable",
193
- scrollButtons: "auto"
194
- }, tabs.map(function (tab, i) {
195
- var tabContent = _react["default"].forwardRef(function (props, ref) {
196
- return _react["default"].createElement("div", (0, _extends2["default"])({
197
- role: "button"
198
- }, props, {
199
- ref: ref
200
- }));
201
- });
202
-
203
- return _react["default"].createElement(_Tab["default"], {
204
- tabIndex: (activeTabIndex === i || innerActiveTabIndex === i) && !tab.isDisabled ? tabIndex : -1,
205
- key: "tab".concat(i).concat(tab.label),
206
- label: getLabelForTab(tab),
207
- disabled: tab.isDisabled,
208
- disableRipple: true,
209
- onMouseEnter: function onMouseEnter() {
210
- onTabHover(i);
211
- },
212
- onMouseLeave: function onMouseLeave() {
213
- onTabHover(null);
214
- }
215
- });
216
- }))));
217
- };
218
-
219
- var ParentLabelSpan = _styledComponents["default"].div(_templateObject());
220
-
221
- var TabLabelContainer = _styledComponents["default"].div(_templateObject2(), function (props) {
222
- return props.hasLabelAndIcon && props.iconPosition === "top" && "column" || "row";
223
- });
224
-
225
- var LabelTextContainer = _styledComponents["default"].div(_templateObject3());
226
-
227
- var BadgeContainer = _styledComponents["default"].div(_templateObject4(), function (props) {
228
- return props.hasLabelAndIcon && props.iconPosition === "top" && "0" || "5px";
229
- });
230
-
231
- var MainLabelContainer = _styledComponents["default"].div(_templateObject5(), function (props) {
232
- return props.hasBadge && "35px" || "unset";
233
- }, function (props) {
234
- return props.hasBadge && "35px" || "unset";
235
- });
236
-
237
- var Underline = _styledComponents["default"].div(_templateObject6(), function (props) {
238
- return props.theme.dividerThickness;
239
- }, function (props) {
240
- return props.theme.dividerColor;
241
- });
242
-
243
- var DxCTabs = _styledComponents["default"].div(_templateObject7(), function (props) {
244
- return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
245
- }, function (props) {
246
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
247
- }, function (props) {
248
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
249
- }, function (props) {
250
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
251
- }, function (props) {
252
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
253
- }, function (props) {
254
- return (!props.hasLabelAndIcon || props.hasLabelAndIcon && props.iconPosition !== "top") && props.theme.minHeight || props.theme.minHeightWithLabelAndIcon;
255
- }, function (props) {
256
- return props.theme.fontTextTransform;
257
- }, function (props) {
258
- return props.theme.fontFamily;
259
- }, function (props) {
260
- return props.theme.fontSize;
261
- }, function (props) {
262
- return props.theme.fontStyle;
263
- }, function (props) {
264
- return props.theme.fontWeight;
265
- }, function (props) {
266
- return (!props.hasLabelAndIcon || props.hasLabelAndIcon && props.iconPosition !== "top") && "12px 16px" || "8px 16px";
267
- }, function (props) {
268
- return (!props.hasLabelAndIcon || props.hasLabelAndIcon && props.iconPosition !== "top") && props.theme.minHeight || props.theme.minHeightWithLabelAndIcon;
269
- }, function (props) {
270
- return props.theme.minWidth;
271
- }, function (props) {
272
- return props.theme.maxWidth;
273
- }, function (props) {
274
- return (!props.hasLabelAndIcon || props.hasLabelAndIcon && props.iconPosition !== "top") && props.theme.minHeight || props.theme.minHeightWithLabelAndIcon;
275
- }, function (props) {
276
- return "".concat(props.theme.hoverBackgroundColor, " !important");
277
- }, function (props) {
278
- return "".concat(props.theme.pressedBackgroundColor, " !important");
279
- }, function (props) {
280
- return "".concat(props.theme.pressedFontWeight, " !important");
281
- }, function (props) {
282
- return props.theme.unselectedBackgroundColor;
283
- }, function (props) {
284
- return props.theme.unselectedFontColor;
285
- }, function (props) {
286
- return props.theme.unselectedIconColor;
287
- }, function (props) {
288
- return props.theme.selectedBackgroundColor;
289
- }, function (props) {
290
- return props.theme.selectedFontColor;
291
- }, function (props) {
292
- return props.theme.selectedIconColor;
293
- }, function (props) {
294
- return props.theme.disabledFontColor;
295
- }, function (props) {
296
- return props.theme.disabledFontStyle;
297
- }, function (props) {
298
- return props.theme.disabledIconColor;
299
- }, function (props) {
300
- return props.theme.focusOutline;
301
- }, function (props) {
302
- return props.theme.selectedUnderlineColor;
303
- }, function (props) {
304
- return props.theme.selectedUnderlineThickness;
305
- }, function (props) {
306
- return props.theme.scrollButtonsWidth;
307
- }, function (props) {
308
- return props.theme.scrollButtonsWidth;
309
- });
310
-
311
- var TabIcon = _styledComponents["default"].img(_templateObject8());
312
-
313
- var TabIconContainer = _styledComponents["default"].div(_templateObject9(), function (props) {
314
- return props.hasLabelAndIcon && props.iconPosition === "top" && "8px" || "";
315
- }, function (props) {
316
- return props.hasLabelAndIcon && props.iconPosition === "left" && "12px" || "";
317
- });
318
-
319
- DxcTabs.propTypes = {
320
- activeTabIndex: _propTypes["default"].number,
321
- onTabClick: _propTypes["default"].func,
322
- onTabHover: _propTypes["default"].func,
323
- tabs: _propTypes["default"].arrayOf(_propTypes["default"].shape({
324
- label: _propTypes["default"].string,
325
- icon: _propTypes["default"].oneOfType([_propTypes["default"].element, _propTypes["default"].func]),
326
- iconSrc: _propTypes["default"].string,
327
- isDisabled: _propTypes["default"].bool,
328
- notificationNumber: _propTypes["default"].oneOfType([_propTypes["default"].bool, _propTypes["default"].string, _propTypes["default"].number])
329
- })),
330
- margin: _propTypes["default"].oneOfType([_propTypes["default"].shape({
331
- top: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
332
- bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
333
- left: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
334
- right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
335
- }), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))]),
336
- iconPosition: _propTypes["default"].oneOf(["top", "left"]),
337
- tabIndex: _propTypes["default"].number
338
- };
339
- DxcTabs.defaultProps = {
340
- activeTabIndex: null,
341
- tabs: [],
342
- onTabClick: function onTabClick() {},
343
- onTabHover: function onTabHover() {},
344
- iconPosition: "top"
345
- };
346
- var _default = DxcTabs;
347
- exports["default"] = _default;
@@ -1,130 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
6
-
7
- var _react = _interopRequireDefault(require("react"));
8
-
9
- var _react2 = require("@storybook/react");
10
-
11
- var _addonActions = require("@storybook/addon-actions");
12
-
13
- var _addonKnobs = require("@storybook/addon-knobs");
14
-
15
- var _readme = _interopRequireDefault(require("./readme.md"));
16
-
17
- var _Tabs = _interopRequireDefault(require("./Tabs"));
18
-
19
- var _Tab = _interopRequireDefault(require("./tab/Tab"));
20
-
21
- var _amazon = _interopRequireDefault(require("../../.storybook/public/amazon.svg"));
22
-
23
- var _ebay = _interopRequireDefault(require("../../.storybook/public/ebay.svg"));
24
-
25
- var _apple = _interopRequireDefault(require("../../.storybook/public/apple.svg"));
26
-
27
- var onChange = (0, _addonActions.action)("onChange");
28
-
29
- onChange.toString = function () {
30
- return "onChangeHandler";
31
- };
32
-
33
- (0, _react2.storiesOf)("Form Components|Tabs", module).add("Types", function () {
34
- return _react["default"].createElement("div", null, _react["default"].createElement("h3", null, "Light"), _react["default"].createElement("div", null, _react["default"].createElement(_Tabs["default"], {
35
- activeTabIndex: 0,
36
- activeTabIndexChange: onChange,
37
- mode: "underlined"
38
- }, _react["default"].createElement(_Tab["default"], {
39
- label: "Tab ONE",
40
- iconSrc: "",
41
- disabled: false
42
- }, _react["default"].createElement("div", null, "Lorem ipsum dolor sit amet consectetur adipiscing elit aliquam class orci, est lectus eros praesent rhoncus dui etiam nascetur a mauris, luctus bibendum facilisis senectus sodales lobortis condimentum porta posuere. Massa varius ac imperdiet mauris quis rhoncus, nisl interdum gravida ullamcorper aliquam aptent pellentesque, consequat leo quam nec montes. Ridiculus mollis augue nam erat volutpat nibh congue, nostra habitasse dignissim pulvinar libero iaculis taciti et, bibendum morbi potenti lobortis purus laoreet.")), _react["default"].createElement(_Tab["default"], {
43
- label: "Tab TWO",
44
- iconSrc: "",
45
- disabled: false
46
- }, _react["default"].createElement("div", null, "Lorem ipsum dolor sit amet consectetur adipiscing elit aliquam class orci, est lectus eros praesent rhoncus dui etiam nascetur a mauris, luctus bibendum facilisis senectus sodales lobortis condimentum porta posuere. Massa varius ac imperdiet mauris quis rhoncus, nisl interdum gravida ullamcorper aliquam aptent pellentesque, consequat leo quam nec montes. Ridiculus mollis augue nam erat volutpat nibh congue, nostra habitasse dignissim pulvinar libero iaculis taciti et, bibendum morbi potenti lobortis purus laoreet.")), _react["default"].createElement(_Tab["default"], {
47
- label: "Tab THREE",
48
- iconSrc: "",
49
- disabled: false
50
- }, _react["default"].createElement("div", null, "Lorem ipsum dolor sit amet consectetur adipiscing elit aliquam class orci, est lectus eros praesent rhoncus dui etiam nascetur a mauris, luctus bibendum facilisis senectus sodales lobortis condimentum porta posuere. Massa varius ac imperdiet mauris quis rhoncus, nisl interdum gravida ullamcorper aliquam aptent pellentesque, consequat leo quam nec montes. Ridiculus mollis augue nam erat volutpat nibh congue, nostra habitasse dignissim pulvinar libero iaculis taciti et, bibendum morbi potenti lobortis purus laoreet.")))), _react["default"].createElement("div", null, _react["default"].createElement(_Tabs["default"], {
51
- activeTabIndex: 0,
52
- activeTabIndexChange: onChange,
53
- mode: "filled"
54
- }, _react["default"].createElement(_Tab["default"], {
55
- label: "Label 1",
56
- iconSrc: _amazon["default"],
57
- disabled: false
58
- }, _react["default"].createElement("div", null, "Lorem ipsum dolor sit amet consectetur adipiscing elit aliquam class orci, est lectus eros praesent rhoncus dui etiam nascetur a mauris, luctus bibendum facilisis senectus sodales lobortis condimentum porta posuere. Massa varius ac imperdiet mauris quis rhoncus, nisl interdum gravida ullamcorper aliquam aptent pellentesque, consequat leo quam nec montes. Ridiculus mollis augue nam erat volutpat nibh congue, nostra habitasse dignissim pulvinar libero iaculis taciti et, bibendum morbi potenti lobortis purus laoreet.")), _react["default"].createElement(_Tab["default"], {
59
- label: "Label 2",
60
- iconSrc: _ebay["default"],
61
- disabled: false
62
- }, _react["default"].createElement("div", null, "Lorem ipsum dolor sit amet consectetur adipiscing elit aliquam class orci, est lectus eros praesent rhoncus dui etiam nascetur a mauris, luctus bibendum facilisis senectus sodales lobortis condimentum porta posuere. Massa varius ac imperdiet mauris quis rhoncus, nisl interdum gravida ullamcorper aliquam aptent pellentesque, consequat leo quam nec montes. Ridiculus mollis augue nam erat volutpat nibh congue, nostra habitasse dignissim pulvinar libero iaculis taciti et, bibendum morbi potenti lobortis purus laoreet.")), _react["default"].createElement(_Tab["default"], {
63
- label: "Label 3",
64
- iconSrc: _apple["default"],
65
- disabled: true
66
- }, _react["default"].createElement("div", null, "Lorem ipsum dolor sit amet consectetur adipiscing elit aliquam class orci, est lectus eros praesent rhoncus dui etiam nascetur a mauris, luctus bibendum facilisis senectus sodales lobortis condimentum porta posuere. Massa varius ac imperdiet mauris quis rhoncus, nisl interdum gravida ullamcorper aliquam aptent pellentesque, consequat leo quam nec montes. Ridiculus mollis augue nam erat volutpat nibh congue, nostra habitasse dignissim pulvinar libero iaculis taciti et, bibendum morbi potenti lobortis purus laoreet.")))));
67
- }, {
68
- notes: {
69
- markdown: _readme["default"]
70
- }
71
- });
72
-
73
- var knobProps = function knobProps() {
74
- return {
75
- mode: (0, _addonKnobs.select)("mode", {
76
- filled: "filled",
77
- underlined: "underlined"
78
- }, "filled"),
79
- theme: (0, _addonKnobs.select)("theme", {
80
- light: "light",
81
- dark: "dark"
82
- }, "light"),
83
- activeTabIndex: (0, _addonKnobs.number)("Tab Active", 0)
84
- };
85
- };
86
-
87
- var knobTab1Props = function knobTab1Props() {
88
- return {
89
- label: (0, _addonKnobs.text)("First Tab Label", "Tab 1"),
90
- disabled: (0, _addonKnobs["boolean"])("First Tab Disabled", false)
91
- };
92
- };
93
-
94
- var knobTab2Props = function knobTab2Props() {
95
- return {
96
- label: (0, _addonKnobs.text)("Second Tab Label", "Tab 2"),
97
- disabled: (0, _addonKnobs["boolean"])("Second Tab Disabled", false)
98
- };
99
- };
100
-
101
- var knobTab3Props = function knobTab3Props() {
102
- return {
103
- label: (0, _addonKnobs.text)("Third Tab Label", "Tab 3"),
104
- disabled: (0, _addonKnobs["boolean"])("Third Tab Disabled", false)
105
- };
106
- };
107
-
108
- (0, _react2.storiesOf)("Form Components|Tabs", module).add("Knobs example", function () {
109
- var props = knobProps();
110
- var tab1Props = knobTab1Props();
111
- var tab2Props = knobTab2Props();
112
- var tab3Props = knobTab3Props();
113
- return _react["default"].createElement("div", {
114
- style: {
115
- background: props.theme === "dark" && "black" || "transparent"
116
- }
117
- }, _react["default"].createElement(_Tabs["default"], (0, _extends2["default"])({}, props, {
118
- activeTabIndexChange: onChange
119
- }), _react["default"].createElement(_Tab["default"], (0, _extends2["default"])({}, tab1Props, {
120
- iconSrc: _amazon["default"]
121
- }), "Content ONE"), _react["default"].createElement(_Tab["default"], (0, _extends2["default"])({}, tab2Props, {
122
- iconSrc: _ebay["default"]
123
- }), "Content TWO"), _react["default"].createElement(_Tab["default"], (0, _extends2["default"])({}, tab3Props, {
124
- iconSrc: _apple["default"]
125
- }), "Content THREE")));
126
- }, {
127
- notes: {
128
- markdown: _readme["default"]
129
- }
130
- });
@@ -1,78 +0,0 @@
1
- # DXC Tabs Component
2
-
3
- ## Tab Group 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>mode: 'filled' | 'underlined'</td>
13
- <td><code>'filled'</code></td>
14
- <td>Uses one of the available component modes.</td>
15
- </tr>
16
- <tr>
17
- <td>theme: 'light' | 'dark'</td>
18
- <td><code>'light'</code></td>
19
- <td>Uses one of the available component themes.</td>
20
- </tr>
21
- <tr>
22
- <td>showDotIndicator: boolean</td>
23
- <td><code>false</code></td>
24
- <td>If true, a dot indicator will be shown in the active tab.</td>
25
- </tr>
26
- <tr>
27
- <td>disableRipple: boolean</td>
28
- <td><code>false</code></td>
29
- <td>If true, the ripple effect will be disabled.</td>
30
- </tr>
31
- <tr>
32
- <td>activeTabIndex: number</td>
33
- <td><code>0</code></td>
34
- <td>The index of the active tab.</td>
35
- </tr>
36
- <tr>
37
- <td>activeTabIndexChange: function</td>
38
- <td></td>
39
- <td>This function will be called when the user clicks on a tab. The index of the clicked tab will be passed as a parameter.</td>
40
- </tr>
41
- <tr>
42
- <td>stepper: boolean</td>
43
- <td><code>false</code></td>
44
- <td>If true, the component should be rendered as a Stepper component.</td>
45
- </tr>
46
- <tr>
47
- <td>orientation: 'horizontal' | 'vertical'</td>
48
- <td><code>'horizontal'</code></td>
49
- <td>Only if stepper, this parameter shows the stepper orientation.</td>
50
- </tr>
51
-
52
- </table>
53
-
54
- ## Tab Props
55
-
56
- <table>
57
- <tr style="background-color: grey">
58
- <td>Name</td>
59
- <td>Default</td>
60
- <td>Description</td>
61
- </tr>
62
- <tr>
63
- <td>label: string</td>
64
- <td></td>
65
- <td>Text to be placed within the tab.</td>
66
- </tr>
67
- <tr>
68
- <td>iconSrc: string</td>
69
- <td></td>
70
- <td>The path of an icon to be placed within the tab.</td>
71
- </tr>
72
- <tr>
73
- <td>disabled: boolean</td>
74
- <td><code>false</code></td>
75
- <td>Whether the tab is disabled.</td>
76
- </tr>
77
- </table>
78
-
@@ -1,92 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports["default"] = void 0;
9
-
10
- var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
11
-
12
- var _react = _interopRequireDefault(require("react"));
13
-
14
- var _styledComponents = _interopRequireDefault(require("styled-components"));
15
-
16
- var _propTypes = _interopRequireDefault(require("prop-types"));
17
-
18
- var _reactUseScrollspy = _interopRequireDefault(require("react-use-scrollspy"));
19
-
20
- var _Tabs = _interopRequireDefault(require("../tabs/Tabs"));
21
-
22
- function _templateObject() {
23
- var data = (0, _taggedTemplateLiteral2["default"])(["\n z-index: 10;\n ", "\n"]);
24
-
25
- _templateObject = function _templateObject() {
26
- return data;
27
- };
28
-
29
- return data;
30
- }
31
-
32
- var TABS_HEIGHT = 54;
33
-
34
- var DxcTabsForSections = function DxcTabsForSections(_ref) {
35
- var _ref$sections = _ref.sections,
36
- sections = _ref$sections === void 0 ? [] : _ref$sections,
37
- _ref$stickAtPx = _ref.stickAtPx,
38
- stickAtPx = _ref$stickAtPx === void 0 ? 0 : _ref$stickAtPx;
39
- var tabs = sections.map(function (section) {
40
- return {
41
- label: section.tabLabel
42
- };
43
- });
44
- var refs = sections.map(function () {
45
- return _react["default"].createRef();
46
- });
47
- var activeTab = (0, _reactUseScrollspy["default"])({
48
- sectionElementRefs: refs,
49
- offsetPx: -stickAtPx - TABS_HEIGHT
50
- });
51
-
52
- var onTabClick = function onTabClick(tabId) {
53
- var topOfElement = refs[tabId].current.offsetTop - stickAtPx - TABS_HEIGHT + 5;
54
- window.scroll({
55
- top: topOfElement,
56
- behavior: "smooth"
57
- });
58
- };
59
-
60
- return _react["default"].createElement(_react["default"].Fragment, null, _react["default"].createElement(StyledTabs, {
61
- stickAtPx: stickAtPx
62
- }, _react["default"].createElement(_Tabs["default"], {
63
- tabs: tabs,
64
- activeTabIndex: activeTab,
65
- onTabClick: onTabClick
66
- })), sections.map(function (section, i) {
67
- return _react["default"].createElement("div", {
68
- key: "section".concat(i),
69
- ref: refs[i]
70
- }, _react["default"].createElement(section.section, null));
71
- }));
72
- };
73
-
74
- DxcTabsForSections.propTypes = {
75
- stickAtPx: _propTypes["default"].number,
76
- sections: _propTypes["default"].arrayOf(_propTypes["default"].shape({
77
- tabLabel: _propTypes["default"].string,
78
- section: _propTypes["default"].func
79
- }))
80
- };
81
- DxcTabsForSections.defaultProps = {
82
- stickAtPx: 0,
83
- sections: []
84
- };
85
-
86
- var StyledTabs = _styledComponents["default"].div(_templateObject(), function (_ref2) {
87
- var stickAtPx = _ref2.stickAtPx;
88
- return stickAtPx && "\n position: sticky;\n top: ".concat(stickAtPx, "px;\n ");
89
- });
90
-
91
- var _default = DxcTabsForSections;
92
- exports["default"] = _default;