@dxc-technology/halstack-react 0.0.0-ecc45e2 → 0.0.0-ede733c

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 (216) hide show
  1. package/BackgroundColorContext.d.ts +2 -2
  2. package/BackgroundColorContext.js +1 -1
  3. package/HalstackContext.d.ts +1329 -5
  4. package/HalstackContext.js +117 -77
  5. package/accordion/Accordion.js +118 -110
  6. package/accordion/Accordion.stories.tsx +103 -15
  7. package/accordion/Accordion.test.js +10 -11
  8. package/accordion/types.d.ts +1 -0
  9. package/accordion-group/AccordionGroup.d.ts +4 -3
  10. package/accordion-group/AccordionGroup.js +24 -65
  11. package/accordion-group/AccordionGroup.stories.tsx +27 -1
  12. package/accordion-group/AccordionGroup.test.js +21 -46
  13. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  14. package/accordion-group/AccordionGroupAccordion.js +43 -0
  15. package/accordion-group/types.d.ts +7 -0
  16. package/alert/Alert.js +5 -9
  17. package/alert/Alert.stories.tsx +28 -0
  18. package/alert/Alert.test.js +1 -1
  19. package/bleed/Bleed.stories.tsx +1 -0
  20. package/box/Box.js +4 -6
  21. package/box/Box.stories.tsx +15 -0
  22. package/box/Box.test.js +1 -1
  23. package/box/types.d.ts +1 -0
  24. package/bulleted-list/BulletedList.js +4 -2
  25. package/bulleted-list/BulletedList.stories.tsx +7 -1
  26. package/bulleted-list/types.d.ts +31 -4
  27. package/button/Button.js +13 -16
  28. package/button/Button.stories.tsx +151 -9
  29. package/button/Button.test.js +1 -1
  30. package/button/types.d.ts +3 -3
  31. package/card/Card.js +12 -13
  32. package/card/Card.stories.tsx +12 -13
  33. package/card/Card.test.js +1 -1
  34. package/card/types.d.ts +1 -0
  35. package/checkbox/Checkbox.d.ts +2 -2
  36. package/checkbox/Checkbox.js +94 -101
  37. package/checkbox/Checkbox.stories.tsx +131 -59
  38. package/checkbox/Checkbox.test.js +94 -17
  39. package/checkbox/types.d.ts +4 -0
  40. package/chip/Chip.js +28 -49
  41. package/chip/Chip.stories.tsx +121 -26
  42. package/chip/Chip.test.js +3 -5
  43. package/common/OpenSans.css +68 -80
  44. package/common/coreTokens.d.ts +146 -0
  45. package/common/coreTokens.js +167 -0
  46. package/common/utils.d.ts +1 -0
  47. package/common/utils.js +4 -4
  48. package/common/variables.d.ts +1482 -0
  49. package/common/variables.js +994 -1137
  50. package/date-input/Calendar.d.ts +4 -0
  51. package/date-input/Calendar.js +258 -0
  52. package/date-input/DateInput.js +134 -237
  53. package/date-input/DateInput.stories.tsx +199 -33
  54. package/date-input/DateInput.test.js +494 -138
  55. package/date-input/DatePicker.d.ts +4 -0
  56. package/date-input/DatePicker.js +146 -0
  57. package/date-input/Icons.d.ts +6 -0
  58. package/date-input/Icons.js +75 -0
  59. package/date-input/YearPicker.d.ts +4 -0
  60. package/date-input/YearPicker.js +126 -0
  61. package/date-input/types.d.ts +51 -0
  62. package/dialog/Dialog.js +60 -73
  63. package/dialog/Dialog.stories.tsx +229 -121
  64. package/dialog/Dialog.test.js +302 -3
  65. package/dialog/types.d.ts +3 -2
  66. package/dropdown/Dropdown.js +43 -42
  67. package/dropdown/Dropdown.stories.tsx +210 -84
  68. package/dropdown/Dropdown.test.js +22 -27
  69. package/dropdown/DropdownMenu.js +12 -18
  70. package/dropdown/DropdownMenuItem.js +5 -18
  71. package/dropdown/types.d.ts +3 -3
  72. package/file-input/FileInput.d.ts +2 -2
  73. package/file-input/FileInput.js +174 -220
  74. package/file-input/FileInput.stories.tsx +122 -11
  75. package/file-input/FileInput.test.js +14 -14
  76. package/file-input/FileItem.d.ts +4 -14
  77. package/file-input/FileItem.js +39 -63
  78. package/file-input/types.d.ts +17 -0
  79. package/flex/Flex.d.ts +1 -1
  80. package/flex/Flex.js +33 -19
  81. package/flex/Flex.stories.tsx +35 -26
  82. package/flex/types.d.ts +83 -7
  83. package/footer/Footer.js +6 -8
  84. package/footer/Footer.stories.tsx +99 -1
  85. package/footer/Footer.test.js +14 -26
  86. package/footer/types.d.ts +1 -0
  87. package/grid/Grid.d.ts +7 -0
  88. package/grid/Grid.js +91 -0
  89. package/grid/Grid.stories.tsx +219 -0
  90. package/grid/types.d.ts +115 -0
  91. package/header/Header.d.ts +3 -2
  92. package/header/Header.js +21 -23
  93. package/header/Header.stories.tsx +152 -9
  94. package/header/Header.test.js +2 -2
  95. package/header/types.d.ts +3 -2
  96. package/heading/Heading.js +1 -1
  97. package/heading/Heading.test.js +1 -1
  98. package/inset/Inset.stories.tsx +2 -1
  99. package/layout/ApplicationLayout.d.ts +3 -3
  100. package/layout/ApplicationLayout.js +1 -1
  101. package/layout/ApplicationLayout.stories.tsx +1 -0
  102. package/layout/types.d.ts +2 -3
  103. package/link/Link.js +4 -4
  104. package/link/Link.stories.tsx +60 -0
  105. package/link/Link.test.js +2 -4
  106. package/link/types.d.ts +2 -2
  107. package/main.d.ts +3 -2
  108. package/main.js +9 -1
  109. package/{tabs-nav → nav-tabs}/NavTabs.js +1 -1
  110. package/{tabs-nav → nav-tabs}/NavTabs.stories.tsx +96 -6
  111. package/{tabs-nav → nav-tabs}/NavTabs.test.js +1 -1
  112. package/{tabs-nav → nav-tabs}/Tab.js +38 -18
  113. package/nav-tabs/types.js +5 -0
  114. package/number-input/NumberInput.test.js +44 -8
  115. package/package.json +15 -20
  116. package/paginator/Icons.d.ts +5 -0
  117. package/paginator/Icons.js +16 -28
  118. package/paginator/Paginator.js +7 -15
  119. package/paginator/Paginator.stories.tsx +24 -0
  120. package/paginator/Paginator.test.js +45 -48
  121. package/paragraph/Paragraph.d.ts +3 -4
  122. package/paragraph/Paragraph.js +5 -5
  123. package/password-input/PasswordInput.test.js +14 -13
  124. package/progress-bar/ProgressBar.d.ts +2 -2
  125. package/progress-bar/ProgressBar.js +5 -5
  126. package/progress-bar/ProgressBar.stories.jsx +35 -2
  127. package/progress-bar/ProgressBar.test.js +1 -1
  128. package/progress-bar/types.d.ts +4 -3
  129. package/quick-nav/QuickNav.js +11 -12
  130. package/quick-nav/QuickNav.stories.tsx +111 -19
  131. package/radio-group/Radio.d.ts +1 -1
  132. package/radio-group/Radio.js +43 -28
  133. package/radio-group/RadioGroup.js +15 -13
  134. package/radio-group/RadioGroup.stories.tsx +132 -18
  135. package/radio-group/RadioGroup.test.js +124 -97
  136. package/radio-group/types.d.ts +2 -2
  137. package/resultsetTable/Icons.d.ts +7 -0
  138. package/resultsetTable/Icons.js +51 -0
  139. package/resultsetTable/ResultsetTable.js +49 -108
  140. package/resultsetTable/ResultsetTable.stories.tsx +50 -25
  141. package/resultsetTable/ResultsetTable.test.js +41 -64
  142. package/resultsetTable/types.d.ts +1 -1
  143. package/select/Listbox.d.ts +1 -1
  144. package/select/Listbox.js +5 -35
  145. package/select/Option.js +11 -24
  146. package/select/Select.js +59 -36
  147. package/select/Select.stories.tsx +494 -150
  148. package/select/Select.test.js +341 -288
  149. package/select/types.d.ts +2 -2
  150. package/sidenav/Icons.d.ts +7 -0
  151. package/sidenav/Icons.js +51 -0
  152. package/sidenav/Sidenav.d.ts +2 -2
  153. package/sidenav/Sidenav.js +66 -96
  154. package/sidenav/Sidenav.stories.tsx +165 -63
  155. package/sidenav/types.d.ts +21 -18
  156. package/slider/Slider.d.ts +2 -2
  157. package/slider/Slider.js +119 -95
  158. package/slider/Slider.stories.tsx +64 -1
  159. package/slider/Slider.test.js +88 -25
  160. package/slider/types.d.ts +4 -0
  161. package/spinner/Spinner.js +17 -23
  162. package/spinner/Spinner.stories.jsx +53 -27
  163. package/spinner/Spinner.test.js +1 -1
  164. package/switch/Switch.d.ts +3 -3
  165. package/switch/Switch.js +96 -85
  166. package/switch/Switch.stories.tsx +33 -0
  167. package/switch/Switch.test.js +27 -14
  168. package/switch/types.d.ts +8 -3
  169. package/table/Table.js +3 -3
  170. package/table/Table.stories.jsx +80 -1
  171. package/table/Table.test.js +2 -2
  172. package/tabs/Tab.d.ts +4 -0
  173. package/tabs/Tab.js +132 -0
  174. package/tabs/Tabs.js +358 -108
  175. package/tabs/Tabs.stories.tsx +119 -5
  176. package/tabs/Tabs.test.js +220 -10
  177. package/tabs/types.d.ts +12 -2
  178. package/tag/Tag.js +8 -10
  179. package/tag/Tag.stories.tsx +14 -1
  180. package/tag/Tag.test.js +1 -1
  181. package/text-input/Icons.d.ts +8 -0
  182. package/text-input/Icons.js +60 -0
  183. package/text-input/Suggestion.js +40 -11
  184. package/text-input/Suggestions.d.ts +4 -0
  185. package/text-input/Suggestions.js +134 -0
  186. package/text-input/TextInput.js +189 -277
  187. package/text-input/TextInput.stories.tsx +280 -184
  188. package/text-input/TextInput.test.js +736 -725
  189. package/text-input/types.d.ts +21 -2
  190. package/textarea/Textarea.js +3 -4
  191. package/textarea/Textarea.stories.jsx +60 -1
  192. package/textarea/Textarea.test.js +2 -4
  193. package/toggle-group/ToggleGroup.d.ts +2 -2
  194. package/toggle-group/ToggleGroup.js +7 -4
  195. package/toggle-group/ToggleGroup.stories.tsx +42 -0
  196. package/toggle-group/ToggleGroup.test.js +1 -1
  197. package/toggle-group/types.d.ts +1 -1
  198. package/typography/Typography.d.ts +2 -2
  199. package/typography/Typography.js +14 -113
  200. package/typography/Typography.stories.tsx +1 -1
  201. package/useTheme.d.ts +1234 -1
  202. package/useTheme.js +1 -1
  203. package/useTranslatedLabels.d.ts +84 -1
  204. package/utils/BaseTypography.d.ts +21 -0
  205. package/utils/BaseTypography.js +108 -0
  206. package/utils/FocusLock.d.ts +13 -0
  207. package/utils/FocusLock.js +138 -0
  208. package/wizard/Wizard.js +2 -2
  209. package/wizard/Wizard.stories.tsx +20 -0
  210. package/wizard/Wizard.test.js +1 -1
  211. package/wizard/types.d.ts +5 -6
  212. package/common/RequiredComponent.js +0 -32
  213. /package/{tabs-nav → grid}/types.js +0 -0
  214. /package/{tabs-nav → nav-tabs}/NavTabs.d.ts +0 -0
  215. /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
  216. /package/{tabs-nav → nav-tabs}/types.d.ts +0 -0
@@ -2,6 +2,7 @@ import React from "react";
2
2
  import DxcTabs from "./Tabs";
3
3
  import Title from "../../.storybook/components/Title";
4
4
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
5
+ import { HalstackProvider } from "../HalstackContext";
5
6
 
6
7
  export default {
7
8
  title: "Tabs",
@@ -9,9 +10,8 @@ export default {
9
10
  };
10
11
 
11
12
  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" />
13
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20" height="20" width="20" fill="currentColor">
14
+ <path d="m10 17-1.042-.938q-2.083-1.854-3.437-3.177-1.354-1.323-2.136-2.354Q2.604 9.5 2.302 8.646 2 7.792 2 6.896q0-1.854 1.271-3.125T6.396 2.5q1.021 0 1.979.438.958.437 1.625 1.229.667-.792 1.625-1.229.958-.438 1.979-.438 1.854 0 3.125 1.271T18 6.896q0 .896-.292 1.729-.291.833-1.073 1.854-.781 1.021-2.145 2.365-1.365 1.344-3.49 3.26Zm0-2.021q1.938-1.729 3.188-2.948 1.25-1.219 1.989-2.125.74-.906 1.031-1.614.292-.709.292-1.396 0-1.229-.833-2.063Q14.833 4 13.604 4q-.729 0-1.364.302-.636.302-1.094.844L10.417 6h-.834l-.729-.854q-.458-.542-1.114-.844Q7.083 4 6.396 4q-1.229 0-2.063.833-.833.834-.833 2.063 0 .687.271 1.364.271.678.989 1.573.719.896 1.98 2.125Q8 13.188 10 14.979Zm0-5.5Z" />
15
15
  </svg>
16
16
  );
17
17
 
@@ -29,6 +29,44 @@ const tabs: any = [
29
29
  {
30
30
  label: "Tab 4",
31
31
  },
32
+ {
33
+ label: "Tab 5",
34
+ },
35
+ {
36
+ label: "Tab 6",
37
+ },
38
+ {
39
+ label: "Tab 7",
40
+ },
41
+ ];
42
+
43
+ const disabledTabs: any = [
44
+ {
45
+ label: "Tab 1",
46
+ isDisabled: true,
47
+ },
48
+ {
49
+ label: "Tab 2",
50
+ isDisabled: true,
51
+ },
52
+ {
53
+ label: "Tab 3",
54
+ isDisabled: true,
55
+ },
56
+ ];
57
+
58
+ const firstDisabledTabs: any = [
59
+ {
60
+ label: "Tab 1",
61
+ isDisabled: true,
62
+ },
63
+ {
64
+ label: "Tab 2",
65
+ isDisabled: true,
66
+ },
67
+ {
68
+ label: "Tab 3",
69
+ },
32
70
  ];
33
71
 
34
72
  const tabsNotification = tabs.map((tab, index) => ({
@@ -36,16 +74,34 @@ const tabsNotification = tabs.map((tab, index) => ({
36
74
  notificationNumber: (index === 0 && true) || (index === 1 && 5) || (index === 2 && 200),
37
75
  }));
38
76
 
39
- const tabsIcon = tabs.map((tab) => ({ ...tab, icon: iconSVG }));
77
+ const tabsIcon = tabs.map((tab, index) =>
78
+ index <= tabs.length / 2
79
+ ? { ...tab, icon: "https://cdn-icons-png.flaticon.com/512/5039/5039041.png" }
80
+ : { ...tab, icon: iconSVG }
81
+ );
40
82
 
41
83
  const tabsNotificationIcon = tabsNotification.map((tab) => ({ ...tab, icon: iconSVG }));
42
84
 
85
+ const opinionatedTheme = {
86
+ tabs: {
87
+ baseColor: "#5f249f",
88
+ },
89
+ };
90
+
43
91
  export const Chromatic = () => (
44
92
  <>
45
93
  <ExampleContainer>
46
94
  <Title title="Only label" theme="light" level={4} />
47
95
  <DxcTabs tabs={tabs} />
48
96
  </ExampleContainer>
97
+ <ExampleContainer>
98
+ <Title title="Disabled tabs" theme="light" level={4} />
99
+ <DxcTabs activeTabIndex={0} tabs={disabledTabs} />
100
+ </ExampleContainer>
101
+ <ExampleContainer>
102
+ <Title title="First two tabs disabled" theme="light" level={4} />
103
+ <DxcTabs tabs={firstDisabledTabs} />
104
+ </ExampleContainer>
49
105
  <ExampleContainer pseudoState="pseudo-hover">
50
106
  <Title title="Hovered tabs" theme="light" level={4} />
51
107
  <DxcTabs tabs={tabs} />
@@ -106,7 +162,65 @@ export const Chromatic = () => (
106
162
  <ExampleContainer>
107
163
  <Title title="Xxlarge margin" theme="light" level={4} />
108
164
  <DxcTabs tabs={tabs} margin="xxlarge" />
109
- <hr />
165
+ </ExampleContainer>
166
+ <Title title="Opinionated theme" theme="light" level={2} />
167
+ <ExampleContainer>
168
+ <Title title="With icon and notification" theme="light" level={4} />
169
+ <HalstackProvider theme={opinionatedTheme}>
170
+ <DxcTabs tabs={tabsNotificationIcon} />
171
+ </HalstackProvider>
172
+ </ExampleContainer>
173
+ <ExampleContainer>
174
+ <Title title="Disabled" theme="light" level={4} />
175
+ <HalstackProvider theme={opinionatedTheme}>
176
+ <DxcTabs activeTabIndex={0} tabs={disabledTabs} />
177
+ </HalstackProvider>
178
+ </ExampleContainer>
179
+ <ExampleContainer pseudoState="pseudo-hover">
180
+ <Title title="Hovered" theme="light" level={4} />
181
+ <HalstackProvider theme={opinionatedTheme}>
182
+ <DxcTabs tabs={tabs} />
183
+ </HalstackProvider>
184
+ </ExampleContainer>
185
+ <ExampleContainer pseudoState="pseudo-focus">
186
+ <Title title="Focused" theme="light" level={4} />
187
+ <HalstackProvider theme={opinionatedTheme}>
188
+ <DxcTabs tabs={tabs} />
189
+ </HalstackProvider>
190
+ </ExampleContainer>
191
+ <ExampleContainer pseudoState="pseudo-active">
192
+ <Title title="Actived" theme="light" level={4} />
193
+ <HalstackProvider theme={opinionatedTheme}>
194
+ <DxcTabs tabs={tabs} />
195
+ </HalstackProvider>
110
196
  </ExampleContainer>
111
197
  </>
112
198
  );
199
+
200
+ export const ScrollableTabs = () => (
201
+ <>
202
+ <ExampleContainer>
203
+ <Title title="Only label" theme="light" level={4} />
204
+ <DxcTabs tabs={tabs} />
205
+ </ExampleContainer>
206
+ <ExampleContainer pseudoState="pseudo-hover">
207
+ <Title title="Hovered tabs" theme="light" level={4} />
208
+ <DxcTabs tabs={tabs} />
209
+ </ExampleContainer>
210
+ <ExampleContainer pseudoState="pseudo-focus">
211
+ <Title title="Focused tabs" theme="light" level={4} />
212
+ <DxcTabs tabs={tabs} />
213
+ </ExampleContainer>
214
+ <ExampleContainer pseudoState="pseudo-active">
215
+ <Title title="Actived tabs" theme="light" level={4} />
216
+ <DxcTabs tabs={tabs} />
217
+ </ExampleContainer>
218
+ </>
219
+ );
220
+
221
+ ScrollableTabs.parameters = {
222
+ viewport: {
223
+ defaultViewport: "iphonex",
224
+ },
225
+ chromatic: { viewports: [375], delay: 5000 },
226
+ };
package/tabs/Tabs.test.js CHANGED
@@ -6,7 +6,7 @@ var _react = _interopRequireDefault(require("react"));
6
6
 
7
7
  var _react2 = require("@testing-library/react");
8
8
 
9
- var _Tabs = _interopRequireDefault(require("./Tabs"));
9
+ var _Tabs = _interopRequireDefault(require("./Tabs.tsx"));
10
10
 
11
11
  var sampleTabs = [{
12
12
  label: "Tab-1"
@@ -17,13 +17,30 @@ var sampleTabs = [{
17
17
  }];
18
18
  var sampleTabsWithBadge = [{
19
19
  label: "Tab-1",
20
- notificationNumber: "10"
20
+ notificationNumber: 10
21
21
  }, {
22
22
  label: "Tab-2",
23
- notificationNumber: "20"
23
+ notificationNumber: 20
24
24
  }, {
25
25
  label: "Tab-3",
26
- notificationNumber: "101"
26
+ notificationNumber: 101
27
+ }];
28
+ var sampleTabsMiddleDisabled = [{
29
+ label: "Tab-1"
30
+ }, {
31
+ label: "Tab-2",
32
+ isDisabled: true
33
+ }, {
34
+ label: "Tab-3"
35
+ }];
36
+ var sampleTabsLastTabNonDisabled = [{
37
+ label: "Tab-1",
38
+ isDisabled: true
39
+ }, {
40
+ label: "Tab-2",
41
+ isDisabled: true
42
+ }, {
43
+ label: "Tab-3"
27
44
  }];
28
45
  describe("Tabs component tests", function () {
29
46
  test("Tabs render with correct labels", function () {
@@ -103,18 +120,26 @@ describe("Tabs component tests", function () {
103
120
  tabs: sampleTabs,
104
121
  onTabClick: onTabClick
105
122
  })),
106
- getByText = _render6.getByText;
123
+ getByText = _render6.getByText,
124
+ getAllByRole = _render6.getAllByRole;
107
125
 
126
+ var tabs = getAllByRole("tab");
108
127
  var tab1 = getByText("Tab-1");
109
128
  var tab2 = getByText("Tab-2");
110
129
 
111
130
  _react2.fireEvent.click(tab2);
112
131
 
113
132
  expect(onTabClick).toHaveBeenCalledWith(1);
133
+ expect(tabs[0].getAttribute("aria-selected")).toBe("false");
134
+ expect(tabs[1].getAttribute("aria-selected")).toBe("true");
135
+ expect(tabs[2].getAttribute("aria-selected")).toBe("false");
114
136
 
115
137
  _react2.fireEvent.click(tab1);
116
138
 
117
139
  expect(onTabClick).toHaveBeenCalledWith(0);
140
+ expect(tabs[0].getAttribute("aria-selected")).toBe("true");
141
+ expect(tabs[1].getAttribute("aria-selected")).toBe("false");
142
+ expect(tabs[2].getAttribute("aria-selected")).toBe("false");
118
143
  });
119
144
  test("Controlled tabs", function () {
120
145
  var onTabClick = jest.fn();
@@ -124,17 +149,202 @@ describe("Tabs component tests", function () {
124
149
  onTabClick: onTabClick,
125
150
  activeTabIndex: 0
126
151
  })),
127
- getByText = _render7.getByText;
152
+ getAllByRole = _render7.getAllByRole;
128
153
 
129
- var tab2 = getByText("Tab-2");
130
- var tab3 = getByText("Tab-3");
154
+ var tabs = getAllByRole("tab");
131
155
 
132
- _react2.fireEvent.click(tab2);
156
+ _react2.fireEvent.click(tabs[1]);
157
+
158
+ expect(onTabClick).toHaveBeenCalledWith(1);
159
+ expect(tabs[0].getAttribute("aria-selected")).toBe("true");
160
+ expect(tabs[1].getAttribute("aria-selected")).toBe("false");
161
+ expect(tabs[2].getAttribute("aria-selected")).toBe("false");
162
+
163
+ _react2.fireEvent.click(tabs[2]);
164
+
165
+ expect(onTabClick).toHaveBeenCalledWith(2);
166
+ expect(tabs[0].getAttribute("aria-selected")).toBe("true");
167
+ expect(tabs[1].getAttribute("aria-selected")).toBe("false");
168
+ expect(tabs[2].getAttribute("aria-selected")).toBe("false");
169
+ });
170
+ test("Uncontrolled tabs should have focus in the first non-disabled tab", function () {
171
+ var onTabClick = jest.fn();
172
+
173
+ var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tabs["default"], {
174
+ tabs: sampleTabsLastTabNonDisabled,
175
+ onTabClick: onTabClick
176
+ })),
177
+ getAllByRole = _render8.getAllByRole;
178
+
179
+ var tabs = getAllByRole("tab");
180
+ expect(tabs[0].hasAttribute("disabled")).toBeTruthy();
181
+ expect(tabs[1].hasAttribute("disabled")).toBeTruthy();
182
+ expect(tabs[2].hasAttribute("disabled")).toBeFalsy();
183
+ expect(tabs[0].getAttribute("aria-selected")).toBe("false");
184
+ expect(tabs[1].getAttribute("aria-selected")).toBe("false");
185
+ expect(tabs[2].getAttribute("aria-selected")).toBe("true");
186
+ });
187
+ test("Controlled tabs with active index in disabled tab should not change focus to the first available tab", function () {
188
+ var onTabClick = jest.fn();
189
+
190
+ var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tabs["default"], {
191
+ tabs: sampleTabsLastTabNonDisabled,
192
+ onTabClick: onTabClick,
193
+ activeTabIndex: 0
194
+ })),
195
+ getAllByRole = _render9.getAllByRole;
196
+
197
+ var tabs = getAllByRole("tab");
198
+ expect(tabs[0].getAttribute("aria-selected")).toBe("true");
199
+ expect(tabs[1].getAttribute("aria-selected")).toBe("false");
200
+ expect(tabs[2].getAttribute("aria-selected")).toBe("false");
201
+ expect(tabs[0].hasAttribute("disabled")).toBeTruthy();
202
+ expect(tabs[1].hasAttribute("disabled")).toBeTruthy();
203
+ expect(tabs[2].hasAttribute("disabled")).toBeFalsy();
204
+
205
+ _react2.fireEvent.click(tabs[2]);
206
+
207
+ expect(onTabClick).toHaveBeenCalledWith(2);
208
+ expect(tabs[0].getAttribute("aria-selected")).toBe("true");
209
+ expect(tabs[1].getAttribute("aria-selected")).toBe("false");
210
+ expect(tabs[2].getAttribute("aria-selected")).toBe("false");
211
+ expect(tabs[0].hasAttribute("disabled")).toBeTruthy();
212
+ expect(tabs[1].hasAttribute("disabled")).toBeTruthy();
213
+ expect(tabs[2].hasAttribute("disabled")).toBeFalsy();
214
+ });
215
+ test("Select tabs with keyboard event arrows", function () {
216
+ var onTabClick = jest.fn();
217
+
218
+ var _render10 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tabs["default"], {
219
+ tabs: sampleTabs,
220
+ onTabClick: onTabClick
221
+ })),
222
+ getByText = _render10.getByText,
223
+ getByRole = _render10.getByRole,
224
+ getAllByRole = _render10.getAllByRole;
225
+
226
+ var tabList = getByRole("tablist");
227
+ var tab1 = getByText("Tab-1");
228
+ var tabs = getAllByRole("tab");
229
+
230
+ _react2.fireEvent.click(tab1);
231
+
232
+ expect(tabs[0].getAttribute("aria-selected")).toBe("true");
233
+ expect(tabs[1].getAttribute("aria-selected")).toBe("false");
234
+ expect(tabs[2].getAttribute("aria-selected")).toBe("false");
235
+ expect(onTabClick).toHaveBeenCalledWith(0);
133
236
 
237
+ _react2.fireEvent.keyDown(tabList, {
238
+ key: "ArrowRight"
239
+ });
240
+
241
+ _react2.fireEvent.keyDown(tabList, {
242
+ key: "Enter"
243
+ });
244
+
245
+ expect(tabs[0].getAttribute("aria-selected")).toBe("false");
246
+ expect(tabs[1].getAttribute("aria-selected")).toBe("true");
247
+ expect(tabs[2].getAttribute("aria-selected")).toBe("false");
134
248
  expect(onTabClick).toHaveBeenCalledWith(1);
135
249
 
136
- _react2.fireEvent.click(tab3);
250
+ _react2.fireEvent.keyDown(tabList, {
251
+ key: "ArrowRight"
252
+ });
253
+
254
+ _react2.fireEvent.keyDown(tabList, {
255
+ key: "Enter"
256
+ });
257
+
258
+ expect(tabs[0].getAttribute("aria-selected")).toBe("false");
259
+ expect(tabs[1].getAttribute("aria-selected")).toBe("false");
260
+ expect(tabs[2].getAttribute("aria-selected")).toBe("true");
261
+ expect(onTabClick).toHaveBeenCalledWith(2);
262
+
263
+ _react2.fireEvent.keyDown(tabList, {
264
+ key: "ArrowLeft"
265
+ });
266
+
267
+ _react2.fireEvent.keyDown(tabList, {
268
+ key: "Enter"
269
+ });
270
+
271
+ expect(tabs[0].getAttribute("aria-selected")).toBe("false");
272
+ expect(tabs[1].getAttribute("aria-selected")).toBe("true");
273
+ expect(tabs[2].getAttribute("aria-selected")).toBe("false");
274
+ expect(onTabClick).toHaveBeenCalledWith(1);
275
+
276
+ _react2.fireEvent.keyDown(tabList, {
277
+ key: "ArrowLeft"
278
+ });
279
+
280
+ _react2.fireEvent.keyDown(tabList, {
281
+ key: "Enter"
282
+ });
283
+
284
+ expect(tabs[0].getAttribute("aria-selected")).toBe("true");
285
+ expect(tabs[1].getAttribute("aria-selected")).toBe("false");
286
+ expect(tabs[2].getAttribute("aria-selected")).toBe("false");
287
+ expect(onTabClick).toHaveBeenCalledWith(0);
288
+
289
+ _react2.fireEvent.keyDown(tabList, {
290
+ key: "ArrowLeft"
291
+ });
137
292
 
293
+ _react2.fireEvent.keyDown(tabList, {
294
+ key: "Enter"
295
+ });
296
+
297
+ expect(tabs[0].getAttribute("aria-selected")).toBe("false");
298
+ expect(tabs[1].getAttribute("aria-selected")).toBe("false");
299
+ expect(tabs[2].getAttribute("aria-selected")).toBe("true");
300
+ expect(onTabClick).toHaveBeenCalledWith(2);
301
+
302
+ _react2.fireEvent.keyDown(tabList, {
303
+ key: "ArrowRight"
304
+ });
305
+
306
+ _react2.fireEvent.keyDown(tabList, {
307
+ key: "Enter"
308
+ });
309
+
310
+ expect(tabs[0].getAttribute("aria-selected")).toBe("true");
311
+ expect(tabs[1].getAttribute("aria-selected")).toBe("false");
312
+ expect(tabs[2].getAttribute("aria-selected")).toBe("false");
313
+ expect(onTabClick).toHaveBeenCalledWith(0);
314
+ });
315
+ test("Skip disabled tab with keyboard event arrows", function () {
316
+ var onTabClick = jest.fn();
317
+
318
+ var _render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tabs["default"], {
319
+ tabs: sampleTabsMiddleDisabled,
320
+ onTabClick: onTabClick
321
+ })),
322
+ getByText = _render11.getByText,
323
+ getByRole = _render11.getByRole,
324
+ getAllByRole = _render11.getAllByRole;
325
+
326
+ var tabList = getByRole("tablist");
327
+ var tab1 = getByText("Tab-1");
328
+ var tabs = getAllByRole("tab");
329
+
330
+ _react2.fireEvent.click(tab1);
331
+
332
+ expect(tabs[0].getAttribute("aria-selected")).toBe("true");
333
+ expect(tabs[1].getAttribute("aria-selected")).toBe("false");
334
+ expect(tabs[2].getAttribute("aria-selected")).toBe("false");
335
+ expect(onTabClick).toHaveBeenCalledWith(0);
336
+
337
+ _react2.fireEvent.keyDown(tabList, {
338
+ key: "ArrowRight"
339
+ });
340
+
341
+ _react2.fireEvent.keyDown(tabList, {
342
+ key: " "
343
+ });
344
+
345
+ expect(tabs[0].getAttribute("aria-selected")).toBe("false");
346
+ expect(tabs[1].getAttribute("aria-selected")).toBe("false");
347
+ expect(tabs[2].getAttribute("aria-selected")).toBe("true");
138
348
  expect(onTabClick).toHaveBeenCalledWith(2);
139
349
  });
140
350
  });
package/tabs/types.d.ts CHANGED
@@ -21,7 +21,7 @@ declare type TabCommonProps = {
21
21
  */
22
22
  notificationNumber?: boolean | number;
23
23
  };
24
- declare type TabLabelProps = TabCommonProps & {
24
+ export declare type TabLabelProps = TabCommonProps & {
25
25
  /**
26
26
  * Tab label.
27
27
  */
@@ -31,7 +31,7 @@ declare type TabLabelProps = TabCommonProps & {
31
31
  */
32
32
  icon?: string | SVG;
33
33
  };
34
- declare type TabIconProps = TabCommonProps & {
34
+ export declare type TabIconProps = TabCommonProps & {
35
35
  /**
36
36
  * Tab label.
37
37
  */
@@ -41,6 +41,16 @@ declare type TabIconProps = TabCommonProps & {
41
41
  */
42
42
  icon: string | SVG;
43
43
  };
44
+ export declare type TabProps = {
45
+ tab: TabLabelProps | TabIconProps;
46
+ active: boolean;
47
+ tabIndex: number;
48
+ hasLabelAndIcon: boolean;
49
+ iconPosition: "top" | "left";
50
+ onClick: () => void;
51
+ onMouseEnter: () => void;
52
+ onMouseLeave: () => void;
53
+ };
44
54
  declare type Props = {
45
55
  /**
46
56
  * An array of objects representing the tabs.
package/tag/Tag.js CHANGED
@@ -19,11 +19,11 @@ var _react = _interopRequireWildcard(require("react"));
19
19
 
20
20
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
21
21
 
22
- var _variables = require("../common/variables.js");
22
+ var _variables = require("../common/variables");
23
23
 
24
24
  var _useTheme = _interopRequireDefault(require("../useTheme"));
25
25
 
26
- var _utils = require("../common/utils.js");
26
+ var _utils = require("../common/utils");
27
27
 
28
28
  var _Box = _interopRequireDefault(require("../box/Box"));
29
29
 
@@ -64,9 +64,7 @@ var DxcTag = function DxcTag(_ref) {
64
64
  var tagContent = /*#__PURE__*/_react["default"].createElement(_Box["default"], {
65
65
  size: size,
66
66
  shadowDepth: isHovered && (onClick || linkHref) && 2 || 1
67
- }, /*#__PURE__*/_react["default"].createElement(TagContent, {
68
- labelPosition: labelPosition
69
- }, labelPosition === "before" && size !== "small" && label && /*#__PURE__*/_react["default"].createElement(TagLabel, null, label), icon && /*#__PURE__*/_react["default"].createElement(IconContainer, {
67
+ }, /*#__PURE__*/_react["default"].createElement(TagContent, null, labelPosition === "before" && size !== "small" && label && /*#__PURE__*/_react["default"].createElement(TagLabel, null, label), icon && /*#__PURE__*/_react["default"].createElement(IconContainer, {
70
68
  iconBgColor: iconBgColor
71
69
  }, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(TagIcon, {
72
70
  src: icon
@@ -99,7 +97,7 @@ var sizes = {
99
97
  medium: "240px",
100
98
  large: "480px",
101
99
  fillParent: "100%",
102
- fitContent: "unset"
100
+ fitContent: "fit-content"
103
101
  };
104
102
 
105
103
  var calculateWidth = function calculateWidth(margin, size) {
@@ -114,16 +112,16 @@ var StyledDxcTag = _styledComponents["default"].div(_templateObject || (_templat
114
112
  return margin && (0, _typeof2["default"])(margin) !== "object" ? _variables.spaces[margin] : "0px";
115
113
  }, function (_ref4) {
116
114
  var margin = _ref4.margin;
117
- return margin && margin.top ? _variables.spaces[margin.top] : "";
115
+ return margin && (0, _typeof2["default"])(margin) === "object" && margin.top ? _variables.spaces[margin.top] : "";
118
116
  }, function (_ref5) {
119
117
  var margin = _ref5.margin;
120
- return margin && margin.right ? _variables.spaces[margin.right] : "";
118
+ return margin && (0, _typeof2["default"])(margin) === "object" && margin.right ? _variables.spaces[margin.right] : "";
121
119
  }, function (_ref6) {
122
120
  var margin = _ref6.margin;
123
- return margin && margin.bottom ? _variables.spaces[margin.bottom] : "";
121
+ return margin && (0, _typeof2["default"])(margin) === "object" && margin.bottom ? _variables.spaces[margin.bottom] : "";
124
122
  }, function (_ref7) {
125
123
  var margin = _ref7.margin;
126
- return margin && margin.left ? _variables.spaces[margin.left] : "";
124
+ return margin && (0, _typeof2["default"])(margin) === "object" && margin.left ? _variables.spaces[margin.left] : "";
127
125
  }, function (props) {
128
126
  return calculateWidth(props.margin, props.size);
129
127
  }, function (props) {
@@ -3,6 +3,7 @@ import { userEvent, within } from "@storybook/testing-library";
3
3
  import Title from "../../.storybook/components/Title";
4
4
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
5
5
  import DxcTag from "./Tag";
6
+ import { HalstackProvider } from "../HalstackContext";
6
7
 
7
8
  export default {
8
9
  title: "Tag",
@@ -23,6 +24,13 @@ const largeIcon = (
23
24
  </svg>
24
25
  );
25
26
 
27
+ const opinionatedTheme = {
28
+ tag: {
29
+ fontColor: "#000000",
30
+ iconColor: "#ffffff",
31
+ },
32
+ };
33
+
26
34
  export const Chromatic = () => (
27
35
  <>
28
36
  <ExampleContainer>
@@ -124,7 +132,12 @@ export const Chromatic = () => (
124
132
  <Title title="FitContent size" theme="light" level={4} />
125
133
  <DxcTag label="FitContent" size="fitContent" icon={icon} />
126
134
  </ExampleContainer>
127
- <hr />
135
+ <Title title="Opinionated theme" theme="light" level={2} />
136
+ <ExampleContainer>
137
+ <HalstackProvider theme={opinionatedTheme}>
138
+ <DxcTag label="Tag" icon={icon} />
139
+ </HalstackProvider>
140
+ </ExampleContainer>
128
141
  </>
129
142
  );
130
143
 
package/tag/Tag.test.js CHANGED
@@ -6,7 +6,7 @@ var _react = _interopRequireDefault(require("react"));
6
6
 
7
7
  var _react2 = require("@testing-library/react");
8
8
 
9
- var _Tag = _interopRequireDefault(require("./Tag"));
9
+ var _Tag = _interopRequireDefault(require("./Tag.tsx"));
10
10
 
11
11
  describe("Tag component tests", function () {
12
12
  test("Tag renders with correct label", function () {
@@ -0,0 +1,8 @@
1
+ /// <reference types="react" />
2
+ declare const icons: {
3
+ error: JSX.Element;
4
+ clear: JSX.Element;
5
+ increment: JSX.Element;
6
+ decrement: JSX.Element;
7
+ };
8
+ export default icons;
@@ -0,0 +1,60 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+
10
+ var _react = _interopRequireDefault(require("react"));
11
+
12
+ var icons = {
13
+ error: /*#__PURE__*/_react["default"].createElement("svg", {
14
+ xmlns: "http://www.w3.org/2000/svg",
15
+ height: "24px",
16
+ viewBox: "0 0 24 24",
17
+ width: "24px",
18
+ fill: "currentColor"
19
+ }, /*#__PURE__*/_react["default"].createElement("path", {
20
+ d: "M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-2h2v2zm0-4h-2V7h2v6z"
21
+ })),
22
+ clear: /*#__PURE__*/_react["default"].createElement("svg", {
23
+ xmlns: "http://www.w3.org/2000/svg",
24
+ width: "24",
25
+ height: "24",
26
+ viewBox: "0 0 24 24",
27
+ fill: "currentColor"
28
+ }, /*#__PURE__*/_react["default"].createElement("path", {
29
+ d: "M0 0h24v24H0V0z",
30
+ fill: "none"
31
+ }), /*#__PURE__*/_react["default"].createElement("path", {
32
+ d: "M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12 19 6.41z"
33
+ })),
34
+ increment: /*#__PURE__*/_react["default"].createElement("svg", {
35
+ xmlns: "http://www.w3.org/2000/svg",
36
+ height: "24px",
37
+ viewBox: "0 0 24 24",
38
+ width: "24px",
39
+ fill: "currentColor"
40
+ }, /*#__PURE__*/_react["default"].createElement("path", {
41
+ d: "M0 0h24v24H0z",
42
+ fill: "none"
43
+ }), /*#__PURE__*/_react["default"].createElement("path", {
44
+ d: "M19 13h-6v6h-2v-6H5v-2h6V5h2v6h6v2z"
45
+ })),
46
+ decrement: /*#__PURE__*/_react["default"].createElement("svg", {
47
+ xmlns: "http://www.w3.org/2000/svg",
48
+ height: "24px",
49
+ viewBox: "0 0 24 24",
50
+ width: "24px",
51
+ fill: "currentColor"
52
+ }, /*#__PURE__*/_react["default"].createElement("path", {
53
+ d: "M0 0h24v24H0z",
54
+ fill: "none"
55
+ }), /*#__PURE__*/_react["default"].createElement("path", {
56
+ d: "M19 13H5v-2h14v2z"
57
+ }))
58
+ };
59
+ var _default = icons;
60
+ exports["default"] = _default;