@dxc-technology/halstack-react 0.0.0-ff5083e → 0.0.0-ff6c8bf

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 (403) 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 +126 -111
  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 +105 -160
  9. package/accordion/Accordion.stories.tsx +82 -148
  10. package/accordion/Accordion.test.js +25 -41
  11. package/accordion/types.d.ts +6 -17
  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 +31 -98
  15. package/accordion-group/AccordionGroup.stories.tsx +94 -67
  16. package/accordion-group/AccordionGroup.test.js +52 -105
  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 +12 -17
  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 +37 -127
  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 +64 -63
  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 +19 -60
  45. package/box/Box.stories.tsx +38 -51
  46. package/box/Box.test.js +2 -7
  47. package/box/types.d.ts +3 -14
  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 +35 -63
  62. package/bulleted-list/BulletedList.stories.tsx +18 -106
  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 +64 -117
  67. package/button/Button.stories.tsx +151 -100
  68. package/button/Button.test.js +20 -17
  69. package/button/types.d.ts +12 -8
  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 -11
  76. package/checkbox/Checkbox.accessibility.test.js +87 -0
  77. package/checkbox/Checkbox.d.ts +2 -2
  78. package/checkbox/Checkbox.js +139 -181
  79. package/checkbox/Checkbox.stories.tsx +128 -94
  80. package/checkbox/Checkbox.test.js +160 -39
  81. package/checkbox/types.d.ts +11 -3
  82. package/chip/Chip.accessibility.test.js +67 -0
  83. package/chip/Chip.js +45 -80
  84. package/chip/Chip.stories.tsx +107 -27
  85. package/chip/Chip.test.js +18 -33
  86. package/chip/types.d.ts +4 -4
  87. package/common/coreTokens.d.ts +237 -0
  88. package/common/coreTokens.js +184 -0
  89. package/common/utils.d.ts +1 -0
  90. package/common/utils.js +6 -12
  91. package/common/variables.d.ts +1392 -0
  92. package/common/variables.js +984 -1206
  93. package/container/Container.d.ts +4 -0
  94. package/container/Container.js +194 -0
  95. package/container/Container.stories.tsx +214 -0
  96. package/container/types.d.ts +74 -0
  97. package/contextual-menu/ContextualMenu.accessibility.test.js +97 -0
  98. package/contextual-menu/ContextualMenu.d.ts +5 -0
  99. package/contextual-menu/ContextualMenu.js +88 -0
  100. package/contextual-menu/ContextualMenu.stories.tsx +232 -0
  101. package/contextual-menu/ContextualMenu.test.js +205 -0
  102. package/contextual-menu/GroupItem.d.ts +4 -0
  103. package/contextual-menu/GroupItem.js +67 -0
  104. package/contextual-menu/ItemAction.d.ts +4 -0
  105. package/contextual-menu/ItemAction.js +51 -0
  106. package/contextual-menu/MenuItem.d.ts +4 -0
  107. package/contextual-menu/MenuItem.js +29 -0
  108. package/contextual-menu/SingleItem.d.ts +4 -0
  109. package/contextual-menu/SingleItem.js +38 -0
  110. package/contextual-menu/types.d.ts +58 -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 +700 -371
  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 +61 -106
  125. package/dialog/Dialog.stories.tsx +326 -167
  126. package/dialog/Dialog.test.js +287 -20
  127. package/dialog/types.d.ts +18 -25
  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/dropdown/Dropdown.accessibility.test.js +180 -0
  135. package/dropdown/Dropdown.d.ts +1 -1
  136. package/dropdown/Dropdown.js +233 -303
  137. package/dropdown/Dropdown.stories.tsx +235 -57
  138. package/dropdown/Dropdown.test.js +575 -165
  139. package/dropdown/DropdownMenu.d.ts +4 -0
  140. package/dropdown/DropdownMenu.js +63 -0
  141. package/dropdown/DropdownMenuItem.d.ts +4 -0
  142. package/dropdown/DropdownMenuItem.js +71 -0
  143. package/dropdown/types.d.ts +35 -19
  144. package/file-input/FileInput.accessibility.test.js +160 -0
  145. package/file-input/FileInput.d.ts +2 -2
  146. package/file-input/FileInput.js +241 -391
  147. package/file-input/FileInput.stories.tsx +123 -12
  148. package/file-input/FileInput.test.js +306 -367
  149. package/file-input/FileItem.d.ts +4 -14
  150. package/file-input/FileItem.js +56 -117
  151. package/file-input/types.d.ts +25 -8
  152. package/flex/Flex.d.ts +4 -0
  153. package/flex/Flex.js +57 -0
  154. package/flex/Flex.stories.tsx +112 -0
  155. package/flex/types.d.ts +97 -0
  156. package/footer/Footer.accessibility.test.js +125 -0
  157. package/footer/Footer.d.ts +1 -1
  158. package/footer/Footer.js +73 -118
  159. package/footer/Footer.stories.tsx +99 -21
  160. package/footer/Footer.test.js +33 -57
  161. package/footer/Icons.d.ts +3 -2
  162. package/footer/Icons.js +54 -23
  163. package/footer/types.d.ts +26 -27
  164. package/grid/Grid.d.ts +7 -0
  165. package/grid/Grid.js +76 -0
  166. package/grid/Grid.stories.tsx +219 -0
  167. package/grid/types.d.ts +115 -0
  168. package/grid/types.js +5 -0
  169. package/header/Header.accessibility.test.js +93 -0
  170. package/header/Header.d.ts +4 -3
  171. package/header/Header.js +90 -183
  172. package/header/Header.stories.tsx +133 -38
  173. package/header/Header.test.js +13 -26
  174. package/header/Icons.d.ts +2 -2
  175. package/header/Icons.js +5 -15
  176. package/header/types.d.ts +7 -21
  177. package/heading/Heading.accessibility.test.js +33 -0
  178. package/heading/Heading.js +10 -32
  179. package/heading/Heading.test.js +71 -88
  180. package/heading/types.d.ts +7 -7
  181. package/icon/Icon.accessibility.test.js +30 -0
  182. package/icon/Icon.d.ts +4 -0
  183. package/icon/Icon.js +33 -0
  184. package/icon/Icon.stories.tsx +28 -0
  185. package/icon/types.d.ts +4 -0
  186. package/icon/types.js +5 -0
  187. package/image/Image.accessibility.test.js +56 -0
  188. package/image/Image.d.ts +4 -0
  189. package/image/Image.js +70 -0
  190. package/image/Image.stories.tsx +129 -0
  191. package/image/types.d.ts +72 -0
  192. package/image/types.js +5 -0
  193. package/inset/Inset.js +13 -21
  194. package/inset/Inset.stories.tsx +5 -4
  195. package/inset/types.d.ts +2 -2
  196. package/layout/ApplicationLayout.d.ts +15 -6
  197. package/layout/ApplicationLayout.js +57 -119
  198. package/layout/ApplicationLayout.stories.tsx +81 -45
  199. package/layout/Icons.d.ts +7 -5
  200. package/layout/Icons.js +41 -59
  201. package/layout/types.d.ts +21 -32
  202. package/link/Link.accessibility.test.js +108 -0
  203. package/link/Link.js +32 -51
  204. package/link/Link.stories.tsx +76 -9
  205. package/link/Link.test.js +24 -44
  206. package/link/types.d.ts +14 -14
  207. package/main.d.ts +14 -12
  208. package/main.js +51 -88
  209. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  210. package/nav-tabs/NavTabs.d.ts +7 -0
  211. package/{tabs-nav → nav-tabs}/NavTabs.js +30 -62
  212. package/nav-tabs/NavTabs.stories.tsx +279 -0
  213. package/nav-tabs/NavTabs.test.js +77 -0
  214. package/nav-tabs/NavTabsContext.d.ts +3 -0
  215. package/nav-tabs/NavTabsContext.js +8 -0
  216. package/nav-tabs/Tab.js +117 -0
  217. package/{tabs-nav → nav-tabs}/types.d.ts +15 -16
  218. package/nav-tabs/types.js +5 -0
  219. package/number-input/NumberInput.accessibility.test.js +228 -0
  220. package/number-input/NumberInput.js +46 -36
  221. package/number-input/NumberInput.stories.tsx +42 -26
  222. package/number-input/NumberInput.test.js +860 -377
  223. package/number-input/NumberInputContext.d.ts +3 -4
  224. package/number-input/NumberInputContext.js +3 -14
  225. package/number-input/types.d.ts +17 -5
  226. package/package.json +51 -51
  227. package/paginator/Paginator.accessibility.test.js +79 -0
  228. package/paginator/Paginator.js +35 -68
  229. package/paginator/Paginator.stories.tsx +24 -0
  230. package/paginator/Paginator.test.js +280 -211
  231. package/paginator/types.d.ts +3 -3
  232. package/paragraph/Paragraph.accessibility.test.js +28 -0
  233. package/paragraph/Paragraph.d.ts +3 -4
  234. package/paragraph/Paragraph.js +7 -23
  235. package/paragraph/Paragraph.stories.tsx +1 -18
  236. package/password-input/PasswordInput.accessibility.test.js +153 -0
  237. package/password-input/PasswordInput.js +58 -127
  238. package/password-input/PasswordInput.stories.tsx +1 -33
  239. package/password-input/PasswordInput.test.js +160 -142
  240. package/password-input/types.d.ts +8 -7
  241. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  242. package/progress-bar/ProgressBar.js +68 -92
  243. package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +39 -4
  244. package/progress-bar/ProgressBar.test.js +72 -44
  245. package/progress-bar/types.d.ts +3 -3
  246. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  247. package/quick-nav/QuickNav.js +24 -42
  248. package/quick-nav/QuickNav.stories.tsx +146 -27
  249. package/quick-nav/types.d.ts +10 -10
  250. package/radio-group/Radio.d.ts +1 -1
  251. package/radio-group/Radio.js +59 -76
  252. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  253. package/radio-group/RadioGroup.js +68 -114
  254. package/radio-group/RadioGroup.stories.tsx +132 -18
  255. package/radio-group/RadioGroup.test.js +518 -457
  256. package/radio-group/types.d.ts +10 -10
  257. package/resultset-table/Icons.d.ts +7 -0
  258. package/resultset-table/Icons.js +47 -0
  259. package/resultset-table/ResultsetTable.accessibility.test.js +285 -0
  260. package/resultset-table/ResultsetTable.d.ts +7 -0
  261. package/resultset-table/ResultsetTable.js +171 -0
  262. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +168 -30
  263. package/resultset-table/ResultsetTable.test.js +381 -0
  264. package/{resultsetTable → resultset-table}/types.d.ts +44 -11
  265. package/resultset-table/types.js +5 -0
  266. package/select/Listbox.d.ts +1 -1
  267. package/select/Listbox.js +68 -65
  268. package/select/Option.js +35 -56
  269. package/select/Select.accessibility.test.js +228 -0
  270. package/select/Select.js +171 -214
  271. package/select/Select.stories.tsx +515 -190
  272. package/select/Select.test.js +1934 -1789
  273. package/select/types.d.ts +17 -21
  274. package/sidenav/Sidenav.accessibility.test.js +59 -0
  275. package/sidenav/Sidenav.d.ts +6 -5
  276. package/sidenav/Sidenav.js +132 -78
  277. package/sidenav/Sidenav.stories.tsx +246 -151
  278. package/sidenav/Sidenav.test.js +26 -45
  279. package/{layout → sidenav}/SidenavContext.d.ts +1 -1
  280. package/{layout → sidenav}/SidenavContext.js +3 -9
  281. package/sidenav/types.d.ts +52 -26
  282. package/slider/Slider.accessibility.test.js +104 -0
  283. package/slider/Slider.d.ts +2 -2
  284. package/slider/Slider.js +149 -181
  285. package/slider/Slider.stories.tsx +64 -61
  286. package/slider/Slider.test.js +185 -81
  287. package/slider/types.d.ts +7 -3
  288. package/spinner/Spinner.accessibility.test.js +96 -0
  289. package/spinner/Spinner.js +34 -74
  290. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
  291. package/spinner/Spinner.test.js +26 -35
  292. package/spinner/types.d.ts +3 -3
  293. package/status-light/StatusLight.accessibility.test.js +157 -0
  294. package/status-light/StatusLight.d.ts +4 -0
  295. package/status-light/StatusLight.js +51 -0
  296. package/status-light/StatusLight.stories.tsx +74 -0
  297. package/status-light/StatusLight.test.js +25 -0
  298. package/status-light/types.d.ts +17 -0
  299. package/status-light/types.js +5 -0
  300. package/switch/Switch.accessibility.test.js +98 -0
  301. package/switch/Switch.d.ts +2 -2
  302. package/switch/Switch.js +145 -126
  303. package/switch/Switch.stories.tsx +49 -60
  304. package/switch/Switch.test.js +138 -56
  305. package/switch/types.d.ts +7 -3
  306. package/table/DropdownTheme.js +62 -0
  307. package/table/Table.accessibility.test.js +93 -0
  308. package/table/Table.d.ts +6 -2
  309. package/table/Table.js +78 -35
  310. package/table/Table.stories.tsx +663 -0
  311. package/table/Table.test.js +95 -8
  312. package/table/types.d.ts +34 -6
  313. package/tabs/Tab.d.ts +4 -0
  314. package/tabs/Tab.js +117 -0
  315. package/tabs/Tabs.accessibility.test.js +56 -0
  316. package/tabs/Tabs.js +303 -141
  317. package/tabs/Tabs.stories.tsx +124 -6
  318. package/tabs/Tabs.test.js +213 -77
  319. package/tabs/types.d.ts +30 -20
  320. package/tag/Tag.accessibility.test.js +69 -0
  321. package/tag/Tag.js +35 -67
  322. package/tag/Tag.stories.tsx +18 -8
  323. package/tag/Tag.test.js +18 -37
  324. package/tag/types.d.ts +9 -9
  325. package/text-input/Suggestion.js +40 -28
  326. package/text-input/Suggestions.d.ts +4 -0
  327. package/text-input/Suggestions.js +94 -0
  328. package/text-input/TextInput.accessibility.test.js +321 -0
  329. package/text-input/TextInput.js +316 -515
  330. package/text-input/TextInput.stories.tsx +276 -276
  331. package/text-input/TextInput.test.js +1419 -1375
  332. package/text-input/types.d.ts +43 -16
  333. package/textarea/Textarea.accessibility.test.js +155 -0
  334. package/textarea/Textarea.js +71 -113
  335. package/textarea/Textarea.stories.tsx +174 -0
  336. package/textarea/Textarea.test.js +152 -183
  337. package/textarea/types.d.ts +9 -5
  338. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  339. package/toggle-group/ToggleGroup.d.ts +2 -2
  340. package/toggle-group/ToggleGroup.js +94 -107
  341. package/toggle-group/ToggleGroup.stories.tsx +52 -7
  342. package/toggle-group/ToggleGroup.test.js +69 -88
  343. package/toggle-group/types.d.ts +28 -19
  344. package/typography/Typography.accessibility.test.js +339 -0
  345. package/typography/Typography.d.ts +2 -2
  346. package/typography/Typography.js +16 -124
  347. package/typography/Typography.stories.tsx +185 -162
  348. package/typography/types.d.ts +1 -1
  349. package/useTheme.d.ts +1144 -1
  350. package/useTheme.js +2 -9
  351. package/useTranslatedLabels.d.ts +84 -1
  352. package/useTranslatedLabels.js +1 -7
  353. package/utils/BaseTypography.d.ts +21 -0
  354. package/utils/BaseTypography.js +94 -0
  355. package/utils/FocusLock.d.ts +13 -0
  356. package/utils/FocusLock.js +124 -0
  357. package/wizard/Wizard.accessibility.test.js +55 -0
  358. package/wizard/Wizard.js +34 -87
  359. package/wizard/Wizard.stories.tsx +59 -1
  360. package/wizard/Wizard.test.js +54 -81
  361. package/wizard/types.d.ts +9 -9
  362. package/card/ice-cream.jpg +0 -0
  363. package/common/OpenSans.css +0 -81
  364. package/common/RequiredComponent.js +0 -32
  365. package/common/fonts/OpenSans-Bold.ttf +0 -0
  366. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  367. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  368. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  369. package/common/fonts/OpenSans-Italic.ttf +0 -0
  370. package/common/fonts/OpenSans-Light.ttf +0 -0
  371. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  372. package/common/fonts/OpenSans-Regular.ttf +0 -0
  373. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  374. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  375. package/number-input/numberInputContextTypes.d.ts +0 -19
  376. package/paginator/Icons.js +0 -66
  377. package/resultsetTable/ResultsetTable.d.ts +0 -4
  378. package/resultsetTable/ResultsetTable.js +0 -254
  379. package/resultsetTable/ResultsetTable.test.js +0 -306
  380. package/row/Row.d.ts +0 -3
  381. package/row/Row.js +0 -127
  382. package/row/Row.stories.tsx +0 -237
  383. package/row/types.d.ts +0 -28
  384. package/select/Icons.d.ts +0 -10
  385. package/select/Icons.js +0 -93
  386. package/stack/Stack.d.ts +0 -3
  387. package/stack/Stack.js +0 -97
  388. package/stack/Stack.stories.tsx +0 -164
  389. package/stack/types.d.ts +0 -24
  390. package/table/Table.stories.jsx +0 -277
  391. package/tabs-nav/NavTabs.d.ts +0 -8
  392. package/tabs-nav/NavTabs.stories.tsx +0 -170
  393. package/tabs-nav/NavTabs.test.js +0 -82
  394. package/tabs-nav/Tab.js +0 -132
  395. package/textarea/Textarea.stories.jsx +0 -157
  396. package/typography/typographyContextTypes.d.ts +0 -16
  397. /package/{resultsetTable → action-icon}/types.js +0 -0
  398. /package/{row → breadcrumbs}/types.js +0 -0
  399. /package/{stack → container}/types.js +0 -0
  400. /package/{tabs-nav → contextual-menu}/types.js +0 -0
  401. /package/{number-input/numberInputContextTypes.js → divider/types.js} +0 -0
  402. /package/{typography/typographyContextTypes.js → flex/types.js} +0 -0
  403. /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
@@ -1,96 +1,142 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
4
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
5
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
6
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
7
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
5
8
  var _react = _interopRequireDefault(require("react"));
6
-
7
9
  var _react2 = require("@testing-library/react");
8
-
9
10
  var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
10
-
11
- var _NumberInput = _interopRequireDefault(require("./NumberInput"));
12
-
11
+ var _NumberInput = _interopRequireDefault(require("./NumberInput.tsx"));
12
+ // Mocking DOMRect for Radix Primitive Popover
13
+ global.globalThis = global;
14
+ global.DOMRect = {
15
+ fromRect: function fromRect() {
16
+ return {
17
+ top: 0,
18
+ left: 0,
19
+ bottom: 0,
20
+ right: 0,
21
+ width: 0,
22
+ height: 0
23
+ };
24
+ }
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
+ }();
13
42
  describe("Number input component tests", function () {
14
- test("Number input renders with label", function () {
43
+ test("Number input renders with label, helper text, placeholder and increment/decrement action buttons", function () {
15
44
  var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
16
- label: "Number input label"
17
- })),
18
- getByText = _render.getByText;
19
-
45
+ label: "Number input label",
46
+ helperText: "Helper text",
47
+ placeholder: "Placeholder"
48
+ })),
49
+ getByLabelText = _render.getByLabelText,
50
+ getByText = _render.getByText,
51
+ queryAllByRole = _render.queryAllByRole;
52
+ var number = getByLabelText("Number input label");
20
53
  expect(getByText("Number input label")).toBeTruthy();
21
- });
22
- test("Number input renders with helper text", function () {
23
- var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
24
- helperText: "Helper text"
25
- })),
26
- getByText = _render2.getByText;
27
-
28
54
  expect(getByText("Helper text")).toBeTruthy();
29
- });
30
- test("Number input renders with placeholder", function () {
31
- var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
32
- label: "Number label",
33
- placeholder: "Placeholder"
34
- })),
35
- getByLabelText = _render3.getByLabelText;
36
-
37
- var number = getByLabelText("Number label");
38
55
  expect(number.getAttribute("placeholder")).toBe("Placeholder");
39
- });
40
- test("Number input renders increment and decrement buttons", function () {
41
- var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
42
- label: "Number label"
43
- })),
44
- queryAllByRole = _render4.queryAllByRole;
45
-
46
56
  expect(queryAllByRole("button").length).toBe(2);
47
57
  });
48
58
  test("Number input buttons' tooltip is correct", function () {
49
- var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
50
- label: "Number label"
51
- })),
52
- getByTitle = _render5.getByTitle;
53
-
59
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
60
+ label: "Number label"
61
+ })),
62
+ getByTitle = _render2.getByTitle;
54
63
  expect(getByTitle("Decrement value")).toBeTruthy();
55
64
  expect(getByTitle("Increment value")).toBeTruthy();
56
65
  });
57
66
  test("Number input is disabled", function () {
58
- var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
59
- label: "Number label",
60
- disabled: true
61
- })),
62
- getByLabelText = _render6.getByLabelText;
63
-
67
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
68
+ label: "Number label",
69
+ disabled: true
70
+ })),
71
+ getByLabelText = _render3.getByLabelText;
64
72
  var number = getByLabelText("Number label");
65
73
  expect(number.disabled).toBeTruthy();
66
74
  });
75
+ test("Number input is read only and cannot be incremented or decremented using the actions", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
76
+ var _render4, getByLabelText, getAllByRole, number, decrement, increment;
77
+ return _regenerator["default"].wrap(function _callee$(_context) {
78
+ while (1) switch (_context.prev = _context.next) {
79
+ case 0:
80
+ _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
81
+ label: "Number label",
82
+ readOnly: true
83
+ })), getByLabelText = _render4.getByLabelText, getAllByRole = _render4.getAllByRole;
84
+ number = getByLabelText("Number label");
85
+ expect(number.readOnly).toBeTruthy();
86
+ decrement = getAllByRole("button")[0];
87
+ _context.next = 6;
88
+ return _userEvent["default"].click(decrement);
89
+ case 6:
90
+ expect(number.value).toBe("");
91
+ increment = getAllByRole("button")[1];
92
+ _context.next = 10;
93
+ return _userEvent["default"].click(increment);
94
+ case 10:
95
+ expect(number.value).toBe("");
96
+ case 11:
97
+ case "end":
98
+ return _context.stop();
99
+ }
100
+ }, _callee);
101
+ })));
102
+ test("Number input is read only and cannot be incremented or decremented using the arrow keys", function () {
103
+ var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
104
+ label: "Number label",
105
+ readOnly: true
106
+ })),
107
+ getByLabelText = _render5.getByLabelText;
108
+ var number = getByLabelText("Number label");
109
+ expect(number.readOnly).toBeTruthy();
110
+ _react2.fireEvent.keyDown(number, {
111
+ keyCode: 38
112
+ });
113
+ expect(number.value).toBe("");
114
+ _react2.fireEvent.keyDown(number, {
115
+ keyCode: 40
116
+ });
117
+ expect(number.value).toBe("");
118
+ });
67
119
  test("Number input is optional", function () {
68
- var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
69
- label: "Number label",
70
- optional: true
71
- })),
72
- getByText = _render7.getByText;
73
-
120
+ var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
121
+ label: "Number label",
122
+ optional: true
123
+ })),
124
+ getByText = _render6.getByText;
74
125
  expect(getByText("(Optional)")).toBeTruthy();
75
126
  });
76
127
  test("Number input is not optional: required field, displays error if not filled in", function () {
77
128
  var onBlur = jest.fn();
78
129
  var onChange = jest.fn();
79
-
80
- var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
81
- onBlur: onBlur,
82
- onChange: onChange
83
- })),
84
- getByRole = _render8.getByRole;
85
-
86
- var input = getByRole("textbox");
87
-
88
- _userEvent["default"].type(input, "1");
89
-
90
- _userEvent["default"].clear(input);
91
-
92
- _react2.fireEvent.blur(input);
93
-
130
+ var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
131
+ label: "Number input label",
132
+ onBlur: onBlur,
133
+ onChange: onChange
134
+ })),
135
+ getByLabelText = _render7.getByLabelText;
136
+ var number = getByLabelText("Number input label");
137
+ _userEvent["default"].type(number, "1");
138
+ _userEvent["default"].clear(number);
139
+ _react2.fireEvent.blur(number);
94
140
  expect(onBlur).toHaveBeenCalled();
95
141
  expect(onBlur).toHaveBeenCalledWith({
96
142
  value: "",
@@ -102,399 +148,794 @@ describe("Number input component tests", function () {
102
148
  error: "This field is required. Please, enter a value."
103
149
  });
104
150
  });
105
- test("Suffix and prefix must be shown)", function () {
106
- var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
107
- label: "Number input label",
108
- prefix: "+34",
109
- suffix: "USD"
110
- })),
111
- getByText = _render9.getByText;
112
-
151
+ test("Suffix and prefix must be shown", function () {
152
+ var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
153
+ label: "Number input label",
154
+ prefix: "+34",
155
+ suffix: "USD"
156
+ })),
157
+ getByText = _render8.getByText;
113
158
  expect(getByText("+34")).toBeTruthy();
114
159
  expect(getByText("USD")).toBeTruthy();
115
160
  });
116
161
  test("Invalid number input renders error", function () {
117
- var _render10 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
118
- error: "Error message."
119
- })),
120
- getByText = _render10.getByText;
121
-
162
+ var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
163
+ error: "Error message."
164
+ })),
165
+ getByText = _render9.getByText;
122
166
  expect(getByText("Error message.")).toBeTruthy();
123
167
  });
124
168
  test("onChange function is called correctly", function () {
125
169
  var onChange = jest.fn();
126
-
127
- var _render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
128
- label: "Number input label",
129
- onChange: onChange
130
- })),
131
- getByLabelText = _render11.getByLabelText;
132
-
170
+ var _render10 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
171
+ label: "Number input label",
172
+ onChange: onChange
173
+ })),
174
+ getByLabelText = _render10.getByLabelText;
133
175
  var number = getByLabelText("Number input label");
134
-
135
176
  _userEvent["default"].type(number, "t");
136
-
137
177
  expect(onChange).not.toHaveBeenCalledWith({
138
178
  value: "t"
139
179
  });
140
180
  expect(number.value).toBe("");
141
-
142
181
  _userEvent["default"].type(number, "1");
143
-
144
182
  expect(onChange).toHaveBeenCalledWith({
145
183
  value: "1"
146
184
  });
147
185
  expect(number.value).toBe("1");
148
186
  });
149
- test("Error message is shown if the value is less than the min value", function () {
150
- var onChange = jest.fn(function (_ref) {
151
- var value = _ref.value,
152
- error = _ref.error;
153
- expect(value).toBe("1");
154
- expect(error).toBe("Value must be greater than or equal to 5.");
155
- });
156
- var onBlur = jest.fn(function (_ref2) {
187
+ test("Error message is shown if the typed value is less than the min value", function () {
188
+ var onChange = jest.fn(function (_ref2) {
157
189
  var value = _ref2.value,
158
- error = _ref2.error;
159
- expect(value).toBe("1");
160
- expect(error).toBe("Value must be greater than or equal to 5.");
190
+ error = _ref2.error;
191
+ expect(value).toBe("-1");
192
+ expect(error).toBe("Value must be greater than or equal to 0.");
161
193
  });
162
-
163
- var _render12 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
164
- label: "Number input label",
165
- min: 5,
166
- onBlur: onBlur,
167
- onChange: onChange
168
- })),
169
- getByLabelText = _render12.getByLabelText;
170
-
171
- var number = getByLabelText("Number input label");
172
-
173
- _userEvent["default"].type(number, "1");
174
-
175
- _react2.fireEvent.blur(number);
176
- });
177
- test("Cannot decrement the value if it is less than the min value", function () {
178
- var _render13 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
179
- label: "Number input label",
180
- min: 5
181
- })),
182
- getByLabelText = _render13.getByLabelText,
183
- getAllByRole = _render13.getAllByRole;
184
-
185
- var number = getByLabelText("Number input label");
186
-
187
- _userEvent["default"].type(number, "1");
188
-
189
- _react2.fireEvent.blur(number);
190
-
191
- expect(number.value).toBe("1");
192
- var decrement = getAllByRole("button")[0];
193
-
194
- _userEvent["default"].click(decrement);
195
-
196
- expect(number.value).toBe("1");
197
- });
198
- test("Increment the value when it is less than the min value", function () {
199
- var _render14 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
200
- label: "Number input label",
201
- min: 5
202
- })),
203
- getByLabelText = _render14.getByLabelText,
204
- getAllByRole = _render14.getAllByRole;
205
-
194
+ var onBlur = jest.fn(function (_ref3) {
195
+ var value = _ref3.value,
196
+ error = _ref3.error;
197
+ expect(value).toBe("-1");
198
+ expect(error).toBe("Value must be greater than or equal to 0.");
199
+ });
200
+ var _render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
201
+ label: "Number input label",
202
+ min: 0,
203
+ onBlur: onBlur,
204
+ onChange: onChange
205
+ })),
206
+ getByLabelText = _render11.getByLabelText;
206
207
  var number = getByLabelText("Number input label");
207
-
208
- _userEvent["default"].type(number, "1");
209
-
208
+ _userEvent["default"].type(number, "-1");
210
209
  _react2.fireEvent.blur(number);
211
-
212
- expect(number.value).toBe("1");
213
- var increment = getAllByRole("button")[1];
214
-
215
- _userEvent["default"].click(increment);
216
-
217
- expect(number.value).toBe("5");
218
210
  });
219
- test("Error message is shown if the value is greater than the max value", function () {
211
+ test("Cannot decrement the value if it is less than the min value", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
212
+ var _render12, getByLabelText, getAllByRole, number, decrement;
213
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
214
+ while (1) switch (_context2.prev = _context2.next) {
215
+ case 0:
216
+ _render12 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
217
+ label: "Number input label",
218
+ min: 5
219
+ })), getByLabelText = _render12.getByLabelText, getAllByRole = _render12.getAllByRole;
220
+ number = getByLabelText("Number input label");
221
+ _userEvent["default"].type(number, "1");
222
+ _react2.fireEvent.blur(number);
223
+ expect(number.value).toBe("1");
224
+ decrement = getAllByRole("button")[0];
225
+ _context2.next = 8;
226
+ return _userEvent["default"].click(decrement);
227
+ case 8:
228
+ expect(number.value).toBe("1");
229
+ case 9:
230
+ case "end":
231
+ return _context2.stop();
232
+ }
233
+ }, _callee2);
234
+ })));
235
+ test("Increment the value when it is less than the min value", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() {
236
+ var _render13, getByLabelText, getAllByRole, number, increment;
237
+ return _regenerator["default"].wrap(function _callee3$(_context3) {
238
+ while (1) switch (_context3.prev = _context3.next) {
239
+ case 0:
240
+ _render13 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
241
+ label: "Number input label",
242
+ min: 5
243
+ })), getByLabelText = _render13.getByLabelText, getAllByRole = _render13.getAllByRole;
244
+ number = getByLabelText("Number input label");
245
+ _userEvent["default"].type(number, "1");
246
+ _react2.fireEvent.blur(number);
247
+ expect(number.value).toBe("1");
248
+ increment = getAllByRole("button")[1];
249
+ _context3.next = 8;
250
+ return _userEvent["default"].click(increment);
251
+ case 8:
252
+ expect(number.value).toBe("5");
253
+ case 9:
254
+ case "end":
255
+ return _context3.stop();
256
+ }
257
+ }, _callee3);
258
+ })));
259
+ test("Error message is shown if the typed value is greater than the max value", function () {
220
260
  var onChange = jest.fn();
221
261
  var onBlur = jest.fn();
222
-
223
- var _render15 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
224
- label: "Number input label",
225
- max: 10,
226
- onBlur: onBlur,
227
- onChange: onChange
228
- })),
229
- getByLabelText = _render15.getByLabelText;
230
-
262
+ var _render14 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
263
+ label: "Number input label",
264
+ max: 10,
265
+ onBlur: onBlur,
266
+ onChange: onChange
267
+ })),
268
+ getByLabelText = _render14.getByLabelText;
231
269
  var number = getByLabelText("Number input label");
232
-
233
270
  _userEvent["default"].type(number, "12");
234
-
235
271
  expect(onChange).toHaveBeenCalledTimes(2);
236
272
  expect(onChange).toHaveBeenCalledWith({
237
273
  value: "12",
238
274
  error: "Value must be less than or equal to 10."
239
275
  });
240
-
241
276
  _react2.fireEvent.blur(number);
242
-
243
277
  expect(onBlur).toHaveBeenCalled();
244
278
  expect(onBlur).toHaveBeenCalledWith({
245
279
  value: "12",
246
280
  error: "Value must be less than or equal to 10."
247
281
  });
248
282
  });
249
- test("Cannot increment the value if it is greater than the max value", function () {
250
- var _render16 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
251
- label: "Number input label",
252
- max: 10
253
- })),
254
- getByLabelText = _render16.getByLabelText,
255
- getAllByRole = _render16.getAllByRole;
256
-
257
- var number = getByLabelText("Number input label");
258
-
259
- _userEvent["default"].type(number, "12");
260
-
261
- _react2.fireEvent.blur(number);
262
-
263
- expect(number.value).toBe("12");
264
- var decrement = getAllByRole("button")[1];
265
-
266
- _userEvent["default"].click(decrement);
267
-
268
- expect(number.value).toBe("12");
269
- });
270
- test("Decrement the value when it is greater than the max value", function () {
271
- var _render17 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
272
- label: "Number input label",
273
- max: 10
274
- })),
275
- getByLabelText = _render17.getByLabelText,
276
- getAllByRole = _render17.getAllByRole;
277
-
278
- var number = getByLabelText("Number input label");
279
-
280
- _userEvent["default"].type(number, "12");
281
-
282
- _react2.fireEvent.blur(number);
283
-
284
- expect(number.value).toBe("12");
285
- var decrement = getAllByRole("button")[0];
286
-
287
- _userEvent["default"].click(decrement);
288
-
289
- expect(number.value).toBe("10");
290
- });
291
- test("Increment and decrement the value with min and max values", function () {
292
- var _render18 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
293
- label: "Number input label",
294
- min: 5,
295
- max: 10
296
- })),
297
- getByLabelText = _render18.getByLabelText,
298
- getAllByRole = _render18.getAllByRole;
299
-
300
- var number = getByLabelText("Number input label");
301
-
302
- _userEvent["default"].type(number, "1");
303
-
304
- _react2.fireEvent.blur(number);
305
-
306
- expect(number.value).toBe("1");
307
- var decrement = getAllByRole("button")[0];
308
-
309
- _userEvent["default"].click(decrement);
310
-
311
- expect(number.value).toBe("1");
312
- var increment = getAllByRole("button")[1];
313
-
314
- _userEvent["default"].click(increment);
315
-
316
- expect(number.value).toBe("5");
317
-
318
- _userEvent["default"].click(increment);
319
-
320
- _userEvent["default"].click(increment);
321
-
322
- _userEvent["default"].click(increment);
323
-
324
- _userEvent["default"].click(increment);
325
-
326
- _userEvent["default"].click(increment);
327
-
328
- expect(number.value).toBe("10");
329
-
330
- _userEvent["default"].click(increment);
331
-
332
- expect(number.value).toBe("10");
333
- });
334
- test("Increment and decrement the value with step", function () {
335
- var _render19 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
336
- label: "Number input label",
337
- step: 5
338
- })),
339
- getByLabelText = _render19.getByLabelText,
340
- getAllByRole = _render19.getAllByRole;
341
-
342
- var number = getByLabelText("Number input label");
343
-
344
- _userEvent["default"].type(number, "10");
345
-
346
- _react2.fireEvent.blur(number);
347
-
348
- expect(number.value).toBe("10");
349
- var increment = getAllByRole("button")[1];
350
-
351
- _userEvent["default"].click(increment);
352
-
353
- expect(number.value).toBe("15");
354
-
355
- _userEvent["default"].click(increment);
356
-
357
- expect(number.value).toBe("20");
358
- var decrement = getAllByRole("button")[0];
359
-
360
- _userEvent["default"].click(decrement);
361
-
362
- expect(number.value).toBe("15");
363
-
364
- _userEvent["default"].click(decrement);
365
-
366
- expect(number.value).toBe("10");
367
- });
368
- test("Increment and decrement the value with min, max and step", function () {
369
- var onBlur = jest.fn(function (_ref3) {
370
- var value = _ref3.value,
371
- error = _ref3.error;
372
- expect(value).toBe("1");
373
- expect(error).toBe("Value must be greater than or equal to 5.");
374
- });
375
-
376
- var _render20 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
377
- label: "Number input label",
378
- min: 5,
379
- max: 20,
380
- step: 8,
381
- onBlur: onBlur
382
- })),
383
- getByLabelText = _render20.getByLabelText,
384
- getAllByRole = _render20.getAllByRole;
385
-
386
- var number = getByLabelText("Number input label");
387
-
388
- _userEvent["default"].type(number, "1");
389
-
390
- _react2.fireEvent.blur(number);
391
-
392
- var increment = getAllByRole("button")[1];
393
-
394
- _userEvent["default"].click(increment);
395
-
396
- expect(number.value).toBe("5");
397
-
398
- _userEvent["default"].click(increment);
399
-
400
- expect(number.value).toBe("13");
401
-
402
- _userEvent["default"].click(increment);
403
-
404
- expect(number.value).toBe("20");
405
-
406
- _userEvent["default"].click(increment);
407
-
408
- expect(number.value).toBe("20");
409
- var decrement = getAllByRole("button")[0];
410
-
411
- _userEvent["default"].click(decrement);
412
-
413
- expect(number.value).toBe("12");
414
-
415
- _userEvent["default"].click(decrement);
416
-
417
- expect(number.value).toBe("5");
418
-
419
- _userEvent["default"].click(decrement);
420
-
421
- expect(number.value).toBe("5");
422
- });
283
+ test("Cannot increment the value if it is greater than the max value", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee4() {
284
+ var _render15, getByLabelText, getAllByRole, number, decrement;
285
+ return _regenerator["default"].wrap(function _callee4$(_context4) {
286
+ while (1) switch (_context4.prev = _context4.next) {
287
+ case 0:
288
+ _render15 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
289
+ label: "Number input label",
290
+ max: 10
291
+ })), getByLabelText = _render15.getByLabelText, getAllByRole = _render15.getAllByRole;
292
+ number = getByLabelText("Number input label");
293
+ _userEvent["default"].type(number, "12");
294
+ _react2.fireEvent.blur(number);
295
+ expect(number.value).toBe("12");
296
+ decrement = getAllByRole("button")[1];
297
+ _context4.next = 8;
298
+ return _userEvent["default"].click(decrement);
299
+ case 8:
300
+ expect(number.value).toBe("12");
301
+ case 9:
302
+ case "end":
303
+ return _context4.stop();
304
+ }
305
+ }, _callee4);
306
+ })));
307
+ test("Decrement the value when it is greater than the max value", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee5() {
308
+ var _render16, getByLabelText, getAllByRole, number, decrement;
309
+ return _regenerator["default"].wrap(function _callee5$(_context5) {
310
+ while (1) switch (_context5.prev = _context5.next) {
311
+ case 0:
312
+ _render16 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
313
+ label: "Number input label",
314
+ max: 10
315
+ })), getByLabelText = _render16.getByLabelText, getAllByRole = _render16.getAllByRole;
316
+ number = getByLabelText("Number input label");
317
+ _userEvent["default"].type(number, "120");
318
+ _react2.fireEvent.blur(number);
319
+ expect(number.value).toBe("120");
320
+ decrement = getAllByRole("button")[0];
321
+ _context5.next = 8;
322
+ return _userEvent["default"].click(decrement);
323
+ case 8:
324
+ expect(number.value).toBe("10");
325
+ case 9:
326
+ case "end":
327
+ return _context5.stop();
328
+ }
329
+ }, _callee5);
330
+ })));
331
+ test("Increment and decrement the value with min and max values", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee6() {
332
+ var _render17, getByLabelText, getAllByRole, number, decrement, increment;
333
+ return _regenerator["default"].wrap(function _callee6$(_context6) {
334
+ while (1) switch (_context6.prev = _context6.next) {
335
+ case 0:
336
+ _render17 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
337
+ label: "Number input label",
338
+ min: 5,
339
+ max: 10
340
+ })), getByLabelText = _render17.getByLabelText, getAllByRole = _render17.getAllByRole;
341
+ number = getByLabelText("Number input label");
342
+ _userEvent["default"].type(number, "1");
343
+ _react2.fireEvent.blur(number);
344
+ expect(number.value).toBe("1");
345
+ decrement = getAllByRole("button")[0];
346
+ _context6.next = 8;
347
+ return _userEvent["default"].click(decrement);
348
+ case 8:
349
+ expect(number.value).toBe("1");
350
+ increment = getAllByRole("button")[1];
351
+ _context6.next = 12;
352
+ return _userEvent["default"].click(increment);
353
+ case 12:
354
+ expect(number.value).toBe("5");
355
+ _context6.next = 15;
356
+ return _userEvent["default"].click(increment);
357
+ case 15:
358
+ _context6.next = 17;
359
+ return _userEvent["default"].click(increment);
360
+ case 17:
361
+ _context6.next = 19;
362
+ return _userEvent["default"].click(increment);
363
+ case 19:
364
+ _context6.next = 21;
365
+ return _userEvent["default"].click(increment);
366
+ case 21:
367
+ _context6.next = 23;
368
+ return _userEvent["default"].click(increment);
369
+ case 23:
370
+ expect(number.value).toBe("10");
371
+ _context6.next = 26;
372
+ return _userEvent["default"].click(increment);
373
+ case 26:
374
+ expect(number.value).toBe("10");
375
+ case 27:
376
+ case "end":
377
+ return _context6.stop();
378
+ }
379
+ }, _callee6);
380
+ })));
381
+ test("Increment and decrement the value with an integer step", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee7() {
382
+ var _render18, getByLabelText, getAllByRole, number, increment, decrement;
383
+ return _regenerator["default"].wrap(function _callee7$(_context7) {
384
+ while (1) switch (_context7.prev = _context7.next) {
385
+ case 0:
386
+ _render18 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
387
+ label: "Number input label",
388
+ step: 5
389
+ })), getByLabelText = _render18.getByLabelText, getAllByRole = _render18.getAllByRole;
390
+ number = getByLabelText("Number input label");
391
+ _userEvent["default"].type(number, "10");
392
+ _react2.fireEvent.blur(number);
393
+ expect(number.value).toBe("10");
394
+ increment = getAllByRole("button")[1];
395
+ _context7.next = 8;
396
+ return _userEvent["default"].click(increment);
397
+ case 8:
398
+ expect(number.value).toBe("15");
399
+ _context7.next = 11;
400
+ return _userEvent["default"].click(increment);
401
+ case 11:
402
+ expect(number.value).toBe("20");
403
+ decrement = getAllByRole("button")[0];
404
+ _context7.next = 15;
405
+ return _userEvent["default"].click(decrement);
406
+ case 15:
407
+ expect(number.value).toBe("15");
408
+ _context7.next = 18;
409
+ return _userEvent["default"].click(decrement);
410
+ case 18:
411
+ expect(number.value).toBe("10");
412
+ case 19:
413
+ case "end":
414
+ return _context7.stop();
415
+ }
416
+ }, _callee7);
417
+ })));
418
+ test("Increment and decrement the value with a decimal step", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee8() {
419
+ var _render19, getByLabelText, getAllByRole, number, increment, decrement;
420
+ return _regenerator["default"].wrap(function _callee8$(_context8) {
421
+ while (1) switch (_context8.prev = _context8.next) {
422
+ case 0:
423
+ _render19 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
424
+ label: "Number input label",
425
+ step: 0.5
426
+ })), getByLabelText = _render19.getByLabelText, getAllByRole = _render19.getAllByRole;
427
+ number = getByLabelText("Number input label");
428
+ _userEvent["default"].type(number, "-9");
429
+ _react2.fireEvent.blur(number);
430
+ expect(number.value).toBe("-9");
431
+ increment = getAllByRole("button")[1];
432
+ _context8.next = 8;
433
+ return _userEvent["default"].click(increment);
434
+ case 8:
435
+ expect(number.value).toBe("-8.5");
436
+ _context8.next = 11;
437
+ return _userEvent["default"].click(increment);
438
+ case 11:
439
+ expect(number.value).toBe("-8");
440
+ decrement = getAllByRole("button")[0];
441
+ _context8.next = 15;
442
+ return _userEvent["default"].click(decrement);
443
+ case 15:
444
+ _context8.next = 17;
445
+ return _userEvent["default"].click(decrement);
446
+ case 17:
447
+ _context8.next = 19;
448
+ return _userEvent["default"].click(decrement);
449
+ case 19:
450
+ expect(number.value).toBe("-9.5");
451
+ _context8.next = 22;
452
+ return _userEvent["default"].click(decrement);
453
+ case 22:
454
+ expect(number.value).toBe("-10");
455
+ case 23:
456
+ case "end":
457
+ return _context8.stop();
458
+ }
459
+ }, _callee8);
460
+ })));
461
+ test("Increment and decrement the value with min, max and step", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee9() {
462
+ var onBlur, _render20, getByLabelText, getAllByRole, number, increment, decrement;
463
+ return _regenerator["default"].wrap(function _callee9$(_context9) {
464
+ while (1) switch (_context9.prev = _context9.next) {
465
+ case 0:
466
+ onBlur = jest.fn();
467
+ _render20 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
468
+ label: "Number input label",
469
+ min: 5,
470
+ max: 20,
471
+ step: 8,
472
+ onBlur: onBlur
473
+ })), getByLabelText = _render20.getByLabelText, getAllByRole = _render20.getAllByRole;
474
+ number = getByLabelText("Number input label");
475
+ _userEvent["default"].type(number, "1");
476
+ _react2.fireEvent.blur(number);
477
+ expect(onBlur).toHaveBeenCalledWith({
478
+ value: "1",
479
+ error: "Value must be greater than or equal to 5."
480
+ });
481
+ increment = getAllByRole("button")[1];
482
+ _context9.next = 9;
483
+ return _userEvent["default"].click(increment);
484
+ case 9:
485
+ expect(number.value).toBe("5");
486
+ _context9.next = 12;
487
+ return _userEvent["default"].click(increment);
488
+ case 12:
489
+ expect(number.value).toBe("13");
490
+ _context9.next = 15;
491
+ return _userEvent["default"].click(increment);
492
+ case 15:
493
+ expect(number.value).toBe("13");
494
+ _context9.next = 18;
495
+ return _userEvent["default"].click(increment);
496
+ case 18:
497
+ expect(number.value).toBe("13");
498
+ decrement = getAllByRole("button")[0];
499
+ _context9.next = 22;
500
+ return _userEvent["default"].click(decrement);
501
+ case 22:
502
+ expect(number.value).toBe("5");
503
+ _context9.next = 25;
504
+ return _userEvent["default"].click(decrement);
505
+ case 25:
506
+ expect(number.value).toBe("5");
507
+ _context9.next = 28;
508
+ return _userEvent["default"].click(decrement);
509
+ case 28:
510
+ case "end":
511
+ return _context9.stop();
512
+ }
513
+ }, _callee9);
514
+ })));
515
+ test("Start incrementing from 0 when the min value is less than 0 and the max value is bigger than 0", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee10() {
516
+ var onBlur, _render21, getByLabelText, getAllByRole, number, increment;
517
+ return _regenerator["default"].wrap(function _callee10$(_context10) {
518
+ while (1) switch (_context10.prev = _context10.next) {
519
+ case 0:
520
+ onBlur = jest.fn();
521
+ _render21 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
522
+ label: "Number input label",
523
+ min: -10,
524
+ max: 10,
525
+ step: 1,
526
+ onBlur: onBlur
527
+ })), getByLabelText = _render21.getByLabelText, getAllByRole = _render21.getAllByRole;
528
+ number = getByLabelText("Number input label");
529
+ increment = getAllByRole("button")[1];
530
+ _context10.next = 6;
531
+ return _userEvent["default"].click(increment);
532
+ case 6:
533
+ expect(number.value).toBe("1");
534
+ _context10.next = 9;
535
+ return _userEvent["default"].click(increment);
536
+ case 9:
537
+ expect(number.value).toBe("2");
538
+ case 10:
539
+ case "end":
540
+ return _context10.stop();
541
+ }
542
+ }, _callee10);
543
+ })));
544
+ test("Start incrementing from 0 when the min value is less than 0 and the max is 0", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee11() {
545
+ var _render22, getByLabelText, getAllByRole, number, increment;
546
+ return _regenerator["default"].wrap(function _callee11$(_context11) {
547
+ while (1) switch (_context11.prev = _context11.next) {
548
+ case 0:
549
+ _render22 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
550
+ label: "Number input label",
551
+ min: -10,
552
+ max: 0,
553
+ step: 1
554
+ })), getByLabelText = _render22.getByLabelText, getAllByRole = _render22.getAllByRole;
555
+ number = getByLabelText("Number input label");
556
+ increment = getAllByRole("button")[1];
557
+ _context11.next = 5;
558
+ return _userEvent["default"].click(increment);
559
+ case 5:
560
+ expect(number.value).toBe("0");
561
+ _context11.next = 8;
562
+ return _userEvent["default"].click(increment);
563
+ case 8:
564
+ expect(number.value).toBe("0");
565
+ case 9:
566
+ case "end":
567
+ return _context11.stop();
568
+ }
569
+ }, _callee11);
570
+ })));
571
+ test("Start incrementing from the min value when it is bigger than 0", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee12() {
572
+ var _render23, getByLabelText, getAllByRole, number, increment;
573
+ return _regenerator["default"].wrap(function _callee12$(_context12) {
574
+ while (1) switch (_context12.prev = _context12.next) {
575
+ case 0:
576
+ _render23 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
577
+ label: "Number input label",
578
+ min: 2,
579
+ max: 10,
580
+ step: 0.5
581
+ })), getByLabelText = _render23.getByLabelText, getAllByRole = _render23.getAllByRole;
582
+ number = getByLabelText("Number input label");
583
+ increment = getAllByRole("button")[1];
584
+ _context12.next = 5;
585
+ return _userEvent["default"].click(increment);
586
+ case 5:
587
+ expect(number.value).toBe("2");
588
+ _context12.next = 8;
589
+ return _userEvent["default"].click(increment);
590
+ case 8:
591
+ expect(number.value).toBe("2.5");
592
+ case 9:
593
+ case "end":
594
+ return _context12.stop();
595
+ }
596
+ }, _callee12);
597
+ })));
598
+ test("Start incrementing from the max value when it is less than 0", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee13() {
599
+ var _render24, getByLabelText, getAllByRole, number, increment;
600
+ return _regenerator["default"].wrap(function _callee13$(_context13) {
601
+ while (1) switch (_context13.prev = _context13.next) {
602
+ case 0:
603
+ _render24 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
604
+ label: "Number input label",
605
+ min: -10,
606
+ max: -1,
607
+ step: 0.5
608
+ })), getByLabelText = _render24.getByLabelText, getAllByRole = _render24.getAllByRole;
609
+ number = getByLabelText("Number input label");
610
+ increment = getAllByRole("button")[1];
611
+ _context13.next = 5;
612
+ return _userEvent["default"].click(increment);
613
+ case 5:
614
+ expect(number.value).toBe("-1");
615
+ _context13.next = 8;
616
+ return _userEvent["default"].click(increment);
617
+ case 8:
618
+ expect(number.value).toBe("-1");
619
+ case 9:
620
+ case "end":
621
+ return _context13.stop();
622
+ }
623
+ }, _callee13);
624
+ })));
625
+ test("Start decrementing from 0 when the min value is less than 0 and the max value is bigger than 0", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee14() {
626
+ var _render25, getByLabelText, getAllByRole, number, decrement;
627
+ return _regenerator["default"].wrap(function _callee14$(_context14) {
628
+ while (1) switch (_context14.prev = _context14.next) {
629
+ case 0:
630
+ _render25 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
631
+ label: "Number input label",
632
+ min: -10,
633
+ max: 10,
634
+ step: 1
635
+ })), getByLabelText = _render25.getByLabelText, getAllByRole = _render25.getAllByRole;
636
+ number = getByLabelText("Number input label");
637
+ decrement = getAllByRole("button")[0];
638
+ _context14.next = 5;
639
+ return _userEvent["default"].click(decrement);
640
+ case 5:
641
+ expect(number.value).toBe("-1");
642
+ case 6:
643
+ case "end":
644
+ return _context14.stop();
645
+ }
646
+ }, _callee14);
647
+ })));
648
+ test("Start decrementing from 0 when the min value is 0 and the max value is bigger than 0", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee15() {
649
+ var _render26, getByLabelText, getAllByRole, number, decrement;
650
+ return _regenerator["default"].wrap(function _callee15$(_context15) {
651
+ while (1) switch (_context15.prev = _context15.next) {
652
+ case 0:
653
+ _render26 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
654
+ label: "Number input label",
655
+ min: 0,
656
+ max: 10,
657
+ step: 1
658
+ })), getByLabelText = _render26.getByLabelText, getAllByRole = _render26.getAllByRole;
659
+ number = getByLabelText("Number input label");
660
+ decrement = getAllByRole("button")[0];
661
+ _context15.next = 5;
662
+ return _userEvent["default"].click(decrement);
663
+ case 5:
664
+ expect(number.value).toBe("0");
665
+ case 6:
666
+ case "end":
667
+ return _context15.stop();
668
+ }
669
+ }, _callee15);
670
+ })));
671
+ test("Start decrementing from the min value when it is bigger than 0", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee16() {
672
+ var _render27, getByLabelText, getAllByRole, number, decrement;
673
+ return _regenerator["default"].wrap(function _callee16$(_context16) {
674
+ while (1) switch (_context16.prev = _context16.next) {
675
+ case 0:
676
+ _render27 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
677
+ label: "Number input label",
678
+ min: 2,
679
+ max: 10,
680
+ step: 0.5
681
+ })), getByLabelText = _render27.getByLabelText, getAllByRole = _render27.getAllByRole;
682
+ number = getByLabelText("Number input label");
683
+ decrement = getAllByRole("button")[0];
684
+ _context16.next = 5;
685
+ return _userEvent["default"].click(decrement);
686
+ case 5:
687
+ expect(number.value).toBe("2");
688
+ _context16.next = 8;
689
+ return _userEvent["default"].click(decrement);
690
+ case 8:
691
+ expect(number.value).toBe("2");
692
+ case 9:
693
+ case "end":
694
+ return _context16.stop();
695
+ }
696
+ }, _callee16);
697
+ })));
698
+ test("Start decrementing from the max value when it is less than 0", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee17() {
699
+ var _render28, getByLabelText, getAllByRole, number, decrement;
700
+ return _regenerator["default"].wrap(function _callee17$(_context17) {
701
+ while (1) switch (_context17.prev = _context17.next) {
702
+ case 0:
703
+ _render28 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
704
+ label: "Number input label",
705
+ min: -10,
706
+ max: -1,
707
+ step: 0.5
708
+ })), getByLabelText = _render28.getByLabelText, getAllByRole = _render28.getAllByRole;
709
+ number = getByLabelText("Number input label");
710
+ decrement = getAllByRole("button")[0];
711
+ _context17.next = 5;
712
+ return _userEvent["default"].click(decrement);
713
+ case 5:
714
+ expect(number.value).toBe("-1");
715
+ _context17.next = 8;
716
+ return _userEvent["default"].click(decrement);
717
+ case 8:
718
+ expect(number.value).toBe("-1.5");
719
+ case 9:
720
+ case "end":
721
+ return _context17.stop();
722
+ }
723
+ }, _callee17);
724
+ })));
423
725
  test("Increment and decrement the value with min, max and step using the arrows in keyboard", function () {
424
- var _render21 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
425
- label: "Number input label",
426
- min: 5,
427
- max: 20,
428
- step: 5
429
- })),
430
- getByLabelText = _render21.getByLabelText;
431
-
726
+ var _render29 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
727
+ label: "Number input label",
728
+ min: 5,
729
+ max: 20,
730
+ step: 5
731
+ })),
732
+ getByLabelText = _render29.getByLabelText;
432
733
  var number = getByLabelText("Number input label");
433
-
434
734
  _userEvent["default"].type(number, "1");
435
-
436
735
  _react2.fireEvent.keyDown(number, {
437
736
  keyCode: 38
438
737
  });
439
-
440
738
  expect(number.value).toBe("5");
441
-
442
739
  _react2.fireEvent.keyDown(number, {
443
740
  keyCode: 38
444
741
  });
445
-
446
742
  expect(number.value).toBe("10");
447
-
448
743
  _react2.fireEvent.keyDown(number, {
449
744
  keyCode: 38
450
745
  });
451
-
452
746
  expect(number.value).toBe("15");
453
-
454
747
  _react2.fireEvent.keyDown(number, {
455
748
  keyCode: 38
456
749
  });
457
-
458
750
  expect(number.value).toBe("20");
459
-
460
751
  _react2.fireEvent.keyDown(number, {
461
752
  keyCode: 38
462
753
  });
463
-
464
754
  expect(number.value).toBe("20");
465
-
466
755
  _react2.fireEvent.keyDown(number, {
467
756
  keyCode: 40
468
757
  });
469
-
470
758
  expect(number.value).toBe("15");
471
-
472
759
  _react2.fireEvent.keyDown(number, {
473
760
  keyCode: 40
474
761
  });
475
-
476
762
  expect(number.value).toBe("10");
477
-
478
763
  _react2.fireEvent.keyDown(number, {
479
764
  keyCode: 40
480
765
  });
481
-
482
766
  expect(number.value).toBe("5");
483
-
484
767
  _react2.fireEvent.keyDown(number, {
485
768
  keyCode: 40
486
769
  });
487
-
488
770
  expect(number.value).toBe("5");
489
771
  });
490
- test("Number has correct accesibility attributes", function () {
491
- var _render22 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
492
- label: "Number input label"
493
- })),
494
- getByLabelText = _render22.getByLabelText,
495
- getAllByRole = _render22.getAllByRole;
496
-
772
+ test("Value is unchanged when using the scroll wheel in mouse in a disabled input", function () {
773
+ var _render30 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
774
+ disabled: true,
775
+ label: "Number input label",
776
+ min: 5,
777
+ max: 20,
778
+ step: 5,
779
+ defaultValue: 10
780
+ })),
781
+ getByLabelText = _render30.getByLabelText;
782
+ var number = getByLabelText("Number input label");
783
+ _react2.fireEvent.wheel(number, {
784
+ deltaY: -100
785
+ });
786
+ expect(number.value).toBe("10");
787
+ _react2.fireEvent.wheel(number, {
788
+ deltaY: 100
789
+ });
790
+ expect(number.value).toBe("10");
791
+ _react2.fireEvent.wheel(number, {
792
+ deltaY: -100
793
+ });
794
+ expect(number.value).toBe("10");
795
+ _react2.fireEvent.wheel(number, {
796
+ deltaY: 100
797
+ });
798
+ expect(number.value).toBe("10");
799
+ });
800
+ test("Value is unchanged when using the arrows in keyboard in a disabled input", function () {
801
+ var _render31 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
802
+ disabled: true,
803
+ label: "Number input label",
804
+ min: 5,
805
+ max: 20,
806
+ step: 5,
807
+ defaultValue: 10
808
+ })),
809
+ getByLabelText = _render31.getByLabelText;
810
+ var number = getByLabelText("Number input label");
811
+ _react2.fireEvent.keyDown(number, {
812
+ keyCode: 38
813
+ });
814
+ expect(number.value).toBe("10");
815
+ _react2.fireEvent.keyDown(number, {
816
+ keyCode: 40
817
+ });
818
+ expect(number.value).toBe("10");
819
+ _react2.fireEvent.keyDown(number, {
820
+ keyCode: 38
821
+ });
822
+ expect(number.value).toBe("10");
823
+ _react2.fireEvent.keyDown(number, {
824
+ keyCode: 40
825
+ });
826
+ expect(number.value).toBe("10");
827
+ });
828
+ test("Value is unchanged when using the scroll wheel in mouse in a read-only input", function () {
829
+ var _render32 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
830
+ readOnly: true,
831
+ label: "Number input label",
832
+ min: 5,
833
+ max: 20,
834
+ step: 5,
835
+ defaultValue: 10
836
+ })),
837
+ getByLabelText = _render32.getByLabelText;
838
+ var number = getByLabelText("Number input label");
839
+ _react2.fireEvent.wheel(number, {
840
+ deltaY: -100
841
+ });
842
+ expect(number.value).toBe("10");
843
+ _react2.fireEvent.wheel(number, {
844
+ deltaY: 100
845
+ });
846
+ expect(number.value).toBe("10");
847
+ _react2.fireEvent.wheel(number, {
848
+ deltaY: -100
849
+ });
850
+ expect(number.value).toBe("10");
851
+ _react2.fireEvent.wheel(number, {
852
+ deltaY: 100
853
+ });
854
+ expect(number.value).toBe("10");
855
+ });
856
+ test("Value is unchanged when using the arrows in keyboard in a read-only input", function () {
857
+ var _render33 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
858
+ readOnly: true,
859
+ label: "Number input label",
860
+ min: 5,
861
+ max: 20,
862
+ step: 5,
863
+ defaultValue: 10
864
+ })),
865
+ getByLabelText = _render33.getByLabelText;
866
+ var number = getByLabelText("Number input label");
867
+ _react2.fireEvent.keyDown(number, {
868
+ keyCode: 38
869
+ });
870
+ expect(number.value).toBe("10");
871
+ _react2.fireEvent.keyDown(number, {
872
+ keyCode: 40
873
+ });
874
+ expect(number.value).toBe("10");
875
+ _react2.fireEvent.keyDown(number, {
876
+ keyCode: 38
877
+ });
878
+ expect(number.value).toBe("10");
879
+ _react2.fireEvent.keyDown(number, {
880
+ keyCode: 40
881
+ });
882
+ expect(number.value).toBe("10");
883
+ });
884
+ test("Increment and decrement the value with min, max and step using the scroll wheel in mouse", function () {
885
+ var _render34 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
886
+ label: "Number input label",
887
+ min: 5,
888
+ max: 20,
889
+ step: 5
890
+ })),
891
+ getByLabelText = _render34.getByLabelText;
892
+ var number = getByLabelText("Number input label");
893
+ _userEvent["default"].type(number, "1");
894
+ _react2.fireEvent.wheel(number, {
895
+ deltaY: -100
896
+ });
897
+ expect(number.value).toBe("5");
898
+ _react2.fireEvent.wheel(number, {
899
+ deltaY: -100
900
+ });
901
+ expect(number.value).toBe("10");
902
+ _react2.fireEvent.wheel(number, {
903
+ deltaY: -100
904
+ });
905
+ expect(number.value).toBe("15");
906
+ _react2.fireEvent.wheel(number, {
907
+ deltaY: -100
908
+ });
909
+ expect(number.value).toBe("20");
910
+ _react2.fireEvent.wheel(number, {
911
+ deltaY: -100
912
+ });
913
+ expect(number.value).toBe("20");
914
+ _react2.fireEvent.wheel(number, {
915
+ deltaY: 100
916
+ });
917
+ expect(number.value).toBe("15");
918
+ _react2.fireEvent.wheel(number, {
919
+ deltaY: 100
920
+ });
921
+ expect(number.value).toBe("10");
922
+ _react2.fireEvent.wheel(number, {
923
+ deltaY: 100
924
+ });
925
+ expect(number.value).toBe("5");
926
+ _react2.fireEvent.wheel(number, {
927
+ deltaY: 100
928
+ });
929
+ expect(number.value).toBe("5");
930
+ });
931
+ test("Number has correct accessibility attributes", function () {
932
+ var _render35 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
933
+ label: "Number input label"
934
+ })),
935
+ getByLabelText = _render35.getByLabelText,
936
+ getAllByRole = _render35.getAllByRole;
497
937
  var number = getByLabelText("Number input label");
938
+ expect(number.getAttribute("type")).toBe("number");
498
939
  expect(number.getAttribute("aria-autocomplete")).toBeNull();
499
940
  expect(number.getAttribute("aria-controls")).toBeNull();
500
941
  expect(number.getAttribute("aria-expanded")).toBeNull();
@@ -503,4 +944,46 @@ describe("Number input component tests", function () {
503
944
  var increment = getAllByRole("button")[1];
504
945
  expect(increment.getAttribute("aria-label")).toBe("Increment value");
505
946
  });
947
+ test("Number input submits correct values inside a form and actions don't trigger the submit event", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee18() {
948
+ var handlerOnSubmit, _render36, getByText, getAllByRole, less, more, submit;
949
+ return _regenerator["default"].wrap(function _callee18$(_context18) {
950
+ while (1) switch (_context18.prev = _context18.next) {
951
+ case 0:
952
+ handlerOnSubmit = jest.fn(function (e) {
953
+ e.preventDefault();
954
+ var formData = new FormData(e.target);
955
+ var formProps = Object.fromEntries(formData);
956
+ expect(formProps).toStrictEqual({
957
+ data: "0"
958
+ });
959
+ });
960
+ _render36 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement("form", {
961
+ onSubmit: handlerOnSubmit
962
+ }, /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
963
+ label: "Number input label",
964
+ name: "data"
965
+ }), /*#__PURE__*/_react["default"].createElement("button", {
966
+ type: "submit"
967
+ }, "Submit"))), getByText = _render36.getByText, getAllByRole = _render36.getAllByRole;
968
+ less = getAllByRole("button")[0];
969
+ more = getAllByRole("button")[1];
970
+ submit = getByText("Submit");
971
+ _context18.next = 7;
972
+ return _userEvent["default"].click(more);
973
+ case 7:
974
+ expect(handlerOnSubmit).not.toHaveBeenCalled();
975
+ _context18.next = 10;
976
+ return _userEvent["default"].click(less);
977
+ case 10:
978
+ expect(handlerOnSubmit).not.toHaveBeenCalled();
979
+ _context18.next = 13;
980
+ return _userEvent["default"].click(submit);
981
+ case 13:
982
+ expect(handlerOnSubmit).toHaveBeenCalled();
983
+ case 14:
984
+ case "end":
985
+ return _context18.stop();
986
+ }
987
+ }, _callee18);
988
+ })));
506
989
  });