@dxc-technology/halstack-react 0.0.0-e1386cf → 0.0.0-e19ca5f

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 (385) 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 +122 -106
  5. package/README.md +47 -0
  6. package/accordion/Accordion.accessibility.test.js +71 -0
  7. package/accordion/Accordion.d.ts +1 -1
  8. package/accordion/Accordion.js +44 -118
  9. package/accordion/Accordion.stories.tsx +82 -147
  10. package/accordion/Accordion.test.js +19 -34
  11. package/accordion/types.d.ts +6 -18
  12. package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
  13. package/accordion-group/AccordionGroup.d.ts +2 -2
  14. package/accordion-group/AccordionGroup.js +29 -77
  15. package/accordion-group/AccordionGroup.stories.tsx +78 -77
  16. package/accordion-group/AccordionGroup.test.js +44 -72
  17. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  18. package/accordion-group/AccordionGroupAccordion.js +31 -0
  19. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  20. package/accordion-group/AccordionGroupContext.js +8 -0
  21. package/accordion-group/types.d.ts +7 -19
  22. package/action-icon/ActionIcon.accessibility.test.js +63 -0
  23. package/action-icon/ActionIcon.d.ts +4 -0
  24. package/action-icon/ActionIcon.js +48 -0
  25. package/action-icon/ActionIcon.stories.tsx +41 -0
  26. package/action-icon/ActionIcon.test.js +64 -0
  27. package/action-icon/types.d.ts +26 -0
  28. package/alert/Alert.accessibility.test.js +95 -0
  29. package/alert/Alert.js +36 -126
  30. package/alert/Alert.stories.tsx +28 -0
  31. package/alert/Alert.test.js +29 -46
  32. package/alert/types.d.ts +5 -5
  33. package/badge/Badge.accessibility.test.js +129 -0
  34. package/badge/Badge.d.ts +1 -1
  35. package/badge/Badge.js +142 -42
  36. package/badge/Badge.stories.tsx +210 -0
  37. package/badge/Badge.test.js +30 -0
  38. package/badge/types.d.ts +52 -3
  39. package/bleed/Bleed.js +13 -21
  40. package/bleed/Bleed.stories.tsx +1 -0
  41. package/bleed/types.d.ts +2 -2
  42. package/box/Box.accessibility.test.js +33 -0
  43. package/box/Box.d.ts +1 -1
  44. package/box/Box.js +18 -59
  45. package/box/Box.stories.tsx +38 -51
  46. package/box/Box.test.js +2 -7
  47. package/box/types.d.ts +3 -15
  48. package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
  49. package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
  50. package/breadcrumbs/Breadcrumbs.d.ts +4 -0
  51. package/breadcrumbs/Breadcrumbs.js +79 -0
  52. package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
  53. package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
  54. package/breadcrumbs/Breadcrumbs.test.js +169 -0
  55. package/breadcrumbs/Item.d.ts +4 -0
  56. package/breadcrumbs/Item.js +52 -0
  57. package/breadcrumbs/dropdownTheme.d.ts +53 -0
  58. package/breadcrumbs/dropdownTheme.js +62 -0
  59. package/breadcrumbs/types.d.ts +16 -0
  60. package/bulleted-list/BulletedList.accessibility.test.js +119 -0
  61. package/bulleted-list/BulletedList.js +22 -53
  62. package/bulleted-list/BulletedList.stories.tsx +8 -93
  63. package/bulleted-list/types.d.ts +32 -5
  64. package/button/Button.accessibility.test.js +127 -0
  65. package/button/Button.d.ts +1 -1
  66. package/button/Button.js +71 -106
  67. package/button/Button.stories.tsx +143 -101
  68. package/button/Button.test.js +20 -17
  69. package/button/types.d.ts +9 -5
  70. package/card/Card.accessibility.test.js +36 -0
  71. package/card/Card.d.ts +1 -1
  72. package/card/Card.js +49 -89
  73. package/card/Card.stories.tsx +12 -42
  74. package/card/Card.test.js +11 -22
  75. package/card/types.d.ts +6 -12
  76. package/checkbox/Checkbox.accessibility.test.js +87 -0
  77. package/checkbox/Checkbox.js +90 -125
  78. package/checkbox/Checkbox.stories.tsx +68 -54
  79. package/checkbox/Checkbox.test.js +108 -64
  80. package/checkbox/types.d.ts +8 -4
  81. package/chip/Chip.accessibility.test.js +67 -0
  82. package/chip/Chip.js +45 -80
  83. package/chip/Chip.stories.tsx +107 -27
  84. package/chip/Chip.test.js +18 -33
  85. package/chip/types.d.ts +4 -4
  86. package/common/coreTokens.d.ts +237 -0
  87. package/common/coreTokens.js +184 -0
  88. package/common/utils.d.ts +1 -0
  89. package/common/utils.js +6 -12
  90. package/common/variables.d.ts +1392 -0
  91. package/common/variables.js +969 -1213
  92. package/container/Container.d.ts +4 -0
  93. package/container/Container.js +194 -0
  94. package/container/Container.stories.tsx +214 -0
  95. package/container/types.d.ts +74 -0
  96. package/contextual-menu/ContextualMenu.accessibility.test.js +97 -0
  97. package/contextual-menu/ContextualMenu.d.ts +5 -0
  98. package/contextual-menu/ContextualMenu.js +88 -0
  99. package/contextual-menu/ContextualMenu.stories.tsx +232 -0
  100. package/contextual-menu/ContextualMenu.test.js +205 -0
  101. package/contextual-menu/GroupItem.d.ts +4 -0
  102. package/contextual-menu/GroupItem.js +67 -0
  103. package/contextual-menu/ItemAction.d.ts +4 -0
  104. package/contextual-menu/ItemAction.js +51 -0
  105. package/contextual-menu/MenuItem.d.ts +4 -0
  106. package/contextual-menu/MenuItem.js +29 -0
  107. package/contextual-menu/SingleItem.d.ts +4 -0
  108. package/contextual-menu/SingleItem.js +38 -0
  109. package/contextual-menu/types.d.ts +58 -0
  110. package/contextual-menu/types.js +5 -0
  111. package/date-input/Calendar.d.ts +4 -0
  112. package/date-input/Calendar.js +214 -0
  113. package/date-input/DateInput.accessibility.test.js +228 -0
  114. package/date-input/DateInput.js +149 -299
  115. package/date-input/DateInput.stories.tsx +210 -56
  116. package/date-input/DateInput.test.js +694 -429
  117. package/date-input/DatePicker.d.ts +4 -0
  118. package/date-input/DatePicker.js +121 -0
  119. package/date-input/YearPicker.d.ts +4 -0
  120. package/date-input/YearPicker.js +100 -0
  121. package/date-input/types.d.ts +72 -15
  122. package/dialog/Dialog.accessibility.test.js +69 -0
  123. package/dialog/Dialog.d.ts +1 -1
  124. package/dialog/Dialog.js +51 -120
  125. package/dialog/Dialog.stories.tsx +316 -212
  126. package/dialog/Dialog.test.js +270 -33
  127. package/dialog/types.d.ts +18 -26
  128. package/divider/Divider.accessibility.test.js +33 -0
  129. package/divider/Divider.d.ts +4 -0
  130. package/divider/Divider.js +36 -0
  131. package/divider/Divider.stories.tsx +223 -0
  132. package/divider/Divider.test.js +38 -0
  133. package/divider/types.d.ts +21 -0
  134. package/divider/types.js +5 -0
  135. package/dropdown/Dropdown.accessibility.test.js +180 -0
  136. package/dropdown/Dropdown.js +66 -136
  137. package/dropdown/Dropdown.stories.tsx +209 -94
  138. package/dropdown/Dropdown.test.js +404 -390
  139. package/dropdown/DropdownMenu.js +23 -40
  140. package/dropdown/DropdownMenuItem.js +17 -38
  141. package/dropdown/types.d.ts +20 -24
  142. package/file-input/FileInput.accessibility.test.js +160 -0
  143. package/file-input/FileInput.js +184 -292
  144. package/file-input/FileInput.stories.tsx +86 -3
  145. package/file-input/FileInput.test.js +279 -395
  146. package/file-input/FileItem.js +31 -67
  147. package/file-input/types.d.ts +10 -10
  148. package/flex/Flex.js +27 -39
  149. package/flex/Flex.stories.tsx +35 -26
  150. package/flex/types.d.ts +74 -9
  151. package/footer/Footer.accessibility.test.js +125 -0
  152. package/footer/Footer.d.ts +1 -1
  153. package/footer/Footer.js +73 -118
  154. package/footer/Footer.stories.tsx +94 -23
  155. package/footer/Footer.test.js +33 -57
  156. package/footer/Icons.d.ts +3 -2
  157. package/footer/Icons.js +53 -22
  158. package/footer/types.d.ts +26 -28
  159. package/grid/Grid.d.ts +7 -0
  160. package/grid/Grid.js +76 -0
  161. package/grid/Grid.stories.tsx +219 -0
  162. package/grid/types.d.ts +115 -0
  163. package/grid/types.js +5 -0
  164. package/header/Header.accessibility.test.js +93 -0
  165. package/header/Header.d.ts +4 -3
  166. package/header/Header.js +55 -150
  167. package/header/Header.stories.tsx +130 -35
  168. package/header/Header.test.js +13 -26
  169. package/header/Icons.d.ts +2 -2
  170. package/header/Icons.js +3 -13
  171. package/header/types.d.ts +7 -22
  172. package/heading/Heading.accessibility.test.js +33 -0
  173. package/heading/Heading.js +10 -32
  174. package/heading/Heading.test.js +71 -88
  175. package/heading/types.d.ts +7 -7
  176. package/icon/Icon.accessibility.test.js +30 -0
  177. package/icon/Icon.d.ts +4 -0
  178. package/icon/Icon.js +33 -0
  179. package/icon/Icon.stories.tsx +28 -0
  180. package/icon/types.d.ts +4 -0
  181. package/icon/types.js +5 -0
  182. package/image/Image.accessibility.test.js +56 -0
  183. package/image/Image.d.ts +4 -0
  184. package/image/Image.js +70 -0
  185. package/image/Image.stories.tsx +129 -0
  186. package/image/types.d.ts +72 -0
  187. package/image/types.js +5 -0
  188. package/inset/Inset.js +13 -21
  189. package/inset/Inset.stories.tsx +2 -1
  190. package/inset/types.d.ts +2 -2
  191. package/layout/ApplicationLayout.d.ts +5 -5
  192. package/layout/ApplicationLayout.js +36 -70
  193. package/layout/ApplicationLayout.stories.tsx +1 -1
  194. package/layout/Icons.d.ts +7 -5
  195. package/layout/Icons.js +41 -59
  196. package/layout/types.d.ts +5 -6
  197. package/link/Link.accessibility.test.js +108 -0
  198. package/link/Link.js +31 -50
  199. package/link/Link.stories.tsx +64 -4
  200. package/link/Link.test.js +24 -44
  201. package/link/types.d.ts +14 -14
  202. package/main.d.ts +11 -5
  203. package/main.js +54 -59
  204. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  205. package/nav-tabs/NavTabs.d.ts +7 -0
  206. package/{tabs-nav → nav-tabs}/NavTabs.js +25 -57
  207. package/nav-tabs/NavTabs.stories.tsx +279 -0
  208. package/nav-tabs/NavTabs.test.js +77 -0
  209. package/nav-tabs/NavTabsContext.d.ts +3 -0
  210. package/nav-tabs/NavTabsContext.js +8 -0
  211. package/nav-tabs/Tab.js +117 -0
  212. package/{tabs-nav → nav-tabs}/types.d.ts +15 -16
  213. package/nav-tabs/types.js +5 -0
  214. package/number-input/NumberInput.accessibility.test.js +228 -0
  215. package/number-input/NumberInput.js +46 -36
  216. package/number-input/NumberInput.stories.tsx +42 -26
  217. package/number-input/NumberInput.test.js +860 -413
  218. package/number-input/NumberInputContext.d.ts +3 -4
  219. package/number-input/NumberInputContext.js +3 -14
  220. package/number-input/types.d.ts +17 -5
  221. package/package.json +43 -46
  222. package/paginator/Paginator.accessibility.test.js +79 -0
  223. package/paginator/Paginator.js +34 -67
  224. package/paginator/Paginator.stories.tsx +24 -0
  225. package/paginator/Paginator.test.js +252 -225
  226. package/paginator/types.d.ts +3 -3
  227. package/paragraph/Paragraph.accessibility.test.js +28 -0
  228. package/paragraph/Paragraph.d.ts +3 -4
  229. package/paragraph/Paragraph.js +6 -22
  230. package/paragraph/Paragraph.stories.tsx +0 -17
  231. package/password-input/PasswordInput.accessibility.test.js +153 -0
  232. package/password-input/PasswordInput.js +58 -127
  233. package/password-input/PasswordInput.stories.tsx +1 -33
  234. package/password-input/PasswordInput.test.js +158 -141
  235. package/password-input/types.d.ts +8 -7
  236. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  237. package/progress-bar/ProgressBar.d.ts +2 -2
  238. package/progress-bar/ProgressBar.js +28 -58
  239. package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +36 -3
  240. package/progress-bar/ProgressBar.test.js +36 -53
  241. package/progress-bar/types.d.ts +4 -3
  242. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  243. package/quick-nav/QuickNav.js +4 -27
  244. package/quick-nav/QuickNav.stories.tsx +15 -1
  245. package/quick-nav/types.d.ts +10 -10
  246. package/radio-group/Radio.d.ts +1 -1
  247. package/radio-group/Radio.js +31 -63
  248. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  249. package/radio-group/RadioGroup.js +46 -93
  250. package/radio-group/RadioGroup.stories.tsx +131 -18
  251. package/radio-group/RadioGroup.test.js +505 -471
  252. package/radio-group/types.d.ts +8 -8
  253. package/resultset-table/Icons.d.ts +7 -0
  254. package/{text-input → resultset-table}/Icons.js +13 -26
  255. package/resultset-table/ResultsetTable.accessibility.test.js +285 -0
  256. package/resultset-table/ResultsetTable.d.ts +7 -0
  257. package/resultset-table/ResultsetTable.js +171 -0
  258. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +168 -30
  259. package/resultset-table/ResultsetTable.test.js +381 -0
  260. package/{resultsetTable → resultset-table}/types.d.ts +44 -11
  261. package/resultset-table/types.js +5 -0
  262. package/select/Listbox.d.ts +1 -1
  263. package/select/Listbox.js +43 -86
  264. package/select/Option.js +35 -56
  265. package/select/Select.accessibility.test.js +228 -0
  266. package/select/Select.js +140 -183
  267. package/select/Select.stories.tsx +496 -204
  268. package/select/Select.test.js +1949 -1917
  269. package/select/types.d.ts +17 -18
  270. package/sidenav/Sidenav.accessibility.test.js +59 -0
  271. package/sidenav/Sidenav.d.ts +2 -2
  272. package/sidenav/Sidenav.js +90 -157
  273. package/sidenav/Sidenav.stories.tsx +160 -63
  274. package/sidenav/Sidenav.test.js +3 -10
  275. package/{layout → sidenav}/SidenavContext.d.ts +1 -1
  276. package/{layout → sidenav}/SidenavContext.js +3 -9
  277. package/sidenav/types.d.ts +33 -30
  278. package/slider/Slider.accessibility.test.js +104 -0
  279. package/slider/Slider.js +75 -132
  280. package/slider/Slider.test.js +108 -104
  281. package/slider/types.d.ts +4 -4
  282. package/spinner/Spinner.accessibility.test.js +96 -0
  283. package/spinner/Spinner.js +34 -74
  284. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
  285. package/spinner/Spinner.test.js +26 -35
  286. package/spinner/types.d.ts +3 -3
  287. package/status-light/StatusLight.accessibility.test.js +157 -0
  288. package/status-light/StatusLight.d.ts +4 -0
  289. package/status-light/StatusLight.js +51 -0
  290. package/status-light/StatusLight.stories.tsx +74 -0
  291. package/status-light/StatusLight.test.js +25 -0
  292. package/status-light/types.d.ts +17 -0
  293. package/status-light/types.js +5 -0
  294. package/switch/Switch.accessibility.test.js +98 -0
  295. package/switch/Switch.js +52 -100
  296. package/switch/Switch.stories.tsx +45 -34
  297. package/switch/Switch.test.js +52 -97
  298. package/switch/types.d.ts +4 -4
  299. package/table/DropdownTheme.js +62 -0
  300. package/table/Table.accessibility.test.js +93 -0
  301. package/table/Table.d.ts +6 -2
  302. package/table/Table.js +78 -35
  303. package/table/Table.stories.tsx +663 -0
  304. package/table/Table.test.js +94 -7
  305. package/table/types.d.ts +34 -6
  306. package/tabs/Tab.js +28 -46
  307. package/tabs/Tabs.accessibility.test.js +56 -0
  308. package/tabs/Tabs.js +69 -163
  309. package/tabs/Tabs.stories.tsx +50 -6
  310. package/tabs/Tabs.test.js +61 -136
  311. package/tabs/types.d.ts +21 -21
  312. package/tag/Tag.accessibility.test.js +69 -0
  313. package/tag/Tag.js +34 -66
  314. package/tag/Tag.stories.tsx +18 -8
  315. package/tag/Tag.test.js +18 -37
  316. package/tag/types.d.ts +9 -9
  317. package/text-input/Suggestion.js +35 -25
  318. package/text-input/Suggestions.d.ts +1 -1
  319. package/text-input/Suggestions.js +30 -70
  320. package/text-input/TextInput.accessibility.test.js +321 -0
  321. package/text-input/TextInput.js +229 -335
  322. package/text-input/TextInput.stories.tsx +155 -162
  323. package/text-input/TextInput.test.js +1289 -1157
  324. package/text-input/types.d.ts +25 -17
  325. package/textarea/Textarea.accessibility.test.js +155 -0
  326. package/textarea/Textarea.js +71 -113
  327. package/textarea/Textarea.stories.tsx +174 -0
  328. package/textarea/Textarea.test.js +152 -183
  329. package/textarea/types.d.ts +9 -5
  330. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  331. package/toggle-group/ToggleGroup.d.ts +2 -2
  332. package/toggle-group/ToggleGroup.js +94 -107
  333. package/toggle-group/ToggleGroup.stories.tsx +52 -7
  334. package/toggle-group/ToggleGroup.test.js +69 -88
  335. package/toggle-group/types.d.ts +28 -19
  336. package/typography/Typography.accessibility.test.js +339 -0
  337. package/typography/Typography.d.ts +2 -2
  338. package/typography/Typography.js +15 -123
  339. package/typography/Typography.stories.tsx +1 -1
  340. package/typography/types.d.ts +1 -1
  341. package/useTheme.d.ts +1144 -1
  342. package/useTheme.js +2 -9
  343. package/useTranslatedLabels.d.ts +84 -1
  344. package/useTranslatedLabels.js +1 -7
  345. package/utils/BaseTypography.d.ts +21 -0
  346. package/utils/BaseTypography.js +94 -0
  347. package/utils/FocusLock.d.ts +13 -0
  348. package/utils/FocusLock.js +124 -0
  349. package/wizard/Wizard.accessibility.test.js +55 -0
  350. package/wizard/Wizard.js +29 -75
  351. package/wizard/Wizard.stories.tsx +39 -0
  352. package/wizard/Wizard.test.js +54 -81
  353. package/wizard/types.d.ts +10 -11
  354. package/card/ice-cream.jpg +0 -0
  355. package/common/OpenSans.css +0 -81
  356. package/common/RequiredComponent.js +0 -32
  357. package/common/fonts/OpenSans-Bold.ttf +0 -0
  358. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  359. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  360. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  361. package/common/fonts/OpenSans-Italic.ttf +0 -0
  362. package/common/fonts/OpenSans-Light.ttf +0 -0
  363. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  364. package/common/fonts/OpenSans-Regular.ttf +0 -0
  365. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  366. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  367. package/number-input/numberInputContextTypes.d.ts +0 -19
  368. package/paginator/Icons.js +0 -66
  369. package/resultsetTable/ResultsetTable.d.ts +0 -4
  370. package/resultsetTable/ResultsetTable.js +0 -252
  371. package/resultsetTable/ResultsetTable.test.js +0 -348
  372. package/select/Icons.d.ts +0 -10
  373. package/select/Icons.js +0 -93
  374. package/slider/Slider.stories.tsx +0 -183
  375. package/table/Table.stories.jsx +0 -277
  376. package/tabs-nav/NavTabs.d.ts +0 -8
  377. package/tabs-nav/NavTabs.stories.tsx +0 -170
  378. package/tabs-nav/NavTabs.test.js +0 -82
  379. package/tabs-nav/Tab.js +0 -130
  380. package/text-input/Icons.d.ts +0 -8
  381. package/textarea/Textarea.stories.jsx +0 -157
  382. /package/{resultsetTable → action-icon}/types.js +0 -0
  383. /package/{tabs-nav → breadcrumbs}/types.js +0 -0
  384. /package/{number-input/numberInputContextTypes.js → container/types.js} +0 -0
  385. /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
@@ -1,49 +1,16 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
6
-
7
5
  var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
8
-
9
6
  var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
10
-
11
7
  var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
12
-
13
8
  var _react = _interopRequireDefault(require("react"));
14
-
15
9
  var _react2 = require("@testing-library/react");
16
-
17
10
  var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
18
-
19
- var _TextInput = _interopRequireDefault(require("./TextInput"));
20
-
11
+ var _TextInput = _interopRequireDefault(require("./TextInput.tsx"));
21
12
  // Mocking DOMRect for Radix Primitive Popover
22
13
  global.globalThis = global;
23
-
24
- global.ResizeObserver = /*#__PURE__*/function () {
25
- function ResizeObserver(cb) {
26
- (0, _classCallCheck2["default"])(this, ResizeObserver);
27
- this.cb = cb;
28
- }
29
-
30
- (0, _createClass2["default"])(ResizeObserver, [{
31
- key: "observe",
32
- value: function observe() {
33
- this.cb([{
34
- borderBoxSize: {
35
- inlineSize: 0,
36
- blockSize: 0
37
- }
38
- }]);
39
- }
40
- }, {
41
- key: "unobserve",
42
- value: function unobserve() {}
43
- }]);
44
- return ResizeObserver;
45
- }();
46
-
47
14
  global.DOMRect = {
48
15
  fromRect: function fromRect() {
49
16
  return {
@@ -56,17 +23,33 @@ global.DOMRect = {
56
23
  };
57
24
  }
58
25
  };
26
+ global.ResizeObserver = /*#__PURE__*/function () {
27
+ function ResizeObserver() {
28
+ (0, _classCallCheck2["default"])(this, ResizeObserver);
29
+ }
30
+ (0, _createClass2["default"])(ResizeObserver, [{
31
+ key: "observe",
32
+ value: function observe() {}
33
+ }, {
34
+ key: "unobserve",
35
+ value: function unobserve() {}
36
+ }, {
37
+ key: "disconnect",
38
+ value: function disconnect() {}
39
+ }]);
40
+ return ResizeObserver;
41
+ }();
59
42
  var countries = ["Afghanistan", "Albania", "Algeria", "Andorra", "Angola", "Antigua and Barbuda", "Bahamas", "Bahrain", "Bangladesh", "Barbados", "Cabo Verde", "Cambodia", "Cameroon", "Canada", "Cayman Islands, The", "Central African Republic", "Chad", "Democratic Republic of the Congo", "Dominican Republic", "Dominica", "Denmark", "Djibouti"];
43
+ var specialCharacters = ["/", "\\", "*", "(", ")", "[", "]", "+", "?", "*{[]}|"];
60
44
  describe("TextInput component tests", function () {
61
45
  test("Renders with correct error aria attributes", function () {
62
46
  var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
63
- label: "Error label",
64
- placeholder: "Placeholder",
65
- error: "Error message."
66
- })),
67
- getByText = _render.getByText,
68
- getByRole = _render.getByRole;
69
-
47
+ label: "Error label",
48
+ placeholder: "Placeholder",
49
+ error: "Error message."
50
+ })),
51
+ getByText = _render.getByText,
52
+ getByRole = _render.getByRole;
70
53
  var input = getByRole("textbox");
71
54
  var errorMessage = getByText("Error message.");
72
55
  expect(errorMessage).toBeTruthy();
@@ -76,48 +59,39 @@ describe("TextInput component tests", function () {
76
59
  });
77
60
  test("Renders with correct initial value", function () {
78
61
  var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
79
- label: "Default label",
80
- placeholder: "Placeholder",
81
- defaultValue: "Example text"
82
- })),
83
- getByRole = _render2.getByRole;
84
-
62
+ label: "Default label",
63
+ placeholder: "Placeholder",
64
+ defaultValue: "Example text"
65
+ })),
66
+ getByRole = _render2.getByRole;
85
67
  var input = getByRole("textbox");
86
68
  expect(input.value).toBe("Example text");
87
69
  });
88
70
  test("Not optional constraint (onBlur)", function () {
89
71
  var onChange = jest.fn();
90
72
  var onBlur = jest.fn();
91
-
92
73
  var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
93
- label: "Input label",
94
- placeholder: "Placeholder",
95
- onChange: onChange,
96
- onBlur: onBlur,
97
- clearable: true
98
- })),
99
- getByRole = _render3.getByRole;
100
-
74
+ label: "Input label",
75
+ placeholder: "Placeholder",
76
+ onChange: onChange,
77
+ onBlur: onBlur,
78
+ clearable: true
79
+ })),
80
+ getByRole = _render3.getByRole;
101
81
  var input = getByRole("textbox");
102
-
103
82
  _react2.fireEvent.focus(input);
104
-
105
83
  _react2.fireEvent.blur(input);
106
-
107
84
  expect(onBlur).toHaveBeenCalled();
108
85
  expect(onBlur).toHaveBeenCalledWith({
109
86
  value: "",
110
87
  error: "This field is required. Please, enter a value."
111
88
  });
112
-
113
89
  _react2.fireEvent.change(input, {
114
90
  target: {
115
91
  value: "Test"
116
92
  }
117
93
  });
118
-
119
94
  _react2.fireEvent.blur(input);
120
-
121
95
  expect(onBlur).toHaveBeenCalled();
122
96
  expect(onBlur).toHaveBeenCalledWith({
123
97
  value: "Test"
@@ -125,30 +99,24 @@ describe("TextInput component tests", function () {
125
99
  });
126
100
  test("Not optional constraint (onChange)", function () {
127
101
  var onChange = jest.fn();
128
-
129
102
  var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
130
- label: "Input label",
131
- placeholder: "Placeholder",
132
- onChange: onChange,
133
- clearable: true
134
- })),
135
- getByRole = _render4.getByRole;
136
-
103
+ label: "Input label",
104
+ placeholder: "Placeholder",
105
+ onChange: onChange,
106
+ clearable: true
107
+ })),
108
+ getByRole = _render4.getByRole;
137
109
  var input = getByRole("textbox");
138
-
139
110
  _react2.fireEvent.change(input, {
140
111
  target: {
141
112
  value: "Test"
142
113
  }
143
114
  });
144
-
145
115
  expect(onChange).toHaveBeenCalled();
146
116
  expect(onChange).toHaveBeenCalledWith({
147
117
  value: "Test"
148
118
  });
149
-
150
119
  _userEvent["default"].clear(input);
151
-
152
120
  expect(onChange).toHaveBeenCalled();
153
121
  expect(onChange).toHaveBeenCalledWith({
154
122
  value: "",
@@ -158,58 +126,47 @@ describe("TextInput component tests", function () {
158
126
  test("Pattern constraint", function () {
159
127
  var onChange = jest.fn();
160
128
  var onBlur = jest.fn();
161
-
162
129
  var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
163
- label: "Input label",
164
- placeholder: "Placeholder",
165
- onChange: onChange,
166
- onBlur: onBlur,
167
- margin: {
168
- left: "medium",
169
- right: "medium"
170
- },
171
- clearable: true,
172
- pattern: "^.*(?=.*[a-zA-Z])(?=.*\\d)(?=.*[!&$%&? \"]).*$"
173
- })),
174
- getByRole = _render5.getByRole;
175
-
130
+ label: "Input label",
131
+ placeholder: "Placeholder",
132
+ onChange: onChange,
133
+ onBlur: onBlur,
134
+ margin: {
135
+ left: "medium",
136
+ right: "medium"
137
+ },
138
+ clearable: true,
139
+ pattern: "^.*(?=.*[a-zA-Z])(?=.*\\d)(?=.*[!&$%&? \"]).*$"
140
+ })),
141
+ getByRole = _render5.getByRole;
176
142
  var input = getByRole("textbox");
177
-
178
143
  _react2.fireEvent.change(input, {
179
144
  target: {
180
145
  value: "pattern test"
181
146
  }
182
147
  });
183
-
184
148
  expect(onChange).toHaveBeenCalled();
185
149
  expect(onChange).toHaveBeenCalledWith({
186
150
  value: "pattern test",
187
151
  error: "Please match the format requested."
188
152
  });
189
-
190
153
  _react2.fireEvent.blur(input);
191
-
192
154
  expect(onBlur).toHaveBeenCalled();
193
155
  expect(onBlur).toHaveBeenCalledWith({
194
156
  value: "pattern test",
195
157
  error: "Please match the format requested."
196
158
  });
197
-
198
159
  _userEvent["default"].clear(input);
199
-
200
160
  _react2.fireEvent.change(input, {
201
161
  target: {
202
162
  value: "pattern4&"
203
163
  }
204
164
  });
205
-
206
165
  expect(onChange).toHaveBeenCalled();
207
166
  expect(onChange).toHaveBeenCalledWith({
208
167
  value: "pattern4&"
209
168
  });
210
-
211
169
  _react2.fireEvent.blur(input);
212
-
213
170
  expect(onBlur).toHaveBeenCalled();
214
171
  expect(onBlur).toHaveBeenCalledWith({
215
172
  value: "pattern4&"
@@ -218,59 +175,48 @@ describe("TextInput component tests", function () {
218
175
  test("Length constraint", function () {
219
176
  var onChange = jest.fn();
220
177
  var onBlur = jest.fn();
221
-
222
178
  var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
223
- label: "Input label",
224
- placeholder: "Placeholder",
225
- onChange: onChange,
226
- onBlur: onBlur,
227
- margin: {
228
- left: "medium",
229
- right: "medium"
230
- },
231
- clearable: true,
232
- minLength: 5,
233
- maxLength: 10
234
- })),
235
- getByRole = _render6.getByRole;
236
-
179
+ label: "Input label",
180
+ placeholder: "Placeholder",
181
+ onChange: onChange,
182
+ onBlur: onBlur,
183
+ margin: {
184
+ left: "medium",
185
+ right: "medium"
186
+ },
187
+ clearable: true,
188
+ minLength: 5,
189
+ maxLength: 10
190
+ })),
191
+ getByRole = _render6.getByRole;
237
192
  var input = getByRole("textbox");
238
-
239
193
  _react2.fireEvent.change(input, {
240
194
  target: {
241
195
  value: "test"
242
196
  }
243
197
  });
244
-
245
198
  expect(onChange).toHaveBeenCalled();
246
199
  expect(onChange).toHaveBeenCalledWith({
247
200
  value: "test",
248
201
  error: "Min length 5, max length 10."
249
202
  });
250
-
251
203
  _react2.fireEvent.blur(input);
252
-
253
204
  expect(onBlur).toHaveBeenCalled();
254
205
  expect(onBlur).toHaveBeenCalledWith({
255
206
  value: "test",
256
207
  error: "Min length 5, max length 10."
257
208
  });
258
-
259
209
  _userEvent["default"].clear(input);
260
-
261
210
  _react2.fireEvent.change(input, {
262
211
  target: {
263
212
  value: "length"
264
213
  }
265
214
  });
266
-
267
215
  expect(onChange).toHaveBeenCalled();
268
216
  expect(onChange).toHaveBeenCalledWith({
269
217
  value: "length"
270
218
  });
271
-
272
219
  _react2.fireEvent.blur(input);
273
-
274
220
  expect(onBlur).toHaveBeenCalled();
275
221
  expect(onBlur).toHaveBeenCalledWith({
276
222
  value: "length"
@@ -279,78 +225,64 @@ describe("TextInput component tests", function () {
279
225
  test("Pattern and length constraints", function () {
280
226
  var onChange = jest.fn();
281
227
  var onBlur = jest.fn();
282
-
283
228
  var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
284
- label: "Input label",
285
- placeholder: "Placeholder",
286
- onChange: onChange,
287
- onBlur: onBlur,
288
- margin: {
289
- left: "medium",
290
- right: "medium"
291
- },
292
- clearable: true,
293
- pattern: "^.*(?=.*[a-zA-Z])(?=.*\\d)(?=.*[!&$%&? \"]).*$",
294
- minLength: 5,
295
- maxLength: 10
296
- })),
297
- getByRole = _render7.getByRole;
298
-
229
+ label: "Input label",
230
+ placeholder: "Placeholder",
231
+ onChange: onChange,
232
+ onBlur: onBlur,
233
+ margin: {
234
+ left: "medium",
235
+ right: "medium"
236
+ },
237
+ clearable: true,
238
+ pattern: "^.*(?=.*[a-zA-Z])(?=.*\\d)(?=.*[!&$%&? \"]).*$",
239
+ minLength: 5,
240
+ maxLength: 10
241
+ })),
242
+ getByRole = _render7.getByRole;
299
243
  var input = getByRole("textbox");
300
-
301
244
  _react2.fireEvent.change(input, {
302
245
  target: {
303
246
  value: "test"
304
247
  }
305
248
  });
306
-
307
249
  expect(onChange).toHaveBeenCalled();
308
250
  expect(onChange).toHaveBeenCalledWith({
309
251
  value: "test",
310
252
  error: "Min length 5, max length 10."
311
253
  });
312
-
313
254
  _react2.fireEvent.blur(input);
314
-
315
255
  expect(onBlur).toHaveBeenCalled();
316
256
  expect(onBlur).toHaveBeenCalledWith({
317
257
  value: "test",
318
258
  error: "Min length 5, max length 10."
319
259
  });
320
-
321
260
  _react2.fireEvent.change(input, {
322
261
  target: {
323
262
  value: "tests"
324
263
  }
325
264
  });
326
-
327
265
  expect(onChange).toHaveBeenCalled();
328
266
  expect(onChange).toHaveBeenCalledWith({
329
267
  value: "tests",
330
268
  error: "Please match the format requested."
331
269
  });
332
-
333
270
  _react2.fireEvent.blur(input);
334
-
335
271
  expect(onBlur).toHaveBeenCalled();
336
272
  expect(onBlur).toHaveBeenCalledWith({
337
273
  value: "tests",
338
274
  error: "Please match the format requested."
339
275
  });
340
-
341
276
  _react2.fireEvent.change(input, {
342
277
  target: {
343
278
  value: "tests4&"
344
279
  }
345
280
  });
346
-
347
281
  expect(onChange).toHaveBeenCalled();
348
282
  expect(onChange).toHaveBeenCalledWith({
349
283
  value: "tests4&"
350
284
  });
351
-
352
285
  _react2.fireEvent.blur(input);
353
-
354
286
  expect(onBlur).toHaveBeenCalled();
355
287
  expect(onBlur).toHaveBeenCalledWith({
356
288
  value: "tests4&"
@@ -358,17 +290,13 @@ describe("TextInput component tests", function () {
358
290
  });
359
291
  test("onChange function is called correctly", function () {
360
292
  var onChange = jest.fn();
361
-
362
293
  var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
363
- label: "Input label",
364
- onChange: onChange
365
- })),
366
- getByRole = _render8.getByRole;
367
-
294
+ label: "Input label",
295
+ onChange: onChange
296
+ })),
297
+ getByRole = _render8.getByRole;
368
298
  var input = getByRole("textbox");
369
-
370
299
  _userEvent["default"].type(input, "onchange event test");
371
-
372
300
  expect(input.value).toBe("onchange event test");
373
301
  expect(onChange).toHaveBeenCalled();
374
302
  expect(onChange).toHaveBeenCalledWith({
@@ -378,24 +306,19 @@ describe("TextInput component tests", function () {
378
306
  test("onBlur function is called correctly", function () {
379
307
  var onBlur = jest.fn();
380
308
  var onChange = jest.fn();
381
-
382
309
  var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
383
- label: "Input label",
384
- onChange: onChange,
385
- onBlur: onBlur
386
- })),
387
- getByRole = _render9.getByRole;
388
-
310
+ label: "Input label",
311
+ onChange: onChange,
312
+ onBlur: onBlur
313
+ })),
314
+ getByRole = _render9.getByRole;
389
315
  var input = getByRole("textbox");
390
-
391
316
  _react2.fireEvent.change(input, {
392
317
  target: {
393
318
  value: "Blur test"
394
319
  }
395
320
  });
396
-
397
321
  _react2.fireEvent.blur(input);
398
-
399
322
  expect(onBlur).toHaveBeenCalled();
400
323
  expect(onBlur).toHaveBeenCalledWith({
401
324
  value: "Blur test"
@@ -403,214 +326,320 @@ describe("TextInput component tests", function () {
403
326
  });
404
327
  test("Clear action tooltip is correct", function () {
405
328
  var _render10 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
406
- label: "Input label",
407
- value: "Text",
408
- clearable: true
409
- })),
410
- getByTitle = _render10.getByTitle;
411
-
329
+ label: "Input label",
330
+ value: "Text",
331
+ clearable: true
332
+ })),
333
+ getByTitle = _render10.getByTitle;
412
334
  expect(getByTitle("Clear field")).toBeTruthy();
413
335
  });
414
- test("Clear action onClick cleans the input", function () {
415
- var _render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
416
- label: "Input label",
417
- clearable: true
418
- })),
419
- getByRole = _render11.getByRole;
420
-
421
- var input = getByRole("textbox");
422
-
423
- _userEvent["default"].type(input, "Test");
424
-
425
- var closeAction = getByRole("button");
426
-
427
- _userEvent["default"].click(closeAction);
428
-
429
- expect(input.value).toBe("");
430
- });
431
- test("Disabled input renders with correct aria and can not be modified", function () {
336
+ test("Clear action onClick cleans the input", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
337
+ var _render11, getByRole, input, closeAction;
338
+ return _regenerator["default"].wrap(function _callee$(_context) {
339
+ while (1) switch (_context.prev = _context.next) {
340
+ case 0:
341
+ _render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
342
+ label: "Input label",
343
+ clearable: true
344
+ })), getByRole = _render11.getByRole;
345
+ input = getByRole("textbox");
346
+ _userEvent["default"].type(input, "Test");
347
+ closeAction = getByRole("button");
348
+ _context.next = 6;
349
+ return _userEvent["default"].click(closeAction);
350
+ case 6:
351
+ expect(input.value).toBe("");
352
+ case 7:
353
+ case "end":
354
+ return _context.stop();
355
+ }
356
+ }, _callee);
357
+ })));
358
+ test("Disabled text input renders with correct aria and can not be modified", function () {
432
359
  var onChange = jest.fn();
433
-
434
360
  var _render12 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
435
- label: "Input label",
436
- onChange: onChange,
437
- disabled: true
438
- })),
439
- getByRole = _render12.getByRole;
440
-
361
+ label: "Input label",
362
+ onChange: onChange,
363
+ disabled: true
364
+ })),
365
+ getByRole = _render12.getByRole;
441
366
  var input = getByRole("textbox");
442
-
443
367
  _userEvent["default"].type(input, "Test");
444
-
445
368
  expect(onChange).not.toHaveBeenCalled();
446
369
  });
447
- test("Disabled input (action must be shown but not clickable)", function () {
448
- var onClick = jest.fn();
449
- var action = {
450
- onClick: onClick,
451
- icon: /*#__PURE__*/_react["default"].createElement("svg", {
452
- "data-testid": "image",
453
- xmlns: "http://www.w3.org/2000/svg",
454
- height: "24px",
455
- viewBox: "0 0 24 24",
456
- width: "24px",
457
- fill: "currentColor"
458
- }, /*#__PURE__*/_react["default"].createElement("path", {
459
- d: "M0 0h24v24H0V0z",
460
- fill: "none"
461
- }), /*#__PURE__*/_react["default"].createElement("path", {
462
- d: "M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z"
463
- }))
464
- };
465
-
466
- var _render13 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
467
- label: "Disabled input label",
468
- action: action,
469
- disabled: true
470
- })),
471
- getByRole = _render13.getByRole;
472
-
473
- var input = getByRole("textbox");
474
- expect(input.disabled).toBeTruthy();
475
-
476
- _userEvent["default"].click(getByRole("button"));
477
-
478
- expect(onClick).not.toHaveBeenCalled();
479
- });
480
- test("Disabled input (clear default action should not be displayed, even with text written on the input)", function () {
370
+ test("Disabled text input (action must be shown but not clickable)", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
371
+ var onClick, action, _render13, getByRole, input;
372
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
373
+ while (1) switch (_context2.prev = _context2.next) {
374
+ case 0:
375
+ onClick = jest.fn();
376
+ action = {
377
+ onClick: onClick,
378
+ icon: /*#__PURE__*/_react["default"].createElement("svg", {
379
+ "data-testid": "image",
380
+ xmlns: "http://www.w3.org/2000/svg",
381
+ height: "24px",
382
+ viewBox: "0 0 24 24",
383
+ width: "24px",
384
+ fill: "currentColor"
385
+ }, /*#__PURE__*/_react["default"].createElement("path", {
386
+ d: "M0 0h24v24H0V0z",
387
+ fill: "none"
388
+ }), /*#__PURE__*/_react["default"].createElement("path", {
389
+ d: "M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z"
390
+ }))
391
+ };
392
+ _render13 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
393
+ label: "Disabled input label",
394
+ action: action,
395
+ disabled: true
396
+ })), getByRole = _render13.getByRole;
397
+ input = getByRole("textbox");
398
+ expect(input.disabled).toBeTruthy();
399
+ _context2.next = 7;
400
+ return _userEvent["default"].click(getByRole("button"));
401
+ case 7:
402
+ expect(onClick).not.toHaveBeenCalled();
403
+ case 8:
404
+ case "end":
405
+ return _context2.stop();
406
+ }
407
+ }, _callee2);
408
+ })));
409
+ test("Disabled text input (clear default action should not be displayed, even with text written on the input)", function () {
481
410
  var _render14 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
482
- label: "Disabled input label",
483
- value: "Sample text",
484
- disabled: true,
485
- clearable: true
486
- })),
487
- getByRole = _render14.getByRole,
488
- queryByRole = _render14.queryByRole;
489
-
411
+ label: "Disabled input label",
412
+ value: "Sample text",
413
+ disabled: true,
414
+ clearable: true
415
+ })),
416
+ getByRole = _render14.getByRole,
417
+ queryByRole = _render14.queryByRole;
490
418
  var input = getByRole("textbox");
491
419
  expect(input.disabled).toBeTruthy();
492
420
  expect(queryByRole("button")).toBeFalsy();
493
421
  });
494
- test("Disabled input (suffix and preffix must be displayed)", function () {
422
+ test("Disabled text input (suffix and prefix must be displayed)", function () {
495
423
  var _render15 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
496
- label: "Disabled input label",
497
- value: "Sample text",
498
- prefix: "+34",
499
- suffix: "USD",
500
- disabled: true
501
- })),
502
- getByRole = _render15.getByRole,
503
- getByText = _render15.getByText;
504
-
424
+ label: "Disabled input label",
425
+ value: "Sample text",
426
+ prefix: "+34",
427
+ suffix: "USD",
428
+ disabled: true
429
+ })),
430
+ getByRole = _render15.getByRole,
431
+ getByText = _render15.getByText;
505
432
  var input = getByRole("textbox");
506
433
  expect(input.disabled).toBeTruthy();
507
434
  expect(getByText("+34")).toBeTruthy();
508
435
  expect(getByText("USD")).toBeTruthy();
509
436
  });
510
- test("Action prop: image displayed with title and onClick event", function () {
511
- var onClick = jest.fn();
512
- var action = {
513
- onClick: onClick,
514
- icon: /*#__PURE__*/_react["default"].createElement("svg", {
515
- "data-testid": "image",
516
- xmlns: "http://www.w3.org/2000/svg",
517
- height: "24px",
518
- viewBox: "0 0 24 24",
519
- width: "24px",
520
- fill: "currentColor"
521
- }, /*#__PURE__*/_react["default"].createElement("path", {
522
- d: "M0 0h24v24H0V0z",
523
- fill: "none"
524
- }), /*#__PURE__*/_react["default"].createElement("path", {
525
- d: "M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z"
526
- })),
527
- title: "Search"
528
- };
529
-
437
+ test("Read-only text input doesn't render the clear action", function () {
530
438
  var _render16 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
531
- label: "Input label",
532
- action: action
533
- })),
534
- getByRole = _render16.getByRole,
535
- getByTestId = _render16.getByTestId,
536
- getByTitle = _render16.getByTitle;
537
-
538
- expect(getByTestId("image")).toBeTruthy();
539
- expect(getByTitle("Search")).toBeTruthy();
540
-
541
- _userEvent["default"].click(getByRole("button"));
542
-
543
- expect(onClick).toHaveBeenCalled();
544
- });
545
- test("Text input submit correctly value in form", function () {
546
- var onClick = jest.fn();
547
- var action = {
548
- onClick: onClick,
549
- icon: /*#__PURE__*/_react["default"].createElement("svg", {
550
- "data-testid": "image",
551
- xmlns: "http://www.w3.org/2000/svg",
552
- height: "24px",
553
- viewBox: "0 0 24 24",
554
- width: "24px",
555
- fill: "currentColor"
556
- }, /*#__PURE__*/_react["default"].createElement("path", {
557
- d: "M0 0h24v24H0V0z",
558
- fill: "none"
559
- }), /*#__PURE__*/_react["default"].createElement("path", {
560
- d: "M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z"
439
+ label: "Disabled input label",
440
+ defaultValue: "Sample text",
441
+ readOnly: true,
442
+ clearable: true
561
443
  })),
562
- title: "Search"
563
- };
564
- var handlerOnSubmit = jest.fn(function (e) {
565
- e.preventDefault();
566
- var formData = new FormData(e.target);
567
- var formProps = Object.fromEntries(formData);
568
- expect(formProps).toStrictEqual({
569
- data: "test"
570
- });
571
- });
572
-
573
- var _render17 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement("form", {
574
- onSubmit: handlerOnSubmit
575
- }, /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
576
- label: "Input label",
577
- name: "data",
578
- action: action
579
- }), /*#__PURE__*/_react["default"].createElement("button", {
580
- type: "submit"
581
- }, "Submit"))),
582
- getByText = _render17.getByText,
583
- getAllByRole = _render17.getAllByRole,
584
- getByRole = _render17.getByRole;
585
-
586
- var search = getAllByRole("button")[0];
587
- var submit = getByText("Submit");
444
+ getByRole = _render16.getByRole,
445
+ queryByRole = _render16.queryByRole;
588
446
  var input = getByRole("textbox");
589
-
590
- _userEvent["default"].type(input, "test");
591
-
592
- expect(input.value).toBe("test");
593
-
594
- _userEvent["default"].click(search);
595
-
596
- expect(handlerOnSubmit).not.toHaveBeenCalled();
597
-
598
- _userEvent["default"].click(submit);
599
-
600
- expect(handlerOnSubmit).toHaveBeenCalled();
447
+ expect(input.readOnly).toBeTruthy();
448
+ expect(queryByRole("button")).toBeFalsy();
449
+ });
450
+ test("Read-only text input does not trigger onChange function", function () {
451
+ var onChange = jest.fn();
452
+ var _render17 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
453
+ label: "Example label",
454
+ onChange: onChange,
455
+ readOnly: true
456
+ })),
457
+ getByLabelText = _render17.getByLabelText;
458
+ var textInput = getByLabelText("Example label");
459
+ _userEvent["default"].type(textInput, "Test");
460
+ expect(onChange).not.toHaveBeenCalled();
601
461
  });
462
+ test("Read-only text input sends its value on submit", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() {
463
+ var handlerOnSubmit, _render18, getByText, submit;
464
+ return _regenerator["default"].wrap(function _callee3$(_context3) {
465
+ while (1) switch (_context3.prev = _context3.next) {
466
+ case 0:
467
+ handlerOnSubmit = jest.fn(function (e) {
468
+ e.preventDefault();
469
+ var formData = new FormData(e.target);
470
+ var formProps = Object.fromEntries(formData);
471
+ expect(formProps).toStrictEqual({
472
+ data: "Text"
473
+ });
474
+ });
475
+ _render18 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement("form", {
476
+ onSubmit: handlerOnSubmit
477
+ }, /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
478
+ label: "Example label",
479
+ name: "data",
480
+ defaultValue: "Text",
481
+ readOnly: true
482
+ }), /*#__PURE__*/_react["default"].createElement("button", {
483
+ type: "submit"
484
+ }, "Submit"))), getByText = _render18.getByText;
485
+ submit = getByText("Submit");
486
+ _context3.next = 5;
487
+ return _userEvent["default"].click(submit);
488
+ case 5:
489
+ expect(handlerOnSubmit).toHaveBeenCalled();
490
+ case 6:
491
+ case "end":
492
+ return _context3.stop();
493
+ }
494
+ }, _callee3);
495
+ })));
496
+ test("Read-only text input doesn't trigger custom action's onClick event", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee4() {
497
+ var onClick, action, _render19, getByRole;
498
+ return _regenerator["default"].wrap(function _callee4$(_context4) {
499
+ while (1) switch (_context4.prev = _context4.next) {
500
+ case 0:
501
+ onClick = jest.fn();
502
+ action = {
503
+ onClick: onClick,
504
+ icon: /*#__PURE__*/_react["default"].createElement("svg", {
505
+ "data-testid": "image",
506
+ xmlns: "http://www.w3.org/2000/svg",
507
+ height: "24px",
508
+ viewBox: "0 0 24 24",
509
+ width: "24px",
510
+ fill: "currentColor"
511
+ }, /*#__PURE__*/_react["default"].createElement("path", {
512
+ d: "M0 0h24v24H0V0z",
513
+ fill: "none"
514
+ }), /*#__PURE__*/_react["default"].createElement("path", {
515
+ d: "M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z"
516
+ })),
517
+ title: "Search"
518
+ };
519
+ _render19 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
520
+ label: "Input label",
521
+ action: action,
522
+ readOnly: true
523
+ })), getByRole = _render19.getByRole;
524
+ _context4.next = 5;
525
+ return _userEvent["default"].click(getByRole("button"));
526
+ case 5:
527
+ expect(onClick).not.toHaveBeenCalled();
528
+ case 6:
529
+ case "end":
530
+ return _context4.stop();
531
+ }
532
+ }, _callee4);
533
+ })));
534
+ test("Action prop: image displayed with title and onClick event", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee5() {
535
+ var onClick, action, _render20, getByRole, getByTestId, getByTitle;
536
+ return _regenerator["default"].wrap(function _callee5$(_context5) {
537
+ while (1) switch (_context5.prev = _context5.next) {
538
+ case 0:
539
+ onClick = jest.fn();
540
+ action = {
541
+ onClick: onClick,
542
+ icon: /*#__PURE__*/_react["default"].createElement("svg", {
543
+ "data-testid": "image",
544
+ xmlns: "http://www.w3.org/2000/svg",
545
+ height: "24px",
546
+ viewBox: "0 0 24 24",
547
+ width: "24px",
548
+ fill: "currentColor"
549
+ }, /*#__PURE__*/_react["default"].createElement("path", {
550
+ d: "M0 0h24v24H0V0z",
551
+ fill: "none"
552
+ }), /*#__PURE__*/_react["default"].createElement("path", {
553
+ d: "M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z"
554
+ })),
555
+ title: "Search"
556
+ };
557
+ _render20 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
558
+ label: "Input label",
559
+ action: action
560
+ })), getByRole = _render20.getByRole, getByTestId = _render20.getByTestId, getByTitle = _render20.getByTitle;
561
+ expect(getByTestId("image")).toBeTruthy();
562
+ expect(getByTitle("Search")).toBeTruthy();
563
+ _context5.next = 7;
564
+ return _userEvent["default"].click(getByRole("button"));
565
+ case 7:
566
+ expect(onClick).toHaveBeenCalled();
567
+ case 8:
568
+ case "end":
569
+ return _context5.stop();
570
+ }
571
+ }, _callee5);
572
+ })));
573
+ test("Text input submit correctly value in form", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee6() {
574
+ var onClick, action, handlerOnSubmit, _render21, getByText, getAllByRole, getByRole, search, submit, input;
575
+ return _regenerator["default"].wrap(function _callee6$(_context6) {
576
+ while (1) switch (_context6.prev = _context6.next) {
577
+ case 0:
578
+ onClick = jest.fn();
579
+ action = {
580
+ onClick: onClick,
581
+ icon: /*#__PURE__*/_react["default"].createElement("svg", {
582
+ "data-testid": "image",
583
+ xmlns: "http://www.w3.org/2000/svg",
584
+ height: "24px",
585
+ viewBox: "0 0 24 24",
586
+ width: "24px",
587
+ fill: "currentColor"
588
+ }, /*#__PURE__*/_react["default"].createElement("path", {
589
+ d: "M0 0h24v24H0V0z",
590
+ fill: "none"
591
+ }), /*#__PURE__*/_react["default"].createElement("path", {
592
+ d: "M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z"
593
+ })),
594
+ title: "Search"
595
+ };
596
+ handlerOnSubmit = jest.fn(function (e) {
597
+ e.preventDefault();
598
+ var formData = new FormData(e.target);
599
+ var formProps = Object.fromEntries(formData);
600
+ expect(formProps).toStrictEqual({
601
+ data: "test"
602
+ });
603
+ });
604
+ _render21 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement("form", {
605
+ onSubmit: handlerOnSubmit
606
+ }, /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
607
+ label: "Input label",
608
+ name: "data",
609
+ action: action
610
+ }), /*#__PURE__*/_react["default"].createElement("button", {
611
+ type: "submit"
612
+ }, "Submit"))), getByText = _render21.getByText, getAllByRole = _render21.getAllByRole, getByRole = _render21.getByRole;
613
+ search = getAllByRole("button")[0];
614
+ submit = getByText("Submit");
615
+ input = getByRole("textbox");
616
+ _userEvent["default"].type(input, "test");
617
+ expect(input.value).toBe("test");
618
+ _context6.next = 11;
619
+ return _userEvent["default"].click(search);
620
+ case 11:
621
+ expect(handlerOnSubmit).not.toHaveBeenCalled();
622
+ _context6.next = 14;
623
+ return _userEvent["default"].click(submit);
624
+ case 14:
625
+ expect(handlerOnSubmit).toHaveBeenCalled();
626
+ case 15:
627
+ case "end":
628
+ return _context6.stop();
629
+ }
630
+ }, _callee6);
631
+ })));
602
632
  test("Renders with correct prefix and suffix", function () {
603
- var _render18 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
604
- label: "Input label",
605
- prefix: "+34",
606
- suffix: "USD"
607
- })),
608
- getByText = _render18.getByText;
609
-
633
+ var _render22 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
634
+ label: "Input label",
635
+ prefix: "+34",
636
+ suffix: "USD"
637
+ })),
638
+ getByText = _render22.getByText;
610
639
  expect(getByText("+34")).toBeTruthy();
611
640
  expect(getByText("USD")).toBeTruthy();
612
641
  });
613
- test("Text Input has correct aria accesibility attributes", function () {
642
+ test("Text Input has correct aria accessibility attributes", function () {
614
643
  var onClick = jest.fn();
615
644
  var action = {
616
645
  onClick: onClick,
@@ -629,15 +658,13 @@ describe("TextInput component tests", function () {
629
658
  })),
630
659
  title: "Search"
631
660
  };
632
-
633
- var _render19 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
634
- label: "Example label",
635
- clearable: true,
636
- action: action
637
- })),
638
- getByRole = _render19.getByRole,
639
- getAllByRole = _render19.getAllByRole;
640
-
661
+ var _render23 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
662
+ label: "Example label",
663
+ clearable: true,
664
+ action: action
665
+ })),
666
+ getByRole = _render23.getByRole,
667
+ getAllByRole = _render23.getAllByRole;
641
668
  var input = getByRole("textbox");
642
669
  expect(input.getAttribute("aria-autocomplete")).toBeNull();
643
670
  expect(input.getAttribute("aria-controls")).toBeNull();
@@ -647,76 +674,62 @@ describe("TextInput component tests", function () {
647
674
  expect(input.getAttribute("aria-invalid")).toBe("false");
648
675
  expect(input.getAttribute("aria-errormessage")).toBeNull();
649
676
  expect(input.getAttribute("aria-required")).toBe("true");
650
-
651
677
  _userEvent["default"].type(input, "Text");
652
-
653
678
  var clear = getAllByRole("button")[0];
654
679
  expect(clear.getAttribute("aria-label")).toBe("Clear field");
655
680
  var search = getAllByRole("button")[1];
656
681
  expect(search.getAttribute("aria-label")).toBe("Search");
657
682
  });
658
- test("Autosuggest has correct accesibility attributes", function () {
659
- var _render20 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
660
- label: "Autocomplete Countries",
661
- optional: true,
662
- suggestions: countries
663
- })),
664
- getByRole = _render20.getByRole,
665
- getAllByRole = _render20.getAllByRole;
666
-
683
+ test("Autosuggest has correct accessibility attributes", function () {
684
+ var _render24 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
685
+ label: "Autocomplete Countries",
686
+ optional: true,
687
+ suggestions: countries
688
+ })),
689
+ getByRole = _render24.getByRole,
690
+ getAllByRole = _render24.getAllByRole;
667
691
  var input = getByRole("combobox");
668
692
  expect(input.getAttribute("aria-autocomplete")).toBe("list");
669
693
  expect(input.getAttribute("aria-expanded")).toBe("false");
670
694
  expect(input.getAttribute("aria-haspopup")).toBe("listbox");
671
695
  expect(input.getAttribute("aria-required")).toBe("false");
672
-
673
696
  _react2.fireEvent.focus(input);
674
-
675
697
  var list = getByRole("listbox");
676
698
  expect(input.getAttribute("aria-controls")).toBe(list.id);
677
699
  expect(input.getAttribute("aria-expanded")).toBe("true");
678
700
  var options = getAllByRole("option");
679
701
  expect(options[0].getAttribute("aria-selected")).toBeNull();
680
702
  });
703
+ test("Mouse wheel interaction does not affect the text value", function () {
704
+ var _render25 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
705
+ label: "Default label",
706
+ placeholder: "Placeholder",
707
+ defaultValue: "Example text"
708
+ })),
709
+ getByRole = _render25.getByRole;
710
+ var input = getByRole("textbox");
711
+ _react2.fireEvent.wheel(input, {
712
+ deltaY: -100
713
+ });
714
+ expect(input.value).toBe("Example text");
715
+ _react2.fireEvent.wheel(input, {
716
+ deltaY: 100
717
+ });
718
+ expect(input.value).toBe("Example text");
719
+ });
681
720
  });
682
721
  describe("TextInput component synchronous autosuggest tests", function () {
683
722
  test("Autosuggest is displayed when the input gains focus", function () {
684
723
  var onChange = jest.fn();
685
-
686
- var _render21 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
687
- label: "Autocomplete Countries",
688
- suggestions: countries,
689
- onChange: onChange
690
- })),
691
- getByRole = _render21.getByRole,
692
- getByText = _render21.getByText;
693
-
724
+ var _render26 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
725
+ label: "Autocomplete Countries",
726
+ suggestions: countries,
727
+ onChange: onChange
728
+ })),
729
+ getByRole = _render26.getByRole,
730
+ getByText = _render26.getByText;
694
731
  var input = getByRole("combobox");
695
-
696
732
  _react2.fireEvent.focus(input);
697
-
698
- var list = getByRole("listbox");
699
- expect(list).toBeTruthy();
700
- expect(getByText("Afghanistan")).toBeTruthy();
701
- expect(getByText("Albania")).toBeTruthy();
702
- expect(getByText("Algeria")).toBeTruthy();
703
- expect(getByText("Andorra")).toBeTruthy();
704
- });
705
- test("Autosuggest is displayed when the user clicks the input", function () {
706
- var onChange = jest.fn();
707
-
708
- var _render22 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
709
- label: "Autocomplete Countries",
710
- suggestions: countries,
711
- onChange: onChange
712
- })),
713
- getByRole = _render22.getByRole,
714
- getByText = _render22.getByText;
715
-
716
- var input = getByRole("combobox");
717
-
718
- _react2.fireEvent.focus(input);
719
-
720
733
  var list = getByRole("listbox");
721
734
  expect(list).toBeTruthy();
722
735
  expect(getByText("Afghanistan")).toBeTruthy();
@@ -724,538 +737,707 @@ describe("TextInput component synchronous autosuggest tests", function () {
724
737
  expect(getByText("Algeria")).toBeTruthy();
725
738
  expect(getByText("Andorra")).toBeTruthy();
726
739
  });
727
- test("Autosuggest is displayed while the user is writing (if closed previously, if it is open stays open)", function () {
728
- var onChange = jest.fn();
729
-
730
- var _render23 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
731
- label: "Autocomplete Countries",
732
- suggestions: countries,
733
- onChange: onChange
734
- })),
735
- getByRole = _render23.getByRole,
736
- queryByRole = _render23.queryByRole,
737
- getByText = _render23.getByText,
738
- getAllByText = _render23.getAllByText;
739
-
740
- var input = getByRole("combobox");
741
-
742
- _react2.fireEvent.focus(input);
743
-
744
- var list = getByRole("listbox");
745
- expect(list).toBeTruthy();
746
-
747
- _react2.fireEvent.keyDown(input, {
748
- key: "Esc",
749
- code: "Esc",
750
- keyCode: 27,
751
- charCode: 27
752
- });
753
-
754
- expect(queryByRole("listbox")).toBeFalsy();
755
-
756
- _userEvent["default"].type(input, "B");
757
-
758
- expect(list).toBeTruthy();
759
- expect(getAllByText("B").length).toBe(4);
760
- expect(getByText("ahamas")).toBeTruthy();
761
- expect(getByText("ahrain")).toBeTruthy();
762
- expect(getByText("angladesh")).toBeTruthy();
763
- expect(getByText("arbados")).toBeTruthy();
764
- });
740
+ test("Autosuggest is displayed when the user clicks the input", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee7() {
741
+ var onChange, _render27, getByRole, getByText, input, list;
742
+ return _regenerator["default"].wrap(function _callee7$(_context7) {
743
+ while (1) switch (_context7.prev = _context7.next) {
744
+ case 0:
745
+ onChange = jest.fn();
746
+ _render27 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
747
+ label: "Autocomplete Countries",
748
+ suggestions: countries,
749
+ onChange: onChange
750
+ })), getByRole = _render27.getByRole, getByText = _render27.getByText;
751
+ input = getByRole("combobox");
752
+ _context7.next = 5;
753
+ return _userEvent["default"].click(input);
754
+ case 5:
755
+ list = getByRole("listbox");
756
+ expect(list).toBeTruthy();
757
+ expect(getByText("Afghanistan")).toBeTruthy();
758
+ expect(getByText("Albania")).toBeTruthy();
759
+ expect(getByText("Algeria")).toBeTruthy();
760
+ expect(getByText("Andorra")).toBeTruthy();
761
+ case 11:
762
+ case "end":
763
+ return _context7.stop();
764
+ }
765
+ }, _callee7);
766
+ })));
767
+ test("Autosuggest is displayed while the user is writing (if closed previously, if it is open stays open)", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee8() {
768
+ var _render28, getByRole, getByText, getAllByText, input;
769
+ return _regenerator["default"].wrap(function _callee8$(_context8) {
770
+ while (1) switch (_context8.prev = _context8.next) {
771
+ case 0:
772
+ _render28 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
773
+ label: "Autocomplete Countries",
774
+ suggestions: countries
775
+ })), getByRole = _render28.getByRole, getByText = _render28.getByText, getAllByText = _render28.getAllByText;
776
+ input = getByRole("combobox");
777
+ _context8.next = 4;
778
+ return _userEvent["default"].type(input, "Bah");
779
+ case 4:
780
+ expect(getByRole("listbox")).toBeTruthy();
781
+ expect(getAllByText("Bah").length).toBe(2);
782
+ expect(getByText("amas")).toBeTruthy();
783
+ expect(getByText("rain")).toBeTruthy();
784
+ case 8:
785
+ case "end":
786
+ return _context8.stop();
787
+ }
788
+ }, _callee8);
789
+ })));
790
+ test("Read-only text input does not open the suggestions list", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee9() {
791
+ var onChange, _render29, getByRole, queryByRole, input;
792
+ return _regenerator["default"].wrap(function _callee9$(_context9) {
793
+ while (1) switch (_context9.prev = _context9.next) {
794
+ case 0:
795
+ onChange = jest.fn();
796
+ _render29 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
797
+ label: "Autocomplete Countries",
798
+ suggestions: countries,
799
+ onChange: onChange,
800
+ readOnly: true
801
+ })), getByRole = _render29.getByRole, queryByRole = _render29.queryByRole;
802
+ input = getByRole("combobox");
803
+ _react2.fireEvent.focus(input);
804
+ expect(queryByRole("listbox")).toBeFalsy();
805
+ _context9.next = 7;
806
+ return _userEvent["default"].click(input);
807
+ case 7:
808
+ expect(queryByRole("listbox")).toBeFalsy();
809
+ case 8:
810
+ case "end":
811
+ return _context9.stop();
812
+ }
813
+ }, _callee9);
814
+ })));
765
815
  test("Autosuggest displays filtered when the input has a default value", function () {
766
- var _render24 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
767
- label: "Uncontrolled suggestions filtered by default",
768
- helperText: "Example of helper text",
769
- placeholder: "Placeholder",
770
- margin: "medium",
771
- defaultValue: "Suggestion 2",
772
- suggestions: ["Suggestion 11", "Suggestion 12", "Suggestion 23", "Suggestion 24"],
773
- clearable: true
774
- })),
775
- getByRole = _render24.getByRole,
776
- getByText = _render24.getByText,
777
- getAllByText = _render24.getAllByText;
778
-
816
+ var _render30 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
817
+ label: "Uncontrolled suggestions filtered by default",
818
+ helperText: "Example of helper text",
819
+ placeholder: "Placeholder",
820
+ margin: "medium",
821
+ defaultValue: "Suggestion 2",
822
+ suggestions: ["Suggestion 11", "Suggestion 12", "Suggestion 23", "Suggestion 24"],
823
+ clearable: true
824
+ })),
825
+ getByRole = _render30.getByRole,
826
+ getByText = _render30.getByText,
827
+ getAllByText = _render30.getAllByText;
779
828
  var input = getByRole("combobox");
780
829
  expect(input.value).toBe("Suggestion 2");
781
-
782
830
  _react2.fireEvent.focus(input);
783
-
784
831
  expect(getAllByText("Suggestion 2").length).toBe(2);
785
832
  expect(getByText("3")).toBeTruthy();
786
833
  expect(getByText("4")).toBeTruthy();
787
834
  });
788
835
  test("Autosuggest is not displayed when prop suggestions is an empty array", function () {
789
836
  var onChange = jest.fn();
790
-
791
- var _render25 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
792
- label: "Autocomplete Countries",
793
- suggestions: [],
794
- onChange: onChange
795
- })),
796
- queryByRole = _render25.queryByRole;
797
-
837
+ var _render31 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
838
+ label: "Autocomplete Countries",
839
+ suggestions: [],
840
+ onChange: onChange
841
+ })),
842
+ queryByRole = _render31.queryByRole;
798
843
  var input = queryByRole("textbox");
799
-
800
844
  _react2.fireEvent.focus(input);
801
-
802
845
  expect(queryByRole("listbox")).toBeFalsy();
803
846
  });
804
- test("Autosuggest closes the listbox when there are no matches for the user's input", function () {
805
- var onChange = jest.fn();
806
-
807
- var _render26 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
808
- label: "Autocomplete Countries",
809
- suggestions: countries,
810
- onChange: onChange
811
- })),
812
- getByRole = _render26.getByRole,
813
- queryByRole = _render26.queryByRole,
814
- getByText = _render26.getByText;
815
-
816
- var input = getByRole("combobox");
817
-
818
- _react2.fireEvent.focus(input);
819
-
820
- var list = getByRole("listbox");
821
- expect(list).toBeTruthy();
822
- expect(getByText("Afghanistan")).toBeTruthy();
823
-
824
- _userEvent["default"].type(input, "x");
825
-
826
- expect(queryByRole("listbox")).toBeFalsy();
827
- });
828
- test("Autosuggest with no matches founded doesn't let the listbox to be opened", function () {
829
- var onChange = jest.fn();
830
-
831
- var _render27 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
832
- label: "Autocomplete Countries",
833
- suggestions: countries,
834
- onChange: onChange
835
- })),
836
- getByRole = _render27.getByRole,
837
- queryByRole = _render27.queryByRole,
838
- getByText = _render27.getByText;
839
-
840
- var input = getByRole("combobox");
841
-
842
- _react2.fireEvent.focus(input);
843
-
844
- var list = getByRole("listbox");
845
- expect(list).toBeTruthy();
846
- expect(getByText("Afghanistan")).toBeTruthy();
847
-
848
- _userEvent["default"].type(input, "x");
849
-
850
- expect(queryByRole("listbox")).toBeFalsy();
851
-
852
- _react2.fireEvent.focus(input);
853
-
854
- expect(queryByRole("listbox")).toBeFalsy();
855
-
856
- _react2.fireEvent.keyDown(input, {
857
- key: "ArrowUp",
858
- code: "ArrowUp",
859
- keyCode: 38,
860
- charCode: 38
861
- });
862
-
863
- expect(queryByRole("listbox")).toBeFalsy();
864
-
865
- _react2.fireEvent.keyDown(input, {
866
- key: "ArrowDown",
867
- code: "ArrowDown",
868
- keyCode: 40,
869
- charCode: 40
870
- });
871
-
872
- expect(queryByRole("listbox")).toBeFalsy();
873
- });
874
- test("Autosuggest uncontrolled - Suggestion selected by click", function () {
875
- var onChange = jest.fn();
876
-
877
- var _render28 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
878
- label: "Autocomplete Countries",
879
- suggestions: countries,
880
- onChange: onChange
881
- })),
882
- getByRole = _render28.getByRole,
883
- getByText = _render28.getByText,
884
- queryByRole = _render28.queryByRole;
885
-
886
- var input = getByRole("combobox");
887
-
888
- _react2.fireEvent.focus(input);
889
-
890
- _userEvent["default"].type(input, "Alba");
891
-
892
- expect(onChange).toHaveBeenCalled();
893
- expect(getByText("Alba")).toBeTruthy();
894
- expect(getByText("nia")).toBeTruthy();
895
-
896
- _userEvent["default"].click(getByRole("option"));
897
-
898
- expect(input.value).toBe("Albania");
899
- expect(queryByRole("listbox")).toBeFalsy();
900
- });
901
- test("Autosuggest controlled - Suggestion selected by click", function () {
902
- var onChange = jest.fn();
903
-
904
- var _render29 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
905
- label: "Autocomplete Countries",
906
- value: "Andor",
907
- suggestions: countries,
908
- onChange: onChange
909
- })),
910
- getByRole = _render29.getByRole,
911
- getByText = _render29.getByText,
912
- queryByRole = _render29.queryByRole;
913
-
914
- var input = getByRole("combobox");
915
-
916
- _userEvent["default"].click(getByText("Autocomplete Countries"));
917
-
918
- expect(input.value).toBe("Andor");
919
- expect(getByText("Andor")).toBeTruthy();
920
- expect(getByText("ra")).toBeTruthy();
921
-
922
- _userEvent["default"].click(getByRole("option"));
923
-
924
- expect(onChange).toHaveBeenCalledWith({
925
- value: "Andorra"
926
- });
927
- expect(queryByRole("listbox")).toBeFalsy();
928
- });
929
- test("Autosuggest - Pattern constraint", function () {
930
- var onChange = jest.fn();
931
- var onBlur = jest.fn();
932
-
933
- var _render30 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
934
- label: "Autocomplete Countries",
935
- suggestions: countries,
936
- onChange: onChange,
937
- onBlur: onBlur,
938
- pattern: "^.*(?=.*[a-zA-Z])(?=.*\\d)(?=.*[!&$%&? \"]).*$"
939
- })),
940
- getByRole = _render30.getByRole,
941
- getByText = _render30.getByText;
942
-
943
- var input = getByRole("combobox");
944
-
945
- _react2.fireEvent.focus(input);
946
-
947
- _userEvent["default"].type(input, "Andor");
948
-
949
- expect(getByText("Andor")).toBeTruthy();
950
- expect(getByText("ra")).toBeTruthy();
951
-
952
- _userEvent["default"].click(getByRole("option"));
953
-
954
- expect(onChange).toHaveBeenCalledWith({
955
- value: "Andorra",
956
- error: "Please match the format requested."
957
- });
958
-
959
- _react2.fireEvent.blur(input);
960
-
961
- expect(onBlur).toHaveBeenCalledWith({
962
- value: "Andorra",
963
- error: "Please match the format requested."
964
- });
965
- });
966
- test("Autosuggest - Length constraint", function () {
967
- var onChange = jest.fn();
968
- var onBlur = jest.fn();
969
-
970
- var _render31 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
971
- label: "Autocomplete Countries",
972
- suggestions: countries,
973
- onChange: onChange,
974
- onBlur: onBlur,
975
- minLength: 5,
976
- maxLength: 10
977
- })),
978
- getByText = _render31.getByText,
979
- getByRole = _render31.getByRole;
980
-
981
- var input = getByRole("combobox");
982
-
983
- _react2.fireEvent.focus(input);
984
-
985
- _userEvent["default"].type(input, "Cha");
986
-
987
- expect(getByText("Cha")).toBeTruthy();
988
- expect(getByText("d")).toBeTruthy();
989
-
990
- _userEvent["default"].click(getByRole("option"));
991
-
992
- expect(onChange).toHaveBeenCalledWith({
993
- value: "Cha",
994
- error: "Min length 5, max length 10."
995
- });
996
-
997
- _react2.fireEvent.blur(input);
998
-
999
- expect(onBlur).toHaveBeenCalledWith({
1000
- value: "Chad",
1001
- error: "Min length 5, max length 10."
1002
- });
1003
- });
847
+ test("Autosuggest closes the listbox when there are no matches for the user's input", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee11() {
848
+ var onChange, _render32, getByRole, queryByRole, input;
849
+ return _regenerator["default"].wrap(function _callee11$(_context11) {
850
+ while (1) switch (_context11.prev = _context11.next) {
851
+ case 0:
852
+ onChange = jest.fn();
853
+ _render32 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
854
+ label: "Autocomplete Countries",
855
+ suggestions: countries,
856
+ onChange: onChange
857
+ })), getByRole = _render32.getByRole, queryByRole = _render32.queryByRole;
858
+ input = getByRole("combobox");
859
+ _context11.next = 5;
860
+ return (0, _react2.act)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee10() {
861
+ return _regenerator["default"].wrap(function _callee10$(_context10) {
862
+ while (1) switch (_context10.prev = _context10.next) {
863
+ case 0:
864
+ _userEvent["default"].type(input, "x");
865
+ case 1:
866
+ case "end":
867
+ return _context10.stop();
868
+ }
869
+ }, _callee10);
870
+ })));
871
+ case 5:
872
+ expect(queryByRole("listbox")).toBeFalsy();
873
+ case 6:
874
+ case "end":
875
+ return _context11.stop();
876
+ }
877
+ }, _callee11);
878
+ })));
879
+ test("Autosuggest with no matches founded doesn't let the listbox to be opened", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee13() {
880
+ var onChange, _render33, getByRole, queryByRole, input;
881
+ return _regenerator["default"].wrap(function _callee13$(_context13) {
882
+ while (1) switch (_context13.prev = _context13.next) {
883
+ case 0:
884
+ onChange = jest.fn();
885
+ _render33 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
886
+ label: "Autocomplete Countries",
887
+ suggestions: countries,
888
+ onChange: onChange
889
+ })), getByRole = _render33.getByRole, queryByRole = _render33.queryByRole;
890
+ input = getByRole("combobox");
891
+ _context13.next = 5;
892
+ return (0, _react2.act)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee12() {
893
+ return _regenerator["default"].wrap(function _callee12$(_context12) {
894
+ while (1) switch (_context12.prev = _context12.next) {
895
+ case 0:
896
+ _userEvent["default"].type(input, "x");
897
+ case 1:
898
+ case "end":
899
+ return _context12.stop();
900
+ }
901
+ }, _callee12);
902
+ })));
903
+ case 5:
904
+ expect(queryByRole("listbox")).toBeFalsy();
905
+ _react2.fireEvent.focus(input);
906
+ expect(queryByRole("listbox")).toBeFalsy();
907
+ _react2.fireEvent.keyDown(input, {
908
+ key: "ArrowUp",
909
+ code: "ArrowUp",
910
+ keyCode: 38,
911
+ charCode: 38
912
+ });
913
+ expect(queryByRole("listbox")).toBeFalsy();
914
+ _react2.fireEvent.keyDown(input, {
915
+ key: "ArrowDown",
916
+ code: "ArrowDown",
917
+ keyCode: 40,
918
+ charCode: 40
919
+ });
920
+ expect(queryByRole("listbox")).toBeFalsy();
921
+ case 12:
922
+ case "end":
923
+ return _context13.stop();
924
+ }
925
+ }, _callee13);
926
+ })));
927
+ test("Autosuggest uncontrolled - Suggestion selected by click", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee16() {
928
+ var onChange, _render34, getByRole, getByText, queryByRole, input;
929
+ return _regenerator["default"].wrap(function _callee16$(_context16) {
930
+ while (1) switch (_context16.prev = _context16.next) {
931
+ case 0:
932
+ onChange = jest.fn();
933
+ _render34 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
934
+ label: "Autocomplete Countries",
935
+ suggestions: countries,
936
+ onChange: onChange
937
+ })), getByRole = _render34.getByRole, getByText = _render34.getByText, queryByRole = _render34.queryByRole;
938
+ input = getByRole("combobox");
939
+ _react2.fireEvent.focus(input);
940
+ _context16.next = 6;
941
+ return (0, _react2.act)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee14() {
942
+ return _regenerator["default"].wrap(function _callee14$(_context14) {
943
+ while (1) switch (_context14.prev = _context14.next) {
944
+ case 0:
945
+ _userEvent["default"].type(input, "Alba");
946
+ case 1:
947
+ case "end":
948
+ return _context14.stop();
949
+ }
950
+ }, _callee14);
951
+ })));
952
+ case 6:
953
+ expect(onChange).toHaveBeenCalled();
954
+ expect(getByText("Alba")).toBeTruthy();
955
+ expect(getByText("nia")).toBeTruthy();
956
+ _context16.next = 11;
957
+ return (0, _react2.act)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee15() {
958
+ return _regenerator["default"].wrap(function _callee15$(_context15) {
959
+ while (1) switch (_context15.prev = _context15.next) {
960
+ case 0:
961
+ _userEvent["default"].click(getByRole("option"));
962
+ case 1:
963
+ case "end":
964
+ return _context15.stop();
965
+ }
966
+ }, _callee15);
967
+ })));
968
+ case 11:
969
+ expect(input.value).toBe("Albania");
970
+ expect(queryByRole("listbox")).toBeFalsy();
971
+ case 13:
972
+ case "end":
973
+ return _context16.stop();
974
+ }
975
+ }, _callee16);
976
+ })));
977
+ test("Autosuggest controlled - Suggestion selected by click", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee17() {
978
+ var onChange, _render35, getByRole, getByText, queryByRole, input;
979
+ return _regenerator["default"].wrap(function _callee17$(_context17) {
980
+ while (1) switch (_context17.prev = _context17.next) {
981
+ case 0:
982
+ onChange = jest.fn();
983
+ _render35 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
984
+ label: "Autocomplete Countries",
985
+ value: "Andor",
986
+ suggestions: countries,
987
+ onChange: onChange
988
+ })), getByRole = _render35.getByRole, getByText = _render35.getByText, queryByRole = _render35.queryByRole;
989
+ input = getByRole("combobox");
990
+ _context17.next = 5;
991
+ return _userEvent["default"].click(getByText("Autocomplete Countries"));
992
+ case 5:
993
+ expect(input.value).toBe("Andor");
994
+ expect(getByText("Andor")).toBeTruthy();
995
+ expect(getByText("ra")).toBeTruthy();
996
+ _context17.next = 10;
997
+ return _userEvent["default"].click(getByRole("option"));
998
+ case 10:
999
+ expect(onChange).toHaveBeenCalledWith({
1000
+ value: "Andorra"
1001
+ });
1002
+ expect(queryByRole("listbox")).toBeFalsy();
1003
+ case 12:
1004
+ case "end":
1005
+ return _context17.stop();
1006
+ }
1007
+ }, _callee17);
1008
+ })));
1009
+ test("Autosuggest - Pattern constraint", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee20() {
1010
+ var onChange, onBlur, _render36, getByRole, getByText, input;
1011
+ return _regenerator["default"].wrap(function _callee20$(_context20) {
1012
+ while (1) switch (_context20.prev = _context20.next) {
1013
+ case 0:
1014
+ onChange = jest.fn();
1015
+ onBlur = jest.fn();
1016
+ _render36 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1017
+ label: "Autocomplete Countries",
1018
+ suggestions: countries,
1019
+ onChange: onChange,
1020
+ onBlur: onBlur,
1021
+ pattern: "^.*(?=.*[a-zA-Z])(?=.*\\d)(?=.*[!&$%&? \"]).*$"
1022
+ })), getByRole = _render36.getByRole, getByText = _render36.getByText;
1023
+ input = getByRole("combobox");
1024
+ _react2.fireEvent.focus(input);
1025
+ _context20.next = 7;
1026
+ return (0, _react2.act)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee18() {
1027
+ return _regenerator["default"].wrap(function _callee18$(_context18) {
1028
+ while (1) switch (_context18.prev = _context18.next) {
1029
+ case 0:
1030
+ _userEvent["default"].type(input, "Andor");
1031
+ case 1:
1032
+ case "end":
1033
+ return _context18.stop();
1034
+ }
1035
+ }, _callee18);
1036
+ })));
1037
+ case 7:
1038
+ expect(getByText("Andor")).toBeTruthy();
1039
+ expect(getByText("ra")).toBeTruthy();
1040
+ _context20.next = 11;
1041
+ return (0, _react2.act)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee19() {
1042
+ return _regenerator["default"].wrap(function _callee19$(_context19) {
1043
+ while (1) switch (_context19.prev = _context19.next) {
1044
+ case 0:
1045
+ _userEvent["default"].click(getByRole("option"));
1046
+ case 1:
1047
+ case "end":
1048
+ return _context19.stop();
1049
+ }
1050
+ }, _callee19);
1051
+ })));
1052
+ case 11:
1053
+ expect(onChange).toHaveBeenCalledWith({
1054
+ value: "Andorra",
1055
+ error: "Please match the format requested."
1056
+ });
1057
+ _react2.fireEvent.blur(input);
1058
+ expect(onBlur).toHaveBeenCalledWith({
1059
+ value: "Andorra",
1060
+ error: "Please match the format requested."
1061
+ });
1062
+ case 14:
1063
+ case "end":
1064
+ return _context20.stop();
1065
+ }
1066
+ }, _callee20);
1067
+ })));
1068
+ test("Autosuggest - Length constraint", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee23() {
1069
+ var onChange, onBlur, _render37, getByText, getByRole, input;
1070
+ return _regenerator["default"].wrap(function _callee23$(_context23) {
1071
+ while (1) switch (_context23.prev = _context23.next) {
1072
+ case 0:
1073
+ onChange = jest.fn();
1074
+ onBlur = jest.fn();
1075
+ _render37 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1076
+ label: "Autocomplete Countries",
1077
+ suggestions: countries,
1078
+ onChange: onChange,
1079
+ onBlur: onBlur,
1080
+ minLength: 5,
1081
+ maxLength: 10
1082
+ })), getByText = _render37.getByText, getByRole = _render37.getByRole;
1083
+ input = getByRole("combobox");
1084
+ _react2.fireEvent.focus(input);
1085
+ _context23.next = 7;
1086
+ return (0, _react2.act)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee21() {
1087
+ return _regenerator["default"].wrap(function _callee21$(_context21) {
1088
+ while (1) switch (_context21.prev = _context21.next) {
1089
+ case 0:
1090
+ _userEvent["default"].type(input, "Cha");
1091
+ case 1:
1092
+ case "end":
1093
+ return _context21.stop();
1094
+ }
1095
+ }, _callee21);
1096
+ })));
1097
+ case 7:
1098
+ expect(getByText("Cha")).toBeTruthy();
1099
+ expect(getByText("d")).toBeTruthy();
1100
+ _context23.next = 11;
1101
+ return (0, _react2.act)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee22() {
1102
+ return _regenerator["default"].wrap(function _callee22$(_context22) {
1103
+ while (1) switch (_context22.prev = _context22.next) {
1104
+ case 0:
1105
+ _userEvent["default"].click(getByRole("option"));
1106
+ case 1:
1107
+ case "end":
1108
+ return _context22.stop();
1109
+ }
1110
+ }, _callee22);
1111
+ })));
1112
+ case 11:
1113
+ expect(onChange).toHaveBeenCalledWith({
1114
+ value: "Cha",
1115
+ error: "Min length 5, max length 10."
1116
+ });
1117
+ _react2.fireEvent.blur(input);
1118
+ expect(onBlur).toHaveBeenCalledWith({
1119
+ value: "Chad",
1120
+ error: "Min length 5, max length 10."
1121
+ });
1122
+ case 14:
1123
+ case "end":
1124
+ return _context23.stop();
1125
+ }
1126
+ }, _callee23);
1127
+ })));
1004
1128
  test("Autosuggest keys: arrow down key opens autosuggest, active first option is selected with Enter and closes the autosuggest", function () {
1005
1129
  var onChange = jest.fn();
1006
-
1007
- var _render32 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1008
- label: "Autocomplete Countries",
1009
- suggestions: countries,
1010
- onChange: onChange
1011
- })),
1012
- getByRole = _render32.getByRole,
1013
- queryByRole = _render32.queryByRole;
1014
-
1130
+ var _render38 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1131
+ label: "Autocomplete Countries",
1132
+ suggestions: countries,
1133
+ onChange: onChange
1134
+ })),
1135
+ getByRole = _render38.getByRole,
1136
+ queryByRole = _render38.queryByRole;
1015
1137
  var input = getByRole("combobox");
1016
-
1017
1138
  _react2.fireEvent.keyDown(input, {
1018
1139
  key: "ArrowDown",
1019
1140
  code: "ArrowDown",
1020
1141
  keyCode: 40,
1021
1142
  charCode: 40
1022
1143
  });
1023
-
1024
1144
  var list = getByRole("listbox");
1025
1145
  expect(list).toBeTruthy();
1026
-
1027
1146
  _react2.fireEvent.keyDown(input, {
1028
1147
  key: "Enter",
1029
1148
  code: "Enter",
1030
1149
  keyCode: 13,
1031
1150
  charCode: 13
1032
1151
  });
1033
-
1034
1152
  expect(input.value).toBe("Afghanistan");
1035
1153
  expect(queryByRole("list")).toBeFalsy();
1036
1154
  });
1037
1155
  test("Autosuggest keys: arrow up key opens autosuggest, active last option is selected with Enter and closes the autosuggest", function () {
1038
1156
  var onChange = jest.fn();
1039
-
1040
- var _render33 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1041
- label: "Autocomplete Countries",
1042
- suggestions: countries,
1043
- onChange: onChange
1044
- })),
1045
- getByRole = _render33.getByRole,
1046
- queryByRole = _render33.queryByRole;
1047
-
1157
+ var _render39 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1158
+ label: "Autocomplete Countries",
1159
+ suggestions: countries,
1160
+ onChange: onChange
1161
+ })),
1162
+ getByRole = _render39.getByRole,
1163
+ queryByRole = _render39.queryByRole;
1048
1164
  var input = getByRole("combobox");
1049
-
1050
1165
  _react2.fireEvent.keyDown(input, {
1051
1166
  key: "ArrowUp",
1052
1167
  code: "ArrowUp",
1053
1168
  keyCode: 38,
1054
1169
  charCode: 38
1055
1170
  });
1056
-
1057
1171
  var list = getByRole("listbox");
1058
1172
  expect(list).toBeTruthy();
1059
-
1060
1173
  _react2.fireEvent.keyDown(input, {
1061
1174
  key: "Enter",
1062
1175
  code: "Enter",
1063
1176
  keyCode: 13,
1064
1177
  charCode: 13
1065
1178
  });
1066
-
1067
1179
  expect(input.value).toBe("Djibouti");
1068
1180
  expect(queryByRole("list")).toBeFalsy();
1069
1181
  });
1070
1182
  test("Autosuggest keys: Esc key closes the autosuggest and cleans the input", function () {
1071
1183
  var onChange = jest.fn();
1072
-
1073
- var _render34 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1074
- label: "Autocomplete Countries",
1075
- suggestions: countries,
1076
- onChange: onChange
1077
- })),
1078
- getByRole = _render34.getByRole,
1079
- queryByRole = _render34.queryByRole;
1080
-
1184
+ var _render40 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1185
+ label: "Autocomplete Countries",
1186
+ suggestions: countries,
1187
+ onChange: onChange
1188
+ })),
1189
+ getByRole = _render40.getByRole,
1190
+ queryByRole = _render40.queryByRole;
1081
1191
  var input = getByRole("combobox");
1082
-
1083
1192
  _react2.fireEvent.focus(input);
1084
-
1085
1193
  _userEvent["default"].type(input, "Bangla");
1086
-
1087
1194
  var list = getByRole("listbox");
1088
1195
  expect(list).toBeTruthy();
1089
-
1090
1196
  _react2.fireEvent.keyDown(input, {
1091
1197
  key: "Esc",
1092
1198
  code: "Esc",
1093
1199
  keyCode: 27,
1094
1200
  charCode: 27
1095
1201
  });
1096
-
1097
1202
  expect(input.value).toBe("");
1098
1203
  expect(queryByRole("listbox")).toBeFalsy();
1099
1204
  });
1100
1205
  test("Autosuggest keys: Enter, if no active suggestion closes the autosuggest", function () {
1101
1206
  var onChange = jest.fn();
1102
-
1103
- var _render35 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1104
- label: "Autocomplete Countries",
1105
- suggestions: countries,
1106
- onChange: onChange
1107
- })),
1108
- getByRole = _render35.getByRole,
1109
- queryByRole = _render35.queryByRole;
1110
-
1207
+ var _render41 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1208
+ label: "Autocomplete Countries",
1209
+ suggestions: countries,
1210
+ onChange: onChange
1211
+ })),
1212
+ getByRole = _render41.getByRole,
1213
+ queryByRole = _render41.queryByRole;
1111
1214
  var input = getByRole("combobox");
1112
-
1113
1215
  _react2.fireEvent.focus(input);
1114
-
1115
1216
  var list = getByRole("listbox");
1116
1217
  expect(list).toBeTruthy();
1117
-
1118
1218
  _react2.fireEvent.keyDown(input, {
1119
1219
  key: "Enter",
1120
1220
  code: "Enter",
1121
1221
  keyCode: 27,
1122
1222
  charCode: 27
1123
1223
  });
1124
-
1125
1224
  expect(input.value).toBe("");
1126
1225
  expect(queryByRole("list")).toBeFalsy();
1127
1226
  });
1128
- test("Autosuggest complex key secuence: write, arrow up two times, arrow down and select with Enter. Then, clean with Esc.", function () {
1227
+ test("Autosuggest complex key sequence: write, arrow up two times, arrow down and select with Enter. Then, clean with Esc.", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee25() {
1228
+ var onChange, _render42, getByRole, queryByRole, input;
1229
+ return _regenerator["default"].wrap(function _callee25$(_context25) {
1230
+ while (1) switch (_context25.prev = _context25.next) {
1231
+ case 0:
1232
+ onChange = jest.fn();
1233
+ _render42 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1234
+ label: "Autocomplete Countries",
1235
+ suggestions: countries,
1236
+ onChange: onChange
1237
+ })), getByRole = _render42.getByRole, queryByRole = _render42.queryByRole;
1238
+ input = getByRole("combobox");
1239
+ _react2.fireEvent.focus(input);
1240
+ _context25.next = 6;
1241
+ return (0, _react2.act)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee24() {
1242
+ return _regenerator["default"].wrap(function _callee24$(_context24) {
1243
+ while (1) switch (_context24.prev = _context24.next) {
1244
+ case 0:
1245
+ _userEvent["default"].type(input, "Ba");
1246
+ case 1:
1247
+ case "end":
1248
+ return _context24.stop();
1249
+ }
1250
+ }, _callee24);
1251
+ })));
1252
+ case 6:
1253
+ _react2.fireEvent.keyDown(input, {
1254
+ key: "ArrowUp",
1255
+ code: "ArrowUp",
1256
+ keyCode: 38,
1257
+ charCode: 38
1258
+ });
1259
+ _react2.fireEvent.keyDown(input, {
1260
+ key: "ArrowUp",
1261
+ code: "ArrowUpp",
1262
+ keyCode: 38,
1263
+ charCode: 38
1264
+ });
1265
+ _react2.fireEvent.keyDown(input, {
1266
+ key: "ArrowDown",
1267
+ code: "ArrowDown",
1268
+ keyCode: 40,
1269
+ charCode: 40
1270
+ });
1271
+ _react2.fireEvent.keyDown(input, {
1272
+ key: "Enter",
1273
+ code: "Enter",
1274
+ keyCode: 13,
1275
+ charCode: 13
1276
+ });
1277
+ expect(input.value).toBe("Barbados");
1278
+ expect(queryByRole("listbox")).toBeFalsy();
1279
+ _react2.fireEvent.keyDown(input, {
1280
+ key: "Esc",
1281
+ code: "Esp",
1282
+ keyCode: 27,
1283
+ charCode: 27
1284
+ });
1285
+ expect(input.value).toBe("");
1286
+ expect(queryByRole("listbox")).toBeFalsy();
1287
+ case 15:
1288
+ case "end":
1289
+ return _context25.stop();
1290
+ }
1291
+ }, _callee25);
1292
+ })));
1293
+ test("Autosuggest escapes special characters", function () {
1129
1294
  var onChange = jest.fn();
1130
-
1131
- var _render36 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1132
- label: "Autocomplete Countries",
1133
- suggestions: countries,
1134
- onChange: onChange
1135
- })),
1136
- getByRole = _render36.getByRole,
1137
- queryByRole = _render36.queryByRole;
1138
-
1295
+ var _render43 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1296
+ label: "Autocomplete Countries",
1297
+ suggestions: specialCharacters,
1298
+ onChange: onChange
1299
+ })),
1300
+ getAllByText = _render43.getAllByText,
1301
+ getByRole = _render43.getByRole;
1139
1302
  var input = getByRole("combobox");
1140
-
1141
1303
  _react2.fireEvent.focus(input);
1142
-
1143
- _userEvent["default"].type(input, "Ba");
1144
-
1145
- _react2.fireEvent.keyDown(input, {
1146
- key: "ArrowUp",
1147
- code: "ArrowUp",
1148
- keyCode: 38,
1149
- charCode: 38
1304
+ var list = getByRole("listbox");
1305
+ _react2.fireEvent.change(input, {
1306
+ target: {
1307
+ value: "/"
1308
+ }
1150
1309
  });
1151
-
1152
- _react2.fireEvent.keyDown(input, {
1153
- key: "ArrowUp",
1154
- code: "ArrowUpp",
1155
- keyCode: 38,
1156
- charCode: 38
1310
+ expect(list).toBeTruthy();
1311
+ expect(getAllByText("/").length).toBe(1);
1312
+ _react2.fireEvent.change(input, {
1313
+ target: {
1314
+ value: "\\"
1315
+ }
1157
1316
  });
1158
-
1159
- _react2.fireEvent.keyDown(input, {
1160
- key: "ArrowDown",
1161
- code: "ArrowDown",
1162
- keyCode: 40,
1163
- charCode: 40
1317
+ expect(list).toBeTruthy();
1318
+ expect(getAllByText("\\").length).toBe(1);
1319
+ _react2.fireEvent.change(input, {
1320
+ target: {
1321
+ value: "*"
1322
+ }
1164
1323
  });
1165
-
1166
- _react2.fireEvent.keyDown(input, {
1167
- key: "Enter",
1168
- code: "Enter",
1169
- keyCode: 13,
1170
- charCode: 13
1324
+ expect(list).toBeTruthy();
1325
+ expect(getAllByText("*").length).toBe(2);
1326
+ _react2.fireEvent.change(input, {
1327
+ target: {
1328
+ value: "("
1329
+ }
1171
1330
  });
1172
-
1173
- expect(input.value).toBe("Barbados");
1174
- expect(queryByRole("listbox")).toBeFalsy();
1175
-
1176
- _react2.fireEvent.keyDown(input, {
1177
- key: "Esc",
1178
- code: "Esp",
1179
- keyCode: 27,
1180
- charCode: 27
1331
+ expect(list).toBeTruthy();
1332
+ expect(getAllByText("(").length).toBe(1);
1333
+ _react2.fireEvent.change(input, {
1334
+ target: {
1335
+ value: ")"
1336
+ }
1181
1337
  });
1182
-
1183
- expect(input.value).toBe("");
1184
- expect(queryByRole("listbox")).toBeFalsy();
1338
+ expect(list).toBeTruthy();
1339
+ expect(getAllByText(")").length).toBe(1);
1340
+ _react2.fireEvent.change(input, {
1341
+ target: {
1342
+ value: "["
1343
+ }
1344
+ });
1345
+ expect(list).toBeTruthy();
1346
+ expect(getAllByText("[").length).toBe(1);
1347
+ _react2.fireEvent.change(input, {
1348
+ target: {
1349
+ value: "]"
1350
+ }
1351
+ });
1352
+ expect(list).toBeTruthy();
1353
+ expect(getAllByText("]").length).toBe(1);
1354
+ _react2.fireEvent.change(input, {
1355
+ target: {
1356
+ value: "+"
1357
+ }
1358
+ });
1359
+ expect(list).toBeTruthy();
1360
+ expect(getAllByText("+").length).toBe(1);
1361
+ _react2.fireEvent.change(input, {
1362
+ target: {
1363
+ value: "?"
1364
+ }
1365
+ });
1366
+ expect(list).toBeTruthy();
1367
+ expect(getAllByText("?").length).toBe(1);
1185
1368
  });
1186
1369
  });
1187
1370
  describe("TextInput component asynchronous autosuggest tests", function () {
1188
- test("Autosuggest 'Searching...' message is shown", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
1189
- var callbackFunc, onChange, _render37, getByRole, getByText, input;
1190
-
1191
- return _regenerator["default"].wrap(function _callee$(_context) {
1192
- while (1) {
1193
- switch (_context.prev = _context.next) {
1194
- case 0:
1195
- callbackFunc = jest.fn(function (newValue) {
1196
- var result = new Promise(function (resolve) {
1197
- return setTimeout(function () {
1198
- resolve(newValue ? countries.filter(function (option) {
1199
- return option.toUpperCase().includes(newValue.toUpperCase());
1200
- }) : countries);
1201
- }, 100);
1202
- });
1203
- return result;
1204
- });
1205
- onChange = jest.fn();
1206
- _render37 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1207
- label: "Autosuggest Countries",
1208
- suggestions: callbackFunc,
1209
- onChange: onChange
1210
- })), getByRole = _render37.getByRole, getByText = _render37.getByText;
1211
- input = getByRole("combobox");
1212
-
1213
- _react2.fireEvent.focus(input);
1214
-
1215
- expect(getByRole("listbox")).toBeTruthy();
1216
- _context.next = 8;
1217
- return (0, _react2.waitForElementToBeRemoved)(function () {
1218
- return getByText("Searching...");
1219
- });
1220
-
1221
- case 8:
1222
- expect(getByText("Afghanistan")).toBeTruthy();
1223
- expect(getByText("Albania")).toBeTruthy();
1224
- expect(getByText("Algeria")).toBeTruthy();
1225
- expect(getByText("Andorra")).toBeTruthy();
1226
-
1227
- _userEvent["default"].type(input, "Ab");
1228
-
1229
- _context.next = 15;
1230
- return (0, _react2.waitForElementToBeRemoved)(function () {
1231
- return getByText("Searching...");
1232
- });
1233
-
1234
- case 15:
1235
- expect(getByText("Cabo Verde")).toBeTruthy();
1236
-
1237
- _react2.fireEvent.keyDown(input, {
1238
- key: "ArrowUp",
1239
- code: "ArrowUp",
1240
- keyCode: 38,
1241
- charCode: 38
1371
+ test("Autosuggest 'Searching...' message is shown", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee27() {
1372
+ var callbackFunc, onChange, _render44, getByRole, getByText, input;
1373
+ return _regenerator["default"].wrap(function _callee27$(_context27) {
1374
+ while (1) switch (_context27.prev = _context27.next) {
1375
+ case 0:
1376
+ callbackFunc = jest.fn(function (newValue) {
1377
+ var result = new Promise(function (resolve) {
1378
+ return setTimeout(function () {
1379
+ resolve(newValue ? countries.filter(function (option) {
1380
+ return option.toUpperCase().includes(newValue.toUpperCase());
1381
+ }) : countries);
1382
+ }, 100);
1242
1383
  });
1243
-
1244
- _react2.fireEvent.keyDown(input, {
1245
- key: "Enter",
1246
- code: "Enter",
1247
- keyCode: 13,
1248
- charCode: 13
1249
- });
1250
-
1251
- expect(input.value).toBe("Cabo Verde");
1252
-
1253
- case 19:
1254
- case "end":
1255
- return _context.stop();
1256
- }
1384
+ return result;
1385
+ });
1386
+ onChange = jest.fn();
1387
+ _render44 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1388
+ label: "Autosuggest Countries",
1389
+ suggestions: callbackFunc,
1390
+ onChange: onChange
1391
+ })), getByRole = _render44.getByRole, getByText = _render44.getByText;
1392
+ input = getByRole("combobox");
1393
+ _react2.fireEvent.focus(input);
1394
+ expect(getByRole("listbox")).toBeTruthy();
1395
+ _context27.next = 8;
1396
+ return (0, _react2.waitForElementToBeRemoved)(function () {
1397
+ return getByText("Searching...");
1398
+ });
1399
+ case 8:
1400
+ expect(getByText("Afghanistan")).toBeTruthy();
1401
+ expect(getByText("Albania")).toBeTruthy();
1402
+ expect(getByText("Algeria")).toBeTruthy();
1403
+ expect(getByText("Andorra")).toBeTruthy();
1404
+ _context27.next = 14;
1405
+ return (0, _react2.act)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee26() {
1406
+ return _regenerator["default"].wrap(function _callee26$(_context26) {
1407
+ while (1) switch (_context26.prev = _context26.next) {
1408
+ case 0:
1409
+ _userEvent["default"].type(input, "Ab");
1410
+ case 1:
1411
+ case "end":
1412
+ return _context26.stop();
1413
+ }
1414
+ }, _callee26);
1415
+ })));
1416
+ case 14:
1417
+ _context27.next = 16;
1418
+ return (0, _react2.waitForElementToBeRemoved)(function () {
1419
+ return getByText("Searching...");
1420
+ });
1421
+ case 16:
1422
+ expect(getByText("Cabo Verde")).toBeTruthy();
1423
+ _react2.fireEvent.keyDown(input, {
1424
+ key: "ArrowUp",
1425
+ code: "ArrowUp",
1426
+ keyCode: 38,
1427
+ charCode: 38
1428
+ });
1429
+ _react2.fireEvent.keyDown(input, {
1430
+ key: "Enter",
1431
+ code: "Enter",
1432
+ keyCode: 13,
1433
+ charCode: 13
1434
+ });
1435
+ expect(input.value).toBe("Cabo Verde");
1436
+ case 20:
1437
+ case "end":
1438
+ return _context27.stop();
1257
1439
  }
1258
- }, _callee);
1440
+ }, _callee27);
1259
1441
  })));
1260
1442
  test("Autosuggest Esc key works while 'Searching...' message is shown", function () {
1261
1443
  var callbackFunc = jest.fn(function (newValue) {
@@ -1269,356 +1451,306 @@ describe("TextInput component asynchronous autosuggest tests", function () {
1269
1451
  return result;
1270
1452
  });
1271
1453
  var onChange = jest.fn();
1272
-
1273
- var _render38 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1274
- label: "Autosuggest Countries",
1275
- suggestions: callbackFunc,
1276
- onChange: onChange
1277
- })),
1278
- getByRole = _render38.getByRole,
1279
- queryByText = _render38.queryByText,
1280
- queryByRole = _render38.queryByRole;
1281
-
1454
+ var _render45 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1455
+ label: "Autosuggest Countries",
1456
+ suggestions: callbackFunc,
1457
+ onChange: onChange
1458
+ })),
1459
+ getByRole = _render45.getByRole,
1460
+ queryByText = _render45.queryByText,
1461
+ queryByRole = _render45.queryByRole;
1282
1462
  var input = getByRole("combobox");
1283
-
1284
1463
  _react2.fireEvent.focus(input);
1285
-
1286
1464
  expect(getByRole("listbox")).toBeTruthy();
1287
-
1288
1465
  _userEvent["default"].type(input, "Ab");
1289
-
1290
1466
  _react2.fireEvent.keyDown(input, {
1291
1467
  key: "Esc",
1292
1468
  code: "Esc",
1293
1469
  keyCode: 27,
1294
1470
  charCode: 27
1295
1471
  });
1296
-
1297
1472
  expect(queryByRole("listbox")).toBeFalsy();
1298
1473
  expect(queryByText("Searching...")).toBeFalsy();
1299
1474
  expect(input.value).toBe("");
1300
1475
  });
1301
- test("Autosuggest Esc + arrow down working while 'Searching...' message is shown", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
1302
- var callbackFunc, onChange, _render39, getByRole, getByText, queryByText, queryByRole, input, list;
1303
-
1304
- return _regenerator["default"].wrap(function _callee2$(_context2) {
1305
- while (1) {
1306
- switch (_context2.prev = _context2.next) {
1307
- case 0:
1308
- callbackFunc = jest.fn(function (newValue) {
1309
- var result = new Promise(function (resolve) {
1310
- return setTimeout(function () {
1311
- resolve(newValue ? countries.filter(function (option) {
1312
- return option.toUpperCase().includes(newValue.toUpperCase());
1313
- }) : countries);
1314
- }, 100);
1315
- });
1316
- return result;
1476
+ test("Autosuggest Esc + arrow down working while 'Searching...' message is shown", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee28() {
1477
+ var callbackFunc, onChange, _render46, getByRole, getByText, queryByText, queryByRole, input, list;
1478
+ return _regenerator["default"].wrap(function _callee28$(_context28) {
1479
+ while (1) switch (_context28.prev = _context28.next) {
1480
+ case 0:
1481
+ callbackFunc = jest.fn(function (newValue) {
1482
+ var result = new Promise(function (resolve) {
1483
+ return setTimeout(function () {
1484
+ resolve(newValue ? countries.filter(function (option) {
1485
+ return option.toUpperCase().includes(newValue.toUpperCase());
1486
+ }) : countries);
1487
+ }, 100);
1317
1488
  });
1318
- onChange = jest.fn();
1319
- _render39 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1320
- label: "Autosuggest Countries",
1321
- suggestions: callbackFunc,
1322
- onChange: onChange
1323
- })), getByRole = _render39.getByRole, getByText = _render39.getByText, queryByText = _render39.queryByText, queryByRole = _render39.queryByRole;
1324
- input = getByRole("combobox");
1325
-
1326
- _react2.fireEvent.focus(input);
1327
-
1328
- list = getByRole("listbox");
1329
- expect(list).toBeTruthy();
1330
-
1331
- _userEvent["default"].type(input, "Ab");
1332
-
1333
- _react2.fireEvent.keyDown(input, {
1334
- key: "Esc",
1335
- code: "Esc",
1336
- keyCode: 27,
1337
- charCode: 27
1338
- });
1339
-
1340
- expect(queryByRole("listbox")).toBeFalsy();
1341
- expect(queryByText("Searching...")).toBeFalsy();
1342
- expect(input.value).toBe("");
1343
-
1344
- _react2.fireEvent.keyDown(input, {
1345
- key: "ArrowDown",
1346
- code: "ArrowDown",
1347
- keyCode: 40,
1348
- charCode: 40
1349
- });
1350
-
1351
- expect(list).toBeTruthy();
1352
- _context2.next = 16;
1353
- return (0, _react2.waitForElementToBeRemoved)(function () {
1354
- return getByText("Searching...");
1355
- });
1356
-
1357
- case 16:
1358
- expect(getByText("Afghanistan")).toBeTruthy();
1359
- expect(getByText("Albania")).toBeTruthy();
1360
- expect(getByText("Algeria")).toBeTruthy();
1361
- expect(getByText("Andorra")).toBeTruthy();
1362
-
1363
- case 20:
1364
- case "end":
1365
- return _context2.stop();
1366
- }
1489
+ return result;
1490
+ });
1491
+ onChange = jest.fn();
1492
+ _render46 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1493
+ label: "Autosuggest Countries",
1494
+ suggestions: callbackFunc,
1495
+ onChange: onChange
1496
+ })), getByRole = _render46.getByRole, getByText = _render46.getByText, queryByText = _render46.queryByText, queryByRole = _render46.queryByRole;
1497
+ input = getByRole("combobox");
1498
+ _react2.fireEvent.focus(input);
1499
+ list = getByRole("listbox");
1500
+ expect(list).toBeTruthy();
1501
+ _userEvent["default"].type(input, "Ab");
1502
+ _react2.fireEvent.keyDown(input, {
1503
+ key: "Esc",
1504
+ code: "Esc",
1505
+ keyCode: 27,
1506
+ charCode: 27
1507
+ });
1508
+ expect(queryByRole("listbox")).toBeFalsy();
1509
+ expect(queryByText("Searching...")).toBeFalsy();
1510
+ expect(input.value).toBe("");
1511
+ _react2.fireEvent.keyDown(input, {
1512
+ key: "ArrowDown",
1513
+ code: "ArrowDown",
1514
+ keyCode: 40,
1515
+ charCode: 40
1516
+ });
1517
+ expect(list).toBeTruthy();
1518
+ _context28.next = 16;
1519
+ return (0, _react2.waitForElementToBeRemoved)(function () {
1520
+ return getByText("Searching...");
1521
+ });
1522
+ case 16:
1523
+ expect(getByText("Afghanistan")).toBeTruthy();
1524
+ expect(getByText("Albania")).toBeTruthy();
1525
+ expect(getByText("Algeria")).toBeTruthy();
1526
+ expect(getByText("Andorra")).toBeTruthy();
1527
+ case 20:
1528
+ case "end":
1529
+ return _context28.stop();
1367
1530
  }
1368
- }, _callee2);
1531
+ }, _callee28);
1369
1532
  })));
1370
- test("Asynchronous uncontrolled autosuggest test", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() {
1371
- var callbackFunc, onChange, _render40, getByRole, getByText, input;
1372
-
1373
- return _regenerator["default"].wrap(function _callee3$(_context3) {
1374
- while (1) {
1375
- switch (_context3.prev = _context3.next) {
1376
- case 0:
1377
- callbackFunc = jest.fn(function (newValue) {
1378
- var result = new Promise(function (resolve) {
1379
- return setTimeout(function () {
1380
- resolve(newValue ? countries.filter(function (option) {
1381
- return option.toUpperCase().includes(newValue.toUpperCase());
1382
- }) : countries);
1383
- }, 100);
1384
- });
1385
- return result;
1386
- });
1387
- onChange = jest.fn();
1388
- _render40 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1389
- label: "Autosuggest Countries",
1390
- onChange: onChange,
1391
- suggestions: callbackFunc
1392
- })), getByRole = _render40.getByRole, getByText = _render40.getByText;
1393
- input = getByRole("combobox");
1394
-
1395
- _react2.fireEvent.focus(input);
1396
-
1397
- _userEvent["default"].type(input, "Den");
1398
-
1399
- _context3.next = 8;
1400
- return (0, _react2.waitForElementToBeRemoved)(function () {
1401
- return getByText("Searching...");
1402
- });
1403
-
1404
- case 8:
1405
- expect(getByText("Denmark")).toBeTruthy();
1406
-
1407
- _userEvent["default"].click(getByRole("option"));
1408
-
1409
- expect(onChange).toHaveBeenCalledWith({
1410
- value: "Denmark"
1533
+ test("Asynchronous uncontrolled autosuggest test", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee29() {
1534
+ var callbackFunc, onChange, _render47, getByRole, getByText, input;
1535
+ return _regenerator["default"].wrap(function _callee29$(_context29) {
1536
+ while (1) switch (_context29.prev = _context29.next) {
1537
+ case 0:
1538
+ callbackFunc = jest.fn(function (newValue) {
1539
+ var result = new Promise(function (resolve) {
1540
+ return setTimeout(function () {
1541
+ resolve(newValue ? countries.filter(function (option) {
1542
+ return option.toUpperCase().includes(newValue.toUpperCase());
1543
+ }) : countries);
1544
+ }, 100);
1411
1545
  });
1412
- expect(input.value).toBe("Denmark");
1413
-
1414
- case 12:
1415
- case "end":
1416
- return _context3.stop();
1417
- }
1546
+ return result;
1547
+ });
1548
+ onChange = jest.fn();
1549
+ _render47 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1550
+ label: "Autosuggest Countries",
1551
+ onChange: onChange,
1552
+ suggestions: callbackFunc
1553
+ })), getByRole = _render47.getByRole, getByText = _render47.getByText;
1554
+ input = getByRole("combobox");
1555
+ _react2.fireEvent.focus(input);
1556
+ _userEvent["default"].type(input, "Den");
1557
+ _context29.next = 8;
1558
+ return (0, _react2.waitForElementToBeRemoved)(function () {
1559
+ return getByText("Searching...");
1560
+ });
1561
+ case 8:
1562
+ expect(getByText("Denmark")).toBeTruthy();
1563
+ _context29.next = 11;
1564
+ return _userEvent["default"].click(getByRole("option"));
1565
+ case 11:
1566
+ expect(onChange).toHaveBeenCalledWith({
1567
+ value: "Denmark"
1568
+ });
1569
+ expect(input.value).toBe("Denmark");
1570
+ case 13:
1571
+ case "end":
1572
+ return _context29.stop();
1418
1573
  }
1419
- }, _callee3);
1574
+ }, _callee29);
1420
1575
  })));
1421
- test("Asynchronous controlled autosuggest test", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee4() {
1422
- var callbackFunc, onChange, _render41, getByRole, getByText, queryByRole, input;
1423
-
1424
- return _regenerator["default"].wrap(function _callee4$(_context4) {
1425
- while (1) {
1426
- switch (_context4.prev = _context4.next) {
1427
- case 0:
1428
- callbackFunc = jest.fn(function (newValue) {
1429
- var result = new Promise(function (resolve) {
1430
- return setTimeout(function () {
1431
- resolve(newValue ? countries.filter(function (option) {
1432
- return option.toUpperCase().includes(newValue.toUpperCase());
1433
- }) : countries);
1434
- }, 100);
1435
- });
1436
- return result;
1576
+ test("Asynchronous controlled autosuggest test", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee30() {
1577
+ var callbackFunc, onChange, _render48, getByRole, getByText, queryByRole, input;
1578
+ return _regenerator["default"].wrap(function _callee30$(_context30) {
1579
+ while (1) switch (_context30.prev = _context30.next) {
1580
+ case 0:
1581
+ callbackFunc = jest.fn(function (newValue) {
1582
+ var result = new Promise(function (resolve) {
1583
+ return setTimeout(function () {
1584
+ resolve(newValue ? countries.filter(function (option) {
1585
+ return option.toUpperCase().includes(newValue.toUpperCase());
1586
+ }) : countries);
1587
+ }, 100);
1437
1588
  });
1438
- onChange = jest.fn();
1439
- _render41 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1440
- label: "Autosuggest Countries",
1441
- value: "Denm",
1442
- onChange: onChange,
1443
- suggestions: callbackFunc
1444
- })), getByRole = _render41.getByRole, getByText = _render41.getByText, queryByRole = _render41.queryByRole;
1445
- input = getByRole("combobox");
1446
- expect(input.value).toBe("Denm");
1447
-
1448
- _userEvent["default"].click(getByText("Autosuggest Countries"));
1449
-
1450
- _context4.next = 8;
1451
- return (0, _react2.waitForElementToBeRemoved)(function () {
1452
- return getByText("Searching...");
1453
- });
1454
-
1455
- case 8:
1456
- expect(getByText("Denmark")).toBeTruthy();
1457
-
1458
- _react2.fireEvent.focus(getByRole("option"));
1459
-
1460
- _userEvent["default"].click(getByText("Denmark"));
1461
-
1462
- expect(onChange).toHaveBeenCalledWith({
1463
- value: "Denmark"
1464
- });
1465
- expect(queryByRole("listbox")).toBeFalsy();
1466
-
1467
- case 13:
1468
- case "end":
1469
- return _context4.stop();
1470
- }
1589
+ return result;
1590
+ });
1591
+ onChange = jest.fn();
1592
+ _render48 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1593
+ label: "Autosuggest Countries",
1594
+ value: "Denm",
1595
+ onChange: onChange,
1596
+ suggestions: callbackFunc
1597
+ })), getByRole = _render48.getByRole, getByText = _render48.getByText, queryByRole = _render48.queryByRole;
1598
+ input = getByRole("combobox");
1599
+ expect(input.value).toBe("Denm");
1600
+ _context30.next = 7;
1601
+ return _userEvent["default"].click(getByText("Autosuggest Countries"));
1602
+ case 7:
1603
+ _context30.next = 9;
1604
+ return (0, _react2.waitForElementToBeRemoved)(function () {
1605
+ return getByText("Searching...");
1606
+ });
1607
+ case 9:
1608
+ expect(getByText("Denmark")).toBeTruthy();
1609
+ _react2.fireEvent.focus(getByRole("option"));
1610
+ _context30.next = 13;
1611
+ return _userEvent["default"].click(getByText("Denmark"));
1612
+ case 13:
1613
+ expect(onChange).toHaveBeenCalledWith({
1614
+ value: "Denmark"
1615
+ });
1616
+ expect(queryByRole("listbox")).toBeFalsy();
1617
+ case 15:
1618
+ case "end":
1619
+ return _context30.stop();
1471
1620
  }
1472
- }, _callee4);
1621
+ }, _callee30);
1473
1622
  })));
1474
- test("Asynchronous autosuggest closes the listbox after finishing no matches search", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee5() {
1475
- var callbackFunc, onChange, _render42, getByText, getByRole, queryByRole, input;
1476
-
1477
- return _regenerator["default"].wrap(function _callee5$(_context5) {
1478
- while (1) {
1479
- switch (_context5.prev = _context5.next) {
1480
- case 0:
1481
- callbackFunc = jest.fn(function (newValue) {
1482
- var result = new Promise(function (resolve) {
1483
- return setTimeout(function () {
1484
- resolve(newValue ? countries.filter(function (option) {
1485
- return option.toUpperCase().includes(newValue.toUpperCase());
1486
- }) : countries);
1487
- }, 100);
1488
- });
1489
- return result;
1490
- });
1491
- onChange = jest.fn();
1492
- _render42 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1493
- label: "Autosuggest Countries",
1494
- onChange: onChange,
1495
- suggestions: callbackFunc
1496
- })), getByText = _render42.getByText, getByRole = _render42.getByRole, queryByRole = _render42.queryByRole;
1497
- input = getByRole("combobox");
1498
-
1499
- _react2.fireEvent.focus(input);
1500
-
1501
- _userEvent["default"].type(input, "Example text");
1502
-
1503
- _context5.next = 8;
1504
- return (0, _react2.waitForElementToBeRemoved)(function () {
1505
- return getByText("Searching...");
1623
+ test("Asynchronous autosuggest closes the listbox after finishing no matches search", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee32() {
1624
+ var callbackFunc, onChange, _render49, getByText, getByRole, queryByRole, input;
1625
+ return _regenerator["default"].wrap(function _callee32$(_context32) {
1626
+ while (1) switch (_context32.prev = _context32.next) {
1627
+ case 0:
1628
+ callbackFunc = jest.fn(function (newValue) {
1629
+ var result = new Promise(function (resolve) {
1630
+ return setTimeout(function () {
1631
+ resolve(newValue ? countries.filter(function (option) {
1632
+ return option.toUpperCase().includes(newValue.toUpperCase());
1633
+ }) : countries);
1634
+ }, 100);
1506
1635
  });
1507
-
1508
- case 8:
1509
- expect(queryByRole("listbox")).toBeFalsy();
1510
-
1511
- case 9:
1512
- case "end":
1513
- return _context5.stop();
1514
- }
1636
+ return result;
1637
+ });
1638
+ onChange = jest.fn();
1639
+ _render49 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1640
+ label: "Autosuggest Countries",
1641
+ onChange: onChange,
1642
+ suggestions: callbackFunc
1643
+ })), getByText = _render49.getByText, getByRole = _render49.getByRole, queryByRole = _render49.queryByRole;
1644
+ input = getByRole("combobox");
1645
+ _react2.fireEvent.focus(input);
1646
+ _context32.next = 7;
1647
+ return (0, _react2.act)( /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee31() {
1648
+ return _regenerator["default"].wrap(function _callee31$(_context31) {
1649
+ while (1) switch (_context31.prev = _context31.next) {
1650
+ case 0:
1651
+ _userEvent["default"].type(input, "Example text");
1652
+ case 1:
1653
+ case "end":
1654
+ return _context31.stop();
1655
+ }
1656
+ }, _callee31);
1657
+ })));
1658
+ case 7:
1659
+ _context32.next = 9;
1660
+ return (0, _react2.waitForElementToBeRemoved)(function () {
1661
+ return getByText("Searching...");
1662
+ });
1663
+ case 9:
1664
+ expect(queryByRole("listbox")).toBeFalsy();
1665
+ case 10:
1666
+ case "end":
1667
+ return _context32.stop();
1515
1668
  }
1516
- }, _callee5);
1669
+ }, _callee32);
1517
1670
  })));
1518
- test("Asynchronous autosuggest with no matches founded doesn't let the listbox to be opened", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee6() {
1519
- var callbackFunc, onChange, _render43, getByText, getByRole, queryByRole, input;
1520
-
1521
- return _regenerator["default"].wrap(function _callee6$(_context6) {
1522
- while (1) {
1523
- switch (_context6.prev = _context6.next) {
1524
- case 0:
1525
- callbackFunc = jest.fn(function (newValue) {
1526
- var result = new Promise(function (resolve) {
1527
- return setTimeout(function () {
1528
- resolve(newValue ? countries.filter(function (option) {
1529
- return option.toUpperCase().includes(newValue.toUpperCase());
1530
- }) : countries);
1531
- }, 100);
1532
- });
1533
- return result;
1671
+ test("Asynchronous autosuggest with no matches founded doesn't let the listbox to be opened", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee33() {
1672
+ var callbackFunc, onChange, _render50, getByText, getByRole, queryByRole, input;
1673
+ return _regenerator["default"].wrap(function _callee33$(_context33) {
1674
+ while (1) switch (_context33.prev = _context33.next) {
1675
+ case 0:
1676
+ callbackFunc = jest.fn(function (newValue) {
1677
+ var result = new Promise(function (resolve) {
1678
+ return setTimeout(function () {
1679
+ resolve(newValue ? countries.filter(function (option) {
1680
+ return option.toUpperCase().includes(newValue.toUpperCase());
1681
+ }) : countries);
1682
+ }, 100);
1534
1683
  });
1535
- onChange = jest.fn();
1536
- _render43 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1537
- label: "Autosuggest Countries",
1538
- onChange: onChange,
1539
- suggestions: callbackFunc
1540
- })), getByText = _render43.getByText, getByRole = _render43.getByRole, queryByRole = _render43.queryByRole;
1541
- input = getByRole("combobox");
1542
-
1543
- _react2.fireEvent.focus(input);
1544
-
1545
- _userEvent["default"].type(input, "wrong");
1546
-
1547
- _context6.next = 8;
1548
- return (0, _react2.waitForElementToBeRemoved)(function () {
1549
- return getByText("Searching...");
1550
- });
1551
-
1552
- case 8:
1553
- expect(queryByRole("listbox")).toBeFalsy();
1554
-
1555
- _react2.fireEvent.focus(input);
1556
-
1557
- expect(queryByRole("listbox")).toBeFalsy();
1558
-
1559
- _react2.fireEvent.keyDown(input, {
1560
- key: "ArrowUp",
1561
- code: "ArrowUp",
1562
- keyCode: 38,
1563
- charCode: 38
1564
- });
1565
-
1566
- expect(queryByRole("listbox")).toBeFalsy();
1567
-
1568
- _react2.fireEvent.keyDown(input, {
1569
- key: "ArrowDown",
1570
- code: "ArrowDown",
1571
- keyCode: 40,
1572
- charCode: 40
1573
- });
1574
-
1575
- expect(queryByRole("listbox")).toBeFalsy();
1576
-
1577
- case 15:
1578
- case "end":
1579
- return _context6.stop();
1580
- }
1684
+ return result;
1685
+ });
1686
+ onChange = jest.fn();
1687
+ _render50 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1688
+ label: "Autosuggest Countries",
1689
+ onChange: onChange,
1690
+ suggestions: callbackFunc
1691
+ })), getByText = _render50.getByText, getByRole = _render50.getByRole, queryByRole = _render50.queryByRole;
1692
+ input = getByRole("combobox");
1693
+ _react2.fireEvent.focus(input);
1694
+ _userEvent["default"].type(input, "wrong");
1695
+ _context33.next = 8;
1696
+ return (0, _react2.waitForElementToBeRemoved)(function () {
1697
+ return getByText("Searching...");
1698
+ });
1699
+ case 8:
1700
+ expect(queryByRole("listbox")).toBeFalsy();
1701
+ _react2.fireEvent.focus(input);
1702
+ expect(queryByRole("listbox")).toBeFalsy();
1703
+ _react2.fireEvent.keyDown(input, {
1704
+ key: "ArrowUp",
1705
+ code: "ArrowUp",
1706
+ keyCode: 38,
1707
+ charCode: 38
1708
+ });
1709
+ expect(queryByRole("listbox")).toBeFalsy();
1710
+ _react2.fireEvent.keyDown(input, {
1711
+ key: "ArrowDown",
1712
+ code: "ArrowDown",
1713
+ keyCode: 40,
1714
+ charCode: 40
1715
+ });
1716
+ expect(queryByRole("listbox")).toBeFalsy();
1717
+ case 15:
1718
+ case "end":
1719
+ return _context33.stop();
1581
1720
  }
1582
- }, _callee6);
1721
+ }, _callee33);
1583
1722
  })));
1584
- test("Asynchronous autosuggest request failed, shows 'Error fetching data' message", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee7() {
1585
- var errorCallbackFunc, onChange, _render44, getByRole, getByText, input;
1586
-
1587
- return _regenerator["default"].wrap(function _callee7$(_context7) {
1588
- while (1) {
1589
- switch (_context7.prev = _context7.next) {
1590
- case 0:
1591
- errorCallbackFunc = jest.fn(function () {
1592
- var result = new Promise(function (resolve, reject) {
1593
- return setTimeout(function () {
1594
- reject("err");
1595
- }, 100);
1596
- });
1597
- return result;
1723
+ test("Asynchronous autosuggest request failed, shows 'Error fetching data' message", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee34() {
1724
+ var errorCallbackFunc, onChange, _render51, getByRole, getByText, input;
1725
+ return _regenerator["default"].wrap(function _callee34$(_context34) {
1726
+ while (1) switch (_context34.prev = _context34.next) {
1727
+ case 0:
1728
+ errorCallbackFunc = jest.fn(function () {
1729
+ var result = new Promise(function (resolve, reject) {
1730
+ return setTimeout(function () {
1731
+ reject("err");
1732
+ }, 100);
1598
1733
  });
1599
- onChange = jest.fn();
1600
- _render44 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1601
- label: "Autosuggest Countries",
1602
- onChange: onChange,
1603
- suggestions: errorCallbackFunc
1604
- })), getByRole = _render44.getByRole, getByText = _render44.getByText;
1605
- input = getByRole("combobox");
1606
-
1607
- _react2.fireEvent.focus(input);
1608
-
1609
- _context7.next = 7;
1610
- return (0, _react2.waitForElementToBeRemoved)(function () {
1611
- return getByText("Searching...");
1612
- });
1613
-
1614
- case 7:
1615
- expect(getByText("Error fetching data")).toBeTruthy();
1616
-
1617
- case 8:
1618
- case "end":
1619
- return _context7.stop();
1620
- }
1734
+ return result;
1735
+ });
1736
+ onChange = jest.fn();
1737
+ _render51 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1738
+ label: "Autosuggest Countries",
1739
+ onChange: onChange,
1740
+ suggestions: errorCallbackFunc
1741
+ })), getByRole = _render51.getByRole, getByText = _render51.getByText;
1742
+ input = getByRole("combobox");
1743
+ _react2.fireEvent.focus(input);
1744
+ _context34.next = 7;
1745
+ return (0, _react2.waitForElementToBeRemoved)(function () {
1746
+ return getByText("Searching...");
1747
+ });
1748
+ case 7:
1749
+ expect(getByText("Error fetching data")).toBeTruthy();
1750
+ case 8:
1751
+ case "end":
1752
+ return _context34.stop();
1621
1753
  }
1622
- }, _callee7);
1754
+ }, _callee34);
1623
1755
  })));
1624
1756
  });