@dxc-technology/halstack-react 0.0.0-cd617f3 → 0.0.0-cedf067

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 (332) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +1 -4
  3. package/HalstackContext.d.ts +12 -0
  4. package/HalstackContext.js +295 -0
  5. package/accordion/Accordion.d.ts +1 -1
  6. package/accordion/Accordion.js +15 -47
  7. package/accordion/Accordion.stories.tsx +307 -0
  8. package/accordion/Accordion.test.js +72 -0
  9. package/accordion/types.d.ts +8 -8
  10. package/accordion-group/AccordionGroup.d.ts +1 -1
  11. package/accordion-group/AccordionGroup.js +16 -17
  12. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  13. package/accordion-group/AccordionGroup.test.js +151 -0
  14. package/accordion-group/types.d.ts +8 -8
  15. package/alert/Alert.js +6 -3
  16. package/alert/Alert.stories.tsx +170 -0
  17. package/alert/Alert.test.js +92 -0
  18. package/alert/types.d.ts +1 -1
  19. package/badge/Badge.d.ts +4 -0
  20. package/badge/Badge.js +6 -4
  21. package/badge/types.d.ts +5 -0
  22. package/{radio → badge}/types.js +0 -0
  23. package/bleed/Bleed.d.ts +3 -0
  24. package/bleed/Bleed.js +51 -0
  25. package/bleed/Bleed.stories.tsx +341 -0
  26. package/bleed/types.d.ts +37 -0
  27. package/bleed/types.js +5 -0
  28. package/box/Box.d.ts +4 -0
  29. package/box/Box.js +28 -64
  30. package/box/Box.stories.tsx +132 -0
  31. package/box/Box.test.js +18 -0
  32. package/box/types.d.ts +43 -0
  33. package/box/types.js +5 -0
  34. package/bulleted-list/BulletedList.d.ts +7 -0
  35. package/bulleted-list/BulletedList.js +123 -0
  36. package/bulleted-list/BulletedList.stories.tsx +200 -0
  37. package/bulleted-list/types.d.ts +11 -0
  38. package/bulleted-list/types.js +5 -0
  39. package/button/Button.d.ts +1 -1
  40. package/button/Button.js +61 -87
  41. package/button/Button.stories.tsx +232 -242
  42. package/button/Button.test.js +35 -0
  43. package/button/types.d.ts +14 -18
  44. package/card/Card.d.ts +4 -0
  45. package/card/Card.js +38 -77
  46. package/card/Card.stories.tsx +201 -0
  47. package/card/Card.test.js +50 -0
  48. package/card/ice-cream.jpg +0 -0
  49. package/card/types.d.ts +67 -0
  50. package/card/types.js +5 -0
  51. package/checkbox/Checkbox.d.ts +1 -1
  52. package/checkbox/Checkbox.js +45 -41
  53. package/checkbox/Checkbox.stories.tsx +188 -0
  54. package/checkbox/Checkbox.test.js +78 -0
  55. package/checkbox/types.d.ts +9 -6
  56. package/chip/Chip.d.ts +4 -0
  57. package/chip/Chip.js +16 -76
  58. package/chip/Chip.stories.tsx +119 -0
  59. package/chip/Chip.test.js +56 -0
  60. package/chip/types.d.ts +45 -0
  61. package/chip/types.js +5 -0
  62. package/common/variables.js +301 -373
  63. package/date-input/DateInput.js +63 -52
  64. package/date-input/DateInput.stories.tsx +138 -0
  65. package/date-input/DateInput.test.js +479 -0
  66. package/date-input/types.d.ts +16 -9
  67. package/dialog/Dialog.d.ts +4 -0
  68. package/dialog/Dialog.js +10 -56
  69. package/dialog/Dialog.stories.tsx +212 -0
  70. package/dialog/Dialog.test.js +40 -0
  71. package/dialog/types.d.ts +43 -0
  72. package/dialog/types.js +5 -0
  73. package/dropdown/Dropdown.d.ts +4 -0
  74. package/dropdown/Dropdown.js +28 -87
  75. package/dropdown/Dropdown.stories.tsx +249 -0
  76. package/dropdown/Dropdown.test.js +189 -0
  77. package/dropdown/types.d.ts +80 -0
  78. package/dropdown/types.js +5 -0
  79. package/file-input/FileInput.d.ts +4 -0
  80. package/file-input/FileInput.js +172 -111
  81. package/file-input/FileInput.stories.tsx +507 -0
  82. package/file-input/FileInput.test.js +457 -0
  83. package/file-input/FileItem.d.ts +14 -0
  84. package/file-input/FileItem.js +16 -23
  85. package/file-input/types.d.ts +112 -0
  86. package/file-input/types.js +5 -0
  87. package/flex/Flex.d.ts +4 -0
  88. package/flex/Flex.js +57 -0
  89. package/flex/Flex.stories.tsx +103 -0
  90. package/flex/types.d.ts +21 -0
  91. package/flex/types.js +5 -0
  92. package/footer/Footer.d.ts +4 -0
  93. package/footer/Footer.js +36 -148
  94. package/footer/Footer.stories.tsx +130 -0
  95. package/footer/Footer.test.js +109 -0
  96. package/footer/Icons.d.ts +2 -0
  97. package/footer/Icons.js +4 -4
  98. package/footer/types.d.ts +65 -0
  99. package/footer/types.js +5 -0
  100. package/header/Header.d.ts +7 -0
  101. package/header/Header.js +55 -78
  102. package/header/Header.stories.tsx +172 -0
  103. package/header/Header.test.js +79 -0
  104. package/header/Icons.d.ts +2 -0
  105. package/header/Icons.js +2 -27
  106. package/header/types.d.ts +47 -0
  107. package/header/types.js +5 -0
  108. package/heading/Heading.d.ts +4 -0
  109. package/heading/Heading.js +7 -24
  110. package/heading/Heading.stories.tsx +54 -0
  111. package/heading/Heading.test.js +186 -0
  112. package/heading/types.d.ts +33 -0
  113. package/heading/types.js +5 -0
  114. package/inset/Inset.d.ts +3 -0
  115. package/inset/Inset.js +51 -0
  116. package/inset/Inset.stories.tsx +229 -0
  117. package/inset/types.d.ts +37 -0
  118. package/inset/types.js +5 -0
  119. package/layout/ApplicationLayout.d.ts +20 -0
  120. package/layout/ApplicationLayout.js +71 -135
  121. package/layout/ApplicationLayout.stories.tsx +161 -0
  122. package/layout/Icons.d.ts +5 -0
  123. package/layout/Icons.js +13 -2
  124. package/layout/SidenavContext.d.ts +5 -0
  125. package/layout/SidenavContext.js +19 -0
  126. package/layout/types.d.ts +42 -0
  127. package/layout/types.js +5 -0
  128. package/link/Link.d.ts +4 -0
  129. package/link/Link.js +60 -107
  130. package/link/Link.stories.tsx +193 -0
  131. package/link/Link.test.js +83 -0
  132. package/link/types.d.ts +54 -0
  133. package/link/types.js +5 -0
  134. package/main.d.ts +12 -12
  135. package/main.js +64 -58
  136. package/number-input/NumberInput.d.ts +4 -0
  137. package/number-input/NumberInput.js +16 -68
  138. package/number-input/NumberInput.stories.tsx +115 -0
  139. package/number-input/NumberInput.test.js +506 -0
  140. package/number-input/NumberInputContext.d.ts +4 -0
  141. package/number-input/NumberInputContext.js +5 -2
  142. package/number-input/numberInputContextTypes.d.ts +19 -0
  143. package/number-input/numberInputContextTypes.js +5 -0
  144. package/number-input/types.d.ts +124 -0
  145. package/number-input/types.js +5 -0
  146. package/package.json +10 -6
  147. package/paginator/Paginator.js +19 -46
  148. package/paginator/Paginator.stories.tsx +63 -0
  149. package/paginator/Paginator.test.js +308 -0
  150. package/paragraph/Paragraph.d.ts +6 -0
  151. package/paragraph/Paragraph.js +38 -0
  152. package/paragraph/Paragraph.stories.tsx +44 -0
  153. package/password-input/PasswordInput.d.ts +4 -0
  154. package/password-input/PasswordInput.js +22 -55
  155. package/password-input/{PasswordInput.stories.jsx → PasswordInput.stories.tsx} +4 -4
  156. package/password-input/PasswordInput.test.js +180 -0
  157. package/password-input/types.d.ts +110 -0
  158. package/password-input/types.js +5 -0
  159. package/progress-bar/ProgressBar.d.ts +4 -0
  160. package/progress-bar/ProgressBar.js +64 -71
  161. package/progress-bar/ProgressBar.stories.jsx +60 -0
  162. package/progress-bar/ProgressBar.test.js +110 -0
  163. package/progress-bar/types.d.ts +36 -0
  164. package/progress-bar/types.js +5 -0
  165. package/quick-nav/QuickNav.d.ts +4 -0
  166. package/quick-nav/QuickNav.js +118 -0
  167. package/quick-nav/QuickNav.stories.tsx +264 -0
  168. package/quick-nav/types.d.ts +21 -0
  169. package/quick-nav/types.js +5 -0
  170. package/radio-group/Radio.d.ts +4 -0
  171. package/radio-group/Radio.js +141 -0
  172. package/radio-group/RadioGroup.d.ts +4 -0
  173. package/radio-group/RadioGroup.js +283 -0
  174. package/radio-group/RadioGroup.stories.tsx +100 -0
  175. package/radio-group/RadioGroup.test.js +695 -0
  176. package/radio-group/types.d.ts +114 -0
  177. package/radio-group/types.js +5 -0
  178. package/resultsetTable/ResultsetTable.d.ts +4 -0
  179. package/resultsetTable/ResultsetTable.js +9 -29
  180. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  181. package/resultsetTable/ResultsetTable.test.js +348 -0
  182. package/resultsetTable/types.d.ts +67 -0
  183. package/resultsetTable/types.js +5 -0
  184. package/select/Icons.d.ts +10 -0
  185. package/select/Icons.js +93 -0
  186. package/select/Listbox.d.ts +4 -0
  187. package/select/Listbox.js +199 -0
  188. package/select/Option.d.ts +4 -0
  189. package/select/Option.js +110 -0
  190. package/select/Select.d.ts +4 -0
  191. package/select/Select.js +158 -380
  192. package/select/Select.stories.tsx +627 -0
  193. package/select/Select.test.js +2175 -0
  194. package/select/types.d.ts +210 -0
  195. package/select/types.js +5 -0
  196. package/sidenav/Sidenav.d.ts +10 -0
  197. package/sidenav/Sidenav.js +186 -63
  198. package/sidenav/Sidenav.stories.tsx +180 -0
  199. package/sidenav/Sidenav.test.js +44 -0
  200. package/sidenav/types.d.ts +73 -0
  201. package/sidenav/types.js +5 -0
  202. package/slider/Slider.d.ts +4 -0
  203. package/slider/Slider.js +63 -85
  204. package/slider/Slider.stories.tsx +177 -0
  205. package/slider/Slider.test.js +150 -0
  206. package/slider/types.d.ts +82 -0
  207. package/slider/types.js +5 -0
  208. package/spinner/Spinner.d.ts +4 -0
  209. package/spinner/Spinner.js +9 -26
  210. package/spinner/Spinner.stories.jsx +103 -0
  211. package/spinner/Spinner.test.js +64 -0
  212. package/spinner/types.d.ts +32 -0
  213. package/spinner/types.js +5 -0
  214. package/switch/Switch.d.ts +1 -1
  215. package/switch/Switch.js +37 -21
  216. package/switch/Switch.stories.tsx +160 -0
  217. package/switch/Switch.test.js +98 -0
  218. package/switch/types.d.ts +6 -2
  219. package/table/Table.d.ts +4 -0
  220. package/table/Table.js +3 -3
  221. package/table/Table.stories.jsx +277 -0
  222. package/table/Table.test.js +26 -0
  223. package/table/types.d.ts +21 -0
  224. package/table/types.js +5 -0
  225. package/tabs/Tabs.d.ts +4 -0
  226. package/tabs/Tabs.js +24 -72
  227. package/tabs/Tabs.stories.tsx +112 -0
  228. package/tabs/Tabs.test.js +140 -0
  229. package/tabs/types.d.ts +82 -0
  230. package/tabs/types.js +5 -0
  231. package/tabs-nav/NavTabs.d.ts +8 -0
  232. package/tabs-nav/NavTabs.js +125 -0
  233. package/tabs-nav/NavTabs.stories.tsx +170 -0
  234. package/tabs-nav/NavTabs.test.js +82 -0
  235. package/tabs-nav/Tab.d.ts +4 -0
  236. package/tabs-nav/Tab.js +132 -0
  237. package/tabs-nav/types.d.ts +53 -0
  238. package/tabs-nav/types.js +5 -0
  239. package/tag/Tag.d.ts +4 -0
  240. package/tag/Tag.js +34 -59
  241. package/tag/Tag.stories.tsx +142 -0
  242. package/tag/Tag.test.js +60 -0
  243. package/tag/types.d.ts +69 -0
  244. package/tag/types.js +5 -0
  245. package/text-input/Suggestion.d.ts +4 -0
  246. package/text-input/Suggestion.js +55 -0
  247. package/text-input/TextInput.d.ts +4 -0
  248. package/text-input/TextInput.js +91 -146
  249. package/text-input/TextInput.stories.tsx +474 -0
  250. package/text-input/TextInput.test.js +1712 -0
  251. package/text-input/types.d.ts +178 -0
  252. package/text-input/types.js +5 -0
  253. package/textarea/Textarea.d.ts +4 -0
  254. package/textarea/Textarea.js +39 -79
  255. package/textarea/Textarea.stories.jsx +157 -0
  256. package/textarea/Textarea.test.js +437 -0
  257. package/textarea/types.d.ts +137 -0
  258. package/textarea/types.js +5 -0
  259. package/toggle-group/ToggleGroup.d.ts +4 -0
  260. package/toggle-group/ToggleGroup.js +18 -46
  261. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  262. package/toggle-group/ToggleGroup.test.js +156 -0
  263. package/toggle-group/types.d.ts +105 -0
  264. package/toggle-group/types.js +5 -0
  265. package/typography/Typography.d.ts +4 -0
  266. package/typography/Typography.js +131 -0
  267. package/typography/Typography.stories.tsx +198 -0
  268. package/typography/types.d.ts +18 -0
  269. package/typography/types.js +5 -0
  270. package/useTheme.d.ts +2 -0
  271. package/useTheme.js +2 -2
  272. package/useTranslatedLabels.d.ts +2 -0
  273. package/useTranslatedLabels.js +20 -0
  274. package/wizard/Wizard.d.ts +4 -0
  275. package/wizard/Wizard.js +118 -104
  276. package/wizard/Wizard.stories.tsx +233 -0
  277. package/wizard/Wizard.test.js +141 -0
  278. package/wizard/types.d.ts +65 -0
  279. package/wizard/types.js +5 -0
  280. package/ThemeContext.js +0 -246
  281. package/V3Select/V3Select.js +0 -455
  282. package/V3Select/index.d.ts +0 -27
  283. package/V3Textarea/V3Textarea.js +0 -260
  284. package/V3Textarea/index.d.ts +0 -27
  285. package/box/index.d.ts +0 -25
  286. package/card/index.d.ts +0 -22
  287. package/chip/index.d.ts +0 -22
  288. package/date/Date.js +0 -373
  289. package/date/index.d.ts +0 -27
  290. package/dialog/index.d.ts +0 -18
  291. package/dropdown/index.d.ts +0 -26
  292. package/file-input/index.d.ts +0 -81
  293. package/footer/index.d.ts +0 -25
  294. package/header/index.d.ts +0 -25
  295. package/heading/index.d.ts +0 -17
  296. package/input-text/Icons.js +0 -22
  297. package/input-text/InputText.js +0 -611
  298. package/input-text/index.d.ts +0 -36
  299. package/link/index.d.ts +0 -23
  300. package/number-input/index.d.ts +0 -113
  301. package/password-input/index.d.ts +0 -94
  302. package/progress-bar/index.d.ts +0 -18
  303. package/radio/Radio.d.ts +0 -4
  304. package/radio/Radio.js +0 -174
  305. package/radio/types.d.ts +0 -54
  306. package/resultsetTable/index.d.ts +0 -19
  307. package/select/index.d.ts +0 -131
  308. package/sidenav/index.d.ts +0 -13
  309. package/slider/index.d.ts +0 -29
  310. package/spinner/index.d.ts +0 -17
  311. package/table/index.d.ts +0 -13
  312. package/tabs/index.d.ts +0 -19
  313. package/tag/index.d.ts +0 -24
  314. package/text-input/index.d.ts +0 -135
  315. package/textarea/index.d.ts +0 -117
  316. package/toggle/Toggle.js +0 -186
  317. package/toggle/index.d.ts +0 -21
  318. package/toggle-group/index.d.ts +0 -21
  319. package/upload/Upload.js +0 -201
  320. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  321. package/upload/buttons-upload/Icons.js +0 -40
  322. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  323. package/upload/dragAndDropArea/Icons.js +0 -39
  324. package/upload/file-upload/FileToUpload.js +0 -115
  325. package/upload/file-upload/Icons.js +0 -66
  326. package/upload/files-upload/FilesToUpload.js +0 -109
  327. package/upload/index.d.ts +0 -15
  328. package/upload/transaction/Icons.js +0 -160
  329. package/upload/transaction/Transaction.js +0 -104
  330. package/upload/transactions/Transactions.js +0 -94
  331. package/wizard/Icons.js +0 -65
  332. package/wizard/index.d.ts +0 -18
@@ -0,0 +1,140 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _react = _interopRequireDefault(require("react"));
6
+
7
+ var _react2 = require("@testing-library/react");
8
+
9
+ var _Tabs = _interopRequireDefault(require("./Tabs"));
10
+
11
+ var sampleTabs = [{
12
+ label: "Tab-1"
13
+ }, {
14
+ label: "Tab-2"
15
+ }, {
16
+ label: "Tab-3"
17
+ }];
18
+ var sampleTabsWithBadge = [{
19
+ label: "Tab-1",
20
+ notificationNumber: "10"
21
+ }, {
22
+ label: "Tab-2",
23
+ notificationNumber: "20"
24
+ }, {
25
+ label: "Tab-3",
26
+ notificationNumber: "101"
27
+ }];
28
+ describe("Tabs component tests", function () {
29
+ test("Tabs render with correct labels", function () {
30
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tabs["default"], {
31
+ tabs: sampleTabs
32
+ })),
33
+ getByText = _render.getByText,
34
+ getAllByRole = _render.getAllByRole;
35
+
36
+ var tabs = getAllByRole("tab");
37
+ expect(getByText("Tab-1")).toBeTruthy();
38
+ expect(getByText("Tab-2")).toBeTruthy();
39
+ expect(getByText("Tab-3")).toBeTruthy();
40
+ expect(tabs[0].getAttribute("aria-selected")).toBe("true");
41
+ expect(tabs[1].getAttribute("aria-selected")).toBe("false");
42
+ expect(tabs[2].getAttribute("aria-selected")).toBe("false");
43
+ });
44
+ test("Tabs render with correct labels and badges", function () {
45
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tabs["default"], {
46
+ tabs: sampleTabsWithBadge
47
+ })),
48
+ getByText = _render2.getByText;
49
+
50
+ expect(getByText("10")).toBeTruthy();
51
+ expect(getByText("20")).toBeTruthy();
52
+ expect(getByText("+99")).toBeTruthy();
53
+ });
54
+ test("Tabs render with an initially active tab", function () {
55
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tabs["default"], {
56
+ defaultActiveTabIndex: 2,
57
+ tabs: sampleTabsWithBadge
58
+ })),
59
+ getAllByRole = _render3.getAllByRole;
60
+
61
+ var tabs = getAllByRole("tab");
62
+ expect(tabs[0].getAttribute("aria-selected")).toBe("false");
63
+ expect(tabs[1].getAttribute("aria-selected")).toBe("false");
64
+ expect(tabs[2].getAttribute("aria-selected")).toBe("true");
65
+ });
66
+ test("Tabs render with correct icons", function () {
67
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tabs["default"], {
68
+ tabs: [{
69
+ label: "Tab-1",
70
+ icon: "/testIcon1.png"
71
+ }, {
72
+ label: "Tab-2",
73
+ icon: "/testIcon2.png"
74
+ }, {
75
+ label: "Tab-3",
76
+ icon: "/testIcon3.png"
77
+ }]
78
+ })),
79
+ getAllByRole = _render4.getAllByRole;
80
+
81
+ expect(getAllByRole("img")[0].getAttribute("src")).toBe("/testIcon1.png");
82
+ expect(getAllByRole("img")[1].getAttribute("src")).toBe("/testIcon2.png");
83
+ expect(getAllByRole("img")[2].getAttribute("src")).toBe("/testIcon3.png");
84
+ });
85
+ test("Tabs render with disabled tab", function () {
86
+ var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tabs["default"], {
87
+ tabs: [{
88
+ label: "Tab-1",
89
+ isDisabled: true
90
+ }, {
91
+ label: "Tab-2"
92
+ }]
93
+ })),
94
+ getAllByRole = _render5.getAllByRole;
95
+
96
+ expect(getAllByRole("tab")[0].hasAttribute("disabled")).toBeTruthy();
97
+ expect(getAllByRole("tab")[1].hasAttribute("disabled")).toBeFalsy();
98
+ });
99
+ test("Uncontrolled tabs", function () {
100
+ var onTabClick = jest.fn();
101
+
102
+ var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tabs["default"], {
103
+ tabs: sampleTabs,
104
+ onTabClick: onTabClick
105
+ })),
106
+ getByText = _render6.getByText;
107
+
108
+ var tab1 = getByText("Tab-1");
109
+ var tab2 = getByText("Tab-2");
110
+
111
+ _react2.fireEvent.click(tab2);
112
+
113
+ expect(onTabClick).toHaveBeenCalledWith(1);
114
+
115
+ _react2.fireEvent.click(tab1);
116
+
117
+ expect(onTabClick).toHaveBeenCalledWith(0);
118
+ });
119
+ test("Controlled tabs", function () {
120
+ var onTabClick = jest.fn();
121
+
122
+ var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tabs["default"], {
123
+ tabs: sampleTabs,
124
+ onTabClick: onTabClick,
125
+ activeTabIndex: 0
126
+ })),
127
+ getByText = _render7.getByText;
128
+
129
+ var tab2 = getByText("Tab-2");
130
+ var tab3 = getByText("Tab-3");
131
+
132
+ _react2.fireEvent.click(tab2);
133
+
134
+ expect(onTabClick).toHaveBeenCalledWith(1);
135
+
136
+ _react2.fireEvent.click(tab3);
137
+
138
+ expect(onTabClick).toHaveBeenCalledWith(2);
139
+ });
140
+ });
@@ -0,0 +1,82 @@
1
+ /// <reference types="react" />
2
+ declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ declare type Margin = {
4
+ top?: Space;
5
+ bottom?: Space;
6
+ left?: Space;
7
+ right?: Space;
8
+ };
9
+ declare type SVG = React.SVGProps<SVGSVGElement>;
10
+ declare type TabCommonProps = {
11
+ /**
12
+ * Whether the tab is disabled or not.
13
+ */
14
+ isDisabled?: boolean;
15
+ /**
16
+ * If the value is 'true', an empty badge will appear.
17
+ * If it is 'false', no badge will appear.
18
+ * If a number is put it will be shown as the label of the notification
19
+ * in the tab, taking into account that if that number is greater than 99,
20
+ * it will appear as '+99' in the badge.
21
+ */
22
+ notificationNumber?: boolean | number;
23
+ };
24
+ declare type TabLabelProps = TabCommonProps & {
25
+ /**
26
+ * Tab label.
27
+ */
28
+ label: string;
29
+ /**
30
+ * Element or path used as the icon that will be displayed in the tab.
31
+ */
32
+ icon?: string | SVG;
33
+ };
34
+ declare type TabIconProps = TabCommonProps & {
35
+ /**
36
+ * Tab label.
37
+ */
38
+ label?: string;
39
+ /**
40
+ * Element or path used as the icon that will be displayed in the tab.
41
+ */
42
+ icon: string | SVG;
43
+ };
44
+ declare type Props = {
45
+ /**
46
+ * An array of objects representing the tabs.
47
+ */
48
+ tabs: (TabLabelProps | TabIconProps)[];
49
+ /**
50
+ * Whether the icon should appear above or to the left of the label.
51
+ */
52
+ iconPosition?: "top" | "left";
53
+ /**
54
+ * Initially active tab, only when it is uncontrolled.
55
+ */
56
+ defaultActiveTabIndex?: number;
57
+ /**
58
+ * The index of the active tab. If undefined, the component will be
59
+ * uncontrolled and the active tab will be managed internally by the component.
60
+ */
61
+ activeTabIndex?: number;
62
+ /**
63
+ * This function will be called when the user clicks on a tab. The index of the
64
+ * clicked tab will be passed as a parameter.
65
+ */
66
+ onTabClick?: (tabIndex: number) => void;
67
+ /**
68
+ * This function will be called when the user hovers a tab.The index of the
69
+ * hovered tab will be passed as a parameter.
70
+ */
71
+ onTabHover?: (tabIndex: number) => void;
72
+ /**
73
+ * Size of the margin to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
74
+ * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
75
+ */
76
+ margin?: Space | Margin;
77
+ /**
78
+ * Value of the tabindex for each tab.
79
+ */
80
+ tabIndex?: number;
81
+ };
82
+ export default Props;
package/tabs/types.js ADDED
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
@@ -0,0 +1,8 @@
1
+ import React from "react";
2
+ import { NavTabsContextProps, NavTabsProps } from "./types";
3
+ export declare const NavTabsContext: React.Context<NavTabsContextProps>;
4
+ declare const DxcNavTabs: {
5
+ ({ iconPosition, tabIndex, children }: NavTabsProps): JSX.Element;
6
+ Tab: React.ForwardRefExoticComponent<import("./types").TabProps & React.RefAttributes<HTMLAnchorElement>>;
7
+ };
8
+ export default DxcNavTabs;
@@ -0,0 +1,125 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _typeof = require("@babel/runtime/helpers/typeof");
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports["default"] = exports.NavTabsContext = void 0;
11
+
12
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
+
14
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
15
+
16
+ var _react = _interopRequireWildcard(require("react"));
17
+
18
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
19
+
20
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
21
+
22
+ var _Tab = _interopRequireDefault(require("./Tab"));
23
+
24
+ var _templateObject;
25
+
26
+ 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); }
27
+
28
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(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; }
29
+
30
+ var NavTabsContext = /*#__PURE__*/(0, _react.createContext)(null);
31
+ exports.NavTabsContext = NavTabsContext;
32
+
33
+ var getPropInChild = function getPropInChild(child, propName) {
34
+ return child.props ? child.props[propName] ? child.props[propName] : child.props.children ? getPropInChild(child.props.children, propName) : undefined : undefined;
35
+ };
36
+
37
+ var getLabelFromTab = function getLabelFromTab(child) {
38
+ if (typeof child === "string") {
39
+ return child.toString();
40
+ } else if (child.props.children) {
41
+ return Array.isArray(child.props.children) ? getLabelFromTab(child.props.children[0]) : getLabelFromTab(child.props.children);
42
+ }
43
+ };
44
+
45
+ var getPreviousTabIndex = function getPreviousTabIndex(array, initialIndex) {
46
+ var index = initialIndex === 0 ? array.length - 1 : initialIndex - 1;
47
+
48
+ while (getPropInChild(array[index], "disabled")) {
49
+ index = index === 0 ? array.length - 1 : index - 1;
50
+ }
51
+
52
+ return index;
53
+ };
54
+
55
+ var getNextTabIndex = function getNextTabIndex(array, initialIndex) {
56
+ var index = initialIndex === array.length - 1 ? 0 : initialIndex + 1;
57
+
58
+ while (getPropInChild(array[index], "disabled")) {
59
+ index = index === array.length - 1 ? 0 : index + 1;
60
+ }
61
+
62
+ return index;
63
+ };
64
+
65
+ var DxcNavTabs = function DxcNavTabs(_ref) {
66
+ var _ref$iconPosition = _ref.iconPosition,
67
+ iconPosition = _ref$iconPosition === void 0 ? "top" : _ref$iconPosition,
68
+ _ref$tabIndex = _ref.tabIndex,
69
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex,
70
+ children = _ref.children;
71
+ var colorsTheme = (0, _useTheme["default"])();
72
+
73
+ var _useState = (0, _react.useState)(null),
74
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
75
+ innerFocus = _useState2[0],
76
+ setInnerFocus = _useState2[1];
77
+
78
+ var contextValue = (0, _react.useMemo)(function () {
79
+ return {
80
+ iconPosition: iconPosition,
81
+ tabIndex: tabIndex,
82
+ hasIcons: _react["default"].Children.toArray(children).some(function (child) {
83
+ return getPropInChild(child, "icon");
84
+ }),
85
+ focusedLabel: innerFocus === null ? undefined : getLabelFromTab(children[innerFocus])
86
+ };
87
+ }, [iconPosition, tabIndex, innerFocus]);
88
+
89
+ var handleOnKeyDown = function handleOnKeyDown(event) {
90
+ var activeTab = _react["default"].Children.toArray(children).findIndex(function (child) {
91
+ return getPropInChild(child, "active");
92
+ });
93
+
94
+ switch (event.keyCode) {
95
+ case 37:
96
+ // arrow left
97
+ event.preventDefault();
98
+ setInnerFocus(getPreviousTabIndex(children, innerFocus === null ? activeTab : innerFocus));
99
+ break;
100
+
101
+ case 39:
102
+ // arrow right
103
+ event.preventDefault();
104
+ setInnerFocus(getNextTabIndex(children, innerFocus === null ? activeTab : innerFocus));
105
+ break;
106
+ }
107
+ };
108
+
109
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
110
+ theme: colorsTheme.tabs
111
+ }, /*#__PURE__*/_react["default"].createElement(NavTabsContainer, {
112
+ onKeyDown: handleOnKeyDown,
113
+ role: "tablist",
114
+ "aria-label": "Navigation tabs"
115
+ }, /*#__PURE__*/_react["default"].createElement(NavTabsContext.Provider, {
116
+ value: contextValue
117
+ }, children)));
118
+ };
119
+
120
+ DxcNavTabs.Tab = _Tab["default"];
121
+
122
+ var NavTabsContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n"])));
123
+
124
+ var _default = DxcNavTabs;
125
+ exports["default"] = _default;
@@ -0,0 +1,170 @@
1
+ import React from "react";
2
+ import DxcNavTabs from "./NavTabs";
3
+ import Title from "../../.storybook/components/Title";
4
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
5
+
6
+ export default {
7
+ title: "NavTabs",
8
+ component: DxcNavTabs,
9
+ };
10
+
11
+ const iconSVG = (
12
+ <svg viewBox="0 0 24 24" fill="currentColor">
13
+ <path d="M0 0h24v24H0z" fill="none" />
14
+ <path d="M12 21.35l-1.45-1.32C5.4 15.36 2 12.28 2 8.5 2 5.42 4.42 3 7.5 3c1.74 0 3.41.81 4.5 2.09C13.09 3.81 14.76 3 16.5 3 19.58 3 22 5.42 22 8.5c0 3.78-3.4 6.86-8.55 11.54L12 21.35z" />
15
+ </svg>
16
+ );
17
+
18
+ export const Chromatic = () => (
19
+ <>
20
+ <ExampleContainer>
21
+ <Title title="Only label" theme="light" level={4} />
22
+ <DxcNavTabs>
23
+ <DxcNavTabs.Tab href="#" active>
24
+ Tab 1
25
+ </DxcNavTabs.Tab>
26
+ <DxcNavTabs.Tab href="#" disabled>
27
+ Tab 2
28
+ </DxcNavTabs.Tab>
29
+ <DxcNavTabs.Tab href="#">Tab 3</DxcNavTabs.Tab>
30
+ <DxcNavTabs.Tab href="#">Tab 4</DxcNavTabs.Tab>
31
+ </DxcNavTabs>
32
+ </ExampleContainer>
33
+ <ExampleContainer pseudoState="pseudo-hover">
34
+ <Title title="Hovered tabs" theme="light" level={4} />
35
+ <DxcNavTabs>
36
+ <DxcNavTabs.Tab href="#" active>
37
+ Tab 1
38
+ </DxcNavTabs.Tab>
39
+ <DxcNavTabs.Tab href="#" disabled>
40
+ Tab 2
41
+ </DxcNavTabs.Tab>
42
+ <DxcNavTabs.Tab href="#">Tab 3</DxcNavTabs.Tab>
43
+ <DxcNavTabs.Tab href="#">Tab 4</DxcNavTabs.Tab>
44
+ </DxcNavTabs>
45
+ </ExampleContainer>
46
+ <ExampleContainer pseudoState="pseudo-focus">
47
+ <Title title="Focused tabs" theme="light" level={4} />
48
+ <DxcNavTabs>
49
+ <DxcNavTabs.Tab href="#" active>
50
+ Tab 1
51
+ </DxcNavTabs.Tab>
52
+ <DxcNavTabs.Tab href="#" disabled>
53
+ Tab 2
54
+ </DxcNavTabs.Tab>
55
+ <DxcNavTabs.Tab href="#">Tab 3</DxcNavTabs.Tab>
56
+ <DxcNavTabs.Tab href="#">Tab 4</DxcNavTabs.Tab>
57
+ </DxcNavTabs>
58
+ </ExampleContainer>
59
+ <ExampleContainer pseudoState="pseudo-active">
60
+ <Title title="Actived tabs" theme="light" level={4} />
61
+ <DxcNavTabs>
62
+ <DxcNavTabs.Tab href="#" active>
63
+ Tab 1
64
+ </DxcNavTabs.Tab>
65
+ <DxcNavTabs.Tab href="#" disabled>
66
+ Tab 2
67
+ </DxcNavTabs.Tab>
68
+ <DxcNavTabs.Tab href="#">Tab 3</DxcNavTabs.Tab>
69
+ <DxcNavTabs.Tab href="#">Tab 4</DxcNavTabs.Tab>
70
+ </DxcNavTabs>
71
+ </ExampleContainer>
72
+ <ExampleContainer>
73
+ <Title title="With notification number" theme="light" level={4} />
74
+ <DxcNavTabs>
75
+ <DxcNavTabs.Tab href="#" active notificationNumber>
76
+ Tab 1
77
+ </DxcNavTabs.Tab>
78
+ <DxcNavTabs.Tab href="#" disabled notificationNumber={5}>
79
+ Tab 2
80
+ </DxcNavTabs.Tab>
81
+ <DxcNavTabs.Tab href="#" notificationNumber={120}>
82
+ Tab 3
83
+ </DxcNavTabs.Tab>
84
+ <DxcNavTabs.Tab href="#">Tab 4</DxcNavTabs.Tab>
85
+ </DxcNavTabs>
86
+ </ExampleContainer>
87
+ <ExampleContainer>
88
+ <Title title="With icon position top" theme="light" level={4} />
89
+ <DxcNavTabs>
90
+ <DxcNavTabs.Tab href="#" active icon={iconSVG}>
91
+ Tab 1
92
+ </DxcNavTabs.Tab>
93
+ <DxcNavTabs.Tab href="#" disabled icon={iconSVG}>
94
+ Tab 2
95
+ </DxcNavTabs.Tab>
96
+ <DxcNavTabs.Tab href="#" icon={iconSVG}>
97
+ Tab 3
98
+ </DxcNavTabs.Tab>
99
+ <DxcNavTabs.Tab href="#" icon={iconSVG}>
100
+ Tab 4
101
+ </DxcNavTabs.Tab>
102
+ </DxcNavTabs>
103
+ </ExampleContainer>
104
+ <ExampleContainer>
105
+ <Title title="With icon position left" theme="light" level={4} />
106
+ <DxcNavTabs iconPosition="left">
107
+ <DxcNavTabs.Tab href="#" active icon={iconSVG}>
108
+ Tab 1
109
+ </DxcNavTabs.Tab>
110
+ <DxcNavTabs.Tab href="#" disabled icon={iconSVG}>
111
+ Tab 2
112
+ </DxcNavTabs.Tab>
113
+ <DxcNavTabs.Tab href="#" icon={iconSVG}>
114
+ Tab 3
115
+ </DxcNavTabs.Tab>
116
+ <DxcNavTabs.Tab href="#" icon={iconSVG}>
117
+ Tab 4
118
+ </DxcNavTabs.Tab>
119
+ </DxcNavTabs>
120
+ </ExampleContainer>
121
+ <ExampleContainer>
122
+ <Title title="With icon and notification number" theme="light" level={4} />
123
+ <DxcNavTabs>
124
+ <DxcNavTabs.Tab href="#" active icon={iconSVG} notificationNumber>
125
+ Tab 1
126
+ </DxcNavTabs.Tab>
127
+ <DxcNavTabs.Tab href="#" disabled icon={iconSVG} notificationNumber={5}>
128
+ Tab 2
129
+ </DxcNavTabs.Tab>
130
+ <DxcNavTabs.Tab href="#" icon={iconSVG} notificationNumber={120}>
131
+ Tab 3
132
+ </DxcNavTabs.Tab>
133
+ <DxcNavTabs.Tab href="#" icon={iconSVG}>
134
+ Tab 4
135
+ </DxcNavTabs.Tab>
136
+ </DxcNavTabs>
137
+ </ExampleContainer>
138
+ <ExampleContainer>
139
+ <Title title="With icon on the left and notification number" theme="light" level={4} />
140
+ <DxcNavTabs iconPosition="left">
141
+ <DxcNavTabs.Tab href="#" active icon={iconSVG} notificationNumber>
142
+ Tab 1
143
+ </DxcNavTabs.Tab>
144
+ <DxcNavTabs.Tab href="#" disabled icon={iconSVG} notificationNumber={5}>
145
+ Tab 2
146
+ </DxcNavTabs.Tab>
147
+ <DxcNavTabs.Tab href="#" icon={iconSVG} notificationNumber={120}>
148
+ Tab 3
149
+ </DxcNavTabs.Tab>
150
+ <DxcNavTabs.Tab href="#" icon={iconSVG}>
151
+ Tab 4
152
+ </DxcNavTabs.Tab>
153
+ </DxcNavTabs>
154
+ </ExampleContainer>
155
+ <ExampleContainer>
156
+ <Title title="With long label" theme="light" level={4} />
157
+ <DxcNavTabs>
158
+ <DxcNavTabs.Tab href="#" active>
159
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit
160
+ </DxcNavTabs.Tab>
161
+ <DxcNavTabs.Tab href="#" icon={iconSVG} disabled notificationNumber={3}>
162
+ Tab 2
163
+ </DxcNavTabs.Tab>
164
+ <DxcNavTabs.Tab href="#" icon={iconSVG}>
165
+ Tab 3
166
+ </DxcNavTabs.Tab>
167
+ </DxcNavTabs>
168
+ </ExampleContainer>
169
+ </>
170
+ );
@@ -0,0 +1,82 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _react = _interopRequireDefault(require("react"));
6
+
7
+ var _react2 = require("@testing-library/react");
8
+
9
+ var _NavTabs = _interopRequireDefault(require("./NavTabs"));
10
+
11
+ describe("Tabs component tests", function () {
12
+ test("Tabs render with correct labels and attributes", function () {
13
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NavTabs["default"], null, /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
14
+ href: "/test1",
15
+ active: true
16
+ }, "Tab 1"), /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
17
+ href: "/test2",
18
+ disabled: true
19
+ }, "Tab 2"), /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
20
+ href: "/test3"
21
+ }, "Tab 3"))),
22
+ getByText = _render.getByText,
23
+ getAllByRole = _render.getAllByRole,
24
+ getByRole = _render.getByRole;
25
+
26
+ expect(getByRole("tablist")).toBeTruthy();
27
+ expect(getByRole("tablist").getAttribute("aria-label")).toBe("Navigation tabs");
28
+ expect(getByText("Tab 1")).toBeTruthy();
29
+ expect(getByText("Tab 2")).toBeTruthy();
30
+ expect(getByText("Tab 3")).toBeTruthy();
31
+ var tabs = getAllByRole("tab");
32
+ tabs.forEach(function (tab, index) {
33
+ expect(tab.getAttribute("aria-selected")).toBe((index === 0).toString());
34
+ });
35
+ var anchors = getAllByRole("link");
36
+ expect(anchors.length).toBe(2);
37
+ expect(anchors[0].getAttribute("href")).toBe("/test1");
38
+ expect(anchors[1].getAttribute("href")).toBe("/test3");
39
+ expect(anchors[0].getAttribute("tabindex")).toBe("0");
40
+ expect(anchors[1].getAttribute("tabindex")).toBe("-1");
41
+ });
42
+ test("Tabs render with correct labels, badges and icons", function () {
43
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NavTabs["default"], null, /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
44
+ href: "/test1",
45
+ active: true,
46
+ notificationNumber: 10
47
+ }, "Tab 1"), /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
48
+ href: "/test2",
49
+ disabled: true,
50
+ notificationNumber: 20
51
+ }, "Tab 2"), /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
52
+ href: "/test3",
53
+ notificationNumber: 1000,
54
+ icon: "/testIcon.png"
55
+ }, "Tab 3"))),
56
+ getByText = _render2.getByText,
57
+ getByRole = _render2.getByRole;
58
+
59
+ expect(getByText("10")).toBeTruthy();
60
+ expect(getByText("20")).toBeTruthy();
61
+ expect(getByText("+99")).toBeTruthy();
62
+ expect(getByRole("img")).toBeTruthy();
63
+ });
64
+ test("Tabs render with correct tab index", function () {
65
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NavTabs["default"], {
66
+ tabIndex: 3
67
+ }, /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
68
+ href: "/test1"
69
+ }, "Tab 1"), /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
70
+ href: "/test2",
71
+ disabled: true
72
+ }, "Tab 2"), /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
73
+ href: "/test3",
74
+ active: true
75
+ }, "Tab 3"))),
76
+ getAllByRole = _render3.getAllByRole;
77
+
78
+ var tabs = getAllByRole("link");
79
+ expect(tabs[0].getAttribute("tabindex")).toBe("-1");
80
+ expect(tabs[1].getAttribute("tabindex")).toBe("3");
81
+ });
82
+ });
@@ -0,0 +1,4 @@
1
+ import React from "react";
2
+ import { TabProps } from "./types";
3
+ declare const DxcTab: React.ForwardRefExoticComponent<TabProps & React.RefAttributes<HTMLAnchorElement>>;
4
+ export default DxcTab;