@dxc-technology/halstack-react 0.0.0-9e83fd2 → 0.0.0-9ef63cd

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 (353) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +4 -21
  3. package/HalstackContext.d.ts +53 -143
  4. package/HalstackContext.js +10 -35
  5. package/README.md +47 -0
  6. package/accordion/Accordion.accessibility.test.js +71 -0
  7. package/accordion/Accordion.js +33 -87
  8. package/accordion/Accordion.stories.tsx +8 -64
  9. package/accordion/Accordion.test.js +18 -33
  10. package/accordion/types.d.ts +6 -6
  11. package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
  12. package/accordion-group/AccordionGroup.d.ts +2 -3
  13. package/accordion-group/AccordionGroup.js +17 -44
  14. package/accordion-group/AccordionGroup.stories.tsx +24 -24
  15. package/accordion-group/AccordionGroup.test.js +42 -60
  16. package/accordion-group/AccordionGroupAccordion.js +11 -23
  17. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  18. package/accordion-group/AccordionGroupContext.js +8 -0
  19. package/accordion-group/types.d.ts +7 -7
  20. package/action-icon/ActionIcon.accessibility.test.js +63 -0
  21. package/action-icon/ActionIcon.d.ts +4 -0
  22. package/action-icon/ActionIcon.js +48 -0
  23. package/action-icon/ActionIcon.stories.tsx +41 -0
  24. package/action-icon/ActionIcon.test.js +64 -0
  25. package/action-icon/types.d.ts +26 -0
  26. package/alert/Alert.accessibility.test.js +95 -0
  27. package/alert/Alert.js +34 -120
  28. package/alert/Alert.test.js +28 -45
  29. package/alert/types.d.ts +5 -5
  30. package/badge/Badge.accessibility.test.js +129 -0
  31. package/badge/Badge.d.ts +1 -1
  32. package/badge/Badge.js +142 -42
  33. package/badge/Badge.stories.tsx +210 -0
  34. package/badge/Badge.test.js +30 -0
  35. package/badge/types.d.ts +52 -3
  36. package/bleed/Bleed.js +13 -21
  37. package/bleed/types.d.ts +2 -2
  38. package/box/Box.accessibility.test.js +33 -0
  39. package/box/Box.js +11 -33
  40. package/box/Box.test.js +1 -6
  41. package/box/types.d.ts +3 -3
  42. package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
  43. package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
  44. package/breadcrumbs/Breadcrumbs.d.ts +4 -0
  45. package/breadcrumbs/Breadcrumbs.js +79 -0
  46. package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
  47. package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
  48. package/breadcrumbs/Breadcrumbs.test.js +169 -0
  49. package/breadcrumbs/Item.d.ts +4 -0
  50. package/breadcrumbs/Item.js +52 -0
  51. package/breadcrumbs/dropdownTheme.d.ts +53 -0
  52. package/breadcrumbs/dropdownTheme.js +62 -0
  53. package/breadcrumbs/types.d.ts +16 -0
  54. package/breadcrumbs/types.js +5 -0
  55. package/bulleted-list/BulletedList.accessibility.test.js +119 -0
  56. package/bulleted-list/BulletedList.js +22 -55
  57. package/bulleted-list/BulletedList.stories.tsx +2 -93
  58. package/bulleted-list/types.d.ts +5 -5
  59. package/button/Button.accessibility.test.js +127 -0
  60. package/button/Button.js +36 -59
  61. package/button/Button.stories.tsx +35 -135
  62. package/button/Button.test.js +13 -21
  63. package/button/types.d.ts +5 -5
  64. package/card/Card.accessibility.test.js +36 -0
  65. package/card/Card.js +23 -45
  66. package/card/Card.test.js +10 -21
  67. package/card/types.d.ts +5 -5
  68. package/checkbox/Checkbox.accessibility.test.js +87 -0
  69. package/checkbox/Checkbox.js +88 -126
  70. package/checkbox/Checkbox.stories.tsx +16 -54
  71. package/checkbox/Checkbox.test.js +107 -63
  72. package/checkbox/types.d.ts +8 -4
  73. package/chip/Chip.accessibility.test.js +67 -0
  74. package/chip/Chip.js +22 -36
  75. package/chip/Chip.stories.tsx +10 -25
  76. package/chip/Chip.test.js +17 -30
  77. package/chip/types.d.ts +4 -4
  78. package/common/coreTokens.d.ts +105 -14
  79. package/common/coreTokens.js +40 -23
  80. package/common/utils.js +2 -8
  81. package/common/variables.d.ts +54 -144
  82. package/common/variables.js +128 -225
  83. package/container/Container.d.ts +4 -0
  84. package/container/Container.js +194 -0
  85. package/container/Container.stories.tsx +214 -0
  86. package/container/types.d.ts +74 -0
  87. package/container/types.js +5 -0
  88. package/contextual-menu/ContextualMenu.accessibility.test.js +97 -0
  89. package/contextual-menu/ContextualMenu.d.ts +5 -0
  90. package/contextual-menu/ContextualMenu.js +88 -0
  91. package/contextual-menu/ContextualMenu.stories.tsx +232 -0
  92. package/contextual-menu/ContextualMenu.test.js +205 -0
  93. package/contextual-menu/GroupItem.d.ts +4 -0
  94. package/contextual-menu/GroupItem.js +67 -0
  95. package/contextual-menu/ItemAction.d.ts +4 -0
  96. package/contextual-menu/ItemAction.js +51 -0
  97. package/contextual-menu/MenuItem.d.ts +4 -0
  98. package/contextual-menu/MenuItem.js +29 -0
  99. package/contextual-menu/SingleItem.d.ts +4 -0
  100. package/contextual-menu/SingleItem.js +38 -0
  101. package/contextual-menu/types.d.ts +58 -0
  102. package/contextual-menu/types.js +5 -0
  103. package/date-input/Calendar.js +13 -57
  104. package/date-input/DateInput.accessibility.test.js +228 -0
  105. package/date-input/DateInput.js +61 -108
  106. package/date-input/DateInput.stories.tsx +19 -31
  107. package/date-input/DateInput.test.js +674 -701
  108. package/date-input/DatePicker.js +23 -48
  109. package/date-input/YearPicker.js +8 -34
  110. package/date-input/types.d.ts +28 -22
  111. package/dialog/Dialog.accessibility.test.js +69 -0
  112. package/dialog/Dialog.js +21 -59
  113. package/dialog/Dialog.stories.tsx +175 -0
  114. package/dialog/Dialog.test.js +206 -204
  115. package/dialog/types.d.ts +18 -13
  116. package/divider/Divider.accessibility.test.js +33 -0
  117. package/divider/Divider.d.ts +4 -0
  118. package/divider/Divider.js +36 -0
  119. package/divider/Divider.stories.tsx +223 -0
  120. package/divider/Divider.test.js +38 -0
  121. package/divider/types.d.ts +21 -0
  122. package/divider/types.js +5 -0
  123. package/dropdown/Dropdown.accessibility.test.js +180 -0
  124. package/dropdown/Dropdown.js +67 -135
  125. package/dropdown/Dropdown.stories.tsx +15 -26
  126. package/dropdown/Dropdown.test.js +402 -389
  127. package/dropdown/DropdownMenu.js +12 -23
  128. package/dropdown/DropdownMenuItem.js +13 -21
  129. package/dropdown/types.d.ts +20 -24
  130. package/file-input/FileInput.accessibility.test.js +160 -0
  131. package/file-input/FileInput.js +179 -286
  132. package/file-input/FileInput.stories.tsx +1 -1
  133. package/file-input/FileInput.test.js +293 -354
  134. package/file-input/FileItem.js +29 -66
  135. package/file-input/types.d.ts +9 -9
  136. package/flex/Flex.js +25 -39
  137. package/flex/types.d.ts +6 -6
  138. package/footer/Footer.accessibility.test.js +125 -0
  139. package/footer/Footer.d.ts +1 -1
  140. package/footer/Footer.js +43 -68
  141. package/footer/Footer.stories.tsx +66 -9
  142. package/footer/Footer.test.js +18 -32
  143. package/footer/Icons.d.ts +3 -2
  144. package/footer/Icons.js +53 -22
  145. package/footer/types.d.ts +17 -17
  146. package/grid/Grid.js +1 -16
  147. package/grid/types.d.ts +10 -10
  148. package/header/Header.accessibility.test.js +93 -0
  149. package/header/Header.d.ts +1 -1
  150. package/header/Header.js +38 -104
  151. package/header/Header.stories.tsx +16 -0
  152. package/header/Header.test.js +12 -25
  153. package/header/Icons.d.ts +2 -2
  154. package/header/Icons.js +3 -13
  155. package/header/types.d.ts +7 -8
  156. package/heading/Heading.accessibility.test.js +33 -0
  157. package/heading/Heading.js +9 -31
  158. package/heading/Heading.test.js +70 -87
  159. package/heading/types.d.ts +7 -7
  160. package/icon/Icon.accessibility.test.js +30 -0
  161. package/icon/Icon.d.ts +4 -0
  162. package/icon/Icon.js +33 -0
  163. package/icon/Icon.stories.tsx +28 -0
  164. package/icon/types.d.ts +4 -0
  165. package/icon/types.js +5 -0
  166. package/image/Image.accessibility.test.js +56 -0
  167. package/image/Image.d.ts +4 -0
  168. package/image/Image.js +70 -0
  169. package/image/Image.stories.tsx +129 -0
  170. package/image/types.d.ts +72 -0
  171. package/image/types.js +5 -0
  172. package/inset/Inset.js +13 -21
  173. package/inset/types.d.ts +2 -2
  174. package/layout/ApplicationLayout.d.ts +2 -2
  175. package/layout/ApplicationLayout.js +32 -69
  176. package/layout/ApplicationLayout.stories.tsx +1 -1
  177. package/layout/Icons.d.ts +7 -5
  178. package/layout/Icons.js +41 -59
  179. package/layout/types.d.ts +3 -3
  180. package/link/Link.accessibility.test.js +108 -0
  181. package/link/Link.js +28 -47
  182. package/link/Link.stories.tsx +4 -4
  183. package/link/Link.test.js +23 -41
  184. package/link/types.d.ts +14 -14
  185. package/main.d.ts +9 -4
  186. package/main.js +46 -59
  187. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  188. package/nav-tabs/NavTabs.d.ts +1 -2
  189. package/nav-tabs/NavTabs.js +19 -48
  190. package/nav-tabs/NavTabs.stories.tsx +30 -25
  191. package/nav-tabs/NavTabs.test.js +45 -50
  192. package/nav-tabs/NavTabsContext.d.ts +3 -0
  193. package/nav-tabs/NavTabsContext.js +8 -0
  194. package/nav-tabs/Tab.js +38 -67
  195. package/nav-tabs/types.d.ts +10 -10
  196. package/number-input/NumberInput.accessibility.test.js +228 -0
  197. package/number-input/NumberInput.d.ts +0 -7
  198. package/number-input/NumberInput.js +47 -39
  199. package/number-input/NumberInput.stories.tsx +42 -26
  200. package/number-input/NumberInput.test.js +839 -575
  201. package/number-input/NumberInputContext.d.ts +3 -0
  202. package/number-input/NumberInputContext.js +8 -0
  203. package/number-input/types.d.ts +17 -5
  204. package/package.json +42 -40
  205. package/paginator/Paginator.accessibility.test.js +79 -0
  206. package/paginator/Paginator.js +27 -52
  207. package/paginator/Paginator.test.js +224 -207
  208. package/paginator/types.d.ts +3 -3
  209. package/paragraph/Paragraph.accessibility.test.js +28 -0
  210. package/paragraph/Paragraph.js +3 -19
  211. package/paragraph/Paragraph.stories.tsx +0 -17
  212. package/password-input/PasswordInput.accessibility.test.js +153 -0
  213. package/password-input/PasswordInput.js +32 -54
  214. package/password-input/PasswordInput.stories.tsx +1 -34
  215. package/password-input/PasswordInput.test.js +153 -129
  216. package/password-input/types.d.ts +8 -7
  217. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  218. package/progress-bar/ProgressBar.js +26 -56
  219. package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +1 -1
  220. package/progress-bar/ProgressBar.test.js +35 -52
  221. package/progress-bar/types.d.ts +3 -3
  222. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  223. package/quick-nav/QuickNav.js +4 -27
  224. package/quick-nav/QuickNav.stories.tsx +1 -1
  225. package/quick-nav/types.d.ts +10 -10
  226. package/radio-group/Radio.d.ts +1 -1
  227. package/radio-group/Radio.js +22 -57
  228. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  229. package/radio-group/RadioGroup.js +40 -88
  230. package/radio-group/RadioGroup.stories.tsx +10 -10
  231. package/radio-group/RadioGroup.test.js +504 -472
  232. package/radio-group/types.d.ts +8 -8
  233. package/resultset-table/Icons.d.ts +7 -0
  234. package/{resultsetTable → resultset-table}/Icons.js +1 -5
  235. package/resultset-table/ResultsetTable.accessibility.test.js +285 -0
  236. package/resultset-table/ResultsetTable.d.ts +7 -0
  237. package/{resultsetTable → resultset-table}/ResultsetTable.js +45 -69
  238. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +118 -5
  239. package/{resultsetTable → resultset-table}/ResultsetTable.test.js +148 -92
  240. package/{resultsetTable → resultset-table}/types.d.ts +44 -11
  241. package/resultset-table/types.js +5 -0
  242. package/select/Listbox.js +36 -54
  243. package/select/Option.js +28 -36
  244. package/select/Select.accessibility.test.js +228 -0
  245. package/select/Select.js +111 -177
  246. package/select/Select.stories.tsx +59 -111
  247. package/select/Select.test.js +1895 -1858
  248. package/select/types.d.ts +15 -16
  249. package/sidenav/Sidenav.accessibility.test.js +59 -0
  250. package/sidenav/Sidenav.js +44 -81
  251. package/sidenav/Sidenav.stories.tsx +4 -9
  252. package/sidenav/Sidenav.test.js +3 -10
  253. package/{layout → sidenav}/SidenavContext.d.ts +1 -1
  254. package/{layout → sidenav}/SidenavContext.js +3 -9
  255. package/sidenav/types.d.ts +20 -20
  256. package/slider/Slider.accessibility.test.js +104 -0
  257. package/slider/Slider.js +66 -125
  258. package/slider/Slider.stories.tsx +0 -60
  259. package/slider/Slider.test.js +107 -103
  260. package/slider/types.d.ts +4 -4
  261. package/spinner/Spinner.accessibility.test.js +96 -0
  262. package/spinner/Spinner.js +21 -55
  263. package/spinner/Spinner.test.js +25 -34
  264. package/spinner/types.d.ts +3 -3
  265. package/status-light/StatusLight.accessibility.test.js +157 -0
  266. package/status-light/StatusLight.d.ts +4 -0
  267. package/status-light/StatusLight.js +51 -0
  268. package/status-light/StatusLight.stories.tsx +74 -0
  269. package/status-light/StatusLight.test.js +25 -0
  270. package/status-light/types.d.ts +17 -0
  271. package/status-light/types.js +5 -0
  272. package/switch/Switch.accessibility.test.js +98 -0
  273. package/switch/Switch.js +49 -100
  274. package/switch/Switch.stories.tsx +12 -34
  275. package/switch/Switch.test.js +51 -96
  276. package/switch/types.d.ts +4 -4
  277. package/table/DropdownTheme.js +62 -0
  278. package/table/Table.accessibility.test.js +93 -0
  279. package/table/Table.d.ts +6 -2
  280. package/table/Table.js +76 -33
  281. package/table/{Table.stories.jsx → Table.stories.tsx} +309 -2
  282. package/table/Table.test.js +93 -6
  283. package/table/types.d.ts +34 -6
  284. package/tabs/Tab.js +22 -37
  285. package/tabs/Tabs.accessibility.test.js +56 -0
  286. package/tabs/Tabs.js +59 -147
  287. package/tabs/Tabs.stories.tsx +8 -4
  288. package/tabs/Tabs.test.js +57 -131
  289. package/tabs/types.d.ts +21 -21
  290. package/tag/Tag.accessibility.test.js +69 -0
  291. package/tag/Tag.js +27 -57
  292. package/tag/Tag.stories.tsx +4 -7
  293. package/tag/Tag.test.js +17 -36
  294. package/tag/types.d.ts +9 -9
  295. package/text-input/Suggestion.js +9 -26
  296. package/text-input/Suggestions.d.ts +1 -1
  297. package/text-input/Suggestions.js +30 -70
  298. package/text-input/TextInput.accessibility.test.js +321 -0
  299. package/text-input/TextInput.js +198 -286
  300. package/text-input/TextInput.stories.tsx +65 -160
  301. package/text-input/TextInput.test.js +1227 -1194
  302. package/text-input/types.d.ts +25 -17
  303. package/textarea/Textarea.accessibility.test.js +155 -0
  304. package/textarea/Textarea.js +67 -111
  305. package/textarea/{Textarea.stories.jsx → Textarea.stories.tsx} +58 -100
  306. package/textarea/Textarea.test.js +150 -179
  307. package/textarea/types.d.ts +9 -5
  308. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  309. package/toggle-group/ToggleGroup.js +25 -67
  310. package/toggle-group/ToggleGroup.stories.tsx +7 -7
  311. package/toggle-group/ToggleGroup.test.js +48 -81
  312. package/toggle-group/types.d.ts +12 -12
  313. package/typography/Typography.accessibility.test.js +339 -0
  314. package/typography/Typography.js +4 -13
  315. package/typography/types.d.ts +1 -1
  316. package/useTheme.d.ts +51 -141
  317. package/useTheme.js +1 -8
  318. package/useTranslatedLabels.js +1 -7
  319. package/utils/BaseTypography.d.ts +2 -2
  320. package/utils/BaseTypography.js +16 -30
  321. package/utils/FocusLock.js +25 -39
  322. package/wizard/Wizard.accessibility.test.js +55 -0
  323. package/wizard/Wizard.js +27 -73
  324. package/wizard/Wizard.stories.tsx +19 -0
  325. package/wizard/Wizard.test.js +53 -80
  326. package/wizard/types.d.ts +8 -8
  327. package/common/OpenSans.css +0 -69
  328. package/common/fonts/OpenSans-Bold.ttf +0 -0
  329. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  330. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  331. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  332. package/common/fonts/OpenSans-Italic.ttf +0 -0
  333. package/common/fonts/OpenSans-Light.ttf +0 -0
  334. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  335. package/common/fonts/OpenSans-Regular.ttf +0 -0
  336. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  337. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  338. package/date-input/Icons.d.ts +0 -6
  339. package/date-input/Icons.js +0 -75
  340. package/paginator/Icons.d.ts +0 -5
  341. package/paginator/Icons.js +0 -54
  342. package/password-input/Icons.d.ts +0 -6
  343. package/password-input/Icons.js +0 -39
  344. package/resultsetTable/Icons.d.ts +0 -7
  345. package/resultsetTable/ResultsetTable.d.ts +0 -4
  346. package/select/Icons.d.ts +0 -10
  347. package/select/Icons.js +0 -93
  348. package/sidenav/Icons.d.ts +0 -7
  349. package/sidenav/Icons.js +0 -51
  350. package/text-input/Icons.d.ts +0 -8
  351. package/text-input/Icons.js +0 -60
  352. /package/{resultsetTable → action-icon}/types.js +0 -0
  353. /package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +0 -0
package/link/Link.test.js CHANGED
@@ -1,81 +1,63 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  var _react = _interopRequireDefault(require("react"));
6
-
7
5
  var _react2 = require("@testing-library/react");
8
-
9
6
  var _Link = _interopRequireDefault(require("./Link.tsx"));
10
-
11
7
  describe("Link component tests", function () {
12
8
  test("Link renders with correct text", function () {
13
9
  var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Link["default"], null, "Link")),
14
- getByText = _render.getByText;
15
-
10
+ getByText = _render.getByText;
16
11
  expect(getByText("Link")).toBeTruthy();
17
12
  });
18
13
  test("Link renders with correct href", function () {
19
14
  var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Link["default"], {
20
- href: "/testPage"
21
- }, "Link")),
22
- getByRole = _render2.getByRole;
23
-
15
+ href: "/testPage"
16
+ }, "Link")),
17
+ getByRole = _render2.getByRole;
24
18
  expect(getByRole("link").getAttribute("href")).toEqual("/testPage");
25
19
  });
26
20
  test("Link renders with correct disabled state", function () {
27
21
  var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Link["default"], {
28
- href: "/testPage",
29
- disabled: true
30
- }, "Link")),
31
- getByText = _render3.getByText;
32
-
22
+ href: "/testPage",
23
+ disabled: true
24
+ }, "Link")),
25
+ getByText = _render3.getByText;
33
26
  expect(getByText("Link").hasAttribute("href")).toBeFalsy();
34
-
35
27
  var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Link["default"], {
36
- onClick: function onClick() {},
37
- disabled: true
38
- }, "LinkButton")),
39
- getByTextLinkButton = _render4.getByText;
40
-
28
+ onClick: function onClick() {},
29
+ disabled: true
30
+ }, "LinkButton")),
31
+ getByTextLinkButton = _render4.getByText;
41
32
  expect(getByTextLinkButton("LinkButton").hasAttribute("onclick")).toBeFalsy();
42
33
  });
43
34
  test("Link open new tab", function () {
44
35
  var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Link["default"], {
45
- href: "/testPage",
46
- newWindow: true
47
- }, "Link")),
48
- getByRole = _render5.getByRole;
49
-
36
+ href: "/testPage",
37
+ newWindow: true
38
+ }, "Link")),
39
+ getByRole = _render5.getByRole;
50
40
  expect(getByRole("link").getAttribute("target")).toEqual("_blank");
51
41
  });
52
42
  test("Link onClick called", function () {
53
43
  var onClick = jest.fn();
54
-
55
44
  var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Link["default"], {
56
- onClick: onClick
57
- }, "Link")),
58
- getByText = _render6.getByText;
59
-
45
+ onClick: onClick
46
+ }, "Link")),
47
+ getByText = _render6.getByText;
60
48
  var link = getByText("Link");
61
-
62
49
  _react2.fireEvent.click(link);
63
-
64
50
  expect(onClick).toHaveBeenCalled();
65
51
  });
66
52
  test("Disabled link onClick not called", function () {
67
53
  var onClick = jest.fn();
68
-
69
54
  var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Link["default"], {
70
- onClick: onClick,
71
- disabled: true
72
- }, "Link")),
73
- getByText = _render7.getByText;
74
-
55
+ onClick: onClick,
56
+ disabled: true
57
+ }, "Link")),
58
+ getByText = _render7.getByText;
75
59
  var link = getByText("Link");
76
-
77
60
  _react2.fireEvent.click(link);
78
-
79
61
  expect(onClick).toHaveBeenCalledTimes(0);
80
62
  });
81
63
  });
package/link/types.d.ts CHANGED
@@ -1,21 +1,25 @@
1
1
  /// <reference types="react" />
2
- declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
- declare type Margin = {
2
+ type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ type Margin = {
4
4
  top?: Space;
5
5
  bottom?: Space;
6
6
  left?: Space;
7
7
  right?: Space;
8
8
  };
9
- declare type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
10
- export declare type LinkProps = {
9
+ type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
10
+ export type LinkProps = {
11
+ /**
12
+ * If true, the link is disabled.
13
+ */
14
+ disabled?: boolean;
11
15
  /**
12
16
  * If true, the color is inherited from parent.
13
17
  */
14
18
  inheritColor?: boolean;
15
19
  /**
16
- * If true, the link is disabled.
20
+ * Material Symbol name or SVG element as the icon that will be placed next to the link text.
17
21
  */
18
- disabled?: boolean;
22
+ icon?: string | SVG;
19
23
  /**
20
24
  * Indicates the position of the icon in the component.
21
25
  */
@@ -33,6 +37,10 @@ export declare type LinkProps = {
33
37
  * function will be called when the user clicks the link.
34
38
  */
35
39
  onClick?: () => void;
40
+ /**
41
+ * Text of the link.
42
+ */
43
+ children: string;
36
44
  /**
37
45
  * Size of the margin to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
38
46
  * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
@@ -42,13 +50,5 @@ export declare type LinkProps = {
42
50
  * Value of the tabindex.
43
51
  */
44
52
  tabIndex?: number;
45
- /**
46
- * Content of the link.
47
- */
48
- children: string;
49
- /**
50
- * Element or path used as the icon that will be placed next to the link text.
51
- */
52
- icon?: string | SVG;
53
53
  };
54
54
  export {};
package/main.d.ts CHANGED
@@ -17,12 +17,11 @@ import DxcPaginator from "./paginator/Paginator";
17
17
  import DxcWizard from "./wizard/Wizard";
18
18
  import DxcLink from "./link/Link";
19
19
  import DxcHeading from "./heading/Heading";
20
- import DxcResultsetTable from "./resultsetTable/ResultsetTable";
20
+ import DxcResultsetTable from "./resultset-table/ResultsetTable";
21
21
  import DxcChip from "./chip/Chip";
22
22
  import DxcApplicationLayout from "./layout/ApplicationLayout";
23
23
  import DxcToggleGroup from "./toggle-group/ToggleGroup";
24
24
  import DxcAccordionGroup from "./accordion-group/AccordionGroup";
25
- import DxcBadge from "./badge/Badge";
26
25
  import DxcTextInput from "./text-input/TextInput";
27
26
  import DxcPasswordInput from "./password-input/PasswordInput";
28
27
  import DxcDateInput from "./date-input/DateInput";
@@ -40,6 +39,12 @@ import DxcTypography from "./typography/Typography";
40
39
  import DxcParagraph from "./paragraph/Paragraph";
41
40
  import DxcBulletedList from "./bulleted-list/BulletedList";
42
41
  import DxcGrid from "./grid/Grid";
42
+ import DxcImage from "./image/Image";
43
+ import DxcContainer from "./container/Container";
44
+ import DxcBadge from "./badge/Badge";
45
+ import DxcStatusLight from "./status-light/StatusLight";
46
+ import DxcContextualMenu from "./contextual-menu/ContextualMenu";
47
+ import DxcDivider from "./divider/Divider";
48
+ import DxcBreadcrumbs from "./breadcrumbs/Breadcrumbs";
43
49
  import HalstackContext, { HalstackProvider, HalstackLanguageContext } from "./HalstackContext";
44
- import { BackgroundColorProvider } from "./BackgroundColorContext";
45
- export { DxcAlert, DxcButton, DxcCheckbox, DxcTextInput, DxcDropdown, DxcSwitch, DxcSlider, DxcTable, DxcTabs, DxcToggleGroup, DxcDialog, DxcCard, DxcProgressBar, DxcAccordion, DxcSpinner, DxcBox, DxcTag, DxcPaginator, DxcWizard, DxcLink, DxcHeading, DxcResultsetTable, DxcChip, DxcApplicationLayout, HalstackContext, HalstackLanguageContext, HalstackProvider, BackgroundColorProvider, DxcAccordionGroup, DxcBadge, DxcPasswordInput, DxcDateInput, DxcNumberInput, DxcTextarea, DxcSelect, DxcFileInput, DxcRadioGroup, DxcBleed, DxcInset, DxcQuickNav, DxcNavTabs, DxcFlex, DxcTypography, DxcParagraph, DxcBulletedList, DxcGrid, };
50
+ export { DxcAlert, DxcButton, DxcCheckbox, DxcTextInput, DxcDropdown, DxcSwitch, DxcSlider, DxcTable, DxcTabs, DxcToggleGroup, DxcDialog, DxcCard, DxcProgressBar, DxcAccordion, DxcSpinner, DxcBox, DxcTag, DxcPaginator, DxcWizard, DxcLink, DxcHeading, DxcResultsetTable, DxcChip, DxcApplicationLayout, HalstackContext, HalstackLanguageContext, HalstackProvider, DxcAccordionGroup, DxcPasswordInput, DxcDateInput, DxcNumberInput, DxcTextarea, DxcSelect, DxcFileInput, DxcRadioGroup, DxcBleed, DxcInset, DxcQuickNav, DxcNavTabs, DxcFlex, DxcTypography, DxcParagraph, DxcBulletedList, DxcGrid, DxcImage, DxcContainer, DxcBadge, DxcStatusLight, DxcContextualMenu, DxcDivider, DxcBreadcrumbs, };
package/main.js CHANGED
@@ -1,18 +1,10 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  var _typeof = require("@babel/runtime/helpers/typeof");
6
-
7
5
  Object.defineProperty(exports, "__esModule", {
8
6
  value: true
9
7
  });
10
- Object.defineProperty(exports, "BackgroundColorProvider", {
11
- enumerable: true,
12
- get: function get() {
13
- return _BackgroundColorContext.BackgroundColorProvider;
14
- }
15
- });
16
8
  Object.defineProperty(exports, "DxcAccordion", {
17
9
  enumerable: true,
18
10
  get: function get() {
@@ -55,6 +47,12 @@ Object.defineProperty(exports, "DxcBox", {
55
47
  return _Box["default"];
56
48
  }
57
49
  });
50
+ Object.defineProperty(exports, "DxcBreadcrumbs", {
51
+ enumerable: true,
52
+ get: function get() {
53
+ return _Breadcrumbs["default"];
54
+ }
55
+ });
58
56
  Object.defineProperty(exports, "DxcBulletedList", {
59
57
  enumerable: true,
60
58
  get: function get() {
@@ -85,6 +83,18 @@ Object.defineProperty(exports, "DxcChip", {
85
83
  return _Chip["default"];
86
84
  }
87
85
  });
86
+ Object.defineProperty(exports, "DxcContainer", {
87
+ enumerable: true,
88
+ get: function get() {
89
+ return _Container["default"];
90
+ }
91
+ });
92
+ Object.defineProperty(exports, "DxcContextualMenu", {
93
+ enumerable: true,
94
+ get: function get() {
95
+ return _ContextualMenu["default"];
96
+ }
97
+ });
88
98
  Object.defineProperty(exports, "DxcDateInput", {
89
99
  enumerable: true,
90
100
  get: function get() {
@@ -97,6 +107,12 @@ Object.defineProperty(exports, "DxcDialog", {
97
107
  return _Dialog["default"];
98
108
  }
99
109
  });
110
+ Object.defineProperty(exports, "DxcDivider", {
111
+ enumerable: true,
112
+ get: function get() {
113
+ return _Divider["default"];
114
+ }
115
+ });
100
116
  Object.defineProperty(exports, "DxcDropdown", {
101
117
  enumerable: true,
102
118
  get: function get() {
@@ -127,6 +143,12 @@ Object.defineProperty(exports, "DxcHeading", {
127
143
  return _Heading["default"];
128
144
  }
129
145
  });
146
+ Object.defineProperty(exports, "DxcImage", {
147
+ enumerable: true,
148
+ get: function get() {
149
+ return _Image["default"];
150
+ }
151
+ });
130
152
  Object.defineProperty(exports, "DxcInset", {
131
153
  enumerable: true,
132
154
  get: function get() {
@@ -211,6 +233,12 @@ Object.defineProperty(exports, "DxcSpinner", {
211
233
  return _Spinner["default"];
212
234
  }
213
235
  });
236
+ Object.defineProperty(exports, "DxcStatusLight", {
237
+ enumerable: true,
238
+ get: function get() {
239
+ return _StatusLight["default"];
240
+ }
241
+ });
214
242
  Object.defineProperty(exports, "DxcSwitch", {
215
243
  enumerable: true,
216
244
  get: function get() {
@@ -283,95 +311,54 @@ Object.defineProperty(exports, "HalstackProvider", {
283
311
  return _HalstackContext.HalstackProvider;
284
312
  }
285
313
  });
286
-
287
314
  var _Alert = _interopRequireDefault(require("./alert/Alert"));
288
-
289
315
  var _Accordion = _interopRequireDefault(require("./accordion/Accordion"));
290
-
291
316
  var _Button = _interopRequireDefault(require("./button/Button"));
292
-
293
317
  var _Card = _interopRequireDefault(require("./card/Card"));
294
-
295
318
  var _Checkbox = _interopRequireDefault(require("./checkbox/Checkbox"));
296
-
297
319
  var _Dialog = _interopRequireDefault(require("./dialog/Dialog"));
298
-
299
320
  var _Dropdown = _interopRequireDefault(require("./dropdown/Dropdown"));
300
-
301
321
  var _Slider = _interopRequireDefault(require("./slider/Slider"));
302
-
303
322
  var _Switch = _interopRequireDefault(require("./switch/Switch"));
304
-
305
323
  var _Tabs = _interopRequireDefault(require("./tabs/Tabs"));
306
-
307
324
  var _ProgressBar = _interopRequireDefault(require("./progress-bar/ProgressBar"));
308
-
309
325
  var _Spinner = _interopRequireDefault(require("./spinner/Spinner"));
310
-
311
326
  var _Table = _interopRequireDefault(require("./table/Table"));
312
-
313
327
  var _Box = _interopRequireDefault(require("./box/Box"));
314
-
315
328
  var _Tag = _interopRequireDefault(require("./tag/Tag"));
316
-
317
329
  var _Paginator = _interopRequireDefault(require("./paginator/Paginator"));
318
-
319
330
  var _Wizard = _interopRequireDefault(require("./wizard/Wizard"));
320
-
321
331
  var _Link = _interopRequireDefault(require("./link/Link"));
322
-
323
332
  var _Heading = _interopRequireDefault(require("./heading/Heading"));
324
-
325
- var _ResultsetTable = _interopRequireDefault(require("./resultsetTable/ResultsetTable"));
326
-
333
+ var _ResultsetTable = _interopRequireDefault(require("./resultset-table/ResultsetTable"));
327
334
  var _Chip = _interopRequireDefault(require("./chip/Chip"));
328
-
329
335
  var _ApplicationLayout = _interopRequireDefault(require("./layout/ApplicationLayout"));
330
-
331
336
  var _ToggleGroup = _interopRequireDefault(require("./toggle-group/ToggleGroup"));
332
-
333
337
  var _AccordionGroup = _interopRequireDefault(require("./accordion-group/AccordionGroup"));
334
-
335
- var _Badge = _interopRequireDefault(require("./badge/Badge"));
336
-
337
338
  var _TextInput = _interopRequireDefault(require("./text-input/TextInput"));
338
-
339
339
  var _PasswordInput = _interopRequireDefault(require("./password-input/PasswordInput"));
340
-
341
340
  var _DateInput = _interopRequireDefault(require("./date-input/DateInput"));
342
-
343
341
  var _NumberInput = _interopRequireDefault(require("./number-input/NumberInput"));
344
-
345
342
  var _Textarea = _interopRequireDefault(require("./textarea/Textarea"));
346
-
347
343
  var _Select = _interopRequireDefault(require("./select/Select"));
348
-
349
344
  var _FileInput = _interopRequireDefault(require("./file-input/FileInput"));
350
-
351
345
  var _RadioGroup = _interopRequireDefault(require("./radio-group/RadioGroup"));
352
-
353
346
  var _Bleed = _interopRequireDefault(require("./bleed/Bleed"));
354
-
355
347
  var _Inset = _interopRequireDefault(require("./inset/Inset"));
356
-
357
348
  var _QuickNav = _interopRequireDefault(require("./quick-nav/QuickNav"));
358
-
359
349
  var _NavTabs = _interopRequireDefault(require("./nav-tabs/NavTabs"));
360
-
361
350
  var _Flex = _interopRequireDefault(require("./flex/Flex"));
362
-
363
351
  var _Typography = _interopRequireDefault(require("./typography/Typography"));
364
-
365
352
  var _Paragraph = _interopRequireDefault(require("./paragraph/Paragraph"));
366
-
367
353
  var _BulletedList = _interopRequireDefault(require("./bulleted-list/BulletedList"));
368
-
369
354
  var _Grid = _interopRequireDefault(require("./grid/Grid"));
370
-
355
+ var _Image = _interopRequireDefault(require("./image/Image"));
356
+ var _Container = _interopRequireDefault(require("./container/Container"));
357
+ var _Badge = _interopRequireDefault(require("./badge/Badge"));
358
+ var _StatusLight = _interopRequireDefault(require("./status-light/StatusLight"));
359
+ var _ContextualMenu = _interopRequireDefault(require("./contextual-menu/ContextualMenu"));
360
+ var _Divider = _interopRequireDefault(require("./divider/Divider"));
361
+ var _Breadcrumbs = _interopRequireDefault(require("./breadcrumbs/Breadcrumbs"));
371
362
  var _HalstackContext = _interopRequireWildcard(require("./HalstackContext"));
372
-
373
- var _BackgroundColorContext = require("./BackgroundColorContext");
374
-
375
- 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); }
376
-
377
- 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; }
363
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
364
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
@@ -0,0 +1,44 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
5
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
6
+ var _react = _interopRequireDefault(require("react"));
7
+ var _react2 = require("@testing-library/react");
8
+ var _axeHelper = require("../../test/accessibility/axe-helper.js");
9
+ var _NavTabs = _interopRequireDefault(require("./NavTabs.tsx"));
10
+ var favoriteIcon = 'filled_Favorite';
11
+ var pinIcon = 'Location_On';
12
+ describe("Tabs component accessibility tests", function () {
13
+ it("Should not have basic accessibility issues", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
14
+ var _render, container, results;
15
+ return _regenerator["default"].wrap(function _callee$(_context) {
16
+ while (1) switch (_context.prev = _context.next) {
17
+ case 0:
18
+ _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NavTabs["default"], {
19
+ iconPosition: "left"
20
+ }, /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
21
+ href: "/test1",
22
+ icon: favoriteIcon,
23
+ active: true
24
+ }, "Tab 1"), /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
25
+ href: "/test2",
26
+ icon: favoriteIcon,
27
+ disabled: true
28
+ }, "Tab 2"), /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
29
+ href: "/test3",
30
+ icon: pinIcon,
31
+ notificationNumber: 12
32
+ }, "Tab 3"))), container = _render.container;
33
+ _context.next = 3;
34
+ return (0, _axeHelper.axe)(container);
35
+ case 3:
36
+ results = _context.sent;
37
+ expect(results).toHaveNoViolations();
38
+ case 5:
39
+ case "end":
40
+ return _context.stop();
41
+ }
42
+ }, _callee);
43
+ })));
44
+ });
@@ -1,6 +1,5 @@
1
1
  import React from "react";
2
- import NavTabsPropsType, { NavTabsContextProps } from "./types";
3
- export declare const NavTabsContext: React.Context<NavTabsContextProps>;
2
+ import NavTabsPropsType from "./types";
4
3
  declare const DxcNavTabs: {
5
4
  ({ iconPosition, tabIndex, children }: NavTabsPropsType): JSX.Element;
6
5
  Tab: React.ForwardRefExoticComponent<import("./types").TabProps & React.RefAttributes<HTMLAnchorElement>>;
@@ -1,39 +1,24 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  var _typeof = require("@babel/runtime/helpers/typeof");
6
-
7
5
  Object.defineProperty(exports, "__esModule", {
8
6
  value: true
9
7
  });
10
- exports["default"] = exports.NavTabsContext = void 0;
11
-
8
+ exports["default"] = void 0;
12
9
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
-
14
10
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
15
-
16
11
  var _react = _interopRequireWildcard(require("react"));
17
-
18
12
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
19
-
20
13
  var _useTheme = _interopRequireDefault(require("../useTheme"));
21
-
22
14
  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
-
15
+ var _NavTabsContext = require("./NavTabsContext");
16
+ var _templateObject, _templateObject2;
17
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
18
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
33
19
  var getPropInChild = function getPropInChild(child, propName) {
34
20
  return child.props ? child.props[propName] ? child.props[propName] : child.props.children ? getPropInChild(child.props.children, propName) : undefined : undefined;
35
21
  };
36
-
37
22
  var getLabelFromTab = function getLabelFromTab(child) {
38
23
  if (typeof child === "string") {
39
24
  return child.toString();
@@ -41,39 +26,30 @@ var getLabelFromTab = function getLabelFromTab(child) {
41
26
  return Array.isArray(child.props.children) ? getLabelFromTab(child.props.children[0]) : getLabelFromTab(child.props.children);
42
27
  }
43
28
  };
44
-
45
29
  var getPreviousTabIndex = function getPreviousTabIndex(array, initialIndex) {
46
30
  var index = initialIndex === 0 ? array.length - 1 : initialIndex - 1;
47
-
48
31
  while (getPropInChild(array[index], "disabled")) {
49
32
  index = index === 0 ? array.length - 1 : index - 1;
50
33
  }
51
-
52
34
  return index;
53
35
  };
54
-
55
36
  var getNextTabIndex = function getNextTabIndex(array, initialIndex) {
56
37
  var index = initialIndex === array.length - 1 ? 0 : initialIndex + 1;
57
-
58
38
  while (getPropInChild(array[index], "disabled")) {
59
39
  index = index === array.length - 1 ? 0 : index + 1;
60
40
  }
61
-
62
41
  return index;
63
42
  };
64
-
65
43
  var DxcNavTabs = function DxcNavTabs(_ref) {
66
44
  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
-
45
+ iconPosition = _ref$iconPosition === void 0 ? "top" : _ref$iconPosition,
46
+ _ref$tabIndex = _ref.tabIndex,
47
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex,
48
+ children = _ref.children;
72
49
  var _useState = (0, _react.useState)(null),
73
- _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
74
- innerFocusIndex = _useState2[0],
75
- setInnerFocusIndex = _useState2[1];
76
-
50
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
51
+ innerFocusIndex = _useState2[0],
52
+ setInnerFocusIndex = _useState2[1];
77
53
  var colorsTheme = (0, _useTheme["default"])();
78
54
  var contextValue = (0, _react.useMemo)(function () {
79
55
  return {
@@ -82,19 +58,16 @@ var DxcNavTabs = function DxcNavTabs(_ref) {
82
58
  focusedLabel: innerFocusIndex === null ? undefined : getLabelFromTab(children[innerFocusIndex])
83
59
  };
84
60
  }, [iconPosition, tabIndex, innerFocusIndex]);
85
-
86
61
  var handleOnKeyDown = function handleOnKeyDown(event) {
87
62
  var activeTab = _react["default"].Children.toArray(children).findIndex(function (child) {
88
63
  return getPropInChild(child, "active");
89
64
  });
90
-
91
65
  switch (event.key) {
92
66
  case "Left":
93
67
  case "ArrowLeft":
94
68
  event.preventDefault();
95
69
  setInnerFocusIndex(getPreviousTabIndex(children, innerFocusIndex === null ? activeTab : innerFocusIndex));
96
70
  break;
97
-
98
71
  case "Right":
99
72
  case "ArrowRight":
100
73
  event.preventDefault();
@@ -102,21 +75,19 @@ var DxcNavTabs = function DxcNavTabs(_ref) {
102
75
  break;
103
76
  }
104
77
  };
105
-
106
78
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
107
79
  theme: colorsTheme.navTabs
108
80
  }, /*#__PURE__*/_react["default"].createElement(NavTabsContainer, {
109
81
  onKeyDown: handleOnKeyDown,
110
82
  role: "tablist",
111
83
  "aria-label": "Navigation tabs"
112
- }, /*#__PURE__*/_react["default"].createElement(NavTabsContext.Provider, {
84
+ }, /*#__PURE__*/_react["default"].createElement(_NavTabsContext.NavTabsContext.Provider, {
113
85
  value: contextValue
114
- }, children)));
86
+ }, children), /*#__PURE__*/_react["default"].createElement(Underline, null)));
115
87
  };
116
-
88
+ var Underline = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n bottom: 0;\n left: 0;\n width: 100%;\n height: 2px;\n background-color: ", ";\n"])), function (props) {
89
+ return props.theme.dividerColor;
90
+ });
117
91
  DxcNavTabs.Tab = _Tab["default"];
118
-
119
- var NavTabsContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n"])));
120
-
121
- var _default = DxcNavTabs;
122
- exports["default"] = _default;
92
+ var NavTabsContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n position: relative;\n"])));
93
+ var _default = exports["default"] = DxcNavTabs;