@instructure/ui-selectable 10.11.1-snapshot-2 → 10.11.1-snapshot-3

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.
@@ -0,0 +1,775 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+ var _react = _interopRequireDefault(require("react"));
5
+ var _react2 = require("@testing-library/react");
6
+ var _vitest = require("vitest");
7
+ var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
8
+ require("@testing-library/jest-dom");
9
+ var _index = require("../index");
10
+ /*
11
+ * The MIT License (MIT)
12
+ *
13
+ * Copyright (c) 2015 - present Instructure, Inc.
14
+ *
15
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
16
+ * of this software and associated documentation files (the "Software"), to deal
17
+ * in the Software without restriction, including without limitation the rights
18
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
19
+ * copies of the Software, and to permit persons to whom the Software is
20
+ * furnished to do so, subject to the following conditions:
21
+ *
22
+ * The above copyright notice and this permission notice shall be included in all
23
+ * copies or substantial portions of the Software.
24
+ *
25
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
26
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
27
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
28
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
29
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
30
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
31
+ * SOFTWARE.
32
+ */
33
+
34
+ const defaultOptions = ['foo', 'bar', 'baz'];
35
+ describe('<Selectable />', () => {
36
+ const getSelectable = selectable => /*#__PURE__*/_react.default.createElement("span", selectable.getRootProps(), /*#__PURE__*/_react.default.createElement("label", selectable.getLabelProps(), "Selectable"), /*#__PURE__*/_react.default.createElement("input", Object.assign({
37
+ type: "text"
38
+ }, selectable.getTriggerProps(), selectable.getInputProps())), /*#__PURE__*/_react.default.createElement("ul", selectable.getListProps(), defaultOptions.map(opt => /*#__PURE__*/_react.default.createElement("li", Object.assign({
39
+ key: opt
40
+ }, selectable.getOptionProps({
41
+ id: opt
42
+ })), opt))));
43
+ it('should focus trigger when label is clicked', async () => {
44
+ (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, null, selectable => /*#__PURE__*/_react.default.createElement("span", selectable.getRootProps(), /*#__PURE__*/_react.default.createElement("label", selectable.getLabelProps(), "Selectable"), /*#__PURE__*/_react.default.createElement("input", Object.assign({
45
+ type: "text"
46
+ }, selectable.getTriggerProps(), selectable.getInputProps())), /*#__PURE__*/_react.default.createElement("ul", selectable.getListProps(), defaultOptions.map(opt => /*#__PURE__*/_react.default.createElement("li", Object.assign({
47
+ key: opt
48
+ }, selectable.getOptionProps({
49
+ id: opt
50
+ })), opt))))));
51
+ const label = _react2.screen.getByText('Selectable');
52
+ const input = _react2.screen.getByRole('combobox');
53
+ expect(document.activeElement).not.toBe(input);
54
+ _userEvent.default.click(label);
55
+ await (0, _react2.waitFor)(() => {
56
+ expect(document.activeElement).toBe(input);
57
+ });
58
+ });
59
+ it('should not blur trigger when label is clicked', async () => {
60
+ const onFocus = _vitest.vi.fn();
61
+ const onBlur = _vitest.vi.fn();
62
+ (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, null, selectable => /*#__PURE__*/_react.default.createElement("span", selectable.getRootProps(), /*#__PURE__*/_react.default.createElement("label", selectable.getLabelProps(), "Selectable"), /*#__PURE__*/_react.default.createElement("input", Object.assign({
63
+ type: "text"
64
+ }, selectable.getTriggerProps(), selectable.getInputProps(), {
65
+ onBlur: onBlur,
66
+ onFocus: onFocus
67
+ })), /*#__PURE__*/_react.default.createElement("ul", selectable.getListProps(), defaultOptions.map(opt => /*#__PURE__*/_react.default.createElement("li", Object.assign({
68
+ key: opt
69
+ }, selectable.getOptionProps({
70
+ id: opt
71
+ })), opt))))));
72
+ const label = _react2.screen.getByText('Selectable');
73
+ const input = _react2.screen.getByRole('combobox');
74
+ expect(document.activeElement).not.toBe(input);
75
+ _userEvent.default.click(label);
76
+ await (0, _react2.waitFor)(() => {
77
+ expect(onFocus).toHaveBeenCalledTimes(1);
78
+ expect(onBlur).not.toHaveBeenCalled();
79
+ });
80
+ });
81
+ it('should not hide options when list is clicked', async () => {
82
+ const onClick = _vitest.vi.fn();
83
+ const onMouseDown = _vitest.vi.fn();
84
+ const onRequestHideOptions = _vitest.vi.fn();
85
+ (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
86
+ isShowingOptions: true,
87
+ onRequestHideOptions: onRequestHideOptions
88
+ }, selectable => /*#__PURE__*/_react.default.createElement("span", selectable.getRootProps(), /*#__PURE__*/_react.default.createElement("label", selectable.getLabelProps(), "Selectable"), /*#__PURE__*/_react.default.createElement("input", Object.assign({
89
+ type: "text"
90
+ }, selectable.getTriggerProps(), selectable.getInputProps())), /*#__PURE__*/_react.default.createElement("ul", selectable.getListProps({
91
+ onClick,
92
+ onMouseDown
93
+ }), defaultOptions.map(opt => /*#__PURE__*/_react.default.createElement("li", Object.assign({
94
+ key: opt
95
+ }, selectable.getOptionProps({
96
+ id: opt
97
+ })), opt))))));
98
+ const input = _react2.screen.getByRole('combobox');
99
+ const list = _react2.screen.getByRole('listbox');
100
+ input.focus();
101
+ _userEvent.default.click(list);
102
+ await (0, _react2.waitFor)(() => {
103
+ expect(document.activeElement).toBe(input);
104
+ expect(onClick).toHaveBeenCalledTimes(1);
105
+ expect(onMouseDown).toHaveBeenCalledTimes(1);
106
+ expect(onRequestHideOptions).not.toHaveBeenCalled();
107
+ });
108
+ });
109
+ it('should not hide options when an option is clicked', async () => {
110
+ const onClick = _vitest.vi.fn();
111
+ const onMouseDown = _vitest.vi.fn();
112
+ const onRequestHideOptions = _vitest.vi.fn();
113
+ (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
114
+ isShowingOptions: true,
115
+ onRequestHideOptions: onRequestHideOptions
116
+ }, selectable => /*#__PURE__*/_react.default.createElement("span", selectable.getRootProps(), /*#__PURE__*/_react.default.createElement("label", selectable.getLabelProps(), "Selectable"), /*#__PURE__*/_react.default.createElement("input", Object.assign({
117
+ type: "text"
118
+ }, selectable.getTriggerProps(), selectable.getInputProps())), /*#__PURE__*/_react.default.createElement("ul", selectable.getListProps(), defaultOptions.map(opt => /*#__PURE__*/_react.default.createElement("li", Object.assign({
119
+ key: opt
120
+ }, selectable.getOptionProps({
121
+ id: opt,
122
+ onClick,
123
+ onMouseDown
124
+ })), opt))))));
125
+ const input = _react2.screen.getByRole('combobox');
126
+ const option = _react2.screen.getByText('foo');
127
+ input.focus();
128
+ _userEvent.default.click(option);
129
+ await (0, _react2.waitFor)(() => {
130
+ expect(document.activeElement).toBe(input);
131
+ expect(onClick).toHaveBeenCalledTimes(1);
132
+ expect(onMouseDown).toHaveBeenCalledTimes(1);
133
+ expect(onRequestHideOptions).not.toHaveBeenCalled();
134
+ });
135
+ });
136
+ it('should not prevent events on other children', async () => {
137
+ var _button;
138
+ const onMouseDown = _vitest.vi.fn();
139
+ const onClick = _vitest.vi.fn();
140
+ const onKeyDown = _vitest.vi.fn();
141
+ (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, null, selectable => /*#__PURE__*/_react.default.createElement("span", selectable.getRootProps(), /*#__PURE__*/_react.default.createElement("label", selectable.getLabelProps(), "Selectable"), _button || (_button = /*#__PURE__*/_react.default.createElement("button", {
142
+ onMouseDown: onMouseDown,
143
+ onClick: onClick,
144
+ onKeyDown: onKeyDown
145
+ }, "Selected")), /*#__PURE__*/_react.default.createElement("input", Object.assign({
146
+ type: "text"
147
+ }, selectable.getTriggerProps(), selectable.getInputProps())), /*#__PURE__*/_react.default.createElement("ul", selectable.getListProps(), defaultOptions.map(opt => /*#__PURE__*/_react.default.createElement("li", Object.assign({
148
+ key: opt
149
+ }, selectable.getOptionProps({
150
+ id: opt
151
+ })), opt))))));
152
+ const button = _react2.screen.getByText('Selected');
153
+ _userEvent.default.click(button);
154
+ await _userEvent.default.type(button, '{enter}');
155
+ await (0, _react2.waitFor)(() => {
156
+ expect(onClick).toHaveBeenCalled();
157
+ expect(onMouseDown).toHaveBeenCalled();
158
+ expect(onKeyDown).toHaveBeenCalled();
159
+ });
160
+ });
161
+ describe('with callbacks', () => {
162
+ describe('should fire onRequestShowOptions', () => {
163
+ it('when label is clicked', async () => {
164
+ const onRequestShowOptions = _vitest.vi.fn();
165
+ const _render = (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
166
+ isShowingOptions: false,
167
+ onRequestShowOptions: onRequestShowOptions
168
+ }, selectable => getSelectable(selectable))),
169
+ rerender = _render.rerender;
170
+ const label = _react2.screen.getByText('Selectable');
171
+ _userEvent.default.click(label);
172
+ await (0, _react2.waitFor)(() => {
173
+ expect(onRequestShowOptions).toHaveBeenCalledTimes(1);
174
+ });
175
+
176
+ // Set isShowingOptions:
177
+ rerender(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
178
+ isShowingOptions: true,
179
+ onRequestShowOptions: onRequestShowOptions
180
+ }, selectable => getSelectable(selectable)));
181
+ _userEvent.default.click(label);
182
+ await (0, _react2.waitFor)(() => {
183
+ expect(onRequestShowOptions).toHaveBeenCalledTimes(1);
184
+ });
185
+ });
186
+ it('when input is clicked', async () => {
187
+ const onRequestShowOptions = _vitest.vi.fn();
188
+ const _render2 = (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
189
+ isShowingOptions: false,
190
+ onRequestShowOptions: onRequestShowOptions
191
+ }, selectable => getSelectable(selectable))),
192
+ rerender = _render2.rerender;
193
+ const input = _react2.screen.getByRole('combobox');
194
+ _userEvent.default.click(input);
195
+ await (0, _react2.waitFor)(() => {
196
+ expect(onRequestShowOptions).toHaveBeenCalledTimes(1);
197
+ });
198
+ rerender(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
199
+ isShowingOptions: true,
200
+ onRequestShowOptions: onRequestShowOptions
201
+ }, selectable => getSelectable(selectable)));
202
+ _userEvent.default.click(input);
203
+ await (0, _react2.waitFor)(() => {
204
+ expect(onRequestShowOptions).toHaveBeenCalledTimes(1);
205
+ });
206
+ });
207
+ it('when up/down arrows are pressed', async () => {
208
+ const onRequestShowOptions = _vitest.vi.fn();
209
+ (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
210
+ isShowingOptions: false,
211
+ onRequestShowOptions: onRequestShowOptions
212
+ }, selectable => getSelectable(selectable)));
213
+ const input = _react2.screen.getByRole('combobox');
214
+ await _userEvent.default.type(input, '{arrowdown}');
215
+ await (0, _react2.waitFor)(() => {
216
+ expect(onRequestShowOptions).toHaveBeenCalledTimes(1);
217
+ });
218
+ await _userEvent.default.type(input, '{arrowup}');
219
+ await (0, _react2.waitFor)(() => {
220
+ expect(onRequestShowOptions).toHaveBeenCalledTimes(2);
221
+ });
222
+ });
223
+ it('when space is pressed', async () => {
224
+ const onRequestShowOptions = _vitest.vi.fn();
225
+ const _render3 = (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
226
+ onRequestShowOptions: onRequestShowOptions
227
+ }, selectable => getSelectable(selectable))),
228
+ rerender = _render3.rerender;
229
+ const input = _react2.screen.getByRole('combobox');
230
+ await _userEvent.default.type(input, '{space}');
231
+ rerender(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
232
+ isShowingOptions: true,
233
+ onRequestShowOptions: onRequestShowOptions
234
+ }, selectable => getSelectable(selectable)));
235
+ await _userEvent.default.type(input, '{space}');
236
+ await (0, _react2.waitFor)(() => {
237
+ expect(onRequestShowOptions).toHaveBeenCalledTimes(1);
238
+ });
239
+ });
240
+ });
241
+ describe('should fire onRequestHideOptions', () => {
242
+ it('when label is clicked', async () => {
243
+ const onRequestHideOptions = _vitest.vi.fn();
244
+ const _render4 = (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
245
+ isShowingOptions: true,
246
+ onRequestHideOptions: onRequestHideOptions
247
+ }, selectable => getSelectable(selectable))),
248
+ rerender = _render4.rerender;
249
+ const label = _react2.screen.getByText('Selectable');
250
+ await _userEvent.default.click(label);
251
+ await (0, _react2.waitFor)(() => {
252
+ expect(onRequestHideOptions).toHaveBeenCalledTimes(1);
253
+ });
254
+ rerender(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
255
+ isShowingOptions: false,
256
+ onRequestHideOptions: onRequestHideOptions
257
+ }, selectable => getSelectable(selectable)));
258
+ await _userEvent.default.click(label);
259
+ await (0, _react2.waitFor)(() => {
260
+ expect(onRequestHideOptions).toHaveBeenCalledTimes(1);
261
+ });
262
+ });
263
+ it('when input is clicked', async () => {
264
+ const onRequestHideOptions = _vitest.vi.fn();
265
+ const _render5 = (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
266
+ isShowingOptions: true,
267
+ onRequestHideOptions: onRequestHideOptions
268
+ }, selectable => getSelectable(selectable))),
269
+ rerender = _render5.rerender;
270
+ const input = _react2.screen.getByRole('combobox');
271
+ await _userEvent.default.click(input);
272
+ await (0, _react2.waitFor)(() => {
273
+ expect(onRequestHideOptions).toHaveBeenCalledTimes(1);
274
+ });
275
+ rerender(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
276
+ isShowingOptions: false,
277
+ onRequestHideOptions: onRequestHideOptions
278
+ }, selectable => getSelectable(selectable)));
279
+ await _userEvent.default.click(input);
280
+ await (0, _react2.waitFor)(() => {
281
+ expect(onRequestHideOptions).toHaveBeenCalledTimes(1);
282
+ });
283
+ });
284
+ });
285
+ });
286
+ describe('getRootProps()', () => {
287
+ it('should provide prop getter for root element', async () => {
288
+ const renderSpy = _vitest.vi.fn();
289
+ (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, null, selectable => {
290
+ renderSpy(selectable);
291
+ return null;
292
+ }));
293
+ const selectableProps = renderSpy.mock.calls[0][0];
294
+ expect(selectableProps.getRootProps).toBeDefined();
295
+ });
296
+ it('should allow custom props to pass through', async () => {
297
+ (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, null, selectable => /*#__PURE__*/_react.default.createElement("span", selectable.getRootProps({
298
+ 'data-custom-attr': true,
299
+ className: 'customClass',
300
+ style: {
301
+ color: 'red'
302
+ }
303
+ }), /*#__PURE__*/_react.default.createElement("label", selectable.getLabelProps(), "Selectable"), /*#__PURE__*/_react.default.createElement("input", Object.assign({
304
+ type: "text"
305
+ }, selectable.getTriggerProps(), selectable.getInputProps())))));
306
+ const root = _react2.screen.getByText('Selectable').closest('span');
307
+ expect(root).toHaveAttribute('data-custom-attr', 'true');
308
+ expect(root).toHaveClass('customClass');
309
+ expect(root).toHaveStyle('color: rgb(255, 0, 0)');
310
+ });
311
+ it('should allow supplemental onClick behavior', async () => {
312
+ const onClick = _vitest.vi.fn();
313
+ const onRequestShowOptions = _vitest.vi.fn();
314
+ (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
315
+ onRequestShowOptions: onRequestShowOptions
316
+ }, selectable => /*#__PURE__*/_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement("input", Object.assign({
317
+ type: "text"
318
+ }, selectable.getTriggerProps({
319
+ onClick
320
+ }), selectable.getInputProps())))));
321
+ const input = _react2.screen.getByRole('combobox');
322
+ await _userEvent.default.click(input);
323
+ await (0, _react2.waitFor)(() => {
324
+ expect(onClick).toHaveBeenCalledTimes(1);
325
+ expect(onRequestShowOptions).toHaveBeenCalledTimes(1);
326
+ });
327
+ });
328
+ });
329
+ describe('getLabelProps()', () => {
330
+ it('should provide prop getter for label element', async () => {
331
+ const renderSpy = _vitest.vi.fn();
332
+ (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, null, selectable => {
333
+ renderSpy(selectable);
334
+ return null;
335
+ }));
336
+ expect(renderSpy.mock.calls[0].length > 0).toBeTruthy();
337
+ });
338
+ it('should set htmlFor prop', async () => {
339
+ (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, null, selectable => /*#__PURE__*/_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement("label", selectable.getLabelProps(), "Selectable"), /*#__PURE__*/_react.default.createElement("input", Object.assign({
340
+ type: "text"
341
+ }, selectable.getTriggerProps(), selectable.getInputProps())))));
342
+ const label = _react2.screen.getByText('Selectable');
343
+ const input = _react2.screen.getByRole('combobox');
344
+ expect(label).toHaveAttribute('for', input.getAttribute('id'));
345
+ });
346
+ it('should set htmlFor prop with custom defined id', async () => {
347
+ const customId = 'CustomSelect';
348
+ (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
349
+ id: customId
350
+ }, selectable => /*#__PURE__*/_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement("label", selectable.getLabelProps(), "Selectable"), /*#__PURE__*/_react.default.createElement("input", Object.assign({
351
+ type: "text"
352
+ }, selectable.getTriggerProps(), selectable.getInputProps())))));
353
+ const label = _react2.screen.getByText('Selectable');
354
+ const input = _react2.screen.getByRole('combobox');
355
+ expect(input).toHaveAttribute('id', customId);
356
+ expect(label).toHaveAttribute('for', customId);
357
+ });
358
+ it('should allow custom props to pass through', async () => {
359
+ (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, null, selectable => /*#__PURE__*/_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement("label", selectable.getLabelProps({
360
+ 'data-custom-attr': true,
361
+ className: 'customClass',
362
+ style: {
363
+ color: 'red'
364
+ }
365
+ }), "Selectable"), /*#__PURE__*/_react.default.createElement("input", Object.assign({
366
+ type: "text"
367
+ }, selectable.getTriggerProps(), selectable.getInputProps())))));
368
+ const label = _react2.screen.getByText('Selectable');
369
+ expect(label).toHaveAttribute('data-custom-attr', 'true');
370
+ expect(label).toHaveClass('customClass');
371
+ expect(label).toHaveStyle({
372
+ color: 'rgb(255, 0, 0)'
373
+ });
374
+ });
375
+ });
376
+ describe('getTriggerProps()', () => {
377
+ it('should provide prop getter for trigger element', async () => {
378
+ const renderSpy = _vitest.vi.fn();
379
+ (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, null, selectable => {
380
+ renderSpy(selectable);
381
+ return null;
382
+ }));
383
+ expect(renderSpy.mock.calls[0][0].getTriggerProps).toBeDefined();
384
+ });
385
+ it('should set appropriate prop defaults', async () => {
386
+ const _render6 = (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, null, selectable => /*#__PURE__*/_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement("input", Object.assign({
387
+ type: "text"
388
+ }, selectable.getTriggerProps())), /*#__PURE__*/_react.default.createElement("span", selectable.getDescriptionProps(), "description")))),
389
+ container = _render6.container;
390
+ const input = container.querySelector('input');
391
+ const desc = _react2.screen.getByText('description');
392
+ expect(input).toHaveAttribute('aria-haspopup', 'listbox');
393
+ expect(input).toHaveAttribute('aria-describedby', desc.id);
394
+ expect(input).toHaveAttribute('id');
395
+ });
396
+ it('should set appropriate props based on isShowingOptions', async () => {
397
+ const _render7 = (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
398
+ isShowingOptions: false
399
+ }, selectable => /*#__PURE__*/_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement("input", Object.assign({
400
+ type: "text"
401
+ }, selectable.getTriggerProps())), /*#__PURE__*/_react.default.createElement("ul", selectable.getListProps())))),
402
+ container = _render7.container,
403
+ rerender = _render7.rerender;
404
+ const input = container.querySelector('input');
405
+ const list = _react2.screen.getByRole('listbox');
406
+ expect(input).toHaveAttribute('aria-expanded', 'false');
407
+ expect(input).not.toHaveAttribute('aria-controls');
408
+
409
+ // Set prop: isShowingOptions true
410
+ rerender(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
411
+ isShowingOptions: true
412
+ }, selectable => /*#__PURE__*/_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement("input", Object.assign({
413
+ type: "text"
414
+ }, selectable.getTriggerProps())), /*#__PURE__*/_react.default.createElement("ul", selectable.getListProps()))));
415
+ expect(input).toHaveAttribute('aria-expanded', 'true');
416
+ expect(input).toHaveAttribute('aria-controls', list.id);
417
+ });
418
+ it('should set appropriate props based on highlightedOptionId', async () => {
419
+ const _render8 = (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
420
+ isShowingOptions: true
421
+ }, selectable => /*#__PURE__*/_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement("input", Object.assign({
422
+ type: "text"
423
+ }, selectable.getTriggerProps())), /*#__PURE__*/_react.default.createElement("ul", selectable.getListProps(), defaultOptions.map(opt => /*#__PURE__*/_react.default.createElement("li", Object.assign({
424
+ key: opt
425
+ }, selectable.getOptionProps({
426
+ id: opt
427
+ })))))))),
428
+ container = _render8.container,
429
+ rerender = _render8.rerender;
430
+ const input = container.querySelector('input');
431
+ const options = _react2.screen.getAllByRole('option');
432
+ expect(input).not.toHaveAttribute('aria-activedescendant');
433
+
434
+ // Set prop: highlightedOptionId
435
+ rerender(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
436
+ isShowingOptions: true,
437
+ highlightedOptionId: defaultOptions[0]
438
+ }, selectable => /*#__PURE__*/_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement("input", Object.assign({
439
+ type: "text"
440
+ }, selectable.getTriggerProps())), /*#__PURE__*/_react.default.createElement("ul", selectable.getListProps(), defaultOptions.map(opt => /*#__PURE__*/_react.default.createElement("li", Object.assign({
441
+ key: opt
442
+ }, selectable.getOptionProps({
443
+ id: opt
444
+ }))))))));
445
+ expect(input).toHaveAttribute('aria-activedescendant', options[0].id);
446
+
447
+ // Set prop: highlightedOptionId
448
+ rerender(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
449
+ isShowingOptions: true,
450
+ highlightedOptionId: defaultOptions[1]
451
+ }, selectable => /*#__PURE__*/_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement("input", Object.assign({
452
+ type: "text"
453
+ }, selectable.getTriggerProps())), /*#__PURE__*/_react.default.createElement("ul", selectable.getListProps(), defaultOptions.map(opt => /*#__PURE__*/_react.default.createElement("li", Object.assign({
454
+ key: opt
455
+ }, selectable.getOptionProps({
456
+ id: opt
457
+ }))))))));
458
+ expect(input).toHaveAttribute('aria-activedescendant', options[1].id);
459
+
460
+ // Set prop: isShowingOptions
461
+ rerender(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
462
+ isShowingOptions: false,
463
+ highlightedOptionId: defaultOptions[1]
464
+ }, selectable => /*#__PURE__*/_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement("input", Object.assign({
465
+ type: "text"
466
+ }, selectable.getTriggerProps())), /*#__PURE__*/_react.default.createElement("ul", selectable.getListProps(), defaultOptions.map(opt => /*#__PURE__*/_react.default.createElement("li", Object.assign({
467
+ key: opt
468
+ }, selectable.getOptionProps({
469
+ id: opt
470
+ }))))))));
471
+ expect(input).not.toHaveAttribute('aria-activedescendant');
472
+ });
473
+ it('should allow custom props to pass through', async () => {
474
+ const _render9 = (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, null, selectable => /*#__PURE__*/_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement("input", Object.assign({
475
+ type: "text"
476
+ }, selectable.getTriggerProps({
477
+ 'data-custom-attr': true,
478
+ placeholder: 'Type to enter text',
479
+ className: 'customClass',
480
+ style: {
481
+ color: 'red'
482
+ }
483
+ })))))),
484
+ container = _render9.container;
485
+ const input = container.querySelector('input');
486
+ expect(input).toHaveAttribute('data-custom-attr', 'true');
487
+ expect(input).toHaveAttribute('style', 'color: red;');
488
+ expect(input).toHaveAttribute('placeholder');
489
+ expect(input).toHaveClass('customClass');
490
+ });
491
+ it('should allow props to be overridden', async () => {
492
+ const _render10 = (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, null, selectable => /*#__PURE__*/_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement("input", Object.assign({
493
+ type: "text"
494
+ }, selectable.getTriggerProps({
495
+ 'aria-haspopup': 'menu',
496
+ 'aria-controls': 'customId'
497
+ })))))),
498
+ container = _render10.container;
499
+ const input = container.querySelector('input');
500
+ expect(input).toHaveAttribute('aria-haspopup', 'menu');
501
+ expect(input).toHaveAttribute('aria-controls', 'customId');
502
+ });
503
+ it('should provide a ref to the text input', async () => {
504
+ const inputRef = _vitest.vi.fn();
505
+ const _render11 = (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, null, selectable => /*#__PURE__*/_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement("input", Object.assign({
506
+ type: "text"
507
+ }, selectable.getTriggerProps({
508
+ ref: inputRef
509
+ })))))),
510
+ container = _render11.container;
511
+ const input = container.querySelector('input');
512
+ expect(inputRef).toHaveBeenCalledWith(input);
513
+ });
514
+ it('should allow role and aria-autocomplete props to be overridden', async () => {
515
+ const _render12 = (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, null, selectable => /*#__PURE__*/_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement("input", Object.assign({
516
+ type: "text"
517
+ }, selectable.getTriggerProps({
518
+ role: 'textbox',
519
+ 'aria-autocomplete': 'list'
520
+ })))))),
521
+ container = _render12.container;
522
+ const input = container.querySelector('input');
523
+ expect(input).toHaveAttribute('role', 'textbox');
524
+ expect(input).toHaveAttribute('aria-autocomplete', 'list');
525
+ });
526
+ it('should allow supplemental onClick behavior', async () => {
527
+ const onClick = _vitest.vi.fn();
528
+ const onRequestShowOptions = _vitest.vi.fn();
529
+ (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
530
+ onRequestShowOptions: onRequestShowOptions
531
+ }, selectable => /*#__PURE__*/_react.default.createElement("span", selectable.getRootProps(), /*#__PURE__*/_react.default.createElement("input", Object.assign({
532
+ type: "text"
533
+ }, selectable.getTriggerProps({
534
+ onClick
535
+ }), selectable.getInputProps())))));
536
+ const input = _react2.screen.getByRole('combobox');
537
+ await input.click();
538
+ expect(onClick).toHaveBeenCalledTimes(1);
539
+ expect(onRequestShowOptions).toHaveBeenCalledTimes(1);
540
+ });
541
+ });
542
+ describe('getInputProps()', () => {
543
+ it('should provide prop getter for trigger element', async () => {
544
+ const renderSpy = _vitest.vi.fn();
545
+ (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, null, selectable => {
546
+ renderSpy(selectable);
547
+ return null;
548
+ }));
549
+ const args = renderSpy.mock.calls[0][0];
550
+ expect(args.getInputProps).toBeDefined();
551
+ });
552
+ it('should set appropriate prop defaults', async () => {
553
+ const _render13 = (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, null, selectable => /*#__PURE__*/_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement("input", Object.assign({
554
+ type: "text"
555
+ }, selectable.getInputProps()))))),
556
+ container = _render13.container;
557
+ const input = container.querySelector('input');
558
+ expect(input).toHaveAttribute('role', 'combobox');
559
+ expect(input).toHaveAttribute('aria-autocomplete', 'both');
560
+ expect(input).toHaveAttribute('autocomplete', 'off');
561
+ });
562
+ it('should set appropriate props when readOnly', async () => {
563
+ (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, null, selectable => /*#__PURE__*/_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement("input", Object.assign({
564
+ type: "text"
565
+ }, selectable.getInputProps({
566
+ readOnly: true
567
+ }))))));
568
+ const input = _react2.screen.getByRole('combobox');
569
+ expect(input).toHaveAttribute('aria-autocomplete', 'none');
570
+ expect(input).toHaveAttribute('readOnly');
571
+ expect(input).not.toHaveAttribute('disabled');
572
+ });
573
+ it('should allow props to be overridden', async () => {
574
+ const _render14 = (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, null, selectable => /*#__PURE__*/_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement("input", Object.assign({
575
+ type: "text"
576
+ }, selectable.getInputProps({
577
+ role: 'textbox',
578
+ 'aria-autocomplete': 'inline'
579
+ })))))),
580
+ container = _render14.container;
581
+ const input = container.querySelector('input');
582
+ expect(input).toHaveAttribute('role', 'textbox');
583
+ expect(input).toHaveAttribute('aria-autocomplete', 'inline');
584
+ });
585
+ it('should allow custom props to pass through', async () => {
586
+ const _render15 = (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, null, selectable => /*#__PURE__*/_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement("input", Object.assign({
587
+ type: "text"
588
+ }, selectable.getInputProps({
589
+ 'data-custom-attr': true,
590
+ placeholder: 'Type to enter text',
591
+ className: 'customClass',
592
+ style: {
593
+ color: 'red'
594
+ }
595
+ })))))),
596
+ container = _render15.container;
597
+ const input = container.querySelector('input');
598
+ expect(input).toHaveAttribute('data-custom-attr', 'true');
599
+ expect(input).toHaveAttribute('placeholder');
600
+ expect(input).toHaveClass('customClass');
601
+ expect(input).toHaveAttribute('style', 'color: red;');
602
+ });
603
+ });
604
+ describe('getListProps()', () => {
605
+ it('should provide prop getter for list element', async () => {
606
+ const renderSpy = _vitest.vi.fn();
607
+ (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, null, selectable => {
608
+ renderSpy(selectable);
609
+ return null;
610
+ }));
611
+ const args = renderSpy.mock.calls[0][0];
612
+ expect(args.getListProps).toBeDefined();
613
+ });
614
+ it('should set appropriate prop defaults', async () => {
615
+ const _render16 = (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
616
+ isShowingOptions: true
617
+ }, selectable => /*#__PURE__*/_react.default.createElement("span", selectable.getRootProps(), /*#__PURE__*/_react.default.createElement("input", Object.assign({
618
+ type: "text"
619
+ }, selectable.getTriggerProps())), /*#__PURE__*/_react.default.createElement("ul", selectable.getListProps())))),
620
+ container = _render16.container;
621
+ const list = container.querySelector('ul');
622
+ expect(list).toHaveAttribute('id');
623
+ expect(list).toHaveAttribute('role', 'listbox');
624
+ });
625
+ it('should allow custom props to pass through', async () => {
626
+ const _render17 = (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
627
+ isShowingOptions: true
628
+ }, selectable => /*#__PURE__*/_react.default.createElement("span", selectable.getRootProps(), /*#__PURE__*/_react.default.createElement("input", Object.assign({
629
+ type: "text"
630
+ }, selectable.getTriggerProps())), /*#__PURE__*/_react.default.createElement("ul", selectable.getListProps({
631
+ 'data-custom-attr': true,
632
+ className: 'customClass',
633
+ style: {
634
+ color: 'red'
635
+ }
636
+ }))))),
637
+ container = _render17.container;
638
+ const list = container.querySelector('ul');
639
+ expect(list).toHaveAttribute('data-custom-attr', 'true');
640
+ expect(list).toHaveClass('customClass');
641
+ expect(list).toHaveAttribute('style', 'color: red;');
642
+ });
643
+ });
644
+ describe('getOptionProps()', () => {
645
+ it('should provide prop getter for option element', async () => {
646
+ const renderSpy = _vitest.vi.fn();
647
+ (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, null, selectable => {
648
+ renderSpy(selectable);
649
+ return null;
650
+ }));
651
+ const args = renderSpy.mock.calls[0][0];
652
+ expect(args.getOptionProps).toBeDefined();
653
+ });
654
+ it('should set appropriate prop defaults', async () => {
655
+ (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, null, selectable => /*#__PURE__*/_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement("input", Object.assign({
656
+ type: "text"
657
+ }, selectable.getTriggerProps())), /*#__PURE__*/_react.default.createElement("ul", selectable.getListProps(), defaultOptions.map(opt => /*#__PURE__*/_react.default.createElement("li", Object.assign({
658
+ key: opt
659
+ }, selectable.getOptionProps({
660
+ id: opt
661
+ })), opt))))));
662
+ const option = _react2.screen.getByText(defaultOptions[0]);
663
+ expect(option.tagName).toBe('LI');
664
+ expect(option).toHaveAttribute('role', 'option');
665
+ expect(option).toHaveAttribute('aria-selected', 'false');
666
+ });
667
+ it('should set aria-selected based on selectedOptionId', async () => {
668
+ const _render18 = (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
669
+ selectedOptionId: defaultOptions[1]
670
+ }, selectable => /*#__PURE__*/_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement("input", Object.assign({
671
+ type: "text"
672
+ }, selectable.getTriggerProps())), /*#__PURE__*/_react.default.createElement("ul", selectable.getListProps(), defaultOptions.map(opt => /*#__PURE__*/_react.default.createElement("li", Object.assign({
673
+ key: opt
674
+ }, selectable.getOptionProps({
675
+ id: opt
676
+ })), opt)))))),
677
+ container = _render18.container,
678
+ rerender = _render18.rerender;
679
+ const options = container.querySelectorAll('li');
680
+ expect(options[0]).toHaveAttribute('aria-selected', 'false');
681
+ expect(options[1]).toHaveAttribute('aria-selected', 'true');
682
+ expect(options[2]).toHaveAttribute('aria-selected', 'false');
683
+
684
+ // Set prop: selectedOptionId
685
+ rerender(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
686
+ selectedOptionId: [defaultOptions[0], defaultOptions[1]]
687
+ }, selectable => /*#__PURE__*/_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement("input", Object.assign({
688
+ type: "text"
689
+ }, selectable.getTriggerProps())), /*#__PURE__*/_react.default.createElement("ul", selectable.getListProps(), defaultOptions.map(opt => /*#__PURE__*/_react.default.createElement("li", Object.assign({
690
+ key: opt
691
+ }, selectable.getOptionProps({
692
+ id: opt
693
+ })), opt))))));
694
+ expect(options[0]).toHaveAttribute('aria-selected', 'true');
695
+ expect(options[1]).toHaveAttribute('aria-selected', 'true');
696
+ expect(options[2]).toHaveAttribute('aria-selected', 'false');
697
+ });
698
+ it('should allow custom props to pass through', async () => {
699
+ (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, null, selectable => /*#__PURE__*/_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement("input", Object.assign({
700
+ type: "text"
701
+ }, selectable.getTriggerProps())), /*#__PURE__*/_react.default.createElement("ul", selectable.getListProps(), defaultOptions.map(opt => /*#__PURE__*/_react.default.createElement("li", Object.assign({
702
+ key: opt
703
+ }, selectable.getOptionProps({
704
+ id: opt,
705
+ 'data-custom-attr': true,
706
+ className: 'customClass',
707
+ style: {
708
+ color: 'red'
709
+ }
710
+ })), opt))))));
711
+ const option = _react2.screen.getByText(defaultOptions[0]);
712
+ expect(option.tagName).toBe('LI');
713
+ expect(option).toHaveAttribute('data-custom-attr', 'true');
714
+ expect(option).toHaveClass('customClass');
715
+ expect(option).toHaveAttribute('style', 'color: red;');
716
+ });
717
+ it('should allow supplemental onClick behavior', async () => {
718
+ const onClick = _vitest.vi.fn();
719
+ const onRequestSelectOption = _vitest.vi.fn();
720
+ (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, {
721
+ isShowingOptions: true,
722
+ onRequestSelectOption: onRequestSelectOption
723
+ }, selectable => /*#__PURE__*/_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement("input", Object.assign({
724
+ type: "text"
725
+ }, selectable.getInputProps())), /*#__PURE__*/_react.default.createElement("ul", selectable.getListProps(), defaultOptions.map(opt => /*#__PURE__*/_react.default.createElement("li", Object.assign({
726
+ key: opt
727
+ }, selectable.getOptionProps({
728
+ id: opt,
729
+ onClick
730
+ })), opt))))));
731
+ const option_0 = _react2.screen.getByText(defaultOptions[0]);
732
+ const option_1 = _react2.screen.getByText(defaultOptions[1]);
733
+ _userEvent.default.click(option_0);
734
+ _userEvent.default.click(option_1);
735
+ await (0, _react2.waitFor)(() => {
736
+ expect(onRequestSelectOption).toHaveBeenCalledTimes(2);
737
+ expect(onClick).toHaveBeenCalledTimes(2);
738
+ });
739
+ });
740
+ });
741
+ describe('getDisabledOptionProps()', () => {
742
+ it('should provide prop getter for disabled option element', async () => {
743
+ const renderSpy = _vitest.vi.fn();
744
+ (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, null, selectable => {
745
+ renderSpy(selectable);
746
+ return null;
747
+ }));
748
+ const args = renderSpy.mock.calls[0][0];
749
+ expect(args.getDisabledOptionProps).toBeDefined();
750
+ });
751
+ it('should set aria-disabled prop', async () => {
752
+ (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, null, selectable => /*#__PURE__*/_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement("input", Object.assign({
753
+ type: "text"
754
+ }, selectable.getTriggerProps(), selectable.getInputProps())), /*#__PURE__*/_react.default.createElement("ul", selectable.getListProps(), defaultOptions.map(opt => /*#__PURE__*/_react.default.createElement("li", Object.assign({
755
+ key: opt
756
+ }, selectable.getOptionProps({
757
+ id: opt
758
+ }), selectable.getDisabledOptionProps()), opt))))));
759
+ const option = _react2.screen.getByText(defaultOptions[0]);
760
+ expect(option.tagName).toBe('LI');
761
+ expect(option).toHaveAttribute('aria-disabled', 'true');
762
+ });
763
+ });
764
+ describe('getDescriptionProps()', () => {
765
+ it('should provide prop getter for description element', async () => {
766
+ const renderSpy = _vitest.vi.fn();
767
+ (0, _react2.render)(/*#__PURE__*/_react.default.createElement(_index.Selectable, null, selectable => {
768
+ renderSpy(selectable);
769
+ return null;
770
+ }));
771
+ const selectableProps = renderSpy.mock.calls[0][0];
772
+ expect(selectableProps.getDescriptionProps).toBeDefined();
773
+ });
774
+ });
775
+ });