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

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 (323) hide show
  1. package/BackgroundColorContext.js +50 -0
  2. package/ThemeContext.js +246 -0
  3. package/V3Select/V3Select.js +455 -0
  4. package/V3Select/index.d.ts +27 -0
  5. package/V3Textarea/V3Textarea.js +260 -0
  6. package/V3Textarea/index.d.ts +27 -0
  7. package/accordion/Accordion.d.ts +4 -0
  8. package/accordion/Accordion.js +258 -0
  9. package/accordion/types.d.ts +68 -0
  10. package/accordion/types.js +5 -0
  11. package/accordion-group/AccordionGroup.d.ts +7 -0
  12. package/accordion-group/AccordionGroup.js +170 -0
  13. package/accordion-group/types.d.ts +72 -0
  14. package/accordion-group/types.js +5 -0
  15. package/alert/Alert.d.ts +4 -0
  16. package/alert/Alert.js +290 -0
  17. package/alert/types.d.ts +49 -0
  18. package/alert/types.js +5 -0
  19. package/badge/Badge.js +59 -0
  20. package/{dist/box → box}/Box.js +38 -34
  21. package/box/index.d.ts +25 -0
  22. package/button/Button.d.ts +4 -0
  23. package/button/Button.js +182 -0
  24. package/button/Button.stories.tsx +293 -0
  25. package/button/types.d.ts +57 -0
  26. package/button/types.js +5 -0
  27. package/card/Card.d.ts +4 -0
  28. package/card/Card.js +165 -0
  29. package/card/types.d.ts +69 -0
  30. package/card/types.js +5 -0
  31. package/checkbox/Checkbox.d.ts +4 -0
  32. package/checkbox/Checkbox.js +253 -0
  33. package/checkbox/types.d.ts +60 -0
  34. package/checkbox/types.js +5 -0
  35. package/chip/Chip.js +221 -0
  36. package/chip/index.d.ts +22 -0
  37. package/{dist/common → common}/OpenSans.css +0 -0
  38. package/{dist/common → common}/RequiredComponent.js +3 -11
  39. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  40. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  41. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  42. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  43. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  44. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  45. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  46. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  47. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  48. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  49. package/common/utils.js +22 -0
  50. package/common/variables.js +1569 -0
  51. package/{dist/date → date}/Date.js +81 -65
  52. package/date/index.d.ts +27 -0
  53. package/date-input/DateInput.d.ts +4 -0
  54. package/date-input/DateInput.js +361 -0
  55. package/date-input/types.d.ts +100 -0
  56. package/date-input/types.js +5 -0
  57. package/dialog/Dialog.js +184 -0
  58. package/dialog/index.d.ts +18 -0
  59. package/dropdown/Dropdown.d.ts +4 -0
  60. package/dropdown/Dropdown.js +417 -0
  61. package/dropdown/types.d.ts +89 -0
  62. package/dropdown/types.js +5 -0
  63. package/file-input/FileInput.js +532 -0
  64. package/file-input/FileItem.js +193 -0
  65. package/file-input/index.d.ts +81 -0
  66. package/footer/Footer.js +297 -0
  67. package/footer/Icons.js +77 -0
  68. package/footer/index.d.ts +25 -0
  69. package/header/Header.js +326 -0
  70. package/header/Icons.js +59 -0
  71. package/header/index.d.ts +25 -0
  72. package/heading/Heading.js +176 -0
  73. package/heading/index.d.ts +17 -0
  74. package/input-text/Icons.js +22 -0
  75. package/input-text/InputText.js +611 -0
  76. package/input-text/index.d.ts +36 -0
  77. package/{dist/layout → layout}/ApplicationLayout.js +42 -142
  78. package/layout/Icons.js +55 -0
  79. package/link/Link.js +183 -0
  80. package/link/index.d.ts +23 -0
  81. package/main.d.ts +44 -0
  82. package/{dist/main.js → main.js} +125 -65
  83. package/number-input/NumberInput.js +128 -0
  84. package/number-input/NumberInputContext.js +16 -0
  85. package/number-input/index.d.ts +113 -0
  86. package/package.json +34 -22
  87. package/paginator/Icons.js +66 -0
  88. package/paginator/Paginator.d.ts +4 -0
  89. package/paginator/Paginator.js +198 -0
  90. package/paginator/types.d.ts +38 -0
  91. package/paginator/types.js +5 -0
  92. package/password-input/PasswordInput.js +199 -0
  93. package/password-input/PasswordInput.stories.jsx +131 -0
  94. package/password-input/index.d.ts +94 -0
  95. package/progress-bar/ProgressBar.d.ts +4 -0
  96. package/progress-bar/ProgressBar.js +170 -0
  97. package/progress-bar/types.d.ts +37 -0
  98. package/progress-bar/types.js +5 -0
  99. package/radio/Radio.d.ts +4 -0
  100. package/radio/Radio.js +174 -0
  101. package/radio/types.d.ts +54 -0
  102. package/radio/types.js +5 -0
  103. package/{dist/resultsetTable → resultsetTable}/ResultsetTable.js +95 -162
  104. package/resultsetTable/index.d.ts +19 -0
  105. package/select/Select.js +865 -0
  106. package/select/index.d.ts +131 -0
  107. package/sidenav/Sidenav.js +145 -0
  108. package/sidenav/index.d.ts +13 -0
  109. package/slider/Slider.d.ts +4 -0
  110. package/slider/Slider.js +306 -0
  111. package/slider/types.d.ts +83 -0
  112. package/slider/types.js +5 -0
  113. package/spinner/Spinner.js +267 -0
  114. package/spinner/index.d.ts +17 -0
  115. package/switch/Switch.d.ts +4 -0
  116. package/switch/Switch.js +179 -0
  117. package/switch/types.d.ts +58 -0
  118. package/switch/types.js +5 -0
  119. package/table/Table.js +118 -0
  120. package/table/index.d.ts +13 -0
  121. package/tabs/Tabs.d.ts +4 -0
  122. package/tabs/Tabs.js +211 -0
  123. package/tabs/types.d.ts +71 -0
  124. package/tabs/types.js +5 -0
  125. package/tag/Tag.js +208 -0
  126. package/tag/index.d.ts +24 -0
  127. package/text-input/TextInput.js +825 -0
  128. package/text-input/index.d.ts +135 -0
  129. package/textarea/Textarea.js +317 -0
  130. package/textarea/Textarea.stories.jsx +135 -0
  131. package/textarea/index.d.ts +117 -0
  132. package/{dist/toggle → toggle}/Toggle.js +30 -67
  133. package/toggle/index.d.ts +21 -0
  134. package/toggle-group/ToggleGroup.js +243 -0
  135. package/toggle-group/index.d.ts +21 -0
  136. package/{dist/upload → upload}/Upload.js +23 -22
  137. package/upload/buttons-upload/ButtonsUpload.js +111 -0
  138. package/upload/buttons-upload/Icons.js +40 -0
  139. package/upload/dragAndDropArea/DragAndDropArea.js +225 -0
  140. package/upload/dragAndDropArea/Icons.js +39 -0
  141. package/upload/file-upload/FileToUpload.js +115 -0
  142. package/upload/file-upload/Icons.js +66 -0
  143. package/upload/files-upload/FilesToUpload.js +109 -0
  144. package/upload/index.d.ts +15 -0
  145. package/upload/transaction/Icons.js +160 -0
  146. package/upload/transaction/Transaction.js +104 -0
  147. package/upload/transactions/Transactions.js +94 -0
  148. package/{dist/useTheme.js → useTheme.js} +0 -0
  149. package/wizard/Icons.js +65 -0
  150. package/wizard/Wizard.js +271 -0
  151. package/wizard/index.d.ts +18 -0
  152. package/README.md +0 -66
  153. package/babel.config.js +0 -4
  154. package/dist/ThemeContext.js +0 -54
  155. package/dist/accordion/Accordion.js +0 -273
  156. package/dist/accordion/Accordion.stories.js +0 -207
  157. package/dist/accordion/readme.md +0 -96
  158. package/dist/accordion-group/AccordionGroup.js +0 -159
  159. package/dist/accordion-group/AccordionGroup.stories.js +0 -207
  160. package/dist/accordion-group/readme.md +0 -70
  161. package/dist/alert/Alert.js +0 -304
  162. package/dist/alert/Alert.stories.js +0 -158
  163. package/dist/alert/close.svg +0 -4
  164. package/dist/alert/error.svg +0 -4
  165. package/dist/alert/info.svg +0 -4
  166. package/dist/alert/readme.md +0 -43
  167. package/dist/alert/success.svg +0 -4
  168. package/dist/alert/warning.svg +0 -4
  169. package/dist/badge/Badge.js +0 -58
  170. package/dist/button/Button.js +0 -202
  171. package/dist/button/Button.stories.js +0 -224
  172. package/dist/button/readme.md +0 -93
  173. package/dist/card/Card.js +0 -217
  174. package/dist/checkbox/Checkbox.js +0 -240
  175. package/dist/checkbox/Checkbox.stories.js +0 -144
  176. package/dist/checkbox/readme.md +0 -116
  177. package/dist/chip/Chip.js +0 -208
  178. package/dist/common/services/example-service.js +0 -10
  179. package/dist/common/services/example-service.test.js +0 -12
  180. package/dist/common/utils.js +0 -42
  181. package/dist/common/variables.js +0 -436
  182. package/dist/date/Date.stories.js +0 -205
  183. package/dist/date/calendar.svg +0 -1
  184. package/dist/date/calendar_dark.svg +0 -1
  185. package/dist/date/readme.md +0 -73
  186. package/dist/dialog/Dialog.js +0 -197
  187. package/dist/dialog/Dialog.stories.js +0 -217
  188. package/dist/dialog/readme.md +0 -32
  189. package/dist/dropdown/Dropdown.js +0 -449
  190. package/dist/dropdown/Dropdown.stories.js +0 -249
  191. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  192. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  193. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  194. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  195. package/dist/dropdown/readme.md +0 -69
  196. package/dist/footer/Footer.js +0 -371
  197. package/dist/footer/Footer.stories.js +0 -94
  198. package/dist/footer/dxc_logo_wht.png +0 -0
  199. package/dist/footer/readme.md +0 -41
  200. package/dist/header/Header.js +0 -373
  201. package/dist/header/Header.stories.js +0 -176
  202. package/dist/header/close_icon.svg +0 -1
  203. package/dist/header/dxc_logo_black.png +0 -0
  204. package/dist/header/dxc_logo_blk_rgb.svg +0 -6
  205. package/dist/header/dxc_logo_white.png +0 -0
  206. package/dist/header/hamb_menu_black.svg +0 -1
  207. package/dist/header/hamb_menu_white.svg +0 -1
  208. package/dist/header/readme.md +0 -33
  209. package/dist/heading/Heading.js +0 -153
  210. package/dist/input-text/InputText.js +0 -570
  211. package/dist/input-text/InputText.stories.js +0 -209
  212. package/dist/input-text/error.svg +0 -1
  213. package/dist/input-text/readme.md +0 -91
  214. package/dist/layout/facebook.svg +0 -45
  215. package/dist/layout/linkedin.svg +0 -50
  216. package/dist/layout/twitter.svg +0 -53
  217. package/dist/link/Link.js +0 -192
  218. package/dist/link/readme.md +0 -51
  219. package/dist/paginator/Paginator.js +0 -232
  220. package/dist/paginator/images/next.svg +0 -3
  221. package/dist/paginator/images/nextPage.svg +0 -3
  222. package/dist/paginator/images/previous.svg +0 -3
  223. package/dist/paginator/images/previousPage.svg +0 -3
  224. package/dist/paginator/readme.md +0 -50
  225. package/dist/progress-bar/ProgressBar.js +0 -185
  226. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  227. package/dist/progress-bar/readme.md +0 -63
  228. package/dist/radio/Radio.js +0 -195
  229. package/dist/radio/Radio.stories.js +0 -166
  230. package/dist/radio/readme.md +0 -70
  231. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  232. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  233. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  234. package/dist/select/Select.js +0 -473
  235. package/dist/select/Select.stories.js +0 -235
  236. package/dist/select/readme.md +0 -72
  237. package/dist/sidenav/Sidenav.js +0 -128
  238. package/dist/slider/Slider.js +0 -266
  239. package/dist/slider/Slider.stories.js +0 -241
  240. package/dist/slider/readme.md +0 -64
  241. package/dist/spinner/Spinner.js +0 -193
  242. package/dist/spinner/Spinner.stories.js +0 -183
  243. package/dist/spinner/readme.md +0 -65
  244. package/dist/switch/Switch.js +0 -199
  245. package/dist/switch/Switch.stories.js +0 -134
  246. package/dist/switch/readme.md +0 -133
  247. package/dist/table/Table.js +0 -105
  248. package/dist/tabs/Tabs.js +0 -292
  249. package/dist/tabs/Tabs.stories.js +0 -130
  250. package/dist/tabs/readme.md +0 -78
  251. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  252. package/dist/tabs-for-sections/readme.md +0 -78
  253. package/dist/tag/Tag.js +0 -249
  254. package/dist/textarea/Textarea.js +0 -227
  255. package/dist/toggle/Toggle.stories.js +0 -297
  256. package/dist/toggle/readme.md +0 -80
  257. package/dist/toggle-group/ToggleGroup.js +0 -226
  258. package/dist/toggle-group/readme.md +0 -82
  259. package/dist/upload/Upload.stories.js +0 -72
  260. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -122
  261. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  262. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  263. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -279
  264. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  265. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  266. package/dist/upload/file-upload/FileToUpload.js +0 -158
  267. package/dist/upload/file-upload/audio-icon.svg +0 -4
  268. package/dist/upload/file-upload/close.svg +0 -4
  269. package/dist/upload/file-upload/file-icon.svg +0 -4
  270. package/dist/upload/file-upload/video-icon.svg +0 -4
  271. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  272. package/dist/upload/readme.md +0 -37
  273. package/dist/upload/transaction/Transaction.js +0 -155
  274. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  275. package/dist/upload/transaction/audio-icon.svg +0 -4
  276. package/dist/upload/transaction/error-icon.svg +0 -4
  277. package/dist/upload/transaction/file-icon-err.svg +0 -4
  278. package/dist/upload/transaction/file-icon.svg +0 -4
  279. package/dist/upload/transaction/image-icon-err.svg +0 -4
  280. package/dist/upload/transaction/image-icon.svg +0 -4
  281. package/dist/upload/transaction/success-icon.svg +0 -4
  282. package/dist/upload/transaction/video-icon-err.svg +0 -4
  283. package/dist/upload/transaction/video-icon.svg +0 -4
  284. package/dist/upload/transactions/Transactions.js +0 -120
  285. package/dist/wizard/Wizard.js +0 -331
  286. package/dist/wizard/invalid_icon.svg +0 -6
  287. package/dist/wizard/valid_icon.svg +0 -6
  288. package/dist/wizard/validation-wrong.svg +0 -6
  289. package/test/Accordion.test.js +0 -33
  290. package/test/AccordionGroup.test.js +0 -109
  291. package/test/Alert.test.js +0 -53
  292. package/test/Box.test.js +0 -10
  293. package/test/Button.test.js +0 -18
  294. package/test/Card.test.js +0 -30
  295. package/test/Checkbox.test.js +0 -45
  296. package/test/Chip.test.js +0 -25
  297. package/test/Date.test.js +0 -393
  298. package/test/Dialog.test.js +0 -23
  299. package/test/Dropdown.test.js +0 -130
  300. package/test/Footer.test.js +0 -99
  301. package/test/Header.test.js +0 -39
  302. package/test/Heading.test.js +0 -35
  303. package/test/InputText.test.js +0 -240
  304. package/test/Link.test.js +0 -42
  305. package/test/Paginator.test.js +0 -194
  306. package/test/ProgressBar.test.js +0 -35
  307. package/test/Radio.test.js +0 -37
  308. package/test/ResultsetTable.test.js +0 -304
  309. package/test/Select.test.js +0 -192
  310. package/test/Sidenav.test.js +0 -45
  311. package/test/Slider.test.js +0 -82
  312. package/test/Spinner.test.js +0 -27
  313. package/test/Switch.test.js +0 -45
  314. package/test/Table.test.js +0 -36
  315. package/test/Tabs.test.js +0 -109
  316. package/test/TabsForSections.test.js +0 -34
  317. package/test/Tag.test.js +0 -32
  318. package/test/TextArea.test.js +0 -52
  319. package/test/ToggleGroup.test.js +0 -81
  320. package/test/Upload.test.js +0 -60
  321. package/test/Wizard.test.js +0 -130
  322. package/test/mocks/pngMock.js +0 -1
  323. package/test/mocks/svgMock.js +0 -1
@@ -1,304 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent } from "@testing-library/react";
3
- import DxcResultsetTable from "../src/resultsetTable/ResultsetTable";
4
-
5
- const columns = [
6
- {
7
- displayValue: "Id",
8
- isSortable: false,
9
- },
10
- {
11
- displayValue: "Name",
12
- isSortable: true,
13
- },
14
- {
15
- displayValue: "City",
16
- isSortable: false,
17
- },
18
- ];
19
-
20
- const rows = [
21
- [
22
- {
23
- displayValue: "001",
24
- sortValue: "001",
25
- },
26
- {
27
- displayValue: "Peter",
28
- sortValue: "Peter",
29
- },
30
- {
31
- displayValue: "Oviedo",
32
- sortValue: "Oviedo",
33
- },
34
- ],
35
- [
36
- {
37
- displayValue: "002",
38
- sortValue: "002",
39
- },
40
- {
41
- displayValue: "Louis",
42
- sortValue: "Louis",
43
- },
44
- {
45
- displayValue: "Oviedo",
46
- sortValue: "Oviedo",
47
- },
48
- {
49
- displayValue: "",
50
- },
51
- ],
52
- [
53
- {
54
- displayValue: "003",
55
- sortValue: "003",
56
- },
57
- {
58
- displayValue: "Lana",
59
- sortValue: "Lana",
60
- },
61
- {
62
- displayValue: "Albacete",
63
- sortValue: "Albacete",
64
- },
65
- ],
66
- [
67
- {
68
- displayValue: "004",
69
- sortValue: "004",
70
- },
71
- {
72
- displayValue: "Rick",
73
- sortValue: "Rick",
74
- },
75
- {
76
- displayValue: "Albacete",
77
- sortValue: "Albacete",
78
- },
79
- ],
80
- [
81
- {
82
- displayValue: "005",
83
- sortValue: "005",
84
- },
85
- {
86
- displayValue: "Mark",
87
- sortValue: "Mark",
88
- },
89
- {
90
- displayValue: "Madrid",
91
- sortValue: "Madrid",
92
- },
93
- ],
94
- [
95
- {
96
- displayValue: "006",
97
- sortValue: "006",
98
- },
99
- {
100
- displayValue: "Cris",
101
- sortValue: "Cris",
102
- },
103
- {
104
- displayValue: "Barcelona",
105
- sortValue: "Barcelona",
106
- },
107
- {
108
- displayValue: "",
109
- },
110
- ],
111
- [
112
- {
113
- displayValue: "007",
114
- sortValue: "007",
115
- },
116
- {
117
- displayValue: "Susan",
118
- sortValue: "Susan",
119
- },
120
- {
121
- displayValue: "Madrid",
122
- sortValue: "Madrid",
123
- },
124
- ],
125
- [
126
- {
127
- displayValue: "008",
128
- sortValue: "008",
129
- },
130
- {
131
- displayValue: "Tina",
132
- sortValue: "Tina",
133
- },
134
- {
135
- displayValue: "Barcelona",
136
- sortValue: "Barcelona",
137
- },
138
- ],
139
- [
140
- {
141
- displayValue: "009",
142
- sortValue: "009",
143
- },
144
- {
145
- displayValue: "Kevin",
146
- sortValue: "Kevin",
147
- },
148
- {
149
- displayValue: "Oviedo",
150
- sortValue: "Oviedo",
151
- },
152
- {
153
- displayValue: "",
154
- },
155
- ],
156
- [
157
- {
158
- displayValue: "010",
159
- sortValue: "010",
160
- },
161
- {
162
- displayValue: "Cosmin",
163
- sortValue: "Cosmin",
164
- },
165
- {
166
- displayValue: "Barcelona",
167
- sortValue: "Barcelona",
168
- },
169
- {
170
- displayValue: "",
171
- },
172
- ],
173
- ];
174
-
175
- const rows2 = [
176
- [
177
- {
178
- displayValue: "546",
179
- sortValue: "465",
180
- },
181
- {
182
- displayValue: "OtherValue",
183
- sortValue: "OtherValue",
184
- },
185
- {
186
- displayValue: "OtherValue",
187
- sortValue: "OtherValue",
188
- },
189
- ],
190
- [
191
- {
192
- displayValue: "978",
193
- sortValue: "465",
194
- },
195
- {
196
- displayValue: "OtherValue",
197
- sortValue: "OtherValue",
198
- },
199
- {
200
- displayValue: "OtherValue",
201
- sortValue: "OtherValue",
202
- },
203
- {
204
- displayValue: "",
205
- },
206
- ],
207
- [
208
- {
209
- displayValue: "678",
210
- sortValue: "344",
211
- },
212
- {
213
- displayValue: "OtherValue",
214
- sortValue: "OtherValue",
215
- },
216
- {
217
- displayValue: "OtherValue",
218
- sortValue: "OtherValue",
219
- },
220
- ],
221
- ];
222
-
223
- describe("ResultsetTable component tests", () => {
224
- test("ResultsetTable rendered correctly", () => {
225
- const { getByText } = render(
226
- <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={3}></DxcResultsetTable>
227
- );
228
- expect(getByText("Peter")).toBeTruthy();
229
- });
230
- test("Resultsettable shows as many rows as itemsPerPage", () => {
231
- const { getAllByRole } = render(
232
- <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={3}></DxcResultsetTable>
233
- );
234
- expect(getAllByRole("row").length - 1).toEqual(3);
235
- });
236
-
237
- test("Resultsettable shows rows on second page", () => {
238
- const { getByText, getAllByRole } = render(
239
- <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={3}></DxcResultsetTable>
240
- );
241
- expect(getByText("Peter")).toBeTruthy();
242
- expect(getByText("Louis")).toBeTruthy();
243
- expect(getByText("Lana")).toBeTruthy();
244
- expect(getAllByRole("row").length - 1).toEqual(3);
245
- const nextButton = getAllByRole("button")[2];
246
- fireEvent.click(nextButton);
247
- expect(getByText("4 to 6 of 10")).toBeTruthy();
248
- expect(getByText("Page: 2 of 4")).toBeTruthy();
249
- expect(getByText("Rick")).toBeTruthy();
250
- expect(getByText("Mark")).toBeTruthy();
251
- expect(getByText("Cris")).toBeTruthy();
252
- expect(getAllByRole("row").length - 1).toEqual(3);
253
- });
254
-
255
- test("Resultsettable going to the last page shows only one row", () => {
256
- const { getByText, getAllByRole } = render(
257
- <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={3}></DxcResultsetTable>
258
- );
259
- const lastButton = getAllByRole("button")[3];
260
- fireEvent.click(lastButton);
261
- expect(getByText("10 to 10 of 10")).toBeTruthy();
262
- expect(getByText("Page: 4 of 4")).toBeTruthy();
263
- expect(getAllByRole("row")).toHaveLength(2);
264
- expect(getByText("Cosmin")).toBeTruthy();
265
- });
266
-
267
- test("Resultsettable sort rows by column", () => {
268
- const component = render(<DxcResultsetTable columns={columns} rows={rows} itemsPerPage={3}></DxcResultsetTable>);
269
- expect(component.queryByText("Peter")).toBeTruthy();
270
- fireEvent.click(component.queryByText("Name"));
271
- expect(component.queryByText("Tina")).not.toBeTruthy();
272
- expect(component.queryByText("Cosmin")).toBeTruthy();
273
-
274
- fireEvent.click(component.queryByText("Name"));
275
- expect(component.queryByText("Tina")).toBeTruthy();
276
- expect(component.queryByText("Cosmin")).not.toBeTruthy();
277
- });
278
- test("Resultsettable change rows should go to first page", () => {
279
- const { queryByText, rerender } = render(
280
- <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={3}></DxcResultsetTable>
281
- );
282
- expect(queryByText("Peter")).toBeTruthy();
283
- rerender(<DxcResultsetTable columns={columns} rows={rows2} itemsPerPage={3}></DxcResultsetTable>);
284
- expect(queryByText("1 to 3 of 3")).toBeTruthy();
285
- });
286
-
287
- test("Resultsettable change itemsPerPage should go to first page", () => {
288
- const { getAllByRole, queryByText, rerender } = render(
289
- <DxcResultsetTable
290
- columns={columns}
291
- rows={rows}
292
- itemsPerPage={3}
293
- itemsPerPageOptions={[2, 3]}
294
- ></DxcResultsetTable>
295
- );
296
- const lastButton = getAllByRole("button")[4];
297
- fireEvent.click(lastButton);
298
- expect(getAllByRole("row").length - 1).toEqual(1);
299
- expect(queryByText("Page: 4 of 4")).toBeTruthy();
300
- rerender(<DxcResultsetTable columns={columns} rows={rows} itemsPerPage={6}></DxcResultsetTable>);
301
- expect(getAllByRole("row").length - 1).toEqual(6);
302
- expect(queryByText("Page: 1 of 2")).toBeTruthy();
303
- });
304
- });
@@ -1,192 +0,0 @@
1
- import React from "react";
2
- import { render, act } from "@testing-library/react";
3
- import userEvent from "@testing-library/user-event";
4
- import DxcSelect from "../src/select/Select";
5
-
6
- const optionsWithoutIcon = [
7
- {
8
- value: 1,
9
- label: "Amazon",
10
- },
11
- {
12
- value: 2,
13
- label: "Ebay",
14
- },
15
- {
16
- value: 3,
17
- label: "Apple",
18
- },
19
- ];
20
-
21
- const optionsWithIcons = [
22
- {
23
- value: 1,
24
- label: "Facebook",
25
- iconSrc: "/testIconFacebook",
26
- },
27
- {
28
- value: 2,
29
- label: "Twitter",
30
- iconSrc: "/testIconTwitter",
31
- },
32
- {
33
- value: 3,
34
- label: "Linkedin",
35
- iconSrc: "/testIconLinkedin",
36
- },
37
- ];
38
-
39
- describe("Select component tests", () => {
40
- test("Select renders with correct label", () => {
41
- const { getByText } = render(<DxcSelect label="test-select-label"></DxcSelect>);
42
- expect(getByText("test-select-label")).toBeTruthy();
43
- });
44
-
45
- test("Select renders options when select is clicked", () => {
46
- const { getByText, getByRole, queryByText } = render(
47
- <DxcSelect label="test-select-name" options={optionsWithoutIcon}></DxcSelect>
48
- );
49
- //Before are not shown
50
- expect(queryByText("Amazon")).toBeFalsy();
51
- expect(queryByText("Ebay")).toBeFalsy();
52
- expect(queryByText("Apple")).toBeFalsy();
53
- const select = getByRole("button");
54
- act(() => {
55
- userEvent.click(select);
56
- });
57
- expect(getByText("Amazon")).toBeTruthy();
58
- expect(getByText("Ebay")).toBeTruthy();
59
- expect(getByText("Apple")).toBeTruthy();
60
- });
61
-
62
- test("Select renders options with icons before", () => {
63
- const { getByRole, getAllByRole } = render(
64
- <DxcSelect label="test-select-name" options={optionsWithIcons}></DxcSelect>
65
- );
66
- const select = getByRole("button");
67
- act(() => {
68
- userEvent.click(select);
69
- });
70
- expect(getAllByRole("img")[0].getAttribute("src")).toEqual("/testIconFacebook");
71
- expect(getAllByRole("img")[1].getAttribute("src")).toEqual("/testIconTwitter");
72
- expect(getAllByRole("img")[2].getAttribute("src")).toEqual("/testIconLinkedin");
73
- });
74
-
75
- test("Select renders options with icons after", () => {
76
- const { getByRole, getAllByRole } = render(
77
- <DxcSelect label="test-select-name" options={optionsWithIcons} iconPosition="after"></DxcSelect>
78
- );
79
- const select = getByRole("button");
80
- act(() => {
81
- userEvent.click(select);
82
- });
83
- expect(getAllByRole("img")[0].getAttribute("src")).toEqual("/testIconFacebook");
84
- expect(getAllByRole("img")[1].getAttribute("src")).toEqual("/testIconTwitter");
85
- expect(getAllByRole("img")[2].getAttribute("src")).toEqual("/testIconLinkedin");
86
- });
87
-
88
- test("Select renders with a default value", () => {
89
- const { getByText } = render(
90
- <DxcSelect label="test-select-name" options={optionsWithoutIcon} value={1}></DxcSelect>
91
- );
92
- expect(getByText("Amazon")).toBeTruthy();
93
- });
94
-
95
- test("Select renders with multiple default values", () => {
96
- const { getByText } = render(
97
- <DxcSelect label="test-select-name" options={optionsWithoutIcon} value={[1, 2]} multiple></DxcSelect>
98
- );
99
- expect(getByText("Amazon, Ebay")).toBeTruthy();
100
- });
101
-
102
- test("Disabled select is not clickable", () => {
103
- const { getByText, queryByText } = render(
104
- <DxcSelect label="test-select-name" options={optionsWithoutIcon} disabled></DxcSelect>
105
- );
106
- expect(queryByText("Amazon")).toBeFalsy();
107
- expect(queryByText("Ebay")).toBeFalsy();
108
- expect(queryByText("Apple")).toBeFalsy();
109
- const select = getByText("test-select-name");
110
- act(() => {
111
- userEvent.click(select);
112
- });
113
- expect(queryByText("Amazon")).toBeFalsy();
114
- expect(queryByText("Ebay")).toBeFalsy();
115
- expect(queryByText("Apple")).toBeFalsy();
116
- });
117
-
118
- test("Controlled select with unique value", () => {
119
- const onChange = jest.fn();
120
- const { getByText, getAllByText } = render(
121
- <DxcSelect label="test-select-name" options={optionsWithoutIcon} value={1} onChange={onChange}></DxcSelect>
122
- );
123
- const select = getByText("Amazon");
124
- act(() => {
125
- userEvent.click(select);
126
- });
127
- const option2 = getByText("Ebay");
128
- act(() => {
129
- userEvent.click(option2);
130
- });
131
- expect(onChange).toHaveBeenCalledWith(2);
132
- //The value is not changed
133
- expect(getAllByText("Amazon").length).toBe(2);
134
- });
135
-
136
- test("Controlled select with multiple values", () => {
137
- const onChange = jest.fn();
138
- const { getByText } = render(
139
- <DxcSelect
140
- label="test-select-name"
141
- options={optionsWithoutIcon}
142
- value={[1, 2]}
143
- multiple
144
- onChange={onChange}
145
- ></DxcSelect>
146
- );
147
- const select = getByText("Amazon, Ebay");
148
- act(() => {
149
- userEvent.click(select);
150
- });
151
- const option3 = getByText("Apple");
152
- act(() => {
153
- userEvent.click(option3);
154
- });
155
- expect(onChange).toHaveBeenCalledWith([1, 2, 3]);
156
- //The value is not changed
157
- expect(getByText("Amazon, Ebay")).toBeTruthy();
158
- });
159
-
160
- test("Uncontrolled select with multiple values", () => {
161
- const onChange = jest.fn();
162
- const { getByText, getByRole } = render(
163
- <DxcSelect label="test-select-name" options={optionsWithoutIcon} multiple onChange={onChange}></DxcSelect>
164
- );
165
- const select = getByRole("button");
166
- act(() => {
167
- userEvent.click(select);
168
- });
169
- const option1 = getByText("Amazon");
170
- const option2 = getByText("Ebay");
171
- const option3 = getByText("Apple");
172
- act(() => {
173
- userEvent.click(option1);
174
- });
175
- expect(onChange).toHaveBeenCalledWith([1]);
176
- act(() => {
177
- userEvent.click(option2);
178
- });
179
- expect(onChange).toHaveBeenCalledWith([1, 2]);
180
- expect(getByText("Amazon, Ebay")).toBeTruthy();
181
- act(() => {
182
- userEvent.click(option3);
183
- });
184
- expect(onChange).toHaveBeenCalledWith([1, 2, 3]);
185
- expect(getByText("Amazon, Ebay, Apple")).toBeTruthy();
186
- act(() => {
187
- userEvent.click(option1);
188
- });
189
- expect(onChange).toHaveBeenCalledWith([2, 3]);
190
- expect(getByText("Ebay, Apple")).toBeTruthy();
191
- });
192
- });
@@ -1,45 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent } from "@testing-library/react";
3
- import DxcSidenav from "../src/sidenav/Sidenav";
4
-
5
- const navContent = <p>nav-content-test</p>;
6
-
7
- describe("Sidenav component tests", () => {
8
- test("Sidenav renders nav content", () => {
9
- const { getByText } = render(<DxcSidenav>{navContent}</DxcSidenav>);
10
- expect(getByText("nav-content-test")).toBeTruthy();
11
- });
12
-
13
- test("Sidenav renders nav and page content in mobile version", () => {
14
- //425 is mobile width
15
- Object.defineProperty(HTMLElement.prototype, "offsetWidth", { configurable: true, value: 425 });
16
- const { getByText } = render(<DxcSidenav>{navContent}</DxcSidenav>);
17
- expect(getByText("nav-content-test")).toBeTruthy();
18
- });
19
-
20
- test("Sidenav renders compound components", () => {
21
- const { getByText } = render(
22
- <DxcSidenav>
23
- <DxcSidenav.Title>test-title</DxcSidenav.Title>
24
- <DxcSidenav.Subtitle>test-subtitle</DxcSidenav.Subtitle>
25
- <DxcSidenav.Link href="#">test-link</DxcSidenav.Link>
26
- </DxcSidenav>
27
- );
28
- expect(getByText("test-title")).toBeTruthy();
29
- expect(getByText("test-subtitle")).toBeTruthy();
30
- expect(getByText("test-link")).toBeTruthy();
31
- });
32
-
33
- test("Sidenav link onClick", () => {
34
- const onClick = jest.fn();
35
- const { getByText } = render(
36
- <DxcSidenav>
37
- <DxcSidenav.Link onClick={onClick}>test-link</DxcSidenav.Link>
38
- </DxcSidenav>
39
- );
40
-
41
- const link = getByText("test-link");
42
- fireEvent.click(link);
43
- expect(onClick).toHaveBeenCalled();
44
- });
45
- });
@@ -1,82 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent, act } from "@testing-library/react";
3
- import DxcSlider from "../src/slider/Slider";
4
-
5
- describe("Slider component tests", () => {
6
- test("Slider renders with correct text", () => {
7
- const { getByText } = render(<DxcSlider minValue={0} maxValue={100} showLimitsValues></DxcSlider>);
8
- expect(getByText("0")).toBeTruthy();
9
- expect(getByText("100")).toBeTruthy();
10
- });
11
-
12
- test("Calls correct function onChange in controlled slider", () => {
13
- const onChange = jest.fn();
14
- const { getByRole } = render(
15
- <DxcSlider minValue={0} maxValue={100} onChange={onChange} showLimitsValues value={13} showInput></DxcSlider>
16
- );
17
- act(() => {
18
- fireEvent.change(getByRole("textbox"), { target: { value: 25 } });
19
- });
20
- expect(onChange).toHaveBeenCalledWith("25");
21
- });
22
-
23
- test("Calls correct function onChange in uncontrolled slider", () => {
24
- const onChange = jest.fn();
25
- const { getByRole } = render(
26
- <DxcSlider minValue={0} maxValue={100} onChange={onChange} showLimitsValues showInput></DxcSlider>
27
- );
28
- act(() => {
29
- fireEvent.change(getByRole("textbox"), { target: { value: 25 } });
30
- });
31
- expect(onChange).toHaveBeenCalledWith("25");
32
- });
33
-
34
- test("Disabled slider have disabled input", () => {
35
- const onChange = jest.fn();
36
- const { getByRole } = render(
37
- <DxcSlider
38
- minValue={0}
39
- maxValue={100}
40
- onChange={onChange}
41
- showLimitsValues
42
- disabled
43
- showInput
44
- value={13}
45
- ></DxcSlider>
46
- );
47
- act(() => {
48
- fireEvent.change(getByRole("textbox"), { target: { value: 25 } });
49
- });
50
- expect(getByRole("textbox").hasAttribute("disabled")).toBeTruthy();
51
- expect(getByRole("textbox").value).toBe("13");
52
- });
53
-
54
- test("Calls correct function onDragEnd", () => {
55
- const onDragEnd = jest.fn();
56
- const { getByRole } = render(
57
- <DxcSlider minValue={0} maxValue={100} showLimitsValues showInput onDragEnd={onDragEnd} value={25}></DxcSlider>
58
- );
59
- act(() => {
60
- fireEvent.mouseDown(getByRole("slider"));
61
- fireEvent.mouseUp(getByRole("slider"));
62
- });
63
- expect(onDragEnd).toHaveBeenCalled();
64
- });
65
-
66
- test("Calls correct function labelFormatCallback", () => {
67
- const labelFormatCallback = jest.fn(x => `${x}$`);
68
- const { getByText } = render(
69
- <DxcSlider
70
- minValue={0}
71
- maxValue={100}
72
- showLimitsValues
73
- showInput
74
- value={25}
75
- labelFormatCallback={labelFormatCallback}
76
- ></DxcSlider>
77
- );
78
- expect(getByText("0$")).toBeTruthy();
79
- expect(getByText("100$")).toBeTruthy();
80
- expect(labelFormatCallback).toHaveBeenCalledTimes(2);
81
- });
82
- });
@@ -1,27 +0,0 @@
1
- import React from "react";
2
- import { render } from "@testing-library/react";
3
- import DxcSpinner from "../src/spinner/Spinner";
4
-
5
- describe("Spinner component tests", () => {
6
- test("Spinner renders with correct label", () => {
7
- const { getByText } = render(<DxcSpinner label="test-loading"></DxcSpinner>);
8
- expect(getByText("test-loading")).toBeTruthy();
9
- });
10
-
11
- test("Spinner shows value correctly", () => {
12
- const { getByText } = render(<DxcSpinner label="test-loading" value={75} showValue></DxcSpinner>);
13
- expect(getByText("75%")).toBeTruthy();
14
- });
15
-
16
- test("Small spinner hides value and label correctly", () => {
17
- const { queryByText } = render(<DxcSpinner mode="small" label="test-loading" value={75} showValue></DxcSpinner>);
18
- expect(queryByText("test-loading")).toBeFalsy();
19
- expect(queryByText("75%")).toBeFalsy();
20
- });
21
-
22
- test("Overlay spinner shows value and label correctly", () => {
23
- const { getByText } = render(<DxcSpinner mode="overlay" label="test-loading" value={75} showValue></DxcSpinner>);
24
- expect(getByText("test-loading")).toBeTruthy();
25
- expect(getByText("75%")).toBeTruthy();
26
- });
27
- });
@@ -1,45 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent } from "@testing-library/react";
3
- import DxcSwitch from "../src/switch/Switch";
4
-
5
- describe("Switch component tests", () => {
6
- test("Switch renders with correct text", () => {
7
- const onChange = jest.fn((returnedValue) => {
8
- expect(returnedValue).toBe(true);
9
- });
10
-
11
- const { getByText } = render(<DxcSwitch label={"SwitchComponent"} checked={false} onChange={onChange} />);
12
- expect(getByText("SwitchComponent")).toBeTruthy();
13
- });
14
-
15
- test("Calls correct function on click", () => {
16
- const onChange = jest.fn();
17
- const { getByText } = render(<DxcSwitch label={"SwitchComponent"} checked={false} onChange={onChange} />);
18
-
19
- fireEvent.click(getByText("SwitchComponent"));
20
- expect(onChange).toHaveBeenCalled();
21
- });
22
-
23
- test("Everytime the user clicks the component the onchange function is called with the correct value CONTROLLED COMPONENT", () => {
24
- const onChange = jest.fn();
25
-
26
- const { getByText } = render(<DxcSwitch label={"SwitchComponent"} checked={false} onChange={onChange} />);
27
-
28
- fireEvent.click(getByText("SwitchComponent"));
29
- fireEvent.click(getByText("SwitchComponent"));
30
- expect(onChange.mock.calls[0][0]).toBe(true);
31
- expect(onChange.mock.calls[1][0]).toBe(true);
32
- });
33
-
34
-
35
- test("Everytime the user clicks the component the onchange function is called with the correct value UNCONTROLLED COMPONENT", () => {
36
- const onChange = jest.fn();
37
-
38
- const { getByText } = render(<DxcSwitch label={"SwitchComponent"} onChange={onChange} />);
39
-
40
- fireEvent.click(getByText("SwitchComponent"));
41
- fireEvent.click(getByText("SwitchComponent"));
42
- expect(onChange.mock.calls[0][0]).toBe(true);
43
- expect(onChange.mock.calls[1][0]).toBe(false);
44
- });
45
- });