@dxc-technology/halstack-react 0.0.0-c8db8a2 → 0.0.0-c908d78

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 (339) 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/box/Box.d.ts +4 -0
  21. package/{dist/box → box}/Box.js +18 -53
  22. package/box/Box.stories.tsx +132 -0
  23. package/box/types.d.ts +47 -0
  24. package/box/types.js +5 -0
  25. package/button/Button.d.ts +4 -0
  26. package/button/Button.js +177 -0
  27. package/button/Button.stories.tsx +293 -0
  28. package/button/types.d.ts +57 -0
  29. package/button/types.js +5 -0
  30. package/card/Card.d.ts +4 -0
  31. package/{dist/card → card}/Card.js +42 -124
  32. package/card/types.d.ts +69 -0
  33. package/card/types.js +5 -0
  34. package/checkbox/Checkbox.d.ts +4 -0
  35. package/{dist/checkbox → checkbox}/Checkbox.js +44 -82
  36. package/checkbox/Checkbox.stories.tsx +192 -0
  37. package/checkbox/types.d.ts +60 -0
  38. package/checkbox/types.js +5 -0
  39. package/{dist/chip → chip}/Chip.js +48 -104
  40. package/chip/index.d.ts +22 -0
  41. package/{dist/common → common}/OpenSans.css +0 -0
  42. package/{dist/common → common}/RequiredComponent.js +3 -11
  43. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  44. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  45. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  46. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  47. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  48. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  49. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  50. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  51. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  52. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  53. package/{dist/common → common}/utils.js +0 -0
  54. package/common/variables.js +1569 -0
  55. package/{dist/date → date}/Date.js +71 -57
  56. package/date/index.d.ts +27 -0
  57. package/date-input/DateInput.d.ts +4 -0
  58. package/date-input/DateInput.js +361 -0
  59. package/date-input/types.d.ts +100 -0
  60. package/date-input/types.js +5 -0
  61. package/dialog/Dialog.d.ts +4 -0
  62. package/{dist/dialog → dialog}/Dialog.js +29 -100
  63. package/dialog/types.d.ts +43 -0
  64. package/dialog/types.js +5 -0
  65. package/dropdown/Dropdown.d.ts +4 -0
  66. package/dropdown/Dropdown.js +417 -0
  67. package/dropdown/types.d.ts +89 -0
  68. package/dropdown/types.js +5 -0
  69. package/file-input/FileInput.js +532 -0
  70. package/file-input/FileItem.js +193 -0
  71. package/file-input/index.d.ts +81 -0
  72. package/footer/Footer.d.ts +4 -0
  73. package/footer/Footer.js +266 -0
  74. package/footer/Footer.stories.jsx +151 -0
  75. package/footer/Icons.js +77 -0
  76. package/footer/types.d.ts +61 -0
  77. package/footer/types.js +5 -0
  78. package/header/Header.d.ts +7 -0
  79. package/header/Header.js +324 -0
  80. package/header/Icons.js +34 -0
  81. package/header/types.d.ts +45 -0
  82. package/header/types.js +5 -0
  83. package/{dist/heading → heading}/Heading.js +30 -76
  84. package/heading/index.d.ts +17 -0
  85. package/input-text/Icons.js +22 -0
  86. package/{dist/input-text → input-text}/InputText.js +151 -171
  87. package/input-text/index.d.ts +36 -0
  88. package/{dist/layout → layout}/ApplicationLayout.js +35 -131
  89. package/layout/Icons.js +55 -0
  90. package/link/Link.d.ts +3 -0
  91. package/link/Link.js +161 -0
  92. package/link/types.d.ts +74 -0
  93. package/link/types.js +5 -0
  94. package/main.d.ts +44 -0
  95. package/{dist/main.js → main.js} +121 -69
  96. package/number-input/NumberInput.js +128 -0
  97. package/number-input/NumberInput.stories.jsx +115 -0
  98. package/number-input/NumberInputContext.js +16 -0
  99. package/number-input/index.d.ts +113 -0
  100. package/package.json +34 -25
  101. package/paginator/Icons.js +66 -0
  102. package/paginator/Paginator.d.ts +4 -0
  103. package/paginator/Paginator.js +198 -0
  104. package/paginator/Paginator.stories.tsx +63 -0
  105. package/paginator/types.d.ts +38 -0
  106. package/paginator/types.js +5 -0
  107. package/password-input/PasswordInput.d.ts +4 -0
  108. package/password-input/PasswordInput.js +162 -0
  109. package/password-input/PasswordInput.stories.tsx +131 -0
  110. package/password-input/types.d.ts +100 -0
  111. package/password-input/types.js +5 -0
  112. package/progress-bar/ProgressBar.d.ts +4 -0
  113. package/progress-bar/ProgressBar.js +170 -0
  114. package/progress-bar/ProgressBar.stories.jsx +58 -0
  115. package/progress-bar/types.d.ts +37 -0
  116. package/progress-bar/types.js +5 -0
  117. package/radio/Radio.d.ts +4 -0
  118. package/{dist/radio → radio}/Radio.js +17 -52
  119. package/radio/Radio.stories.tsx +192 -0
  120. package/radio/types.d.ts +54 -0
  121. package/radio/types.js +5 -0
  122. package/{dist/resultsetTable → resultsetTable}/ResultsetTable.js +77 -135
  123. package/resultsetTable/index.d.ts +19 -0
  124. package/select/Select.js +865 -0
  125. package/select/index.d.ts +131 -0
  126. package/{dist/sidenav → sidenav}/Sidenav.js +20 -58
  127. package/sidenav/index.d.ts +13 -0
  128. package/slider/Slider.d.ts +4 -0
  129. package/slider/Slider.js +306 -0
  130. package/slider/types.d.ts +83 -0
  131. package/slider/types.js +5 -0
  132. package/spinner/Spinner.d.ts +4 -0
  133. package/spinner/Spinner.js +250 -0
  134. package/spinner/Spinner.stories.jsx +102 -0
  135. package/spinner/types.d.ts +32 -0
  136. package/spinner/types.js +5 -0
  137. package/switch/Switch.d.ts +4 -0
  138. package/{dist/switch → switch}/Switch.js +28 -71
  139. package/switch/Switch.stories.tsx +160 -0
  140. package/switch/types.d.ts +58 -0
  141. package/switch/types.js +5 -0
  142. package/table/Table.d.ts +4 -0
  143. package/table/Table.js +118 -0
  144. package/table/Table.stories.jsx +276 -0
  145. package/table/types.d.ts +21 -0
  146. package/table/types.js +5 -0
  147. package/tabs/Tabs.d.ts +4 -0
  148. package/tabs/Tabs.js +211 -0
  149. package/tabs/types.d.ts +71 -0
  150. package/tabs/types.js +5 -0
  151. package/tag/Tag.d.ts +4 -0
  152. package/tag/Tag.js +193 -0
  153. package/tag/Tag.stories.tsx +145 -0
  154. package/tag/types.d.ts +60 -0
  155. package/tag/types.js +5 -0
  156. package/text-input/TextInput.js +825 -0
  157. package/text-input/index.d.ts +135 -0
  158. package/textarea/Textarea.js +317 -0
  159. package/textarea/Textarea.stories.jsx +135 -0
  160. package/textarea/index.d.ts +117 -0
  161. package/{dist/toggle → toggle}/Toggle.js +15 -49
  162. package/toggle/index.d.ts +21 -0
  163. package/toggle-group/ToggleGroup.js +243 -0
  164. package/toggle-group/index.d.ts +21 -0
  165. package/{dist/upload → upload}/Upload.js +11 -15
  166. package/upload/buttons-upload/ButtonsUpload.js +111 -0
  167. package/upload/buttons-upload/Icons.js +40 -0
  168. package/upload/dragAndDropArea/DragAndDropArea.js +225 -0
  169. package/upload/dragAndDropArea/Icons.js +39 -0
  170. package/upload/file-upload/FileToUpload.js +115 -0
  171. package/upload/file-upload/Icons.js +66 -0
  172. package/{dist/upload → upload}/files-upload/FilesToUpload.js +12 -26
  173. package/upload/index.d.ts +15 -0
  174. package/upload/transaction/Icons.js +160 -0
  175. package/upload/transaction/Transaction.js +104 -0
  176. package/upload/transactions/Transactions.js +94 -0
  177. package/{dist/useTheme.js → useTheme.js} +0 -0
  178. package/wizard/Icons.js +65 -0
  179. package/wizard/Wizard.js +271 -0
  180. package/wizard/index.d.ts +18 -0
  181. package/README.md +0 -66
  182. package/babel.config.js +0 -8
  183. package/dist/BackgroundColorContext.js +0 -46
  184. package/dist/ThemeContext.js +0 -216
  185. package/dist/accordion/Accordion.js +0 -356
  186. package/dist/accordion/Accordion.stories.js +0 -207
  187. package/dist/accordion/readme.md +0 -96
  188. package/dist/accordion-group/AccordionGroup.js +0 -188
  189. package/dist/accordion-group/AccordionGroup.stories.js +0 -207
  190. package/dist/accordion-group/readme.md +0 -70
  191. package/dist/alert/Alert.js +0 -388
  192. package/dist/alert/Alert.stories.js +0 -158
  193. package/dist/alert/close.svg +0 -4
  194. package/dist/alert/error.svg +0 -4
  195. package/dist/alert/info.svg +0 -4
  196. package/dist/alert/readme.md +0 -43
  197. package/dist/alert/success.svg +0 -4
  198. package/dist/alert/warning.svg +0 -4
  199. package/dist/badge/Badge.js +0 -61
  200. package/dist/button/Button.js +0 -228
  201. package/dist/button/Button.stories.js +0 -224
  202. package/dist/button/readme.md +0 -93
  203. package/dist/checkbox/Checkbox.stories.js +0 -144
  204. package/dist/checkbox/readme.md +0 -116
  205. package/dist/common/variables.js +0 -1134
  206. package/dist/date/Date.stories.js +0 -205
  207. package/dist/date/calendar.svg +0 -1
  208. package/dist/date/calendar_dark.svg +0 -1
  209. package/dist/date/readme.md +0 -73
  210. package/dist/dialog/Dialog.stories.js +0 -217
  211. package/dist/dialog/readme.md +0 -32
  212. package/dist/dropdown/Dropdown.js +0 -498
  213. package/dist/dropdown/Dropdown.stories.js +0 -249
  214. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  215. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  216. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  217. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  218. package/dist/dropdown/readme.md +0 -69
  219. package/dist/footer/Footer.js +0 -405
  220. package/dist/footer/Footer.stories.js +0 -94
  221. package/dist/footer/dxc_logo_wht.png +0 -0
  222. package/dist/footer/readme.md +0 -41
  223. package/dist/header/Header.js +0 -431
  224. package/dist/header/Header.stories.js +0 -176
  225. package/dist/header/close_icon.svg +0 -1
  226. package/dist/header/dxc_logo_black.png +0 -0
  227. package/dist/header/dxc_logo_blk_rgb.svg +0 -6
  228. package/dist/header/dxc_logo_white.png +0 -0
  229. package/dist/header/hamb_menu_black.svg +0 -1
  230. package/dist/header/hamb_menu_white.svg +0 -1
  231. package/dist/header/readme.md +0 -33
  232. package/dist/input-text/InputText.stories.js +0 -209
  233. package/dist/input-text/error.svg +0 -1
  234. package/dist/input-text/readme.md +0 -91
  235. package/dist/layout/facebook.svg +0 -45
  236. package/dist/layout/linkedin.svg +0 -50
  237. package/dist/layout/twitter.svg +0 -53
  238. package/dist/link/Link.js +0 -212
  239. package/dist/link/readme.md +0 -51
  240. package/dist/paginator/Paginator.js +0 -283
  241. package/dist/paginator/images/next.svg +0 -3
  242. package/dist/paginator/images/nextPage.svg +0 -3
  243. package/dist/paginator/images/previous.svg +0 -3
  244. package/dist/paginator/images/previousPage.svg +0 -3
  245. package/dist/paginator/readme.md +0 -50
  246. package/dist/progress-bar/ProgressBar.js +0 -206
  247. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  248. package/dist/progress-bar/readme.md +0 -63
  249. package/dist/radio/Radio.stories.js +0 -166
  250. package/dist/radio/readme.md +0 -70
  251. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  252. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  253. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  254. package/dist/select/Select.js +0 -525
  255. package/dist/select/Select.stories.js +0 -235
  256. package/dist/select/readme.md +0 -72
  257. package/dist/slider/Slider.js +0 -315
  258. package/dist/slider/Slider.stories.js +0 -241
  259. package/dist/slider/readme.md +0 -64
  260. package/dist/spinner/Spinner.js +0 -214
  261. package/dist/spinner/Spinner.stories.js +0 -183
  262. package/dist/spinner/readme.md +0 -65
  263. package/dist/switch/Switch.stories.js +0 -134
  264. package/dist/switch/readme.md +0 -133
  265. package/dist/table/Table.js +0 -118
  266. package/dist/tabs/Tabs.js +0 -347
  267. package/dist/tabs/Tabs.stories.js +0 -130
  268. package/dist/tabs/readme.md +0 -78
  269. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  270. package/dist/tabs-for-sections/readme.md +0 -78
  271. package/dist/tag/Tag.js +0 -280
  272. package/dist/toggle/Toggle.stories.js +0 -297
  273. package/dist/toggle/readme.md +0 -80
  274. package/dist/toggle-group/ToggleGroup.js +0 -241
  275. package/dist/toggle-group/readme.md +0 -82
  276. package/dist/upload/Upload.stories.js +0 -72
  277. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -135
  278. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  279. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  280. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -325
  281. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  282. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  283. package/dist/upload/file-upload/FileToUpload.js +0 -184
  284. package/dist/upload/file-upload/audio-icon.svg +0 -4
  285. package/dist/upload/file-upload/close.svg +0 -4
  286. package/dist/upload/file-upload/file-icon.svg +0 -4
  287. package/dist/upload/file-upload/video-icon.svg +0 -4
  288. package/dist/upload/readme.md +0 -37
  289. package/dist/upload/transaction/Transaction.js +0 -171
  290. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  291. package/dist/upload/transaction/audio-icon.svg +0 -4
  292. package/dist/upload/transaction/error-icon.svg +0 -4
  293. package/dist/upload/transaction/file-icon-err.svg +0 -4
  294. package/dist/upload/transaction/file-icon.svg +0 -4
  295. package/dist/upload/transaction/image-icon-err.svg +0 -4
  296. package/dist/upload/transaction/image-icon.svg +0 -4
  297. package/dist/upload/transaction/success-icon.svg +0 -4
  298. package/dist/upload/transaction/video-icon-err.svg +0 -4
  299. package/dist/upload/transaction/video-icon.svg +0 -4
  300. package/dist/upload/transactions/Transactions.js +0 -138
  301. package/dist/wizard/Wizard.js +0 -383
  302. package/dist/wizard/invalid_icon.svg +0 -6
  303. package/dist/wizard/valid_icon.svg +0 -6
  304. package/dist/wizard/validation-wrong.svg +0 -6
  305. package/test/Accordion.test.js +0 -33
  306. package/test/AccordionGroup.test.js +0 -125
  307. package/test/Alert.test.js +0 -53
  308. package/test/Box.test.js +0 -10
  309. package/test/Button.test.js +0 -18
  310. package/test/Card.test.js +0 -30
  311. package/test/Checkbox.test.js +0 -45
  312. package/test/Chip.test.js +0 -25
  313. package/test/Date.test.js +0 -393
  314. package/test/Dialog.test.js +0 -23
  315. package/test/Dropdown.test.js +0 -130
  316. package/test/Footer.test.js +0 -99
  317. package/test/Header.test.js +0 -39
  318. package/test/Heading.test.js +0 -35
  319. package/test/InputText.test.js +0 -240
  320. package/test/Link.test.js +0 -42
  321. package/test/Paginator.test.js +0 -177
  322. package/test/ProgressBar.test.js +0 -35
  323. package/test/Radio.test.js +0 -37
  324. package/test/ResultsetTable.test.js +0 -330
  325. package/test/Select.test.js +0 -192
  326. package/test/Sidenav.test.js +0 -45
  327. package/test/Slider.test.js +0 -82
  328. package/test/Spinner.test.js +0 -27
  329. package/test/Switch.test.js +0 -45
  330. package/test/Table.test.js +0 -36
  331. package/test/Tabs.test.js +0 -109
  332. package/test/TabsForSections.test.js +0 -34
  333. package/test/Tag.test.js +0 -32
  334. package/test/TextArea.test.js +0 -52
  335. package/test/ToggleGroup.test.js +0 -81
  336. package/test/Upload.test.js +0 -60
  337. package/test/Wizard.test.js +0 -130
  338. package/test/mocks/pngMock.js +0 -1
  339. 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;