@dxc-technology/halstack-react 0.0.0-b177758 → 0.0.0-b243e75

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 (293) 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.js +289 -0
  8. package/accordion/index.d.ts +28 -0
  9. package/accordion-group/AccordionGroup.js +184 -0
  10. package/accordion-group/index.d.ts +16 -0
  11. package/alert/Alert.js +309 -0
  12. package/alert/index.d.ts +51 -0
  13. package/badge/Badge.js +59 -0
  14. package/{dist/box → box}/Box.js +38 -34
  15. package/box/index.d.ts +25 -0
  16. package/button/Button.d.ts +4 -0
  17. package/button/Button.js +182 -0
  18. package/button/Button.stories.tsx +306 -0
  19. package/button/types.d.ts +57 -0
  20. package/button/types.js +5 -0
  21. package/card/Card.js +200 -0
  22. package/card/index.d.ts +22 -0
  23. package/checkbox/Checkbox.js +275 -0
  24. package/checkbox/index.d.ts +24 -0
  25. package/chip/Chip.js +221 -0
  26. package/chip/index.d.ts +22 -0
  27. package/{dist/common → common}/OpenSans.css +0 -0
  28. package/{dist/common → common}/RequiredComponent.js +5 -19
  29. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  30. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  31. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  32. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  33. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  34. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  35. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  36. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  37. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  38. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  39. package/common/utils.js +22 -0
  40. package/common/variables.js +1569 -0
  41. package/{dist/date → date}/Date.js +87 -70
  42. package/date/index.d.ts +27 -0
  43. package/date-input/DateInput.js +396 -0
  44. package/date-input/index.d.ts +95 -0
  45. package/dialog/Dialog.js +184 -0
  46. package/dialog/index.d.ts +18 -0
  47. package/dropdown/Dropdown.js +450 -0
  48. package/dropdown/index.d.ts +26 -0
  49. package/file-input/FileInput.js +532 -0
  50. package/file-input/FileItem.js +193 -0
  51. package/file-input/index.d.ts +81 -0
  52. package/footer/Footer.js +297 -0
  53. package/footer/Icons.js +77 -0
  54. package/footer/index.d.ts +25 -0
  55. package/header/Header.js +326 -0
  56. package/header/Icons.js +59 -0
  57. package/header/index.d.ts +25 -0
  58. package/heading/Heading.js +176 -0
  59. package/heading/index.d.ts +17 -0
  60. package/input-text/Icons.js +22 -0
  61. package/input-text/InputText.js +611 -0
  62. package/input-text/index.d.ts +36 -0
  63. package/layout/ApplicationLayout.js +235 -0
  64. package/layout/Icons.js +55 -0
  65. package/link/Link.js +183 -0
  66. package/link/index.d.ts +23 -0
  67. package/main.d.ts +44 -0
  68. package/{dist/main.js → main.js} +137 -53
  69. package/number-input/NumberInput.js +128 -0
  70. package/{dist/ThemeContext.js → number-input/NumberInputContext.js} +3 -2
  71. package/number-input/index.d.ts +113 -0
  72. package/package.json +38 -23
  73. package/paginator/Icons.js +66 -0
  74. package/paginator/Paginator.js +221 -0
  75. package/paginator/index.d.ts +20 -0
  76. package/password-input/PasswordInput.js +199 -0
  77. package/password-input/index.d.ts +94 -0
  78. package/progress-bar/ProgressBar.js +188 -0
  79. package/progress-bar/index.d.ts +18 -0
  80. package/{dist/radio → radio}/Radio.js +40 -40
  81. package/radio/index.d.ts +23 -0
  82. package/resultsetTable/ResultsetTable.js +274 -0
  83. package/resultsetTable/index.d.ts +19 -0
  84. package/select/Select.js +865 -0
  85. package/select/index.d.ts +131 -0
  86. package/sidenav/Sidenav.js +145 -0
  87. package/sidenav/index.d.ts +13 -0
  88. package/slider/Slider.js +340 -0
  89. package/slider/index.d.ts +29 -0
  90. package/spinner/Spinner.js +267 -0
  91. package/spinner/index.d.ts +17 -0
  92. package/switch/Switch.js +208 -0
  93. package/switch/index.d.ts +24 -0
  94. package/table/Table.js +118 -0
  95. package/table/index.d.ts +13 -0
  96. package/tabs/Tabs.js +259 -0
  97. package/tabs/index.d.ts +19 -0
  98. package/tag/Tag.js +208 -0
  99. package/tag/index.d.ts +24 -0
  100. package/text-input/TextInput.js +825 -0
  101. package/text-input/index.d.ts +135 -0
  102. package/textarea/Textarea.js +317 -0
  103. package/textarea/index.d.ts +117 -0
  104. package/{dist/toggle → toggle}/Toggle.js +30 -67
  105. package/toggle/index.d.ts +21 -0
  106. package/toggle-group/ToggleGroup.js +243 -0
  107. package/toggle-group/index.d.ts +21 -0
  108. package/{dist/upload → upload}/Upload.js +23 -22
  109. package/upload/buttons-upload/ButtonsUpload.js +111 -0
  110. package/upload/buttons-upload/Icons.js +40 -0
  111. package/upload/dragAndDropArea/DragAndDropArea.js +225 -0
  112. package/upload/dragAndDropArea/Icons.js +39 -0
  113. package/upload/file-upload/FileToUpload.js +115 -0
  114. package/upload/file-upload/Icons.js +66 -0
  115. package/upload/files-upload/FilesToUpload.js +109 -0
  116. package/upload/index.d.ts +15 -0
  117. package/upload/transaction/Icons.js +160 -0
  118. package/upload/transaction/Transaction.js +104 -0
  119. package/upload/transactions/Transactions.js +94 -0
  120. package/useTheme.js +22 -0
  121. package/wizard/Icons.js +65 -0
  122. package/wizard/Wizard.js +271 -0
  123. package/wizard/index.d.ts +18 -0
  124. package/README.md +0 -66
  125. package/babel.config.js +0 -4
  126. package/dist/accordion/Accordion.js +0 -248
  127. package/dist/accordion/Accordion.stories.js +0 -207
  128. package/dist/accordion/readme.md +0 -96
  129. package/dist/alert/Alert.js +0 -304
  130. package/dist/alert/Alert.stories.js +0 -158
  131. package/dist/alert/close.svg +0 -4
  132. package/dist/alert/error.svg +0 -4
  133. package/dist/alert/info.svg +0 -4
  134. package/dist/alert/readme.md +0 -43
  135. package/dist/alert/success.svg +0 -4
  136. package/dist/alert/warning.svg +0 -4
  137. package/dist/button/Button.js +0 -181
  138. package/dist/button/Button.stories.js +0 -224
  139. package/dist/button/readme.md +0 -93
  140. package/dist/card/Card.js +0 -217
  141. package/dist/checkbox/Checkbox.js +0 -240
  142. package/dist/checkbox/Checkbox.stories.js +0 -144
  143. package/dist/checkbox/readme.md +0 -116
  144. package/dist/chip/Chip.js +0 -173
  145. package/dist/common/services/example-service.js +0 -10
  146. package/dist/common/services/example-service.test.js +0 -12
  147. package/dist/common/utils.js +0 -42
  148. package/dist/common/variables.js +0 -438
  149. package/dist/date/Date.stories.js +0 -205
  150. package/dist/date/calendar.svg +0 -1
  151. package/dist/date/calendar_dark.svg +0 -1
  152. package/dist/date/readme.md +0 -73
  153. package/dist/dialog/Dialog.js +0 -197
  154. package/dist/dialog/Dialog.stories.js +0 -217
  155. package/dist/dialog/readme.md +0 -32
  156. package/dist/dropdown/Dropdown.js +0 -416
  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.js +0 -346
  164. package/dist/footer/Footer.stories.js +0 -94
  165. package/dist/footer/dxc_logo_wht.png +0 -0
  166. package/dist/footer/readme.md +0 -41
  167. package/dist/header/Header.js +0 -360
  168. package/dist/header/Header.stories.js +0 -176
  169. package/dist/header/close_icon.svg +0 -1
  170. package/dist/header/dxc_logo_black.png +0 -0
  171. package/dist/header/dxc_logo_blk_rgb.svg +0 -6
  172. package/dist/header/dxc_logo_white.png +0 -0
  173. package/dist/header/hamb_menu_black.svg +0 -1
  174. package/dist/header/hamb_menu_white.svg +0 -1
  175. package/dist/header/readme.md +0 -33
  176. package/dist/heading/Heading.js +0 -153
  177. package/dist/input-text/InputText.js +0 -519
  178. package/dist/input-text/InputText.stories.js +0 -209
  179. package/dist/input-text/error.svg +0 -1
  180. package/dist/input-text/readme.md +0 -91
  181. package/dist/layout/ApplicationLayout.js +0 -320
  182. package/dist/layout/SideNav.js +0 -67
  183. package/dist/layout/facebook.svg +0 -45
  184. package/dist/layout/linkedin.svg +0 -50
  185. package/dist/layout/twitter.svg +0 -53
  186. package/dist/link/Link.js +0 -136
  187. package/dist/link/readme.md +0 -51
  188. package/dist/paginator/Paginator.js +0 -196
  189. package/dist/paginator/images/next.svg +0 -3
  190. package/dist/paginator/images/nextPage.svg +0 -3
  191. package/dist/paginator/images/previous.svg +0 -3
  192. package/dist/paginator/images/previousPage.svg +0 -3
  193. package/dist/paginator/readme.md +0 -50
  194. package/dist/progress-bar/ProgressBar.js +0 -185
  195. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  196. package/dist/progress-bar/readme.md +0 -63
  197. package/dist/radio/Radio.stories.js +0 -166
  198. package/dist/radio/readme.md +0 -70
  199. package/dist/resultsetTable/ResultsetTable.js +0 -333
  200. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  201. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  202. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  203. package/dist/select/Select.js +0 -451
  204. package/dist/select/Select.stories.js +0 -235
  205. package/dist/select/readme.md +0 -72
  206. package/dist/sidenav/Sidenav.js +0 -222
  207. package/dist/sidenav/arrow_icon.svg +0 -3
  208. package/dist/slider/Slider.js +0 -258
  209. package/dist/slider/Slider.stories.js +0 -241
  210. package/dist/slider/readme.md +0 -64
  211. package/dist/spinner/Spinner.js +0 -193
  212. package/dist/spinner/Spinner.stories.js +0 -183
  213. package/dist/spinner/readme.md +0 -65
  214. package/dist/switch/Switch.js +0 -199
  215. package/dist/switch/Switch.stories.js +0 -134
  216. package/dist/switch/readme.md +0 -133
  217. package/dist/table/Table.js +0 -93
  218. package/dist/tabs/Tabs.js +0 -172
  219. package/dist/tabs/Tabs.stories.js +0 -130
  220. package/dist/tabs/readme.md +0 -78
  221. package/dist/tabs-for-sections/TabsForSections.js +0 -107
  222. package/dist/tabs-for-sections/readme.md +0 -78
  223. package/dist/tag/Tag.js +0 -217
  224. package/dist/textarea/Textarea.js +0 -227
  225. package/dist/toggle/Toggle.stories.js +0 -297
  226. package/dist/toggle/readme.md +0 -80
  227. package/dist/toggle-group/ToggleGroup.js +0 -214
  228. package/dist/toggle-group/readme.md +0 -82
  229. package/dist/upload/Upload.stories.js +0 -72
  230. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -122
  231. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  232. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  233. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -279
  234. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  235. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  236. package/dist/upload/file-upload/FileToUpload.js +0 -158
  237. package/dist/upload/file-upload/audio-icon.svg +0 -4
  238. package/dist/upload/file-upload/close.svg +0 -4
  239. package/dist/upload/file-upload/file-icon.svg +0 -4
  240. package/dist/upload/file-upload/video-icon.svg +0 -4
  241. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  242. package/dist/upload/readme.md +0 -37
  243. package/dist/upload/transaction/Transaction.js +0 -155
  244. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  245. package/dist/upload/transaction/audio-icon.svg +0 -4
  246. package/dist/upload/transaction/error-icon.svg +0 -4
  247. package/dist/upload/transaction/file-icon-err.svg +0 -4
  248. package/dist/upload/transaction/file-icon.svg +0 -4
  249. package/dist/upload/transaction/image-icon-err.svg +0 -4
  250. package/dist/upload/transaction/image-icon.svg +0 -4
  251. package/dist/upload/transaction/success-icon.svg +0 -4
  252. package/dist/upload/transaction/video-icon-err.svg +0 -4
  253. package/dist/upload/transaction/video-icon.svg +0 -4
  254. package/dist/upload/transactions/Transactions.js +0 -120
  255. package/dist/wizard/Wizard.js +0 -327
  256. package/dist/wizard/invalid_icon.svg +0 -6
  257. package/dist/wizard/valid_icon.svg +0 -6
  258. package/dist/wizard/validation-wrong.svg +0 -6
  259. package/test/Accordion.test.js +0 -33
  260. package/test/Alert.test.js +0 -53
  261. package/test/Box.test.js +0 -10
  262. package/test/Button.test.js +0 -18
  263. package/test/Card.test.js +0 -30
  264. package/test/Checkbox.test.js +0 -45
  265. package/test/Chip.test.js +0 -25
  266. package/test/Date.test.js +0 -393
  267. package/test/Dialog.test.js +0 -23
  268. package/test/Dropdown.test.js +0 -130
  269. package/test/Footer.test.js +0 -99
  270. package/test/Header.test.js +0 -39
  271. package/test/Heading.test.js +0 -35
  272. package/test/InputText.test.js +0 -236
  273. package/test/Link.test.js +0 -25
  274. package/test/Paginator.test.js +0 -165
  275. package/test/ProgressBar.test.js +0 -35
  276. package/test/Radio.test.js +0 -37
  277. package/test/ResultsetTable.test.js +0 -282
  278. package/test/Select.test.js +0 -191
  279. package/test/Sidenav.test.js +0 -87
  280. package/test/Slider.test.js +0 -65
  281. package/test/Spinner.test.js +0 -27
  282. package/test/Switch.test.js +0 -45
  283. package/test/Table.test.js +0 -36
  284. package/test/Tabs.test.js +0 -88
  285. package/test/TabsForSections.test.js +0 -34
  286. package/test/Tag.test.js +0 -32
  287. package/test/TextArea.test.js +0 -52
  288. package/test/Toggle.test.js +0 -43
  289. package/test/ToggleGroup.test.js +0 -81
  290. package/test/Upload.test.js +0 -60
  291. package/test/Wizard.test.js +0 -130
  292. package/test/mocks/pngMock.js +0 -1
  293. package/test/mocks/svgMock.js +0 -1
@@ -1,36 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent } from "@testing-library/react";
3
- import DxcTable from "../src/table/Table";
4
-
5
- describe("Table component tests", () => {
6
- test("Table renders with correct content", () => {
7
- const { getByText } = render(
8
- <DxcTable>
9
- <tr>
10
- <th>header-1</th>
11
- <th>header-2</th>
12
- <th>header-3</th>
13
- </tr>
14
- <tr>
15
- <td>cell-1</td>
16
- <td>cell-2</td>
17
- <td>cell-3</td>
18
- </tr>
19
- <tr>
20
- <td>cell-4</td>
21
- <td>cell-5</td>
22
- <td>cell-6</td>
23
- </tr>
24
- </DxcTable>
25
- );
26
- expect(getByText("header-1")).toBeTruthy();
27
- expect(getByText("header-2")).toBeTruthy();
28
- expect(getByText("header-3")).toBeTruthy();
29
- expect(getByText("cell-1")).toBeTruthy();
30
- expect(getByText("cell-2")).toBeTruthy();
31
- expect(getByText("cell-3")).toBeTruthy();
32
- expect(getByText("cell-4")).toBeTruthy();
33
- expect(getByText("cell-5")).toBeTruthy();
34
- expect(getByText("cell-6")).toBeTruthy();
35
- });
36
- });
package/test/Tabs.test.js DELETED
@@ -1,88 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent } from "@testing-library/react";
3
- import DxcTabs from "../src/tabs/Tabs";
4
-
5
- const sampleTabs = [
6
- {
7
- label: "Tab-1",
8
- },
9
- {
10
- label: "Tab-2",
11
- },
12
- {
13
- label: "Tab-3",
14
- },
15
- ];
16
-
17
- describe("Tabs component tests", () => {
18
- test("Tabs render with correct labels", () => {
19
- const { getByText } = render(<DxcTabs tabs={sampleTabs}></DxcTabs>);
20
- expect(getByText("Tab-1")).toBeTruthy();
21
- expect(getByText("Tab-2")).toBeTruthy();
22
- expect(getByText("Tab-3")).toBeTruthy();
23
- });
24
-
25
- test("Tabs render with correct icons", () => {
26
- const { getAllByRole } = render(
27
- <DxcTabs
28
- tabs={[
29
- {
30
- label: "Tab-1",
31
- iconSrc: "/testIcon1.png",
32
- },
33
- {
34
- label: "Tab-2",
35
- iconSrc: "/testIcon2.png",
36
- },
37
- {
38
- label: "Tab-3",
39
- iconSrc: "/testIcon3.png",
40
- },
41
- ]}
42
- ></DxcTabs>
43
- );
44
- expect(getAllByRole("img")[0].getAttribute("src")).toBe("/testIcon1.png");
45
- expect(getAllByRole("img")[1].getAttribute("src")).toBe("/testIcon2.png");
46
- expect(getAllByRole("img")[2].getAttribute("src")).toBe("/testIcon3.png");
47
- });
48
-
49
- test("Tabs render with disabled tab", () => {
50
- const { getAllByRole } = render(
51
- <DxcTabs
52
- tabs={[
53
- {
54
- label: "Tab-1",
55
- isDisabled: true,
56
- },
57
- {
58
- label: "Tab-2",
59
- },
60
- ]}
61
- ></DxcTabs>
62
- );
63
- expect(getAllByRole("tab")[0].hasAttribute("disabled")).toBeTruthy();
64
- expect(getAllByRole("tab")[1].hasAttribute("disabled")).toBeFalsy();
65
- });
66
-
67
- test("Uncontrolled tabs", () => {
68
- const onTabClick = jest.fn();
69
- const { getByText } = render(<DxcTabs tabs={sampleTabs} onTabClick={onTabClick}></DxcTabs>);
70
- const tab1 = getByText("Tab-1");
71
- const tab2 = getByText("Tab-2");
72
- fireEvent.click(tab2);
73
- expect(onTabClick).toHaveBeenCalledWith(1);
74
- fireEvent.click(tab1);
75
- expect(onTabClick).toHaveBeenCalledWith(0);
76
- });
77
-
78
- test("Controlled tabs", () => {
79
- const onTabClick = jest.fn();
80
- const { getByText } = render(<DxcTabs tabs={sampleTabs} onTabClick={onTabClick} activeTabIndex={0}></DxcTabs>);
81
- const tab2 = getByText("Tab-2");
82
- const tab3 = getByText("Tab-3");
83
- fireEvent.click(tab2);
84
- expect(onTabClick).toHaveBeenCalledWith(1);
85
- fireEvent.click(tab3);
86
- expect(onTabClick).toHaveBeenCalledWith(2);
87
- });
88
- });
@@ -1,34 +0,0 @@
1
- import React from "react";
2
- import { render } from "@testing-library/react";
3
- import DxcTabsForSections from "../src/tabs-for-sections/TabsForSections";
4
-
5
- const sections = [
6
- {
7
- tabLabel: "S1",
8
- section: () => <div>test-section-1</div>,
9
- },
10
- {
11
- tabLabel: "S2",
12
- section: () => <div>test-section-2</div>,
13
- },
14
- {
15
- tabLabel: "S3",
16
- section: () => <div>test-section-3</div>,
17
- },
18
- ];
19
-
20
- describe("TabsForSections component tests", () => {
21
- test("TabsForSections renders with correct sections label", () => {
22
- const { getByText } = render(<DxcTabsForSections sections={sections}></DxcTabsForSections>);
23
- expect(getByText("S1")).toBeTruthy();
24
- expect(getByText("S2")).toBeTruthy();
25
- expect(getByText("S3")).toBeTruthy();
26
- });
27
-
28
- test("TabsForSections renders with correct sections content", () => {
29
- const { getByText } = render(<DxcTabsForSections sections={sections}></DxcTabsForSections>);
30
- expect(getByText("test-section-1")).toBeTruthy();
31
- expect(getByText("test-section-2")).toBeTruthy();
32
- expect(getByText("test-section-3")).toBeTruthy();
33
- });
34
- });
package/test/Tag.test.js DELETED
@@ -1,32 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent } from "@testing-library/react";
3
- import DxcTag from "../src/tag/Tag";
4
-
5
- describe("Tag component tests", () => {
6
- test("Tag renders with correct label", () => {
7
- const { getByText } = render(<DxcTag label="tag-test"></DxcTag>);
8
- expect(getByText("tag-test")).toBeTruthy();
9
- });
10
-
11
- test("Tag renders with correct label before", () => {
12
- const { getByText } = render(<DxcTag label="tag-test" labelPosition="before"></DxcTag>);
13
- expect(getByText("tag-test")).toBeTruthy();
14
- });
15
-
16
- test("Tag renders with correct icon", () => {
17
- const { getByRole } = render(<DxcTag label="tag-test" iconSrc="/test-icon.jpg"></DxcTag>);
18
- expect(getByRole("img").getAttribute("src")).toBe("/test-icon.jpg");
19
- });
20
-
21
- test("Tag renders with link href", () => {
22
- const { getByRole } = render(<DxcTag label="tag-test" linkHref="/test/page"></DxcTag>);
23
- expect(getByRole("link").getAttribute("href")).toBe("/test/page");
24
- });
25
-
26
- test("Call correct function on click", () => {
27
- const onClick = jest.fn();
28
- const { getByText } = render(<DxcTag label="tag-test" onClick={onClick}></DxcTag>);
29
- fireEvent.click(getByText("tag-test"));
30
- expect(onClick).toHaveBeenCalled();
31
- });
32
- });
@@ -1,52 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent } from "@testing-library/react";
3
- import DxcTextarea from "../src/textarea/Textarea";
4
-
5
- describe("TextArea component tests", () => {
6
- test("TextArea renders with correct text", () => {
7
- const { getByText } = render(<DxcTextarea label="TextArea label" />);
8
- expect(getByText("TextArea label")).toBeTruthy();
9
- });
10
-
11
- test("onChange function is called correctly", () => {
12
- const onChange = jest.fn();
13
-
14
- const { getByRole } = render(<DxcTextarea label="TextArea label" onChange={onChange} />);
15
- const input = getByRole("textbox");
16
- fireEvent.change(input, { target: { value: "Testing..." } });
17
- expect(onChange).toHaveBeenCalled();
18
- expect(onChange).toHaveBeenCalledWith("Testing...");
19
- });
20
-
21
- test("onBlur function is called correctly", () => {
22
- const onBlur = jest.fn();
23
-
24
- const { getByRole } = render(<DxcTextarea label="TextArea label" onBlur={onBlur} />);
25
- const input = getByRole("textbox");
26
- fireEvent.change(input, { target: { value: "Testing..." } });
27
- fireEvent.blur(input);
28
- expect(onBlur).toHaveBeenCalled();
29
- expect(onBlur).toHaveBeenCalledWith("Testing...");
30
- });
31
-
32
- test("Controlled component", () => {
33
- const onChange = jest.fn();
34
- const { getByRole } = render(<DxcTextarea label="TextArea label" value="TextArea Value" onChange={onChange} />);
35
- const input = getByRole("textbox");
36
- fireEvent.change(input, { target: { value: "Tests" } });
37
- expect(onChange).toHaveBeenCalled();
38
- expect(onChange).toHaveBeenCalledWith("Tests");
39
- expect(input.value).toBe("TextArea Value");
40
- });
41
-
42
- test("Uncontrolled component", () => {
43
- const onChange = jest.fn();
44
- const { getByRole } = render(<DxcTextarea label="TextArea label" onChange={onChange} />);
45
- const input = getByRole("textbox");
46
- fireEvent.change(input, { target: { value: "Tests" } });
47
- expect(onChange).toHaveBeenCalled();
48
- expect(onChange).toHaveBeenCalledWith("Tests");
49
- expect(input.value).toBe("Tests");
50
- });
51
-
52
- });
@@ -1,43 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent } from "@testing-library/react";
3
- import DxcToggle from "../src/toggle/Toggle";
4
-
5
- describe("Toggle component tests", () => {
6
- test("Toggle renders with correct text", () => {
7
- const { getByText } = render(<DxcToggle label="Toggle" />);
8
- expect(getByText("Toggle")).toBeTruthy();
9
- });
10
-
11
- test("Calls correct function on click", () => {
12
- const onClick = jest.fn();
13
- const { getByText} = render(<DxcToggle label="ToggleTest" onClick={onClick} />);
14
- fireEvent.click(getByText("ToggleTest"));
15
- expect(onClick).toHaveBeenCalled();
16
- });
17
-
18
- test("Calls correct function on click with the correct value.", () => {
19
- const onClick = jest.fn();
20
- const { getByText, rerender } = render(<DxcToggle label="ToggleTest" onClick={onClick} />);
21
-
22
- fireEvent.click(getByText("ToggleTest"));
23
- rerender(<DxcToggle label="ToggleTest" onClick={onClick} selected={true} />);
24
- fireEvent.click(getByText("ToggleTest"));
25
- expect(onClick.mock.calls[0][0]).toBe(true);
26
- expect(onClick.mock.calls[1][0]).toBe(false);
27
- });
28
-
29
-
30
- test("Calls correct function on click with the correct value, if it´s controlled and the user doesn´t change the value the function always receives the same", () => {
31
- const onClick = jest.fn();
32
- const { getByText } = render(<DxcToggle label="ToggleTest" selected={true} onClick={onClick} />);
33
-
34
- fireEvent.click(getByText("ToggleTest"));
35
- fireEvent.click(getByText("ToggleTest"));
36
- fireEvent.click(getByText("ToggleTest"));
37
- expect(onClick).toHaveBeenCalledTimes(3);
38
- expect(onClick.mock.calls[0][0]).toBe(false);
39
- expect(onClick.mock.calls[1][0]).toBe(false);
40
- expect(onClick.mock.calls[2][0]).toBe(false);
41
- });
42
-
43
- });
@@ -1,81 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent } from "@testing-library/react";
3
- import DxcToggleGroup from "../src/toggle-group/ToggleGroup";
4
-
5
- const options = [
6
- {
7
- value: 1,
8
- label: "Amazon",
9
- },
10
- {
11
- value: 2,
12
- label: "Ebay",
13
- },
14
- {
15
- value: 3,
16
- label: "Apple",
17
- },
18
- {
19
- value: 4,
20
- label: "Google",
21
- },
22
- ];
23
-
24
- describe("Toggle group component tests", () => {
25
- test("Toggle group renders with correct labels", () => {
26
- const { getByText } = render(<DxcToggleGroup options={options} />);
27
- expect(getByText("Amazon")).toBeTruthy();
28
- expect(getByText("Ebay")).toBeTruthy();
29
- expect(getByText("Apple")).toBeTruthy();
30
- expect(getByText("Google")).toBeTruthy();
31
- });
32
-
33
- test("Uncontrolled toggle group calls correct function on change with value", () => {
34
- const onChange = jest.fn();
35
- const { getByText } = render(<DxcToggleGroup options={options} onChange={onChange} />);
36
-
37
- const option = getByText("Ebay");
38
- fireEvent.click(option);
39
- expect(onChange).toHaveBeenCalledWith(2);
40
- });
41
-
42
- test("Controlled toggle group calls correct function on change with value", () => {
43
- const onChange = jest.fn();
44
- const { getByText } = render(<DxcToggleGroup options={options} onChange={onChange} value={1} />);
45
-
46
- const option = getByText("Ebay");
47
- fireEvent.click(option);
48
- expect(onChange).toHaveBeenCalledWith(2);
49
- });
50
-
51
- test("Function on change is not called when disable", () => {
52
- const onChange = jest.fn();
53
- const { getByText } = render(<DxcToggleGroup options={options} onChange={onChange} disabled />);
54
-
55
- const option = getByText("Ebay");
56
- fireEvent.click(option);
57
- expect(onChange).toHaveBeenCalledTimes(0);
58
- });
59
-
60
- test("Uncontrolled multiple toggle group calls correct function on change with value when is multiple", () => {
61
- const onChange = jest.fn();
62
- const { getByText } = render(<DxcToggleGroup options={options} onChange={onChange} multiple />);
63
-
64
- const option = getByText("Ebay");
65
- fireEvent.click(option);
66
- expect(onChange).toHaveBeenCalledWith([2]);
67
- });
68
-
69
- test("Controlled multiple toggle returns always same values", () => {
70
- const onChange = jest.fn();
71
- const { getByText } = render(<DxcToggleGroup options={options} onChange={onChange} value={[1]} multiple />);
72
-
73
- const option = getByText("Ebay");
74
- fireEvent.click(option);
75
- expect(onChange).toHaveBeenCalledWith([1, 2]);
76
-
77
- const option2 = getByText("Google");
78
- fireEvent.click(option2);
79
- expect(onChange).toHaveBeenNthCalledWith(2, [1, 4]);
80
- });
81
- });
@@ -1,60 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent, act, createEvent } from "@testing-library/react";
3
- import DxcUpload from "../src/upload/Upload";
4
-
5
- describe("Upload component tests", () => {
6
- test("Upload renders with correct text", () => {
7
- const { getByText } = render(<DxcUpload margin="small"></DxcUpload>);
8
- expect(getByText("There are no files to upload")).toBeTruthy();
9
- expect(getByText("Drag and drop your files here or choose one from your computer")).toBeTruthy();
10
- expect(getByText("CHOOSE FILES")).toBeTruthy();
11
- });
12
-
13
- test("Upload shows file information", () => {
14
- const myfunction = jest.fn();
15
- const { getByText } = render(<DxcUpload margin="small"></DxcUpload>);
16
-
17
- const dropZone = getByText("There are no files to upload");
18
- const dropEvent = createEvent.drop(dropZone);
19
- const fileList = [new File(["(⌐□_□)"], "test.png", { type: "image/png" })];
20
-
21
- Object.defineProperty(dropEvent, "dataTransfer", {
22
- value: {
23
- files: fileList,
24
- clearData: myfunction,
25
- },
26
- });
27
-
28
- act(() => {
29
- fireEvent(dropZone, dropEvent);
30
- });
31
- expect(getByText("test.png")).toBeTruthy();
32
- expect(getByText("image/png")).toBeTruthy();
33
- expect(getByText("UPLOAD")).toBeTruthy();
34
- });
35
-
36
- test("Calls correct function callbackUpload", () => {
37
- const onCallbackUpload = jest.fn(() => new Promise(resolve => setTimeout(resolve, 1000)));
38
- const myfunction = jest.fn();
39
- const { getByText } = render(<DxcUpload margin="small" callbackUpload={onCallbackUpload}></DxcUpload>);
40
-
41
- const dropZone = getByText("There are no files to upload");
42
- const dropEvent = createEvent.drop(dropZone);
43
- const fileList = [new File(["(⌐□_□)"], "test.png", { type: "image/png" })];
44
-
45
- Object.defineProperty(dropEvent, "dataTransfer", {
46
- value: {
47
- files: fileList,
48
- clearData: myfunction,
49
- },
50
- });
51
-
52
- act(() => {
53
- fireEvent(dropZone, dropEvent);
54
- });
55
- act(() => {
56
- fireEvent.click(getByText("UPLOAD"));
57
- });
58
- expect(onCallbackUpload).toHaveBeenCalled();
59
- });
60
- });
@@ -1,130 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent } from "@testing-library/react";
3
- import DxcWizard from "../src/wizard/Wizard";
4
-
5
- describe("Wizard components tests", () => {
6
- test("Wizard renders with correct steps", () => {
7
- const { getByText } = render(
8
- <DxcWizard
9
- steps={[
10
- {
11
- label: "first-step",
12
- },
13
- {
14
- label: "second-step",
15
- },
16
- ]}
17
- ></DxcWizard>
18
- );
19
-
20
- expect(getByText("first-step")).toBeTruthy();
21
- expect(getByText("second-step")).toBeTruthy();
22
- });
23
-
24
- test("Click on step text", () => {
25
- const onClick = jest.fn();
26
- const { getByText } = render(
27
- <DxcWizard
28
- onStepClick={onClick}
29
- steps={[
30
- {
31
- label: "first-step",
32
- },
33
- ]}
34
- ></DxcWizard>
35
- );
36
-
37
- const step = getByText("first-step");
38
- fireEvent.click(step);
39
- expect(onClick).toHaveBeenCalled();
40
- });
41
-
42
- test("Click on step description", () => {
43
- const onClick = jest.fn();
44
- const { getByText } = render(
45
- <DxcWizard
46
- onStepClick={onClick}
47
- steps={[
48
- {
49
- label: "first-step",
50
- description: "step-description",
51
- },
52
- ]}
53
- ></DxcWizard>
54
- );
55
-
56
- const step = getByText("step-description");
57
- fireEvent.click(step);
58
- expect(onClick).toHaveBeenCalled();
59
- });
60
-
61
- test("Click on step number", () => {
62
- const onClick = jest.fn();
63
- const { getByText } = render(
64
- <DxcWizard
65
- onStepClick={onClick}
66
- steps={[
67
- {
68
- label: "first-step",
69
- },
70
- ]}
71
- ></DxcWizard>
72
- );
73
-
74
- const step = getByText("1");
75
- fireEvent.click(step);
76
- expect(onClick).toHaveBeenCalled();
77
- });
78
-
79
- test("Click on disable step", () => {
80
- const onClick = jest.fn();
81
- const { getByText } = render(
82
- <DxcWizard
83
- onStepClick={onClick}
84
- steps={[
85
- {
86
- label: "first-step",
87
- },
88
- {
89
- label: "second-step",
90
- disabled: true,
91
- },
92
- ]}
93
- ></DxcWizard>
94
- );
95
-
96
- const step = getByText("second-step");
97
- fireEvent.click(step);
98
- expect(onClick).toHaveBeenCalledTimes(0);
99
- });
100
-
101
- test("Controlled wizard function is called", () => {
102
- const onClick = jest.fn((i) => i);
103
- const { getByText } = render(
104
- <DxcWizard
105
- currentStep={1}
106
- onStepClick={onClick}
107
- steps={[
108
- {
109
- label: "first-step",
110
- },
111
- {
112
- label: "second-step",
113
- },
114
- ]}
115
- ></DxcWizard>
116
- );
117
-
118
- const step1 = getByText("first-step");
119
- const step2 = getByText("second-step");
120
- fireEvent.click(step1);
121
- fireEvent.click(step2);
122
- fireEvent.click(step1);
123
-
124
- expect(onClick).toHaveBeenCalledTimes(3);
125
- //Test the received value in the onClick function
126
- expect(onClick).toHaveBeenNthCalledWith(1, 0);
127
- expect(onClick).toHaveBeenNthCalledWith(2, 1);
128
- expect(onClick).toHaveBeenNthCalledWith(3, 0);
129
- });
130
- });
@@ -1 +0,0 @@
1
- module.exports = 'ImageMock';
@@ -1 +0,0 @@
1
- module.exports = 'IconMock';