UNPKG

@wix/design-system

Version:

@wix/design-system

1,089 lines (1,088 loc) 88.3 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator")); var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator")); var _react = _interopRequireDefault(require("react")); var _ = _interopRequireDefault(require("..")); var _react2 = require("../../utils/test-utils/react"); var _CalendarUni = require("../Calendar.uni.driver"); var _LocaleUtils = require("../../common/LocaleUtils/LocaleUtils"); var _WixStyleReactEnvironmentProvider = _interopRequireDefault(require("../../WixStyleReactEnvironmentProvider")); var _jsxFileName = "/home/builduser/work/57e038ea7326c1ec/packages/wix-design-system/dist/cjs/Calendar/test/Calendar.spec.jsx"; function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t["return"] || t["return"](); } finally { if (u) throw o; } } }; } function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } var isFirstLetterCapitalized = function isFirstLetterCapitalized(str) { return str && str.length && str[0] === str[0].toLocaleUpperCase(); }; describe('Calendar', function () { describe('[async]', function () { runTests((0, _react2.createRendererWithUniDriver)(_CalendarUni.calendarUniDriverFactory)); }); function runTests(render) { var _this = this; afterEach(function () { return (0, _react2.cleanup)(); }); var AUGUST = 7, SEPTEMBER = 8, OCTOBER = 9, NOVEMBER = 10; var monthNames = 'January February March April May June July August September October November December'.split(' '); describe('rendering the Calendar', function () { it('should display years from current date to 15 years into the future and past in the year drop-down', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee() { var _render, driver, yearDriver, options, actualYears, currentYear, expectedYears, year; return _regenerator["default"].wrap(function _callee$(_context) { while (1) switch (_context.prev = _context.next) { case 0: _render = render(/*#__PURE__*/_react["default"].createElement(_["default"], { showYearDropdown: true, onChange: function onChange() {}, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 35, columnNumber: 11 } })), driver = _render.driver; _context.next = 3; return driver.getYearDropdownDriver(); case 3: yearDriver = _context.sent; _context.next = 6; return yearDriver.options(); case 6: options = _context.sent; _context.next = 9; return Promise.all(options.map(function (_ref2) { var content = _ref2.content; return content(); })); case 9: actualYears = _context.sent; currentYear = new Date().getFullYear(); expectedYears = []; for (year = currentYear + 15; year > currentYear - 30; year--) { expectedYears.push(year.toString()); } // Adding loader content expectedYears.push(''); expect(actualYears).toEqual(expectedYears); case 15: case "end": return _context.stop(); } }, _callee); }))); it('should display the month of the {from} Date if the provided value is {from, to}', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee2() { var _render2, driver; return _regenerator["default"].wrap(function _callee2$(_context2) { while (1) switch (_context2.prev = _context2.next) { case 0: _render2 = render(/*#__PURE__*/_react["default"].createElement(_["default"], { value: { from: new Date(2018, OCTOBER, 5), to: new Date(2018, NOVEMBER, 7) }, onChange: function onChange() {}, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 58, columnNumber: 11 } })), driver = _render2.driver; _context2.t0 = expect; _context2.next = 4; return driver.getMonthCaption(); case 4: _context2.t1 = _context2.sent; (0, _context2.t0)(_context2.t1).toEqual(monthNames[OCTOBER]); case 6: case "end": return _context2.stop(); } }, _callee2); }))); it('should display the month of the {from} Date if the provided value is {from}', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee3() { var _render3, driver; return _regenerator["default"].wrap(function _callee3$(_context3) { while (1) switch (_context3.prev = _context3.next) { case 0: _render3 = render(/*#__PURE__*/_react["default"].createElement(_["default"], { value: { from: new Date(2018, OCTOBER, 5) }, onChange: function onChange() {}, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 72, columnNumber: 11 } })), driver = _render3.driver; _context3.t0 = expect; _context3.next = 4; return driver.getMonthCaption(); case 4: _context3.t1 = _context3.sent; (0, _context3.t0)(_context3.t1).toEqual(monthNames[OCTOBER]); case 6: case "end": return _context3.stop(); } }, _callee3); }))); it('should capitalize first letter of month in certain languages', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee4() { var _iterator, _step, locale, _render4, driver, monthCaption; return _regenerator["default"].wrap(function _callee4$(_context4) { while (1) switch (_context4.prev = _context4.next) { case 0: _iterator = _createForOfIteratorHelper(_LocaleUtils.CAPITALIZED_MONTH_LANGUAGES); _context4.prev = 1; _iterator.s(); case 3: if ((_step = _iterator.n()).done) { _context4.next = 12; break; } locale = _step.value; _render4 = render(/*#__PURE__*/_react["default"].createElement(_["default"], { value: { from: new Date(2018, OCTOBER, 5) }, onChange: function onChange() {}, locale: locale, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 84, columnNumber: 13 } })), driver = _render4.driver; _context4.next = 8; return driver.getMonthCaption(); case 8: monthCaption = _context4.sent; expect(isFirstLetterCapitalized(monthCaption)).toBe(true); case 10: _context4.next = 3; break; case 12: _context4.next = 17; break; case 14: _context4.prev = 14; _context4.t0 = _context4["catch"](1); _iterator.e(_context4.t0); case 17: _context4.prev = 17; _iterator.f(); return _context4.finish(17); case 20: case "end": return _context4.stop(); } }, _callee4, null, [[1, 14, 17, 20]]); }))); it('should display the month of the {to} Date if the provided value is {to}', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee5() { var _render5, driver; return _regenerator["default"].wrap(function _callee5$(_context5) { while (1) switch (_context5.prev = _context5.next) { case 0: _render5 = render(/*#__PURE__*/_react["default"].createElement(_["default"], { value: { to: new Date(2018, NOVEMBER, 7) }, onChange: function onChange() {}, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 98, columnNumber: 11 } })), driver = _render5.driver; _context5.t0 = expect; _context5.next = 4; return driver.getMonthCaption(); case 4: _context5.t1 = _context5.sent; (0, _context5.t0)(_context5.t1).toEqual(monthNames[NOVEMBER]); case 6: case "end": return _context5.stop(); } }, _callee5); }))); it('should display the month of the Date if the provided value is a single Date', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee6() { var _render6, driver; return _regenerator["default"].wrap(function _callee6$(_context6) { while (1) switch (_context6.prev = _context6.next) { case 0: _render6 = render(/*#__PURE__*/_react["default"].createElement(_["default"], { value: new Date(2018, NOVEMBER, 7), onChange: function onChange() {}, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 109, columnNumber: 11 } })), driver = _render6.driver; _context6.t0 = expect; _context6.next = 4; return driver.getMonthCaption(); case 4: _context6.t1 = _context6.sent; (0, _context6.t0)(_context6.t1).toEqual(monthNames[NOVEMBER]); case 6: case "end": return _context6.stop(); } }, _callee6); }))); it('should display the current month if the provided value is undefined', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee7() { var _render7, driver; return _regenerator["default"].wrap(function _callee7$(_context7) { while (1) switch (_context7.prev = _context7.next) { case 0: _render7 = render(/*#__PURE__*/_react["default"].createElement(_["default"], { onChange: function onChange() {}, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 116, columnNumber: 35 } })), driver = _render7.driver; _context7.t0 = expect; _context7.next = 4; return driver.getMonthCaption(); case 4: _context7.t1 = _context7.sent; (0, _context7.t0)(_context7.t1).toEqual(monthNames[new Date().getMonth()]); case 6: case "end": return _context7.stop(); } }, _callee7); }))); it('should display the current month if the provided value is an empty object', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee8() { var _render8, driver; return _regenerator["default"].wrap(function _callee8$(_context8) { while (1) switch (_context8.prev = _context8.next) { case 0: _render8 = render(/*#__PURE__*/_react["default"].createElement(_["default"], { value: {}, onChange: function onChange() {}, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 124, columnNumber: 35 } })), driver = _render8.driver; _context8.t0 = expect; _context8.next = 4; return driver.getMonthCaption(); case 4: _context8.t1 = _context8.sent; (0, _context8.t0)(_context8.t1).toEqual(monthNames[new Date().getMonth()]); case 6: case "end": return _context8.stop(); } }, _callee8); }))); it('should have 5 selected dates', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee9() { var _render9, driver; return _regenerator["default"].wrap(function _callee9$(_context9) { while (1) switch (_context9.prev = _context9.next) { case 0: _render9 = render(/*#__PURE__*/_react["default"].createElement(_["default"], { value: { from: new Date(2018, 10, 5), to: new Date(2018, 10, 9) }, onChange: function onChange() {}, selectionMode: "range", __self: _this, __source: { fileName: _jsxFileName, lineNumber: 132, columnNumber: 11 } })), driver = _render9.driver; _context9.t0 = expect; _context9.next = 4; return driver.getNumOfSelectedDays(); case 4: _context9.t1 = _context9.sent; (0, _context9.t0)(_context9.t1).toBe(5); case 6: case "end": return _context9.stop(); } }, _callee9); }))); }); describe('`filterDate` prop', function () { it('should not affect calendar if date is modified', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee0() { var date, _render0, driver; return _regenerator["default"].wrap(function _callee0$(_context0) { while (1) switch (_context0.prev = _context0.next) { case 0: date = new Date(2017, 9, 2); _render0 = render(/*#__PURE__*/_react["default"].createElement(_["default"], { onChange: function onChange() {}, filterDate: function filterDate(_date) { _date.setUTCDate(3); return false; }, value: date, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 150, columnNumber: 11 } })), driver = _render0.driver; _context0.t0 = expect; _context0.next = 5; return driver.getSelectedDay(); case 5: _context0.t1 = _context0.sent; (0, _context0.t0)(_context0.t1).toBe('2'); case 7: case "end": return _context0.stop(); } }, _callee0); }))); }); describe('onClose', function () { it('should be call with default not prevented when closing with ESC key', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee1() { var onCloseMock, value, _render1, driver; return _regenerator["default"].wrap(function _callee1$(_context1) { while (1) switch (_context1.prev = _context1.next) { case 0: onCloseMock = vi.fn(); value = new Date(2018, 10, 5); _render1 = render(/*#__PURE__*/_react["default"].createElement(_["default"], { value: value, onChange: function onChange() {}, onClose: onCloseMock, shouldCloseOnSelect: false, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 169, columnNumber: 11 } })), driver = _render1.driver; _context1.next = 5; return driver.clickDay(new Date(2018, 10, 1)); case 5: _context1.next = 7; return driver.triggerKeyDown({ key: 'Escape', keyCode: 27 }); case 7: expect(onCloseMock).toHaveBeenCalledTimes(1); expect(onCloseMock.mock.calls[0][0].type).toEqual('keydown'); expect(onCloseMock.mock.calls[0][0].defaultPrevented).toBeFalsy(); case 10: case "end": return _context1.stop(); } }, _callee1); }))); }); describe('Prevent Default', function () { it('should prevent default when clicking in header parts', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee10() { var eventListenerMock, dataHook, _render10, driver; return _regenerator["default"].wrap(function _callee10$(_context10) { while (1) switch (_context10.prev = _context10.next) { case 0: eventListenerMock = vi.fn(function (event) { return event.persist(); }); dataHook = 'calendar-data-hook'; // We use a label wrapper, since a label's default is to delegate the click on to it's target. Just to demonstrate that this is a use-case that needs to be prevented. _render10 = render(/*#__PURE__*/_react["default"].createElement("label", { onClick: eventListenerMock, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 195, columnNumber: 11 } }, /*#__PURE__*/_react["default"].createElement(_["default"], { dataHook: dataHook, onChange: function onChange() {}, showYearDropdown: true, showMonthDropdown: true, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 196, columnNumber: 13 } })), { dataHook: dataHook }), driver = _render10.driver; _context10.next = 5; return driver.clickOnPrevMonthButton(); case 5: _context10.next = 7; return driver.clickOnNextMonthButton(); case 7: _context10.next = 9; return driver.clickOnYearDropdown(); case 9: _context10.next = 11; return driver.clickOnMonthDropdown(); case 11: expect(eventListenerMock).toHaveBeenCalledTimes(4); expect(eventListenerMock.mock.calls[0][0].defaultPrevented).toEqual(true); expect(eventListenerMock.mock.calls[1][0].defaultPrevented).toEqual(true); expect(eventListenerMock.mock.calls[2][0].defaultPrevented).toEqual(true); expect(eventListenerMock.mock.calls[3][0].defaultPrevented).toEqual(true); case 16: case "end": return _context10.stop(); } }, _callee10); }))); }); it('should call onMonthChange with the current month first day when changing the displayed month', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee11() { var currentMonth, date, expectedMonth, onMonthChange, _render11, driver, onMonthChangeValue; return _regenerator["default"].wrap(function _callee11$(_context11) { while (1) switch (_context11.prev = _context11.next) { case 0: currentMonth = 2; date = new Date(2021, currentMonth, 1); expectedMonth = new Date(2021, currentMonth + 1, 1); onMonthChange = vi.fn(); _render11 = render(/*#__PURE__*/_react["default"].createElement(_["default"], { value: date, onMonthChange: onMonthChange, onChange: function onChange() {}, selectionMode: "day", __self: _this, __source: { fileName: _jsxFileName, lineNumber: 233, columnNumber: 9 } })), driver = _render11.driver; expect(onMonthChange).toHaveBeenCalledTimes(0); _context11.next = 8; return driver.clickOnNextMonthButton(); case 8: expect(onMonthChange).toHaveBeenCalledTimes(1); onMonthChangeValue = onMonthChange.mock.calls[0][0]; expect(onMonthChangeValue.toLocaleDateString()).toEqual(expectedMonth.toLocaleDateString()); case 11: case "end": return _context11.stop(); } }, _callee11); }))); it('should call onMonthChange with the current month first day when navigating with keyboard (next year)', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee12() { var currentYear, date, expectedMonth, onMonthChange, _render12, driver, onMonthChangeValue; return _regenerator["default"].wrap(function _callee12$(_context12) { while (1) switch (_context12.prev = _context12.next) { case 0: currentYear = 2021; date = new Date(currentYear, 1, 1); expectedMonth = new Date(currentYear + 1, 1, 1); onMonthChange = vi.fn(); _render12 = render(/*#__PURE__*/_react["default"].createElement(_["default"], { value: date, onMonthChange: onMonthChange, onChange: function onChange() {}, selectionMode: "day", __self: _this, __source: { fileName: _jsxFileName, lineNumber: 257, columnNumber: 9 } })), driver = _render12.driver; expect(onMonthChange).toHaveBeenCalledTimes(0); _context12.next = 8; return driver.keyboardNextYear(); case 8: expect(onMonthChange).toHaveBeenCalledTimes(1); onMonthChangeValue = onMonthChange.mock.calls[0][0]; expect(onMonthChangeValue.toLocaleDateString()).toEqual(expectedMonth.toLocaleDateString()); case 11: case "end": return _context12.stop(); } }, _callee12); }))); it('should call onMonthChange with the current month first day when navigating with keyboard (previous year)', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee13() { var currentYear, date, expectedMonth, onMonthChange, _render13, driver, onMonthChangeValue; return _regenerator["default"].wrap(function _callee13$(_context13) { while (1) switch (_context13.prev = _context13.next) { case 0: currentYear = 2021; date = new Date(currentYear, 1, 1); expectedMonth = new Date(currentYear - 1, 1, 1); onMonthChange = vi.fn(); _render13 = render(/*#__PURE__*/_react["default"].createElement(_["default"], { value: date, onMonthChange: onMonthChange, onChange: function onChange() {}, selectionMode: "day", __self: _this, __source: { fileName: _jsxFileName, lineNumber: 281, columnNumber: 9 } })), driver = _render13.driver; expect(onMonthChange).toHaveBeenCalledTimes(0); _context13.next = 8; return driver.keyboardPrevYear(); case 8: expect(onMonthChange).toHaveBeenCalledTimes(1); onMonthChangeValue = onMonthChange.mock.calls[0][0]; expect(onMonthChangeValue.toLocaleDateString()).toEqual(expectedMonth.toLocaleDateString()); case 11: case "end": return _context13.stop(); } }, _callee13); }))); describe('clicking on a day', function () { var onChange; beforeEach(function () { onChange = vi.fn(); }); describe("with selectionMode='day'", function () { it('should call onChange with the clicked day', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee14() { var date, _render14, driver; return _regenerator["default"].wrap(function _callee14$(_context14) { while (1) switch (_context14.prev = _context14.next) { case 0: date = new Date(2018, 10, 5); _render14 = render(/*#__PURE__*/_react["default"].createElement(_["default"], { value: date, onChange: onChange, selectionMode: "day", __self: _this, __source: { fileName: _jsxFileName, lineNumber: 310, columnNumber: 13 } })), driver = _render14.driver; expect(onChange).toHaveBeenCalledTimes(0); _context14.next = 5; return driver.clickDay(new Date(2018, 10, 1)); case 5: expect(onChange).toHaveBeenCalledTimes(1); expect(onChange.mock.calls[0][0].getDate()).toEqual(1); case 7: case "end": return _context14.stop(); } }, _callee14); }))); it('should prevent event default', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee15() { var dataHook, date, eventListenerMock, _render15, driver; return _regenerator["default"].wrap(function _callee15$(_context15) { while (1) switch (_context15.prev = _context15.next) { case 0: dataHook = 'calendar-data-hook'; date = new Date(2018, 10, 5); eventListenerMock = vi.fn(); _render15 = render(/*#__PURE__*/_react["default"].createElement("div", { onClick: eventListenerMock, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 326, columnNumber: 13 } }, /*#__PURE__*/_react["default"].createElement(_["default"], { value: date, onChange: onChange, selectionMode: "day", dataHook: dataHook, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 327, columnNumber: 15 } })), { dataHook: dataHook }), driver = _render15.driver; _context15.next = 6; return driver.clickDay(new Date(2018, 10, 1)); case 6: expect(eventListenerMock).toHaveBeenCalledTimes(1); expect(eventListenerMock.mock.calls[0][0].defaultPrevented).toEqual(true); case 8: case "end": return _context15.stop(); } }, _callee15); }))); it('should call `onClose` callback with event', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee16() { var date, onCloseMock, _render16, driver; return _regenerator["default"].wrap(function _callee16$(_context16) { while (1) switch (_context16.prev = _context16.next) { case 0: date = new Date(2018, 10, 5); onCloseMock = vi.fn(); _render16 = render(/*#__PURE__*/_react["default"].createElement(_["default"], { value: date, onChange: onChange, selectionMode: "day", onClose: onCloseMock, shouldCloseOnSelect: true, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 349, columnNumber: 13 } })), driver = _render16.driver; _context16.next = 5; return driver.clickDay(new Date(2018, 10, 1)); case 5: expect(onCloseMock).toHaveBeenCalledTimes(1); expect(onCloseMock.mock.calls[0][0].type).toEqual('click'); case 7: case "end": return _context16.stop(); } }, _callee16); }))); }); describe("with selectionMode='range'", function () { it('should call onChange({from: $clickedDay}) when value is undefined', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee17() { var _render17, driver; return _regenerator["default"].wrap(function _callee17$(_context17) { while (1) switch (_context17.prev = _context17.next) { case 0: _render17 = render(/*#__PURE__*/_react["default"].createElement(_["default"], { onChange: onChange, selectionMode: "range", __self: _this, __source: { fileName: _jsxFileName, lineNumber: 368, columnNumber: 13 } })), driver = _render17.driver; _context17.next = 3; return driver.clickOnNthDay(0); case 3: expect(onChange).toHaveBeenCalledTimes(1); expect(onChange.mock.calls[0][0].from.getDate()).toEqual(1); case 5: case "end": return _context17.stop(); } }, _callee17); }))); it('should call onChange({from: $clickedDay}) when value is a Range', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee18() { var _render18, driver; return _regenerator["default"].wrap(function _callee18$(_context18) { while (1) switch (_context18.prev = _context18.next) { case 0: _render18 = render(/*#__PURE__*/_react["default"].createElement(_["default"], { value: { from: new Date(2018, 10, 5), to: new Date(2018, 10, 10) }, onChange: onChange, selectionMode: "range", __self: _this, __source: { fileName: _jsxFileName, lineNumber: 378, columnNumber: 13 } })), driver = _render18.driver; _context18.next = 3; return driver.clickOnNthDay(0); case 3: expect(onChange).toHaveBeenCalledTimes(1); expect(onChange.mock.calls[0][0].from.getDate()).toEqual(1); case 5: case "end": return _context18.stop(); } }, _callee18); }))); it('should call onChange({from: $clickedDay}) when value is a single Date', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee19() { var _render19, driver; return _regenerator["default"].wrap(function _callee19$(_context19) { while (1) switch (_context19.prev = _context19.next) { case 0: _render19 = render(/*#__PURE__*/_react["default"].createElement(_["default"], { value: new Date(2018, 10, 5), onChange: onChange, selectionMode: "range", __self: _this, __source: { fileName: _jsxFileName, lineNumber: 395, columnNumber: 13 } })), driver = _render19.driver; _context19.next = 3; return driver.clickOnNthDay(0); case 3: expect(onChange).toHaveBeenCalledTimes(1); expect(onChange.mock.calls[0][0].from.getDate()).toEqual(1); case 5: case "end": return _context19.stop(); } }, _callee19); }))); it("should call onChange({from: $from, to: $clickedDay}) when value has only 'from'", /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee20() { var _render20, driver; return _regenerator["default"].wrap(function _callee20$(_context20) { while (1) switch (_context20.prev = _context20.next) { case 0: _render20 = render(/*#__PURE__*/_react["default"].createElement(_["default"], { value: { from: new Date(2018, 10, 1) }, onChange: onChange, selectionMode: "range", __self: _this, __source: { fileName: _jsxFileName, lineNumber: 409, columnNumber: 13 } })), driver = _render20.driver; _context20.next = 3; return driver.clickOnNthDay(2); case 3: expect(onChange).toHaveBeenCalledTimes(1); expect(onChange.mock.calls[0][0].from.getDate()).toEqual(1); expect(onChange.mock.calls[0][0].to.getDate()).toEqual(3); case 6: case "end": return _context20.stop(); } }, _callee20); }))); it("should call onChange({from: $clickedDay, to: $to}) when a day is clicked, given only 'to'", /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee21() { var _render21, driver; return _regenerator["default"].wrap(function _callee21$(_context21) { while (1) switch (_context21.prev = _context21.next) { case 0: _render21 = render(/*#__PURE__*/_react["default"].createElement(_["default"], { value: { to: new Date(2018, 10, 3) }, onChange: onChange, selectionMode: "range", __self: _this, __source: { fileName: _jsxFileName, lineNumber: 424, columnNumber: 13 } })), driver = _render21.driver; _context21.next = 3; return driver.clickOnNthDay(0); case 3: expect(onChange).toHaveBeenCalledTimes(1); expect(onChange.mock.calls[0][0].from.getDate()).toEqual(1); expect(onChange.mock.calls[0][0].to.getDate()).toEqual(3); case 6: case "end": return _context21.stop(); } }, _callee21); }))); it("should call onChange({from: $clickedDay, to: $from}) if the clicked day is earlier than the provided 'from'", /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee22() { var _render22, driver; return _regenerator["default"].wrap(function _callee22$(_context22) { while (1) switch (_context22.prev = _context22.next) { case 0: _render22 = render(/*#__PURE__*/_react["default"].createElement(_["default"], { value: { from: new Date(2018, 10, 10) }, onChange: onChange, selectionMode: "range", __self: _this, __source: { fileName: _jsxFileName, lineNumber: 438, columnNumber: 13 } })), driver = _render22.driver; _context22.next = 3; return driver.clickOnNthDay(0); case 3: expect(onChange).toHaveBeenCalledTimes(1); expect(onChange.mock.calls[0][0].from.getDate()).toEqual(1); expect(onChange.mock.calls[0][0].to.getDate()).toEqual(10); case 6: case "end": return _context22.stop(); } }, _callee22); }))); it("should call onChange({from: $clickedDay, to: $from}) when a day is clicked, given only 'from'", /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee23() { var _render23, driver; return _regenerator["default"].wrap(function _callee23$(_context23) { while (1) switch (_context23.prev = _context23.next) { case 0: _render23 = render(/*#__PURE__*/_react["default"].createElement(_["default"], { value: { from: new Date(2018, 10, 10) }, onChange: onChange, selectionMode: "range", __self: _this, __source: { fileName: _jsxFileName, lineNumber: 453, columnNumber: 13 } })), driver = _render23.driver; _context23.next = 3; return driver.clickOnNthDay(2); case 3: expect(onChange).toHaveBeenCalledTimes(1); expect(onChange.mock.calls[0][0].from.getDate()).toEqual(3); expect(onChange.mock.calls[0][0].to.getDate()).toEqual(10); case 6: case "end": return _context23.stop(); } }, _callee23); }))); it('should prevent event default', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee24() { var dataHook, eventListenerMock, _render24, driver; return _regenerator["default"].wrap(function _callee24$(_context24) { while (1) switch (_context24.prev = _context24.next) { case 0: dataHook = 'calendar-data-hook'; eventListenerMock = vi.fn(); _render24 = render(/*#__PURE__*/_react["default"].createElement("div", { onClick: eventListenerMock, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 470, columnNumber: 13 } }, /*#__PURE__*/_react["default"].createElement(_["default"], { value: { from: new Date(2018, 10, 10) }, onChange: onChange, selectionMode: "range", dataHook: dataHook, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 471, columnNumber: 15 } })), { dataHook: dataHook }), driver = _render24.driver; _context24.next = 5; return driver.clickOnNthDay(2); case 5: expect(eventListenerMock).toHaveBeenCalledTimes(1); expect(eventListenerMock.mock.calls[0][0].defaultPrevented).toEqual(true); case 7: case "end": return _context24.stop(); } }, _callee24); }))); it('should call `onClose` callback with event', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee25() { var onCloseMock, _render25, driver; return _regenerator["default"].wrap(function _callee25$(_context25) { while (1) switch (_context25.prev = _context25.next) { case 0: onCloseMock = vi.fn(); _render25 = render(/*#__PURE__*/_react["default"].createElement(_["default"], { value: { from: new Date(2018, 10, 10) }, onChange: onChange, selectionMode: "range", onClose: onCloseMock, shouldCloseOnSelect: true, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 491, columnNumber: 13 } })), driver = _render25.driver; _context25.next = 4; return driver.clickOnNthDay(2); case 4: expect(onCloseMock).toHaveBeenCalledTimes(1); expect(onCloseMock.mock.calls[0][0].type).toEqual('click'); case 6: case "end": return _context25.stop(); } }, _callee25); }))); }); }); describe('excludePastDates', function () { var defaultProps = { onChange: function onChange() {} }; it('past dates should not be active', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee26() { var _render26, driver; return _regenerator["default"].wrap(function _callee26$(_context26) { while (1) switch (_context26.prev = _context26.next) { case 0: _render26 = render(/*#__PURE__*/_react["default"].createElement(_["default"], (0, _extends2["default"])({}, defaultProps, { value: new Date(2020, 0, 17), excludePastDates: true, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 514, columnNumber: 11 } }))), driver = _render26.driver; _context26.t0 = expect; _context26.next = 4; return driver.isDayActive(new Date(2020, 0, 7)); case 4: _context26.t1 = _context26.sent; (0, _context26.t0)(_context26.t1).toBe(false); case 6: case "end": return _context26.stop(); } }, _callee26); }))); it('other days should be active', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee27() { var _render27, driver; return _regenerator["default"].wrap(function _callee27$(_context27) { while (1) switch (_context27.prev = _context27.next) { case 0: _render27 = render(/*#__PURE__*/_react["default"].createElement(_["default"], (0, _extends2["default"])({}, defaultProps, { value: new Date(), excludePastDates: true, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 525, columnNumber: 11 } }))), driver = _render27.driver; _context27.t0 = expect; _context27.next = 4; return driver.isDayActive(new Date()); case 4: _context27.t1 = _context27.sent; (0, _context27.t0)(_context27.t1).toBe(true); case 6: case "end": return _context27.stop(); } }, _callee27); }))); it('when combined with filterDate prop disable more than one range of date', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee28() { var today, yesterday, tomorrow, _render28, driver; return _regenerator["default"].wrap(function _callee28$(_context28) { while (1) switch (_context28.prev = _context28.next) { case 0: today = new Date(2021, 2, 17); yesterday = new Date(2021, 2, 16); tomorrow = new Date(2021, 2, 18); _render28 = render(/*#__PURE__*/_react["default"].createElement(_["default"], (0, _extends2["default"])({}, defaultProps, { value: today, filterDate: function filterDate(date) { return date < new Date(); }, excludePastDates: true, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 536, columnNumber: 11 } }))), driver = _render28.driver; _context28.t0 = expect; _context28.next = 7; return driver.isDayActive(yesterday); case 7: _context28.t1 = _context28.sent; (0, _context28.t0)(_context28.t1).toBe(false); _context28.t2 = expect; _context28.next = 12; return driver.isDayActive(tomorrow); case 12: _context28.t3 = _context28.sent; (0, _context28.t2)(_context28.t3).toBe(false); case 14: case "end": return _context28.stop(); } }, _callee28); }))); }); describe('Auto Focus', function () { var defaultProps = { onChange: function onChange() {} }; it('should autoFocus on selected Day when autoFocus prop is true', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee29() { var _render29, driver; return _regenerator["default"].wrap(function _callee29$(_context29) { while (1) switch (_context29.prev = _context29.next) { case 0: _render29 = render(/*#__PURE__*/_react["default"].createElement(_["default"], (0, _extends2["default"])({}, defaultProps, { autoFocus: true, value: new Date(2018, 10, 10), __self: _this, __source: { fileName: _jsxFileName, lineNumber: 555, columnNumber: 11 } }))), driver = _render29.driver; _context29.t0 = expect; _context29.next = 4; return driver.getFocusedDay(); case 4: _context29.t1 = _context29.sent; (0, _context29.t0)(_context29.t1).toBe('10'); case 6: case "end": return _context29.stop(); } }, _callee29); }))); it('should NOT autoFocus on selected Day when autoFocus prop is false', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee30() { var _render30, driver; return _regenerator["default"].wrap(function _callee30$(_context30) { while (1) switch (_context30.prev = _context30.next) { case 0: _render30 = render(/*#__PURE__*/_react["default"].createElement(_["default"], (0, _extends2["default"])({}, defaultProps, { value: new Date(2018, 10, 10), autoFocus: false, __self: _this, __source: { fileName: