@dxc-technology/halstack-react 10.1.0 → 12.0.0

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 (350) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +4 -21
  3. package/HalstackContext.d.ts +45 -143
  4. package/HalstackContext.js +10 -35
  5. package/accordion/Accordion.accessibility.test.js +71 -0
  6. package/accordion/Accordion.js +33 -84
  7. package/accordion/Accordion.stories.tsx +8 -64
  8. package/accordion/Accordion.test.js +18 -33
  9. package/accordion/types.d.ts +6 -6
  10. package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
  11. package/accordion-group/AccordionGroup.d.ts +2 -3
  12. package/accordion-group/AccordionGroup.js +17 -44
  13. package/accordion-group/AccordionGroup.stories.tsx +24 -24
  14. package/accordion-group/AccordionGroup.test.js +42 -60
  15. package/accordion-group/AccordionGroupAccordion.js +11 -23
  16. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  17. package/accordion-group/AccordionGroupContext.js +8 -0
  18. package/accordion-group/types.d.ts +7 -7
  19. package/action-icon/ActionIcon.accessibility.test.js +63 -0
  20. package/action-icon/ActionIcon.d.ts +4 -0
  21. package/action-icon/ActionIcon.js +48 -0
  22. package/action-icon/ActionIcon.stories.tsx +41 -0
  23. package/action-icon/ActionIcon.test.js +64 -0
  24. package/action-icon/types.d.ts +26 -0
  25. package/alert/Alert.accessibility.test.js +95 -0
  26. package/alert/Alert.js +34 -120
  27. package/alert/Alert.test.js +28 -45
  28. package/alert/types.d.ts +5 -5
  29. package/badge/Badge.accessibility.test.js +129 -0
  30. package/badge/Badge.d.ts +1 -1
  31. package/badge/Badge.js +142 -42
  32. package/badge/Badge.stories.tsx +210 -0
  33. package/badge/Badge.test.js +30 -0
  34. package/badge/types.d.ts +52 -3
  35. package/bleed/Bleed.js +13 -21
  36. package/bleed/types.d.ts +2 -2
  37. package/box/Box.accessibility.test.js +33 -0
  38. package/box/Box.js +11 -33
  39. package/box/Box.test.js +1 -6
  40. package/box/types.d.ts +3 -3
  41. package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
  42. package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
  43. package/breadcrumbs/Breadcrumbs.d.ts +4 -0
  44. package/breadcrumbs/Breadcrumbs.js +79 -0
  45. package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
  46. package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
  47. package/breadcrumbs/Breadcrumbs.test.js +169 -0
  48. package/breadcrumbs/Item.d.ts +4 -0
  49. package/breadcrumbs/Item.js +52 -0
  50. package/breadcrumbs/dropdownTheme.d.ts +53 -0
  51. package/breadcrumbs/dropdownTheme.js +62 -0
  52. package/breadcrumbs/types.d.ts +16 -0
  53. package/breadcrumbs/types.js +5 -0
  54. package/bulleted-list/BulletedList.accessibility.test.js +119 -0
  55. package/bulleted-list/BulletedList.js +22 -55
  56. package/bulleted-list/BulletedList.stories.tsx +2 -93
  57. package/bulleted-list/types.d.ts +5 -5
  58. package/button/Button.accessibility.test.js +127 -0
  59. package/button/Button.js +36 -59
  60. package/button/Button.stories.tsx +35 -135
  61. package/button/Button.test.js +13 -21
  62. package/button/types.d.ts +5 -5
  63. package/card/Card.accessibility.test.js +36 -0
  64. package/card/Card.js +23 -45
  65. package/card/Card.test.js +10 -21
  66. package/card/types.d.ts +5 -5
  67. package/checkbox/Checkbox.accessibility.test.js +87 -0
  68. package/checkbox/Checkbox.js +88 -123
  69. package/checkbox/Checkbox.stories.tsx +16 -54
  70. package/checkbox/Checkbox.test.js +107 -63
  71. package/checkbox/types.d.ts +8 -4
  72. package/chip/Chip.accessibility.test.js +67 -0
  73. package/chip/Chip.js +22 -36
  74. package/chip/Chip.stories.tsx +10 -25
  75. package/chip/Chip.test.js +17 -30
  76. package/chip/types.d.ts +4 -4
  77. package/common/coreTokens.d.ts +105 -14
  78. package/common/coreTokens.js +40 -23
  79. package/common/utils.js +2 -8
  80. package/common/variables.d.ts +46 -144
  81. package/common/variables.js +120 -225
  82. package/container/Container.d.ts +4 -0
  83. package/container/Container.js +194 -0
  84. package/container/Container.stories.tsx +214 -0
  85. package/container/types.d.ts +74 -0
  86. package/container/types.js +5 -0
  87. package/contextual-menu/ContextualMenu.accessibility.test.js +97 -0
  88. package/contextual-menu/ContextualMenu.d.ts +5 -0
  89. package/contextual-menu/ContextualMenu.js +88 -0
  90. package/contextual-menu/ContextualMenu.stories.tsx +232 -0
  91. package/contextual-menu/ContextualMenu.test.js +205 -0
  92. package/contextual-menu/GroupItem.d.ts +4 -0
  93. package/contextual-menu/GroupItem.js +67 -0
  94. package/contextual-menu/ItemAction.d.ts +4 -0
  95. package/contextual-menu/ItemAction.js +51 -0
  96. package/contextual-menu/MenuItem.d.ts +4 -0
  97. package/contextual-menu/MenuItem.js +29 -0
  98. package/contextual-menu/SingleItem.d.ts +4 -0
  99. package/contextual-menu/SingleItem.js +38 -0
  100. package/contextual-menu/types.d.ts +58 -0
  101. package/contextual-menu/types.js +5 -0
  102. package/date-input/Calendar.js +13 -57
  103. package/date-input/DateInput.accessibility.test.js +228 -0
  104. package/date-input/DateInput.js +53 -100
  105. package/date-input/DateInput.stories.tsx +19 -31
  106. package/date-input/DateInput.test.js +674 -701
  107. package/date-input/DatePicker.js +23 -48
  108. package/date-input/YearPicker.js +8 -34
  109. package/date-input/types.d.ts +28 -22
  110. package/dialog/Dialog.accessibility.test.js +69 -0
  111. package/dialog/Dialog.js +21 -59
  112. package/dialog/Dialog.stories.tsx +176 -0
  113. package/dialog/Dialog.test.js +126 -188
  114. package/dialog/types.d.ts +18 -13
  115. package/divider/Divider.accessibility.test.js +33 -0
  116. package/divider/Divider.d.ts +4 -0
  117. package/divider/Divider.js +36 -0
  118. package/divider/Divider.stories.tsx +223 -0
  119. package/divider/Divider.test.js +38 -0
  120. package/divider/types.d.ts +21 -0
  121. package/divider/types.js +5 -0
  122. package/dropdown/Dropdown.accessibility.test.js +180 -0
  123. package/dropdown/Dropdown.js +63 -130
  124. package/dropdown/Dropdown.stories.tsx +15 -26
  125. package/dropdown/Dropdown.test.js +402 -389
  126. package/dropdown/DropdownMenu.js +12 -23
  127. package/dropdown/DropdownMenuItem.js +13 -21
  128. package/dropdown/types.d.ts +20 -24
  129. package/file-input/FileInput.accessibility.test.js +160 -0
  130. package/file-input/FileInput.js +180 -284
  131. package/file-input/FileInput.stories.tsx +1 -1
  132. package/file-input/FileInput.test.js +279 -354
  133. package/file-input/FileItem.js +29 -66
  134. package/file-input/types.d.ts +9 -9
  135. package/flex/Flex.js +25 -39
  136. package/flex/types.d.ts +6 -6
  137. package/footer/Footer.accessibility.test.js +125 -0
  138. package/footer/Footer.d.ts +1 -1
  139. package/footer/Footer.js +43 -68
  140. package/footer/Footer.stories.tsx +58 -2
  141. package/footer/Footer.test.js +18 -32
  142. package/footer/Icons.d.ts +3 -2
  143. package/footer/Icons.js +53 -22
  144. package/footer/types.d.ts +17 -17
  145. package/grid/Grid.js +1 -16
  146. package/grid/types.d.ts +10 -10
  147. package/header/Header.accessibility.test.js +93 -0
  148. package/header/Header.d.ts +1 -1
  149. package/header/Header.js +38 -104
  150. package/header/Header.stories.tsx +16 -0
  151. package/header/Header.test.js +12 -25
  152. package/header/Icons.d.ts +2 -2
  153. package/header/Icons.js +3 -13
  154. package/header/types.d.ts +7 -8
  155. package/heading/Heading.accessibility.test.js +33 -0
  156. package/heading/Heading.js +9 -31
  157. package/heading/Heading.test.js +70 -87
  158. package/heading/types.d.ts +7 -7
  159. package/icon/Icon.accessibility.test.js +30 -0
  160. package/icon/Icon.d.ts +4 -0
  161. package/icon/Icon.js +33 -0
  162. package/icon/Icon.stories.tsx +28 -0
  163. package/icon/types.d.ts +4 -0
  164. package/icon/types.js +5 -0
  165. package/image/Image.accessibility.test.js +56 -0
  166. package/image/Image.d.ts +2 -2
  167. package/image/Image.js +17 -32
  168. package/image/Image.stories.tsx +3 -1
  169. package/image/types.d.ts +2 -2
  170. package/inset/Inset.js +13 -21
  171. package/inset/types.d.ts +2 -2
  172. package/layout/ApplicationLayout.d.ts +2 -2
  173. package/layout/ApplicationLayout.js +23 -60
  174. package/layout/Icons.d.ts +4 -5
  175. package/layout/Icons.js +2 -16
  176. package/layout/types.d.ts +3 -3
  177. package/link/Link.accessibility.test.js +108 -0
  178. package/link/Link.js +28 -47
  179. package/link/Link.stories.tsx +4 -4
  180. package/link/Link.test.js +23 -41
  181. package/link/types.d.ts +14 -14
  182. package/main.d.ts +8 -4
  183. package/main.js +39 -60
  184. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  185. package/nav-tabs/NavTabs.d.ts +1 -2
  186. package/nav-tabs/NavTabs.js +19 -48
  187. package/nav-tabs/NavTabs.stories.tsx +30 -25
  188. package/nav-tabs/NavTabs.test.js +45 -50
  189. package/nav-tabs/NavTabsContext.d.ts +3 -0
  190. package/nav-tabs/NavTabsContext.js +8 -0
  191. package/nav-tabs/Tab.js +38 -67
  192. package/nav-tabs/types.d.ts +10 -10
  193. package/number-input/NumberInput.accessibility.test.js +228 -0
  194. package/number-input/NumberInput.d.ts +0 -7
  195. package/number-input/NumberInput.js +47 -39
  196. package/number-input/NumberInput.stories.tsx +42 -26
  197. package/number-input/NumberInput.test.js +839 -575
  198. package/number-input/NumberInputContext.d.ts +3 -0
  199. package/number-input/NumberInputContext.js +8 -0
  200. package/number-input/types.d.ts +17 -5
  201. package/package.json +41 -37
  202. package/paginator/Paginator.accessibility.test.js +79 -0
  203. package/paginator/Paginator.js +27 -52
  204. package/paginator/Paginator.test.js +224 -207
  205. package/paginator/types.d.ts +3 -3
  206. package/paragraph/Paragraph.accessibility.test.js +28 -0
  207. package/paragraph/Paragraph.js +3 -19
  208. package/paragraph/Paragraph.stories.tsx +0 -17
  209. package/password-input/PasswordInput.accessibility.test.js +153 -0
  210. package/password-input/PasswordInput.js +32 -54
  211. package/password-input/PasswordInput.stories.tsx +1 -34
  212. package/password-input/PasswordInput.test.js +153 -129
  213. package/password-input/types.d.ts +8 -7
  214. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  215. package/progress-bar/ProgressBar.js +26 -56
  216. package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +1 -1
  217. package/progress-bar/ProgressBar.test.js +35 -52
  218. package/progress-bar/types.d.ts +3 -3
  219. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  220. package/quick-nav/QuickNav.js +4 -27
  221. package/quick-nav/QuickNav.stories.tsx +1 -1
  222. package/quick-nav/types.d.ts +10 -10
  223. package/radio-group/Radio.d.ts +1 -1
  224. package/radio-group/Radio.js +22 -54
  225. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  226. package/radio-group/RadioGroup.js +38 -83
  227. package/radio-group/RadioGroup.stories.tsx +10 -10
  228. package/radio-group/RadioGroup.test.js +504 -470
  229. package/radio-group/types.d.ts +8 -8
  230. package/resultset-table/Icons.d.ts +7 -0
  231. package/{resultsetTable → resultset-table}/Icons.js +1 -5
  232. package/resultset-table/ResultsetTable.accessibility.test.js +285 -0
  233. package/resultset-table/ResultsetTable.d.ts +7 -0
  234. package/{resultsetTable → resultset-table}/ResultsetTable.js +45 -69
  235. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +118 -5
  236. package/{resultsetTable → resultset-table}/ResultsetTable.test.js +148 -92
  237. package/{resultsetTable → resultset-table}/types.d.ts +44 -11
  238. package/resultset-table/types.js +5 -0
  239. package/select/Listbox.js +40 -54
  240. package/select/Option.js +28 -36
  241. package/select/Select.accessibility.test.js +228 -0
  242. package/select/Select.js +107 -171
  243. package/select/Select.stories.tsx +59 -111
  244. package/select/Select.test.js +1895 -1858
  245. package/select/types.d.ts +15 -16
  246. package/sidenav/Sidenav.accessibility.test.js +59 -0
  247. package/sidenav/Sidenav.js +44 -81
  248. package/sidenav/Sidenav.stories.tsx +4 -9
  249. package/sidenav/Sidenav.test.js +3 -10
  250. package/{layout → sidenav}/SidenavContext.d.ts +1 -1
  251. package/{layout → sidenav}/SidenavContext.js +3 -9
  252. package/sidenav/types.d.ts +20 -20
  253. package/slider/Slider.accessibility.test.js +104 -0
  254. package/slider/Slider.js +70 -126
  255. package/slider/Slider.test.js +107 -103
  256. package/slider/types.d.ts +4 -4
  257. package/spinner/Spinner.accessibility.test.js +96 -0
  258. package/spinner/Spinner.js +21 -55
  259. package/spinner/Spinner.test.js +25 -34
  260. package/spinner/types.d.ts +3 -3
  261. package/status-light/StatusLight.accessibility.test.js +157 -0
  262. package/status-light/StatusLight.d.ts +4 -0
  263. package/status-light/StatusLight.js +51 -0
  264. package/status-light/StatusLight.stories.tsx +74 -0
  265. package/status-light/StatusLight.test.js +25 -0
  266. package/status-light/types.d.ts +17 -0
  267. package/status-light/types.js +5 -0
  268. package/switch/Switch.accessibility.test.js +98 -0
  269. package/switch/Switch.js +49 -97
  270. package/switch/Switch.stories.tsx +12 -34
  271. package/switch/Switch.test.js +51 -96
  272. package/switch/types.d.ts +4 -4
  273. package/table/DropdownTheme.js +62 -0
  274. package/table/Table.accessibility.test.js +93 -0
  275. package/table/Table.d.ts +6 -2
  276. package/table/Table.js +76 -33
  277. package/table/{Table.stories.jsx → Table.stories.tsx} +309 -2
  278. package/table/Table.test.js +93 -6
  279. package/table/types.d.ts +34 -6
  280. package/tabs/Tab.js +22 -37
  281. package/tabs/Tabs.accessibility.test.js +56 -0
  282. package/tabs/Tabs.js +59 -147
  283. package/tabs/Tabs.stories.tsx +8 -4
  284. package/tabs/Tabs.test.js +57 -131
  285. package/tabs/types.d.ts +21 -21
  286. package/tag/Tag.accessibility.test.js +69 -0
  287. package/tag/Tag.js +27 -57
  288. package/tag/Tag.stories.tsx +4 -7
  289. package/tag/Tag.test.js +17 -36
  290. package/tag/types.d.ts +9 -9
  291. package/text-input/Suggestion.js +9 -26
  292. package/text-input/Suggestions.d.ts +1 -1
  293. package/text-input/Suggestions.js +30 -70
  294. package/text-input/TextInput.accessibility.test.js +321 -0
  295. package/text-input/TextInput.js +203 -289
  296. package/text-input/TextInput.stories.tsx +65 -160
  297. package/text-input/TextInput.test.js +1227 -1194
  298. package/text-input/types.d.ts +25 -17
  299. package/textarea/Textarea.accessibility.test.js +155 -0
  300. package/textarea/Textarea.js +68 -109
  301. package/textarea/{Textarea.stories.jsx → Textarea.stories.tsx} +58 -100
  302. package/textarea/Textarea.test.js +150 -179
  303. package/textarea/types.d.ts +9 -5
  304. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  305. package/toggle-group/ToggleGroup.js +25 -64
  306. package/toggle-group/ToggleGroup.stories.tsx +4 -4
  307. package/toggle-group/ToggleGroup.test.js +48 -81
  308. package/toggle-group/types.d.ts +12 -12
  309. package/typography/Typography.accessibility.test.js +339 -0
  310. package/typography/Typography.js +4 -13
  311. package/typography/types.d.ts +1 -1
  312. package/useTheme.d.ts +43 -141
  313. package/useTheme.js +1 -8
  314. package/useTranslatedLabels.js +1 -7
  315. package/utils/BaseTypography.d.ts +2 -2
  316. package/utils/BaseTypography.js +16 -30
  317. package/utils/FocusLock.js +25 -39
  318. package/wizard/Wizard.accessibility.test.js +55 -0
  319. package/wizard/Wizard.js +27 -73
  320. package/wizard/Wizard.stories.tsx +19 -0
  321. package/wizard/Wizard.test.js +53 -80
  322. package/wizard/types.d.ts +8 -8
  323. package/common/OpenSans.css +0 -69
  324. package/common/fonts/OpenSans-Bold.ttf +0 -0
  325. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  326. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  327. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  328. package/common/fonts/OpenSans-Italic.ttf +0 -0
  329. package/common/fonts/OpenSans-Light.ttf +0 -0
  330. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  331. package/common/fonts/OpenSans-Regular.ttf +0 -0
  332. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  333. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  334. package/date-input/Icons.d.ts +0 -6
  335. package/date-input/Icons.js +0 -75
  336. package/paginator/Icons.d.ts +0 -5
  337. package/paginator/Icons.js +0 -54
  338. package/password-input/Icons.d.ts +0 -6
  339. package/password-input/Icons.js +0 -39
  340. package/resultsetTable/Icons.d.ts +0 -7
  341. package/resultsetTable/ResultsetTable.d.ts +0 -4
  342. package/select/Icons.d.ts +0 -10
  343. package/select/Icons.js +0 -93
  344. package/sidenav/Icons.d.ts +0 -7
  345. package/sidenav/Icons.js +0 -51
  346. package/slider/Slider.stories.tsx +0 -240
  347. package/text-input/Icons.d.ts +0 -8
  348. package/text-input/Icons.js +0 -60
  349. /package/{resultsetTable → action-icon}/types.js +0 -0
  350. /package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +0 -0
@@ -1,26 +1,54 @@
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
11
  var _NumberInput = _interopRequireDefault(require("./NumberInput.tsx"));
12
-
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
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
- helperText: "Helper text",
18
- placeholder: "Placeholder"
19
- })),
20
- getByLabelText = _render.getByLabelText,
21
- getByText = _render.getByText,
22
- queryAllByRole = _render.queryAllByRole;
23
-
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;
24
52
  var number = getByLabelText("Number input label");
25
53
  expect(getByText("Number input label")).toBeTruthy();
26
54
  expect(getByText("Helper text")).toBeTruthy();
@@ -29,51 +57,86 @@ describe("Number input component tests", function () {
29
57
  });
30
58
  test("Number input buttons' tooltip is correct", function () {
31
59
  var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
32
- label: "Number label"
33
- })),
34
- getByTitle = _render2.getByTitle;
35
-
60
+ label: "Number label"
61
+ })),
62
+ getByTitle = _render2.getByTitle;
36
63
  expect(getByTitle("Decrement value")).toBeTruthy();
37
64
  expect(getByTitle("Increment value")).toBeTruthy();
38
65
  });
39
66
  test("Number input is disabled", function () {
40
67
  var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
41
- label: "Number label",
42
- disabled: true
43
- })),
44
- getByLabelText = _render3.getByLabelText;
45
-
68
+ label: "Number label",
69
+ disabled: true
70
+ })),
71
+ getByLabelText = _render3.getByLabelText;
46
72
  var number = getByLabelText("Number label");
47
73
  expect(number.disabled).toBeTruthy();
48
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
+ });
49
119
  test("Number input is optional", function () {
50
- var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
51
- label: "Number label",
52
- optional: true
53
- })),
54
- getByText = _render4.getByText;
55
-
120
+ var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
121
+ label: "Number label",
122
+ optional: true
123
+ })),
124
+ getByText = _render6.getByText;
56
125
  expect(getByText("(Optional)")).toBeTruthy();
57
126
  });
58
127
  test("Number input is not optional: required field, displays error if not filled in", function () {
59
128
  var onBlur = jest.fn();
60
129
  var onChange = jest.fn();
61
-
62
- var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
63
- label: "Number input label",
64
- onBlur: onBlur,
65
- onChange: onChange
66
- })),
67
- getByLabelText = _render5.getByLabelText;
68
-
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;
69
136
  var number = getByLabelText("Number input label");
70
-
71
137
  _userEvent["default"].type(number, "1");
72
-
73
138
  _userEvent["default"].clear(number);
74
-
75
139
  _react2.fireEvent.blur(number);
76
-
77
140
  expect(onBlur).toHaveBeenCalled();
78
141
  expect(onBlur).toHaveBeenCalledWith({
79
142
  value: "",
@@ -86,595 +149,791 @@ describe("Number input component tests", function () {
86
149
  });
87
150
  });
88
151
  test("Suffix and prefix must be shown", function () {
89
- var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
90
- label: "Number input label",
91
- prefix: "+34",
92
- suffix: "USD"
93
- })),
94
- getByText = _render6.getByText;
95
-
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;
96
158
  expect(getByText("+34")).toBeTruthy();
97
159
  expect(getByText("USD")).toBeTruthy();
98
160
  });
99
161
  test("Invalid number input renders error", function () {
100
- var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
101
- error: "Error message."
102
- })),
103
- getByText = _render7.getByText;
104
-
162
+ var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
163
+ error: "Error message."
164
+ })),
165
+ getByText = _render9.getByText;
105
166
  expect(getByText("Error message.")).toBeTruthy();
106
167
  });
107
168
  test("onChange function is called correctly", function () {
108
169
  var onChange = jest.fn();
109
-
110
- var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
111
- label: "Number input label",
112
- onChange: onChange
113
- })),
114
- getByLabelText = _render8.getByLabelText;
115
-
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;
116
175
  var number = getByLabelText("Number input label");
117
-
118
176
  _userEvent["default"].type(number, "t");
119
-
120
177
  expect(onChange).not.toHaveBeenCalledWith({
121
178
  value: "t"
122
179
  });
123
180
  expect(number.value).toBe("");
124
-
125
181
  _userEvent["default"].type(number, "1");
126
-
127
182
  expect(onChange).toHaveBeenCalledWith({
128
183
  value: "1"
129
184
  });
130
185
  expect(number.value).toBe("1");
131
186
  });
132
187
  test("Error message is shown if the typed value is less than the min value", function () {
133
- var onChange = jest.fn(function (_ref) {
134
- var value = _ref.value,
135
- error = _ref.error;
188
+ var onChange = jest.fn(function (_ref2) {
189
+ var value = _ref2.value,
190
+ error = _ref2.error;
136
191
  expect(value).toBe("-1");
137
192
  expect(error).toBe("Value must be greater than or equal to 0.");
138
193
  });
139
- var onBlur = jest.fn(function (_ref2) {
140
- var value = _ref2.value,
141
- error = _ref2.error;
194
+ var onBlur = jest.fn(function (_ref3) {
195
+ var value = _ref3.value,
196
+ error = _ref3.error;
142
197
  expect(value).toBe("-1");
143
198
  expect(error).toBe("Value must be greater than or equal to 0.");
144
199
  });
145
-
146
- var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
147
- label: "Number input label",
148
- min: 0,
149
- onBlur: onBlur,
150
- onChange: onChange
151
- })),
152
- getByLabelText = _render9.getByLabelText;
153
-
154
- var number = getByLabelText("Number input label");
155
-
156
- _userEvent["default"].type(number, "-1");
157
-
158
- _react2.fireEvent.blur(number);
159
- });
160
- test("Cannot decrement the value if it is less than the min value", function () {
161
- var _render10 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
162
- label: "Number input label",
163
- min: 5
164
- })),
165
- getByLabelText = _render10.getByLabelText,
166
- getAllByRole = _render10.getAllByRole;
167
-
168
- var number = getByLabelText("Number input label");
169
-
170
- _userEvent["default"].type(number, "1");
171
-
172
- _react2.fireEvent.blur(number);
173
-
174
- expect(number.value).toBe("1");
175
- var decrement = getAllByRole("button")[0];
176
-
177
- _userEvent["default"].click(decrement);
178
-
179
- expect(number.value).toBe("1");
180
- });
181
- test("Increment the value when it is less than the min value", function () {
182
200
  var _render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
183
- label: "Number input label",
184
- min: 5
185
- })),
186
- getByLabelText = _render11.getByLabelText,
187
- getAllByRole = _render11.getAllByRole;
188
-
201
+ label: "Number input label",
202
+ min: 0,
203
+ onBlur: onBlur,
204
+ onChange: onChange
205
+ })),
206
+ getByLabelText = _render11.getByLabelText;
189
207
  var number = getByLabelText("Number input label");
190
-
191
- _userEvent["default"].type(number, "1");
192
-
208
+ _userEvent["default"].type(number, "-1");
193
209
  _react2.fireEvent.blur(number);
194
-
195
- expect(number.value).toBe("1");
196
- var increment = getAllByRole("button")[1];
197
-
198
- _userEvent["default"].click(increment);
199
-
200
- expect(number.value).toBe("5");
201
210
  });
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
+ })));
202
259
  test("Error message is shown if the typed value is greater than the max value", function () {
203
260
  var onChange = jest.fn();
204
261
  var onBlur = jest.fn();
205
-
206
- var _render12 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
207
- label: "Number input label",
208
- max: 10,
209
- onBlur: onBlur,
210
- onChange: onChange
211
- })),
212
- getByLabelText = _render12.getByLabelText;
213
-
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;
214
269
  var number = getByLabelText("Number input label");
215
-
216
270
  _userEvent["default"].type(number, "12");
217
-
218
271
  expect(onChange).toHaveBeenCalledTimes(2);
219
272
  expect(onChange).toHaveBeenCalledWith({
220
273
  value: "12",
221
274
  error: "Value must be less than or equal to 10."
222
275
  });
223
-
224
276
  _react2.fireEvent.blur(number);
225
-
226
277
  expect(onBlur).toHaveBeenCalled();
227
278
  expect(onBlur).toHaveBeenCalledWith({
228
279
  value: "12",
229
280
  error: "Value must be less than or equal to 10."
230
281
  });
231
282
  });
232
- test("Cannot increment the value if it is greater than the max value", function () {
233
- var _render13 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
234
- label: "Number input label",
235
- max: 10
236
- })),
237
- getByLabelText = _render13.getByLabelText,
238
- getAllByRole = _render13.getAllByRole;
239
-
240
- var number = getByLabelText("Number input label");
241
-
242
- _userEvent["default"].type(number, "12");
243
-
244
- _react2.fireEvent.blur(number);
245
-
246
- expect(number.value).toBe("12");
247
- var decrement = getAllByRole("button")[1];
248
-
249
- _userEvent["default"].click(decrement);
250
-
251
- expect(number.value).toBe("12");
252
- });
253
- test("Decrement the value when it is greater than the max value", function () {
254
- var _render14 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
255
- label: "Number input label",
256
- max: 10
257
- })),
258
- getByLabelText = _render14.getByLabelText,
259
- getAllByRole = _render14.getAllByRole;
260
-
261
- var number = getByLabelText("Number input label");
262
-
263
- _userEvent["default"].type(number, "120");
264
-
265
- _react2.fireEvent.blur(number);
266
-
267
- expect(number.value).toBe("120");
268
- var decrement = getAllByRole("button")[0];
269
-
270
- _userEvent["default"].click(decrement);
271
-
272
- expect(number.value).toBe("10");
273
- });
274
- test("Increment and decrement the value with min and max values", function () {
275
- var _render15 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
276
- label: "Number input label",
277
- min: 5,
278
- max: 10
279
- })),
280
- getByLabelText = _render15.getByLabelText,
281
- getAllByRole = _render15.getAllByRole;
282
-
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
+ })));
725
+ test("Increment and decrement the value with min, max and step using the arrows in keyboard", function () {
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;
283
733
  var number = getByLabelText("Number input label");
284
-
285
734
  _userEvent["default"].type(number, "1");
286
-
287
- _react2.fireEvent.blur(number);
288
-
289
- expect(number.value).toBe("1");
290
- var decrement = getAllByRole("button")[0];
291
-
292
- _userEvent["default"].click(decrement);
293
-
294
- expect(number.value).toBe("1");
295
- var increment = getAllByRole("button")[1];
296
-
297
- _userEvent["default"].click(increment);
298
-
735
+ _react2.fireEvent.keyDown(number, {
736
+ keyCode: 38
737
+ });
299
738
  expect(number.value).toBe("5");
300
-
301
- _userEvent["default"].click(increment);
302
-
303
- _userEvent["default"].click(increment);
304
-
305
- _userEvent["default"].click(increment);
306
-
307
- _userEvent["default"].click(increment);
308
-
309
- _userEvent["default"].click(increment);
310
-
311
- expect(number.value).toBe("10");
312
-
313
- _userEvent["default"].click(increment);
314
-
315
- expect(number.value).toBe("10");
316
- });
317
- test("Increment and decrement the value with an integer step", function () {
318
- var _render16 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
319
- label: "Number input label",
320
- step: 5
321
- })),
322
- getByLabelText = _render16.getByLabelText,
323
- getAllByRole = _render16.getAllByRole;
324
-
325
- var number = getByLabelText("Number input label");
326
-
327
- _userEvent["default"].type(number, "10");
328
-
329
- _react2.fireEvent.blur(number);
330
-
739
+ _react2.fireEvent.keyDown(number, {
740
+ keyCode: 38
741
+ });
331
742
  expect(number.value).toBe("10");
332
- var increment = getAllByRole("button")[1];
333
-
334
- _userEvent["default"].click(increment);
335
-
743
+ _react2.fireEvent.keyDown(number, {
744
+ keyCode: 38
745
+ });
336
746
  expect(number.value).toBe("15");
337
-
338
- _userEvent["default"].click(increment);
339
-
747
+ _react2.fireEvent.keyDown(number, {
748
+ keyCode: 38
749
+ });
340
750
  expect(number.value).toBe("20");
341
- var decrement = getAllByRole("button")[0];
342
-
343
- _userEvent["default"].click(decrement);
344
-
751
+ _react2.fireEvent.keyDown(number, {
752
+ keyCode: 38
753
+ });
754
+ expect(number.value).toBe("20");
755
+ _react2.fireEvent.keyDown(number, {
756
+ keyCode: 40
757
+ });
345
758
  expect(number.value).toBe("15");
346
-
347
- _userEvent["default"].click(decrement);
348
-
759
+ _react2.fireEvent.keyDown(number, {
760
+ keyCode: 40
761
+ });
349
762
  expect(number.value).toBe("10");
350
- });
351
- test("Increment and decrement the value with a decimal step", function () {
352
- var _render17 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
353
- label: "Number input label",
354
- step: 0.5
355
- })),
356
- getByLabelText = _render17.getByLabelText,
357
- getAllByRole = _render17.getAllByRole;
358
-
359
- var number = getByLabelText("Number input label");
360
-
361
- _userEvent["default"].type(number, "-9");
362
-
363
- _react2.fireEvent.blur(number);
364
-
365
- expect(number.value).toBe("-9");
366
- var increment = getAllByRole("button")[1];
367
-
368
- _userEvent["default"].click(increment);
369
-
370
- expect(number.value).toBe("-8.5");
371
-
372
- _userEvent["default"].click(increment);
373
-
374
- expect(number.value).toBe("-8");
375
- var decrement = getAllByRole("button")[0];
376
-
377
- _userEvent["default"].click(decrement);
378
-
379
- _userEvent["default"].click(decrement);
380
-
381
- _userEvent["default"].click(decrement);
382
-
383
- expect(number.value).toBe("-9.5");
384
-
385
- _userEvent["default"].click(decrement);
386
-
387
- expect(number.value).toBe("-10");
388
- });
389
- test("Increment and decrement the value with min, max and step", function () {
390
- var onBlur = jest.fn();
391
-
392
- var _render18 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
393
- label: "Number input label",
394
- min: 5,
395
- max: 20,
396
- step: 8,
397
- onBlur: onBlur
398
- })),
399
- getByLabelText = _render18.getByLabelText,
400
- getAllByRole = _render18.getAllByRole;
401
-
402
- var number = getByLabelText("Number input label");
403
-
404
- _userEvent["default"].type(number, "1");
405
-
406
- _react2.fireEvent.blur(number);
407
-
408
- expect(onBlur).toHaveBeenCalledWith({
409
- value: "1",
410
- error: "Value must be greater than or equal to 5."
763
+ _react2.fireEvent.keyDown(number, {
764
+ keyCode: 40
411
765
  });
412
- var increment = getAllByRole("button")[1];
413
-
414
- _userEvent["default"].click(increment);
415
-
416
766
  expect(number.value).toBe("5");
417
-
418
- _userEvent["default"].click(increment);
419
-
420
- expect(number.value).toBe("13");
421
-
422
- _userEvent["default"].click(increment);
423
-
424
- expect(number.value).toBe("13");
425
-
426
- _userEvent["default"].click(increment);
427
-
428
- expect(number.value).toBe("13");
429
- var decrement = getAllByRole("button")[0];
430
-
431
- _userEvent["default"].click(decrement);
432
-
433
- expect(number.value).toBe("5");
434
-
435
- _userEvent["default"].click(decrement);
436
-
767
+ _react2.fireEvent.keyDown(number, {
768
+ keyCode: 40
769
+ });
437
770
  expect(number.value).toBe("5");
438
-
439
- _userEvent["default"].click(decrement);
440
771
  });
441
- test("Start incrementing from 0 when the min value is less than 0 and the max value is bigger than 0", function () {
442
- var onBlur = jest.fn();
443
-
444
- var _render19 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
445
- label: "Number input label",
446
- min: -10,
447
- max: 10,
448
- step: 1,
449
- onBlur: onBlur
450
- })),
451
- getByLabelText = _render19.getByLabelText,
452
- getAllByRole = _render19.getAllByRole;
453
-
454
- var number = getByLabelText("Number input label");
455
- var increment = getAllByRole("button")[1];
456
-
457
- _userEvent["default"].click(increment);
458
-
459
- expect(number.value).toBe("1");
460
-
461
- _userEvent["default"].click(increment);
462
-
463
- expect(number.value).toBe("2");
464
- });
465
- test("Start incrementing from 0 when the min value is less than 0 and the max is 0", function () {
466
- var _render20 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
467
- label: "Number input label",
468
- min: -10,
469
- max: 0,
470
- step: 1
471
- })),
472
- getByLabelText = _render20.getByLabelText,
473
- getAllByRole = _render20.getAllByRole;
474
-
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;
475
782
  var number = getByLabelText("Number input label");
476
- var increment = getAllByRole("button")[1];
477
-
478
- _userEvent["default"].click(increment);
479
-
480
- expect(number.value).toBe("0");
481
-
482
- _userEvent["default"].click(increment);
483
-
484
- expect(number.value).toBe("0");
485
- });
486
- test("Start incrementing from the min value when it is bigger than 0", function () {
487
- var _render21 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
488
- label: "Number input label",
489
- min: 2,
490
- max: 10,
491
- step: 0.5
492
- })),
493
- getByLabelText = _render21.getByLabelText,
494
- getAllByRole = _render21.getAllByRole;
495
-
496
- var number = getByLabelText("Number input label");
497
- var increment = getAllByRole("button")[1];
498
-
499
- _userEvent["default"].click(increment);
500
-
501
- expect(number.value).toBe("2");
502
-
503
- _userEvent["default"].click(increment);
504
-
505
- expect(number.value).toBe("2.5");
506
- });
507
- test("Start incrementing from the max value when it is less than 0", function () {
508
- var _render22 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
509
- label: "Number input label",
510
- min: -10,
511
- max: -1,
512
- step: 0.5
513
- })),
514
- getByLabelText = _render22.getByLabelText,
515
- getAllByRole = _render22.getAllByRole;
516
-
517
- var number = getByLabelText("Number input label");
518
- var increment = getAllByRole("button")[1];
519
-
520
- _userEvent["default"].click(increment);
521
-
522
- expect(number.value).toBe("-1");
523
-
524
- _userEvent["default"].click(increment);
525
-
526
- expect(number.value).toBe("-1");
527
- });
528
- test("Start decrementing from 0 when the min value is less than 0 and the max value is bigger than 0", function () {
529
- var _render23 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
530
- label: "Number input label",
531
- min: -10,
532
- max: 10,
533
- step: 1
534
- })),
535
- getByLabelText = _render23.getByLabelText,
536
- getAllByRole = _render23.getAllByRole;
537
-
538
- var number = getByLabelText("Number input label");
539
- var decrement = getAllByRole("button")[0];
540
-
541
- _userEvent["default"].click(decrement);
542
-
543
- expect(number.value).toBe("-1");
544
- });
545
- test("Start decrementing from 0 when the min value is 0 and the max value is bigger than 0", function () {
546
- var _render24 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
547
- label: "Number input label",
548
- min: 0,
549
- max: 10,
550
- step: 1
551
- })),
552
- getByLabelText = _render24.getByLabelText,
553
- getAllByRole = _render24.getAllByRole;
554
-
555
- var number = getByLabelText("Number input label");
556
- var decrement = getAllByRole("button")[0];
557
-
558
- _userEvent["default"].click(decrement);
559
-
560
- expect(number.value).toBe("0");
561
- });
562
- test("Start decrementing from the min value when it is bigger than 0", function () {
563
- var _render25 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
564
- label: "Number input label",
565
- min: 2,
566
- max: 10,
567
- step: 0.5
568
- })),
569
- getByLabelText = _render25.getByLabelText,
570
- getAllByRole = _render25.getAllByRole;
571
-
572
- var number = getByLabelText("Number input label");
573
- var decrement = getAllByRole("button")[0];
574
-
575
- _userEvent["default"].click(decrement);
576
-
577
- expect(number.value).toBe("2");
578
-
579
- _userEvent["default"].click(decrement);
580
-
581
- expect(number.value).toBe("2");
582
- });
583
- test("Start decrementing from the max value when it is less than 0", function () {
584
- var _render26 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
585
- label: "Number input label",
586
- min: -10,
587
- max: -1,
588
- step: 0.5
589
- })),
590
- getByLabelText = _render26.getByLabelText,
591
- getAllByRole = _render26.getAllByRole;
592
-
593
- var number = getByLabelText("Number input label");
594
- var decrement = getAllByRole("button")[0];
595
-
596
- _userEvent["default"].click(decrement);
597
-
598
- expect(number.value).toBe("-1");
599
-
600
- _userEvent["default"].click(decrement);
601
-
602
- expect(number.value).toBe("-1.5");
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");
603
799
  });
604
- test("Increment and decrement the value with min, max and step using the arrows in keyboard", function () {
605
- var _render27 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
606
- label: "Number input label",
607
- min: 5,
608
- max: 20,
609
- step: 5
610
- })),
611
- getByLabelText = _render27.getByLabelText;
612
-
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;
613
810
  var number = getByLabelText("Number input label");
614
-
615
- _userEvent["default"].type(number, "1");
616
-
617
811
  _react2.fireEvent.keyDown(number, {
618
812
  keyCode: 38
619
813
  });
620
-
621
- expect(number.value).toBe("5");
622
-
814
+ expect(number.value).toBe("10");
623
815
  _react2.fireEvent.keyDown(number, {
624
- keyCode: 38
816
+ keyCode: 40
625
817
  });
626
-
627
818
  expect(number.value).toBe("10");
628
-
629
819
  _react2.fireEvent.keyDown(number, {
630
820
  keyCode: 38
631
821
  });
632
-
633
- expect(number.value).toBe("15");
634
-
822
+ expect(number.value).toBe("10");
635
823
  _react2.fireEvent.keyDown(number, {
636
- keyCode: 38
824
+ keyCode: 40
637
825
  });
638
-
639
- expect(number.value).toBe("20");
640
-
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");
641
867
  _react2.fireEvent.keyDown(number, {
642
868
  keyCode: 38
643
869
  });
644
-
645
- expect(number.value).toBe("20");
646
-
870
+ expect(number.value).toBe("10");
647
871
  _react2.fireEvent.keyDown(number, {
648
872
  keyCode: 40
649
873
  });
650
-
651
- expect(number.value).toBe("15");
652
-
874
+ expect(number.value).toBe("10");
653
875
  _react2.fireEvent.keyDown(number, {
654
- keyCode: 40
876
+ keyCode: 38
655
877
  });
656
-
657
878
  expect(number.value).toBe("10");
658
-
659
879
  _react2.fireEvent.keyDown(number, {
660
880
  keyCode: 40
661
881
  });
662
-
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
+ });
663
897
  expect(number.value).toBe("5");
664
-
665
- _react2.fireEvent.keyDown(number, {
666
- keyCode: 40
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
667
928
  });
668
-
669
929
  expect(number.value).toBe("5");
670
930
  });
671
931
  test("Number has correct accessibility attributes", function () {
672
- var _render28 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
673
- label: "Number input label"
674
- })),
675
- getByLabelText = _render28.getByLabelText,
676
- getAllByRole = _render28.getAllByRole;
677
-
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;
678
937
  var number = getByLabelText("Number input label");
679
938
  expect(number.getAttribute("type")).toBe("number");
680
939
  expect(number.getAttribute("aria-autocomplete")).toBeNull();
@@ -685,41 +944,46 @@ describe("Number input component tests", function () {
685
944
  var increment = getAllByRole("button")[1];
686
945
  expect(increment.getAttribute("aria-label")).toBe("Increment value");
687
946
  });
688
- test("Number input submits correct values inside a form and actions don't trigger the submit event", function () {
689
- var handlerOnSubmit = jest.fn(function (e) {
690
- e.preventDefault();
691
- var formData = new FormData(e.target);
692
- var formProps = Object.fromEntries(formData);
693
- expect(formProps).toStrictEqual({
694
- data: "0"
695
- });
696
- });
697
-
698
- var _render29 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement("form", {
699
- onSubmit: handlerOnSubmit
700
- }, /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
701
- label: "Number input label",
702
- name: "data"
703
- }), /*#__PURE__*/_react["default"].createElement("button", {
704
- type: "submit"
705
- }, "Submit"))),
706
- getByText = _render29.getByText,
707
- getAllByRole = _render29.getAllByRole;
708
-
709
- var less = getAllByRole("button")[0];
710
- var more = getAllByRole("button")[1];
711
- var submit = getByText("Submit");
712
-
713
- _userEvent["default"].click(more);
714
-
715
- expect(handlerOnSubmit).not.toHaveBeenCalled();
716
-
717
- _userEvent["default"].click(less);
718
-
719
- expect(handlerOnSubmit).not.toHaveBeenCalled();
720
-
721
- _userEvent["default"].click(submit);
722
-
723
- expect(handlerOnSubmit).toHaveBeenCalled();
724
- });
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
+ })));
725
989
  });