UNPKG

@wix/design-system

Version:

@wix/design-system

1,202 lines 171 kB
import _toConsumableArray from "@babel/runtime/helpers/toConsumableArray"; import _createClass from "@babel/runtime/helpers/createClass"; import _classCallCheck from "@babel/runtime/helpers/classCallCheck"; import _possibleConstructorReturn from "@babel/runtime/helpers/possibleConstructorReturn"; import _getPrototypeOf from "@babel/runtime/helpers/getPrototypeOf"; import _inherits from "@babel/runtime/helpers/inherits"; import _extends from "@babel/runtime/helpers/extends"; import _slicedToArray from "@babel/runtime/helpers/slicedToArray"; import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator"; import _defineProperty from "@babel/runtime/helpers/defineProperty"; var _jsxFileName = "/home/builduser/work/57e038ea7326c1ec/packages/wix-design-system/dist/esm/TimeInput/test/TimeInput.spec.jsx", _this = this; 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 _regeneratorRuntime from "@babel/runtime/regenerator"; function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } import React from 'react'; import { act, waitFor } from '../../utils/test-utils/react'; import { createRendererWithUniDriver } from '../../utils/test-utils/unit'; import { TimeInputPrivateDriverFactory } from './TimeInput.private.uni.driver'; import TimeInput, { DEFAULT_STEP, DEFAULT_TIME_STYLE } from '../TimeInput'; import { getClosestTimeSlot, getTimeSlots } from '../TimeInputUtils'; import WixStyleReactEnvironmentProvider from '../../WixStyleReactEnvironmentProvider'; describe(TimeInput.displayName, function () { var render = createRendererWithUniDriver(TimeInputPrivateDriverFactory); beforeAll(function () { var OriginalDateTimeFormat = Intl.DateTimeFormat; vi.spyOn(global.Intl, 'DateTimeFormat').mockImplementation(function (locale, options) { return new OriginalDateTimeFormat(locale, _objectSpread(_objectSpread({}, options), {}, { numberingSystem: 'latn' })); }); }); afterAll(function () { vi.restoreAllMocks(); }); describe('onChange', function () { it("should call onChange with selected date as a parameter [when] second time slot in a list is chosen and value is confirmed", /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee() { var onChange, value, _render, driver, timeSlots; return _regeneratorRuntime.wrap(function _callee$(_context) { while (1) switch (_context.prev = _context.next) { case 0: onChange = vi.fn(); value = new Date('2020-01-01 00:00'); _render = render(/*#__PURE__*/React.createElement(TimeInput, { onChange: onChange, value: value, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 33, columnNumber: 9 } })), driver = _render.driver; timeSlots = getTimeSlots({ value: value, timeStyle: DEFAULT_TIME_STYLE, locale: 'en', step: DEFAULT_STEP }); _context.next = 6; return driver.clickOnInput(); case 6: _context.next = 8; return driver.selectOptionAt(1); case 8: _context.next = 10; return driver.confirmValue(); case 10: expect(onChange).toHaveBeenCalledWith({ date: new Date(timeSlots[1].id) }); case 11: case "end": return _context.stop(); } }, _callee); }))); it('should call onChange one time [when] time slot is selected from dropdown and value is confirmed', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee2() { var onChange, _render2, driver; return _regeneratorRuntime.wrap(function _callee2$(_context2) { while (1) switch (_context2.prev = _context2.next) { case 0: onChange = vi.fn(); _render2 = render(/*#__PURE__*/React.createElement(TimeInput, { onChange: onChange, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 54, columnNumber: 33 } })), driver = _render2.driver; _context2.next = 4; return driver.clickOnInput(); case 4: expect(onChange).not.toHaveBeenCalled(); _context2.next = 7; return driver.selectOptionAt(1); case 7: expect(onChange).toHaveBeenCalledTimes(1); _context2.next = 10; return driver.confirmValue(); case 10: expect(onChange).toHaveBeenCalledTimes(1); case 11: case "end": return _context2.stop(); } }, _callee2); }))); it("should call onChange with date object [when] manually typing time value and confirming it", /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee3() { var onChange, value, _render3, driver; return _regeneratorRuntime.wrap(function _callee3$(_context3) { while (1) switch (_context3.prev = _context3.next) { case 0: onChange = vi.fn(); value = new Date('2020-01-01 00:00'); _render3 = render(/*#__PURE__*/React.createElement(TimeInput, { onChange: onChange, value: value, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 70, columnNumber: 9 } })), driver = _render3.driver; _context3.next = 5; return driver.setValue('12:48'); case 5: _context3.next = 7; return driver.confirmValue(); case 7: expect(onChange).toHaveBeenCalledWith({ date: new Date('2020-01-01 12:48') }); case 8: case "end": return _context3.stop(); } }, _callee3); }))); it("should call onChange with date object [when] time from dropdown is typed in and value is confirmed", /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee4() { var onChange, _render4, driver; return _regeneratorRuntime.wrap(function _callee4$(_context4) { while (1) switch (_context4.prev = _context4.next) { case 0: onChange = vi.fn(); _render4 = render(/*#__PURE__*/React.createElement(TimeInput, { onChange: onChange, locale: "en", __self: _this, __source: { fileName: _jsxFileName, lineNumber: 82, columnNumber: 33 } })), driver = _render4.driver; _context4.next = 4; return driver.setValue('12:00 PM'); case 4: _context4.next = 6; return driver.confirmValue(); case 6: expect(onChange).toHaveBeenCalled(); case 7: case "end": return _context4.stop(); } }, _callee4); }))); it("should call onChange with null [when] clears value and confirms it", /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee5() { var onChange, _render5, driver; return _regeneratorRuntime.wrap(function _callee5$(_context5) { while (1) switch (_context5.prev = _context5.next) { case 0: onChange = vi.fn(); _render5 = render(/*#__PURE__*/React.createElement(TimeInput, { onChange: onChange, value: new Date(), __self: _this, __source: { fileName: _jsxFileName, lineNumber: 93, columnNumber: 9 } })), driver = _render5.driver; _context5.next = 4; return driver.setValue(''); case 4: _context5.next = 6; return driver.confirmValue(); case 6: expect(onChange).toHaveBeenCalledWith({ date: null }); case 7: case "end": return _context5.stop(); } }, _callee5); }))); }); describe('onInvalid', function () { it('should call onInvalid only once', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee6() { var onInvalid, MockedComponent, _render6, driver, invalidValue; return _regeneratorRuntime.wrap(function _callee6$(_context6) { while (1) switch (_context6.prev = _context6.next) { case 0: onInvalid = vi.fn(); MockedComponent = function MockedComponent() { var _React$useState = React.useState(), _React$useState2 = _slicedToArray(_React$useState, 2), _invalidValue = _React$useState2[0], setInvalidValue = _React$useState2[1]; var handleInvalid = function handleInvalid(value) { onInvalid(); setInvalidValue(value); }; return /*#__PURE__*/React.createElement(TimeInput, { size: "medium", onInvalid: handleInvalid, value: null, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 118, columnNumber: 11 } }); }; _render6 = render(/*#__PURE__*/React.createElement(MockedComponent, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 122, columnNumber: 33 } })), driver = _render6.driver; invalidValue = 'typing time'; _context6.next = 6; return driver.setValue(invalidValue); case 6: _context6.next = 8; return driver.blur(); case 8: expect(onInvalid).toHaveBeenCalledTimes(1); case 9: case "end": return _context6.stop(); } }, _callee6); }))); it('should call onInvalid with "formatError" [when] user types invalid value', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee7() { var onInvalid, _render7, driver, invalidValue; return _regeneratorRuntime.wrap(function _callee7$(_context7) { while (1) switch (_context7.prev = _context7.next) { case 0: onInvalid = vi.fn(); _render7 = render(/*#__PURE__*/React.createElement(TimeInput, { onInvalid: onInvalid, invalidMessage: "Invalid message", __self: _this, __source: { fileName: _jsxFileName, lineNumber: 134, columnNumber: 9 } })), driver = _render7.driver; invalidValue = 'typing time'; _context7.next = 5; return driver.setValue(invalidValue); case 5: expect(onInvalid).toHaveBeenCalledWith({ validationType: 'formatError', value: invalidValue }); case 6: case "end": return _context7.stop(); } }, _callee7); }))); it('should call onInvalid and not call onChange [when] user types value that can`t be parsed', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee8() { var onInvalid, onChange, _render8, driver, invalidValue; return _regeneratorRuntime.wrap(function _callee8$(_context8) { while (1) switch (_context8.prev = _context8.next) { case 0: onInvalid = vi.fn(); onChange = vi.fn(); _render8 = render(/*#__PURE__*/React.createElement(TimeInput, { onInvalid: onInvalid, onChange: onChange, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 151, columnNumber: 9 } })), driver = _render8.driver; invalidValue = '12a'; _context8.next = 6; return driver.setValue(invalidValue); case 6: _context8.next = 8; return driver.confirmValue(); case 8: expect(onInvalid).toHaveBeenCalledWith({ validationType: 'formatError', value: invalidValue }); expect(onChange).not.toHaveBeenCalled(); case 10: case "end": return _context8.stop(); } }, _callee8); }))); it('should call onInvalid and not call onChange [when] user types invalid numbers', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee9() { var onInvalid, onChange, _render9, driver, invalidValue; return _regeneratorRuntime.wrap(function _callee9$(_context9) { while (1) switch (_context9.prev = _context9.next) { case 0: onInvalid = vi.fn(); onChange = vi.fn(); _render9 = render(/*#__PURE__*/React.createElement(TimeInput, { onInvalid: onInvalid, onChange: onChange, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 169, columnNumber: 9 } })), driver = _render9.driver; invalidValue = '27:99 PM'; _context9.next = 6; return driver.setValue(invalidValue); case 6: _context9.next = 8; return driver.confirmValue(); case 8: expect(onInvalid).toHaveBeenCalledWith({ validationType: 'formatError', value: invalidValue }); expect(onChange).not.toHaveBeenCalled(); case 10: case "end": return _context9.stop(); } }, _callee9); }))); it('should not call onInvalid and not set status to `error` [when] user clears value and confirms it', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee0() { var status, onInvalid, _render0, driver; return _regeneratorRuntime.wrap(function _callee0$(_context0) { while (1) switch (_context0.prev = _context0.next) { case 0: status = 'error'; onInvalid = vi.fn(); _render0 = render(/*#__PURE__*/React.createElement(TimeInput, { value: new Date(), onInvalid: onInvalid, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 186, columnNumber: 9 } })), driver = _render0.driver; _context0.next = 5; return driver.setValue(''); case 5: _context0.next = 7; return driver.confirmValue(); case 7: _context0.t0 = expect; _context0.next = 10; return driver.hasStatus(status); case 10: _context0.t1 = _context0.sent; (0, _context0.t0)(_context0.t1).toBe(false); expect(onInvalid).not.toHaveBeenCalled(); case 13: case "end": return _context0.stop(); } }, _callee0); }))); }); describe('user interactions', function () { it("dropdown opens [when] clicked on input", /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee1() { var _render1, driver; return _regeneratorRuntime.wrap(function _callee1$(_context1) { while (1) switch (_context1.prev = _context1.next) { case 0: _render1 = render(/*#__PURE__*/React.createElement(TimeInput, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 199, columnNumber: 33 } })), driver = _render1.driver; _context1.next = 3; return driver.clickOnInput(); case 3: _context1.t0 = expect; _context1.next = 6; return driver.isDropdownShown(); case 6: _context1.t1 = _context1.sent; (0, _context1.t0)(_context1.t1).toBe(true); case 8: case "end": return _context1.stop(); } }, _callee1); }))); it("dropdown closes [when] option is selected", /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee13() { var _render10, driver; return _regeneratorRuntime.wrap(function _callee13$(_context13) { while (1) switch (_context13.prev = _context13.next) { case 0: _render10 = render(/*#__PURE__*/React.createElement(TimeInput, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 206, columnNumber: 33 } })), driver = _render10.driver; _context13.next = 3; return act(/*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee10() { return _regeneratorRuntime.wrap(function _callee10$(_context10) { while (1) switch (_context10.prev = _context10.next) { case 0: _context10.next = 2; return driver.clickOnInput(); case 2: case "end": return _context10.stop(); } }, _callee10); }))); case 3: _context13.t0 = expect; _context13.next = 6; return driver.isDropdownShown(); case 6: _context13.t1 = _context13.sent; (0, _context13.t0)(_context13.t1).toBe(true); _context13.next = 10; return act(/*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee11() { return _regeneratorRuntime.wrap(function _callee11$(_context11) { while (1) switch (_context11.prev = _context11.next) { case 0: _context11.next = 2; return driver.selectOptionAt(1); case 2: case "end": return _context11.stop(); } }, _callee11); }))); case 10: _context13.next = 12; return waitFor(/*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee12() { return _regeneratorRuntime.wrap(function _callee12$(_context12) { while (1) switch (_context12.prev = _context12.next) { case 0: _context12.t0 = expect; _context12.next = 3; return driver.isDropdownShown(); case 3: _context12.t1 = _context12.sent; (0, _context12.t0)(_context12.t1).toBe(false); case 5: case "end": return _context12.stop(); } }, _callee12); }))); case 12: case "end": return _context13.stop(); } }, _callee13); }))); it("dropdown closes [when] clicked outside", /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee18() { var _render11, driver; return _regeneratorRuntime.wrap(function _callee18$(_context18) { while (1) switch (_context18.prev = _context18.next) { case 0: _render11 = render(/*#__PURE__*/React.createElement(TimeInput, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 224, columnNumber: 33 } })), driver = _render11.driver; _context18.next = 3; return act(/*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee14() { return _regeneratorRuntime.wrap(function _callee14$(_context14) { while (1) switch (_context14.prev = _context14.next) { case 0: _context14.next = 2; return driver.clickOnInput(); case 2: case "end": return _context14.stop(); } }, _callee14); }))); case 3: _context18.next = 5; return waitFor(/*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee15() { return _regeneratorRuntime.wrap(function _callee15$(_context15) { while (1) switch (_context15.prev = _context15.next) { case 0: _context15.t0 = expect; _context15.next = 3; return driver.isDropdownShown(); case 3: _context15.t1 = _context15.sent; (0, _context15.t0)(_context15.t1).toBe(true); case 5: case "end": return _context15.stop(); } }, _callee15); }))); case 5: _context18.next = 7; return act(/*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee16() { return _regeneratorRuntime.wrap(function _callee16$(_context16) { while (1) switch (_context16.prev = _context16.next) { case 0: _context16.next = 2; return driver.clickOutside(); case 2: case "end": return _context16.stop(); } }, _callee16); }))); case 7: _context18.next = 9; return waitFor(/*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee17() { return _regeneratorRuntime.wrap(function _callee17$(_context17) { while (1) switch (_context17.prev = _context17.next) { case 0: _context17.t0 = expect; _context17.next = 3; return driver.isDropdownShown(); case 3: _context17.t1 = _context17.sent; (0, _context17.t0)(_context17.t1).toBe(false); case 5: case "end": return _context17.stop(); } }, _callee17); }))); case 9: case "end": return _context18.stop(); } }, _callee18); }))); it("input value is set [when] option from dropdown is selected", /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee19() { var value, step, _render12, driver; return _regeneratorRuntime.wrap(function _callee19$(_context19) { while (1) switch (_context19.prev = _context19.next) { case 0: value = new Date('2020-05-06 00:00'); step = 15; _render12 = render(/*#__PURE__*/React.createElement(TimeInput, { value: value, step: step, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 246, columnNumber: 33 } })), driver = _render12.driver; _context19.next = 5; return driver.clickOnInput(); case 5: _context19.next = 7; return driver.selectOptionAt(1); case 7: _context19.t0 = expect; _context19.next = 10; return driver.getInputValue(); case 10: _context19.t1 = _context19.sent; (0, _context19.t0)(_context19.t1).toBe('12:15 AM'); case 12: case "end": return _context19.stop(); } }, _callee19); }))); it('should close dropdown [when] Escape is pressed', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee23() { var _render13, driver; return _regeneratorRuntime.wrap(function _callee23$(_context23) { while (1) switch (_context23.prev = _context23.next) { case 0: _render13 = render(/*#__PURE__*/React.createElement(TimeInput, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 254, columnNumber: 33 } })), driver = _render13.driver; _context23.next = 3; return act(/*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee20() { return _regeneratorRuntime.wrap(function _callee20$(_context20) { while (1) switch (_context20.prev = _context20.next) { case 0: _context20.next = 2; return driver.clickOnInput(); case 2: case "end": return _context20.stop(); } }, _callee20); }))); case 3: _context23.next = 5; return act(/*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee21() { return _regeneratorRuntime.wrap(function _callee21$(_context21) { while (1) switch (_context21.prev = _context21.next) { case 0: _context21.next = 2; return driver.pressKey('Escape'); case 2: case "end": return _context21.stop(); } }, _callee21); }))); case 5: _context23.next = 7; return waitFor(/*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee22() { return _regeneratorRuntime.wrap(function _callee22$(_context22) { while (1) switch (_context22.prev = _context22.next) { case 0: _context22.t0 = expect; _context22.next = 3; return driver.isDropdownShown(); case 3: _context22.t1 = _context22.sent; (0, _context22.t0)(_context22.t1).toBe(false); case 5: case "end": return _context22.stop(); } }, _callee22); }))); case 7: case "end": return _context23.stop(); } }, _callee23); }))); it('should close dropdown [when] Enter is pressed and no option is highlighted', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee24() { var _render14, driver; return _regeneratorRuntime.wrap(function _callee24$(_context24) { while (1) switch (_context24.prev = _context24.next) { case 0: _render14 = render(/*#__PURE__*/React.createElement(TimeInput, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 269, columnNumber: 33 } })), driver = _render14.driver; _context24.next = 3; return driver.clickOnInput(); case 3: _context24.next = 5; return driver.setValue('13'); case 5: _context24.next = 7; return driver.pressKey('Enter'); case 7: _context24.t0 = expect; _context24.next = 10; return driver.isDropdownShown(); case 10: _context24.t1 = _context24.sent; (0, _context24.t0)(_context24.t1).toBe(false); case 12: case "end": return _context24.stop(); } }, _callee24); }))); it('should open dropdown [when] ArrowDown is pressed', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee25() { var _render15, driver; return _regeneratorRuntime.wrap(function _callee25$(_context25) { while (1) switch (_context25.prev = _context25.next) { case 0: _render15 = render(/*#__PURE__*/React.createElement(TimeInput, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 279, columnNumber: 33 } })), driver = _render15.driver; _context25.next = 3; return driver.pressKey('ArrowDown'); case 3: _context25.t0 = expect; _context25.next = 6; return driver.isDropdownShown(); case 6: _context25.t1 = _context25.sent; (0, _context25.t0)(_context25.t1).toBe(true); case 8: case "end": return _context25.stop(); } }, _callee25); }))); it('should not close dropdown and add space to input value [when] option is hovered and Spacebar is pressed', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee26() { var _render16, driver; return _regeneratorRuntime.wrap(function _callee26$(_context26) { while (1) switch (_context26.prev = _context26.next) { case 0: _render16 = render(/*#__PURE__*/React.createElement(TimeInput, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 287, columnNumber: 33 } })), driver = _render16.driver; _context26.next = 3; return driver.setValue('16'); case 3: _context26.next = 5; return driver.pressKey('Spacebar'); case 5: _context26.t0 = expect; _context26.next = 8; return driver.isDropdownShown(); case 8: _context26.t1 = _context26.sent; (0, _context26.t0)(_context26.t1).toBe(true); case 10: case "end": return _context26.stop(); } }, _callee26); }))); it('should stop selecting option [when] there is no matching value to input value', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee27() { var _render17, driver; return _regeneratorRuntime.wrap(function _callee27$(_context27) { while (1) switch (_context27.prev = _context27.next) { case 0: _render17 = render(/*#__PURE__*/React.createElement(TimeInput, { value: new Date('2021-09-10 12:30'), __self: _this, __source: { fileName: _jsxFileName, lineNumber: 298, columnNumber: 9 } })), driver = _render17.driver; _context27.next = 3; return driver.setValue(''); case 3: _context27.t0 = expect; _context27.next = 6; return driver.getSelectedOptionId(); case 6: _context27.t1 = _context27.sent; (0, _context27.t0)(_context27.t1).toBe(null); case 8: case "end": return _context27.stop(); } }, _callee27); }))); it('should open dropdown [when] value is selected with `enter` and user types again', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee28() { var _render18, driver; return _regeneratorRuntime.wrap(function _callee28$(_context28) { while (1) switch (_context28.prev = _context28.next) { case 0: _render18 = render(/*#__PURE__*/React.createElement(TimeInput, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 307, columnNumber: 33 } })), driver = _render18.driver; _context28.next = 3; return driver.setValue('2'); case 3: _context28.next = 5; return driver.pressKey('Enter'); case 5: _context28.t0 = expect; _context28.next = 8; return driver.isDropdownShown(); case 8: _context28.t1 = _context28.sent; (0, _context28.t0)(_context28.t1).toBe(false); _context28.next = 12; return driver.setValue('2'); case 12: _context28.t2 = expect; _context28.next = 15; return driver.isDropdownShown(); case 15: _context28.t3 = _context28.sent; (0, _context28.t2)(_context28.t3).toBe(true); case 17: case "end": return _context28.stop(); } }, _callee28); }))); it('preserves the selected option id when the typed value matches its display value (regression: selectedId comparison fix)', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee29() { var value, _render19, driver, initialSelectedId; return _regeneratorRuntime.wrap(function _callee29$(_context29) { while (1) switch (_context29.prev = _context29.next) { case 0: value = new Date('2021-01-01 10:30'); _render19 = render(/*#__PURE__*/React.createElement(TimeInput, { value: value, locale: "en", __self: _this, __source: { fileName: _jsxFileName, lineNumber: 319, columnNumber: 33 } })), driver = _render19.driver; // syncExternalValue picks 10:30 AM as the selected slot. Re-typing // the exact display value should not clear the selection — previously // the comparison `inputValue !== timeSlots[state.selectedId]` always // nuked selectedId because the timestamp was used as an array index. _context29.next = 4; return driver.clickOnInput(); case 4: _context29.next = 6; return driver.getSelectedOptionId(); case 6: initialSelectedId = _context29.sent; expect(initialSelectedId).toBeTruthy(); _context29.next = 10; return driver.setValue('10:30 AM'); case 10: _context29.t0 = expect; _context29.next = 13; return driver.getSelectedOptionId(); case 13: _context29.t1 = _context29.sent; (0, _context29.t0)(_context29.t1).toBe(initialSelectedId); case 15: case "end": return _context29.stop(); } }, _callee29); }))); it('should fill input with highlighted value [when] input loses focus', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee30() { var _render20, driver; return _regeneratorRuntime.wrap(function _callee30$(_context30) { while (1) switch (_context30.prev = _context30.next) { case 0: _render20 = render(/*#__PURE__*/React.createElement(TimeInput, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 335, columnNumber: 33 } })), driver = _render20.driver; _context30.next = 3; return driver.setValue('2:00 P'); case 3: _context30.next = 5; return driver.confirmValue(); case 5: _context30.t0 = expect; _context30.next = 8; return driver.getInputValue(); case 8: _context30.t1 = _context30.sent; (0, _context30.t0)(_context30.t1).toBe('2:00 PM'); case 10: case "end": return _context30.stop(); } }, _callee30); }))); it('should close dropdown [when] input loses focus', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee32() { var _render21, driver; return _regeneratorRuntime.wrap(function _callee32$(_context32) { while (1) switch (_context32.prev = _context32.next) { case 0: _render21 = render(/*#__PURE__*/React.createElement(TimeInput, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 344, columnNumber: 33 } })), driver = _render21.driver; _context32.next = 3; return driver.clickOnInput(); case 3: _context32.t0 = expect; _context32.next = 6; return driver.isDropdownShown(); case 6: _context32.t1 = _context32.sent; (0, _context32.t0)(_context32.t1).toBe(true); _context32.next = 10; return driver.confirmValue(); case 10: _context32.next = 12; return waitFor(/*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee31() { return _regeneratorRuntime.wrap(function _callee31$(_context31) { while (1) switch (_context31.prev = _context31.next) { case 0: _context31.t0 = expect; _context31.next = 3; return driver.isDropdownShown(); case 3: _context31.t1 = _context31.sent; (0, _context31.t0)(_context31.t1).toBe(false); case 5: case "end": return _context31.stop(); } }, _callee31); }))); case 12: case "end": return _context32.stop(); } }, _callee32); }))); it('should scroll to nearest input value [when] dropdown is opened and there is no selected or autocompleted value', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee33() { var _render22, driver, expectedScrollToOption; return _regeneratorRuntime.wrap(function _callee33$(_context33) { while (1) switch (_context33.prev = _context33.next) { case 0: _render22 = render(/*#__PURE__*/React.createElement(TimeInput, { step: 15, value: new Date('2021-11-16 11:33'), __self: _this, __source: { fileName: _jsxFileName, lineNumber: 357, columnNumber: 9 } })), driver = _render22.driver; expectedScrollToOption = new Date('2021-11-16 11:45').getTime(); _context33.t0 = expect; _context33.next = 5; return driver.getScrollToOptionValue(); case 5: _context33.t1 = _context33.sent; (0, _context33.t0)(_context33.t1).toBe(null); _context33.next = 9; return driver.clickOnInput(); case 9: _context33.t2 = expect; _context33.next = 12; return driver.getScrollToOptionValue(); case 12: _context33.t3 = _context33.sent; (0, _context33.t2)(_context33.t3).toContain("".concat(expectedScrollToOption)); case 14: case "end": return _context33.stop(); } }, _callee33); }))); it('should scroll to nearest input value [when] custom value is set and dropdown is opened', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee34() { var _render23, driver, expectedScrollToOption; return _regeneratorRuntime.wrap(function _callee34$(_context34) { while (1) switch (_context34.prev = _context34.next) { case 0: Date.now = vi.fn(function () { return new Date('2021-01-01 05:00').valueOf(); }); _render23 = render(/*#__PURE__*/React.createElement(TimeInput, { step: 15, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 371, columnNumber: 33 } })), driver = _render23.driver; expectedScrollToOption = new Date('2021-01-01 12:00').getTime(); _context34.next = 5; return driver.setValue('11:48'); case 5: _context34.next = 7; return driver.confirmValue(); case 7: _context34.next = 9; return driver.clickOnInput(); case 9: _context34.t0 = expect; _context34.next = 12; return driver.getScrollToOptionValue(); case 12: _context34.t1 = _context34.sent; (0, _context34.t0)(_context34.t1).toContain("".concat(expectedScrollToOption)); case 14: case "end": return _context34.stop(); } }, _callee34); }))); it('should set to 11:50 AM custom input value [when] 11:5 is typed and `Enter` is pressed', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee35() { var _render24, driver; return _regeneratorRuntime.wrap(function _callee35$(_context35) { while (1) switch (_context35.prev = _context35.next) { case 0: _render24 = render(/*#__PURE__*/React.createElement(TimeInput, { step: 15, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 384, columnNumber: 33 } })), driver = _render24.driver; _context35.next = 3; return driver.setValue('11:5'); case 3: _context35.next = 5; return driver.pressKey('Enter'); case 5: _context35.t0 = expect; _context35.next = 8; return driver.getInputValue(); case 8: _context35.t1 = _context35.sent; (0, _context35.t0)(_context35.t1).toBe('11:50 AM'); case 10: case "end": return _context35.stop(); } }, _callee35); }))); it('should not submit value on blur [when] input is not valid', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee36() { var onChange, _render25, driver; return _regeneratorRuntime.wrap(function _callee36$(_context36) { while (1) switch (_context36.prev = _context36.next) { case 0: onChange = vi.fn(); _render25 = render(/*#__PURE__*/React.createElement(TimeInput, { onChange: onChange, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 394, columnNumber: 33 } })), driver = _render25.driver; _context36.next = 4; return driver.setValue('123123123'); case 4: _context36.next = 6; return driver.confirmValue(); case 6: _context36.t0 = expect; _context36.next = 9; return driver.getInputValue(); case 9: _context36.t1 = _context36.sent; (0, _context36.t0)(_context36.t1).toBe('123123123'); expect(onChange).not.toHaveBeenCalled(); case 12: case "end": return _context36.stop(); } }, _callee36); }))); }); describe('aria', function () { it('should have collapsed dropdown aria attributes [when] dropdown is closed', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee37() { var _render26, driver; return _regeneratorRuntime.wrap(function _callee37$(_context37) { while (1) switch (_context37.prev = _context37.next) { case 0: _render26 = render(/*#__PURE__*/React.createElement(TimeInput, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 406, columnNumber: 33 } })), driver = _render26.driver; _context37.t0 = expect; _context37.next = 4; return driver.getInputAttribute('aria-expanded'); case 4: _context37.t1 = _context37.sent; (0, _context37.t0)(_context37.t1).toBe('false'); _context37.t2 = expect; _context37.next = 9; return driver.getInputAttribute('aria-autocomplete'); case 9: _context37.t3 = _context37.sent; (0, _context37.t2)(_context37.t3).toBe('list'); _context37.t4 = expect; _context37.next = 14; return driver.getInputAttribute('aria-controls'); case 14: _context37.t5 = _context37.sent; (0, _context37.t4)(_context37.t5).toBeNull(); _context37.t6 = expect; _context37.next = 19; return driver.getInputAttribute('aria-activedescendant'); case 19: _context37.t7 = _context37.sent; (0, _context37.t6)(_context37.t7).toBeNull(); case 21: case "end": return _context37.stop(); } }, _callee37); }))); it('should have dropdown aria attributes [when] dropdown is open', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee38() { var _render27, driver; return _regeneratorRuntime.wrap(function _callee38$(_context38) { while (1) switch (_context38.prev = _context38.next) { case 0: _render27 = render(/*#__PURE__*/React.createElement(TimeInput, { value: new Date('2020-01-01 00:00'), __self: _this, __source: { fileName: _jsxFileName, lineNumber: 417, columnNumber: 9 } })), driver = _render27.driver; _context38.next = 3; return driver.clickOnInput(); case 3: _context38.t0 = expect; _context38.next = 6; return driver.getInputAttribute('aria-autocomplete'); case 6: _context38.t1 = _context38.sent; (0, _context38.t0)(_context38.t1).toBe('list'); _context38.t2 = expect; _context38.next = 11; return driver.getInputAttribute('aria-expanded'); case 11: _context38.t3 = _context38.sent; (0, _context38.t2)(_context38.t3).toBe('true'); _context38.t4 = expect; _context38.next = 16; return driver.getInputAttribute('aria-controls'); case 16: _context38.t5 = _context38.sent; (0, _context38.t4)(_context38.t5).toBeDefined(); _context38.t6 = expect; _context38.next = 21; return driver.getInputAttribute('aria-activedescendant'); case 21: _context38.t7 = _context38.sent; (0, _context38.t6)(_context38.t7).toBe('dropdown-item-0'); case 23: case "end": return _context38.stop(); } }, _callee38); }))); }); describe('ref', function () { it('should access focus method through ref [when] ref is passed to component', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee40() { var timeInputRef, _render28, driver; return _regeneratorRuntime.wrap(function _callee40$(_context40) { while (1) switch (_context40.prev = _context40.next) { case 0: timeInputRef = /*#__PURE__*/React.createRef(); _render28 = render(/*#__PURE__*/React.createElement(TimeInput, { ref: timeInputRef, __self: _this, __source: { fileName: _jsx