@dxc-technology/halstack-react 0.0.0-ebb089f → 0.0.0-ec06b53

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 (459) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +47 -0
  3. package/HalstackContext.d.ts +12 -0
  4. package/HalstackContext.js +294 -0
  5. package/accordion/Accordion.d.ts +4 -0
  6. package/accordion/Accordion.js +245 -0
  7. package/accordion/Accordion.stories.tsx +306 -0
  8. package/accordion/Accordion.test.js +71 -0
  9. package/accordion/types.d.ts +69 -0
  10. package/accordion/types.js +5 -0
  11. package/accordion-group/AccordionGroup.d.ts +7 -0
  12. package/accordion-group/AccordionGroup.js +149 -0
  13. package/accordion-group/AccordionGroup.stories.tsx +251 -0
  14. package/accordion-group/AccordionGroup.test.js +126 -0
  15. package/accordion-group/types.d.ts +79 -0
  16. package/accordion-group/types.js +5 -0
  17. package/alert/Alert.d.ts +4 -0
  18. package/{dist/alert → alert}/Alert.js +44 -154
  19. package/alert/Alert.stories.tsx +170 -0
  20. package/alert/Alert.test.js +92 -0
  21. package/alert/types.d.ts +49 -0
  22. package/alert/types.js +5 -0
  23. package/badge/Badge.d.ts +4 -0
  24. package/badge/Badge.js +61 -0
  25. package/badge/types.d.ts +5 -0
  26. package/badge/types.js +5 -0
  27. package/bleed/Bleed.d.ts +3 -0
  28. package/bleed/Bleed.js +51 -0
  29. package/bleed/Bleed.stories.tsx +341 -0
  30. package/bleed/types.d.ts +37 -0
  31. package/bleed/types.js +5 -0
  32. package/box/Box.d.ts +4 -0
  33. package/box/Box.js +116 -0
  34. package/box/Box.stories.tsx +132 -0
  35. package/box/Box.test.js +18 -0
  36. package/box/types.d.ts +44 -0
  37. package/box/types.js +5 -0
  38. package/bulleted-list/BulletedList.d.ts +7 -0
  39. package/bulleted-list/BulletedList.js +123 -0
  40. package/bulleted-list/BulletedList.stories.tsx +200 -0
  41. package/bulleted-list/types.d.ts +11 -0
  42. package/bulleted-list/types.js +5 -0
  43. package/button/Button.d.ts +4 -0
  44. package/button/Button.js +156 -0
  45. package/button/Button.stories.tsx +283 -0
  46. package/button/Button.test.js +35 -0
  47. package/button/types.d.ts +53 -0
  48. package/button/types.js +5 -0
  49. package/card/Card.d.ts +4 -0
  50. package/card/Card.js +161 -0
  51. package/card/Card.stories.tsx +201 -0
  52. package/card/Card.test.js +50 -0
  53. package/card/ice-cream.jpg +0 -0
  54. package/card/types.d.ts +68 -0
  55. package/card/types.js +5 -0
  56. package/checkbox/Checkbox.d.ts +4 -0
  57. package/checkbox/Checkbox.js +250 -0
  58. package/checkbox/Checkbox.stories.tsx +208 -0
  59. package/checkbox/Checkbox.test.js +155 -0
  60. package/checkbox/types.d.ts +68 -0
  61. package/checkbox/types.js +5 -0
  62. package/chip/Chip.d.ts +4 -0
  63. package/chip/Chip.js +161 -0
  64. package/chip/Chip.stories.tsx +119 -0
  65. package/chip/Chip.test.js +56 -0
  66. package/chip/types.d.ts +45 -0
  67. package/chip/types.js +5 -0
  68. package/{dist/common → common}/OpenSans.css +0 -0
  69. package/{dist/common → common}/RequiredComponent.js +3 -11
  70. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  71. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  72. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  73. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  74. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  75. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  76. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  77. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  78. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  79. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  80. package/{dist/common → common}/utils.js +0 -0
  81. package/{dist/common → common}/variables.js +363 -425
  82. package/date-input/Calendar.d.ts +4 -0
  83. package/date-input/Calendar.js +258 -0
  84. package/date-input/DateInput.d.ts +4 -0
  85. package/date-input/DateInput.js +227 -0
  86. package/date-input/DateInput.stories.tsx +151 -0
  87. package/date-input/DateInput.test.js +752 -0
  88. package/date-input/DatePicker.d.ts +4 -0
  89. package/date-input/DatePicker.js +160 -0
  90. package/date-input/YearPicker.d.ts +4 -0
  91. package/date-input/YearPicker.js +115 -0
  92. package/date-input/types.d.ts +160 -0
  93. package/date-input/types.js +5 -0
  94. package/dialog/Dialog.d.ts +4 -0
  95. package/dialog/Dialog.js +162 -0
  96. package/dialog/Dialog.stories.tsx +267 -0
  97. package/dialog/Dialog.test.js +70 -0
  98. package/dialog/types.d.ts +44 -0
  99. package/dialog/types.js +5 -0
  100. package/dropdown/Dropdown.d.ts +4 -0
  101. package/dropdown/Dropdown.js +391 -0
  102. package/dropdown/Dropdown.stories.tsx +312 -0
  103. package/dropdown/Dropdown.test.js +585 -0
  104. package/dropdown/DropdownMenu.d.ts +4 -0
  105. package/dropdown/DropdownMenu.js +80 -0
  106. package/dropdown/DropdownMenuItem.d.ts +4 -0
  107. package/dropdown/DropdownMenuItem.js +92 -0
  108. package/dropdown/types.d.ts +100 -0
  109. package/dropdown/types.js +5 -0
  110. package/file-input/FileInput.d.ts +4 -0
  111. package/file-input/FileInput.js +551 -0
  112. package/file-input/FileInput.stories.tsx +535 -0
  113. package/file-input/FileInput.test.js +498 -0
  114. package/file-input/FileItem.d.ts +4 -0
  115. package/file-input/FileItem.js +161 -0
  116. package/file-input/types.d.ts +129 -0
  117. package/file-input/types.js +5 -0
  118. package/flex/Flex.d.ts +4 -0
  119. package/flex/Flex.js +69 -0
  120. package/flex/Flex.stories.tsx +103 -0
  121. package/flex/types.d.ts +32 -0
  122. package/flex/types.js +5 -0
  123. package/footer/Footer.d.ts +4 -0
  124. package/footer/Footer.js +185 -0
  125. package/footer/Footer.stories.tsx +137 -0
  126. package/footer/Footer.test.js +109 -0
  127. package/footer/Icons.d.ts +2 -0
  128. package/{dist/footer → footer}/Icons.js +16 -16
  129. package/footer/types.d.ts +66 -0
  130. package/footer/types.js +5 -0
  131. package/header/Header.d.ts +7 -0
  132. package/header/Header.js +305 -0
  133. package/header/Header.stories.tsx +172 -0
  134. package/header/Header.test.js +79 -0
  135. package/header/Icons.d.ts +2 -0
  136. package/{dist/header → header}/Icons.js +9 -34
  137. package/header/types.d.ts +48 -0
  138. package/header/types.js +5 -0
  139. package/heading/Heading.d.ts +4 -0
  140. package/{dist/heading → heading}/Heading.js +25 -96
  141. package/heading/Heading.stories.tsx +54 -0
  142. package/heading/Heading.test.js +186 -0
  143. package/heading/types.d.ts +33 -0
  144. package/heading/types.js +5 -0
  145. package/inset/Inset.d.ts +3 -0
  146. package/inset/Inset.js +51 -0
  147. package/inset/Inset.stories.tsx +229 -0
  148. package/inset/types.d.ts +37 -0
  149. package/inset/types.js +5 -0
  150. package/layout/ApplicationLayout.d.ts +20 -0
  151. package/layout/ApplicationLayout.js +171 -0
  152. package/layout/ApplicationLayout.stories.tsx +162 -0
  153. package/layout/Icons.d.ts +5 -0
  154. package/{dist/layout → layout}/Icons.js +19 -8
  155. package/layout/SidenavContext.d.ts +5 -0
  156. package/layout/SidenavContext.js +19 -0
  157. package/layout/types.d.ts +42 -0
  158. package/layout/types.js +5 -0
  159. package/link/Link.d.ts +4 -0
  160. package/link/Link.js +136 -0
  161. package/link/Link.stories.tsx +193 -0
  162. package/link/Link.test.js +83 -0
  163. package/link/types.d.ts +54 -0
  164. package/link/types.js +5 -0
  165. package/main.d.ts +44 -0
  166. package/{dist/main.js → main.js} +114 -104
  167. package/number-input/NumberInput.d.ts +4 -0
  168. package/number-input/NumberInput.js +76 -0
  169. package/number-input/NumberInput.stories.tsx +115 -0
  170. package/number-input/NumberInput.test.js +542 -0
  171. package/number-input/NumberInputContext.d.ts +4 -0
  172. package/{dist/number-input → number-input}/NumberInputContext.js +5 -2
  173. package/number-input/numberInputContextTypes.d.ts +19 -0
  174. package/number-input/numberInputContextTypes.js +5 -0
  175. package/number-input/types.d.ts +124 -0
  176. package/number-input/types.js +5 -0
  177. package/package.json +36 -33
  178. package/{dist/paginator → paginator}/Icons.js +9 -9
  179. package/paginator/Paginator.d.ts +4 -0
  180. package/paginator/Paginator.js +171 -0
  181. package/paginator/Paginator.stories.tsx +63 -0
  182. package/paginator/Paginator.test.js +308 -0
  183. package/paginator/types.d.ts +38 -0
  184. package/paginator/types.js +5 -0
  185. package/paragraph/Paragraph.d.ts +6 -0
  186. package/paragraph/Paragraph.js +38 -0
  187. package/paragraph/Paragraph.stories.tsx +44 -0
  188. package/password-input/PasswordInput.d.ts +4 -0
  189. package/{dist/password-input → password-input}/PasswordInput.js +40 -77
  190. package/password-input/PasswordInput.stories.tsx +131 -0
  191. package/password-input/PasswordInput.test.js +181 -0
  192. package/password-input/types.d.ts +110 -0
  193. package/password-input/types.js +5 -0
  194. package/progress-bar/ProgressBar.d.ts +4 -0
  195. package/progress-bar/ProgressBar.js +176 -0
  196. package/progress-bar/ProgressBar.stories.jsx +60 -0
  197. package/progress-bar/ProgressBar.test.js +110 -0
  198. package/progress-bar/types.d.ts +36 -0
  199. package/progress-bar/types.js +5 -0
  200. package/quick-nav/QuickNav.d.ts +4 -0
  201. package/quick-nav/QuickNav.js +117 -0
  202. package/quick-nav/QuickNav.stories.tsx +342 -0
  203. package/quick-nav/types.d.ts +21 -0
  204. package/quick-nav/types.js +5 -0
  205. package/radio-group/Radio.d.ts +4 -0
  206. package/radio-group/Radio.js +156 -0
  207. package/radio-group/RadioGroup.d.ts +4 -0
  208. package/radio-group/RadioGroup.js +283 -0
  209. package/radio-group/RadioGroup.stories.tsx +101 -0
  210. package/radio-group/RadioGroup.test.js +722 -0
  211. package/radio-group/types.d.ts +114 -0
  212. package/radio-group/types.js +5 -0
  213. package/resultsetTable/Icons.d.ts +7 -0
  214. package/resultsetTable/Icons.js +51 -0
  215. package/resultsetTable/ResultsetTable.d.ts +4 -0
  216. package/resultsetTable/ResultsetTable.js +195 -0
  217. package/resultsetTable/ResultsetTable.stories.tsx +300 -0
  218. package/resultsetTable/ResultsetTable.test.js +330 -0
  219. package/resultsetTable/types.d.ts +67 -0
  220. package/resultsetTable/types.js +5 -0
  221. package/select/Icons.d.ts +10 -0
  222. package/select/Icons.js +93 -0
  223. package/select/Listbox.d.ts +4 -0
  224. package/select/Listbox.js +198 -0
  225. package/select/Option.d.ts +4 -0
  226. package/select/Option.js +110 -0
  227. package/select/Select.d.ts +4 -0
  228. package/select/Select.js +645 -0
  229. package/select/Select.stories.tsx +627 -0
  230. package/select/Select.test.js +2233 -0
  231. package/select/types.d.ts +210 -0
  232. package/select/types.js +5 -0
  233. package/sidenav/Sidenav.d.ts +10 -0
  234. package/sidenav/Sidenav.js +268 -0
  235. package/sidenav/Sidenav.stories.tsx +180 -0
  236. package/sidenav/Sidenav.test.js +44 -0
  237. package/sidenav/types.d.ts +73 -0
  238. package/sidenav/types.js +5 -0
  239. package/slider/Slider.d.ts +4 -0
  240. package/slider/Slider.js +343 -0
  241. package/slider/Slider.stories.tsx +183 -0
  242. package/slider/Slider.test.js +250 -0
  243. package/slider/types.d.ts +86 -0
  244. package/slider/types.js +5 -0
  245. package/spinner/Spinner.d.ts +4 -0
  246. package/spinner/Spinner.js +250 -0
  247. package/spinner/Spinner.stories.jsx +103 -0
  248. package/spinner/Spinner.test.js +64 -0
  249. package/spinner/types.d.ts +32 -0
  250. package/spinner/types.js +5 -0
  251. package/switch/Switch.d.ts +4 -0
  252. package/switch/Switch.js +262 -0
  253. package/switch/Switch.stories.tsx +138 -0
  254. package/switch/Switch.test.js +225 -0
  255. package/switch/types.d.ts +66 -0
  256. package/switch/types.js +5 -0
  257. package/table/Table.d.ts +4 -0
  258. package/{dist/table → table}/Table.js +12 -26
  259. package/table/Table.stories.jsx +277 -0
  260. package/table/Table.test.js +26 -0
  261. package/table/types.d.ts +21 -0
  262. package/table/types.js +5 -0
  263. package/tabs/Tab.d.ts +4 -0
  264. package/tabs/Tab.js +135 -0
  265. package/tabs/Tabs.d.ts +4 -0
  266. package/tabs/Tabs.js +467 -0
  267. package/tabs/Tabs.stories.tsx +186 -0
  268. package/tabs/Tabs.test.js +351 -0
  269. package/tabs/types.d.ts +92 -0
  270. package/tabs/types.js +5 -0
  271. package/tabs-nav/NavTabs.d.ts +8 -0
  272. package/tabs-nav/NavTabs.js +125 -0
  273. package/tabs-nav/NavTabs.stories.tsx +170 -0
  274. package/tabs-nav/NavTabs.test.js +82 -0
  275. package/tabs-nav/Tab.d.ts +4 -0
  276. package/tabs-nav/Tab.js +130 -0
  277. package/tabs-nav/types.d.ts +53 -0
  278. package/tabs-nav/types.js +5 -0
  279. package/tag/Tag.d.ts +4 -0
  280. package/tag/Tag.js +183 -0
  281. package/tag/Tag.stories.tsx +142 -0
  282. package/tag/Tag.test.js +60 -0
  283. package/tag/types.d.ts +69 -0
  284. package/tag/types.js +5 -0
  285. package/text-input/Icons.d.ts +8 -0
  286. package/text-input/Icons.js +60 -0
  287. package/text-input/Suggestion.d.ts +4 -0
  288. package/text-input/Suggestion.js +57 -0
  289. package/text-input/Suggestions.d.ts +4 -0
  290. package/text-input/Suggestions.js +134 -0
  291. package/text-input/TextInput.d.ts +4 -0
  292. package/text-input/TextInput.js +677 -0
  293. package/text-input/TextInput.stories.tsx +481 -0
  294. package/text-input/TextInput.test.js +1624 -0
  295. package/text-input/types.d.ts +197 -0
  296. package/text-input/types.js +5 -0
  297. package/textarea/Textarea.d.ts +4 -0
  298. package/{dist/textarea → textarea}/Textarea.js +50 -142
  299. package/textarea/Textarea.stories.jsx +157 -0
  300. package/textarea/Textarea.test.js +437 -0
  301. package/textarea/types.d.ts +137 -0
  302. package/textarea/types.js +5 -0
  303. package/toggle-group/ToggleGroup.d.ts +4 -0
  304. package/{dist/toggle-group → toggle-group}/ToggleGroup.js +36 -148
  305. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  306. package/toggle-group/ToggleGroup.test.js +156 -0
  307. package/toggle-group/types.d.ts +105 -0
  308. package/toggle-group/types.js +5 -0
  309. package/typography/Typography.d.ts +4 -0
  310. package/typography/Typography.js +131 -0
  311. package/typography/Typography.stories.tsx +198 -0
  312. package/typography/types.d.ts +18 -0
  313. package/typography/types.js +5 -0
  314. package/useTheme.d.ts +2 -0
  315. package/{dist/useTheme.js → useTheme.js} +2 -2
  316. package/useTranslatedLabels.d.ts +2 -0
  317. package/useTranslatedLabels.js +20 -0
  318. package/wizard/Wizard.d.ts +4 -0
  319. package/wizard/Wizard.js +285 -0
  320. package/wizard/Wizard.stories.tsx +233 -0
  321. package/wizard/Wizard.test.js +141 -0
  322. package/wizard/types.d.ts +65 -0
  323. package/wizard/types.js +5 -0
  324. package/README.md +0 -66
  325. package/babel.config.js +0 -7
  326. package/dist/BackgroundColorContext.js +0 -46
  327. package/dist/ThemeContext.js +0 -250
  328. package/dist/V3Select/V3Select.js +0 -549
  329. package/dist/V3Select/index.d.ts +0 -27
  330. package/dist/V3Textarea/V3Textarea.js +0 -264
  331. package/dist/V3Textarea/index.d.ts +0 -27
  332. package/dist/accordion/Accordion.js +0 -353
  333. package/dist/accordion/index.d.ts +0 -28
  334. package/dist/accordion-group/AccordionGroup.js +0 -186
  335. package/dist/accordion-group/index.d.ts +0 -16
  336. package/dist/alert/index.d.ts +0 -51
  337. package/dist/badge/Badge.js +0 -63
  338. package/dist/box/Box.js +0 -156
  339. package/dist/box/index.d.ts +0 -25
  340. package/dist/button/Button.js +0 -238
  341. package/dist/button/Button.stories.js +0 -27
  342. package/dist/button/index.d.ts +0 -24
  343. package/dist/card/Card.js +0 -254
  344. package/dist/card/index.d.ts +0 -22
  345. package/dist/checkbox/Checkbox.js +0 -299
  346. package/dist/checkbox/index.d.ts +0 -24
  347. package/dist/chip/Chip.js +0 -265
  348. package/dist/chip/index.d.ts +0 -22
  349. package/dist/date/Date.js +0 -379
  350. package/dist/date/index.d.ts +0 -27
  351. package/dist/date-input/DateInput.js +0 -400
  352. package/dist/date-input/index.d.ts +0 -95
  353. package/dist/dialog/Dialog.js +0 -218
  354. package/dist/dialog/index.d.ts +0 -18
  355. package/dist/dropdown/Dropdown.js +0 -544
  356. package/dist/dropdown/index.d.ts +0 -26
  357. package/dist/file-input/FileInput.js +0 -644
  358. package/dist/file-input/FileItem.js +0 -287
  359. package/dist/file-input/index.d.ts +0 -81
  360. package/dist/footer/Footer.js +0 -421
  361. package/dist/footer/index.d.ts +0 -25
  362. package/dist/header/Header.js +0 -470
  363. package/dist/header/index.d.ts +0 -25
  364. package/dist/heading/index.d.ts +0 -17
  365. package/dist/input-text/Icons.js +0 -22
  366. package/dist/input-text/InputText.js +0 -705
  367. package/dist/input-text/index.d.ts +0 -36
  368. package/dist/layout/ApplicationLayout.js +0 -327
  369. package/dist/link/Link.js +0 -237
  370. package/dist/link/index.d.ts +0 -23
  371. package/dist/main.d.ts +0 -40
  372. package/dist/number-input/NumberInput.js +0 -136
  373. package/dist/number-input/index.d.ts +0 -113
  374. package/dist/paginator/Paginator.js +0 -305
  375. package/dist/paginator/index.d.ts +0 -20
  376. package/dist/password-input/index.d.ts +0 -94
  377. package/dist/progress-bar/ProgressBar.js +0 -242
  378. package/dist/progress-bar/index.d.ts +0 -18
  379. package/dist/radio/Radio.js +0 -209
  380. package/dist/radio/index.d.ts +0 -23
  381. package/dist/resultsetTable/ResultsetTable.js +0 -358
  382. package/dist/resultsetTable/index.d.ts +0 -19
  383. package/dist/select/Select.js +0 -1137
  384. package/dist/select/index.d.ts +0 -131
  385. package/dist/sidenav/Sidenav.js +0 -179
  386. package/dist/sidenav/index.d.ts +0 -13
  387. package/dist/slider/Slider.js +0 -404
  388. package/dist/slider/index.d.ts +0 -29
  389. package/dist/spinner/Spinner.js +0 -381
  390. package/dist/spinner/index.d.ts +0 -17
  391. package/dist/switch/Switch.js +0 -222
  392. package/dist/switch/index.d.ts +0 -24
  393. package/dist/table/index.d.ts +0 -13
  394. package/dist/tabs/Tabs.js +0 -343
  395. package/dist/tabs/index.d.ts +0 -19
  396. package/dist/tag/Tag.js +0 -282
  397. package/dist/tag/index.d.ts +0 -24
  398. package/dist/text-input/TextInput.js +0 -974
  399. package/dist/text-input/index.d.ts +0 -135
  400. package/dist/textarea/index.d.ts +0 -117
  401. package/dist/toggle/Toggle.js +0 -220
  402. package/dist/toggle/index.d.ts +0 -21
  403. package/dist/toggle-group/index.d.ts +0 -21
  404. package/dist/upload/Upload.js +0 -205
  405. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -135
  406. package/dist/upload/buttons-upload/Icons.js +0 -40
  407. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -329
  408. package/dist/upload/dragAndDropArea/Icons.js +0 -39
  409. package/dist/upload/file-upload/FileToUpload.js +0 -189
  410. package/dist/upload/file-upload/Icons.js +0 -66
  411. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  412. package/dist/upload/index.d.ts +0 -15
  413. package/dist/upload/transaction/Icons.js +0 -160
  414. package/dist/upload/transaction/Transaction.js +0 -148
  415. package/dist/upload/transactions/Transactions.js +0 -138
  416. package/dist/wizard/Icons.js +0 -65
  417. package/dist/wizard/Wizard.js +0 -405
  418. package/dist/wizard/index.d.ts +0 -18
  419. package/test/Accordion.test.js +0 -33
  420. package/test/AccordionGroup.test.js +0 -125
  421. package/test/Alert.test.js +0 -53
  422. package/test/Box.test.js +0 -10
  423. package/test/Button.test.js +0 -18
  424. package/test/Card.test.js +0 -30
  425. package/test/Checkbox.test.js +0 -45
  426. package/test/Chip.test.js +0 -25
  427. package/test/Date.test.js +0 -395
  428. package/test/DateInput.test.js +0 -242
  429. package/test/Dialog.test.js +0 -23
  430. package/test/Dropdown.test.js +0 -145
  431. package/test/FileInput.test.js +0 -201
  432. package/test/Footer.test.js +0 -94
  433. package/test/Header.test.js +0 -34
  434. package/test/Heading.test.js +0 -83
  435. package/test/InputText.test.js +0 -239
  436. package/test/Link.test.js +0 -43
  437. package/test/NumberInput.test.js +0 -259
  438. package/test/Paginator.test.js +0 -181
  439. package/test/PasswordInput.test.js +0 -83
  440. package/test/ProgressBar.test.js +0 -35
  441. package/test/Radio.test.js +0 -37
  442. package/test/ResultsetTable.test.js +0 -330
  443. package/test/Select.test.js +0 -928
  444. package/test/Sidenav.test.js +0 -45
  445. package/test/Slider.test.js +0 -74
  446. package/test/Spinner.test.js +0 -32
  447. package/test/Switch.test.js +0 -45
  448. package/test/Table.test.js +0 -36
  449. package/test/Tabs.test.js +0 -109
  450. package/test/Tag.test.js +0 -32
  451. package/test/TextInput.test.js +0 -731
  452. package/test/Textarea.test.js +0 -193
  453. package/test/ToggleGroup.test.js +0 -85
  454. package/test/Upload.test.js +0 -60
  455. package/test/V3Select.test.js +0 -212
  456. package/test/V3TextArea.test.js +0 -51
  457. package/test/Wizard.test.js +0 -130
  458. package/test/mocks/pngMock.js +0 -1
  459. package/test/mocks/svgMock.js +0 -1
@@ -0,0 +1,752 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
6
+
7
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
8
+
9
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
10
+
11
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
12
+
13
+ var _react = _interopRequireDefault(require("react"));
14
+
15
+ var _react2 = require("@testing-library/react");
16
+
17
+ var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
18
+
19
+ var _dayjs = _interopRequireDefault(require("dayjs"));
20
+
21
+ var _DateInput = _interopRequireDefault(require("./DateInput.tsx"));
22
+
23
+ // Mocking DOMRect for Radix Primitive Popover
24
+ global.globalThis = global;
25
+
26
+ global.ResizeObserver = /*#__PURE__*/function () {
27
+ function ResizeObserver(cb) {
28
+ (0, _classCallCheck2["default"])(this, ResizeObserver);
29
+ this.cb = cb;
30
+ }
31
+
32
+ (0, _createClass2["default"])(ResizeObserver, [{
33
+ key: "observe",
34
+ value: function observe() {
35
+ this.cb([{
36
+ borderBoxSize: {
37
+ inlineSize: 0,
38
+ blockSize: 0
39
+ }
40
+ }]);
41
+ }
42
+ }, {
43
+ key: "unobserve",
44
+ value: function unobserve() {}
45
+ }]);
46
+ return ResizeObserver;
47
+ }();
48
+
49
+ global.DOMRect = {
50
+ fromRect: function fromRect() {
51
+ return {
52
+ top: 0,
53
+ left: 0,
54
+ bottom: 0,
55
+ right: 0,
56
+ width: 0,
57
+ height: 0
58
+ };
59
+ }
60
+ };
61
+ describe("DateInput component tests", function () {
62
+ test("Renders with correct label, helper text, optional, placeholder and clearable action", function () {
63
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
64
+ label: "Example label",
65
+ helperText: "Example of helper text",
66
+ placeholder: true,
67
+ optional: true,
68
+ clearable: true
69
+ })),
70
+ getByText = _render.getByText,
71
+ getByRole = _render.getByRole,
72
+ getAllByRole = _render.getAllByRole;
73
+
74
+ var input = getByRole("textbox");
75
+ expect(getByText("Example label")).toBeTruthy();
76
+ expect(getByText("Example of helper text")).toBeTruthy();
77
+ expect(getByText("(Optional)")).toBeTruthy();
78
+ expect(input.getAttribute("placeholder")).toBe("DD-MM-YYYY");
79
+
80
+ _userEvent["default"].type(input, "10/10/2010");
81
+
82
+ var closeAction = getAllByRole("button")[0];
83
+
84
+ _userEvent["default"].click(closeAction);
85
+
86
+ expect(input.value).toBe("");
87
+ });
88
+ test("Renders with custom error", function () {
89
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
90
+ error: "Personalized error."
91
+ })),
92
+ getByText = _render2.getByText;
93
+
94
+ expect(getByText("Personalized error.")).toBeTruthy();
95
+ });
96
+ test("Renders with an initial value when it is uncontrolled", function () {
97
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
98
+ label: "Default label",
99
+ placeholder: "Placeholder",
100
+ defaultValue: "21-10-2015"
101
+ })),
102
+ getByText = _render3.getByText,
103
+ getByRole = _render3.getByRole;
104
+
105
+ var input = getByRole("textbox");
106
+ var calendarAction = getByRole("combobox");
107
+ expect(input.value).toBe("21-10-2015");
108
+
109
+ _userEvent["default"].click(calendarAction);
110
+
111
+ expect(getByText("21").getAttribute("aria-selected")).toBeTruthy();
112
+ expect(getByText("October 2015")).toBeTruthy();
113
+ });
114
+ test("Renders with correct format: user typed date but it's invalid, onBlur error", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
115
+ var onBlur, _render4, getByRole, input;
116
+
117
+ return _regenerator["default"].wrap(function _callee$(_context) {
118
+ while (1) {
119
+ switch (_context.prev = _context.next) {
120
+ case 0:
121
+ onBlur = jest.fn(function (_ref2) {
122
+ var value = _ref2.value,
123
+ error = _ref2.error;
124
+ expect(value).toBe("10/90/2010");
125
+ expect(error).toBe("Invalid date.");
126
+ });
127
+ _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
128
+ label: "With format MM/dd/yyyy",
129
+ format: "MM/dd/yyyy",
130
+ onBlur: onBlur
131
+ })), getByRole = _render4.getByRole;
132
+ input = getByRole("textbox");
133
+
134
+ _userEvent["default"].click(input);
135
+
136
+ _context.next = 6;
137
+ return _userEvent["default"].keyboard("10");
138
+
139
+ case 6:
140
+ _context.next = 8;
141
+ return _userEvent["default"].keyboard("/");
142
+
143
+ case 8:
144
+ _context.next = 10;
145
+ return _userEvent["default"].keyboard("90");
146
+
147
+ case 10:
148
+ _context.next = 12;
149
+ return _userEvent["default"].keyboard("/");
150
+
151
+ case 12:
152
+ _context.next = 14;
153
+ return _userEvent["default"].keyboard("2010");
154
+
155
+ case 14:
156
+ _react2.fireEvent.blur(input);
157
+
158
+ case 15:
159
+ case "end":
160
+ return _context.stop();
161
+ }
162
+ }
163
+ }, _callee);
164
+ })));
165
+ test("Renders with correct format: user typed date but it's invalid, onChange error", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
166
+ var onChange, _render5, getByRole, input;
167
+
168
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
169
+ while (1) {
170
+ switch (_context2.prev = _context2.next) {
171
+ case 0:
172
+ onChange = jest.fn();
173
+ _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
174
+ label: "With format MM/dd/yyyy",
175
+ format: "MM/dd/yyyy",
176
+ onChange: onChange
177
+ })), getByRole = _render5.getByRole;
178
+ input = getByRole("textbox");
179
+
180
+ _userEvent["default"].click(input);
181
+
182
+ _context2.next = 6;
183
+ return _userEvent["default"].keyboard("10");
184
+
185
+ case 6:
186
+ _context2.next = 8;
187
+ return _userEvent["default"].keyboard("/");
188
+
189
+ case 8:
190
+ _context2.next = 10;
191
+ return _userEvent["default"].keyboard("90");
192
+
193
+ case 10:
194
+ _context2.next = 12;
195
+ return _userEvent["default"].keyboard("/");
196
+
197
+ case 12:
198
+ _context2.next = 14;
199
+ return _userEvent["default"].keyboard("2010");
200
+
201
+ case 14:
202
+ expect(onChange).toHaveBeenCalledTimes(10);
203
+ expect(onChange).toHaveBeenCalledWith({
204
+ value: "10/90/2010",
205
+ error: "Invalid date."
206
+ });
207
+
208
+ case 16:
209
+ case "end":
210
+ return _context2.stop();
211
+ }
212
+ }
213
+ }, _callee2);
214
+ })));
215
+ test("Calendar renders with correct date: today's date", function () {
216
+ var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], null)),
217
+ getByText = _render6.getByText,
218
+ getByRole = _render6.getByRole,
219
+ getAllByText = _render6.getAllByText;
220
+
221
+ var calendarAction = getByRole("combobox");
222
+ var d = (0, _dayjs["default"])();
223
+
224
+ _userEvent["default"].click(calendarAction);
225
+
226
+ expect(getAllByText(d.get("date"))[0].getAttribute("aria-selected")).toBeTruthy();
227
+ expect(getByText(d.format("MMMM YYYY"))).toBeTruthy();
228
+ });
229
+ test("Calendar renders with correct date: value prop", function () {
230
+ var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
231
+ value: "20-10-2019"
232
+ })),
233
+ getByText = _render7.getByText,
234
+ getByRole = _render7.getByRole,
235
+ getAllByText = _render7.getAllByText;
236
+
237
+ var calendarAction = getByRole("combobox");
238
+ var d = (0, _dayjs["default"])("2019-10-20");
239
+
240
+ _userEvent["default"].click(calendarAction);
241
+
242
+ expect(getAllByText(d.get("date"))[0].getAttribute("aria-selected")).toBeTruthy();
243
+ expect(getByText(d.format("MMMM YYYY"))).toBeTruthy();
244
+ });
245
+ test("Calendar renders with correct date: user typed value", function () {
246
+ var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], null)),
247
+ getByText = _render8.getByText,
248
+ getByRole = _render8.getByRole,
249
+ getAllByText = _render8.getAllByText;
250
+
251
+ var calendarAction = getByRole("combobox");
252
+ var d = (0, _dayjs["default"])("2010-1-1");
253
+ var input = getByRole("textbox");
254
+
255
+ _userEvent["default"].type(input, "01-01-2010");
256
+
257
+ _userEvent["default"].click(calendarAction);
258
+
259
+ expect(getAllByText(d.get("date"))[0].getAttribute("aria-selected")).toBeTruthy();
260
+ expect(getByText(d.format("MMMM YYYY"))).toBeTruthy();
261
+ });
262
+ test("Calendar renders with correct date: invalid date, renders with today's date", function () {
263
+ var onBlur = jest.fn();
264
+
265
+ var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
266
+ onBlur: onBlur
267
+ })),
268
+ getByText = _render9.getByText,
269
+ getByRole = _render9.getByRole,
270
+ getAllByText = _render9.getAllByText;
271
+
272
+ var calendarAction = getByRole("combobox");
273
+ var d = (0, _dayjs["default"])();
274
+ var input = getByRole("textbox");
275
+
276
+ _userEvent["default"].type(input, "01-01-xxxx");
277
+
278
+ _react2.fireEvent.blur(input);
279
+
280
+ expect(onBlur).toHaveBeenCalled();
281
+ expect(onBlur).toHaveBeenCalledWith({
282
+ value: "01-01-xxxx",
283
+ error: "Invalid date."
284
+ });
285
+
286
+ _userEvent["default"].click(calendarAction);
287
+
288
+ expect(getAllByText(d.get("date"))[0].getAttribute("aria-selected")).toBeTruthy();
289
+ expect(getByText(d.format("MMMM YYYY"))).toBeTruthy();
290
+ });
291
+ test("Selecting a date from the calendar with an specific format", function () {
292
+ var _render10 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
293
+ label: "With format M-dd-yyyy",
294
+ format: "M-dd-yyyy"
295
+ })),
296
+ getAllByText = _render10.getAllByText,
297
+ getByText = _render10.getByText,
298
+ getByRole = _render10.getByRole;
299
+
300
+ var input = getByRole("textbox");
301
+ var calendarAction = getByRole("combobox");
302
+
303
+ _userEvent["default"].click(calendarAction);
304
+
305
+ var dayButton = getAllByText("10")[0].closest("button");
306
+
307
+ _react2.fireEvent.click(dayButton);
308
+
309
+ var d = (0, _dayjs["default"])();
310
+ d = d.set("date", 10);
311
+ expect(getAllByText(d.get("date"))[0].getAttribute("aria-selected")).toBeTruthy();
312
+ expect(getByText(d.format("MMMM YYYY"))).toBeTruthy();
313
+
314
+ _react2.fireEvent.keyDown(document, {
315
+ key: "Escape",
316
+ code: "Escape",
317
+ keyCode: 27,
318
+ charCode: 27
319
+ });
320
+
321
+ expect(input.value).toBe(d.format("M-DD-YYYY"));
322
+ });
323
+ test("Selecting a date from the calendar from another month", function () {
324
+ var _render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
325
+ format: "dd-mm-yyyy",
326
+ defaultValue: "10-08-2021"
327
+ })),
328
+ getAllByText = _render11.getAllByText,
329
+ getByText = _render11.getByText,
330
+ getByRole = _render11.getByRole;
331
+
332
+ var input = getByRole("textbox");
333
+ var calendarAction = getByRole("combobox");
334
+
335
+ _userEvent["default"].click(calendarAction);
336
+
337
+ var dayButton = getAllByText("31")[0].closest("button");
338
+
339
+ _react2.fireEvent.click(dayButton);
340
+
341
+ var d = (0, _dayjs["default"])("10-08-2021", "DD-MM-YYYY", true);
342
+ d = d.set("date", 31).set("month", 6);
343
+ expect(getAllByText(d.get("date"))[0].getAttribute("aria-selected")).toBeTruthy();
344
+ expect(getByText(d.format("MMMM YYYY"))).toBeTruthy();
345
+
346
+ _react2.fireEvent.keyDown(document, {
347
+ key: "Escape",
348
+ code: "Escape",
349
+ keyCode: 27,
350
+ charCode: 27
351
+ });
352
+
353
+ expect(input.value).toBe(d.format("DD-MM-YYYY"));
354
+ });
355
+ test("Selecting a year from the calendar year picker", function () {
356
+ var _render12 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
357
+ format: "dd-mm-yyyy",
358
+ defaultValue: "10-08-2021"
359
+ })),
360
+ getByText = _render12.getByText,
361
+ getByRole = _render12.getByRole;
362
+
363
+ var input = getByRole("textbox");
364
+ var calendarAction = getByRole("combobox");
365
+
366
+ _userEvent["default"].click(calendarAction);
367
+
368
+ var d = (0, _dayjs["default"])("10-08-2021", "DD-MM-YYYY", true);
369
+
370
+ _userEvent["default"].click(getByText(d.format("MMMM YYYY")));
371
+
372
+ expect(getByText("2024")).toBeTruthy();
373
+
374
+ _userEvent["default"].click(getByText("2024"));
375
+
376
+ _userEvent["default"].click(getByText(d.set("year", 2024).format("MMMM YYYY")));
377
+
378
+ _react2.fireEvent.keyDown(document, {
379
+ key: "Escape",
380
+ code: "Escape",
381
+ keyCode: 27,
382
+ charCode: 27
383
+ });
384
+
385
+ expect(input.value).toBe(d.format("DD-MM-YYYY"));
386
+ });
387
+ test("Selecting a date from the calendar (using keyboard presses)", function () {
388
+ var _render13 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], null)),
389
+ getByRole = _render13.getByRole,
390
+ getAllByText = _render13.getAllByText,
391
+ getByText = _render13.getByText;
392
+
393
+ var calendarAction = getByRole("combobox");
394
+ var input = getByRole("textbox");
395
+
396
+ _userEvent["default"].type(input, "01-01-2010");
397
+
398
+ expect(input.value).toBe("01-01-2010");
399
+
400
+ _userEvent["default"].click(calendarAction);
401
+
402
+ expect(document.activeElement === getAllByText("1")[0].closest("button")).toBeTruthy();
403
+
404
+ _react2.fireEvent.keyDown(getAllByText("1")[0].closest("button"), {
405
+ key: "ArrowRight",
406
+ code: "ArrowRight",
407
+ keyCode: 39,
408
+ charCode: 39
409
+ });
410
+
411
+ expect(document.activeElement === getAllByText("2")[0].closest("button")).toBeTruthy();
412
+
413
+ _react2.fireEvent.keyDown(getAllByText("2")[0].closest("button"), {
414
+ key: "PageUp",
415
+ code: "PageUp",
416
+ keyCode: 33,
417
+ charCode: 33
418
+ });
419
+
420
+ expect(document.activeElement === getAllByText("2")[0].closest("button")).toBeTruthy();
421
+ expect(getByText("December 2009")).toBeTruthy();
422
+
423
+ _react2.fireEvent.keyDown(getAllByText("2")[0].closest("button"), {
424
+ key: "PageDown",
425
+ code: "PageDown",
426
+ keyCode: 34,
427
+ charCode: 34
428
+ });
429
+
430
+ expect(document.activeElement === getAllByText("2")[0].closest("button")).toBeTruthy();
431
+ expect(getByText("January 2010")).toBeTruthy();
432
+
433
+ _react2.fireEvent.keyDown(getAllByText("2")[0].closest("button"), {
434
+ key: "PageDown",
435
+ code: "PageDown",
436
+ keyCode: 34,
437
+ charCode: 34,
438
+ shiftKey: true
439
+ });
440
+
441
+ expect(getByText("January 2011")).toBeTruthy();
442
+
443
+ _react2.fireEvent.keyDown(getAllByText("2")[0].closest("button"), {
444
+ key: "PageUp",
445
+ code: "PageUp",
446
+ keyCode: 33,
447
+ charCode: 33,
448
+ shiftKey: true
449
+ });
450
+
451
+ expect(getByText("January 2010")).toBeTruthy();
452
+ expect(document.activeElement === getAllByText("2")[0].closest("button")).toBeTruthy();
453
+
454
+ _react2.fireEvent.click(getAllByText("2")[0].closest("button"), {
455
+ key: " ",
456
+ code: "Space",
457
+ keyCode: 32,
458
+ charCode: 32
459
+ });
460
+
461
+ expect(getAllByText("2")[0].closest("button").getAttribute("aria-selected")).toBeTruthy();
462
+
463
+ _react2.fireEvent.keyDown(document, {
464
+ key: "Escape",
465
+ code: "Escape",
466
+ keyCode: 27,
467
+ charCode: 27
468
+ });
469
+
470
+ expect(input.value).toBe("02-01-2010");
471
+ });
472
+ test("Selecting a date from the calendar (using keyboard presses) part II", function () {
473
+ var _render14 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], null)),
474
+ getByRole = _render14.getByRole,
475
+ getAllByText = _render14.getAllByText;
476
+
477
+ var calendarAction = getByRole("combobox");
478
+ var input = getByRole("textbox");
479
+
480
+ _userEvent["default"].type(input, "01-01-2010");
481
+
482
+ expect(input.value).toBe("01-01-2010");
483
+
484
+ _userEvent["default"].click(calendarAction);
485
+
486
+ expect(document.activeElement === getAllByText("1")[0].closest("button")).toBeTruthy();
487
+
488
+ _react2.fireEvent.keyDown(getAllByText("1")[0].closest("button"), {
489
+ key: "ArrowDown",
490
+ code: "ArrowDown",
491
+ keyCode: 40,
492
+ charCode: 40
493
+ });
494
+
495
+ expect(document.activeElement === getAllByText("8")[0].closest("button")).toBeTruthy();
496
+
497
+ _react2.fireEvent.keyDown(getAllByText("8")[0].closest("button"), {
498
+ key: "ArrowDown",
499
+ code: "ArrowDown",
500
+ keyCode: 40,
501
+ charCode: 40
502
+ });
503
+
504
+ expect(document.activeElement === getAllByText("15")[0].closest("button")).toBeTruthy();
505
+
506
+ _react2.fireEvent.keyDown(getAllByText("15")[0].closest("button"), {
507
+ key: "ArrowUp",
508
+ code: "ArrowUp",
509
+ keyCode: 38,
510
+ charCode: 38
511
+ });
512
+
513
+ expect(document.activeElement === getAllByText("8")[0].closest("button")).toBeTruthy();
514
+
515
+ _react2.fireEvent.keyDown(getAllByText("8")[0].closest("button"), {
516
+ key: "End",
517
+ code: "End",
518
+ keyCode: 35,
519
+ charCode: 35
520
+ });
521
+
522
+ expect(document.activeElement === getAllByText("10")[0].closest("button")).toBeTruthy();
523
+
524
+ _react2.fireEvent.keyDown(getAllByText("10")[0].closest("button"), {
525
+ key: "Home",
526
+ code: "Home",
527
+ keyCode: 36,
528
+ charCode: 36
529
+ });
530
+
531
+ _react2.fireEvent.keyDown(getAllByText("10")[0].closest("button"), {
532
+ key: " ",
533
+ code: "Space",
534
+ keyCode: 32,
535
+ charCode: 32
536
+ });
537
+
538
+ expect(input.value).toBe("10-01-2010");
539
+ });
540
+ test("onChange & onBlur functions are called correctly", function () {
541
+ var onBlur = jest.fn();
542
+ var onChange = jest.fn();
543
+
544
+ var _render15 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
545
+ onChange: onChange,
546
+ onBlur: onBlur
547
+ })),
548
+ getByRole = _render15.getByRole;
549
+
550
+ var input = getByRole("textbox");
551
+ var d = new Date(2011, 9, 10);
552
+
553
+ _userEvent["default"].type(input, "10-10-2011");
554
+
555
+ expect(input.value).toBe("10-10-2011");
556
+ expect(onChange).toHaveBeenCalledTimes(10);
557
+ expect(onChange).toHaveBeenCalledWith({
558
+ value: "10-10-2011",
559
+ date: d
560
+ });
561
+
562
+ _react2.fireEvent.blur(input);
563
+
564
+ expect(onBlur).toHaveBeenCalled();
565
+ expect(onBlur).toHaveBeenCalledWith({
566
+ value: "10-10-2011",
567
+ date: d
568
+ });
569
+ });
570
+ test("onChange & onBlur functions are called correctly, also with errors", function () {
571
+ var onBlur = jest.fn();
572
+ var onChange = jest.fn();
573
+
574
+ var _render16 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
575
+ onChange: onChange,
576
+ onBlur: onBlur
577
+ })),
578
+ getByRole = _render16.getByRole;
579
+
580
+ var input = getByRole("textbox");
581
+
582
+ _userEvent["default"].type(input, "10-10-");
583
+
584
+ expect(input.value).toBe("10-10-");
585
+ expect(onChange).toHaveBeenCalledTimes(6);
586
+ expect(onChange).toHaveBeenCalledWith({
587
+ value: "10-10-",
588
+ error: "Invalid date."
589
+ });
590
+
591
+ _react2.fireEvent.blur(input);
592
+
593
+ expect(onBlur).toHaveBeenCalled();
594
+ expect(onBlur).toHaveBeenCalledWith({
595
+ value: "10-10-",
596
+ error: "Invalid date."
597
+ });
598
+ });
599
+ test("onBlur function removes the error when it is fixed", function () {
600
+ var onBlur = jest.fn();
601
+
602
+ var _render17 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
603
+ onBlur: onBlur
604
+ })),
605
+ getByRole = _render17.getByRole;
606
+
607
+ var input = getByRole("textbox");
608
+ var d = new Date(2002, 1, 20);
609
+
610
+ _userEvent["default"].type(input, "test");
611
+
612
+ expect(input.value).toBe("test");
613
+
614
+ _react2.fireEvent.blur(input);
615
+
616
+ expect(onBlur).toHaveBeenCalled();
617
+ expect(onBlur).toHaveBeenCalledWith({
618
+ value: "test",
619
+ error: "Invalid date."
620
+ });
621
+
622
+ _userEvent["default"].clear(input);
623
+
624
+ _userEvent["default"].type(input, "20-02-2002");
625
+
626
+ expect(input.value).toBe("20-02-2002");
627
+
628
+ _react2.fireEvent.blur(input);
629
+
630
+ expect(onBlur).toHaveBeenCalled();
631
+ expect(onBlur).toHaveBeenCalledWith({
632
+ value: "20-02-2002",
633
+ date: d
634
+ });
635
+ });
636
+ test("onBlur function removes the error when the input is empty", function () {
637
+ var onBlur = jest.fn();
638
+
639
+ var _render18 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
640
+ onBlur: onBlur,
641
+ optional: true
642
+ })),
643
+ getByRole = _render18.getByRole;
644
+
645
+ var input = getByRole("textbox");
646
+
647
+ _userEvent["default"].type(input, "test");
648
+
649
+ expect(input.value).toBe("test");
650
+
651
+ _react2.fireEvent.blur(input);
652
+
653
+ expect(onBlur).toHaveBeenCalled();
654
+ expect(onBlur).toHaveBeenCalledWith({
655
+ value: "test",
656
+ error: "Invalid date."
657
+ });
658
+
659
+ _userEvent["default"].clear(input);
660
+
661
+ _react2.fireEvent.blur(input);
662
+
663
+ expect(onBlur).toHaveBeenCalled();
664
+ expect(onBlur).toHaveBeenCalledWith({
665
+ value: ""
666
+ });
667
+ });
668
+ test("onBlur & onChange functions error: required field (not optional)", function () {
669
+ var onBlur = jest.fn();
670
+ var onChange = jest.fn();
671
+
672
+ var _render19 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
673
+ onBlur: onBlur,
674
+ onChange: onChange
675
+ })),
676
+ getByRole = _render19.getByRole;
677
+
678
+ var date = getByRole("textbox");
679
+
680
+ _userEvent["default"].type(date, "t");
681
+
682
+ expect(date.value).toBe("t");
683
+
684
+ _userEvent["default"].clear(date);
685
+
686
+ _react2.fireEvent.blur(date);
687
+
688
+ expect(onBlur).toHaveBeenCalled();
689
+ expect(onBlur).toHaveBeenCalledWith({
690
+ value: "",
691
+ error: "This field is required. Please, enter a value."
692
+ });
693
+ expect(onChange).toHaveBeenCalled();
694
+ expect(onChange).toHaveBeenCalledWith({
695
+ value: "",
696
+ error: "This field is required. Please, enter a value."
697
+ });
698
+ });
699
+ test("Disabled date input (calendar action must be shown but not clickable)", function () {
700
+ var _render20 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
701
+ disabled: true
702
+ })),
703
+ getByRole = _render20.getByRole,
704
+ queryByText = _render20.queryByText;
705
+
706
+ var calendarAction = getByRole("button");
707
+ var d = new Date();
708
+ var options = {
709
+ weekday: "short",
710
+ month: "short",
711
+ day: "numeric"
712
+ };
713
+ expect(getByRole("textbox").disabled).toBeTruthy();
714
+
715
+ _userEvent["default"].click(calendarAction);
716
+
717
+ expect(queryByText(d.toLocaleString("en-US", options))).toBeFalsy();
718
+ });
719
+ test("Input has correct accesibility attributes", function () {
720
+ var _render21 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_DateInput["default"], {
721
+ label: "Date input label"
722
+ })),
723
+ getByRole = _render21.getByRole;
724
+
725
+ var input = getByRole("textbox");
726
+ expect(input.getAttribute("aria-autocomplete")).toBeNull();
727
+ expect(input.getAttribute("aria-controls")).toBeNull();
728
+ expect(input.getAttribute("aria-expanded")).toBeNull();
729
+ var calendarAction = getByRole("combobox");
730
+ expect(calendarAction.getAttribute("aria-autocomplete")).toBeNull();
731
+ expect(calendarAction.getAttribute("aria-controls")).toBeTruthy();
732
+ expect(calendarAction.getAttribute("aria-describedby")).toBeTruthy();
733
+ expect(calendarAction.getAttribute("aria-describedby") === calendarAction.getAttribute("aria-controls")).toBeTruthy();
734
+ expect(calendarAction.getAttribute("aria-expanded")).toBe("false");
735
+
736
+ _userEvent["default"].click(calendarAction);
737
+
738
+ var datePicker = getByRole("dialog");
739
+ expect(datePicker.getAttribute("aria-modal")).toBe("true");
740
+ expect(calendarAction.getAttribute("aria-expanded")).toBe("true");
741
+ expect(document.getElementById(calendarAction.getAttribute("aria-describedby"))).toBeTruthy();
742
+
743
+ _react2.fireEvent.keyDown(document, {
744
+ key: "Escape",
745
+ code: "Escape",
746
+ keyCode: 27,
747
+ charCode: 27
748
+ });
749
+
750
+ expect(calendarAction.getAttribute("aria-expanded")).toBe("false");
751
+ });
752
+ });