UNPKG

@wix/design-system

Version:

@wix/design-system

1,197 lines (1,196 loc) 109 kB
import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator"; import _extends from "@babel/runtime/helpers/extends"; import _classCallCheck from "@babel/runtime/helpers/classCallCheck"; import _createClass from "@babel/runtime/helpers/createClass"; import _possibleConstructorReturn from "@babel/runtime/helpers/possibleConstructorReturn"; import _getPrototypeOf from "@babel/runtime/helpers/getPrototypeOf"; import _inherits from "@babel/runtime/helpers/inherits"; var _jsxFileName = "/home/builduser/work/57e038ea7326c1ec/packages/wix-design-system/dist/esm/MultiSelect/test/MultiSelect.spec.jsx"; import _regeneratorRuntime from "@babel/runtime/regenerator"; function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } import React from 'react'; import { multiselectUniDriverFactory } from '../MultiSelect.uni.driver'; import MultiSelect from '../MultiSelect'; import { StatusContext } from '../../FormField/StatusContext'; import { createRendererWithUniDriver, cleanup } from '../../utils/test-utils/unit'; import { multiSelectPrivateDriverFactory } from './MultiSelect.private.uni.driver'; import { dataHooks } from '../../Tag/Tag.constants'; describe('MultiSelect', function () { describe('[async]', function () { runTests(createRendererWithUniDriver(multiselectUniDriverFactory)); runAsyncTests(createRendererWithUniDriver(multiSelectPrivateDriverFactory)); }); function runTests(render) { var _this3 = this; var createDriver = function createDriver(jsx) { return render(jsx).driver; }; var expectEventTargetValue = function expectEventTargetValue(value) { return expect.objectContaining({ target: expect.objectContaining({ value: value }) }); }; var options = [{ value: 'Alabama', id: 'Alabama' }, { value: 'Alaska', id: 'Alaska' }, { value: 'Arkansas', id: 'Arkansas' }, { value: 'Arkansas', id: 'Arkansas' }, { value: 'California', id: 'California' }, { value: 'Two words', id: 'Two words' }]; var FIRST_OPTION = options[0]; var FIRST_OPTION_ID = options[0].id; afterEach(function () { cleanup(); }); var ControlledMultiSelect = /*#__PURE__*/function (_React$Component) { function ControlledMultiSelect() { var _this; _classCallCheck(this, ControlledMultiSelect); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = _callSuper(this, ControlledMultiSelect, [].concat(args)); _this.state = { inputValue: _this.props.value || '' }; return _this; } _inherits(ControlledMultiSelect, _React$Component); return _createClass(ControlledMultiSelect, [{ key: "UNSAFE_componentWillReceiveProps", value: function UNSAFE_componentWillReceiveProps(nextProps) { this.setState({ inputValue: nextProps.value }); } }, { key: "render", value: function render() { var _this2 = this; return /*#__PURE__*/React.createElement(MultiSelect, _extends({}, this.props, { onChange: function onChange(e) { _this2.setState({ inputValue: e.target.value }); }, value: this.state.inputValue, __self: this, __source: { fileName: _jsxFileName, lineNumber: 50, columnNumber: 11 } })); } }]); }(React.Component); it('should NOT show dropdown when autofocus is on', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee() { var _createDriver, inputDriver, dropdownLayoutDriver; return _regeneratorRuntime.wrap(function _callee$(_context) { while (1) switch (_context.prev = _context.next) { case 0: _createDriver = createDriver(/*#__PURE__*/React.createElement(MultiSelect, { options: options, autoFocus: true, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 63, columnNumber: 9 } })), inputDriver = _createDriver.inputDriver, dropdownLayoutDriver = _createDriver.dropdownLayoutDriver; _context.t0 = expect; _context.next = 4; return inputDriver.isFocus(); case 4: _context.t1 = _context.sent; (0, _context.t0)(_context.t1).toBe(true); _context.t2 = expect; _context.next = 9; return dropdownLayoutDriver.isShown(); case 9: _context.t3 = _context.sent; (0, _context.t2)(_context.t3).toBe(false); case 11: case "end": return _context.stop(); } }, _callee); }))); it('should remove options that were selected and became tags', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee2() { var tags, _render, multiSelectDriver, rerender, dropdownLayoutDriver; return _regeneratorRuntime.wrap(function _callee2$(_context2) { while (1) switch (_context2.prev = _context2.next) { case 0: tags = [{ id: 'Alabama', label: 'Alabama' }]; _render = render(/*#__PURE__*/React.createElement(MultiSelect, { options: options, autoFocus: true, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 73, columnNumber: 9 } })), multiSelectDriver = _render.driver, rerender = _render.rerender; dropdownLayoutDriver = multiSelectDriver.dropdownLayoutDriver; _context2.t0 = expect; _context2.next = 6; return dropdownLayoutDriver.optionsLength(); case 6: _context2.t1 = _context2.sent; (0, _context2.t0)(_context2.t1).toBe(options.length); _context2.t2 = expect; _context2.next = 11; return dropdownLayoutDriver.isOptionExists('Alabama'); case 11: _context2.t3 = _context2.sent; (0, _context2.t2)(_context2.t3).toBe(true); rerender(/*#__PURE__*/React.createElement(MultiSelect, { options: options, tags: tags, autoFocus: true, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 79, columnNumber: 16 } })); _context2.t4 = expect; _context2.next = 17; return dropdownLayoutDriver.optionsLength(); case 17: _context2.t5 = _context2.sent; (0, _context2.t4)(_context2.t5).toBe(options.length - tags.length); _context2.t6 = expect; _context2.next = 22; return dropdownLayoutDriver.isOptionExists('Alabama'); case 22: _context2.t7 = _context2.sent; (0, _context2.t6)(_context2.t7).toBe(false); case 24: case "end": return _context2.stop(); } }, _callee2); }))); it('should not filter anything without predicate function', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee3() { var onSelect, _createDriver2, driver, dropdownLayoutDriver; return _regeneratorRuntime.wrap(function _callee3$(_context3) { while (1) switch (_context3.prev = _context3.next) { case 0: onSelect = vi.fn(); _createDriver2 = createDriver(/*#__PURE__*/React.createElement(MultiSelect, { options: options, onSelect: onSelect, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 89, columnNumber: 9 } })), driver = _createDriver2.driver, dropdownLayoutDriver = _createDriver2.dropdownLayoutDriver; _context3.next = 4; return driver.focus(); case 4: _context3.t0 = expect; _context3.next = 7; return dropdownLayoutDriver.optionsLength(); case 7: _context3.t1 = _context3.sent; (0, _context3.t0)(_context3.t1).toBe(options.length); case 9: case "end": return _context3.stop(); } }, _callee3); }))); it('should display empty state message in case all options are filtered', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee4() { var asciiA, emptyStateMessage, _createDriver3, inputDriver, dropdownLayoutDriver, option; return _regeneratorRuntime.wrap(function _callee4$(_context4) { while (1) switch (_context4.prev = _context4.next) { case 0: asciiA = 97; emptyStateMessage = 'Empty state'; _createDriver3 = createDriver(/*#__PURE__*/React.createElement(MultiSelect, { options: options, predicate: function predicate() { return false; }, emptyStateMessage: /*#__PURE__*/React.createElement("div", { __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 102, columnNumber: 30 } }, emptyStateMessage), __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 99, columnNumber: 9 } })), inputDriver = _createDriver3.inputDriver, dropdownLayoutDriver = _createDriver3.dropdownLayoutDriver; _context4.next = 5; return inputDriver.click(); case 5: _context4.next = 7; return inputDriver.trigger('keyDown', { key: asciiA }); case 7: _context4.t0 = expect; _context4.next = 10; return dropdownLayoutDriver.isShown(); case 10: _context4.t1 = _context4.sent; (0, _context4.t0)(_context4.t1).toBe(true); _context4.t2 = expect; _context4.next = 15; return dropdownLayoutDriver.optionsLength(); case 15: _context4.t3 = _context4.sent; (0, _context4.t2)(_context4.t3).toBe(1); _context4.next = 19; return dropdownLayoutDriver.options(); case 19: option = _context4.sent[0]; _context4.t4 = expect; _context4.next = 23; return option.content(); case 23: _context4.t5 = _context4.sent; (0, _context4.t4)(_context4.t5).toBe(emptyStateMessage); _context4.t6 = expect; _context4.next = 28; return option.isDisabled(); case 28: _context4.t7 = _context4.sent; (0, _context4.t6)(_context4.t7).toBe(true); case 30: case "end": return _context4.stop(); } }, _callee4); }))); it('should be editable', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee5() { var _createDriver4, driver; return _regeneratorRuntime.wrap(function _callee5$(_context5) { while (1) switch (_context5.prev = _context5.next) { case 0: _createDriver4 = createDriver(/*#__PURE__*/React.createElement(MultiSelect, { options: options, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 117, columnNumber: 39 } })), driver = _createDriver4.driver; _context5.t0 = expect; _context5.next = 4; return driver.isEditable(); case 4: _context5.t1 = _context5.sent; (0, _context5.t0)(_context5.t1).toBe(true); case 6: case "end": return _context5.stop(); } }, _callee5); }))); it('should NOT be editable on select mode', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee6() { var _createDriver5, driver; return _regeneratorRuntime.wrap(function _callee6$(_context6) { while (1) switch (_context6.prev = _context6.next) { case 0: _createDriver5 = createDriver(/*#__PURE__*/React.createElement(MultiSelect, { mode: "select", options: options, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 123, columnNumber: 9 } })), driver = _createDriver5.driver; _context6.t0 = expect; _context6.next = 4; return driver.isEditable(); case 4: _context6.t1 = _context6.sent; (0, _context6.t0)(_context6.t1).toBe(false); case 6: case "end": return _context6.stop(); } }, _callee6); }))); it('should render custom input as the input element', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee7() { var _createDriver6, inputDriver; return _regeneratorRuntime.wrap(function _callee7$(_context7) { while (1) switch (_context7.prev = _context7.next) { case 0: _createDriver6 = createDriver(/*#__PURE__*/React.createElement(MultiSelect, { options: options, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 129, columnNumber: 44 } })), inputDriver = _createDriver6.inputDriver; _context7.t0 = expect; _context7.next = 4; return inputDriver.isCustomInput(); case 4: _context7.t1 = _context7.sent; (0, _context7.t0)(_context7.t1).toEqual(true); case 6: case "end": return _context7.stop(); } }, _callee7); }))); describe('click-outside', function () { // TODO: failing after migrating to unidriver-jsdom-react it.skip('should clear input when clicked-out-side given input is non-empty', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee8() { var onChange, _createDriver7, driver, inputDriver; return _regeneratorRuntime.wrap(function _callee8$(_context8) { while (1) switch (_context8.prev = _context8.next) { case 0: onChange = vi.fn(function (e) { return e.persist(); }); _createDriver7 = createDriver(/*#__PURE__*/React.createElement(MultiSelect, { value: "", onChange: onChange, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 138, columnNumber: 11 } })), driver = _createDriver7.driver, inputDriver = _createDriver7.inputDriver; _context8.next = 4; return inputDriver.focus('ArrowDown'); case 4: _context8.next = 6; return inputDriver.enterText('foo'); case 6: expect(onChange).toHaveBeenCalledTimes(1); expect(onChange).toHaveBeenCalledWith(expectEventTargetValue('foo')); onChange.mockReset(); _context8.next = 11; return driver.outsideClick(); case 11: expect(onChange).toHaveBeenCalledTimes(1); expect(onChange).toHaveBeenCalledWith(expectEventTargetValue('')); case 13: case "end": return _context8.stop(); } }, _callee8); }))); // TODO: failing after migrating to unidriver-jsdom-react it.skip('should not clear input when clicked-out-side if clearOnBlur is set to false', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee9() { var onChange, _createDriver8, driver, inputDriver; return _regeneratorRuntime.wrap(function _callee9$(_context9) { while (1) switch (_context9.prev = _context9.next) { case 0: onChange = vi.fn(function (e) { return e.persist(); }); _createDriver8 = createDriver(/*#__PURE__*/React.createElement(MultiSelect, { value: "", onChange: onChange, clearOnBlur: false, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 155, columnNumber: 11 } })), driver = _createDriver8.driver, inputDriver = _createDriver8.inputDriver; _context9.next = 4; return inputDriver.focus('ArrowDown'); case 4: _context9.next = 6; return inputDriver.enterText('foo'); case 6: expect(onChange).toHaveBeenCalledTimes(1); expect(onChange).toHaveBeenCalledWith(expectEventTargetValue('foo')); onChange.mockReset(); _context9.next = 11; return driver.outsideClick(); case 11: expect(onChange).toHaveBeenCalledTimes(0); case 12: case "end": return _context9.stop(); } }, _callee9); }))); it('should NOT select option when clicked-out-side given option is marked', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee0() { var onSelect, _createDriver9, driver, dropdownLayoutDriver; return _regeneratorRuntime.wrap(function _callee0$(_context0) { while (1) switch (_context0.prev = _context0.next) { case 0: onSelect = vi.fn(); _createDriver9 = createDriver(/*#__PURE__*/React.createElement(ControlledMultiSelect, { options: options, onSelect: onSelect, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 171, columnNumber: 11 } })), driver = _createDriver9.driver, dropdownLayoutDriver = _createDriver9.dropdownLayoutDriver; _context0.next = 4; return driver.pressKey('ArrowDown'); case 4: _context0.next = 6; return driver.pressKey('ArrowDown'); case 6: _context0.t0 = expect; _context0.next = 9; return dropdownLayoutDriver.isOptionHovered(0); case 9: _context0.t1 = _context0.sent; (0, _context0.t0)(_context0.t1).toBe(true); _context0.next = 13; return driver.outsideClick(); case 13: expect(onSelect).toHaveBeenCalledTimes(0); case 14: case "end": return _context0.stop(); } }, _callee0); }))); }); describe('status attribute', function () { it('should have no status', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee1() { var _createDriver0, inputDriver; return _regeneratorRuntime.wrap(function _callee1$(_context1) { while (1) switch (_context1.prev = _context1.next) { case 0: _createDriver0 = createDriver(/*#__PURE__*/React.createElement(MultiSelect, { __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 183, columnNumber: 46 } })), inputDriver = _createDriver0.inputDriver; _context1.t0 = expect; _context1.next = 4; return inputDriver.hasStatus('error'); case 4: _context1.t1 = _context1.sent; (0, _context1.t0)(_context1.t1).toBe(false); case 6: case "end": return _context1.stop(); } }, _callee1); }))); it.each([{ status: 'error' }, { status: 'warning' }, { status: 'loading' }])('should display status when %p', /*#__PURE__*/function () { var _ref10 = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee10(test) { var _createDriver1, inputDriver; return _regeneratorRuntime.wrap(function _callee10$(_context10) { while (1) switch (_context10.prev = _context10.next) { case 0: _createDriver1 = createDriver(/*#__PURE__*/React.createElement(MultiSelect, _extends({}, test, { __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 193, columnNumber: 46 } }))), inputDriver = _createDriver1.inputDriver; _context10.t0 = expect; _context10.next = 4; return inputDriver.hasStatus(test.status); case 4: _context10.t1 = _context10.sent; (0, _context10.t0)(_context10.t1).toBe(true); case 6: case "end": return _context10.stop(); } }, _callee10); })); return function (_x) { return _ref10.apply(this, arguments); }; }()); it.each([{ status: 'error', statusMessage: 'Error Message' }, { status: 'warning', statusMessage: 'Warning Message' }, { status: 'loading', statusMessage: 'Loading Message' }])('should display status with message when %p', /*#__PURE__*/function () { var _ref11 = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee11(test) { var _createDriver10, inputDriver; return _regeneratorRuntime.wrap(function _callee11$(_context11) { while (1) switch (_context11.prev = _context11.next) { case 0: _createDriver10 = createDriver(/*#__PURE__*/React.createElement(MultiSelect, _extends({}, test, { __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 203, columnNumber: 46 } }))), inputDriver = _createDriver10.inputDriver; _context11.t0 = expect; _context11.next = 4; return inputDriver.hasStatus(test.status); case 4: _context11.t1 = _context11.sent; (0, _context11.t0)(_context11.t1).toBe(true); _context11.t2 = expect; _context11.next = 9; return inputDriver.getStatusMessage(); case 9: _context11.t3 = _context11.sent; (0, _context11.t2)(_context11.t3).toBe(test.statusMessage); case 11: case "end": return _context11.stop(); } }, _callee11); })); return function (_x2) { return _ref11.apply(this, arguments); }; }()); }); describe('Status Context', function () { describe('status', function () { it('should inherit status from context', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee12() { var contextStatus, _createDriver11, inputDriver; return _regeneratorRuntime.wrap(function _callee12$(_context12) { while (1) switch (_context12.prev = _context12.next) { case 0: contextStatus = 'error'; _createDriver11 = createDriver(/*#__PURE__*/React.createElement(StatusContext.Provider, { value: { status: contextStatus }, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 216, columnNumber: 13 } }, /*#__PURE__*/React.createElement(MultiSelect, { __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 217, columnNumber: 15 } }))), inputDriver = _createDriver11.inputDriver; _context12.t0 = expect; _context12.next = 5; return inputDriver.hasStatus(contextStatus); case 5: _context12.t1 = _context12.sent; (0, _context12.t0)(_context12.t1).toBe(true); case 7: case "end": return _context12.stop(); } }, _callee12); }))); it('should render component status [when] given status and statusContext too', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee13() { var propsStatus, contextStatus, _createDriver12, inputDriver; return _regeneratorRuntime.wrap(function _callee13$(_context13) { while (1) switch (_context13.prev = _context13.next) { case 0: propsStatus = 'warning'; contextStatus = 'error'; _createDriver12 = createDriver(/*#__PURE__*/React.createElement(StatusContext.Provider, { value: { status: contextStatus }, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 229, columnNumber: 13 } }, /*#__PURE__*/React.createElement(MultiSelect, { status: propsStatus, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 230, columnNumber: 15 } }))), inputDriver = _createDriver12.inputDriver; _context13.t0 = expect; _context13.next = 6; return inputDriver.hasStatus(propsStatus); case 6: _context13.t1 = _context13.sent; (0, _context13.t0)(_context13.t1).toBe(true); case 8: case "end": return _context13.stop(); } }, _callee13); }))); it.each(['error', 'warning'])('should not render status icon if %p is passed from context', /*#__PURE__*/function () { var _ref14 = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee14(status) { var _createDriver13, driver; return _regeneratorRuntime.wrap(function _callee14$(_context14) { while (1) switch (_context14.prev = _context14.next) { case 0: _createDriver13 = createDriver(/*#__PURE__*/React.createElement(StatusContext.Provider, { value: { status: status }, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 241, columnNumber: 15 } }, /*#__PURE__*/React.createElement(MultiSelect, { __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 242, columnNumber: 17 } }))), driver = _createDriver13.driver; _context14.t0 = expect; _context14.next = 4; return driver.statusIndicatorExists(); case 4: _context14.t1 = _context14.sent; (0, _context14.t0)(_context14.t1).toBe(false); case 6: case "end": return _context14.stop(); } }, _callee14); })); return function (_x3) { return _ref14.apply(this, arguments); }; }()); it('should render status icon if status is passed from context and from props', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee15() { var contextStatus, propsStatus, _createDriver14, driver; return _regeneratorRuntime.wrap(function _callee15$(_context15) { while (1) switch (_context15.prev = _context15.next) { case 0: contextStatus = 'error'; propsStatus = 'warning'; _createDriver14 = createDriver(/*#__PURE__*/React.createElement(StatusContext.Provider, { value: { status: contextStatus }, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 255, columnNumber: 13 } }, /*#__PURE__*/React.createElement(MultiSelect, { status: propsStatus, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 256, columnNumber: 15 } }))), driver = _createDriver14.driver; _context15.t0 = expect; _context15.next = 6; return driver.statusIndicatorExists(); case 6: _context15.t1 = _context15.sent; (0, _context15.t0)(_context15.t1).toBe(true); case 8: case "end": return _context15.stop(); } }, _callee15); }))); }); describe('ariaDescribedBy', function () { it('should inherit ariaDescribedBy [when] context provides', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee16() { var ariaDescribedBy, _createDriver15, driver; return _regeneratorRuntime.wrap(function _callee16$(_context16) { while (1) switch (_context16.prev = _context16.next) { case 0: ariaDescribedBy = 'some-id'; _createDriver15 = createDriver(/*#__PURE__*/React.createElement(StatusContext.Provider, { value: { ariaDescribedBy: ariaDescribedBy }, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 269, columnNumber: 13 } }, /*#__PURE__*/React.createElement(MultiSelect, { __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 270, columnNumber: 15 } }))), driver = _createDriver15.driver; _context16.t0 = expect; _context16.next = 5; return driver.element(); case 5: _context16.t1 = _context16.sent.querySelector('[data-input-parent]').firstChild.getAttribute('aria-describedby'); (0, _context16.t0)(_context16.t1).toBe(ariaDescribedBy); case 7: case "end": return _context16.stop(); } }, _callee16); }))); }); }); describe('Tag Input', function () { it('should render readonly input on select mode', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee17() { var _createDriver16, inputDriver; return _regeneratorRuntime.wrap(function _callee17$(_context17) { while (1) switch (_context17.prev = _context17.next) { case 0: _createDriver16 = createDriver(/*#__PURE__*/React.createElement(MultiSelect, { options: options, mode: "select", __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 286, columnNumber: 11 } })), inputDriver = _createDriver16.inputDriver; _context17.t0 = expect; _context17.next = 4; return inputDriver.getReadOnly(); case 4: _context17.t1 = _context17.sent; (0, _context17.t0)(_context17.t1).toBe(true); case 6: case "end": return _context17.stop(); } }, _callee17); }))); it('should render arrow on select mode', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee18() { var _createDriver17, inputDriver; return _regeneratorRuntime.wrap(function _callee18$(_context18) { while (1) switch (_context18.prev = _context18.next) { case 0: _createDriver17 = createDriver(/*#__PURE__*/React.createElement(MultiSelect, { options: options, mode: "select", __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 293, columnNumber: 11 } })), inputDriver = _createDriver17.inputDriver; _context18.t0 = expect; _context18.next = 4; return inputDriver.hasMenuArrow(); case 4: _context18.t1 = _context18.sent; (0, _context18.t0)(_context18.t1).toBe(true); case 6: case "end": return _context18.stop(); } }, _callee18); }))); it('should have disabled attribute on input if disabled', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee19() { var _createDriver18, driver; return _regeneratorRuntime.wrap(function _callee19$(_context19) { while (1) switch (_context19.prev = _context19.next) { case 0: _createDriver18 = createDriver(/*#__PURE__*/React.createElement(MultiSelect, { disabled: true, options: options, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 300, columnNumber: 11 } })), driver = _createDriver18.driver; _context19.t0 = expect; _context19.next = 4; return driver.isDisabled(); case 4: _context19.t1 = _context19.sent; (0, _context19.t0)(_context19.t1).toBe(true); _context19.t2 = expect; _context19.next = 9; return driver.inputWrapperIsDisabled(); case 9: _context19.t3 = _context19.sent; (0, _context19.t2)(_context19.t3).toBe(true); case 11: case "end": return _context19.stop(); } }, _callee19); }))); it('should have readOnly attribute on input if readOnly', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee20() { var _createDriver19, driver; return _regeneratorRuntime.wrap(function _callee20$(_context20) { while (1) switch (_context20.prev = _context20.next) { case 0: _createDriver19 = createDriver(/*#__PURE__*/React.createElement(MultiSelect, { readOnly: true, options: options, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 308, columnNumber: 11 } })), driver = _createDriver19.driver; _context20.t0 = expect; _context20.next = 4; return driver.isReadOnly(); case 4: _context20.t1 = _context20.sent; (0, _context20.t0)(_context20.t1).toBe(true); case 6: case "end": return _context20.stop(); } }, _callee20); }))); it('should render tag without remove button if readOnly mode is ON', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee21() { var tags, _createDriver20, driver; return _regeneratorRuntime.wrap(function _callee21$(_context21) { while (1) switch (_context21.prev = _context21.next) { case 0: tags = [{ id: 'Alabama', label: 'Alabama' }]; _createDriver20 = createDriver(/*#__PURE__*/React.createElement(MultiSelect, { readOnly: true, tags: tags, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 316, columnNumber: 41 } })), driver = _createDriver20.driver; _context21.t0 = expect; _context21.next = 5; return driver.element(); case 5: _context21.t1 = _context21.sent.querySelector("[data-hook=\"".concat(dataHooks.removeButton, "\"]")); (0, _context21.t0)(_context21.t1).toBeFalsy(); case 7: case "end": return _context21.stop(); } }, _callee21); }))); it('should render tag without remove button if readOnly mode is ON and "onReorder" function is passed', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee22() { var tags, onReorder, _createDriver21, driver; return _regeneratorRuntime.wrap(function _callee22$(_context22) { while (1) switch (_context22.prev = _context22.next) { case 0: tags = [{ id: 'Alabama', label: 'Alabama' }]; onReorder = vi.fn(); _createDriver21 = createDriver(/*#__PURE__*/React.createElement(MultiSelect, { readOnly: true, onReorder: onReorder, tags: tags, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 330, columnNumber: 11 } })), driver = _createDriver21.driver; _context22.t0 = expect; _context22.next = 6; return driver.element(); case 6: _context22.t1 = _context22.sent.querySelector("[data-hook=\"".concat(dataHooks.removeButton, "\"]")); (0, _context22.t0)(_context22.t1).toBeFalsy(); case 8: case "end": return _context22.stop(); } }, _callee22); }))); describe('Placeholder', function () { it('should display a placeholder if there are no tags', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee23() { var placeholder, _createDriver22, inputDriver; return _regeneratorRuntime.wrap(function _callee23$(_context23) { while (1) switch (_context23.prev = _context23.next) { case 0: placeholder = 'myPlaceholder'; _createDriver22 = createDriver(/*#__PURE__*/React.createElement(MultiSelect, { options: options, placeholder: placeholder, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 344, columnNumber: 13 } })), inputDriver = _createDriver22.inputDriver; _context23.t0 = expect; _context23.next = 5; return inputDriver.getPlaceholder(); case 5: _context23.t1 = _context23.sent; (0, _context23.t0)(_context23.t1).toBe(placeholder); case 7: case "end": return _context23.stop(); } }, _callee23); }))); it('should not display a placeholder if there are any tags', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee24() { var tags, placeholder, _createDriver23, inputDriver; return _regeneratorRuntime.wrap(function _callee24$(_context24) { while (1) switch (_context24.prev = _context24.next) { case 0: tags = [{ id: 'Alabama', label: 'Alabama' }]; placeholder = 'myPlaceholder'; _createDriver23 = createDriver(/*#__PURE__*/React.createElement(MultiSelect, { options: options, tags: tags, placeholder: placeholder, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 353, columnNumber: 13 } })), inputDriver = _createDriver23.inputDriver; _context24.t0 = expect; _context24.next = 6; return inputDriver.getPlaceholder(); case 6: _context24.t1 = _context24.sent; (0, _context24.t0)(_context24.t1).toBe(''); case 8: case "end": return _context24.stop(); } }, _callee24); }))); }); it('should focus the input when clicking on the input wrapper', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee25() { var _createDriver24, driver, inputDriver; return _regeneratorRuntime.wrap(function _callee25$(_context25) { while (1) switch (_context25.prev = _context25.next) { case 0: _createDriver24 = createDriver(/*#__PURE__*/React.createElement(MultiSelect, { options: options, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 365, columnNumber: 11 } })), driver = _createDriver24.driver, inputDriver = _createDriver24.inputDriver; _context25.t0 = expect; _context25.next = 4; return inputDriver.isFocus(); case 4: _context25.t1 = _context25.sent; (0, _context25.t0)(_context25.t1).toBe(false); _context25.next = 8; return driver.clickOnInputWrapper(); case 8: _context25.t2 = expect; _context25.next = 11; return inputDriver.isFocus(); case 11: _context25.t3 = _context25.sent; (0, _context25.t2)(_context25.t3).toBe(true); case 13: case "end": return _context25.stop(); } }, _callee25); }))); it('should check that wrapper has focus when the input element does', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee26() { var _createDriver25, driver, inputDriver; return _regeneratorRuntime.wrap(function _callee26$(_context26) { while (1) switch (_context26.prev = _context26.next) { case 0: _createDriver25 = createDriver(/*#__PURE__*/React.createElement(MultiSelect, { options: options, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 374, columnNumber: 11 } })), driver = _createDriver25.driver, inputDriver = _createDriver25.inputDriver; _context26.t0 = expect; _context26.next = 4; return driver.inputWrapperHasFocus(); case 4: _context26.t1 = _context26.sent; (0, _context26.t0)(_context26.t1).toBe(false); _context26.next = 8; return driver.clickOnInputWrapper(); case 8: _context26.t2 = expect; _context26.next = 11; return inputDriver.isFocus(); case 11: _context26.t3 = _context26.sent; (0, _context26.t2)(_context26.t3).toBe(true); _context26.t4 = expect; _context26.next = 16; return driver.inputWrapperHasFocus(); case 16: _context26.t5 = _context26.sent; (0, _context26.t4)(_context26.t5).toBe(true); case 18: case "end": return _context26.stop(); } }, _callee26); }))); it('should contain specific tags', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee27() { var tags, _createDriver26, driver; return _regeneratorRuntime.wrap(function _callee27$(_context27) { while (1) switch (_context27.prev = _context27.next) { case 0: tags = [{ id: 'Alabama', label: 'Alabama' }, { id: 'Alaska', label: 'Alaska' }]; _createDriver26 = createDriver(/*#__PURE__*/React.createElement(MultiSelect, { options: options, tags: tags, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 390, columnNumber: 11 } })), driver = _createDriver26.driver; _context27.t0 = expect; _context27.next = 5; return driver.numberOfTags(); case 5: _context27.t1 = _context27.sent; (0, _context27.t0)(_context27.t1).toBe(tags.length); _context27.t2 = expect; _context27.next = 10; return driver.getTagLabelAt(0); case 10: _context27.t3 = _context27.sent; (0, _context27.t2)(_context27.t3).toBe('Alabama'); _context27.t4 = expect; _context27.next = 15; return driver.getTagLabelAt(1); case 15: _context27.t5 = _context27.sent; (0, _context27.t4)(_context27.t5).toBe('Alaska'); case 17: case "end": return _context27.stop(); } }, _callee27); }))); describe('Submit (Add Tag)', function () { describe('input is empty', function () { it('should NOT submit when Enter is pressed', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee28() { var onManuallyInput, _createDriver27, driver; return _regeneratorRuntime.wrap(function _callee28$(_context28) { while (1) switch (_context28.prev = _context28.next) { case 0: onManuallyInput = vi.fn(); _createDriver27 = createDriver(/*#__PURE__*/React.createElement(ControlledMultiSelect, { options: options, onManuallyInput: onManuallyInput, __self: _this3, __source: { fileName: _jsxFileName, lineNumber: 402, columnNumber: 15 } })), driver = _createDriver27.driver; _context28.next = 4; return driver.focus(); case 4: _context28.next = 6; return driver.pressKey('Enter'); case 6: expect(onManuallyInput).toHaveBeenCalledTimes(0); case 7: case "end": return _context28.stop(); } }, _callee28); }))); }); describe('input is not empty', function () { function testCase(_x4) { return _testCase.apply(this, arguments); } function _testCase() { _testCase = _asyncToGenerator(/*#__PURE__*/_regeneratorRunt