@dxc-technology/halstack-react 0.0.0-c291a0c → 0.0.0-c2b6ec9

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