@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.
Files changed (210) hide show
  1. package/BackgroundColorContext.d.ts +2 -2
  2. package/BackgroundColorContext.js +5 -17
  3. package/HalstackContext.d.ts +18 -6
  4. package/HalstackContext.js +9 -34
  5. package/accordion/Accordion.js +21 -58
  6. package/accordion/Accordion.stories.tsx +1 -15
  7. package/accordion/Accordion.test.js +18 -33
  8. package/accordion/types.d.ts +5 -5
  9. package/accordion-group/AccordionGroup.js +15 -42
  10. package/accordion-group/AccordionGroup.stories.tsx +1 -1
  11. package/accordion-group/AccordionGroup.test.js +42 -60
  12. package/accordion-group/AccordionGroupAccordion.js +9 -21
  13. package/accordion-group/types.d.ts +6 -6
  14. package/alert/Alert.js +14 -46
  15. package/alert/Alert.test.js +28 -45
  16. package/alert/types.d.ts +5 -5
  17. package/badge/Badge.js +4 -17
  18. package/badge/types.d.ts +1 -1
  19. package/bleed/Bleed.js +13 -21
  20. package/bleed/types.d.ts +2 -2
  21. package/box/Box.js +10 -29
  22. package/box/Box.test.js +1 -6
  23. package/box/types.d.ts +3 -3
  24. package/bulleted-list/BulletedList.js +7 -33
  25. package/bulleted-list/BulletedList.stories.tsx +1 -91
  26. package/bulleted-list/types.d.ts +5 -5
  27. package/button/Button.js +23 -46
  28. package/button/Button.stories.tsx +5 -86
  29. package/button/Button.test.js +11 -21
  30. package/button/types.d.ts +4 -4
  31. package/card/Card.js +21 -44
  32. package/card/Card.test.js +10 -21
  33. package/card/types.d.ts +5 -5
  34. package/checkbox/Checkbox.js +81 -111
  35. package/checkbox/Checkbox.stories.tsx +16 -54
  36. package/checkbox/Checkbox.test.js +107 -63
  37. package/checkbox/types.d.ts +8 -4
  38. package/chip/Chip.js +12 -31
  39. package/chip/Chip.test.js +15 -28
  40. package/chip/types.d.ts +4 -4
  41. package/common/coreTokens.js +1 -2
  42. package/common/utils.js +2 -8
  43. package/common/variables.d.ts +15 -6
  44. package/common/variables.js +17 -15
  45. package/date-input/Calendar.js +13 -57
  46. package/date-input/DateInput.js +50 -96
  47. package/date-input/DateInput.stories.tsx +11 -30
  48. package/date-input/DateInput.test.js +674 -701
  49. package/date-input/DatePicker.js +11 -42
  50. package/date-input/Icons.d.ts +6 -6
  51. package/date-input/Icons.js +6 -23
  52. package/date-input/YearPicker.js +8 -34
  53. package/date-input/types.d.ts +27 -21
  54. package/dialog/Dialog.js +11 -35
  55. package/dialog/Dialog.test.js +125 -187
  56. package/dialog/types.d.ts +18 -13
  57. package/dropdown/Dropdown.js +39 -93
  58. package/dropdown/Dropdown.test.js +391 -378
  59. package/dropdown/DropdownMenu.js +8 -19
  60. package/dropdown/DropdownMenuItem.js +5 -17
  61. package/dropdown/types.d.ts +17 -19
  62. package/file-input/FileInput.js +131 -220
  63. package/file-input/FileInput.stories.tsx +1 -1
  64. package/file-input/FileInput.test.js +293 -342
  65. package/file-input/FileItem.js +12 -39
  66. package/file-input/types.d.ts +9 -9
  67. package/flex/Flex.js +25 -39
  68. package/flex/types.d.ts +6 -6
  69. package/footer/Footer.js +9 -39
  70. package/footer/Footer.test.js +18 -32
  71. package/footer/Icons.d.ts +2 -2
  72. package/footer/Icons.js +2 -7
  73. package/footer/types.d.ts +13 -13
  74. package/grid/Grid.js +1 -16
  75. package/grid/types.d.ts +10 -10
  76. package/header/Header.d.ts +1 -1
  77. package/header/Header.js +19 -64
  78. package/header/Header.test.js +12 -25
  79. package/header/Icons.d.ts +2 -2
  80. package/header/Icons.js +2 -7
  81. package/header/types.d.ts +5 -7
  82. package/heading/Heading.js +9 -31
  83. package/heading/Heading.test.js +70 -87
  84. package/heading/types.d.ts +7 -7
  85. package/image/Image.d.ts +2 -2
  86. package/image/Image.js +17 -32
  87. package/image/types.d.ts +2 -2
  88. package/inset/Inset.js +13 -21
  89. package/inset/types.d.ts +2 -2
  90. package/layout/ApplicationLayout.d.ts +1 -1
  91. package/layout/ApplicationLayout.js +14 -54
  92. package/layout/Icons.d.ts +5 -5
  93. package/layout/Icons.js +1 -5
  94. package/layout/SidenavContext.d.ts +1 -1
  95. package/layout/SidenavContext.js +3 -9
  96. package/layout/types.d.ts +3 -3
  97. package/link/Link.js +21 -42
  98. package/link/Link.test.js +23 -41
  99. package/link/types.d.ts +14 -14
  100. package/main.d.ts +1 -1
  101. package/main.js +3 -52
  102. package/nav-tabs/NavTabs.js +11 -43
  103. package/nav-tabs/NavTabs.stories.tsx +1 -1
  104. package/nav-tabs/NavTabs.test.js +36 -43
  105. package/nav-tabs/Tab.js +16 -45
  106. package/nav-tabs/types.d.ts +9 -9
  107. package/number-input/NumberInput.d.ts +1 -1
  108. package/number-input/NumberInput.js +24 -35
  109. package/number-input/NumberInput.stories.tsx +42 -26
  110. package/number-input/NumberInput.test.js +682 -577
  111. package/number-input/types.d.ts +11 -5
  112. package/package.json +27 -25
  113. package/paginator/Icons.d.ts +5 -5
  114. package/paginator/Icons.js +5 -19
  115. package/paginator/Paginator.js +14 -39
  116. package/paginator/Paginator.test.js +224 -207
  117. package/paginator/types.d.ts +3 -3
  118. package/paragraph/Paragraph.js +3 -14
  119. package/paragraph/Paragraph.stories.tsx +0 -17
  120. package/password-input/Icons.d.ts +3 -3
  121. package/password-input/Icons.js +1 -5
  122. package/password-input/PasswordInput.js +26 -48
  123. package/password-input/PasswordInput.stories.tsx +1 -33
  124. package/password-input/PasswordInput.test.js +153 -129
  125. package/password-input/types.d.ts +8 -7
  126. package/progress-bar/ProgressBar.js +16 -42
  127. package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +1 -1
  128. package/progress-bar/ProgressBar.test.js +35 -52
  129. package/progress-bar/types.d.ts +3 -3
  130. package/quick-nav/QuickNav.js +4 -27
  131. package/quick-nav/QuickNav.stories.tsx +1 -1
  132. package/quick-nav/types.d.ts +10 -10
  133. package/radio-group/Radio.d.ts +1 -1
  134. package/radio-group/Radio.js +22 -54
  135. package/radio-group/RadioGroup.js +37 -83
  136. package/radio-group/RadioGroup.stories.tsx +10 -10
  137. package/radio-group/RadioGroup.test.js +504 -470
  138. package/radio-group/types.d.ts +8 -8
  139. package/resultset-table/Icons.d.ts +7 -0
  140. package/{resultsetTable → resultset-table}/Icons.js +1 -5
  141. package/{resultsetTable → resultset-table}/ResultsetTable.js +22 -58
  142. package/{resultsetTable → resultset-table}/ResultsetTable.test.js +72 -92
  143. package/{resultsetTable → resultset-table}/types.d.ts +7 -7
  144. package/select/Icons.d.ts +7 -7
  145. package/select/Icons.js +1 -5
  146. package/select/Listbox.js +13 -39
  147. package/select/Option.js +9 -26
  148. package/select/Select.js +54 -138
  149. package/select/Select.test.js +1902 -1796
  150. package/select/types.d.ts +14 -15
  151. package/sidenav/Icons.d.ts +4 -4
  152. package/sidenav/Icons.js +1 -5
  153. package/sidenav/Sidenav.js +24 -63
  154. package/sidenav/Sidenav.test.js +3 -10
  155. package/sidenav/types.d.ts +18 -18
  156. package/slider/Slider.js +38 -86
  157. package/slider/Slider.test.js +107 -103
  158. package/slider/types.d.ts +4 -4
  159. package/spinner/Spinner.js +10 -40
  160. package/spinner/Spinner.test.js +25 -34
  161. package/spinner/types.d.ts +3 -3
  162. package/switch/Switch.js +26 -69
  163. package/switch/Switch.stories.tsx +0 -34
  164. package/switch/Switch.test.js +51 -96
  165. package/switch/types.d.ts +4 -4
  166. package/table/Table.js +4 -23
  167. package/table/Table.test.js +1 -6
  168. package/table/types.d.ts +8 -8
  169. package/tabs/Tab.js +10 -29
  170. package/tabs/Tabs.js +48 -124
  171. package/tabs/Tabs.test.js +62 -118
  172. package/tabs/types.d.ts +19 -19
  173. package/tag/Tag.js +21 -51
  174. package/tag/Tag.test.js +19 -30
  175. package/tag/types.d.ts +7 -7
  176. package/text-input/Icons.d.ts +5 -5
  177. package/text-input/Icons.js +1 -5
  178. package/text-input/Suggestion.js +9 -26
  179. package/text-input/Suggestions.d.ts +1 -1
  180. package/text-input/Suggestions.js +12 -57
  181. package/text-input/TextInput.js +128 -193
  182. package/text-input/TextInput.stories.tsx +48 -152
  183. package/text-input/TextInput.test.js +1210 -1194
  184. package/text-input/types.d.ts +25 -17
  185. package/textarea/Textarea.js +60 -96
  186. package/textarea/{Textarea.stories.jsx → Textarea.stories.tsx} +58 -99
  187. package/textarea/Textarea.test.js +150 -179
  188. package/textarea/types.d.ts +9 -5
  189. package/toggle-group/ToggleGroup.js +20 -57
  190. package/toggle-group/ToggleGroup.stories.tsx +1 -1
  191. package/toggle-group/ToggleGroup.test.js +48 -81
  192. package/toggle-group/types.d.ts +10 -10
  193. package/typography/Typography.js +4 -13
  194. package/typography/types.d.ts +1 -1
  195. package/useTheme.d.ts +12 -3
  196. package/useTheme.js +1 -8
  197. package/useTranslatedLabels.js +1 -7
  198. package/utils/BaseTypography.d.ts +2 -2
  199. package/utils/BaseTypography.js +16 -30
  200. package/utils/FocusLock.js +12 -36
  201. package/wizard/Wizard.js +14 -49
  202. package/wizard/Wizard.test.js +53 -80
  203. package/wizard/types.d.ts +6 -6
  204. package/resultsetTable/Icons.d.ts +0 -7
  205. package/slider/Slider.stories.tsx +0 -240
  206. /package/{resultsetTable → resultset-table}/ResultsetTable.d.ts +0 -0
  207. /package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +0 -0
  208. /package/{resultsetTable → resultset-table}/types.js +0 -0
  209. /package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +0 -0
  210. /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
- label: "Error label",
65
- placeholder: "Placeholder",
66
- error: "Error message."
67
- })),
68
- getByText = _render.getByText,
69
- getByRole = _render.getByRole;
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
- label: "Default label",
81
- placeholder: "Placeholder",
82
- defaultValue: "Example text"
83
- })),
84
- getByRole = _render2.getByRole;
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
- label: "Input label",
95
- placeholder: "Placeholder",
96
- onChange: onChange,
97
- onBlur: onBlur,
98
- clearable: true
99
- })),
100
- getByRole = _render3.getByRole;
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
- label: "Input label",
132
- placeholder: "Placeholder",
133
- onChange: onChange,
134
- clearable: true
135
- })),
136
- getByRole = _render4.getByRole;
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
- label: "Input label",
165
- placeholder: "Placeholder",
166
- onChange: onChange,
167
- onBlur: onBlur,
168
- margin: {
169
- left: "medium",
170
- right: "medium"
171
- },
172
- clearable: true,
173
- pattern: "^.*(?=.*[a-zA-Z])(?=.*\\d)(?=.*[!&$%&? \"]).*$"
174
- })),
175
- getByRole = _render5.getByRole;
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
- label: "Input label",
225
- placeholder: "Placeholder",
226
- onChange: onChange,
227
- onBlur: onBlur,
228
- margin: {
229
- left: "medium",
230
- right: "medium"
231
- },
232
- clearable: true,
233
- minLength: 5,
234
- maxLength: 10
235
- })),
236
- getByRole = _render6.getByRole;
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
- label: "Input label",
286
- placeholder: "Placeholder",
287
- onChange: onChange,
288
- onBlur: onBlur,
289
- margin: {
290
- left: "medium",
291
- right: "medium"
292
- },
293
- clearable: true,
294
- pattern: "^.*(?=.*[a-zA-Z])(?=.*\\d)(?=.*[!&$%&? \"]).*$",
295
- minLength: 5,
296
- maxLength: 10
297
- })),
298
- getByRole = _render7.getByRole;
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
- label: "Input label",
365
- onChange: onChange
366
- })),
367
- getByRole = _render8.getByRole;
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
- label: "Input label",
385
- onChange: onChange,
386
- onBlur: onBlur
387
- })),
388
- getByRole = _render9.getByRole;
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
- label: "Input label",
408
- value: "Text",
409
- clearable: true
410
- })),
411
- getByTitle = _render10.getByTitle;
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 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
417
- label: "Input label",
418
- clearable: true
419
- })),
420
- getByRole = _render11.getByRole;
421
-
422
- var input = getByRole("textbox");
423
-
424
- _userEvent["default"].type(input, "Test");
425
-
426
- var closeAction = getByRole("button");
427
-
428
- _userEvent["default"].click(closeAction);
429
-
430
- expect(input.value).toBe("");
431
- });
432
- test("Disabled input renders with correct aria and can not be modified", function () {
336
+ test("Clear action onClick cleans the input", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
337
+ var _render11, getByRole, input, closeAction;
338
+ return _regenerator["default"].wrap(function _callee$(_context) {
339
+ while (1) switch (_context.prev = _context.next) {
340
+ case 0:
341
+ _render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
342
+ label: "Input label",
343
+ clearable: true
344
+ })), getByRole = _render11.getByRole;
345
+ input = getByRole("textbox");
346
+ _userEvent["default"].type(input, "Test");
347
+ closeAction = getByRole("button");
348
+ _context.next = 6;
349
+ return _userEvent["default"].click(closeAction);
350
+ case 6:
351
+ expect(input.value).toBe("");
352
+ case 7:
353
+ case "end":
354
+ return _context.stop();
355
+ }
356
+ }, _callee);
357
+ })));
358
+ test("Disabled text input renders with correct aria and can not be modified", function () {
433
359
  var onChange = jest.fn();
434
-
435
360
  var _render12 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
436
- label: "Input label",
437
- onChange: onChange,
438
- disabled: true
439
- })),
440
- getByRole = _render12.getByRole;
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 = jest.fn();
450
- var action = {
451
- onClick: onClick,
452
- icon: /*#__PURE__*/_react["default"].createElement("svg", {
453
- "data-testid": "image",
454
- xmlns: "http://www.w3.org/2000/svg",
455
- height: "24px",
456
- viewBox: "0 0 24 24",
457
- width: "24px",
458
- fill: "currentColor"
459
- }, /*#__PURE__*/_react["default"].createElement("path", {
460
- d: "M0 0h24v24H0V0z",
461
- fill: "none"
462
- }), /*#__PURE__*/_react["default"].createElement("path", {
463
- 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"
464
- }))
465
- };
466
-
467
- var _render13 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
468
- label: "Disabled input label",
469
- action: action,
470
- disabled: true
471
- })),
472
- getByRole = _render13.getByRole;
473
-
474
- var input = getByRole("textbox");
475
- expect(input.disabled).toBeTruthy();
476
-
477
- _userEvent["default"].click(getByRole("button"));
478
-
479
- expect(onClick).not.toHaveBeenCalled();
480
- });
481
- test("Disabled input (clear default action should not be displayed, even with text written on the input)", function () {
370
+ test("Disabled text input (action must be shown but not clickable)", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
371
+ var onClick, action, _render13, getByRole, input;
372
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
373
+ while (1) switch (_context2.prev = _context2.next) {
374
+ case 0:
375
+ onClick = jest.fn();
376
+ action = {
377
+ onClick: onClick,
378
+ icon: /*#__PURE__*/_react["default"].createElement("svg", {
379
+ "data-testid": "image",
380
+ xmlns: "http://www.w3.org/2000/svg",
381
+ height: "24px",
382
+ viewBox: "0 0 24 24",
383
+ width: "24px",
384
+ fill: "currentColor"
385
+ }, /*#__PURE__*/_react["default"].createElement("path", {
386
+ d: "M0 0h24v24H0V0z",
387
+ fill: "none"
388
+ }), /*#__PURE__*/_react["default"].createElement("path", {
389
+ d: "M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z"
390
+ }))
391
+ };
392
+ _render13 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
393
+ label: "Disabled input label",
394
+ action: action,
395
+ disabled: true
396
+ })), getByRole = _render13.getByRole;
397
+ input = getByRole("textbox");
398
+ expect(input.disabled).toBeTruthy();
399
+ _context2.next = 7;
400
+ return _userEvent["default"].click(getByRole("button"));
401
+ case 7:
402
+ expect(onClick).not.toHaveBeenCalled();
403
+ case 8:
404
+ case "end":
405
+ return _context2.stop();
406
+ }
407
+ }, _callee2);
408
+ })));
409
+ test("Disabled text input (clear default action should not be displayed, even with text written on the input)", function () {
482
410
  var _render14 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
483
- label: "Disabled input label",
484
- value: "Sample text",
485
- disabled: true,
486
- clearable: true
487
- })),
488
- getByRole = _render14.getByRole,
489
- queryByRole = _render14.queryByRole;
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 preffix must be displayed)", function () {
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
- label: "Disabled input label",
498
- value: "Sample text",
499
- prefix: "+34",
500
- suffix: "USD",
501
- disabled: true
502
- })),
503
- getByRole = _render15.getByRole,
504
- getByText = _render15.getByText;
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("Action prop: image displayed with title and onClick event", function () {
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
- label: "Input label",
533
- action: action
534
- })),
535
- getByRole = _render16.getByRole,
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
- title: "Search"
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
- _userEvent["default"].type(input, "test");
592
-
593
- expect(input.value).toBe("test");
594
-
595
- _userEvent["default"].click(search);
596
-
597
- expect(handlerOnSubmit).not.toHaveBeenCalled();
598
-
599
- _userEvent["default"].click(submit);
600
-
601
- expect(handlerOnSubmit).toHaveBeenCalled();
447
+ expect(input.readOnly).toBeTruthy();
448
+ expect(queryByRole("button")).toBeFalsy();
449
+ });
450
+ test("Read-only text input does not trigger onChange function", function () {
451
+ var onChange = jest.fn();
452
+ var _render17 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
453
+ label: "Example label",
454
+ onChange: onChange,
455
+ readOnly: true
456
+ })),
457
+ getByLabelText = _render17.getByLabelText;
458
+ var textInput = getByLabelText("Example label");
459
+ _userEvent["default"].type(textInput, "Test");
460
+ expect(onChange).not.toHaveBeenCalled();
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 _render18 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
605
- label: "Input label",
606
- prefix: "+34",
607
- suffix: "USD"
608
- })),
609
- getByText = _render18.getByText;
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 accesibility attributes", function () {
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
- var _render19 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
635
- label: "Example label",
636
- clearable: true,
637
- action: action
638
- })),
639
- getByRole = _render19.getByRole,
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 accesibility attributes", function () {
660
- var _render20 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
661
- label: "Autocomplete Countries",
662
- optional: true,
663
- suggestions: countries
664
- })),
665
- getByRole = _render20.getByRole,
666
- getAllByRole = _render20.getAllByRole;
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
- var _render21 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
688
- label: "Autocomplete Countries",
689
- suggestions: countries,
690
- onChange: onChange
691
- })),
692
- getByRole = _render21.getByRole,
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 = jest.fn();
708
-
709
- var _render22 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
710
- label: "Autocomplete Countries",
711
- suggestions: countries,
712
- onChange: onChange
713
- })),
714
- getByRole = _render22.getByRole,
715
- getByText = _render22.getByText;
716
-
717
- var input = getByRole("combobox");
718
-
719
- _react2.fireEvent.focus(input);
720
-
721
- var list = getByRole("listbox");
722
- expect(list).toBeTruthy();
723
- expect(getByText("Afghanistan")).toBeTruthy();
724
- expect(getByText("Albania")).toBeTruthy();
725
- expect(getByText("Algeria")).toBeTruthy();
726
- expect(getByText("Andorra")).toBeTruthy();
727
- });
728
- test("Autosuggest is displayed while the user is writing (if closed previously, if it is open stays open)", function () {
729
- var onChange = jest.fn();
730
-
731
- var _render23 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
732
- label: "Autocomplete Countries",
733
- suggestions: countries,
734
- onChange: onChange
735
- })),
736
- getByRole = _render23.getByRole,
737
- queryByRole = _render23.queryByRole,
738
- getByText = _render23.getByText,
739
- getAllByText = _render23.getAllByText;
740
-
741
- var input = getByRole("combobox");
742
-
743
- _react2.fireEvent.focus(input);
744
-
745
- var list = getByRole("listbox");
746
- expect(list).toBeTruthy();
747
-
748
- _react2.fireEvent.keyDown(input, {
749
- key: "Esc",
750
- code: "Esc",
751
- keyCode: 27,
752
- charCode: 27
753
- });
754
-
755
- expect(queryByRole("listbox")).toBeFalsy();
756
-
757
- _userEvent["default"].type(input, "B");
758
-
759
- expect(list).toBeTruthy();
760
- expect(getAllByText("B").length).toBe(4);
761
- expect(getByText("ahamas")).toBeTruthy();
762
- expect(getByText("ahrain")).toBeTruthy();
763
- expect(getByText("angladesh")).toBeTruthy();
764
- expect(getByText("arbados")).toBeTruthy();
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 _render24 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
768
- label: "Uncontrolled suggestions filtered by default",
769
- helperText: "Example of helper text",
770
- placeholder: "Placeholder",
771
- margin: "medium",
772
- defaultValue: "Suggestion 2",
773
- suggestions: ["Suggestion 11", "Suggestion 12", "Suggestion 23", "Suggestion 24"],
774
- clearable: true
775
- })),
776
- getByRole = _render24.getByRole,
777
- getByText = _render24.getByText,
778
- getAllByText = _render24.getAllByText;
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
- var _render25 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
793
- label: "Autocomplete Countries",
794
- suggestions: [],
795
- onChange: onChange
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 with no matches founded doesn't let the listbox to be opened", function () {
830
- var onChange = jest.fn();
831
-
832
- var _render27 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
833
- label: "Autocomplete Countries",
834
- suggestions: countries,
835
- onChange: onChange
836
- })),
837
- getByRole = _render27.getByRole,
838
- queryByRole = _render27.queryByRole,
839
- getByText = _render27.getByText;
840
-
841
- var input = getByRole("combobox");
842
-
843
- _react2.fireEvent.focus(input);
844
-
845
- var list = getByRole("listbox");
846
- expect(list).toBeTruthy();
847
- expect(getByText("Afghanistan")).toBeTruthy();
848
-
849
- _userEvent["default"].type(input, "x");
850
-
851
- expect(queryByRole("listbox")).toBeFalsy();
852
-
853
- _react2.fireEvent.focus(input);
854
-
855
- expect(queryByRole("listbox")).toBeFalsy();
856
-
857
- _react2.fireEvent.keyDown(input, {
858
- key: "ArrowUp",
859
- code: "ArrowUp",
860
- keyCode: 38,
861
- charCode: 38
862
- });
863
-
864
- expect(queryByRole("listbox")).toBeFalsy();
865
-
866
- _react2.fireEvent.keyDown(input, {
867
- key: "ArrowDown",
868
- code: "ArrowDown",
869
- keyCode: 40,
870
- charCode: 40
871
- });
872
-
873
- expect(queryByRole("listbox")).toBeFalsy();
874
- });
875
- test("Autosuggest uncontrolled - Suggestion selected by click", function () {
876
- var onChange = jest.fn();
877
-
878
- var _render28 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
879
- label: "Autocomplete Countries",
880
- suggestions: countries,
881
- onChange: onChange
882
- })),
883
- getByRole = _render28.getByRole,
884
- getByText = _render28.getByText,
885
- queryByRole = _render28.queryByRole;
886
-
887
- var input = getByRole("combobox");
888
-
889
- _react2.fireEvent.focus(input);
890
-
891
- _userEvent["default"].type(input, "Alba");
892
-
893
- expect(onChange).toHaveBeenCalled();
894
- expect(getByText("Alba")).toBeTruthy();
895
- expect(getByText("nia")).toBeTruthy();
896
-
897
- _userEvent["default"].click(getByRole("option"));
898
-
899
- expect(input.value).toBe("Albania");
900
- expect(queryByRole("listbox")).toBeFalsy();
901
- });
902
- test("Autosuggest controlled - Suggestion selected by click", function () {
903
- var onChange = jest.fn();
904
-
905
- var _render29 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
906
- label: "Autocomplete Countries",
907
- value: "Andor",
908
- suggestions: countries,
909
- onChange: onChange
910
- })),
911
- getByRole = _render29.getByRole,
912
- getByText = _render29.getByText,
913
- queryByRole = _render29.queryByRole;
914
-
915
- var input = getByRole("combobox");
916
-
917
- _userEvent["default"].click(getByText("Autocomplete Countries"));
918
-
919
- expect(input.value).toBe("Andor");
920
- expect(getByText("Andor")).toBeTruthy();
921
- expect(getByText("ra")).toBeTruthy();
922
-
923
- _userEvent["default"].click(getByRole("option"));
924
-
925
- expect(onChange).toHaveBeenCalledWith({
926
- value: "Andorra"
927
- });
928
- expect(queryByRole("listbox")).toBeFalsy();
929
- });
930
- test("Autosuggest - Pattern constraint", function () {
931
- var onChange = jest.fn();
932
- var onBlur = jest.fn();
933
-
934
- var _render30 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
935
- label: "Autocomplete Countries",
936
- suggestions: countries,
937
- onChange: onChange,
938
- onBlur: onBlur,
939
- pattern: "^.*(?=.*[a-zA-Z])(?=.*\\d)(?=.*[!&$%&? \"]).*$"
940
- })),
941
- getByRole = _render30.getByRole,
942
- getByText = _render30.getByText;
943
-
944
- var input = getByRole("combobox");
945
-
946
- _react2.fireEvent.focus(input);
947
-
948
- _userEvent["default"].type(input, "Andor");
949
-
950
- expect(getByText("Andor")).toBeTruthy();
951
- expect(getByText("ra")).toBeTruthy();
952
-
953
- _userEvent["default"].click(getByRole("option"));
954
-
955
- expect(onChange).toHaveBeenCalledWith({
956
- value: "Andorra",
957
- error: "Please match the format requested."
958
- });
959
-
960
- _react2.fireEvent.blur(input);
961
-
962
- expect(onBlur).toHaveBeenCalledWith({
963
- value: "Andorra",
964
- error: "Please match the format requested."
965
- });
966
- });
967
- test("Autosuggest - Length constraint", function () {
968
- var onChange = jest.fn();
969
- var onBlur = jest.fn();
970
-
971
- var _render31 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
972
- label: "Autocomplete Countries",
973
- suggestions: countries,
974
- onChange: onChange,
975
- onBlur: onBlur,
976
- minLength: 5,
977
- maxLength: 10
978
- })),
979
- getByText = _render31.getByText,
980
- getByRole = _render31.getByRole;
981
-
982
- var input = getByRole("combobox");
983
-
984
- _react2.fireEvent.focus(input);
985
-
986
- _userEvent["default"].type(input, "Cha");
987
-
988
- expect(getByText("Cha")).toBeTruthy();
989
- expect(getByText("d")).toBeTruthy();
990
-
991
- _userEvent["default"].click(getByRole("option"));
992
-
993
- expect(onChange).toHaveBeenCalledWith({
994
- value: "Cha",
995
- error: "Min length 5, max length 10."
996
- });
997
-
998
- _react2.fireEvent.blur(input);
999
-
1000
- expect(onBlur).toHaveBeenCalledWith({
1001
- value: "Chad",
1002
- error: "Min length 5, max length 10."
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
- var _render32 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1009
- label: "Autocomplete Countries",
1010
- suggestions: countries,
1011
- onChange: onChange
1012
- })),
1013
- getByRole = _render32.getByRole,
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
- var _render33 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1042
- label: "Autocomplete Countries",
1043
- suggestions: countries,
1044
- onChange: onChange
1045
- })),
1046
- getByRole = _render33.getByRole,
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
- var _render34 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1075
- label: "Autocomplete Countries",
1076
- suggestions: countries,
1077
- onChange: onChange
1078
- })),
1079
- getByRole = _render34.getByRole,
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
- var _render35 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1105
- label: "Autocomplete Countries",
1106
- suggestions: countries,
1107
- onChange: onChange
1108
- })),
1109
- getByRole = _render35.getByRole,
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 secuence: write, arrow up two times, arrow down and select with Enter. Then, clean with Esc.", function () {
1130
- var onChange = jest.fn();
1131
-
1132
- var _render36 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1133
- label: "Autocomplete Countries",
1134
- suggestions: countries,
1135
- onChange: onChange
1136
- })),
1137
- getByRole = _render36.getByRole,
1138
- queryByRole = _render36.queryByRole;
1139
-
1140
- var input = getByRole("combobox");
1141
-
1142
- _react2.fireEvent.focus(input);
1143
-
1144
- _userEvent["default"].type(input, "Ba");
1145
-
1146
- _react2.fireEvent.keyDown(input, {
1147
- key: "ArrowUp",
1148
- code: "ArrowUp",
1149
- keyCode: 38,
1150
- charCode: 38
1151
- });
1152
-
1153
- _react2.fireEvent.keyDown(input, {
1154
- key: "ArrowUp",
1155
- code: "ArrowUpp",
1156
- keyCode: 38,
1157
- charCode: 38
1158
- });
1159
-
1160
- _react2.fireEvent.keyDown(input, {
1161
- key: "ArrowDown",
1162
- code: "ArrowDown",
1163
- keyCode: 40,
1164
- charCode: 40
1165
- });
1166
-
1167
- _react2.fireEvent.keyDown(input, {
1168
- key: "Enter",
1169
- code: "Enter",
1170
- keyCode: 13,
1171
- charCode: 13
1172
- });
1173
-
1174
- expect(input.value).toBe("Barbados");
1175
- expect(queryByRole("listbox")).toBeFalsy();
1176
-
1177
- _react2.fireEvent.keyDown(input, {
1178
- key: "Esc",
1179
- code: "Esp",
1180
- keyCode: 27,
1181
- charCode: 27
1182
- });
1183
-
1184
- expect(input.value).toBe("");
1185
- expect(queryByRole("listbox")).toBeFalsy();
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
- var _render37 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1191
- label: "Autocomplete Countries",
1192
- suggestions: specialCharacters,
1193
- onChange: onChange
1194
- })),
1195
- getAllByText = _render37.getAllByText,
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 _callee() {
1288
- var callbackFunc, onChange, _render38, getByRole, getByText, input;
1289
-
1290
- return _regenerator["default"].wrap(function _callee$(_context) {
1291
- while (1) {
1292
- switch (_context.prev = _context.next) {
1293
- case 0:
1294
- callbackFunc = jest.fn(function (newValue) {
1295
- var result = new Promise(function (resolve) {
1296
- return setTimeout(function () {
1297
- resolve(newValue ? countries.filter(function (option) {
1298
- return option.toUpperCase().includes(newValue.toUpperCase());
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
- case 15:
1334
- expect(getByText("Cabo Verde")).toBeTruthy();
1335
-
1336
- _react2.fireEvent.keyDown(input, {
1337
- key: "ArrowUp",
1338
- code: "ArrowUp",
1339
- keyCode: 38,
1340
- charCode: 38
1341
- });
1342
-
1343
- _react2.fireEvent.keyDown(input, {
1344
- key: "Enter",
1345
- code: "Enter",
1346
- keyCode: 13,
1347
- charCode: 13
1348
- });
1349
-
1350
- expect(input.value).toBe("Cabo Verde");
1351
-
1352
- case 19:
1353
- case "end":
1354
- return _context.stop();
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
- }, _callee);
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
- var _render39 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1373
- label: "Autosuggest Countries",
1374
- suggestions: callbackFunc,
1375
- onChange: onChange
1376
- })),
1377
- getByRole = _render39.getByRole,
1378
- queryByText = _render39.queryByText,
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 _callee2() {
1401
- var callbackFunc, onChange, _render40, getByRole, getByText, queryByText, queryByRole, input, list;
1402
-
1403
- return _regenerator["default"].wrap(function _callee2$(_context2) {
1404
- while (1) {
1405
- switch (_context2.prev = _context2.next) {
1406
- case 0:
1407
- callbackFunc = jest.fn(function (newValue) {
1408
- var result = new Promise(function (resolve) {
1409
- return setTimeout(function () {
1410
- resolve(newValue ? countries.filter(function (option) {
1411
- return option.toUpperCase().includes(newValue.toUpperCase());
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
- expect(queryByRole("listbox")).toBeFalsy();
1440
- expect(queryByText("Searching...")).toBeFalsy();
1441
- expect(input.value).toBe("");
1442
-
1443
- _react2.fireEvent.keyDown(input, {
1444
- key: "ArrowDown",
1445
- code: "ArrowDown",
1446
- keyCode: 40,
1447
- charCode: 40
1448
- });
1449
-
1450
- expect(list).toBeTruthy();
1451
- _context2.next = 16;
1452
- return (0, _react2.waitForElementToBeRemoved)(function () {
1453
- return getByText("Searching...");
1454
- });
1455
-
1456
- case 16:
1457
- expect(getByText("Afghanistan")).toBeTruthy();
1458
- expect(getByText("Albania")).toBeTruthy();
1459
- expect(getByText("Algeria")).toBeTruthy();
1460
- expect(getByText("Andorra")).toBeTruthy();
1461
-
1462
- case 20:
1463
- case "end":
1464
- return _context2.stop();
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
- }, _callee2);
1514
+ }, _callee28);
1468
1515
  })));
1469
- test("Asynchronous uncontrolled autosuggest test", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() {
1470
- var callbackFunc, onChange, _render41, getByRole, getByText, input;
1471
-
1472
- return _regenerator["default"].wrap(function _callee3$(_context3) {
1473
- while (1) {
1474
- switch (_context3.prev = _context3.next) {
1475
- case 0:
1476
- callbackFunc = jest.fn(function (newValue) {
1477
- var result = new Promise(function (resolve) {
1478
- return setTimeout(function () {
1479
- resolve(newValue ? countries.filter(function (option) {
1480
- return option.toUpperCase().includes(newValue.toUpperCase());
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
- expect(input.value).toBe("Denmark");
1512
-
1513
- case 12:
1514
- case "end":
1515
- return _context3.stop();
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
- }, _callee3);
1557
+ }, _callee29);
1519
1558
  })));
1520
- test("Asynchronous controlled autosuggest test", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee4() {
1521
- var callbackFunc, onChange, _render42, getByRole, getByText, queryByRole, input;
1522
-
1523
- return _regenerator["default"].wrap(function _callee4$(_context4) {
1524
- while (1) {
1525
- switch (_context4.prev = _context4.next) {
1526
- case 0:
1527
- callbackFunc = jest.fn(function (newValue) {
1528
- var result = new Promise(function (resolve) {
1529
- return setTimeout(function () {
1530
- resolve(newValue ? countries.filter(function (option) {
1531
- return option.toUpperCase().includes(newValue.toUpperCase());
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
- expect(queryByRole("listbox")).toBeFalsy();
1565
-
1566
- case 13:
1567
- case "end":
1568
- return _context4.stop();
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
- }, _callee4);
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 _callee5() {
1574
- var callbackFunc, onChange, _render43, getByText, getByRole, queryByRole, input;
1575
-
1576
- return _regenerator["default"].wrap(function _callee5$(_context5) {
1577
- while (1) {
1578
- switch (_context5.prev = _context5.next) {
1579
- case 0:
1580
- callbackFunc = jest.fn(function (newValue) {
1581
- var result = new Promise(function (resolve) {
1582
- return setTimeout(function () {
1583
- resolve(newValue ? countries.filter(function (option) {
1584
- return option.toUpperCase().includes(newValue.toUpperCase());
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
- case 8:
1608
- expect(queryByRole("listbox")).toBeFalsy();
1609
-
1610
- case 9:
1611
- case "end":
1612
- return _context5.stop();
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
- }, _callee5);
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 _callee6() {
1618
- var callbackFunc, onChange, _render44, getByText, getByRole, queryByRole, input;
1619
-
1620
- return _regenerator["default"].wrap(function _callee6$(_context6) {
1621
- while (1) {
1622
- switch (_context6.prev = _context6.next) {
1623
- case 0:
1624
- callbackFunc = jest.fn(function (newValue) {
1625
- var result = new Promise(function (resolve) {
1626
- return setTimeout(function () {
1627
- resolve(newValue ? countries.filter(function (option) {
1628
- return option.toUpperCase().includes(newValue.toUpperCase());
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
- expect(queryByRole("listbox")).toBeFalsy();
1675
-
1676
- case 15:
1677
- case "end":
1678
- return _context6.stop();
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
- }, _callee6);
1704
+ }, _callee33);
1682
1705
  })));
1683
- test("Asynchronous autosuggest request failed, shows 'Error fetching data' message", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee7() {
1684
- var errorCallbackFunc, onChange, _render45, getByRole, getByText, input;
1685
-
1686
- return _regenerator["default"].wrap(function _callee7$(_context7) {
1687
- while (1) {
1688
- switch (_context7.prev = _context7.next) {
1689
- case 0:
1690
- errorCallbackFunc = jest.fn(function () {
1691
- var result = new Promise(function (resolve, reject) {
1692
- return setTimeout(function () {
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
- onChange = jest.fn();
1699
- _render45 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
1700
- label: "Autosuggest Countries",
1701
- onChange: onChange,
1702
- suggestions: errorCallbackFunc
1703
- })), getByRole = _render45.getByRole, getByText = _render45.getByText;
1704
- input = getByRole("combobox");
1705
-
1706
- _react2.fireEvent.focus(input);
1707
-
1708
- _context7.next = 7;
1709
- return (0, _react2.waitForElementToBeRemoved)(function () {
1710
- return getByText("Searching...");
1711
- });
1712
-
1713
- case 7:
1714
- expect(getByText("Error fetching data")).toBeTruthy();
1715
-
1716
- case 8:
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
- }, _callee7);
1737
+ }, _callee34);
1722
1738
  })));
1723
1739
  });