UNPKG

wix-style-react

Version:
184 lines (149 loc) • 6.21 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.dropdownBaseDriverFactory = undefined; var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; // TODO: remove when implementation with UniDriver becomes possible var _baseDriver = require('wix-ui-test-utils/base-driver'); var _DropdownLayoutUni = require('../DropdownLayout/DropdownLayout.uni.driver'); var _testUtils = require('react-dom/test-utils'); function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { step("next", value); }, function (err) { step("throw", err); }); } } return step("next"); }); }; } var dropdownBaseDriverFactory = exports.dropdownBaseDriverFactory = function dropdownBaseDriverFactory(base) { var byDataHook = function byDataHook(dataHook) { return base.$('[data-hook="' + dataHook + '"]'); }; var getTargetElement = function getTargetElement() { return byDataHook('popover-element'); }; var getContentElement = function getContentElement() { return byDataHook('popover-content'); }; var createDropdownLayoutDriver = function createDropdownLayoutDriver() { return (0, _DropdownLayoutUni.dropdownLayoutDriverFactory)(base); }; return _extends({}, (0, _baseDriver.baseUniDriverFactory)(base), { /** Returns the native target element */ clickTargetElement: function clickTargetElement() { return getTargetElement().click(); }, /** Returns `true` if the dropdown is being shown */ isDropdownShown: function () { var _ref = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() { return regeneratorRuntime.wrap(function _callee$(_context) { while (1) { switch (_context.prev = _context.next) { case 0: _context.next = 2; return getContentElement().exists(); case 2: return _context.abrupt('return', _context.sent); case 3: case 'end': return _context.stop(); } } }, _callee, undefined); })); return function isDropdownShown() { return _ref.apply(this, arguments); }; }(), /** Select a specific option (requires the DropdownBase to be opened) */ selectOption: function () { var _ref2 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee2(index) { return regeneratorRuntime.wrap(function _callee2$(_context2) { while (1) { switch (_context2.prev = _context2.next) { case 0: return _context2.abrupt('return', createDropdownLayoutDriver().clickAtOption(index)); case 1: case 'end': return _context2.stop(); } } }, _callee2, undefined); })); return function selectOption(_x) { return _ref2.apply(this, arguments); }; }(), /** Click outside of the component */ clickOutside: function () { var _ref3 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee3() { return regeneratorRuntime.wrap(function _callee3$(_context3) { while (1) { switch (_context3.prev = _context3.next) { case 0: if (base.type === 'react') { document.dispatchEvent(new Event('mousedown')); } case 1: case 'end': return _context3.stop(); } } }, _callee3, undefined); })); return function clickOutside() { return _ref3.apply(this, arguments); }; }(), /** Perform a mouseEnter on the component */ mouseEnter: function () { var _ref4 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee4() { return regeneratorRuntime.wrap(function _callee4$(_context4) { while (1) { switch (_context4.prev = _context4.next) { case 0: if (!(base.type === 'react')) { _context4.next = 6; break; } _context4.t0 = _testUtils.Simulate; _context4.next = 4; return base.getNative(); case 4: _context4.t1 = _context4.sent; _context4.t0.mouseEnter.call(_context4.t0, _context4.t1); case 6: case 'end': return _context4.stop(); } } }, _callee4, undefined); })); return function mouseEnter() { return _ref4.apply(this, arguments); }; }(), /** Perform a mouseLeave on the component */ mouseLeave: function () { var _ref5 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee5() { return regeneratorRuntime.wrap(function _callee5$(_context5) { while (1) { switch (_context5.prev = _context5.next) { case 0: if (!(base.type === 'react')) { _context5.next = 6; break; } _context5.t0 = _testUtils.Simulate; _context5.next = 4; return base.getNative(); case 4: _context5.t1 = _context5.sent; _context5.t0.mouseLeave.call(_context5.t0, _context5.t1); case 6: case 'end': return _context5.stop(); } } }, _callee5, undefined); })); return function mouseLeave() { return _ref5.apply(this, arguments); }; }() }); };