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