@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
@@ -5,7 +5,7 @@ import ExampleContainer from "../../.storybook/components/ExampleContainer";
5
5
  import { HalstackProvider } from "../HalstackContext";
6
6
 
7
7
  export default {
8
- title: "NavTabs",
8
+ title: "Nav Tabs",
9
9
  component: DxcNavTabs,
10
10
  };
11
11
 
@@ -16,7 +16,10 @@ const iconSVG = (
16
16
  </svg>
17
17
  );
18
18
 
19
- const largeIcon = "https://www.iconpacks.net/icons/1/free-pin-icon-48-thumb.png";
19
+
20
+ const favoriteIcon = 'filled_Favorite'
21
+
22
+ const pinIcon = 'Location_On';
20
23
 
21
24
  const opinionatedTheme = {
22
25
  navTabs: {
@@ -91,7 +94,9 @@ export const Chromatic = () => (
91
94
  <DxcNavTabs.Tab href="#" notificationNumber={120}>
92
95
  Tab 3
93
96
  </DxcNavTabs.Tab>
94
- <DxcNavTabs.Tab href="#">Tab 4</DxcNavTabs.Tab>
97
+ <DxcNavTabs.Tab href="#" notificationNumber={12}>
98
+ Tab 4
99
+ </DxcNavTabs.Tab>
95
100
  </DxcNavTabs>
96
101
  </ExampleContainer>
97
102
  <ExampleContainer>
@@ -103,10 +108,10 @@ export const Chromatic = () => (
103
108
  <DxcNavTabs.Tab href="#" disabled icon={iconSVG}>
104
109
  Tab 2
105
110
  </DxcNavTabs.Tab>
106
- <DxcNavTabs.Tab href="#" icon={largeIcon}>
111
+ <DxcNavTabs.Tab href="#" icon={pinIcon}>
107
112
  Tab 3
108
113
  </DxcNavTabs.Tab>
109
- <DxcNavTabs.Tab href="#" icon={largeIcon}>
114
+ <DxcNavTabs.Tab href="#" icon={pinIcon}>
110
115
  Tab 4
111
116
  </DxcNavTabs.Tab>
112
117
  </DxcNavTabs>
@@ -114,16 +119,16 @@ export const Chromatic = () => (
114
119
  <ExampleContainer>
115
120
  <Title title="With icon position left" theme="light" level={4} />
116
121
  <DxcNavTabs iconPosition="left">
117
- <DxcNavTabs.Tab href="#" active icon={largeIcon}>
122
+ <DxcNavTabs.Tab href="#" active icon={pinIcon}>
118
123
  Tab 1
119
124
  </DxcNavTabs.Tab>
120
- <DxcNavTabs.Tab href="#" disabled icon={iconSVG}>
125
+ <DxcNavTabs.Tab href="#" disabled icon={favoriteIcon}>
121
126
  Tab 2
122
127
  </DxcNavTabs.Tab>
123
- <DxcNavTabs.Tab href="#" icon={iconSVG}>
128
+ <DxcNavTabs.Tab href="#" icon={favoriteIcon}>
124
129
  Tab 3
125
130
  </DxcNavTabs.Tab>
126
- <DxcNavTabs.Tab href="#" icon={iconSVG}>
131
+ <DxcNavTabs.Tab href="#" icon={favoriteIcon}>
127
132
  Tab 4
128
133
  </DxcNavTabs.Tab>
129
134
  </DxcNavTabs>
@@ -131,16 +136,16 @@ export const Chromatic = () => (
131
136
  <ExampleContainer>
132
137
  <Title title="With icon and notification number" theme="light" level={4} />
133
138
  <DxcNavTabs>
134
- <DxcNavTabs.Tab href="#" active icon={largeIcon} notificationNumber>
139
+ <DxcNavTabs.Tab href="#" active icon={pinIcon} notificationNumber>
135
140
  Tab 1
136
141
  </DxcNavTabs.Tab>
137
- <DxcNavTabs.Tab href="#" disabled icon={iconSVG} notificationNumber={5}>
142
+ <DxcNavTabs.Tab href="#" disabled icon={favoriteIcon} notificationNumber={5}>
138
143
  Tab 2
139
144
  </DxcNavTabs.Tab>
140
- <DxcNavTabs.Tab href="#" icon={iconSVG} notificationNumber={120}>
145
+ <DxcNavTabs.Tab href="#" icon={favoriteIcon} notificationNumber={120}>
141
146
  Tab 3
142
147
  </DxcNavTabs.Tab>
143
- <DxcNavTabs.Tab href="#" icon={largeIcon}>
148
+ <DxcNavTabs.Tab href="#" icon={pinIcon} notificationNumber={12}>
144
149
  Tab 4
145
150
  </DxcNavTabs.Tab>
146
151
  </DxcNavTabs>
@@ -148,16 +153,16 @@ export const Chromatic = () => (
148
153
  <ExampleContainer>
149
154
  <Title title="With icon on the left and notification number" theme="light" level={4} />
150
155
  <DxcNavTabs iconPosition="left">
151
- <DxcNavTabs.Tab href="#" active icon={iconSVG} notificationNumber>
156
+ <DxcNavTabs.Tab href="#" active icon={favoriteIcon} notificationNumber>
152
157
  Tab 1
153
158
  </DxcNavTabs.Tab>
154
- <DxcNavTabs.Tab href="#" disabled icon={iconSVG} notificationNumber={5}>
159
+ <DxcNavTabs.Tab href="#" disabled icon={favoriteIcon} notificationNumber={5}>
155
160
  Tab 2
156
161
  </DxcNavTabs.Tab>
157
- <DxcNavTabs.Tab href="#" icon={largeIcon} notificationNumber={120}>
162
+ <DxcNavTabs.Tab href="#" icon={pinIcon} notificationNumber={120}>
158
163
  Tab 3
159
164
  </DxcNavTabs.Tab>
160
- <DxcNavTabs.Tab href="#" icon={iconSVG}>
165
+ <DxcNavTabs.Tab href="#" icon={favoriteIcon} notificationNumber={12}>
161
166
  Tab 4
162
167
  </DxcNavTabs.Tab>
163
168
  </DxcNavTabs>
@@ -168,10 +173,10 @@ export const Chromatic = () => (
168
173
  <DxcNavTabs.Tab href="#" active>
169
174
  Lorem ipsum dolor sit amet, consectetur adipiscing elit
170
175
  </DxcNavTabs.Tab>
171
- <DxcNavTabs.Tab href="#" icon={iconSVG} disabled notificationNumber={3}>
176
+ <DxcNavTabs.Tab href="#" icon={favoriteIcon} disabled notificationNumber={3}>
172
177
  Tab 2
173
178
  </DxcNavTabs.Tab>
174
- <DxcNavTabs.Tab href="#" icon={iconSVG}>
179
+ <DxcNavTabs.Tab href="#" icon={favoriteIcon}>
175
180
  Tab 3
176
181
  </DxcNavTabs.Tab>
177
182
  </DxcNavTabs>
@@ -182,10 +187,10 @@ export const Chromatic = () => (
182
187
  <DxcNavTabs.Tab href="#" active>
183
188
  Lorem ipsum dolor sit amet, consectetur adipiscing elit
184
189
  </DxcNavTabs.Tab>
185
- <DxcNavTabs.Tab href="#" icon={iconSVG} disabled notificationNumber={3}>
190
+ <DxcNavTabs.Tab href="#" icon={favoriteIcon} disabled notificationNumber={3}>
186
191
  Tab 2
187
192
  </DxcNavTabs.Tab>
188
- <DxcNavTabs.Tab href="#" icon={iconSVG}>
193
+ <DxcNavTabs.Tab href="#" icon={favoriteIcon}>
189
194
  Tab 3
190
195
  </DxcNavTabs.Tab>
191
196
  </DxcNavTabs>
@@ -255,16 +260,16 @@ export const Chromatic = () => (
255
260
  <Title title="With icon and notification number" theme="light" level={4} />
256
261
  <HalstackProvider theme={opinionatedTheme}>
257
262
  <DxcNavTabs>
258
- <DxcNavTabs.Tab href="#" active icon={iconSVG} notificationNumber>
263
+ <DxcNavTabs.Tab href="#" active icon={favoriteIcon} notificationNumber>
259
264
  Tab 1
260
265
  </DxcNavTabs.Tab>
261
- <DxcNavTabs.Tab href="#" disabled icon={iconSVG} notificationNumber={5}>
266
+ <DxcNavTabs.Tab href="#" disabled icon={favoriteIcon} notificationNumber={5}>
262
267
  Tab 2
263
268
  </DxcNavTabs.Tab>
264
- <DxcNavTabs.Tab href="#" icon={iconSVG} notificationNumber={120}>
269
+ <DxcNavTabs.Tab href="#" icon={favoriteIcon} notificationNumber={120}>
265
270
  Tab 3
266
271
  </DxcNavTabs.Tab>
267
- <DxcNavTabs.Tab href="#" icon={iconSVG}>
272
+ <DxcNavTabs.Tab href="#" icon={favoriteIcon} notificationNumber={12}>
268
273
  Tab 4
269
274
  </DxcNavTabs.Tab>
270
275
  </DxcNavTabs>
@@ -1,28 +1,23 @@
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 _NavTabs = _interopRequireDefault(require("./NavTabs.tsx"));
10
-
11
7
  describe("Tabs component tests", function () {
12
8
  test("Tabs render with correct labels and attributes", function () {
13
9
  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
-
10
+ href: "/test1",
11
+ active: true
12
+ }, "Tab 1"), /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
13
+ href: "/test2",
14
+ disabled: true
15
+ }, "Tab 2"), /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
16
+ href: "/test3"
17
+ }, "Tab 3"))),
18
+ getByText = _render.getByText,
19
+ getAllByRole = _render.getAllByRole,
20
+ getByRole = _render.getByRole;
26
21
  expect(getByRole("tablist")).toBeTruthy();
27
22
  expect(getByRole("tablist").getAttribute("aria-label")).toBe("Navigation tabs");
28
23
  expect(getByText("Tab 1")).toBeTruthy();
@@ -32,51 +27,51 @@ describe("Tabs component tests", function () {
32
27
  tabs.forEach(function (tab, index) {
33
28
  expect(tab.getAttribute("aria-selected")).toBe((index === 0).toString());
34
29
  });
35
- var anchors = getAllByRole("link");
36
- expect(anchors.length).toBe(2);
30
+ var anchors = getAllByRole("tab");
31
+ expect(anchors.length).toBe(3);
37
32
  expect(anchors[0].getAttribute("href")).toBe("/test1");
38
- expect(anchors[1].getAttribute("href")).toBe("/test3");
33
+ expect(anchors[1].getAttribute("href")).toBeFalsy();
34
+ expect(anchors[2].getAttribute("href")).toBe("/test3");
39
35
  expect(anchors[0].getAttribute("tabindex")).toBe("0");
40
36
  expect(anchors[1].getAttribute("tabindex")).toBe("-1");
37
+ expect(anchors[2].getAttribute("tabindex")).toBe("-1");
41
38
  });
42
39
  test("Tabs render with correct labels, badges and icons", function () {
43
40
  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
-
41
+ href: "/test1",
42
+ active: true,
43
+ notificationNumber: 10
44
+ }, "Tab 1"), /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
45
+ href: "/test2",
46
+ disabled: true,
47
+ notificationNumber: 20
48
+ }, "Tab 2"), /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
49
+ href: "/test3",
50
+ notificationNumber: 1000,
51
+ icon: "Settings"
52
+ }, "Tab 3"))),
53
+ getByText = _render2.getByText,
54
+ queryByText = _render2.queryByText;
59
55
  expect(getByText("10")).toBeTruthy();
60
- expect(getByText("20")).toBeTruthy();
56
+ expect(queryByText("20")).toBeFalsy();
61
57
  expect(getByText("+99")).toBeTruthy();
62
- expect(getByRole("img")).toBeTruthy();
63
58
  });
64
59
  test("Tabs render with correct tab index", function () {
65
60
  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");
61
+ tabIndex: 3
62
+ }, /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
63
+ href: "/test1"
64
+ }, "Tab 1"), /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
65
+ href: "/test2",
66
+ disabled: true
67
+ }, "Tab 2"), /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
68
+ href: "/test3",
69
+ active: true
70
+ }, "Tab 3"))),
71
+ getAllByRole = _render3.getAllByRole;
72
+ var tabs = getAllByRole("tab");
79
73
  expect(tabs[0].getAttribute("tabindex")).toBe("-1");
80
- expect(tabs[1].getAttribute("tabindex")).toBe("3");
74
+ expect(tabs[1].getAttribute("tabindex")).toBe("-1");
75
+ expect(tabs[2].getAttribute("tabindex")).toBe("3");
81
76
  });
82
77
  });
@@ -0,0 +1,3 @@
1
+ /// <reference types="react" />
2
+ import { NavTabsContextProps } from "./types";
3
+ export declare const NavTabsContext: import("react").Context<NavTabsContextProps>;
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.NavTabsContext = void 0;
7
+ var _react = require("react");
8
+ var NavTabsContext = exports.NavTabsContext = /*#__PURE__*/(0, _react.createContext)(null);
package/nav-tabs/Tab.js CHANGED
@@ -1,70 +1,49 @@
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
8
  exports["default"] = void 0;
11
-
12
9
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
-
14
10
  var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
15
-
16
11
  var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
17
-
18
12
  var _react = _interopRequireWildcard(require("react"));
19
-
20
13
  var _styledComponents = _interopRequireDefault(require("styled-components"));
21
-
22
14
  var _Badge = _interopRequireDefault(require("../badge/Badge"));
23
-
24
15
  var _Flex = _interopRequireDefault(require("../flex/Flex"));
25
-
26
- var _NavTabs = require("./NavTabs");
27
-
28
16
  var _BaseTypography = _interopRequireDefault(require("../utils/BaseTypography"));
29
-
30
17
  var _useTheme = _interopRequireDefault(require("../useTheme"));
31
-
18
+ var _NavTabsContext = require("./NavTabsContext");
19
+ var _Icon = _interopRequireDefault(require("../icon/Icon"));
32
20
  var _templateObject, _templateObject2, _templateObject3;
33
-
34
21
  var _excluded = ["href", "active", "icon", "disabled", "notificationNumber", "children"];
35
-
36
- 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); }
37
-
38
- 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; }
39
-
22
+ 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); }
23
+ 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; }
40
24
  var DxcTab = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, _ref2) {
41
25
  var href = _ref.href,
42
- _ref$active = _ref.active,
43
- active = _ref$active === void 0 ? false : _ref$active,
44
- icon = _ref.icon,
45
- _ref$disabled = _ref.disabled,
46
- disabled = _ref$disabled === void 0 ? false : _ref$disabled,
47
- _ref$notificationNumb = _ref.notificationNumber,
48
- notificationNumber = _ref$notificationNumb === void 0 ? false : _ref$notificationNumb,
49
- children = _ref.children,
50
- otherProps = (0, _objectWithoutProperties2["default"])(_ref, _excluded);
26
+ _ref$active = _ref.active,
27
+ active = _ref$active === void 0 ? false : _ref$active,
28
+ icon = _ref.icon,
29
+ _ref$disabled = _ref.disabled,
30
+ disabled = _ref$disabled === void 0 ? false : _ref$disabled,
31
+ _ref$notificationNumb = _ref.notificationNumber,
32
+ notificationNumber = _ref$notificationNumb === void 0 ? false : _ref$notificationNumb,
33
+ children = _ref.children,
34
+ otherProps = (0, _objectWithoutProperties2["default"])(_ref, _excluded);
51
35
  var tabRef = (0, _react.useRef)();
52
36
  var colorsTheme = (0, _useTheme["default"])();
53
-
54
- var _useContext = (0, _react.useContext)(_NavTabs.NavTabsContext),
55
- iconPosition = _useContext.iconPosition,
56
- tabIndex = _useContext.tabIndex,
57
- focusedLabel = _useContext.focusedLabel;
58
-
37
+ var _useContext = (0, _react.useContext)(_NavTabsContext.NavTabsContext),
38
+ iconPosition = _useContext.iconPosition,
39
+ tabIndex = _useContext.tabIndex,
40
+ focusedLabel = _useContext.focusedLabel;
59
41
  (0, _react.useEffect)(function () {
60
42
  var _tabRef$current;
61
-
62
43
  focusedLabel === children.toString() && (tabRef === null || tabRef === void 0 ? void 0 : (_tabRef$current = tabRef.current) === null || _tabRef$current === void 0 ? void 0 : _tabRef$current.focus());
63
44
  }, [focusedLabel]);
64
-
65
45
  var handleOnKeyDown = function handleOnKeyDown(event) {
66
46
  var _tabRef$current2;
67
-
68
47
  switch (event.key) {
69
48
  case " ":
70
49
  case "Enter":
@@ -73,12 +52,8 @@ var DxcTab = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, _ref2) {
73
52
  break;
74
53
  }
75
54
  };
76
-
77
55
  return /*#__PURE__*/_react["default"].createElement(TabContainer, {
78
- active: active,
79
- role: "tab",
80
- "aria-selected": active,
81
- "aria-disabled": disabled
56
+ active: active
82
57
  }, /*#__PURE__*/_react["default"].createElement(Tab, (0, _extends2["default"])({
83
58
  href: !disabled ? href : undefined,
84
59
  disabled: disabled,
@@ -87,17 +62,21 @@ var DxcTab = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, _ref2) {
87
62
  hasIcon: icon != null ? true : false,
88
63
  ref: function ref(anchorRef) {
89
64
  tabRef.current = anchorRef;
90
-
91
65
  if (_ref2) {
92
66
  if (typeof _ref2 === "function") _ref2(anchorRef);else _ref2.current = anchorRef;
93
67
  }
94
68
  },
95
69
  onKeyDown: handleOnKeyDown,
96
- tabIndex: active ? tabIndex : -1
70
+ tabIndex: active ? tabIndex : -1,
71
+ role: "tab",
72
+ "aria-selected": active,
73
+ "aria-disabled": disabled
97
74
  }, otherProps), icon && /*#__PURE__*/_react["default"].createElement(TabIconContainer, {
98
- iconPosition: iconPosition
99
- }, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement("img", {
100
- src: icon
75
+ iconPosition: iconPosition,
76
+ active: active,
77
+ disabled: disabled
78
+ }, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(_Icon["default"], {
79
+ icon: icon
101
80
  }) : icon), /*#__PURE__*/_react["default"].createElement(_Flex["default"], {
102
81
  alignItems: "center",
103
82
  gap: "0.5rem"
@@ -110,23 +89,16 @@ var DxcTab = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, _ref2) {
110
89
  textAlign: "center",
111
90
  letterSpacing: "0.025em",
112
91
  lineHeight: "1.715em"
113
- }, children), notificationNumber && /*#__PURE__*/_react["default"].createElement(_Badge["default"], {
114
- notificationText: typeof notificationNumber === "number" && notificationNumber > 99 ? "+99" : notificationNumber,
115
- disabled: disabled
92
+ }, children), notificationNumber && !disabled && /*#__PURE__*/_react["default"].createElement(_Badge["default"], {
93
+ mode: "notification",
94
+ size: "small",
95
+ label: typeof notificationNumber === "number" && notificationNumber
116
96
  }))));
117
97
  });
118
-
119
- var TabContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n align-items: stretch;\n border-bottom: 2px solid ", ";\n padding: 0.5rem;\n\n svg {\n color: ", ";\n }\n &[aria-selected=\"true\"] {\n svg {\n color: ", ";\n }\n }\n &[aria-disabled=\"true\"] {\n svg {\n color: ", ";\n }\n }\n"])), function (props) {
120
- return props.active ? props.theme.selectedUnderlineColor : props.theme.dividerColor;
121
- }, function (props) {
122
- return props.theme.unselectedIconColor;
123
- }, function (props) {
124
- return props.theme.selectedIconColor;
125
- }, function (props) {
126
- return props.theme.disabledIconColor;
98
+ var TabContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n align-items: stretch;\n border-bottom: 2px solid ", ";\n padding: 0.5rem;\n z-index: 1;\n"])), function (props) {
99
+ return props.active ? props.theme.selectedUnderlineColor : "transparent";
127
100
  });
128
-
129
- var Tab = _styledComponents["default"].a(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: flex;\n flex-direction: ", ";\n justify-content: center;\n align-items: center;\n gap: ", ";\n height: ", ";\n min-width: 176px;\n min-height: 44px;\n padding: 0.375rem;\n border-radius: 4px;\n background: ", ";\n text-decoration-color: transparent;\n cursor: ", ";\n\n ", "\n"])), function (props) {
101
+ var Tab = _styledComponents["default"].a(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: flex;\n flex-direction: ", ";\n justify-content: center;\n align-items: center;\n gap: ", ";\n height: ", ";\n min-width: 176px;\n min-height: 44px;\n padding: 0.375rem;\n border-radius: 4px;\n background: ", ";\n text-decoration-color: transparent;\n text-decoration-line: none;\n cursor: ", ";\n\n ", "\n"])), function (props) {
130
102
  return props.hasIcon && props.iconPosition === "top" ? "column" : "row";
131
103
  }, function (props) {
132
104
  return props.hasIcon && props.iconPosition === "top" ? "0.375rem" : "0.625rem";
@@ -139,8 +111,7 @@ var Tab = _styledComponents["default"].a(_templateObject2 || (_templateObject2 =
139
111
  }, function (props) {
140
112
  return !props.disabled && "\n :hover {\n background: ".concat(props.theme.hoverBackgroundColor, ";\n }\n :focus {\n outline: 2px solid ").concat(props.theme.focusOutline, ";\n }\n :active {\n background: ").concat(props.theme.pressedBackgroundColor, ";\n outline: 2px solid #33aaff};\n }\n ");
141
113
  });
142
-
143
- var TabIconContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n\n img,\n svg {\n height: 24px;\n width: 24px;\n }\n"])));
144
-
145
- var _default = DxcTab;
146
- exports["default"] = _default;
114
+ var TabIconContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n font-size: 24px;\n color: ", ";\n svg {\n height: 24px;\n width: 24px;\n }\n"])), function (props) {
115
+ return props.active ? props.theme.selectedIconColor : props.disabled ? props.theme.disabledIconColor : props.theme.unselectedIconColor;
116
+ });
117
+ var _default = exports["default"] = DxcTab;
@@ -1,11 +1,11 @@
1
1
  /// <reference types="react" />
2
- declare type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
3
- export declare type NavTabsContextProps = {
2
+ type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
3
+ export type NavTabsContextProps = {
4
4
  iconPosition: "top" | "left";
5
5
  tabIndex: number;
6
6
  focusedLabel: string;
7
7
  };
8
- export declare type TabProps = {
8
+ export type TabProps = {
9
9
  /**
10
10
  * Whether the tab is active or not.
11
11
  */
@@ -19,7 +19,7 @@ export declare type TabProps = {
19
19
  */
20
20
  href?: string;
21
21
  /**
22
- * Element or path used as the icon that will be displayed in the tab.
22
+ * Material Symbol name or SVG element used as the icon that will be displayed in the tab.
23
23
  */
24
24
  icon?: string | SVG;
25
25
  /**
@@ -31,22 +31,22 @@ export declare type TabProps = {
31
31
  */
32
32
  notificationNumber?: boolean | number;
33
33
  /**
34
- * Contains one or more DxcNavTabs.Tab.
34
+ * Tab text label.
35
35
  */
36
36
  children: string;
37
37
  };
38
- declare type Props = {
38
+ type Props = {
39
39
  /**
40
40
  * Whether the icon should appear above or to the left of the label.
41
41
  */
42
42
  iconPosition?: "top" | "left";
43
43
  /**
44
- * Value of the tabindex for each tab.
44
+ * Contains one or more DxcNavTabs.Tab.
45
45
  */
46
- tabIndex?: number;
46
+ children: React.ReactNode;
47
47
  /**
48
- * Content of the tabs nav.
48
+ * Value of the tabindex attribute applied to each tab.
49
49
  */
50
- children: React.ReactNode;
50
+ tabIndex?: number;
51
51
  };
52
52
  export default Props;