@dxc-technology/halstack-react 0.0.0-beebecd → 0.0.0-bfdc357

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 (333) hide show
  1. package/BackgroundColorContext.js +50 -0
  2. package/ThemeContext.js +246 -0
  3. package/{dist/select/Select.js → V3Select/V3Select.js} +38 -132
  4. package/V3Select/index.d.ts +27 -0
  5. package/{dist/textarea/Textarea.js → V3Textarea/V3Textarea.js} +14 -18
  6. package/V3Textarea/index.d.ts +27 -0
  7. package/accordion/Accordion.d.ts +4 -0
  8. package/{dist/accordion → accordion}/Accordion.js +35 -130
  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/{dist/alert → alert}/Alert.js +38 -151
  17. package/alert/Alert.stories.tsx +170 -0
  18. package/alert/types.d.ts +49 -0
  19. package/alert/types.js +5 -0
  20. package/badge/Badge.js +59 -0
  21. package/box/Box.d.ts +4 -0
  22. package/{dist/box → box}/Box.js +13 -43
  23. package/box/Box.stories.tsx +132 -0
  24. package/box/types.d.ts +43 -0
  25. package/box/types.js +5 -0
  26. package/button/Button.d.ts +4 -0
  27. package/{dist/button → button}/Button.js +23 -84
  28. package/button/Button.stories.tsx +276 -0
  29. package/button/types.d.ts +57 -0
  30. package/button/types.js +5 -0
  31. package/card/Card.d.ts +4 -0
  32. package/{dist/card → card}/Card.js +33 -123
  33. package/card/types.d.ts +69 -0
  34. package/card/types.js +5 -0
  35. package/checkbox/Checkbox.d.ts +4 -0
  36. package/{dist/checkbox → checkbox}/Checkbox.js +16 -63
  37. package/checkbox/Checkbox.stories.tsx +192 -0
  38. package/checkbox/types.d.ts +60 -0
  39. package/checkbox/types.js +5 -0
  40. package/{dist/chip → chip}/Chip.js +17 -61
  41. package/chip/Chip.stories.tsx +121 -0
  42. package/chip/index.d.ts +22 -0
  43. package/{dist/common → common}/OpenSans.css +0 -0
  44. package/{dist/common → common}/RequiredComponent.js +3 -11
  45. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  46. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  47. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  48. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  49. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  50. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  51. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  52. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  53. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  54. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  55. package/{dist/common → common}/utils.js +0 -0
  56. package/{dist/common → common}/variables.js +165 -157
  57. package/{dist/date → date}/Date.js +16 -22
  58. package/date/index.d.ts +27 -0
  59. package/date-input/DateInput.d.ts +4 -0
  60. package/{dist/date-input → date-input}/DateInput.js +22 -61
  61. package/date-input/DateInput.stories.tsx +138 -0
  62. package/date-input/types.d.ts +100 -0
  63. package/date-input/types.js +5 -0
  64. package/dialog/Dialog.d.ts +4 -0
  65. package/{dist/dialog → dialog}/Dialog.js +20 -73
  66. package/dialog/Dialog.stories.tsx +212 -0
  67. package/dialog/types.d.ts +43 -0
  68. package/dialog/types.js +5 -0
  69. package/dropdown/Dropdown.d.ts +4 -0
  70. package/{dist/dropdown → dropdown}/Dropdown.js +44 -171
  71. package/dropdown/types.d.ts +89 -0
  72. package/dropdown/types.js +5 -0
  73. package/file-input/FileInput.d.ts +4 -0
  74. package/{dist/file-input → file-input}/FileInput.js +56 -189
  75. package/file-input/FileItem.d.ts +14 -0
  76. package/file-input/FileItem.js +182 -0
  77. package/file-input/types.d.ts +87 -0
  78. package/file-input/types.js +5 -0
  79. package/footer/Footer.d.ts +4 -0
  80. package/footer/Footer.js +266 -0
  81. package/footer/Footer.stories.jsx +151 -0
  82. package/footer/Icons.js +77 -0
  83. package/footer/types.d.ts +61 -0
  84. package/footer/types.js +5 -0
  85. package/header/Header.d.ts +7 -0
  86. package/header/Header.js +324 -0
  87. package/header/Header.stories.tsx +162 -0
  88. package/header/Icons.js +34 -0
  89. package/header/types.d.ts +45 -0
  90. package/header/types.js +5 -0
  91. package/heading/Heading.d.ts +4 -0
  92. package/{dist/heading → heading}/Heading.js +30 -89
  93. package/heading/types.d.ts +33 -0
  94. package/heading/types.js +5 -0
  95. package/input-text/Icons.js +22 -0
  96. package/{dist/input-text → input-text}/InputText.js +37 -133
  97. package/input-text/index.d.ts +36 -0
  98. package/{dist/layout → layout}/ApplicationLayout.js +35 -131
  99. package/layout/Icons.js +55 -0
  100. package/link/Link.d.ts +3 -0
  101. package/{dist/link → link}/Link.js +18 -94
  102. package/link/Link.stories.tsx +146 -0
  103. package/link/types.d.ts +74 -0
  104. package/link/types.js +5 -0
  105. package/main.d.ts +44 -0
  106. package/{dist/main.js → main.js} +95 -99
  107. package/number-input/NumberInput.d.ts +4 -0
  108. package/number-input/NumberInput.js +86 -0
  109. package/number-input/NumberInput.stories.tsx +115 -0
  110. package/{dist/number-input → number-input}/NumberInputContext.js +1 -1
  111. package/number-input/types.d.ts +117 -0
  112. package/number-input/types.js +5 -0
  113. package/package.json +32 -25
  114. package/paginator/Icons.js +66 -0
  115. package/paginator/Paginator.d.ts +4 -0
  116. package/paginator/Paginator.js +198 -0
  117. package/paginator/Paginator.stories.tsx +63 -0
  118. package/paginator/types.d.ts +38 -0
  119. package/paginator/types.js +5 -0
  120. package/password-input/PasswordInput.d.ts +4 -0
  121. package/{dist/password-input → password-input}/PasswordInput.js +24 -60
  122. package/password-input/PasswordInput.stories.tsx +131 -0
  123. package/password-input/types.d.ts +100 -0
  124. package/password-input/types.js +5 -0
  125. package/progress-bar/ProgressBar.d.ts +4 -0
  126. package/{dist/progress-bar → progress-bar}/ProgressBar.js +20 -92
  127. package/progress-bar/ProgressBar.stories.jsx +58 -0
  128. package/progress-bar/types.d.ts +37 -0
  129. package/progress-bar/types.js +5 -0
  130. package/radio/Radio.d.ts +4 -0
  131. package/{dist/radio → radio}/Radio.js +15 -50
  132. package/radio/Radio.stories.tsx +192 -0
  133. package/radio/types.d.ts +54 -0
  134. package/radio/types.js +5 -0
  135. package/{dist/resultsetTable → resultsetTable}/ResultsetTable.js +35 -119
  136. package/resultsetTable/index.d.ts +19 -0
  137. package/select/Select.js +865 -0
  138. package/select/Select.stories.tsx +572 -0
  139. package/select/index.d.ts +131 -0
  140. package/sidenav/Sidenav.d.ts +9 -0
  141. package/{dist/sidenav → sidenav}/Sidenav.js +19 -62
  142. package/sidenav/types.d.ts +50 -0
  143. package/sidenav/types.js +5 -0
  144. package/slider/Slider.d.ts +4 -0
  145. package/{dist/slider → slider}/Slider.js +75 -152
  146. package/slider/Slider.stories.tsx +177 -0
  147. package/slider/types.d.ts +78 -0
  148. package/slider/types.js +5 -0
  149. package/spinner/Spinner.d.ts +4 -0
  150. package/spinner/Spinner.js +250 -0
  151. package/spinner/Spinner.stories.jsx +102 -0
  152. package/spinner/types.d.ts +32 -0
  153. package/spinner/types.js +5 -0
  154. package/switch/Switch.d.ts +4 -0
  155. package/{dist/switch → switch}/Switch.js +26 -69
  156. package/switch/Switch.stories.tsx +160 -0
  157. package/switch/types.d.ts +58 -0
  158. package/switch/types.js +5 -0
  159. package/table/Table.d.ts +4 -0
  160. package/{dist/table → table}/Table.js +10 -24
  161. package/table/Table.stories.jsx +276 -0
  162. package/table/types.d.ts +21 -0
  163. package/table/types.js +5 -0
  164. package/tabs/Tabs.d.ts +4 -0
  165. package/tabs/Tabs.js +211 -0
  166. package/tabs/types.d.ts +71 -0
  167. package/tabs/types.js +5 -0
  168. package/tag/Tag.d.ts +4 -0
  169. package/tag/Tag.js +193 -0
  170. package/tag/Tag.stories.tsx +145 -0
  171. package/tag/types.d.ts +60 -0
  172. package/tag/types.js +5 -0
  173. package/{dist/text-input → text-input}/TextInput.js +244 -390
  174. package/{dist/text-input → text-input}/index.d.ts +2 -2
  175. package/{dist/new-textarea/NewTextarea.js → textarea/Textarea.js} +23 -75
  176. package/textarea/Textarea.stories.jsx +135 -0
  177. package/{dist/new-textarea → textarea}/index.d.ts +1 -1
  178. package/{dist/toggle → toggle}/Toggle.js +15 -49
  179. package/toggle/index.d.ts +21 -0
  180. package/{dist/toggle-group → toggle-group}/ToggleGroup.js +23 -107
  181. package/toggle-group/ToggleGroup.stories.tsx +178 -0
  182. package/toggle-group/index.d.ts +21 -0
  183. package/{dist/upload → upload}/Upload.js +11 -15
  184. package/upload/buttons-upload/ButtonsUpload.js +111 -0
  185. package/upload/buttons-upload/Icons.js +40 -0
  186. package/upload/dragAndDropArea/DragAndDropArea.js +225 -0
  187. package/upload/dragAndDropArea/Icons.js +39 -0
  188. package/upload/file-upload/FileToUpload.js +115 -0
  189. package/upload/file-upload/Icons.js +66 -0
  190. package/{dist/upload → upload}/files-upload/FilesToUpload.js +12 -26
  191. package/upload/index.d.ts +15 -0
  192. package/upload/transaction/Icons.js +160 -0
  193. package/upload/transaction/Transaction.js +104 -0
  194. package/upload/transactions/Transactions.js +94 -0
  195. package/{dist/useTheme.js → useTheme.js} +0 -0
  196. package/wizard/Icons.js +65 -0
  197. package/wizard/Wizard.d.ts +4 -0
  198. package/{dist/wizard → wizard}/Wizard.js +33 -213
  199. package/wizard/Wizard.stories.jsx +224 -0
  200. package/wizard/types.d.ts +64 -0
  201. package/wizard/types.js +5 -0
  202. package/README.md +0 -66
  203. package/babel.config.js +0 -8
  204. package/dist/BackgroundColorContext.js +0 -46
  205. package/dist/ThemeContext.js +0 -248
  206. package/dist/accordion-group/AccordionGroup.js +0 -186
  207. package/dist/alert/index.d.ts +0 -51
  208. package/dist/badge/Badge.js +0 -63
  209. package/dist/checkbox/Checkbox.stories.js +0 -144
  210. package/dist/checkbox/readme.md +0 -116
  211. package/dist/date/Date.stories.js +0 -205
  212. package/dist/date/readme.md +0 -73
  213. package/dist/date-input/index.d.ts +0 -95
  214. package/dist/file-input/FileItem.js +0 -280
  215. package/dist/file-input/index.d.ts +0 -81
  216. package/dist/footer/Footer.js +0 -395
  217. package/dist/footer/dxc_logo.svg +0 -15
  218. package/dist/footer/readme.md +0 -41
  219. package/dist/header/Header.js +0 -403
  220. package/dist/header/Header.stories.js +0 -176
  221. package/dist/header/close_icon.svg +0 -1
  222. package/dist/header/dxc_logo_black.svg +0 -8
  223. package/dist/header/hamb_menu_black.svg +0 -1
  224. package/dist/header/hamb_menu_white.svg +0 -1
  225. package/dist/header/readme.md +0 -33
  226. package/dist/input-text/error.svg +0 -1
  227. package/dist/input-text/readme.md +0 -91
  228. package/dist/layout/facebook.svg +0 -45
  229. package/dist/layout/linkedin.svg +0 -50
  230. package/dist/layout/twitter.svg +0 -53
  231. package/dist/link/readme.md +0 -51
  232. package/dist/main.d.ts +0 -8
  233. package/dist/new-select/NewSelect.js +0 -836
  234. package/dist/new-select/index.d.ts +0 -53
  235. package/dist/number-input/NumberInput.js +0 -136
  236. package/dist/number-input/index.d.ts +0 -113
  237. package/dist/paginator/Paginator.js +0 -289
  238. package/dist/paginator/images/next.svg +0 -3
  239. package/dist/paginator/images/nextPage.svg +0 -3
  240. package/dist/paginator/images/previous.svg +0 -3
  241. package/dist/paginator/images/previousPage.svg +0 -3
  242. package/dist/paginator/readme.md +0 -50
  243. package/dist/password-input/index.d.ts +0 -94
  244. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  245. package/dist/progress-bar/readme.md +0 -63
  246. package/dist/radio/Radio.stories.js +0 -166
  247. package/dist/radio/readme.md +0 -70
  248. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  249. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  250. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  251. package/dist/slider/readme.md +0 -64
  252. package/dist/spinner/Spinner.js +0 -381
  253. package/dist/spinner/Spinner.stories.js +0 -183
  254. package/dist/spinner/readme.md +0 -65
  255. package/dist/switch/Switch.stories.js +0 -134
  256. package/dist/switch/readme.md +0 -133
  257. package/dist/tabs/Tabs.js +0 -343
  258. package/dist/tabs/Tabs.stories.js +0 -130
  259. package/dist/tabs/readme.md +0 -78
  260. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  261. package/dist/tabs-for-sections/readme.md +0 -78
  262. package/dist/tag/Tag.js +0 -282
  263. package/dist/toggle/Toggle.stories.js +0 -297
  264. package/dist/toggle/readme.md +0 -80
  265. package/dist/upload/Upload.stories.js +0 -72
  266. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -139
  267. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  268. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  269. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -329
  270. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  271. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  272. package/dist/upload/file-upload/FileToUpload.js +0 -184
  273. package/dist/upload/file-upload/audio-icon.svg +0 -4
  274. package/dist/upload/file-upload/close.svg +0 -4
  275. package/dist/upload/file-upload/file-icon.svg +0 -4
  276. package/dist/upload/file-upload/video-icon.svg +0 -4
  277. package/dist/upload/readme.md +0 -37
  278. package/dist/upload/transaction/Transaction.js +0 -175
  279. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  280. package/dist/upload/transaction/audio-icon.svg +0 -4
  281. package/dist/upload/transaction/error-icon.svg +0 -4
  282. package/dist/upload/transaction/file-icon-err.svg +0 -4
  283. package/dist/upload/transaction/file-icon.svg +0 -4
  284. package/dist/upload/transaction/image-icon-err.svg +0 -4
  285. package/dist/upload/transaction/image-icon.svg +0 -4
  286. package/dist/upload/transaction/success-icon.svg +0 -4
  287. package/dist/upload/transaction/video-icon-err.svg +0 -4
  288. package/dist/upload/transaction/video-icon.svg +0 -4
  289. package/dist/upload/transactions/Transactions.js +0 -138
  290. package/dist/wizard/invalid_icon.svg +0 -5
  291. package/dist/wizard/valid_icon.svg +0 -5
  292. package/dist/wizard/validation-wrong.svg +0 -6
  293. package/test/Accordion.test.js +0 -33
  294. package/test/AccordionGroup.test.js +0 -125
  295. package/test/Alert.test.js +0 -53
  296. package/test/Box.test.js +0 -10
  297. package/test/Button.test.js +0 -18
  298. package/test/Card.test.js +0 -30
  299. package/test/Checkbox.test.js +0 -45
  300. package/test/Chip.test.js +0 -25
  301. package/test/Date.test.js +0 -393
  302. package/test/DateInput.test.js +0 -242
  303. package/test/Dialog.test.js +0 -23
  304. package/test/Dropdown.test.js +0 -145
  305. package/test/FileInput.test.js +0 -201
  306. package/test/Footer.test.js +0 -99
  307. package/test/Header.test.js +0 -39
  308. package/test/Heading.test.js +0 -35
  309. package/test/InputText.test.js +0 -248
  310. package/test/Link.test.js +0 -43
  311. package/test/NewTextarea.test.js +0 -195
  312. package/test/NumberInput.test.js +0 -259
  313. package/test/Paginator.test.js +0 -177
  314. package/test/PasswordInput.test.js +0 -83
  315. package/test/ProgressBar.test.js +0 -35
  316. package/test/Radio.test.js +0 -37
  317. package/test/ResultsetTable.test.js +0 -329
  318. package/test/Select.test.js +0 -212
  319. package/test/Sidenav.test.js +0 -45
  320. package/test/Slider.test.js +0 -82
  321. package/test/Spinner.test.js +0 -32
  322. package/test/Switch.test.js +0 -45
  323. package/test/Table.test.js +0 -36
  324. package/test/Tabs.test.js +0 -109
  325. package/test/TabsForSections.test.js +0 -34
  326. package/test/Tag.test.js +0 -32
  327. package/test/TextArea.test.js +0 -52
  328. package/test/TextInput.test.js +0 -732
  329. package/test/ToggleGroup.test.js +0 -85
  330. package/test/Upload.test.js +0 -60
  331. package/test/Wizard.test.js +0 -130
  332. package/test/mocks/pngMock.js +0 -1
  333. package/test/mocks/svgMock.js +0 -1
package/test/Card.test.js DELETED
@@ -1,30 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent } from "@testing-library/react";
3
- import DxcCard from "../src/card/Card";
4
-
5
- describe("Card component tests", () => {
6
- test("Card renders with correct content", () => {
7
- const { getByText } = render(<DxcCard>test-card</DxcCard>);
8
- expect(getByText("test-card")).toBeTruthy();
9
- });
10
-
11
- test("Card renders with correct href", () => {
12
- const { getByRole } = render(<DxcCard linkHref="/testPage">test-card</DxcCard>);
13
- const card = getByRole("link");
14
- expect(card.getAttribute("href")).toEqual("/testPage");
15
- });
16
-
17
- test("Card renders with correct image", () => {
18
- const { getByRole } = render(<DxcCard imageSrc="/testImage">test-card</DxcCard>);
19
- const card = getByRole("img");
20
- expect(card.getAttribute("src")).toEqual("/testImage");
21
- });
22
-
23
- test("OnClick function is called", () => {
24
- const onClick = jest.fn();
25
- const { getByText } = render(<DxcCard onClick={onClick}>test-card</DxcCard>);
26
- const card = getByText("test-card");
27
- fireEvent.click(card);
28
- expect(onClick).toHaveBeenCalled();
29
- });
30
- });
@@ -1,45 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent } from "@testing-library/react";
3
-
4
- import DxcCheckbox from "../src/checkbox/Checkbox";
5
-
6
- describe("Checkbox component tests", () => {
7
- test("Checkbox renders with correct text", () => {
8
- const { getByText } = render(<DxcCheckbox label="Checkbox" />);
9
-
10
- expect(getByText("Checkbox")).toBeTruthy();
11
- });
12
-
13
- test("Calls correct function on click", () => {
14
- const onChange = jest.fn();
15
- const { getByText } = render(<DxcCheckbox label="Checkbox" onChange={onChange} />);
16
-
17
- fireEvent.click(getByText("Checkbox"));
18
- expect(onChange).toHaveBeenCalled();
19
- });
20
-
21
- test("Uncontrolled checkbox", () => {
22
- const onChange = jest.fn();
23
- const component = render(<DxcCheckbox label="Checkbox" onChange={onChange} />);
24
- const visibleCheckbox = component.getByText("Checkbox");
25
- const input = component.getByRole("checkbox");
26
- expect(input.checked).toBe(false);
27
- fireEvent.click(visibleCheckbox);
28
- expect(onChange).toHaveBeenCalled();
29
- expect(onChange).toHaveBeenCalledWith(true);
30
- expect(input.checked).toBe(true);
31
- });
32
-
33
- test("Controlled checkbox", () => {
34
- const onChange = jest.fn();
35
- const component = render(<DxcCheckbox label="Checkbox" checked={false} onChange={onChange} />);
36
-
37
- const input = component.getByRole("checkbox");
38
- const visibleCheckbox = component.getByText("Checkbox");
39
-
40
- fireEvent.click(visibleCheckbox);
41
- expect(onChange).toHaveBeenCalled();
42
- expect(onChange).toHaveBeenCalledWith(true);
43
- expect(input.checked).toBe(false);
44
- });
45
- });
package/test/Chip.test.js DELETED
@@ -1,25 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent } from "@testing-library/react";
3
- import DxcChip from "../src/chip/Chip";
4
- import icon from "../../app/src/images/invision.svg";
5
-
6
- describe("Chip component tests", () => {
7
- test("Chip renders with correct text", () => {
8
- const { getByText } = render(<DxcChip label="Chip" />);
9
- expect(getByText("Chip")).toBeTruthy();
10
- });
11
- test("Calls correct function when clicking on prefix icon", () => {
12
- const onClick = jest.fn();
13
- const { getByText, getByRole } = render(<DxcChip label="Chip" prefixIconSrc={icon} onClickPrefix={onClick} />);
14
- expect(getByText("Chip")).toBeTruthy();
15
- fireEvent.click(getByRole("img"));
16
- expect(onClick).toHaveBeenCalled();
17
- });
18
- test("Calls correct function when clicking on suffix icon", () => {
19
- const onClick = jest.fn();
20
- const { getByText, getByRole } = render(<DxcChip label="Chip" suffixIconSrc={icon} onClickSuffix={onClick} />);
21
- expect(getByText("Chip")).toBeTruthy();
22
- fireEvent.click(getByRole("img"));
23
- expect(onClick).toHaveBeenCalled();
24
- });
25
- });
package/test/Date.test.js DELETED
@@ -1,393 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent } from "@testing-library/react";
3
- import DxcDate from "../src/date/Date";
4
-
5
- const defaultFormat = "DD-MM-YYYY";
6
-
7
- describe("Date component general tests", () => {
8
- test("Date renders correctly", () => {
9
- const { getByPlaceholderText } = render(<DxcDate label="Birthdate" placeholder />);
10
- // const input = getByPlaceholderText('DD-MM-YYYY');
11
- expect(getByPlaceholderText(defaultFormat)).toBeTruthy();
12
- });
13
- });
14
-
15
- describe("Controlled Date Component", () => {
16
- const date = new Date("2020-10-16 00:00:00");
17
-
18
- test("Changing the input value and after this deleting its content input´s value should be ''", () => {
19
- const onChange = jest.fn((returnedValue) => {
20
- expect(returnedValue.dateValue).toBeNull();
21
- expect(returnedValue.stringValue).toBe("something");
22
- });
23
-
24
- const { getByRole, getByPlaceholderText, rerender } = render(
25
- <DxcDate label="Birthdate" value="30-03-1981" onChange={onChange} placeholder />
26
- );
27
- const input = getByPlaceholderText(defaultFormat);
28
-
29
- fireEvent.change(input, { target: { value: "something" } });
30
- expect(onChange).toHaveBeenCalled();
31
- fireEvent.blur(input);
32
- rerender(<DxcDate label="Birthdate" value="" placeholder />);
33
- // expect(getByRole("textbox").value).toBe('');
34
- });
35
-
36
- test("The input´s value is the same as the one received as a parameter (Default format)", () => {
37
- const { getByRole, getByPlaceholderText } = render(<DxcDate label="Birthdate" value="30/03/1981" placeholder />);
38
- // const input = getByRole("textbox");
39
- const input = getByPlaceholderText(defaultFormat);
40
- expect(input.value).toBe("30/03/1981");
41
- });
42
-
43
- test("The input´s value is the same as the one received as a parameter (Custom format)", () => {
44
- const { getByRole, getByPlaceholderText } = render(
45
- <DxcDate label="Birthdate" format="dd/MM/yy" value="30/03/81" placeholder />
46
- );
47
- // const input = getByRole("textbox");
48
- const input = getByPlaceholderText("DD/MM/YY");
49
- expect(input.value).toBe("30/03/81");
50
- });
51
-
52
- test("Calendar´s value is the same as the input´s date if it´s right (Depending on the format)", () => {
53
- const { getByRole, getByText, getByTestId } = render(<DxcDate label="Birthdate" value="16-10-2020" />);
54
- fireEvent.click(getByTestId('calendarIcon'));
55
- expect(getByText("Fri, Oct 16")).toBeTruthy();
56
- });
57
-
58
- test("Calendar´s value is the same as the input´s date if it´s right after changing the input value", () => {
59
- const { getByRole, getByText, rerender, getByPlaceholderText, getByTestId } = render(
60
- <DxcDate label="Birthdate" value="30-03-1981" placeholder />
61
- );
62
- // const input = getByRole("textbox");
63
- const input = getByPlaceholderText(defaultFormat);
64
- fireEvent.change(input, { target: { value: "10-02-2020" } });
65
-
66
- rerender(<DxcDate label="Birthdate" value="10-02-2020" />);
67
- const calendarButton = getByTestId('calendarIcon');
68
- fireEvent.click(calendarButton);
69
- expect(getByText("Mon, Feb 10")).toBeTruthy();
70
- });
71
-
72
- test("onChange function is called when the user types something in the input", () => {
73
- const onChange = jest.fn((returnedValue) => {
74
- expect(returnedValue.dateValue).toBeNull();
75
- expect(returnedValue.stringValue).toBe("something");
76
- });
77
-
78
- const { getByRole, getByPlaceholderText } = render(
79
- <DxcDate label="Birthdate" value="30-03-1981" onChange={onChange} placeholder />
80
- );
81
- // const input = getByRole("textbox");
82
- const input = getByPlaceholderText(defaultFormat);
83
-
84
- fireEvent.change(input, { target: { value: "something" } });
85
- expect(onChange).toHaveBeenCalled();
86
- });
87
-
88
- test("onChange function is called when the user types in the input a valid date(based on its format), the object received as a parameter in the onChange function is what should be(DEFAULT FORMAT)", () => {
89
- const onChange = jest.fn((returnedValue) => {
90
- expect(returnedValue.dateValue.getTime()).toBe(date.getTime());
91
- expect(returnedValue.stringValue).toBe("16-10-2020");
92
- });
93
-
94
- const { getByRole, getByPlaceholderText } = render(
95
- <DxcDate label="Birthdate" value="30-03-1981" onChange={onChange} placeholder />
96
- );
97
- // const input = getByRole("textbox");
98
- const input = getByPlaceholderText(defaultFormat);
99
- fireEvent.change(input, { target: { value: "16-10-2020" } });
100
- expect(onChange).toHaveBeenCalled();
101
- });
102
-
103
- test("onChange function is called when the user types in the input a valid date(based on its format), the object received as a parameter in the onChange function is what should be(CUSTOM FORMAT)", () => {
104
- const onChange = jest.fn((returnedValue) => {
105
- expect(returnedValue.dateValue.getTime()).toBe(date.getTime());
106
- expect(returnedValue.stringValue).toBe("16-10-20");
107
- });
108
-
109
- const { getByRole, getByPlaceholderText } = render(
110
- <DxcDate label="Birthdate" format="dd-MM-yy" value="30-03-81" onChange={onChange} placeholder />
111
- );
112
- // const input = getByRole("textbox");
113
- const input = getByPlaceholderText("DD-MM-YY");
114
-
115
- fireEvent.change(input, { target: { value: "16-10-20" } });
116
- expect(onChange).toHaveBeenCalled();
117
- });
118
-
119
- test("onChange function is called when the user types in the input an invalid date(based on its format), the object received as a parameter in the onChange function is what should be(stringValue with the written string, and null as dateValue)(DEFAULT FORMAT)", () => {
120
- const onChange = jest.fn((returnedValue) => {
121
- expect(returnedValue.dateValue).toBeNull();
122
- expect(returnedValue.stringValue).toBe("11-15-2020");
123
- });
124
-
125
- const { getByRole, getByPlaceholderText } = render(
126
- <DxcDate label="Birthdate" value="30-03-1981" onChange={onChange} placeholder />
127
- );
128
- // const input = getByRole("textbox");
129
- const input = getByPlaceholderText(defaultFormat);
130
-
131
- fireEvent.change(input, { target: { value: "11-15-2020" } });
132
- expect(onChange).toHaveBeenCalled();
133
- });
134
-
135
- test("onChange function is called when the user types in the input an invalid date(based on its format), the object received as a parameter in the onChange function is what should be(stringValue with the written string, and null as dateValue)(CUSTOM FORMAT)", () => {
136
- const onChange = jest.fn((returnedValue) => {
137
- expect(returnedValue.dateValue).toBeNull();
138
- expect(returnedValue.stringValue).toBe("15/11/2020");
139
- });
140
-
141
- const { getByRole, getByPlaceholderText } = render(
142
- <DxcDate label="Birthdate" value="03/30/1981" format="MM/dd/yyyy" onChange={onChange} placeholder />
143
- );
144
- // const input = getByRole("textbox");
145
- const input = getByPlaceholderText("MM/DD/YYYY");
146
-
147
- fireEvent.change(input, { target: { value: "15/11/2020" } });
148
- expect(onChange).toHaveBeenCalled();
149
- });
150
-
151
- test("onChange function is called when the user selects from the calendar", () => {
152
- const onChange = jest.fn();
153
-
154
- const component = render(<DxcDate label="Birthdate" value="01-02-2020" onChange={onChange} />);
155
- const calendarButton = component.getByTestId('calendarIcon');
156
- fireEvent.click(calendarButton);
157
- const dayButton = component.getByRole("button", { name: "10" });
158
- fireEvent.click(dayButton);
159
- expect(dayButton).toBeTruthy();
160
- expect(onChange).toHaveBeenCalled();
161
- });
162
-
163
- test("onChange function is called when the user selects from the calendar, the dateValue received by the onChange function is the selected date", () => {
164
- const onChange = jest.fn((returnedValue) => {
165
- expect(returnedValue.dateValue.getTime()).toBe(date.getTime());
166
- });
167
-
168
- const component = render(<DxcDate label="Birthdate" value="30-10-2020" onChange={onChange} />);
169
- const calendarButton = component.getByTestId('calendarIcon');
170
- fireEvent.click(calendarButton);
171
- const dayButton = component.getByRole("button", { name: "16" });
172
- fireEvent.click(dayButton);
173
- expect(dayButton).toBeTruthy();
174
- });
175
-
176
- test("onChange function is called when the user selects from the calendar, the stringValue received by the onChange function is the date with the correct format (DEFAULT FORMAT)", () => {
177
- const onChange = jest.fn((returnedValue) => {
178
- expect(returnedValue.stringValue).toBe("16-10-2020");
179
- });
180
-
181
- const component = render(<DxcDate label="Birthdate" value="01-10-2020" onChange={onChange} />);
182
- const calendarButton = component.getByTestId('calendarIcon');
183
- fireEvent.click(calendarButton);
184
- const dayButton = component.getByRole("button", { name: "16" });
185
- fireEvent.click(dayButton);
186
- expect(dayButton).toBeTruthy();
187
- });
188
-
189
- test("onChange function is called when the user selects from the calendar, the stringValue received by the onChange function is the date with the correct format (CUSTOM FORMAT)", () => {
190
- const onChange = jest.fn((returnedValue) => {
191
- expect(returnedValue.stringValue).toBe("2020/10/16");
192
- });
193
-
194
- const component = render(<DxcDate label="Birthdate" format="yyyy/MM/dd" value="2020/10/01" onChange={onChange} />);
195
- const calendarButton = component.getByTestId('calendarIcon');
196
- fireEvent.click(calendarButton);
197
- const dayButton = component.getByRole("button", { name: "16" });
198
- fireEvent.click(dayButton);
199
- expect(dayButton).toBeTruthy();
200
- });
201
-
202
- test("Check selected date on calendar is the same date as the one on the input", () => {
203
- const component = render(<DxcDate label="Birthdate" value="01-10-2020" />);
204
- const calendarButton = component.getByTestId('calendarIcon');
205
- fireEvent.click(calendarButton);
206
- const dayButton = component.getByRole("button", { name: "1" });
207
- expect(dayButton.classList.contains("MuiPickersDay-daySelected")).toBe(true);
208
- });
209
- test("onBlur function is called", () => {
210
- const onBlur = jest.fn();
211
- const { getByRole, getByPlaceholderText } = render(
212
- <DxcDate label="Birthdate" value="30-03-81" onBlur={onBlur} placeholder />
213
- );
214
- // const input = getByRole("textbox");
215
- const input = getByPlaceholderText(defaultFormat);
216
-
217
- fireEvent.blur(input);
218
- expect(onBlur).toHaveBeenCalled();
219
- });
220
- test("onBlur function is called and the parameter received is what should be(DEFAULT FORMAT)", () => {
221
- const onBlur = jest.fn((returnedValue) => {
222
- expect(returnedValue).toBe("30-03-81");
223
- });
224
- const { getByRole, getByPlaceholderText } = render(
225
- <DxcDate label="Birthdate" value="30-03-81" onBlur={onBlur} placeholder />
226
- );
227
- // const input = getByRole("textbox");
228
- const input = getByPlaceholderText(defaultFormat);
229
-
230
- fireEvent.blur(input);
231
- expect(onBlur).toHaveBeenCalled();
232
- });
233
- test("onBlur function is called and the parameter received is what should be(CUSTOM FORMAT)", () => {
234
- const onBlur = jest.fn((returnedValue) => {
235
- expect(returnedValue).toBe("30/03/81");
236
- });
237
- const { getByRole, getByPlaceholderText } = render(
238
- <DxcDate label="Birthdate" format="dd/MM/yy" value="30/03/81" onBlur={onBlur} placeholder />
239
- );
240
- // const input = getByRole("textbox");
241
- const input = getByPlaceholderText("DD/MM/YY");
242
-
243
- fireEvent.blur(input);
244
- expect(onBlur).toHaveBeenCalled();
245
- });
246
- });
247
-
248
- describe("Uncontrolled Date Component", () => {
249
- const date = new Date("2020-10-16 00:00:00");
250
-
251
- test("Calendar´s value is the same as the input´s date if it´s right after changing the input value", () => {
252
- const { getByRole, getByText, rerender, getByPlaceholderText, getByTestId } = render(<DxcDate label="Birthdate" placeholder />);
253
- // const input = getByRole("textbox");
254
- const input = getByPlaceholderText(defaultFormat);
255
-
256
- fireEvent.change(input, { target: { value: "10-02-2020" } });
257
-
258
- rerender(<DxcDate label="Birthdate" value="10-02-2020" />);
259
- const calendarButton = getByTestId('calendarIcon');
260
- fireEvent.click(calendarButton);
261
- expect(getByText("Mon, Feb 10")).toBeTruthy();
262
- });
263
-
264
- test("onChange function is called when the user types something in the input", () => {
265
- const onChange = jest.fn((returnedValue) => {
266
- expect(returnedValue.dateValue).toBeNull();
267
- expect(returnedValue.stringValue).toBe("something");
268
- });
269
-
270
- const { getByRole, getByPlaceholderText } = render(<DxcDate label="Birthdate" onChange={onChange} placeholder />);
271
- // const input = getByRole("textbox");
272
- const input = getByPlaceholderText(defaultFormat);
273
-
274
- fireEvent.change(input, { target: { value: "something" } });
275
- expect(onChange).toHaveBeenCalled();
276
- });
277
- test("onChange function is called when the user types in the input a valid date(based on its format), the object received as a parameter in the onChange function is what should be(DEFAULT FORMAT)", () => {
278
- const onChange = jest.fn((returnedValue) => {
279
- expect(returnedValue.dateValue.getTime()).toBe(date.getTime());
280
- expect(returnedValue.stringValue).toBe("16-10-2020");
281
- });
282
-
283
- const { getByRole, getByPlaceholderText } = render(<DxcDate label="Birthdate" onChange={onChange} placeholder />);
284
- // const input = getByRole("textbox");
285
- const input = getByPlaceholderText(defaultFormat);
286
-
287
- fireEvent.change(input, { target: { value: "16-10-2020" } });
288
- expect(onChange).toHaveBeenCalled();
289
- });
290
- test("onChange function is called when the user types in the input a valid date(based on its format), the object received as a parameter in the onChange function is what should be(CUSTOM FORMAT)", () => {
291
- const onChange = jest.fn((returnedValue) => {
292
- expect(returnedValue.dateValue.getTime()).toBe(date.getTime());
293
- expect(returnedValue.stringValue).toBe("16-10-20");
294
- });
295
-
296
- const { getByRole, getByPlaceholderText } = render(
297
- <DxcDate label="Birthdate" format="dd-MM-yy" onChange={onChange} placeholder />
298
- );
299
- // const input = getByRole("textbox");
300
- const input = getByPlaceholderText("DD-MM-YY");
301
-
302
- fireEvent.change(input, { target: { value: "16-10-20" } });
303
- expect(onChange).toHaveBeenCalled();
304
- });
305
-
306
- test("onChange function is called when the user types in the input an invalid date(based on its format), the object received as a parameter in the onChange function is what should be(stringValue with the written string, and null as dateValue)(DEFAULT FORMAT)", () => {
307
- const onChange = jest.fn((returnedValue) => {
308
- expect(returnedValue.dateValue).toBeNull();
309
- expect(returnedValue.stringValue).toBe("11-15-2020");
310
- });
311
-
312
- const { getByRole, getByPlaceholderText } = render(<DxcDate label="Birthdate" onChange={onChange} placeholder />);
313
- // const input = getByRole("textbox");
314
- const input = getByPlaceholderText(defaultFormat);
315
-
316
- fireEvent.change(input, { target: { value: "11-15-2020" } });
317
- expect(onChange).toHaveBeenCalled();
318
- });
319
-
320
- test("onChange function is called when the user types in the input an invalid date(based on its format), the object received as a parameter in the onChange function is what should be(stringValue with the written string, and null as dateValue)(CUSTOM FORMAT)", () => {
321
- const onChange = jest.fn((returnedValue) => {
322
- expect(returnedValue.dateValue).toBeNull();
323
- expect(returnedValue.stringValue).toBe("15/11/2020");
324
- });
325
-
326
- const { getByRole, getByPlaceholderText } = render(
327
- <DxcDate label="Birthdate" format="MM/dd/yyyy" onChange={onChange} placeholder />
328
- );
329
- // const input = getByRole("textbox");
330
- const input = getByPlaceholderText("MM/DD/YYYY");
331
-
332
- fireEvent.change(input, { target: { value: "15/11/2020" } });
333
- expect(onChange).toHaveBeenCalled();
334
- });
335
- test("onChange function is called when the user selects from the calendar", () => {
336
- const onChange = jest.fn();
337
-
338
- const component = render(<DxcDate label="Birthdate" onChange={onChange} />);
339
- const calendarButton = component.getByTestId('calendarIcon');
340
- fireEvent.click(calendarButton);
341
- const dayButton = component.getByRole("button", { name: "10" });
342
- fireEvent.click(dayButton);
343
- expect(dayButton).toBeTruthy();
344
- expect(onChange).toHaveBeenCalled();
345
- });
346
-
347
- test("Check selected date on calendar is the same date as the one on the input", () => {
348
- const component = render(<DxcDate label="Birthdate" placeholder />);
349
- // const input = component.getByRole("textbox");
350
- const input = component.getByPlaceholderText(defaultFormat);
351
-
352
- fireEvent.change(input, { target: { value: "10-02-2020" } });
353
- const calendarButton = component.getByTestId('calendarIcon');
354
- fireEvent.click(calendarButton);
355
- const dayButton = component.getByRole("button", { name: "10" });
356
- expect(dayButton.classList.contains("MuiPickersDay-daySelected")).toBe(true);
357
- });
358
- test("onBlur function is called", () => {
359
- const onBlur = jest.fn();
360
- const { getByRole, getByPlaceholderText } = render(<DxcDate label="Birthdate" onBlur={onBlur} placeholder />);
361
- // const input = getByRole("textbox");
362
- const input = getByPlaceholderText(defaultFormat);
363
-
364
- fireEvent.blur(input);
365
- expect(onBlur).toHaveBeenCalled();
366
- });
367
- test("onBlur function is called and the parameter received is what should be(DEFAULT FORMAT)", () => {
368
- const onBlur = jest.fn((returnedValue) => {
369
- expect(returnedValue).toBe("10-02-2020");
370
- });
371
- const { getByRole, getByPlaceholderText } = render(<DxcDate label="Birthdate" onBlur={onBlur} placeholder />);
372
- // const input = getByRole("textbox");
373
- const input = getByPlaceholderText("DD-MM-YYYY");
374
-
375
- fireEvent.change(input, { target: { value: "10-02-2020" } });
376
- fireEvent.blur(input);
377
- expect(onBlur).toHaveBeenCalled();
378
- });
379
- test("onBlur function is called and the parameter received is what should be(CUSTOM FORMAT)", () => {
380
- const onBlur = jest.fn((returnedValue) => {
381
- expect(returnedValue).toBe("10/02/20");
382
- });
383
- const { getByRole, getByPlaceholderText } = render(
384
- <DxcDate label="Birthdate" format="dd/MM/yy" onBlur={onBlur} placeholder />
385
- );
386
- // const input = getByRole("textbox");
387
- const input = getByPlaceholderText("DD/MM/YY");
388
-
389
- fireEvent.change(input, { target: { value: "10/02/20" } });
390
- fireEvent.blur(input);
391
- expect(onBlur).toHaveBeenCalled();
392
- });
393
- });