@dxc-technology/halstack-react 0.0.0-faa7105 → 0.0.0-fb9047c

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 (288) 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 +38 -34
  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 +306 -0
  19. package/button/types.d.ts +57 -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.d.ts +4 -0
  24. package/checkbox/Checkbox.js +253 -0
  25. package/checkbox/types.d.ts +61 -0
  26. package/checkbox/types.js +5 -0
  27. package/chip/Chip.js +221 -0
  28. package/chip/index.d.ts +22 -0
  29. package/{dist/common → common}/OpenSans.css +0 -0
  30. package/{dist/common → common}/RequiredComponent.js +5 -19
  31. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  32. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  33. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  34. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  35. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  36. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  37. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  38. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  39. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  40. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  41. package/common/utils.js +22 -0
  42. package/common/variables.js +1569 -0
  43. package/{dist/date → date}/Date.js +87 -71
  44. package/date/index.d.ts +27 -0
  45. package/date-input/DateInput.js +396 -0
  46. package/date-input/index.d.ts +95 -0
  47. package/dialog/Dialog.js +184 -0
  48. package/dialog/index.d.ts +18 -0
  49. package/dropdown/Dropdown.js +450 -0
  50. package/dropdown/index.d.ts +26 -0
  51. package/file-input/FileInput.js +532 -0
  52. package/file-input/FileItem.js +193 -0
  53. package/file-input/index.d.ts +81 -0
  54. package/footer/Footer.js +297 -0
  55. package/footer/Icons.js +77 -0
  56. package/footer/index.d.ts +25 -0
  57. package/header/Header.js +326 -0
  58. package/header/Icons.js +59 -0
  59. package/header/index.d.ts +25 -0
  60. package/heading/Heading.js +176 -0
  61. package/heading/index.d.ts +17 -0
  62. package/input-text/Icons.js +22 -0
  63. package/input-text/InputText.js +611 -0
  64. package/input-text/index.d.ts +36 -0
  65. package/layout/ApplicationLayout.js +235 -0
  66. package/layout/Icons.js +55 -0
  67. package/link/Link.js +183 -0
  68. package/link/index.d.ts +23 -0
  69. package/main.d.ts +44 -0
  70. package/{dist/main.js → main.js} +143 -43
  71. package/number-input/NumberInput.js +128 -0
  72. package/{dist/ThemeContext.js → number-input/NumberInputContext.js} +3 -2
  73. package/number-input/index.d.ts +113 -0
  74. package/package.json +39 -24
  75. package/paginator/Icons.js +66 -0
  76. package/paginator/Paginator.d.ts +4 -0
  77. package/paginator/Paginator.js +198 -0
  78. package/paginator/types.d.ts +38 -0
  79. package/paginator/types.js +5 -0
  80. package/password-input/PasswordInput.js +199 -0
  81. package/password-input/index.d.ts +94 -0
  82. package/progress-bar/ProgressBar.js +188 -0
  83. package/progress-bar/index.d.ts +18 -0
  84. package/{dist/radio → radio}/Radio.js +48 -40
  85. package/radio/index.d.ts +23 -0
  86. package/resultsetTable/ResultsetTable.js +274 -0
  87. package/resultsetTable/index.d.ts +19 -0
  88. package/select/Select.js +865 -0
  89. package/select/index.d.ts +131 -0
  90. package/sidenav/Sidenav.js +145 -0
  91. package/sidenav/index.d.ts +13 -0
  92. package/slider/Slider.js +340 -0
  93. package/slider/index.d.ts +29 -0
  94. package/spinner/Spinner.js +267 -0
  95. package/spinner/index.d.ts +17 -0
  96. package/switch/Switch.js +208 -0
  97. package/switch/index.d.ts +24 -0
  98. package/table/Table.js +118 -0
  99. package/table/index.d.ts +13 -0
  100. package/tabs/Tabs.js +259 -0
  101. package/tabs/index.d.ts +19 -0
  102. package/tag/Tag.js +208 -0
  103. package/tag/index.d.ts +24 -0
  104. package/text-input/TextInput.js +825 -0
  105. package/text-input/index.d.ts +135 -0
  106. package/textarea/Textarea.js +317 -0
  107. package/textarea/index.d.ts +117 -0
  108. package/{dist/toggle → toggle}/Toggle.js +30 -67
  109. package/toggle/index.d.ts +21 -0
  110. package/toggle-group/ToggleGroup.js +243 -0
  111. package/toggle-group/index.d.ts +21 -0
  112. package/{dist/upload → upload}/Upload.js +23 -22
  113. package/upload/buttons-upload/ButtonsUpload.js +111 -0
  114. package/upload/buttons-upload/Icons.js +40 -0
  115. package/upload/dragAndDropArea/DragAndDropArea.js +225 -0
  116. package/upload/dragAndDropArea/Icons.js +39 -0
  117. package/upload/file-upload/FileToUpload.js +115 -0
  118. package/upload/file-upload/Icons.js +66 -0
  119. package/upload/files-upload/FilesToUpload.js +109 -0
  120. package/upload/index.d.ts +15 -0
  121. package/upload/transaction/Icons.js +160 -0
  122. package/upload/transaction/Transaction.js +104 -0
  123. package/upload/transactions/Transactions.js +94 -0
  124. package/useTheme.js +22 -0
  125. package/wizard/Icons.js +65 -0
  126. package/wizard/Wizard.js +271 -0
  127. package/wizard/index.d.ts +18 -0
  128. package/README.md +0 -66
  129. package/babel.config.js +0 -4
  130. package/dist/accordion/Accordion.js +0 -242
  131. package/dist/accordion/Accordion.stories.js +0 -207
  132. package/dist/accordion/readme.md +0 -96
  133. package/dist/alert/Alert.js +0 -304
  134. package/dist/alert/Alert.stories.js +0 -158
  135. package/dist/alert/close.svg +0 -4
  136. package/dist/alert/error.svg +0 -4
  137. package/dist/alert/info.svg +0 -4
  138. package/dist/alert/readme.md +0 -43
  139. package/dist/alert/success.svg +0 -4
  140. package/dist/alert/warning.svg +0 -4
  141. package/dist/button/Button.js +0 -181
  142. package/dist/button/Button.stories.js +0 -224
  143. package/dist/button/readme.md +0 -93
  144. package/dist/card/Card.js +0 -217
  145. package/dist/checkbox/Checkbox.js +0 -224
  146. package/dist/checkbox/Checkbox.stories.js +0 -144
  147. package/dist/checkbox/readme.md +0 -116
  148. package/dist/chip/Chip.js +0 -173
  149. package/dist/common/services/example-service.js +0 -10
  150. package/dist/common/services/example-service.test.js +0 -12
  151. package/dist/common/utils.js +0 -42
  152. package/dist/common/variables.js +0 -400
  153. package/dist/date/Date.stories.js +0 -205
  154. package/dist/date/calendar.svg +0 -1
  155. package/dist/date/calendar_dark.svg +0 -1
  156. package/dist/date/readme.md +0 -73
  157. package/dist/dialog/Dialog.js +0 -197
  158. package/dist/dialog/Dialog.stories.js +0 -217
  159. package/dist/dialog/readme.md +0 -32
  160. package/dist/dropdown/Dropdown.js +0 -424
  161. package/dist/dropdown/Dropdown.stories.js +0 -249
  162. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  163. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  164. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  165. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  166. package/dist/dropdown/readme.md +0 -69
  167. package/dist/footer/Footer.js +0 -346
  168. package/dist/footer/Footer.stories.js +0 -94
  169. package/dist/footer/dxc_logo_wht.png +0 -0
  170. package/dist/footer/readme.md +0 -41
  171. package/dist/header/Header.js +0 -372
  172. package/dist/header/Header.stories.js +0 -176
  173. package/dist/header/close_icon.svg +0 -1
  174. package/dist/header/dxc_logo_black.png +0 -0
  175. package/dist/header/dxc_logo_white.png +0 -0
  176. package/dist/header/hamb_menu_black.svg +0 -1
  177. package/dist/header/hamb_menu_white.svg +0 -1
  178. package/dist/header/readme.md +0 -33
  179. package/dist/heading/Heading.js +0 -153
  180. package/dist/input-text/InputText.js +0 -519
  181. package/dist/input-text/InputText.stories.js +0 -209
  182. package/dist/input-text/error.svg +0 -1
  183. package/dist/input-text/readme.md +0 -91
  184. package/dist/link/Link.js +0 -136
  185. package/dist/link/readme.md +0 -51
  186. package/dist/paginator/Paginator.js +0 -196
  187. package/dist/paginator/images/next.svg +0 -3
  188. package/dist/paginator/images/nextPage.svg +0 -3
  189. package/dist/paginator/images/previous.svg +0 -3
  190. package/dist/paginator/images/previousPage.svg +0 -3
  191. package/dist/paginator/readme.md +0 -50
  192. package/dist/progress-bar/ProgressBar.js +0 -185
  193. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  194. package/dist/progress-bar/readme.md +0 -63
  195. package/dist/radio/Radio.stories.js +0 -166
  196. package/dist/radio/readme.md +0 -70
  197. package/dist/resultsetTable/ResultsetTable.js +0 -333
  198. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  199. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  200. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  201. package/dist/select/Select.js +0 -445
  202. package/dist/select/Select.stories.js +0 -235
  203. package/dist/select/readme.md +0 -72
  204. package/dist/sidenav/Sidenav.js +0 -236
  205. package/dist/sidenav/arrow_icon.svg +0 -3
  206. package/dist/slider/Slider.js +0 -258
  207. package/dist/slider/Slider.stories.js +0 -241
  208. package/dist/slider/readme.md +0 -64
  209. package/dist/spinner/Spinner.js +0 -193
  210. package/dist/spinner/Spinner.stories.js +0 -183
  211. package/dist/spinner/readme.md +0 -65
  212. package/dist/switch/Switch.js +0 -199
  213. package/dist/switch/Switch.stories.js +0 -134
  214. package/dist/switch/readme.md +0 -133
  215. package/dist/table/Table.js +0 -87
  216. package/dist/tabs/Tabs.js +0 -172
  217. package/dist/tabs/Tabs.stories.js +0 -130
  218. package/dist/tabs/readme.md +0 -78
  219. package/dist/tabs-for-sections/TabsForSections.js +0 -107
  220. package/dist/tabs-for-sections/readme.md +0 -78
  221. package/dist/tag/Tag.js +0 -217
  222. package/dist/textarea/Textarea.js +0 -227
  223. package/dist/toggle/Toggle.stories.js +0 -297
  224. package/dist/toggle/readme.md +0 -80
  225. package/dist/upload/Upload.stories.js +0 -72
  226. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -122
  227. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  228. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  229. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -279
  230. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  231. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  232. package/dist/upload/file-upload/FileToUpload.js +0 -158
  233. package/dist/upload/file-upload/audio-icon.svg +0 -4
  234. package/dist/upload/file-upload/close.svg +0 -4
  235. package/dist/upload/file-upload/file-icon.svg +0 -4
  236. package/dist/upload/file-upload/video-icon.svg +0 -4
  237. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  238. package/dist/upload/readme.md +0 -37
  239. package/dist/upload/transaction/Transaction.js +0 -155
  240. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  241. package/dist/upload/transaction/audio-icon.svg +0 -4
  242. package/dist/upload/transaction/error-icon.svg +0 -4
  243. package/dist/upload/transaction/file-icon-err.svg +0 -4
  244. package/dist/upload/transaction/file-icon.svg +0 -4
  245. package/dist/upload/transaction/image-icon-err.svg +0 -4
  246. package/dist/upload/transaction/image-icon.svg +0 -4
  247. package/dist/upload/transaction/success-icon.svg +0 -4
  248. package/dist/upload/transaction/video-icon-err.svg +0 -4
  249. package/dist/upload/transaction/video-icon.svg +0 -4
  250. package/dist/upload/transactions/Transactions.js +0 -120
  251. package/dist/wizard/Wizard.js +0 -327
  252. package/dist/wizard/invalid_icon.svg +0 -6
  253. package/dist/wizard/valid_icon.svg +0 -6
  254. package/dist/wizard/validation-wrong.svg +0 -6
  255. package/test/Accordion.test.js +0 -33
  256. package/test/Alert.test.js +0 -53
  257. package/test/Box.test.js +0 -10
  258. package/test/Button.test.js +0 -18
  259. package/test/Card.test.js +0 -30
  260. package/test/Checkbox.test.js +0 -45
  261. package/test/Chip.test.js +0 -25
  262. package/test/Date.test.js +0 -393
  263. package/test/Dialog.test.js +0 -23
  264. package/test/Dropdown.test.js +0 -130
  265. package/test/Footer.test.js +0 -99
  266. package/test/Header.test.js +0 -39
  267. package/test/Heading.test.js +0 -35
  268. package/test/InputText.test.js +0 -236
  269. package/test/Link.test.js +0 -25
  270. package/test/Paginator.test.js +0 -165
  271. package/test/ProgressBar.test.js +0 -35
  272. package/test/Radio.test.js +0 -37
  273. package/test/ResultsetTable.test.js +0 -282
  274. package/test/Select.test.js +0 -191
  275. package/test/Sidenav.test.js +0 -87
  276. package/test/Slider.test.js +0 -65
  277. package/test/Spinner.test.js +0 -27
  278. package/test/Switch.test.js +0 -45
  279. package/test/Table.test.js +0 -36
  280. package/test/Tabs.test.js +0 -88
  281. package/test/TabsForSections.test.js +0 -34
  282. package/test/Tag.test.js +0 -32
  283. package/test/TextArea.test.js +0 -52
  284. package/test/Toggle.test.js +0 -43
  285. package/test/Upload.test.js +0 -60
  286. package/test/Wizard.test.js +0 -130
  287. package/test/mocks/pngMock.js +0 -1
  288. package/test/mocks/svgMock.js +0 -1
package/tabs/Tabs.js ADDED
@@ -0,0 +1,259 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _typeof3 = require("@babel/runtime/helpers/typeof");
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
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9;
39
+
40
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
41
+
42
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
43
+
44
+ var DxcTabs = function DxcTabs(_ref) {
45
+ var activeTabIndex = _ref.activeTabIndex,
46
+ _ref$tabs = _ref.tabs,
47
+ tabs = _ref$tabs === void 0 ? [] : _ref$tabs,
48
+ onTabClick = _ref.onTabClick,
49
+ onTabHover = _ref.onTabHover,
50
+ margin = _ref.margin,
51
+ _ref$iconPosition = _ref.iconPosition,
52
+ iconPosition = _ref$iconPosition === void 0 ? "left" : _ref$iconPosition,
53
+ _ref$tabIndex = _ref.tabIndex,
54
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
55
+
56
+ var _React$useState = _react["default"].useState(0),
57
+ _React$useState2 = (0, _slicedToArray2["default"])(_React$useState, 2),
58
+ innerActiveTabIndex = _React$useState2[0],
59
+ setInnerActiveTabIndex = _React$useState2[1];
60
+
61
+ var colorsTheme = (0, _useTheme["default"])();
62
+ var hasLabelAndIcon = tabs && tabs.filter(function (tab) {
63
+ return tab.label && tab.icon;
64
+ }).length > 0;
65
+
66
+ var handleChange = function handleChange(event, newValue) {
67
+ if (activeTabIndex == null) {
68
+ setInnerActiveTabIndex(newValue);
69
+ }
70
+
71
+ if (typeof onTabClick === "function") {
72
+ onTabClick(newValue);
73
+ }
74
+ };
75
+
76
+ var getTabIndex = function getTabIndex(index, disabled) {
77
+ return (activeTabIndex === index || innerActiveTabIndex === index) && !disabled ? tabIndex : -1;
78
+ };
79
+
80
+ var getLabelForTab = function getLabelForTab(tab) {
81
+ return /*#__PURE__*/_react["default"].createElement(ParentLabelSpan, null, /*#__PURE__*/_react["default"].createElement(MainLabelContainer, {
82
+ hasBadge: tab.notificationNumber
83
+ }, /*#__PURE__*/_react["default"].createElement(TabLabelContainer, {
84
+ hasLabelAndIcon: hasLabelAndIcon,
85
+ iconPosition: iconPosition
86
+ }, tab.icon ? /*#__PURE__*/_react["default"].createElement(TabIconContainer, {
87
+ hasLabelAndIcon: hasLabelAndIcon,
88
+ iconPosition: iconPosition
89
+ }, (0, _typeof2["default"])(tab.icon) === "object" ? tab.icon : /*#__PURE__*/_react["default"].createElement(tab.icon)) : tab.iconSrc && /*#__PURE__*/_react["default"].createElement(TabIcon, {
90
+ src: tab.iconSrc
91
+ }), /*#__PURE__*/_react["default"].createElement(LabelTextContainer, null, tab.label))), tab.notificationNumber && tab.notificationNumber !== false && /*#__PURE__*/_react["default"].createElement(BadgeContainer, {
92
+ hasLabelAndIcon: hasLabelAndIcon,
93
+ iconPosition: iconPosition
94
+ }, /*#__PURE__*/_react["default"].createElement(_Badge["default"], {
95
+ notificationText: tab.notificationNumber > 99 ? "+99" : tab.notificationNumber
96
+ })));
97
+ };
98
+
99
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
100
+ theme: colorsTheme.tabs
101
+ }, /*#__PURE__*/_react["default"].createElement(DxCTabs, {
102
+ margin: margin,
103
+ hasLabelAndIcon: hasLabelAndIcon,
104
+ iconPosition: iconPosition
105
+ }, /*#__PURE__*/_react["default"].createElement(Underline, null), /*#__PURE__*/_react["default"].createElement(_Tabs["default"], {
106
+ value: activeTabIndex != null ? activeTabIndex : innerActiveTabIndex,
107
+ onChange: handleChange,
108
+ variant: "scrollable",
109
+ scrollButtons: "auto"
110
+ }, tabs.map(function (tab, i) {
111
+ var tabContent = /*#__PURE__*/_react["default"].forwardRef(function (props, ref) {
112
+ return /*#__PURE__*/_react["default"].createElement("div", (0, _extends2["default"])({
113
+ role: "button"
114
+ }, props, {
115
+ ref: ref
116
+ }));
117
+ });
118
+
119
+ return /*#__PURE__*/_react["default"].createElement(_Tab["default"], {
120
+ tabIndex: (activeTabIndex === i || innerActiveTabIndex === i) && !tab.isDisabled ? tabIndex : -1,
121
+ key: "tab".concat(i).concat(tab.label),
122
+ label: getLabelForTab(tab),
123
+ disabled: tab.isDisabled,
124
+ disableRipple: true,
125
+ onMouseEnter: function onMouseEnter() {
126
+ onTabHover(i);
127
+ },
128
+ onMouseLeave: function onMouseLeave() {
129
+ onTabHover(null);
130
+ }
131
+ });
132
+ }))));
133
+ };
134
+
135
+ var ParentLabelSpan = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n position: relative;\n"])));
136
+
137
+ var TabLabelContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: ", ";\n align-items: center;\n"])), function (props) {
138
+ return props.hasLabelAndIcon && props.iconPosition === "top" && "column" || "row";
139
+ });
140
+
141
+ var LabelTextContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])([""])));
142
+
143
+ var BadgeContainer = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n right: 0;\n top: ", ";\n width: 23px;\n height: 17px;\n"])), function (props) {
144
+ return props.hasLabelAndIcon && props.iconPosition === "top" && "0" || "5px";
145
+ });
146
+
147
+ var MainLabelContainer = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: row;\n margin-left: ", ";\n margin-right: ", ";\n"])), function (props) {
148
+ return props.hasBadge && "35px" || "unset";
149
+ }, function (props) {
150
+ return props.hasBadge && "35px" || "unset";
151
+ });
152
+
153
+ var Underline = _styledComponents["default"].div(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n left: 0px;\n bottom: 0;\n width: 100%;\n height: ", ";\n position: absolute;\n background-color: ", ";\n"])), function (props) {
154
+ return props.theme.dividerThickness;
155
+ }, function (props) {
156
+ return props.theme.dividerColor;
157
+ });
158
+
159
+ var DxCTabs = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (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: 90px;\n max-width: 360px;\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"])), function (props) {
160
+ return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
161
+ }, function (props) {
162
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
163
+ }, function (props) {
164
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
165
+ }, function (props) {
166
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
167
+ }, function (props) {
168
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
169
+ }, function (props) {
170
+ return (!props.hasLabelAndIcon || props.hasLabelAndIcon && props.iconPosition !== "top") && "48px" || "72px";
171
+ }, function (props) {
172
+ return props.theme.fontTextTransform;
173
+ }, function (props) {
174
+ return props.theme.fontFamily;
175
+ }, function (props) {
176
+ return props.theme.fontSize;
177
+ }, function (props) {
178
+ return props.theme.fontStyle;
179
+ }, function (props) {
180
+ return props.theme.fontWeight;
181
+ }, function (props) {
182
+ return (!props.hasLabelAndIcon || props.hasLabelAndIcon && props.iconPosition !== "top") && "12px 16px" || "8px 16px";
183
+ }, function (props) {
184
+ return (!props.hasLabelAndIcon || props.hasLabelAndIcon && props.iconPosition !== "top") && "48px" || "72px";
185
+ }, function (props) {
186
+ return (!props.hasLabelAndIcon || props.hasLabelAndIcon && props.iconPosition !== "top") && "48px" || "72px";
187
+ }, function (props) {
188
+ return "".concat(props.theme.hoverBackgroundColor, " !important");
189
+ }, function (props) {
190
+ return "".concat(props.theme.pressedBackgroundColor, " !important");
191
+ }, function (props) {
192
+ return "".concat(props.theme.pressedFontWeight, " !important");
193
+ }, function (props) {
194
+ return props.theme.unselectedBackgroundColor;
195
+ }, function (props) {
196
+ return props.theme.unselectedFontColor;
197
+ }, function (props) {
198
+ return props.theme.unselectedIconColor;
199
+ }, function (props) {
200
+ return props.theme.selectedBackgroundColor;
201
+ }, function (props) {
202
+ return props.theme.selectedFontColor;
203
+ }, function (props) {
204
+ return props.theme.selectedIconColor;
205
+ }, function (props) {
206
+ return props.theme.disabledFontColor;
207
+ }, function (props) {
208
+ return props.theme.disabledFontStyle;
209
+ }, function (props) {
210
+ return props.theme.disabledIconColor;
211
+ }, function (props) {
212
+ return props.theme.focusOutline;
213
+ }, function (props) {
214
+ return props.theme.selectedUnderlineColor;
215
+ }, function (props) {
216
+ return props.theme.selectedUnderlineThickness;
217
+ }, function (props) {
218
+ return props.theme.scrollButtonsWidth;
219
+ }, function (props) {
220
+ return props.theme.scrollButtonsWidth;
221
+ });
222
+
223
+ var TabIcon = _styledComponents["default"].img(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n max-height: 22px;\n max-width: 22px;\n"])));
224
+
225
+ var TabIconContainer = _styledComponents["default"].div(_templateObject9 || (_templateObject9 = (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"])), function (props) {
226
+ return props.hasLabelAndIcon && props.iconPosition === "top" && "8px" || "";
227
+ }, function (props) {
228
+ return props.hasLabelAndIcon && props.iconPosition === "left" && "12px" || "";
229
+ });
230
+
231
+ DxcTabs.propTypes = {
232
+ activeTabIndex: _propTypes["default"].number,
233
+ onTabClick: _propTypes["default"].func,
234
+ onTabHover: _propTypes["default"].func,
235
+ tabs: _propTypes["default"].arrayOf(_propTypes["default"].shape({
236
+ label: _propTypes["default"].string,
237
+ icon: _propTypes["default"].oneOfType([_propTypes["default"].element, _propTypes["default"].func]),
238
+ iconSrc: _propTypes["default"].string,
239
+ isDisabled: _propTypes["default"].bool,
240
+ notificationNumber: _propTypes["default"].oneOfType([_propTypes["default"].bool, _propTypes["default"].string, _propTypes["default"].number])
241
+ })),
242
+ margin: _propTypes["default"].oneOfType([_propTypes["default"].shape({
243
+ top: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
244
+ bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
245
+ left: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
246
+ right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
247
+ }), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))]),
248
+ iconPosition: _propTypes["default"].oneOf(["top", "left"]),
249
+ tabIndex: _propTypes["default"].number
250
+ };
251
+ DxcTabs.defaultProps = {
252
+ activeTabIndex: null,
253
+ tabs: [],
254
+ onTabClick: function onTabClick() {},
255
+ onTabHover: function onTabHover() {},
256
+ iconPosition: "top"
257
+ };
258
+ var _default = DxcTabs;
259
+ exports["default"] = _default;
@@ -0,0 +1,19 @@
1
+ type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
+ type Margin = {
3
+ top?: Space;
4
+ bottom?: Space;
5
+ left?: Space;
6
+ right?: Space;
7
+ };
8
+
9
+ type Props = {
10
+ activeTabIndex?: number;
11
+ tabs?: any;
12
+ onTabClick?: void;
13
+ onTabHover?: void;
14
+ iconPosition?: "top" | "left";
15
+ margin?: Space | Margin;
16
+ tabIndex?: number;
17
+ };
18
+
19
+ export default function DxcTabs(props: Props): JSX.Element;
package/tag/Tag.js ADDED
@@ -0,0 +1,208 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _typeof3 = require("@babel/runtime/helpers/typeof");
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 _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
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 _variables = require("../common/variables.js");
27
+
28
+ var _useTheme = _interopRequireDefault(require("../useTheme.js"));
29
+
30
+ var _Box = _interopRequireDefault(require("../box/Box"));
31
+
32
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8;
33
+
34
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
35
+
36
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
37
+
38
+ var DxcTag = function DxcTag(_ref) {
39
+ var icon = _ref.icon,
40
+ iconSrc = _ref.iconSrc,
41
+ label = _ref.label,
42
+ margin = _ref.margin,
43
+ linkHref = _ref.linkHref,
44
+ onClick = _ref.onClick,
45
+ _ref$iconBgColor = _ref.iconBgColor,
46
+ iconBgColor = _ref$iconBgColor === void 0 ? "#5f249f" : _ref$iconBgColor,
47
+ _ref$labelPosition = _ref.labelPosition,
48
+ labelPosition = _ref$labelPosition === void 0 ? "after" : _ref$labelPosition,
49
+ _ref$newWindow = _ref.newWindow,
50
+ newWindow = _ref$newWindow === void 0 ? false : _ref$newWindow,
51
+ _ref$size = _ref.size,
52
+ size = _ref$size === void 0 ? "fitContent" : _ref$size,
53
+ _ref$tabIndex = _ref.tabIndex,
54
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
55
+ var colorsTheme = (0, _useTheme["default"])();
56
+
57
+ var _useState = (0, _react.useState)(false),
58
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
59
+ isHovered = _useState2[0],
60
+ changeIsHovered = _useState2[1];
61
+
62
+ var clickHandler = function clickHandler() {
63
+ onClick && onClick();
64
+ };
65
+
66
+ var tagContent = /*#__PURE__*/_react["default"].createElement(_Box["default"], {
67
+ size: size,
68
+ shadowDepth: isHovered && (onClick || linkHref) && 2 || 1
69
+ }, /*#__PURE__*/_react["default"].createElement(TagContent, {
70
+ labelPosition: labelPosition,
71
+ size: size
72
+ }, /*#__PURE__*/_react["default"].createElement(IconContainer, {
73
+ iconBgColor: iconBgColor
74
+ }, icon ? /*#__PURE__*/_react["default"].createElement(TagIconContainer, null, (0, _typeof2["default"])(icon) === "object" ? icon : /*#__PURE__*/_react["default"].createElement(icon)) : /*#__PURE__*/_react["default"].createElement(TagIcon, {
75
+ src: iconSrc
76
+ })), size !== "small" && /*#__PURE__*/_react["default"].createElement(TagLabel, null, label)));
77
+
78
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
79
+ theme: colorsTheme.tag
80
+ }, /*#__PURE__*/_react["default"].createElement(StyledDxcTag, {
81
+ margin: margin,
82
+ onMouseEnter: function onMouseEnter() {
83
+ return changeIsHovered(true);
84
+ },
85
+ onMouseLeave: function onMouseLeave() {
86
+ return changeIsHovered(false);
87
+ },
88
+ onClick: clickHandler,
89
+ hasAction: onClick || linkHref
90
+ }, onClick ? /*#__PURE__*/_react["default"].createElement(StyledButton, {
91
+ tabIndex: tabIndex
92
+ }, tagContent) : linkHref ? /*#__PURE__*/_react["default"].createElement(StyledLink, {
93
+ tabIndex: tabIndex,
94
+ href: linkHref,
95
+ target: newWindow ? "_blank" : "_self"
96
+ }, tagContent) : tagContent));
97
+ };
98
+
99
+ var sizes = {
100
+ small: "42px",
101
+ medium: "240px",
102
+ large: "480px",
103
+ fillParent: "100%",
104
+ fitContent: "unset"
105
+ };
106
+
107
+ var calculateWidth = function calculateWidth(size) {
108
+ return sizes[size];
109
+ };
110
+
111
+ var StyledDxcTag = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n cursor: ", ";\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n"])), function (_ref2) {
112
+ var hasAction = _ref2.hasAction;
113
+ return hasAction && "pointer" || "unset";
114
+ }, function (_ref3) {
115
+ var margin = _ref3.margin;
116
+ return margin && (0, _typeof2["default"])(margin) !== "object" ? _variables.spaces[margin] : "0px";
117
+ }, function (_ref4) {
118
+ var margin = _ref4.margin;
119
+ return margin && margin.top ? _variables.spaces[margin.top] : "";
120
+ }, function (_ref5) {
121
+ var margin = _ref5.margin;
122
+ return margin && margin.right ? _variables.spaces[margin.right] : "";
123
+ }, function (_ref6) {
124
+ var margin = _ref6.margin;
125
+ return margin && margin.bottom ? _variables.spaces[margin.bottom] : "";
126
+ }, function (_ref7) {
127
+ var margin = _ref7.margin;
128
+ return margin && margin.left ? _variables.spaces[margin.left] : "";
129
+ });
130
+
131
+ var TagContent = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n align-items: center;\n flex-direction: ", ";\n width: ", ";\n height: ", ";\n"])), function (_ref8) {
132
+ var labelPosition = _ref8.labelPosition;
133
+ return labelPosition === "before" && "row-reverse" || "row";
134
+ }, function (props) {
135
+ return calculateWidth(props.size);
136
+ }, function (props) {
137
+ return props.theme.height;
138
+ });
139
+
140
+ var StyledLink = _styledComponents["default"].a(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n text-decoration: none;\n border-radius: 4px;\n\n :focus {\n outline: 2px solid ", ";\n outline-offset: 0px;\n }\n"])), function (props) {
141
+ return props.theme.focusColor;
142
+ });
143
+
144
+ var StyledButton = _styledComponents["default"].button(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n background: none;\n border-radius: 4px;\n border: none;\n padding: 0;\n cursor: pointer;\n font-family: inherit;\n\n :focus {\n outline: 2px solid ", ";\n }\n"])), function (props) {
145
+ return props.theme.focusColor;
146
+ });
147
+
148
+ var TagIcon = _styledComponents["default"].img(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n justify-content: center;\n align-items: center;\n overflow: hidden;\n width: ", ";\n height: ", ";\n"])), function (props) {
149
+ return props.theme.iconWidth;
150
+ }, function (props) {
151
+ return props.theme.iconHeight;
152
+ });
153
+
154
+ var TagIconContainer = _styledComponents["default"].div(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n justify-content: center;\n align-items: center;\n overflow: hidden;\n\n img,\n svg {\n width: ", ";\n height: ", ";\n }\n"])), function (props) {
155
+ return props.theme.iconWidth;
156
+ }, function (props) {
157
+ return props.theme.iconHeight;
158
+ });
159
+
160
+ var IconContainer = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n background: ", ";\n width: ", ";\n height: 100%;\n justify-content: center;\n align-items: center;\n color: ", ";\n"])), function (_ref9) {
161
+ var iconBgColor = _ref9.iconBgColor;
162
+ return iconBgColor;
163
+ }, function (props) {
164
+ return props.theme.iconSectionWidth;
165
+ }, function (props) {
166
+ return props.theme.iconColor;
167
+ });
168
+
169
+ var TagLabel = _styledComponents["default"].div(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n color: ", ";\n padding-top: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n padding-right: ", ";\n flex-grow: 1;\n text-align: center;\n text-overflow: ellipsis;\n overflow: hidden;\n white-space: nowrap;\n"])), function (props) {
170
+ return props.theme.fontFamily;
171
+ }, function (props) {
172
+ return props.theme.fontSize;
173
+ }, function (props) {
174
+ return props.theme.fontStyle;
175
+ }, function (props) {
176
+ return props.theme.fontWeight;
177
+ }, function (props) {
178
+ return props.theme.fontColor;
179
+ }, function (props) {
180
+ return props.theme.labelPaddingTop;
181
+ }, function (props) {
182
+ return props.theme.labelPaddingBottom;
183
+ }, function (props) {
184
+ return props.theme.labelPaddingLeft;
185
+ }, function (props) {
186
+ return props.theme.labelPaddingRight;
187
+ });
188
+
189
+ DxcTag.propTypes = {
190
+ size: _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(sizes))),
191
+ icon: _propTypes["default"].oneOfType([_propTypes["default"].element, _propTypes["default"].func]),
192
+ iconSrc: _propTypes["default"].string,
193
+ iconBgColor: _propTypes["default"].string,
194
+ label: _propTypes["default"].string,
195
+ labelPosition: _propTypes["default"].oneOf(["before", "after"]),
196
+ linkHref: _propTypes["default"].string,
197
+ onClick: _propTypes["default"].func,
198
+ newWindow: _propTypes["default"].bool,
199
+ margin: _propTypes["default"].oneOfType([_propTypes["default"].shape({
200
+ top: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
201
+ bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
202
+ left: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
203
+ right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
204
+ }), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))]),
205
+ tabIndex: _propTypes["default"].number
206
+ };
207
+ var _default = DxcTag;
208
+ exports["default"] = _default;
package/tag/index.d.ts ADDED
@@ -0,0 +1,24 @@
1
+ type Size = "small" | "medium" | "large" | "fillParent" | "fitContent";
2
+ type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ type Margin = {
4
+ top?: Space;
5
+ bottom?: Space;
6
+ left?: Space;
7
+ right?: Space;
8
+ };
9
+
10
+ type Props = {
11
+ icon?: any;
12
+ iconSrc?: string;
13
+ label?: string;
14
+ linkHref?: string;
15
+ onClick?: void,
16
+ iconBgColor?: string;
17
+ labelPosition?: "before" | "after";
18
+ newWindow?: boolean;
19
+ margin?: Space | Margin;
20
+ size?: Size;
21
+ tabIndex?: number;
22
+ };
23
+
24
+ export default function DxcTag(props: Props): JSX.Element;