@dxc-technology/halstack-react 0.0.0-cb610df → 0.0.0-cc01d9c

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 (232) hide show
  1. package/README.md +1 -1
  2. package/babel.config.js +6 -2
  3. package/dist/BackgroundColorContext.js +46 -0
  4. package/dist/ThemeContext.js +237 -2
  5. package/dist/V3Select/V3Select.js +549 -0
  6. package/dist/V3Select/index.d.ts +27 -0
  7. package/dist/V3Textarea/V3Textarea.js +264 -0
  8. package/dist/V3Textarea/index.d.ts +27 -0
  9. package/dist/accordion/Accordion.js +152 -67
  10. package/dist/accordion/index.d.ts +28 -0
  11. package/dist/accordion-group/AccordionGroup.js +186 -0
  12. package/dist/accordion-group/index.d.ts +16 -0
  13. package/dist/alert/Alert.js +183 -84
  14. package/dist/alert/index.d.ts +51 -0
  15. package/dist/badge/Badge.js +63 -0
  16. package/dist/box/Box.js +31 -23
  17. package/dist/box/index.d.ts +25 -0
  18. package/dist/button/Button.js +63 -27
  19. package/dist/button/index.d.ts +24 -0
  20. package/dist/card/Card.js +72 -35
  21. package/dist/card/index.d.ts +22 -0
  22. package/dist/checkbox/Checkbox.js +99 -40
  23. package/dist/checkbox/index.d.ts +24 -0
  24. package/dist/chip/Chip.js +97 -40
  25. package/dist/chip/index.d.ts +22 -0
  26. package/dist/common/RequiredComponent.js +2 -8
  27. package/dist/common/utils.js +2 -22
  28. package/dist/common/variables.js +1444 -304
  29. package/dist/date/Date.js +75 -52
  30. package/dist/date/index.d.ts +27 -0
  31. package/dist/date-input/DateInput.js +400 -0
  32. package/dist/date-input/index.d.ts +95 -0
  33. package/dist/dialog/Dialog.js +58 -37
  34. package/dist/dialog/index.d.ts +18 -0
  35. package/dist/dropdown/Dropdown.js +177 -82
  36. package/dist/dropdown/index.d.ts +26 -0
  37. package/dist/file-input/FileInput.js +644 -0
  38. package/dist/file-input/FileItem.js +287 -0
  39. package/dist/file-input/index.d.ts +81 -0
  40. package/dist/footer/Footer.js +90 -40
  41. package/dist/footer/Icons.js +77 -0
  42. package/dist/footer/index.d.ts +25 -0
  43. package/dist/header/Header.js +192 -95
  44. package/dist/header/Icons.js +59 -0
  45. package/dist/header/index.d.ts +25 -0
  46. package/dist/heading/Heading.js +93 -16
  47. package/dist/heading/index.d.ts +17 -0
  48. package/dist/input-text/Icons.js +22 -0
  49. package/dist/input-text/InputText.js +248 -113
  50. package/dist/input-text/index.d.ts +36 -0
  51. package/dist/layout/ApplicationLayout.js +18 -26
  52. package/dist/layout/Icons.js +55 -0
  53. package/dist/link/Link.js +107 -41
  54. package/dist/link/index.d.ts +23 -0
  55. package/dist/main.d.ts +40 -0
  56. package/dist/main.js +96 -16
  57. package/dist/number-input/NumberInput.js +136 -0
  58. package/dist/number-input/NumberInputContext.js +16 -0
  59. package/dist/number-input/index.d.ts +113 -0
  60. package/dist/paginator/Icons.js +66 -0
  61. package/dist/paginator/Paginator.js +150 -63
  62. package/dist/paginator/index.d.ts +20 -0
  63. package/dist/password-input/PasswordInput.js +203 -0
  64. package/dist/password-input/index.d.ts +94 -0
  65. package/dist/progress-bar/ProgressBar.js +95 -38
  66. package/dist/progress-bar/index.d.ts +18 -0
  67. package/dist/radio/Radio.js +31 -17
  68. package/dist/radio/index.d.ts +23 -0
  69. package/dist/resultsetTable/ResultsetTable.js +90 -65
  70. package/dist/resultsetTable/index.d.ts +19 -0
  71. package/dist/select/Select.js +914 -271
  72. package/dist/select/index.d.ts +53 -0
  73. package/dist/sidenav/Sidenav.js +66 -15
  74. package/dist/sidenav/index.d.ts +13 -0
  75. package/dist/slider/Slider.js +211 -73
  76. package/dist/slider/index.d.ts +29 -0
  77. package/dist/spinner/Spinner.js +247 -59
  78. package/dist/spinner/index.d.ts +17 -0
  79. package/dist/switch/Switch.js +50 -27
  80. package/dist/switch/index.d.ts +24 -0
  81. package/dist/table/Table.js +51 -24
  82. package/dist/table/index.d.ts +13 -0
  83. package/dist/tabs/Tabs.js +206 -35
  84. package/dist/tabs/index.d.ts +19 -0
  85. package/dist/tag/Tag.js +85 -37
  86. package/dist/tag/index.d.ts +24 -0
  87. package/dist/text-input/TextInput.js +974 -0
  88. package/dist/text-input/index.d.ts +135 -0
  89. package/dist/textarea/Textarea.js +248 -106
  90. package/dist/textarea/index.d.ts +117 -0
  91. package/dist/toggle/Toggle.js +16 -19
  92. package/dist/toggle/index.d.ts +21 -0
  93. package/dist/toggle-group/ToggleGroup.js +156 -43
  94. package/dist/toggle-group/index.d.ts +21 -0
  95. package/dist/upload/Upload.js +13 -8
  96. package/dist/upload/buttons-upload/ButtonsUpload.js +32 -19
  97. package/dist/upload/buttons-upload/Icons.js +40 -0
  98. package/dist/upload/dragAndDropArea/DragAndDropArea.js +84 -34
  99. package/dist/upload/dragAndDropArea/Icons.js +39 -0
  100. package/dist/upload/file-upload/FileToUpload.js +64 -33
  101. package/dist/upload/file-upload/Icons.js +66 -0
  102. package/dist/upload/files-upload/FilesToUpload.js +16 -16
  103. package/dist/upload/index.d.ts +15 -0
  104. package/dist/upload/transaction/Icons.js +160 -0
  105. package/dist/upload/transaction/Transaction.js +42 -49
  106. package/dist/upload/transactions/Transactions.js +38 -20
  107. package/dist/useTheme.js +22 -0
  108. package/dist/wizard/Icons.js +65 -0
  109. package/dist/wizard/Wizard.js +138 -60
  110. package/dist/wizard/index.d.ts +18 -0
  111. package/package.json +14 -11
  112. package/test/AccordionGroup.test.js +125 -0
  113. package/test/Date.test.js +15 -13
  114. package/test/DateInput.test.js +242 -0
  115. package/test/Dropdown.test.js +15 -0
  116. package/test/FileInput.test.js +201 -0
  117. package/test/Footer.test.js +2 -7
  118. package/test/Header.test.js +5 -10
  119. package/test/Heading.test.js +60 -12
  120. package/test/InputText.test.js +29 -25
  121. package/test/Link.test.js +12 -2
  122. package/test/NumberInput.test.js +259 -0
  123. package/test/Paginator.test.js +72 -60
  124. package/test/PasswordInput.test.js +83 -0
  125. package/test/ResultsetTable.test.js +66 -19
  126. package/test/Select.test.js +371 -147
  127. package/test/Slider.test.js +9 -17
  128. package/test/Spinner.test.js +5 -0
  129. package/test/Tabs.test.js +21 -0
  130. package/test/TextInput.test.js +732 -0
  131. package/test/Textarea.test.js +193 -0
  132. package/test/ToggleGroup.test.js +5 -1
  133. package/test/Upload.test.js +1 -1
  134. package/test/V3Select.test.js +212 -0
  135. package/test/{TextArea.test.js → V3TextArea.test.js} +6 -7
  136. package/dist/accordion/Accordion.stories.js +0 -207
  137. package/dist/accordion/readme.md +0 -96
  138. package/dist/alert/Alert.stories.js +0 -158
  139. package/dist/alert/close.svg +0 -4
  140. package/dist/alert/error.svg +0 -4
  141. package/dist/alert/info.svg +0 -4
  142. package/dist/alert/readme.md +0 -43
  143. package/dist/alert/success.svg +0 -4
  144. package/dist/alert/warning.svg +0 -4
  145. package/dist/button/Button.stories.js +0 -224
  146. package/dist/button/readme.md +0 -93
  147. package/dist/checkbox/Checkbox.stories.js +0 -144
  148. package/dist/checkbox/readme.md +0 -116
  149. package/dist/common/services/example-service.js +0 -10
  150. package/dist/common/services/example-service.test.js +0 -12
  151. package/dist/date/Date.stories.js +0 -205
  152. package/dist/date/calendar.svg +0 -1
  153. package/dist/date/calendar_dark.svg +0 -1
  154. package/dist/date/readme.md +0 -73
  155. package/dist/dialog/Dialog.stories.js +0 -217
  156. package/dist/dialog/readme.md +0 -32
  157. package/dist/dropdown/Dropdown.stories.js +0 -249
  158. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  159. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  160. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  161. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  162. package/dist/dropdown/readme.md +0 -69
  163. package/dist/footer/Footer.stories.js +0 -94
  164. package/dist/footer/dxc_logo_wht.png +0 -0
  165. package/dist/footer/readme.md +0 -41
  166. package/dist/header/Header.stories.js +0 -176
  167. package/dist/header/close_icon.svg +0 -1
  168. package/dist/header/dxc_logo_black.png +0 -0
  169. package/dist/header/dxc_logo_blk_rgb.svg +0 -6
  170. package/dist/header/dxc_logo_white.png +0 -0
  171. package/dist/header/hamb_menu_black.svg +0 -1
  172. package/dist/header/hamb_menu_white.svg +0 -1
  173. package/dist/header/readme.md +0 -33
  174. package/dist/input-text/InputText.stories.js +0 -209
  175. package/dist/input-text/error.svg +0 -1
  176. package/dist/input-text/readme.md +0 -91
  177. package/dist/layout/facebook.svg +0 -45
  178. package/dist/layout/linkedin.svg +0 -50
  179. package/dist/layout/twitter.svg +0 -53
  180. package/dist/link/readme.md +0 -51
  181. package/dist/paginator/images/next.svg +0 -3
  182. package/dist/paginator/images/nextPage.svg +0 -3
  183. package/dist/paginator/images/previous.svg +0 -3
  184. package/dist/paginator/images/previousPage.svg +0 -3
  185. package/dist/paginator/readme.md +0 -50
  186. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  187. package/dist/progress-bar/readme.md +0 -63
  188. package/dist/radio/Radio.stories.js +0 -166
  189. package/dist/radio/readme.md +0 -70
  190. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  191. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  192. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  193. package/dist/select/Select.stories.js +0 -235
  194. package/dist/select/readme.md +0 -72
  195. package/dist/slider/Slider.stories.js +0 -241
  196. package/dist/slider/readme.md +0 -64
  197. package/dist/spinner/Spinner.stories.js +0 -183
  198. package/dist/spinner/readme.md +0 -65
  199. package/dist/switch/Switch.stories.js +0 -134
  200. package/dist/switch/readme.md +0 -133
  201. package/dist/tabs/Tabs.stories.js +0 -130
  202. package/dist/tabs/readme.md +0 -78
  203. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  204. package/dist/tabs-for-sections/readme.md +0 -78
  205. package/dist/toggle/Toggle.stories.js +0 -297
  206. package/dist/toggle/readme.md +0 -80
  207. package/dist/toggle-group/readme.md +0 -82
  208. package/dist/upload/Upload.stories.js +0 -72
  209. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  210. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  211. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  212. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  213. package/dist/upload/file-upload/audio-icon.svg +0 -4
  214. package/dist/upload/file-upload/close.svg +0 -4
  215. package/dist/upload/file-upload/file-icon.svg +0 -4
  216. package/dist/upload/file-upload/video-icon.svg +0 -4
  217. package/dist/upload/readme.md +0 -37
  218. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  219. package/dist/upload/transaction/audio-icon.svg +0 -4
  220. package/dist/upload/transaction/error-icon.svg +0 -4
  221. package/dist/upload/transaction/file-icon-err.svg +0 -4
  222. package/dist/upload/transaction/file-icon.svg +0 -4
  223. package/dist/upload/transaction/image-icon-err.svg +0 -4
  224. package/dist/upload/transaction/image-icon.svg +0 -4
  225. package/dist/upload/transaction/success-icon.svg +0 -4
  226. package/dist/upload/transaction/video-icon-err.svg +0 -4
  227. package/dist/upload/transaction/video-icon.svg +0 -4
  228. package/dist/wizard/invalid_icon.svg +0 -6
  229. package/dist/wizard/valid_icon.svg +0 -6
  230. package/dist/wizard/validation-wrong.svg +0 -6
  231. package/test/TabsForSections.test.js +0 -34
  232. package/test/Toggle.test.js +0 -43
@@ -1,5 +1,7 @@
1
1
  import React from "react";
2
- import { render, fireEvent } from "@testing-library/react";
2
+ import { render, fireEvent, act } from "@testing-library/react";
3
+ import userEvent from "@testing-library/user-event";
4
+
3
5
  import DxcResultsetTable from "../src/resultsetTable/ResultsetTable";
4
6
 
5
7
  const columns = [
@@ -14,7 +16,7 @@ const columns = [
14
16
  {
15
17
  displayValue: "City",
16
18
  isSortable: false,
17
- }
19
+ },
18
20
  ];
19
21
 
20
22
  const rows = [
@@ -30,7 +32,7 @@ const rows = [
30
32
  {
31
33
  displayValue: "Oviedo",
32
34
  sortValue: "Oviedo",
33
- }
35
+ },
34
36
  ],
35
37
  [
36
38
  {
@@ -61,7 +63,7 @@ const rows = [
61
63
  {
62
64
  displayValue: "Albacete",
63
65
  sortValue: "Albacete",
64
- }
66
+ },
65
67
  ],
66
68
  [
67
69
  {
@@ -75,7 +77,7 @@ const rows = [
75
77
  {
76
78
  displayValue: "Albacete",
77
79
  sortValue: "Albacete",
78
- }
80
+ },
79
81
  ],
80
82
  [
81
83
  {
@@ -89,7 +91,7 @@ const rows = [
89
91
  {
90
92
  displayValue: "Madrid",
91
93
  sortValue: "Madrid",
92
- }
94
+ },
93
95
  ],
94
96
  [
95
97
  {
@@ -120,7 +122,7 @@ const rows = [
120
122
  {
121
123
  displayValue: "Madrid",
122
124
  sortValue: "Madrid",
123
- }
125
+ },
124
126
  ],
125
127
  [
126
128
  {
@@ -134,7 +136,7 @@ const rows = [
134
136
  {
135
137
  displayValue: "Barcelona",
136
138
  sortValue: "Barcelona",
137
- }
139
+ },
138
140
  ],
139
141
  [
140
142
  {
@@ -185,7 +187,7 @@ const rows2 = [
185
187
  {
186
188
  displayValue: "OtherValue",
187
189
  sortValue: "OtherValue",
188
- }
190
+ },
189
191
  ],
190
192
  [
191
193
  {
@@ -216,21 +218,22 @@ const rows2 = [
216
218
  {
217
219
  displayValue: "OtherValue",
218
220
  sortValue: "OtherValue",
219
- }
221
+ },
220
222
  ],
221
223
  ];
222
224
 
223
225
  describe("ResultsetTable component tests", () => {
224
226
  test("ResultsetTable rendered correctly", () => {
225
- const { getByText } = render(<DxcResultsetTable columns={columns} rows={rows} itemsPerPage={3}></DxcResultsetTable>);
227
+ const { getByText } = render(
228
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={3}></DxcResultsetTable>
229
+ );
226
230
  expect(getByText("Peter")).toBeTruthy();
227
231
  });
228
232
  test("Resultsettable shows as many rows as itemsPerPage", () => {
229
- const { getByText, queryByText } = render(
233
+ const { getAllByRole } = render(
230
234
  <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={3}></DxcResultsetTable>
231
235
  );
232
- expect(getByText("Peter")).toBeTruthy();
233
- expect(queryByText("Rick")).toBeFalsy();
236
+ expect(getAllByRole("row").length - 1).toEqual(3);
234
237
  });
235
238
 
236
239
  test("Resultsettable shows rows on second page", () => {
@@ -240,23 +243,49 @@ describe("ResultsetTable component tests", () => {
240
243
  expect(getByText("Peter")).toBeTruthy();
241
244
  expect(getByText("Louis")).toBeTruthy();
242
245
  expect(getByText("Lana")).toBeTruthy();
243
- const nextButton = getAllByRole("button")[2];
246
+ expect(getAllByRole("row").length - 1).toEqual(3);
247
+ const nextButton = getAllByRole("button")[3];
244
248
  fireEvent.click(nextButton);
245
249
  expect(getByText("4 to 6 of 10")).toBeTruthy();
246
- expect(getByText("Page: 2 of 4")).toBeTruthy();
250
+ // expect(getByText("Page: 2 of 4")).toBeTruthy();
251
+ expect(getByText("Rick")).toBeTruthy();
252
+ expect(getByText("Mark")).toBeTruthy();
253
+ expect(getByText("Cris")).toBeTruthy();
254
+ expect(getAllByRole("row").length - 1).toEqual(3);
255
+ });
256
+
257
+ test("Resultsettable goToPage works as expected", () => {
258
+ const { getByText, getAllByRole, getByRole } = render(
259
+ <DxcResultsetTable columns={columns} showGoToPage={true} rows={rows} itemsPerPage={3}></DxcResultsetTable>
260
+ );
261
+ expect(getByText("Peter")).toBeTruthy();
262
+ expect(getByText("Louis")).toBeTruthy();
263
+ expect(getByText("Lana")).toBeTruthy();
264
+ expect(getAllByRole("row").length - 1).toEqual(3);
265
+ const goToPageSelect = getAllByRole("button")[2];
266
+ act(() => {
267
+ userEvent.click(goToPageSelect);
268
+ });
269
+ const goToPageOption = getByText("2");
270
+ act(() => {
271
+ userEvent.click(goToPageOption);
272
+ });
273
+
274
+ expect(getByText("4 to 6 of 10")).toBeTruthy();
247
275
  expect(getByText("Rick")).toBeTruthy();
248
276
  expect(getByText("Mark")).toBeTruthy();
249
277
  expect(getByText("Cris")).toBeTruthy();
278
+ expect(getAllByRole("row").length - 1).toEqual(3);
250
279
  });
251
280
 
252
281
  test("Resultsettable going to the last page shows only one row", () => {
253
282
  const { getByText, getAllByRole } = render(
254
283
  <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={3}></DxcResultsetTable>
255
284
  );
256
- const lastButton = getAllByRole("button")[3];
285
+ debugger;
286
+ const lastButton = getAllByRole("button")[4];
257
287
  fireEvent.click(lastButton);
258
288
  expect(getByText("10 to 10 of 10")).toBeTruthy();
259
- expect(getByText("Page: 4 of 4")).toBeTruthy();
260
289
  expect(getAllByRole("row")).toHaveLength(2);
261
290
  expect(getByText("Cosmin")).toBeTruthy();
262
291
  });
@@ -273,10 +302,28 @@ describe("ResultsetTable component tests", () => {
273
302
  expect(component.queryByText("Cosmin")).not.toBeTruthy();
274
303
  });
275
304
  test("Resultsettable change rows should go to first page", () => {
276
- const {queryByText, rerender} = render(<DxcResultsetTable columns={columns} rows={rows} itemsPerPage={3}></DxcResultsetTable>);
305
+ const { queryByText, rerender } = render(
306
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={3}></DxcResultsetTable>
307
+ );
277
308
  expect(queryByText("Peter")).toBeTruthy();
278
309
  rerender(<DxcResultsetTable columns={columns} rows={rows2} itemsPerPage={3}></DxcResultsetTable>);
279
310
  expect(queryByText("1 to 3 of 3")).toBeTruthy();
280
311
  });
281
312
 
313
+ test("Resultsettable change itemsPerPage should go to first page", () => {
314
+ const { getAllByRole, queryByText, rerender } = render(
315
+ <DxcResultsetTable
316
+ columns={columns}
317
+ rows={rows}
318
+ itemsPerPage={3}
319
+ itemsPerPageOptions={[2, 3]}
320
+ ></DxcResultsetTable>
321
+ );
322
+ const lastButton = getAllByRole("button")[5];
323
+ fireEvent.click(lastButton);
324
+ expect(getAllByRole("row").length - 1).toEqual(1);
325
+ rerender(<DxcResultsetTable columns={columns} rows={rows} itemsPerPage={6}></DxcResultsetTable>);
326
+ expect(getAllByRole("row").length - 1).toEqual(6);
327
+ expect(queryByText("Peter")).toBeTruthy();
328
+ });
282
329
  });