@dxc-technology/halstack-react 0.0.0-c593452 → 0.0.0-c680086

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 (237) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +1 -4
  3. package/ThemeContext.d.ts +15 -0
  4. package/ThemeContext.js +5 -8
  5. package/V3Select/V3Select.js +2 -2
  6. package/V3Textarea/V3Textarea.js +2 -2
  7. package/accordion/Accordion.d.ts +1 -1
  8. package/accordion/Accordion.js +11 -22
  9. package/accordion/Accordion.stories.tsx +307 -0
  10. package/accordion/types.d.ts +4 -8
  11. package/accordion-group/AccordionGroup.js +2 -2
  12. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  13. package/accordion-group/types.d.ts +4 -8
  14. package/alert/Alert.js +2 -2
  15. package/alert/Alert.stories.tsx +170 -0
  16. package/alert/types.d.ts +1 -1
  17. package/badge/Badge.js +1 -1
  18. package/bleed/Bleed.d.ts +3 -0
  19. package/bleed/Bleed.js +84 -0
  20. package/bleed/Bleed.stories.tsx +342 -0
  21. package/bleed/types.d.ts +13 -0
  22. package/bleed/types.js +5 -0
  23. package/box/Box.d.ts +4 -0
  24. package/box/Box.js +6 -32
  25. package/box/Box.stories.tsx +132 -0
  26. package/box/types.d.ts +43 -0
  27. package/box/types.js +5 -0
  28. package/button/Button.d.ts +1 -1
  29. package/button/Button.js +15 -26
  30. package/button/Button.stories.tsx +223 -242
  31. package/button/types.d.ts +9 -13
  32. package/card/Card.js +5 -6
  33. package/card/Card.stories.tsx +201 -0
  34. package/card/ice-cream.jpg +0 -0
  35. package/card/types.d.ts +4 -6
  36. package/checkbox/Checkbox.js +2 -2
  37. package/checkbox/Checkbox.stories.tsx +192 -0
  38. package/checkbox/types.d.ts +2 -2
  39. package/chip/Chip.d.ts +4 -0
  40. package/chip/Chip.js +16 -76
  41. package/chip/Chip.stories.tsx +119 -0
  42. package/chip/types.d.ts +45 -0
  43. package/chip/types.js +5 -0
  44. package/common/variables.js +86 -44
  45. package/date/Date.js +1 -1
  46. package/date-input/DateInput.js +10 -13
  47. package/date-input/DateInput.stories.tsx +138 -0
  48. package/dialog/Dialog.d.ts +4 -0
  49. package/dialog/Dialog.js +8 -26
  50. package/dialog/Dialog.stories.tsx +212 -0
  51. package/dialog/types.d.ts +43 -0
  52. package/dialog/types.js +5 -0
  53. package/dropdown/Dropdown.d.ts +1 -1
  54. package/dropdown/Dropdown.js +13 -35
  55. package/dropdown/Dropdown.stories.tsx +249 -0
  56. package/dropdown/types.d.ts +6 -15
  57. package/file-input/FileInput.d.ts +4 -0
  58. package/file-input/FileInput.js +167 -109
  59. package/file-input/FileInput.stories.tsx +507 -0
  60. package/file-input/FileItem.d.ts +14 -0
  61. package/file-input/FileItem.js +12 -21
  62. package/file-input/types.d.ts +112 -0
  63. package/file-input/types.js +5 -0
  64. package/footer/Footer.d.ts +4 -0
  65. package/footer/Footer.js +31 -70
  66. package/footer/Footer.stories.tsx +130 -0
  67. package/footer/Icons.d.ts +2 -0
  68. package/footer/Icons.js +3 -3
  69. package/footer/types.d.ts +65 -0
  70. package/footer/types.js +5 -0
  71. package/header/Header.d.ts +7 -0
  72. package/header/Header.js +28 -30
  73. package/header/Header.stories.tsx +162 -0
  74. package/header/Icons.d.ts +2 -0
  75. package/header/Icons.js +2 -27
  76. package/header/types.d.ts +47 -0
  77. package/header/types.js +5 -0
  78. package/heading/Heading.d.ts +4 -0
  79. package/heading/Heading.js +7 -24
  80. package/heading/Heading.stories.tsx +54 -0
  81. package/heading/types.d.ts +33 -0
  82. package/heading/types.js +5 -0
  83. package/input-text/InputText.js +2 -2
  84. package/inset/Inset.d.ts +3 -0
  85. package/inset/Inset.js +84 -0
  86. package/inset/Inset.stories.tsx +229 -0
  87. package/inset/types.d.ts +13 -0
  88. package/inset/types.js +5 -0
  89. package/layout/ApplicationLayout.d.ts +10 -0
  90. package/layout/ApplicationLayout.js +9 -19
  91. package/layout/ApplicationLayout.stories.tsx +171 -0
  92. package/layout/types.d.ts +57 -0
  93. package/layout/types.js +5 -0
  94. package/link/Link.d.ts +3 -0
  95. package/link/Link.js +10 -40
  96. package/link/Link.stories.tsx +151 -0
  97. package/link/types.d.ts +70 -0
  98. package/link/types.js +5 -0
  99. package/list/List.d.ts +4 -0
  100. package/list/List.js +47 -0
  101. package/list/List.stories.tsx +95 -0
  102. package/list/types.d.ts +7 -0
  103. package/list/types.js +5 -0
  104. package/main.d.ts +8 -3
  105. package/main.js +42 -2
  106. package/number-input/NumberInput.d.ts +4 -0
  107. package/number-input/NumberInput.js +5 -50
  108. package/number-input/NumberInput.stories.tsx +115 -0
  109. package/number-input/NumberInputContext.d.ts +4 -0
  110. package/number-input/NumberInputContext.js +5 -2
  111. package/number-input/numberInputContextTypes.d.ts +19 -0
  112. package/number-input/numberInputContextTypes.js +5 -0
  113. package/number-input/types.d.ts +117 -0
  114. package/number-input/types.js +5 -0
  115. package/package.json +4 -2
  116. package/paginator/Paginator.js +2 -8
  117. package/paginator/Paginator.stories.tsx +63 -0
  118. package/password-input/PasswordInput.d.ts +4 -0
  119. package/password-input/PasswordInput.js +19 -55
  120. package/password-input/{PasswordInput.stories.jsx → PasswordInput.stories.tsx} +4 -4
  121. package/password-input/types.d.ts +107 -0
  122. package/password-input/types.js +5 -0
  123. package/progress-bar/ProgressBar.js +5 -5
  124. package/progress-bar/ProgressBar.stories.jsx +58 -0
  125. package/radio/Radio.js +2 -2
  126. package/radio/Radio.stories.tsx +192 -0
  127. package/radio/types.d.ts +2 -2
  128. package/radio-group/Radio.d.ts +4 -0
  129. package/radio-group/Radio.js +140 -0
  130. package/radio-group/RadioGroup.d.ts +4 -0
  131. package/radio-group/RadioGroup.js +273 -0
  132. package/radio-group/RadioGroup.stories.tsx +79 -0
  133. package/radio-group/RadioGroup.test.js +248 -0
  134. package/radio-group/types.d.ts +36 -0
  135. package/radio-group/types.js +5 -0
  136. package/resultsetTable/ResultsetTable.d.ts +4 -0
  137. package/resultsetTable/ResultsetTable.js +9 -29
  138. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  139. package/resultsetTable/types.d.ts +67 -0
  140. package/resultsetTable/types.js +5 -0
  141. package/row/Row.d.ts +3 -0
  142. package/row/Row.js +127 -0
  143. package/row/Row.stories.tsx +237 -0
  144. package/row/types.d.ts +10 -0
  145. package/row/types.js +5 -0
  146. package/select/Select.d.ts +4 -0
  147. package/select/Select.js +20 -22
  148. package/select/Select.stories.tsx +572 -0
  149. package/select/types.d.ts +170 -0
  150. package/select/types.js +5 -0
  151. package/sidenav/Sidenav.d.ts +9 -0
  152. package/sidenav/Sidenav.js +6 -15
  153. package/sidenav/Sidenav.stories.tsx +182 -0
  154. package/sidenav/types.d.ts +50 -0
  155. package/sidenav/types.js +5 -0
  156. package/slider/Slider.d.ts +1 -1
  157. package/slider/Slider.js +43 -32
  158. package/slider/Slider.stories.tsx +177 -0
  159. package/slider/types.d.ts +2 -7
  160. package/spinner/Spinner.d.ts +4 -0
  161. package/spinner/Spinner.js +8 -25
  162. package/spinner/Spinner.stories.jsx +103 -0
  163. package/spinner/types.d.ts +32 -0
  164. package/spinner/types.js +5 -0
  165. package/stack/Stack.d.ts +3 -0
  166. package/stack/Stack.js +97 -0
  167. package/stack/Stack.stories.tsx +164 -0
  168. package/stack/types.d.ts +9 -0
  169. package/stack/types.js +5 -0
  170. package/switch/Switch.js +4 -4
  171. package/switch/Switch.stories.tsx +160 -0
  172. package/table/Table.d.ts +4 -0
  173. package/table/Table.js +3 -3
  174. package/table/Table.stories.jsx +277 -0
  175. package/table/types.d.ts +21 -0
  176. package/table/types.js +5 -0
  177. package/tabs/Tabs.js +11 -9
  178. package/tabs/Tabs.stories.tsx +120 -0
  179. package/tabs/types.d.ts +25 -18
  180. package/tag/Tag.d.ts +4 -0
  181. package/tag/Tag.js +26 -46
  182. package/tag/Tag.stories.tsx +138 -0
  183. package/tag/types.d.ts +69 -0
  184. package/tag/types.js +5 -0
  185. package/text/Text.d.ts +7 -0
  186. package/text/Text.js +30 -0
  187. package/text/Text.stories.tsx +19 -0
  188. package/text-input/TextInput.d.ts +4 -0
  189. package/text-input/TextInput.js +54 -85
  190. package/text-input/TextInput.stories.tsx +456 -0
  191. package/text-input/types.d.ts +159 -0
  192. package/text-input/types.js +5 -0
  193. package/textarea/Textarea.d.ts +4 -0
  194. package/textarea/Textarea.js +27 -60
  195. package/textarea/Textarea.stories.jsx +4 -3
  196. package/textarea/types.d.ts +130 -0
  197. package/textarea/types.js +5 -0
  198. package/toggle/Toggle.js +1 -1
  199. package/toggle-group/ToggleGroup.d.ts +4 -0
  200. package/toggle-group/ToggleGroup.js +16 -45
  201. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  202. package/toggle-group/types.d.ts +97 -0
  203. package/toggle-group/types.js +5 -0
  204. package/upload/buttons-upload/ButtonsUpload.js +2 -2
  205. package/upload/dragAndDropArea/DragAndDropArea.js +2 -2
  206. package/upload/file-upload/FileToUpload.js +1 -1
  207. package/upload/files-upload/FilesToUpload.js +1 -1
  208. package/upload/transaction/Transaction.js +2 -2
  209. package/upload/transactions/Transactions.js +1 -1
  210. package/useTheme.d.ts +2 -0
  211. package/useTheme.js +1 -1
  212. package/wizard/Wizard.d.ts +4 -0
  213. package/wizard/Wizard.js +69 -59
  214. package/wizard/Wizard.stories.tsx +224 -0
  215. package/wizard/types.d.ts +60 -0
  216. package/wizard/types.js +5 -0
  217. package/box/index.d.ts +0 -25
  218. package/chip/index.d.ts +0 -22
  219. package/dialog/index.d.ts +0 -18
  220. package/file-input/index.d.ts +0 -81
  221. package/footer/index.d.ts +0 -25
  222. package/header/index.d.ts +0 -25
  223. package/heading/index.d.ts +0 -17
  224. package/link/index.d.ts +0 -23
  225. package/number-input/index.d.ts +0 -113
  226. package/password-input/index.d.ts +0 -94
  227. package/resultsetTable/index.d.ts +0 -19
  228. package/select/index.d.ts +0 -131
  229. package/sidenav/index.d.ts +0 -13
  230. package/spinner/index.d.ts +0 -17
  231. package/table/index.d.ts +0 -13
  232. package/tag/index.d.ts +0 -24
  233. package/text-input/index.d.ts +0 -135
  234. package/textarea/index.d.ts +0 -117
  235. package/toggle-group/index.d.ts +0 -21
  236. package/wizard/Icons.js +0 -65
  237. package/wizard/index.d.ts +0 -18
@@ -0,0 +1,277 @@
1
+ import React from "react";
2
+ import DxcTable from "./Table";
3
+ import Title from "../../.storybook/components/Title";
4
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
5
+
6
+ export default {
7
+ title: "Table",
8
+ component: DxcTable,
9
+ };
10
+
11
+ export const Chromatic = () => (
12
+ <>
13
+ <ExampleContainer>
14
+ <Title title="Default" theme="light" level={4} />
15
+ <DxcTable>
16
+ <tr>
17
+ <th>header 1</th>
18
+ <th>header 2</th>
19
+ <th>header 3</th>
20
+ </tr>
21
+ <tr>
22
+ <td>cell 1</td>
23
+ <td>cell 2</td>
24
+ <td>cell 3</td>
25
+ </tr>
26
+ <tr>
27
+ <td>cell 4</td>
28
+ <td>cell 5</td>
29
+ <td>cell 6</td>
30
+ </tr>
31
+ <tr>
32
+ <td>cell 7</td>
33
+ <td>cell 8</td>
34
+ <td>Cell 9</td>
35
+ </tr>
36
+ </DxcTable>
37
+ </ExampleContainer>
38
+ <ExampleContainer>
39
+ <Title title="With scrollbar" theme="light" level={4} />
40
+ <div
41
+ style={{ height: 200 + "px", display: "flex", flexDirection: "row", width: 100 + "%", marginBottom: 50 + "px" }}
42
+ >
43
+ <DxcTable>
44
+ <tr>
45
+ <th>
46
+ header<br></br>subheader
47
+ </th>
48
+ <th>
49
+ header<br></br>subheader
50
+ </th>
51
+ <th>
52
+ header<br></br>subheader
53
+ </th>
54
+ </tr>
55
+ <tr>
56
+ <td>
57
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et
58
+ dolore magna aliqua.
59
+ </td>
60
+ <td>
61
+ Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo
62
+ consequat.
63
+ </td>
64
+ <td>
65
+ Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.
66
+ </td>
67
+ </tr>
68
+ <tr>
69
+ <td>cell data</td>
70
+ <td>cell data</td>
71
+ <td>cell data</td>
72
+ </tr>
73
+ <tr>
74
+ <td>cell data</td>
75
+ <td>cell data</td>
76
+ <td>cell data</td>
77
+ </tr>
78
+ <tr>
79
+ <td>cell data</td>
80
+ <td>cell data</td>
81
+ <td>cell data</td>
82
+ </tr>
83
+ <tr>
84
+ <td>cell data</td>
85
+ <td>cell data</td>
86
+ <td>cell data</td>
87
+ </tr>
88
+ <tr>
89
+ <td>cell data</td>
90
+ <td>cell data</td>
91
+ <td>cell data</td>
92
+ </tr>
93
+ <tr>
94
+ <td>cell data</td>
95
+ <td>cell data</td>
96
+ <td>cell data</td>
97
+ </tr>
98
+ <tr>
99
+ <td>cell data</td>
100
+ <td>cell data</td>
101
+ <td>cell data</td>
102
+ </tr>
103
+ <tr>
104
+ <td>cell data</td>
105
+ <td>cell data</td>
106
+ <td>cell data</td>
107
+ </tr>
108
+ </DxcTable>
109
+ </div>
110
+ </ExampleContainer>
111
+ <Title title="Margins" theme="light" level={2} />
112
+ <ExampleContainer>
113
+ <Title title="Xxsmall margin" theme="light" level={4} />
114
+ <DxcTable margin="xxsmall">
115
+ <tr>
116
+ <th>header 1</th>
117
+ <th>header 2</th>
118
+ <th>header 3</th>
119
+ </tr>
120
+ <tr>
121
+ <td>cell 1</td>
122
+ <td>cell 2</td>
123
+ <td>cell 3</td>
124
+ </tr>
125
+ <tr>
126
+ <td>cell 4</td>
127
+ <td>cell 5</td>
128
+ <td>cell 6</td>
129
+ </tr>
130
+ <tr>
131
+ <td>cell 7</td>
132
+ <td>cell 8</td>
133
+ <td>Cell 9</td>
134
+ </tr>
135
+ </DxcTable>
136
+ <Title title="Xsmall margin" theme="light" level={4} />
137
+ <DxcTable margin="xsmall">
138
+ <tr>
139
+ <th>header 1</th>
140
+ <th>header 2</th>
141
+ <th>header 3</th>
142
+ </tr>
143
+ <tr>
144
+ <td>cell 1</td>
145
+ <td>cell 2</td>
146
+ <td>cell 3</td>
147
+ </tr>
148
+ <tr>
149
+ <td>cell 4</td>
150
+ <td>cell 5</td>
151
+ <td>cell 6</td>
152
+ </tr>
153
+ <tr>
154
+ <td>cell 7</td>
155
+ <td>cell 8</td>
156
+ <td>Cell 9</td>
157
+ </tr>
158
+ </DxcTable>
159
+ <Title title="Small margin" theme="light" level={4} />
160
+ <DxcTable margin="small">
161
+ <tr>
162
+ <th>header 1</th>
163
+ <th>header 2</th>
164
+ <th>header 3</th>
165
+ </tr>
166
+ <tr>
167
+ <td>cell 1</td>
168
+ <td>cell 2</td>
169
+ <td>cell 3</td>
170
+ </tr>
171
+ <tr>
172
+ <td>cell 4</td>
173
+ <td>cell 5</td>
174
+ <td>cell 6</td>
175
+ </tr>
176
+ <tr>
177
+ <td>cell 7</td>
178
+ <td>cell 8</td>
179
+ <td>Cell 9</td>
180
+ </tr>
181
+ </DxcTable>
182
+ <Title title="Medium margin" theme="light" level={4} />
183
+ <DxcTable margin="medium">
184
+ <tr>
185
+ <th>header 1</th>
186
+ <th>header 2</th>
187
+ <th>header 3</th>
188
+ </tr>
189
+ <tr>
190
+ <td>cell 1</td>
191
+ <td>cell 2</td>
192
+ <td>cell 3</td>
193
+ </tr>
194
+ <tr>
195
+ <td>cell 4</td>
196
+ <td>cell 5</td>
197
+ <td>cell 6</td>
198
+ </tr>
199
+ <tr>
200
+ <td>cell 7</td>
201
+ <td>cell 8</td>
202
+ <td>Cell 9</td>
203
+ </tr>
204
+ </DxcTable>
205
+ <Title title="Large margin" theme="light" level={4} />
206
+ <DxcTable margin="large">
207
+ <tr>
208
+ <th>header 1</th>
209
+ <th>header 2</th>
210
+ <th>header 3</th>
211
+ </tr>
212
+ <tr>
213
+ <td>cell 1</td>
214
+ <td>cell 2</td>
215
+ <td>cell 3</td>
216
+ </tr>
217
+ <tr>
218
+ <td>cell 4</td>
219
+ <td>cell 5</td>
220
+ <td>cell 6</td>
221
+ </tr>
222
+ <tr>
223
+ <td>cell 7</td>
224
+ <td>cell 8</td>
225
+ <td>Cell 9</td>
226
+ </tr>
227
+ </DxcTable>
228
+ <Title title="Xlarge margin" theme="light" level={4} />
229
+ <DxcTable margin="xlarge">
230
+ <tr>
231
+ <th>header 1</th>
232
+ <th>header 2</th>
233
+ <th>header 3</th>
234
+ </tr>
235
+ <tr>
236
+ <td>cell 1</td>
237
+ <td>cell 2</td>
238
+ <td>cell 3</td>
239
+ </tr>
240
+ <tr>
241
+ <td>cell 4</td>
242
+ <td>cell 5</td>
243
+ <td>cell 6</td>
244
+ </tr>
245
+ <tr>
246
+ <td>cell 7</td>
247
+ <td>cell 8</td>
248
+ <td>Cell 9</td>
249
+ </tr>
250
+ </DxcTable>
251
+ <Title title="Xxlarge margin" theme="light" level={4} />
252
+ <DxcTable margin="xxlarge">
253
+ <tr>
254
+ <th>header 1</th>
255
+ <th>header 2</th>
256
+ <th>header 3</th>
257
+ </tr>
258
+ <tr>
259
+ <td>cell 1</td>
260
+ <td>cell 2</td>
261
+ <td>cell 3</td>
262
+ </tr>
263
+ <tr>
264
+ <td>cell 4</td>
265
+ <td>cell 5</td>
266
+ <td>cell 6</td>
267
+ </tr>
268
+ <tr>
269
+ <td>cell 7</td>
270
+ <td>cell 8</td>
271
+ <td>Cell 9</td>
272
+ </tr>
273
+ </DxcTable>
274
+ <hr />
275
+ </ExampleContainer>
276
+ </>
277
+ );
@@ -0,0 +1,21 @@
1
+ /// <reference types="react" />
2
+ declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ declare type Margin = {
4
+ top?: Space;
5
+ bottom?: Space;
6
+ left?: Space;
7
+ right?: Space;
8
+ };
9
+ declare type Props = {
10
+ /**
11
+ * Size of the margin to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
12
+ * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
13
+ */
14
+ margin?: Space | Margin;
15
+ /**
16
+ * The center section of the table. Can be used to render custom
17
+ * content in this area.
18
+ */
19
+ children: React.ReactNode;
20
+ };
21
+ export default Props;
package/table/types.js ADDED
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
package/tabs/Tabs.js CHANGED
@@ -9,10 +9,10 @@ Object.defineProperty(exports, "__esModule", {
9
9
  });
10
10
  exports["default"] = void 0;
11
11
 
12
- var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
-
14
12
  var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
15
13
 
14
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
+
16
16
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
17
17
 
18
18
  var _react = _interopRequireDefault(require("react"));
@@ -27,7 +27,7 @@ var _variables = require("../common/variables.js");
27
27
 
28
28
  var _Badge = _interopRequireDefault(require("../badge/Badge"));
29
29
 
30
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
30
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
31
31
 
32
32
  var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9;
33
33
 
@@ -70,12 +70,12 @@ var DxcTabs = function DxcTabs(_ref) {
70
70
  }, /*#__PURE__*/_react["default"].createElement(TabLabelContainer, {
71
71
  hasLabelAndIcon: hasLabelAndIcon,
72
72
  iconPosition: iconPosition
73
- }, tab.icon ? /*#__PURE__*/_react["default"].createElement(TabIconContainer, {
73
+ }, tab.icon && /*#__PURE__*/_react["default"].createElement(TabIconContainer, {
74
74
  hasLabelAndIcon: hasLabelAndIcon,
75
75
  iconPosition: iconPosition
76
- }, (0, _typeof2["default"])(tab.icon) === "object" ? tab.icon : /*#__PURE__*/_react["default"].createElement(tab.icon)) : tab.iconSrc && /*#__PURE__*/_react["default"].createElement(TabIcon, {
77
- src: tab.iconSrc
78
- }), /*#__PURE__*/_react["default"].createElement(LabelTextContainer, null, tab.label))), tab.notificationNumber && tab.notificationNumber !== false && /*#__PURE__*/_react["default"].createElement(BadgeContainer, {
76
+ }, typeof tab.icon === "string" ? /*#__PURE__*/_react["default"].createElement(TabIcon, {
77
+ src: tab.icon
78
+ }) : tab.icon), /*#__PURE__*/_react["default"].createElement(LabelTextContainer, null, tab.label))), tab.notificationNumber && tab.notificationNumber !== false && /*#__PURE__*/_react["default"].createElement(BadgeContainer, {
79
79
  hasLabelAndIcon: hasLabelAndIcon,
80
80
  iconPosition: iconPosition
81
81
  }, /*#__PURE__*/_react["default"].createElement(_Badge["default"], {
@@ -135,7 +135,7 @@ var Underline = _styledComponents["default"].div(_templateObject6 || (_templateO
135
135
  return props.theme.dividerColor;
136
136
  });
137
137
 
138
- var DxCTabs = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n position: relative;\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n\n .MuiTabs-root {\n background: white;\n min-height: ", ";\n\n .MuiTabs-scroller {\n .MuiTabs-flexContainer + span {\n z-index: 4;\n }\n }\n .MuiTab-root {\n text-transform: ", " !important;\n }\n .MuiButtonBase-root {\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n\n padding: ", ";\n height: ", ";\n min-width: 90px;\n max-width: 360px;\n min-height: ", ";\n\n &:hover {\n background-color: ", ";\n }\n &:active {\n background-color: ", ";\n font-weight: ", ";\n }\n &:not(.Mui-selected) {\n background-color: ", ";\n color: ", ";\n svg {\n color: ", ";\n }\n }\n &.Mui-selected {\n background-color: ", ";\n color: ", ";\n svg {\n color: ", ";\n }\n }\n &.Mui-disabled {\n cursor: not-allowed !important;\n pointer-events: all;\n color: ", ";\n font-style: ", ";\n svg {\n color: ", ";\n }\n }\n &:focus {\n outline: ", " auto 1px;\n }\n }\n .MuiTabs-indicator {\n background-color: ", ";\n height: ", ";\n }\n .MuiTabs-scrollButtons {\n min-width: ", ";\n width: ", ";\n padding: 0;\n }\n @media (max-width: 599.95px) {\n .MuiTabs-scrollButtonsDesktop {\n display: flex;\n }\n }\n }\n"])), function (props) {
138
+ var DxCTabs = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n position: relative;\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n\n .MuiTabs-root {\n background: white;\n min-height: ", ";\n\n .MuiTabs-scroller {\n .MuiTabs-flexContainer + span {\n z-index: 4;\n }\n }\n .MuiTab-root {\n text-transform: ", " !important;\n }\n .MuiButtonBase-root {\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n\n padding: ", ";\n height: ", ";\n min-width: 90px;\n max-width: 360px;\n min-height: ", ";\n\n &:hover {\n background-color: ", ";\n }\n &:active {\n background-color: ", ";\n font-weight: ", ";\n }\n &:not(.Mui-selected) {\n background-color: ", ";\n color: ", ";\n svg {\n color: ", ";\n }\n }\n &.Mui-selected {\n background-color: ", ";\n color: ", ";\n svg {\n color: ", ";\n }\n }\n &.Mui-disabled {\n background-color: ", " !important;\n cursor: not-allowed !important;\n pointer-events: all;\n color: ", ";\n font-style: ", ";\n svg {\n color: ", ";\n }\n outline: none !important;\n }\n &:focus {\n outline: ", " auto 1px;\n }\n }\n .MuiTabs-indicator {\n background-color: ", ";\n height: ", ";\n }\n .MuiTabs-scrollButtons {\n min-width: ", ";\n width: ", ";\n padding: 0;\n }\n @media (max-width: 599.95px) {\n .MuiTabs-scrollButtonsDesktop {\n display: flex;\n }\n }\n }\n"])), function (props) {
139
139
  return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
140
140
  }, function (props) {
141
141
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
@@ -181,6 +181,8 @@ var DxCTabs = _styledComponents["default"].div(_templateObject7 || (_templateObj
181
181
  return props.theme.selectedFontColor;
182
182
  }, function (props) {
183
183
  return props.theme.selectedIconColor;
184
+ }, function (props) {
185
+ return props.theme.unselectedBackgroundColor;
184
186
  }, function (props) {
185
187
  return props.theme.disabledFontColor;
186
188
  }, function (props) {
@@ -199,7 +201,7 @@ var DxCTabs = _styledComponents["default"].div(_templateObject7 || (_templateObj
199
201
  return props.theme.scrollButtonsWidth;
200
202
  });
201
203
 
202
- var TabIcon = _styledComponents["default"].img(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n max-height: 22px;\n max-width: 22px;\n"])));
204
+ var TabIcon = _styledComponents["default"].img(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])([""])));
203
205
 
204
206
  var TabIconContainer = _styledComponents["default"].div(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n max-height: 22px;\n max-width: 22px;\n margin-bottom: ", ";\n margin-right: ", ";\n overflow: hidden;\n display: flex;\n align-items: center;\n img,\n svg {\n height: 100%;\n width: 100%;\n }\n"])), function (props) {
205
207
  return props.hasLabelAndIcon && props.iconPosition === "top" && "8px" || "";
@@ -0,0 +1,120 @@
1
+ import React from "react";
2
+ import { userEvent, within } from "@storybook/testing-library";
3
+ import DxcTabs from "./Tabs";
4
+ import Title from "../../.storybook/components/Title";
5
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
+
7
+ export default {
8
+ title: "Tabs",
9
+ component: DxcTabs,
10
+ };
11
+
12
+ const iconSVG = (
13
+ <svg viewBox="0 0 24 24" fill="currentColor">
14
+ <path d="M0 0h24v24H0z" fill="none" />
15
+ <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" />
16
+ </svg>
17
+ );
18
+
19
+ const tabs: any = [
20
+ {
21
+ label: "Tab 1",
22
+ },
23
+ {
24
+ label: "Tab 2",
25
+ },
26
+ {
27
+ label: "Tab 3",
28
+ isDisabled: true,
29
+ },
30
+ {
31
+ label: "Tab 4",
32
+ },
33
+ ];
34
+
35
+ const tabsNotification = tabs.map((tab, index) => ({
36
+ ...tab,
37
+ notificationNumber: (index === 0 && true) || (index === 1 && 5) || (index === 2 && 200),
38
+ }));
39
+
40
+ const tabsIcon = tabs.map((tab) => ({ ...tab, icon: iconSVG }));
41
+
42
+ const tabsNotificationIcon = tabsNotification.map((tab) => ({ ...tab, icon: iconSVG }));
43
+
44
+ export const Chromatic = () => (
45
+ <>
46
+ <ExampleContainer>
47
+ <Title title="Only label" theme="light" level={4} />
48
+ <DxcTabs tabs={tabs} />
49
+ </ExampleContainer>
50
+ <ExampleContainer pseudoState="pseudo-hover">
51
+ <Title title="Hovered tabs" theme="light" level={4} />
52
+ <DxcTabs tabs={tabs} />
53
+ </ExampleContainer>
54
+ <ExampleContainer pseudoState="pseudo-focus">
55
+ <Title title="Focused tabs" theme="light" level={4} />
56
+ <DxcTabs tabs={tabs} />
57
+ </ExampleContainer>
58
+ <ExampleContainer pseudoState="pseudo-active">
59
+ <Title title="Actived tabs" theme="light" level={4} />
60
+ <DxcTabs tabs={tabs} />
61
+ </ExampleContainer>
62
+ <ExampleContainer>
63
+ <Title title="With notification number" theme="light" level={4} />
64
+ <DxcTabs tabs={tabsNotification} />
65
+ </ExampleContainer>
66
+ <ExampleContainer>
67
+ <Title title="With icon position top" theme="light" level={4} />
68
+ <DxcTabs tabs={tabsIcon} />
69
+ </ExampleContainer>
70
+ <ExampleContainer>
71
+ <Title title="With icon position left" theme="light" level={4} />
72
+ <DxcTabs tabs={tabsIcon} iconPosition="left" />
73
+ </ExampleContainer>
74
+ <ExampleContainer>
75
+ <Title title="With icon and notification number" theme="light" level={4} />
76
+ <DxcTabs tabs={tabsNotificationIcon} />
77
+ </ExampleContainer>
78
+ <ExampleContainer>
79
+ <Title title="With icon on the left and notification number" theme="light" level={4} />
80
+ <DxcTabs tabs={tabsNotificationIcon} iconPosition="left" />
81
+ </ExampleContainer>
82
+ <ExampleContainer>
83
+ <Title title="Scrollable" theme="light" level={4} />
84
+ <div style={{ width: "400px" }}>
85
+ <DxcTabs tabs={tabsNotificationIcon} iconPosition="left" activeTabIndex={1} />
86
+ </div>
87
+ </ExampleContainer>
88
+
89
+ <Title title="Margins" theme="light" level={2} />
90
+ <ExampleContainer>
91
+ <Title title="Xxsmall margin" theme="light" level={4} />
92
+ <DxcTabs tabs={tabs} margin="xxsmall" />
93
+ </ExampleContainer>
94
+ <ExampleContainer>
95
+ <Title title="Xsmall margin" theme="light" level={4} />
96
+ <DxcTabs tabs={tabs} margin="xsmall" />
97
+ </ExampleContainer>
98
+ <ExampleContainer>
99
+ <Title title="Small margin" theme="light" level={4} />
100
+ <DxcTabs tabs={tabs} margin="small" />
101
+ </ExampleContainer>
102
+ <ExampleContainer>
103
+ <Title title="Medium margin" theme="light" level={4} />
104
+ <DxcTabs tabs={tabs} margin="medium" />
105
+ </ExampleContainer>
106
+ <ExampleContainer>
107
+ <Title title="Large margin" theme="light" level={4} />
108
+ <DxcTabs tabs={tabs} margin="large" />
109
+ </ExampleContainer>
110
+ <ExampleContainer>
111
+ <Title title="Xlarge margin" theme="light" level={4} />
112
+ <DxcTabs tabs={tabs} margin="xlarge" />
113
+ </ExampleContainer>
114
+ <ExampleContainer>
115
+ <Title title="Xxlarge margin" theme="light" level={4} />
116
+ <DxcTabs tabs={tabs} margin="xxlarge" />
117
+ <hr />
118
+ </ExampleContainer>
119
+ </>
120
+ );
package/tabs/types.d.ts CHANGED
@@ -6,20 +6,8 @@ declare type Margin = {
6
6
  left?: Space;
7
7
  right?: Space;
8
8
  };
9
- declare type SVG = React.SVGProps<SVGSVGElement> | React.FunctionComponent<React.SVGProps<SVGSVGElement>>;
10
- declare type Tab = {
11
- /**
12
- * Tab label.
13
- */
14
- label?: string;
15
- /**
16
- * Element used as the icon that will be displayed in the tab.
17
- */
18
- icon?: SVG;
19
- /**
20
- * @deprecated URL of the icon to be displayed in the tab.
21
- */
22
- iconSrc?: string;
9
+ declare type SVG = React.SVGProps<SVGSVGElement>;
10
+ declare type TabCommonProps = {
23
11
  /**
24
12
  * Whether the tab is disabled or not.
25
13
  */
@@ -33,11 +21,31 @@ declare type Tab = {
33
21
  */
34
22
  notificationNumber?: boolean | number;
35
23
  };
24
+ declare type TabLabelProps = TabCommonProps & {
25
+ /**
26
+ * Tab label.
27
+ */
28
+ label: string;
29
+ /**
30
+ * Element or path used as the icon that will be displayed in the tab.
31
+ */
32
+ icon?: string | SVG;
33
+ };
34
+ declare type TabIconProps = TabCommonProps & {
35
+ /**
36
+ * Tab label.
37
+ */
38
+ label?: string;
39
+ /**
40
+ * Element or path used as the icon that will be displayed in the tab.
41
+ */
42
+ icon: string | SVG;
43
+ };
36
44
  declare type Props = {
37
45
  /**
38
46
  * An array of objects representing the tabs.
39
47
  */
40
- tabs: [Tab, ...Tab[]];
48
+ tabs: (TabLabelProps | TabIconProps)[];
41
49
  /**
42
50
  * Whether the icon should appear above or to the left of the label.
43
51
  */
@@ -58,9 +66,8 @@ declare type Props = {
58
66
  */
59
67
  onTabHover?: (tabIndex: number) => void;
60
68
  /**
61
- * Size of the margin to be applied to the component. You can pass an object
62
- * with 'top', 'bottom', 'left' and 'right' properties in order to specify
63
- * different margin sizes.
69
+ * Size of the margin to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
70
+ * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
64
71
  */
65
72
  margin?: Space | Margin;
66
73
  /**
package/tag/Tag.d.ts ADDED
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ import TagPropsType from "./types";
3
+ declare const DxcTag: ({ icon, label, linkHref, onClick, iconBgColor, labelPosition, newWindow, margin, size, tabIndex, }: TagPropsType) => JSX.Element;
4
+ export default DxcTag;