@dxc-technology/halstack-react 0.0.0-d3554d7 → 0.0.0-d3df47e
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.
- package/BackgroundColorContext.d.ts +1 -10
- package/BackgroundColorContext.js +5 -22
- package/HalstackContext.d.ts +1221 -0
- package/HalstackContext.js +310 -0
- package/README.md +47 -0
- package/accordion/Accordion.d.ts +1 -1
- package/accordion/Accordion.js +116 -181
- package/accordion/Accordion.stories.tsx +103 -127
- package/accordion/Accordion.test.js +32 -33
- package/accordion/types.d.ts +9 -16
- package/accordion-group/AccordionGroup.d.ts +5 -4
- package/accordion-group/AccordionGroup.js +38 -107
- package/accordion-group/AccordionGroup.stories.tsx +95 -68
- package/accordion-group/AccordionGroup.test.js +55 -90
- package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
- package/accordion-group/AccordionGroupAccordion.js +31 -0
- package/accordion-group/types.d.ts +15 -16
- package/action-icon/ActionIcon.d.ts +4 -0
- package/action-icon/ActionIcon.js +47 -0
- package/action-icon/ActionIcon.stories.tsx +41 -0
- package/action-icon/ActionIcon.test.js +64 -0
- package/action-icon/types.d.ts +26 -0
- package/alert/Alert.js +23 -59
- package/alert/Alert.stories.tsx +28 -0
- package/alert/Alert.test.js +29 -46
- package/alert/types.d.ts +5 -5
- package/badge/Badge.d.ts +1 -1
- package/badge/Badge.js +142 -40
- package/badge/Badge.stories.tsx +210 -0
- package/badge/Badge.test.js +30 -0
- package/badge/types.d.ts +52 -2
- package/bleed/Bleed.js +14 -55
- package/bleed/Bleed.stories.tsx +95 -95
- package/bleed/types.d.ts +26 -2
- package/box/Box.d.ts +1 -1
- package/box/Box.js +30 -81
- package/box/Box.stories.tsx +38 -51
- package/box/Box.test.js +2 -7
- package/box/types.d.ts +3 -14
- package/bulleted-list/BulletedList.d.ts +7 -0
- package/bulleted-list/BulletedList.js +89 -0
- package/bulleted-list/BulletedList.stories.tsx +115 -0
- package/bulleted-list/types.d.ts +38 -0
- package/button/Button.d.ts +1 -1
- package/button/Button.js +62 -113
- package/button/Button.stories.tsx +160 -90
- package/button/Button.test.js +20 -17
- package/button/types.d.ts +12 -8
- package/card/Card.d.ts +1 -1
- package/card/Card.js +58 -102
- package/card/Card.stories.tsx +12 -42
- package/card/Card.test.js +11 -22
- package/card/types.d.ts +6 -11
- package/checkbox/Checkbox.d.ts +2 -2
- package/checkbox/Checkbox.js +144 -182
- package/checkbox/Checkbox.stories.tsx +166 -136
- package/checkbox/Checkbox.test.js +163 -29
- package/checkbox/types.d.ts +18 -6
- package/chip/Chip.js +39 -79
- package/chip/Chip.stories.tsx +121 -26
- package/chip/Chip.test.js +16 -31
- package/chip/types.d.ts +4 -4
- package/common/OpenSans.css +68 -80
- package/common/coreTokens.d.ts +237 -0
- package/common/coreTokens.js +184 -0
- package/common/utils.d.ts +1 -0
- package/common/utils.js +6 -12
- package/common/variables.d.ts +1367 -0
- package/common/variables.js +1002 -1136
- package/container/Container.d.ts +4 -0
- package/container/Container.js +194 -0
- package/container/Container.stories.tsx +214 -0
- package/container/types.d.ts +74 -0
- package/date-input/Calendar.d.ts +4 -0
- package/date-input/Calendar.js +214 -0
- package/date-input/DateInput.js +171 -306
- package/date-input/DateInput.stories.tsx +203 -56
- package/date-input/DateInput.test.js +708 -369
- package/date-input/DatePicker.d.ts +4 -0
- package/date-input/DatePicker.js +115 -0
- package/date-input/Icons.d.ts +6 -0
- package/date-input/Icons.js +58 -0
- package/date-input/YearPicker.d.ts +4 -0
- package/date-input/YearPicker.js +100 -0
- package/date-input/types.d.ts +86 -22
- package/dialog/Dialog.d.ts +1 -1
- package/dialog/Dialog.js +68 -130
- package/dialog/Dialog.stories.tsx +320 -167
- package/dialog/Dialog.test.js +287 -20
- package/dialog/types.d.ts +18 -25
- package/dropdown/Dropdown.d.ts +1 -1
- package/dropdown/Dropdown.js +243 -304
- package/dropdown/Dropdown.stories.tsx +245 -56
- package/dropdown/Dropdown.test.js +575 -165
- package/dropdown/DropdownMenu.d.ts +4 -0
- package/dropdown/DropdownMenu.js +63 -0
- package/dropdown/DropdownMenuItem.d.ts +4 -0
- package/dropdown/DropdownMenuItem.js +67 -0
- package/dropdown/types.d.ts +32 -14
- package/file-input/FileInput.d.ts +2 -2
- package/file-input/FileInput.js +246 -357
- package/file-input/FileInput.stories.tsx +123 -12
- package/file-input/FileInput.test.js +369 -367
- package/file-input/FileItem.d.ts +4 -14
- package/file-input/FileItem.js +50 -99
- package/file-input/types.d.ts +25 -8
- package/flex/Flex.d.ts +4 -0
- package/flex/Flex.js +57 -0
- package/flex/Flex.stories.tsx +112 -0
- package/flex/types.d.ts +97 -0
- package/footer/Footer.d.ts +1 -1
- package/footer/Footer.js +70 -190
- package/footer/Footer.stories.tsx +60 -19
- package/footer/Footer.test.js +33 -57
- package/footer/Icons.d.ts +3 -2
- package/footer/Icons.js +67 -8
- package/footer/types.d.ts +25 -26
- package/grid/Grid.d.ts +7 -0
- package/grid/Grid.js +76 -0
- package/grid/Grid.stories.tsx +219 -0
- package/grid/types.d.ts +115 -0
- package/header/Header.d.ts +4 -3
- package/header/Header.js +99 -203
- package/header/Header.stories.tsx +152 -63
- package/header/Header.test.js +31 -28
- package/header/Icons.d.ts +2 -2
- package/header/Icons.js +4 -9
- package/header/types.d.ts +5 -19
- package/heading/Heading.js +10 -32
- package/heading/Heading.test.js +71 -88
- package/heading/types.d.ts +7 -7
- package/image/Image.d.ts +4 -0
- package/image/Image.js +70 -0
- package/image/Image.stories.tsx +127 -0
- package/image/types.d.ts +72 -0
- package/inset/Inset.js +14 -55
- package/inset/Inset.stories.tsx +37 -36
- package/inset/types.d.ts +26 -2
- package/layout/ApplicationLayout.d.ts +16 -6
- package/layout/ApplicationLayout.js +84 -181
- package/layout/ApplicationLayout.stories.tsx +85 -94
- package/layout/Icons.d.ts +8 -0
- package/layout/Icons.js +51 -48
- package/layout/SidenavContext.d.ts +5 -0
- package/layout/SidenavContext.js +13 -0
- package/layout/types.d.ts +19 -35
- package/link/Link.d.ts +3 -2
- package/link/Link.js +61 -99
- package/link/Link.stories.tsx +155 -53
- package/link/Link.test.js +25 -53
- package/link/types.d.ts +15 -31
- package/main.d.ts +14 -13
- package/main.js +65 -101
- package/nav-tabs/NavTabs.d.ts +8 -0
- package/nav-tabs/NavTabs.js +93 -0
- package/nav-tabs/NavTabs.stories.tsx +276 -0
- package/nav-tabs/NavTabs.test.js +76 -0
- package/nav-tabs/Tab.d.ts +4 -0
- package/nav-tabs/Tab.js +118 -0
- package/nav-tabs/types.d.ts +52 -0
- package/nav-tabs/types.js +5 -0
- package/number-input/NumberInput.d.ts +7 -0
- package/number-input/NumberInput.js +27 -43
- package/number-input/NumberInput.stories.tsx +44 -28
- package/number-input/NumberInput.test.js +703 -381
- package/number-input/types.d.ts +28 -15
- package/package.json +46 -47
- package/paginator/Icons.d.ts +5 -0
- package/paginator/Icons.js +21 -47
- package/paginator/Paginator.js +34 -91
- package/paginator/Paginator.stories.tsx +24 -0
- package/paginator/Paginator.test.js +280 -211
- package/paginator/types.d.ts +3 -3
- package/paragraph/Paragraph.d.ts +5 -0
- package/paragraph/Paragraph.js +22 -0
- package/paragraph/Paragraph.stories.tsx +27 -0
- package/password-input/Icons.d.ts +6 -0
- package/password-input/Icons.js +35 -0
- package/password-input/PasswordInput.js +57 -123
- package/password-input/PasswordInput.stories.tsx +1 -33
- package/password-input/PasswordInput.test.js +162 -147
- package/password-input/types.d.ts +21 -17
- package/progress-bar/ProgressBar.js +65 -91
- package/progress-bar/ProgressBar.stories.tsx +93 -0
- package/progress-bar/ProgressBar.test.js +72 -44
- package/progress-bar/types.d.ts +3 -3
- package/quick-nav/QuickNav.d.ts +4 -0
- package/quick-nav/QuickNav.js +94 -0
- package/quick-nav/QuickNav.stories.tsx +356 -0
- package/quick-nav/types.d.ts +21 -0
- package/quick-nav/types.js +5 -0
- package/radio-group/Radio.d.ts +1 -1
- package/radio-group/Radio.js +59 -76
- package/radio-group/RadioGroup.js +72 -116
- package/radio-group/RadioGroup.stories.tsx +135 -17
- package/radio-group/RadioGroup.test.js +529 -467
- package/radio-group/types.d.ts +86 -9
- package/resultset-table/Icons.d.ts +7 -0
- package/resultset-table/Icons.js +47 -0
- package/{resultsetTable → resultset-table}/ResultsetTable.d.ts +1 -1
- package/resultset-table/ResultsetTable.js +165 -0
- package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +69 -25
- package/{resultsetTable → resultset-table}/ResultsetTable.test.js +117 -118
- package/{resultsetTable → resultset-table}/types.d.ts +13 -7
- package/resultset-table/types.js +5 -0
- package/select/Icons.d.ts +10 -0
- package/select/Icons.js +89 -0
- package/select/Listbox.d.ts +4 -0
- package/select/Listbox.js +143 -0
- package/select/Option.d.ts +4 -0
- package/select/Option.js +87 -0
- package/select/Select.js +223 -502
- package/select/Select.stories.tsx +534 -145
- package/select/Select.test.js +2009 -1539
- package/select/types.d.ts +64 -25
- package/sidenav/Icons.d.ts +7 -0
- package/sidenav/Icons.js +47 -0
- package/sidenav/Sidenav.d.ts +6 -5
- package/sidenav/Sidenav.js +131 -71
- package/sidenav/Sidenav.stories.tsx +251 -151
- package/sidenav/Sidenav.test.js +26 -45
- package/sidenav/types.d.ts +52 -26
- package/slider/Slider.d.ts +2 -2
- package/slider/Slider.js +148 -180
- package/slider/Slider.test.js +198 -73
- package/slider/types.d.ts +11 -3
- package/spinner/Spinner.js +31 -75
- package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
- package/spinner/Spinner.test.js +26 -35
- package/spinner/types.d.ts +3 -3
- package/status-light/StatusLight.d.ts +4 -0
- package/status-light/StatusLight.js +51 -0
- package/status-light/StatusLight.stories.tsx +74 -0
- package/status-light/StatusLight.test.js +25 -0
- package/status-light/types.d.ts +17 -0
- package/status-light/types.js +5 -0
- package/switch/Switch.d.ts +2 -2
- package/switch/Switch.js +149 -114
- package/switch/Switch.stories.tsx +44 -67
- package/switch/Switch.test.js +146 -39
- package/switch/types.d.ts +13 -5
- package/table/Table.d.ts +1 -1
- package/table/Table.js +25 -32
- package/table/{Table.stories.jsx → Table.stories.tsx} +178 -1
- package/table/Table.test.js +3 -8
- package/table/types.d.ts +12 -6
- package/tabs/Tab.d.ts +4 -0
- package/tabs/Tab.js +116 -0
- package/tabs/Tabs.d.ts +1 -1
- package/tabs/Tabs.js +316 -145
- package/tabs/Tabs.stories.tsx +120 -14
- package/tabs/Tabs.test.js +238 -67
- package/tabs/types.d.ts +29 -15
- package/tag/Tag.js +41 -78
- package/tag/Tag.stories.tsx +25 -8
- package/tag/Tag.test.js +20 -31
- package/tag/types.d.ts +7 -7
- package/text-input/Icons.d.ts +8 -0
- package/text-input/Icons.js +56 -0
- package/text-input/Suggestion.d.ts +4 -0
- package/text-input/Suggestion.js +67 -0
- package/text-input/Suggestions.d.ts +4 -0
- package/text-input/Suggestions.js +84 -0
- package/text-input/TextInput.js +324 -548
- package/text-input/TextInput.stories.tsx +272 -281
- package/text-input/TextInput.test.js +1425 -1377
- package/text-input/types.d.ts +70 -24
- package/textarea/Textarea.js +82 -134
- package/textarea/Textarea.stories.tsx +174 -0
- package/textarea/Textarea.test.js +168 -198
- package/textarea/types.d.ts +27 -16
- package/toggle-group/ToggleGroup.d.ts +2 -2
- package/toggle-group/ToggleGroup.js +92 -105
- package/toggle-group/ToggleGroup.stories.tsx +53 -8
- package/toggle-group/ToggleGroup.test.js +78 -66
- package/toggle-group/types.d.ts +34 -17
- package/typography/Typography.d.ts +4 -0
- package/typography/Typography.js +23 -0
- package/typography/Typography.stories.tsx +198 -0
- package/typography/types.d.ts +18 -0
- package/typography/types.js +5 -0
- package/useTheme.d.ts +1119 -1
- package/useTheme.js +4 -11
- package/useTranslatedLabels.d.ts +85 -0
- package/useTranslatedLabels.js +14 -0
- package/utils/BaseTypography.d.ts +21 -0
- package/utils/BaseTypography.js +94 -0
- package/utils/FocusLock.d.ts +13 -0
- package/utils/FocusLock.js +124 -0
- package/wizard/Wizard.d.ts +1 -1
- package/wizard/Wizard.js +70 -101
- package/wizard/Wizard.stories.tsx +48 -19
- package/wizard/Wizard.test.js +73 -87
- package/wizard/types.d.ts +12 -8
- package/ThemeContext.d.ts +0 -10
- package/ThemeContext.js +0 -243
- package/card/ice-cream.jpg +0 -0
- package/common/RequiredComponent.js +0 -32
- package/list/List.d.ts +0 -4
- package/list/List.js +0 -47
- package/list/List.stories.tsx +0 -95
- package/list/types.d.ts +0 -7
- package/number-input/NumberInputContext.d.ts +0 -4
- package/number-input/NumberInputContext.js +0 -19
- package/number-input/numberInputContextTypes.d.ts +0 -19
- package/progress-bar/ProgressBar.stories.jsx +0 -58
- package/radio/Radio.d.ts +0 -4
- package/radio/Radio.js +0 -174
- package/radio/Radio.stories.tsx +0 -192
- package/radio/Radio.test.js +0 -71
- package/radio/types.d.ts +0 -54
- package/resultsetTable/ResultsetTable.js +0 -254
- package/row/Row.d.ts +0 -3
- package/row/Row.js +0 -127
- package/row/Row.stories.tsx +0 -237
- package/row/types.d.ts +0 -10
- package/slider/Slider.stories.tsx +0 -177
- package/stack/Stack.d.ts +0 -3
- package/stack/Stack.js +0 -97
- package/stack/Stack.stories.tsx +0 -164
- package/stack/types.d.ts +0 -9
- package/text/Text.d.ts +0 -7
- package/text/Text.js +0 -30
- package/text/Text.stories.tsx +0 -19
- package/textarea/Textarea.stories.jsx +0 -157
- /package/{list → action-icon}/types.js +0 -0
- /package/{radio → bulleted-list}/types.js +0 -0
- /package/{resultsetTable → container}/types.js +0 -0
- /package/{row → flex}/types.js +0 -0
- /package/{stack → grid}/types.js +0 -0
- /package/{number-input/numberInputContextTypes.js → image/types.js} +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
|
-
|
|
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
|
-
|
|
17
|
-
|
|
18
|
-
|
|
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
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
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
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
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
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
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
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
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,401 +148,635 @@ 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
|
|
106
|
-
var
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
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
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
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
|
-
|
|
128
|
-
|
|
129
|
-
|
|
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
|
-
value: "t"
|
|
139
|
-
error: null
|
|
178
|
+
value: "t"
|
|
140
179
|
});
|
|
141
180
|
expect(number.value).toBe("");
|
|
142
|
-
|
|
143
181
|
_userEvent["default"].type(number, "1");
|
|
144
|
-
|
|
145
182
|
expect(onChange).toHaveBeenCalledWith({
|
|
146
|
-
value: "1"
|
|
147
|
-
error: null
|
|
183
|
+
value: "1"
|
|
148
184
|
});
|
|
149
185
|
expect(number.value).toBe("1");
|
|
150
186
|
});
|
|
151
|
-
test("Error message is shown if the value is less than the min value", function () {
|
|
152
|
-
var onChange = jest.fn(function (
|
|
153
|
-
var value = _ref.value,
|
|
154
|
-
error = _ref.error;
|
|
155
|
-
expect(value).toBe("1");
|
|
156
|
-
expect(error).toBe("Value must be greater than or equal to 5.");
|
|
157
|
-
});
|
|
158
|
-
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) {
|
|
159
189
|
var value = _ref2.value,
|
|
160
|
-
|
|
161
|
-
expect(value).toBe("1");
|
|
162
|
-
expect(error).toBe("Value must be greater than or equal to
|
|
190
|
+
error = _ref2.error;
|
|
191
|
+
expect(value).toBe("-1");
|
|
192
|
+
expect(error).toBe("Value must be greater than or equal to 0.");
|
|
163
193
|
});
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
_react2.fireEvent.blur(number);
|
|
178
|
-
});
|
|
179
|
-
test("Cannot decrement the value if it is less than the min value", function () {
|
|
180
|
-
var _render13 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
|
|
181
|
-
label: "Number input label",
|
|
182
|
-
min: 5
|
|
183
|
-
})),
|
|
184
|
-
getByLabelText = _render13.getByLabelText,
|
|
185
|
-
getAllByRole = _render13.getAllByRole;
|
|
186
|
-
|
|
187
|
-
var number = getByLabelText("Number input label");
|
|
188
|
-
|
|
189
|
-
_userEvent["default"].type(number, "1");
|
|
190
|
-
|
|
191
|
-
_react2.fireEvent.blur(number);
|
|
192
|
-
|
|
193
|
-
expect(number.value).toBe("1");
|
|
194
|
-
var decrement = getAllByRole("button")[0];
|
|
195
|
-
|
|
196
|
-
_userEvent["default"].click(decrement);
|
|
197
|
-
|
|
198
|
-
expect(number.value).toBe("1");
|
|
199
|
-
});
|
|
200
|
-
test("Increment the value when it is less than the min value", function () {
|
|
201
|
-
var _render14 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
|
|
202
|
-
label: "Number input label",
|
|
203
|
-
min: 5
|
|
204
|
-
})),
|
|
205
|
-
getByLabelText = _render14.getByLabelText,
|
|
206
|
-
getAllByRole = _render14.getAllByRole;
|
|
207
|
-
|
|
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;
|
|
208
207
|
var number = getByLabelText("Number input label");
|
|
209
|
-
|
|
210
|
-
_userEvent["default"].type(number, "1");
|
|
211
|
-
|
|
208
|
+
_userEvent["default"].type(number, "-1");
|
|
212
209
|
_react2.fireEvent.blur(number);
|
|
213
|
-
|
|
214
|
-
expect(number.value).toBe("1");
|
|
215
|
-
var increment = getAllByRole("button")[1];
|
|
216
|
-
|
|
217
|
-
_userEvent["default"].click(increment);
|
|
218
|
-
|
|
219
|
-
expect(number.value).toBe("5");
|
|
220
210
|
});
|
|
221
|
-
test("
|
|
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 () {
|
|
222
260
|
var onChange = jest.fn();
|
|
223
261
|
var onBlur = jest.fn();
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
getByLabelText = _render15.getByLabelText;
|
|
232
|
-
|
|
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;
|
|
233
269
|
var number = getByLabelText("Number input label");
|
|
234
|
-
|
|
235
270
|
_userEvent["default"].type(number, "12");
|
|
236
|
-
|
|
237
271
|
expect(onChange).toHaveBeenCalledTimes(2);
|
|
238
272
|
expect(onChange).toHaveBeenCalledWith({
|
|
239
273
|
value: "12",
|
|
240
274
|
error: "Value must be less than or equal to 10."
|
|
241
275
|
});
|
|
242
|
-
|
|
243
276
|
_react2.fireEvent.blur(number);
|
|
244
|
-
|
|
245
277
|
expect(onBlur).toHaveBeenCalled();
|
|
246
278
|
expect(onBlur).toHaveBeenCalledWith({
|
|
247
279
|
value: "12",
|
|
248
280
|
error: "Value must be less than or equal to 10."
|
|
249
281
|
});
|
|
250
282
|
});
|
|
251
|
-
test("Cannot increment the value if it is greater than the max value", function () {
|
|
252
|
-
var
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
})
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
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
|
+
})));
|
|
425
725
|
test("Increment and decrement the value with min, max and step using the arrows in keyboard", function () {
|
|
426
|
-
var
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
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;
|
|
434
733
|
var number = getByLabelText("Number input label");
|
|
435
|
-
|
|
436
734
|
_userEvent["default"].type(number, "1");
|
|
437
|
-
|
|
438
735
|
_react2.fireEvent.keyDown(number, {
|
|
439
736
|
keyCode: 38
|
|
440
737
|
});
|
|
441
|
-
|
|
442
738
|
expect(number.value).toBe("5");
|
|
443
|
-
|
|
444
739
|
_react2.fireEvent.keyDown(number, {
|
|
445
740
|
keyCode: 38
|
|
446
741
|
});
|
|
447
|
-
|
|
448
742
|
expect(number.value).toBe("10");
|
|
449
|
-
|
|
450
743
|
_react2.fireEvent.keyDown(number, {
|
|
451
744
|
keyCode: 38
|
|
452
745
|
});
|
|
453
|
-
|
|
454
746
|
expect(number.value).toBe("15");
|
|
455
|
-
|
|
456
747
|
_react2.fireEvent.keyDown(number, {
|
|
457
748
|
keyCode: 38
|
|
458
749
|
});
|
|
459
|
-
|
|
460
750
|
expect(number.value).toBe("20");
|
|
461
|
-
|
|
462
751
|
_react2.fireEvent.keyDown(number, {
|
|
463
752
|
keyCode: 38
|
|
464
753
|
});
|
|
465
|
-
|
|
466
754
|
expect(number.value).toBe("20");
|
|
467
|
-
|
|
468
755
|
_react2.fireEvent.keyDown(number, {
|
|
469
756
|
keyCode: 40
|
|
470
757
|
});
|
|
471
|
-
|
|
472
758
|
expect(number.value).toBe("15");
|
|
473
|
-
|
|
474
759
|
_react2.fireEvent.keyDown(number, {
|
|
475
760
|
keyCode: 40
|
|
476
761
|
});
|
|
477
|
-
|
|
478
762
|
expect(number.value).toBe("10");
|
|
479
|
-
|
|
480
763
|
_react2.fireEvent.keyDown(number, {
|
|
481
764
|
keyCode: 40
|
|
482
765
|
});
|
|
483
|
-
|
|
484
766
|
expect(number.value).toBe("5");
|
|
485
|
-
|
|
486
767
|
_react2.fireEvent.keyDown(number, {
|
|
487
768
|
keyCode: 40
|
|
488
769
|
});
|
|
489
|
-
|
|
490
770
|
expect(number.value).toBe("5");
|
|
491
771
|
});
|
|
492
|
-
test("Number has correct
|
|
493
|
-
var
|
|
494
|
-
|
|
495
|
-
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
|
|
772
|
+
test("Number has correct accessibility attributes", function () {
|
|
773
|
+
var _render30 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
|
|
774
|
+
label: "Number input label"
|
|
775
|
+
})),
|
|
776
|
+
getByLabelText = _render30.getByLabelText,
|
|
777
|
+
getAllByRole = _render30.getAllByRole;
|
|
499
778
|
var number = getByLabelText("Number input label");
|
|
779
|
+
expect(number.getAttribute("type")).toBe("number");
|
|
500
780
|
expect(number.getAttribute("aria-autocomplete")).toBeNull();
|
|
501
781
|
expect(number.getAttribute("aria-controls")).toBeNull();
|
|
502
782
|
expect(number.getAttribute("aria-expanded")).toBeNull();
|
|
@@ -505,4 +785,46 @@ describe("Number input component tests", function () {
|
|
|
505
785
|
var increment = getAllByRole("button")[1];
|
|
506
786
|
expect(increment.getAttribute("aria-label")).toBe("Increment value");
|
|
507
787
|
});
|
|
788
|
+
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() {
|
|
789
|
+
var handlerOnSubmit, _render31, getByText, getAllByRole, less, more, submit;
|
|
790
|
+
return _regenerator["default"].wrap(function _callee18$(_context18) {
|
|
791
|
+
while (1) switch (_context18.prev = _context18.next) {
|
|
792
|
+
case 0:
|
|
793
|
+
handlerOnSubmit = jest.fn(function (e) {
|
|
794
|
+
e.preventDefault();
|
|
795
|
+
var formData = new FormData(e.target);
|
|
796
|
+
var formProps = Object.fromEntries(formData);
|
|
797
|
+
expect(formProps).toStrictEqual({
|
|
798
|
+
data: "0"
|
|
799
|
+
});
|
|
800
|
+
});
|
|
801
|
+
_render31 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement("form", {
|
|
802
|
+
onSubmit: handlerOnSubmit
|
|
803
|
+
}, /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
|
|
804
|
+
label: "Number input label",
|
|
805
|
+
name: "data"
|
|
806
|
+
}), /*#__PURE__*/_react["default"].createElement("button", {
|
|
807
|
+
type: "submit"
|
|
808
|
+
}, "Submit"))), getByText = _render31.getByText, getAllByRole = _render31.getAllByRole;
|
|
809
|
+
less = getAllByRole("button")[0];
|
|
810
|
+
more = getAllByRole("button")[1];
|
|
811
|
+
submit = getByText("Submit");
|
|
812
|
+
_context18.next = 7;
|
|
813
|
+
return _userEvent["default"].click(more);
|
|
814
|
+
case 7:
|
|
815
|
+
expect(handlerOnSubmit).not.toHaveBeenCalled();
|
|
816
|
+
_context18.next = 10;
|
|
817
|
+
return _userEvent["default"].click(less);
|
|
818
|
+
case 10:
|
|
819
|
+
expect(handlerOnSubmit).not.toHaveBeenCalled();
|
|
820
|
+
_context18.next = 13;
|
|
821
|
+
return _userEvent["default"].click(submit);
|
|
822
|
+
case 13:
|
|
823
|
+
expect(handlerOnSubmit).toHaveBeenCalled();
|
|
824
|
+
case 14:
|
|
825
|
+
case "end":
|
|
826
|
+
return _context18.stop();
|
|
827
|
+
}
|
|
828
|
+
}, _callee18);
|
|
829
|
+
})));
|
|
508
830
|
});
|