@dxc-technology/halstack-react 0.0.0-a105522 → 0.0.0-a33ff0e

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 (341) 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 +41 -154
  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/Card.stories.tsx +201 -0
  34. package/card/ice-cream.jpg +0 -0
  35. package/card/types.d.ts +67 -0
  36. package/card/types.js +5 -0
  37. package/checkbox/Checkbox.d.ts +4 -0
  38. package/{dist/checkbox → checkbox}/Checkbox.js +16 -63
  39. package/checkbox/Checkbox.stories.tsx +192 -0
  40. package/checkbox/types.d.ts +60 -0
  41. package/checkbox/types.js +5 -0
  42. package/{dist/chip → chip}/Chip.js +17 -61
  43. package/chip/Chip.stories.tsx +121 -0
  44. package/chip/index.d.ts +22 -0
  45. package/{dist/common → common}/OpenSans.css +0 -0
  46. package/{dist/common → common}/RequiredComponent.js +3 -11
  47. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  48. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  49. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  50. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  51. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  52. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  53. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  54. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  55. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  56. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  57. package/{dist/common → common}/utils.js +0 -0
  58. package/{dist/common → common}/variables.js +318 -111
  59. package/{dist/date → date}/Date.js +20 -28
  60. package/date/index.d.ts +27 -0
  61. package/date-input/DateInput.d.ts +4 -0
  62. package/{dist/new-date/NewDate.js → date-input/DateInput.js} +88 -130
  63. package/date-input/DateInput.stories.tsx +138 -0
  64. package/date-input/types.d.ts +100 -0
  65. package/date-input/types.js +5 -0
  66. package/dialog/Dialog.d.ts +4 -0
  67. package/{dist/dialog → dialog}/Dialog.js +20 -73
  68. package/dialog/Dialog.stories.tsx +212 -0
  69. package/dialog/types.d.ts +43 -0
  70. package/dialog/types.js +5 -0
  71. package/dropdown/Dropdown.d.ts +4 -0
  72. package/{dist/dropdown → dropdown}/Dropdown.js +44 -171
  73. package/dropdown/types.d.ts +89 -0
  74. package/dropdown/types.js +5 -0
  75. package/file-input/FileInput.d.ts +4 -0
  76. package/file-input/FileInput.js +511 -0
  77. package/file-input/FileItem.d.ts +14 -0
  78. package/file-input/FileItem.js +182 -0
  79. package/file-input/types.d.ts +87 -0
  80. package/file-input/types.js +5 -0
  81. package/footer/Footer.d.ts +4 -0
  82. package/footer/Footer.js +266 -0
  83. package/footer/Footer.stories.jsx +151 -0
  84. package/footer/Icons.js +77 -0
  85. package/footer/types.d.ts +61 -0
  86. package/footer/types.js +5 -0
  87. package/header/Header.d.ts +7 -0
  88. package/header/Header.js +324 -0
  89. package/header/Header.stories.tsx +162 -0
  90. package/header/Icons.js +34 -0
  91. package/header/types.d.ts +47 -0
  92. package/header/types.js +5 -0
  93. package/heading/Heading.d.ts +4 -0
  94. package/{dist/heading → heading}/Heading.js +30 -89
  95. package/heading/Heading.stories.tsx +53 -0
  96. package/heading/types.d.ts +33 -0
  97. package/heading/types.js +5 -0
  98. package/input-text/Icons.js +22 -0
  99. package/{dist/input-text → input-text}/InputText.js +37 -133
  100. package/input-text/index.d.ts +36 -0
  101. package/{dist/layout → layout}/ApplicationLayout.js +35 -131
  102. package/layout/Icons.js +55 -0
  103. package/link/Link.d.ts +3 -0
  104. package/{dist/link → link}/Link.js +18 -94
  105. package/link/Link.stories.tsx +146 -0
  106. package/link/types.d.ts +74 -0
  107. package/link/types.js +5 -0
  108. package/main.d.ts +44 -0
  109. package/{dist/main.js → main.js} +104 -92
  110. package/number-input/NumberInput.d.ts +4 -0
  111. package/number-input/NumberInput.js +86 -0
  112. package/number-input/NumberInput.stories.tsx +115 -0
  113. package/number-input/NumberInputContext.d.ts +4 -0
  114. package/{dist/number/NumberContext.js → number-input/NumberInputContext.js} +6 -3
  115. package/number-input/numberInputContextTypes.d.ts +19 -0
  116. package/number-input/numberInputContextTypes.js +5 -0
  117. package/number-input/types.d.ts +117 -0
  118. package/number-input/types.js +5 -0
  119. package/package.json +32 -25
  120. package/paginator/Icons.js +66 -0
  121. package/paginator/Paginator.d.ts +4 -0
  122. package/paginator/Paginator.js +198 -0
  123. package/paginator/Paginator.stories.tsx +63 -0
  124. package/paginator/types.d.ts +38 -0
  125. package/paginator/types.js +5 -0
  126. package/password-input/PasswordInput.d.ts +4 -0
  127. package/{dist/password/Password.js → password-input/PasswordInput.js} +29 -67
  128. package/password-input/PasswordInput.stories.tsx +131 -0
  129. package/password-input/types.d.ts +105 -0
  130. package/password-input/types.js +5 -0
  131. package/progress-bar/ProgressBar.d.ts +4 -0
  132. package/{dist/progress-bar → progress-bar}/ProgressBar.js +20 -92
  133. package/progress-bar/ProgressBar.stories.jsx +58 -0
  134. package/progress-bar/types.d.ts +37 -0
  135. package/progress-bar/types.js +5 -0
  136. package/radio/Radio.d.ts +4 -0
  137. package/{dist/radio → radio}/Radio.js +15 -50
  138. package/radio/Radio.stories.tsx +192 -0
  139. package/radio/types.d.ts +54 -0
  140. package/radio/types.js +5 -0
  141. package/{dist/resultsetTable → resultsetTable}/ResultsetTable.js +35 -119
  142. package/resultsetTable/index.d.ts +19 -0
  143. package/select/Select.js +865 -0
  144. package/select/Select.stories.tsx +572 -0
  145. package/select/index.d.ts +131 -0
  146. package/sidenav/Sidenav.d.ts +9 -0
  147. package/{dist/sidenav → sidenav}/Sidenav.js +19 -62
  148. package/sidenav/Sidenav.stories.tsx +165 -0
  149. package/sidenav/types.d.ts +50 -0
  150. package/sidenav/types.js +5 -0
  151. package/slider/Slider.d.ts +4 -0
  152. package/slider/Slider.js +317 -0
  153. package/slider/Slider.stories.tsx +177 -0
  154. package/slider/types.d.ts +78 -0
  155. package/slider/types.js +5 -0
  156. package/spinner/Spinner.d.ts +4 -0
  157. package/spinner/Spinner.js +250 -0
  158. package/spinner/Spinner.stories.jsx +102 -0
  159. package/spinner/types.d.ts +32 -0
  160. package/spinner/types.js +5 -0
  161. package/switch/Switch.d.ts +4 -0
  162. package/{dist/switch → switch}/Switch.js +26 -69
  163. package/switch/Switch.stories.tsx +160 -0
  164. package/switch/types.d.ts +58 -0
  165. package/switch/types.js +5 -0
  166. package/table/Table.d.ts +4 -0
  167. package/{dist/table → table}/Table.js +10 -24
  168. package/table/Table.stories.jsx +276 -0
  169. package/table/types.d.ts +21 -0
  170. package/table/types.js +5 -0
  171. package/tabs/Tabs.d.ts +4 -0
  172. package/tabs/Tabs.js +213 -0
  173. package/tabs/types.d.ts +70 -0
  174. package/tabs/types.js +5 -0
  175. package/tag/Tag.d.ts +4 -0
  176. package/tag/Tag.js +193 -0
  177. package/tag/Tag.stories.tsx +145 -0
  178. package/tag/types.d.ts +60 -0
  179. package/tag/types.js +5 -0
  180. package/text-input/TextInput.d.ts +4 -0
  181. package/text-input/TextInput.js +785 -0
  182. package/text-input/types.d.ts +157 -0
  183. package/text-input/types.js +5 -0
  184. package/{dist/new-textarea/NewTextarea.js → textarea/Textarea.js} +73 -121
  185. package/textarea/Textarea.stories.jsx +135 -0
  186. package/textarea/index.d.ts +117 -0
  187. package/{dist/toggle → toggle}/Toggle.js +15 -49
  188. package/toggle/index.d.ts +21 -0
  189. package/toggle-group/ToggleGroup.js +243 -0
  190. package/toggle-group/ToggleGroup.stories.tsx +178 -0
  191. package/toggle-group/index.d.ts +21 -0
  192. package/{dist/upload → upload}/Upload.js +11 -15
  193. package/upload/buttons-upload/ButtonsUpload.js +111 -0
  194. package/upload/buttons-upload/Icons.js +40 -0
  195. package/upload/dragAndDropArea/DragAndDropArea.js +225 -0
  196. package/upload/dragAndDropArea/Icons.js +39 -0
  197. package/upload/file-upload/FileToUpload.js +115 -0
  198. package/upload/file-upload/Icons.js +66 -0
  199. package/{dist/upload → upload}/files-upload/FilesToUpload.js +12 -26
  200. package/upload/index.d.ts +15 -0
  201. package/upload/transaction/Icons.js +160 -0
  202. package/upload/transaction/Transaction.js +104 -0
  203. package/upload/transactions/Transactions.js +94 -0
  204. package/{dist/useTheme.js → useTheme.js} +0 -0
  205. package/wizard/Icons.js +65 -0
  206. package/wizard/Wizard.d.ts +4 -0
  207. package/{dist/wizard → wizard}/Wizard.js +33 -213
  208. package/wizard/Wizard.stories.jsx +224 -0
  209. package/wizard/types.d.ts +64 -0
  210. package/wizard/types.js +5 -0
  211. package/README.md +0 -66
  212. package/babel.config.js +0 -8
  213. package/dist/BackgroundColorContext.js +0 -46
  214. package/dist/ThemeContext.js +0 -240
  215. package/dist/accordion-group/AccordionGroup.js +0 -186
  216. package/dist/alert/index.d.ts +0 -26
  217. package/dist/badge/Badge.js +0 -63
  218. package/dist/checkbox/Checkbox.stories.js +0 -144
  219. package/dist/checkbox/readme.md +0 -116
  220. package/dist/date/Date.stories.js +0 -205
  221. package/dist/date/readme.md +0 -73
  222. package/dist/footer/Footer.js +0 -395
  223. package/dist/footer/Footer.stories.js +0 -94
  224. package/dist/footer/dxc_logo.svg +0 -15
  225. package/dist/footer/readme.md +0 -41
  226. package/dist/header/Header.js +0 -403
  227. package/dist/header/Header.stories.js +0 -176
  228. package/dist/header/close_icon.svg +0 -1
  229. package/dist/header/dxc_logo_black.svg +0 -8
  230. package/dist/header/hamb_menu_black.svg +0 -1
  231. package/dist/header/hamb_menu_white.svg +0 -1
  232. package/dist/header/readme.md +0 -33
  233. package/dist/input-text/InputText.stories.js +0 -209
  234. package/dist/input-text/error.svg +0 -1
  235. package/dist/input-text/readme.md +0 -91
  236. package/dist/layout/facebook.svg +0 -45
  237. package/dist/layout/linkedin.svg +0 -50
  238. package/dist/layout/twitter.svg +0 -53
  239. package/dist/link/readme.md +0 -51
  240. package/dist/main.d.ts +0 -2
  241. package/dist/new-input-text/NewInputText.js +0 -977
  242. package/dist/number/Number.js +0 -138
  243. package/dist/paginator/Paginator.js +0 -289
  244. package/dist/paginator/images/next.svg +0 -3
  245. package/dist/paginator/images/nextPage.svg +0 -3
  246. package/dist/paginator/images/previous.svg +0 -3
  247. package/dist/paginator/images/previousPage.svg +0 -3
  248. package/dist/paginator/readme.md +0 -50
  249. package/dist/password/styles.css +0 -3
  250. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  251. package/dist/progress-bar/readme.md +0 -63
  252. package/dist/radio/Radio.stories.js +0 -166
  253. package/dist/radio/readme.md +0 -70
  254. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  255. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  256. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  257. package/dist/slider/Slider.js +0 -319
  258. package/dist/slider/Slider.stories.js +0 -241
  259. package/dist/slider/readme.md +0 -64
  260. package/dist/spinner/Spinner.js +0 -381
  261. package/dist/spinner/Spinner.stories.js +0 -183
  262. package/dist/spinner/readme.md +0 -65
  263. package/dist/switch/Switch.stories.js +0 -134
  264. package/dist/switch/readme.md +0 -133
  265. package/dist/tabs/Tabs.js +0 -343
  266. package/dist/tabs/Tabs.stories.js +0 -130
  267. package/dist/tabs/readme.md +0 -78
  268. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  269. package/dist/tabs-for-sections/readme.md +0 -78
  270. package/dist/tag/Tag.js +0 -282
  271. package/dist/toggle/Toggle.stories.js +0 -297
  272. package/dist/toggle/readme.md +0 -80
  273. package/dist/toggle-group/ToggleGroup.js +0 -223
  274. package/dist/upload/Upload.stories.js +0 -72
  275. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -139
  276. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  277. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  278. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -329
  279. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  280. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  281. package/dist/upload/file-upload/FileToUpload.js +0 -184
  282. package/dist/upload/file-upload/audio-icon.svg +0 -4
  283. package/dist/upload/file-upload/close.svg +0 -4
  284. package/dist/upload/file-upload/file-icon.svg +0 -4
  285. package/dist/upload/file-upload/video-icon.svg +0 -4
  286. package/dist/upload/readme.md +0 -37
  287. package/dist/upload/transaction/Transaction.js +0 -175
  288. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  289. package/dist/upload/transaction/audio-icon.svg +0 -4
  290. package/dist/upload/transaction/error-icon.svg +0 -4
  291. package/dist/upload/transaction/file-icon-err.svg +0 -4
  292. package/dist/upload/transaction/file-icon.svg +0 -4
  293. package/dist/upload/transaction/image-icon-err.svg +0 -4
  294. package/dist/upload/transaction/image-icon.svg +0 -4
  295. package/dist/upload/transaction/success-icon.svg +0 -4
  296. package/dist/upload/transaction/video-icon-err.svg +0 -4
  297. package/dist/upload/transaction/video-icon.svg +0 -4
  298. package/dist/upload/transactions/Transactions.js +0 -138
  299. package/dist/wizard/invalid_icon.svg +0 -5
  300. package/dist/wizard/valid_icon.svg +0 -5
  301. package/dist/wizard/validation-wrong.svg +0 -6
  302. package/test/Accordion.test.js +0 -33
  303. package/test/AccordionGroup.test.js +0 -125
  304. package/test/Alert.test.js +0 -53
  305. package/test/Box.test.js +0 -10
  306. package/test/Button.test.js +0 -18
  307. package/test/Card.test.js +0 -30
  308. package/test/Checkbox.test.js +0 -45
  309. package/test/Chip.test.js +0 -25
  310. package/test/Date.test.js +0 -393
  311. package/test/Dialog.test.js +0 -23
  312. package/test/Dropdown.test.js +0 -145
  313. package/test/Footer.test.js +0 -99
  314. package/test/Header.test.js +0 -39
  315. package/test/Heading.test.js +0 -35
  316. package/test/InputText.test.js +0 -240
  317. package/test/Link.test.js +0 -43
  318. package/test/NewDate.test.js +0 -203
  319. package/test/NewInputText.test.js +0 -866
  320. package/test/NewTextarea.test.js +0 -252
  321. package/test/Number.test.js +0 -241
  322. package/test/Paginator.test.js +0 -177
  323. package/test/Password.test.js +0 -76
  324. package/test/ProgressBar.test.js +0 -35
  325. package/test/Radio.test.js +0 -37
  326. package/test/ResultsetTable.test.js +0 -329
  327. package/test/Select.test.js +0 -212
  328. package/test/Sidenav.test.js +0 -45
  329. package/test/Slider.test.js +0 -82
  330. package/test/Spinner.test.js +0 -32
  331. package/test/Switch.test.js +0 -45
  332. package/test/Table.test.js +0 -36
  333. package/test/Tabs.test.js +0 -109
  334. package/test/TabsForSections.test.js +0 -34
  335. package/test/Tag.test.js +0 -32
  336. package/test/TextArea.test.js +0 -52
  337. package/test/ToggleGroup.test.js +0 -81
  338. package/test/Upload.test.js +0 -60
  339. package/test/Wizard.test.js +0 -130
  340. package/test/mocks/pngMock.js +0 -1
  341. package/test/mocks/svgMock.js +0 -1
@@ -1,203 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent } from "@testing-library/react";
3
- import userEvent from "@testing-library/user-event";
4
-
5
- import DxcNewDate from "../src/new-date/NewDate";
6
-
7
- describe("NewDate component tests", () => {
8
- test("Renders with correct label, helper text, optional, placeholder and clearable action", () => {
9
- const { getByText, getByRole, getAllByRole } = render(
10
- <DxcNewDate label="Example label" helperText="Example of helper text" placeholder optional clearable />
11
- );
12
- const input = getByRole("textbox");
13
- expect(getByText("Example label")).toBeTruthy();
14
- expect(getByText("Example of helper text")).toBeTruthy();
15
- expect(getByText("(Optional)")).toBeTruthy();
16
- expect(input.getAttribute("placeholder")).toBe("DD-MM-YYYY");
17
- userEvent.type(input, "10/90/2010");
18
- const closeAction = getAllByRole("button")[0];
19
- userEvent.click(closeAction);
20
- expect(input.value).toBe("");
21
- });
22
-
23
- test("Renders with personalized error", () => {
24
- const { getByText } = render(<DxcNewDate error="Personalized error." />);
25
-
26
- expect(getByText("Personalized error.")).toBeTruthy();
27
- });
28
-
29
- test("Renders with correct format: user typed date but it's invalid", () => {
30
- const { getByText, getByRole } = render(<DxcNewDate label="With format MM/dd/yyyy" format="MM/dd/yyyy" />);
31
- const input = getByRole("textbox");
32
-
33
- userEvent.type(input, "10/90/2010");
34
- fireEvent.blur(input);
35
- expect(getByText("Invalid date.")).toBeTruthy();
36
- });
37
-
38
- test("Calendar renders with correct date: today's date", () => {
39
- const { getByText, getByRole } = render(<DxcNewDate />);
40
- const calendarAction = getByRole("button");
41
- const d = new Date();
42
- const options = { weekday: "short", month: "short", day: "numeric" };
43
-
44
- userEvent.click(calendarAction);
45
- expect(getByText(d.toLocaleString("en-US", options))).toBeTruthy();
46
- });
47
-
48
- test("Calendar renders with correct date: value prop", () => {
49
- const { getByText, getByRole } = render(<DxcNewDate value="20-10-2019" />);
50
- const calendarAction = getByRole("button");
51
- const d = new Date(2019, 9, 20);
52
- const options = { weekday: "short", month: "short", day: "numeric" };
53
-
54
- userEvent.click(calendarAction);
55
- expect(getByText(d.toLocaleString("en-US", options))).toBeTruthy();
56
- });
57
-
58
- test("Calendar renders with correct date: user typed value", () => {
59
- const { getByText, getByRole } = render(<DxcNewDate />);
60
- const calendarAction = getByRole("button");
61
- const d = new Date(2010, 0, 1);
62
- const options = { weekday: "short", month: "short", day: "numeric" };
63
- const input = getByRole("textbox");
64
-
65
- userEvent.type(input, "01-01-2010");
66
- userEvent.click(calendarAction);
67
- expect(getByText(d.toLocaleString("en-US", options))).toBeTruthy();
68
- });
69
-
70
- test("Calendar renders with correct date: invalid date, renders with today's date", () => {
71
- const { getByText, getByRole } = render(<DxcNewDate />);
72
- const calendarAction = getByRole("button");
73
- const d = new Date();
74
- const options = { weekday: "short", month: "short", day: "numeric" };
75
- const input = getByRole("textbox");
76
-
77
- userEvent.type(input, "01-01-xxxx");
78
- fireEvent.blur(input);
79
- expect(getByText("Invalid date.")).toBeTruthy();
80
- userEvent.click(calendarAction);
81
- expect(getByText(d.toLocaleString("en-US", options))).toBeTruthy();
82
- });
83
-
84
- test("Selecting a date from the calendar with an specific format", () => {
85
- const { getByText, getByRole } = render(<DxcNewDate label="With format M-dd-yyyy" format="M-dd-yyyy" />);
86
- const input = getByRole("textbox");
87
- const calendarAction = getByRole("button");
88
- userEvent.click(calendarAction);
89
- const dayButton = getByRole("button", { name: "10" });
90
- fireEvent.click(dayButton);
91
- const d = new Date();
92
- d.setDate(10);
93
- const options = { weekday: "short", month: "short", day: "numeric" };
94
- expect(getByText(d.toLocaleString("en-US", options))).toBeTruthy();
95
- fireEvent.keyDown(document, { key: "Esc", code: "Esc", keyCode: 27, charCode: 27 });
96
- expect(input.value).toBe(`${d.getMonth() + 1}-10-${d.getFullYear()}`);
97
- });
98
-
99
- test("Selecting a date from the calendar (using keyboard presses)", () => {
100
- const { getByRole } = render(<DxcNewDate />);
101
- const calendarAction = getByRole("button");
102
- const input = getByRole("textbox");
103
-
104
- userEvent.type(input, "01-01-2010");
105
- userEvent.click(calendarAction);
106
- fireEvent.keyDown(document, { key: "ArrowRight", code: "ArrowRight", keyCode: 39, charCode: 39 });
107
- fireEvent.keyDown(document, { key: "ArrowRight", code: "ArrowRight", keyCode: 39, charCode: 39 });
108
- fireEvent.keyDown(document, { key: "ArrowRight", code: "ArrowRight", keyCode: 39, charCode: 39 });
109
- fireEvent.keyDown(document, { key: "ArrowLeft", code: "ArrowLeft", keyCode: 37, charCode: 37 });
110
- fireEvent.keyDown(document, { key: "Esc", code: "Esc", keyCode: 27, charCode: 27 });
111
- expect(input.value).toBe("03-01-2010");
112
- });
113
-
114
- test("onChange & onBlur functions are called correctly", () => {
115
- const onBlur = jest.fn();
116
- const onChange = jest.fn();
117
- const { getByRole } = render(<DxcNewDate onChange={onChange} onBlur={onBlur} />);
118
- const input = getByRole("textbox");
119
- const d = new Date(2011, 9, 10);
120
-
121
- userEvent.type(input, "10-10-2011");
122
- expect(input.value).toBe("10-10-2011");
123
- expect(onChange).toHaveBeenCalledTimes(10);
124
- expect(onChange).toHaveBeenCalledWith({ value: "10-10-2011", date: d });
125
- fireEvent.blur(input);
126
- expect(onBlur).toHaveBeenCalled();
127
- expect(onBlur).toHaveBeenCalledWith({ value: "10-10-2011", error: null, date: d });
128
- });
129
-
130
- test("onChange & onBlur functions are called correctly, also with errors", () => {
131
- const onBlur = jest.fn();
132
- const onChange = jest.fn();
133
- const { getByRole } = render(<DxcNewDate onChange={onChange} onBlur={onBlur} />);
134
- const input = getByRole("textbox");
135
- const d = new Date(2011, 9, 10);
136
-
137
- userEvent.type(input, "10-10-");
138
- expect(input.value).toBe("10-10-");
139
- expect(onChange).toHaveBeenCalledTimes(6);
140
- expect(onChange).toHaveBeenCalledWith({ value: "10-10-", date: null });
141
- fireEvent.blur(input);
142
- expect(onBlur).toHaveBeenCalled();
143
- expect(onBlur).toHaveBeenCalledWith({ value: "10-10-", error: "Invalid date.", date: null });
144
- });
145
-
146
- test("onBlur function removes the error when it is fixed", () => {
147
- const onBlur = jest.fn();
148
- const { getByRole } = render(<DxcNewDate onBlur={onBlur} />);
149
- const input = getByRole("textbox");
150
- const d = new Date(2002, 1, 20);
151
-
152
- userEvent.type(input, "test");
153
- expect(input.value).toBe("test");
154
- fireEvent.blur(input);
155
- expect(onBlur).toHaveBeenCalled();
156
- expect(onBlur).toHaveBeenCalledWith({ value: "test", error: "Invalid date.", date: null });
157
- userEvent.clear(input);
158
- userEvent.type(input, "20-02-2002");
159
- expect(input.value).toBe("20-02-2002");
160
- fireEvent.blur(input);
161
- expect(onBlur).toHaveBeenCalled();
162
- expect(onBlur).toHaveBeenCalledWith({ value: "20-02-2002", error: null, date: d });
163
- });
164
-
165
- test("onBlur function removes the error when the input is empty", () => {
166
- const onBlur = jest.fn();
167
- const { getByRole } = render(<DxcNewDate onBlur={onBlur} />);
168
- const input = getByRole("textbox");
169
-
170
- userEvent.type(input, "test");
171
- expect(input.value).toBe("test");
172
- fireEvent.blur(input);
173
- expect(onBlur).toHaveBeenCalled();
174
- expect(onBlur).toHaveBeenCalledWith({ value: "test", error: "Invalid date.", date: null });
175
- userEvent.clear(input);
176
- fireEvent.blur(input);
177
- expect(onBlur).toHaveBeenCalled();
178
- expect(onBlur).toHaveBeenCalledWith({ value: "", error: null, date: null });
179
- });
180
-
181
- test("Disabled date (calendar action must be shown but not clickable)", () => {
182
- const { getByRole, queryByText } = render(<DxcNewDate disabled />);
183
- const calendarAction = getByRole("button");
184
- const d = new Date();
185
- const options = { weekday: "short", month: "short", day: "numeric" };
186
-
187
- expect(getByRole("textbox").disabled).toBeTruthy();
188
- userEvent.click(calendarAction);
189
- expect(queryByText(d.toLocaleString("en-US", options))).toBeFalsy();
190
- });
191
-
192
- test("Input has correct accesibility attributes", () => {
193
- const { getByRole } = render(<DxcNewDate label="Date label" />);
194
- const input = getByRole("textbox");
195
- expect(input.getAttribute("aria-autocomplete")).toBeNull();
196
- expect(input.getAttribute("aria-controls")).toBeNull();
197
- expect(input.getAttribute("aria-expanded")).toBeNull();
198
- const calendarAction = getByRole("button");
199
- userEvent.click(calendarAction);
200
- const datePicker = getByRole("dialog");
201
- expect(datePicker.getAttribute("aria-modal")).toBe("true");
202
- });
203
- });