UNPKG

@wix/design-system

Version:

@wix/design-system

480 lines (479 loc) 12.4 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator")); var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator")); var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _react = _interopRequireWildcard(require("react")); var _react2 = require("@storybook/react"); var _MultiSelect = _interopRequireDefault(require("../MultiSelect")); var _FormField = _interopRequireDefault(require("../../FormField")); var _RTLWrapper = require("../../../stories/utils/RTLWrapper"); var _visual = require("../../utils/test-utils/visual"); var _excluded = ["componentDidMount", "rtl"]; var _jsxFileName = "/home/builduser/work/57e038ea7326c1ec/packages/wix-design-system/dist/cjs/MultiSelect/test/MultiSelect.visual.jsx", _this = void 0; function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); } var interactiveDataHook = 'interactive-multiselect'; var inputDataHook = 'wsr-custom-input'; var options = [{ value: 'Alabama', id: 'AL' }, { value: 'Alaska', id: 'AK' }, { value: 'Arizona', id: 'AZ' }, { value: 'Arkansas', id: 'AR' }, { value: 'California', id: 'CA' }, { value: 'North Carolina', id: 'NC' }, { value: 'Colorado', id: 'CO' }, { value: 'Connecticut', id: 'CT' }, { value: 'Delaware', id: 'DL' }, { value: 'Florida', id: 'FL' }, { value: 'Georgia', id: 'GA' }, { value: 'Hawaii', id: 'HI' }, { value: 'Idaho', id: 'IL' }, { value: 'Illinois', id: 'IN' }, { value: 'Indiana', id: 'IA' }]; var tests = [{ describe: 'Basic', its: [{ it: 'should render MultiSelect with customSuffix over 400px width', props: { customSuffix: /*#__PURE__*/_react["default"].createElement("div", { __self: void 0, __source: { fileName: _jsxFileName, lineNumber: 38, columnNumber: 25 } }, "some button"), tags: [{ id: '1', label: 'aaaaaaaaaaaa' }, { id: '2', label: 'aaaaaaaaaaaa' }, { id: '3', label: 'aaaaaaaaaaaa' }] }, width: '400px' }, { it: 'should render MultiSelect with customPrefix over 400px width', props: { customPrefix: /*#__PURE__*/_react["default"].createElement("div", { __self: void 0, __source: { fileName: _jsxFileName, lineNumber: 50, columnNumber: 25 } }, "some button"), tags: [{ id: '1', label: 'aaaaaaaaaaaa' }, { id: '2', label: 'aaaaaaaaaaaa' }, { id: '3', label: 'aaaaaaaaaaaa' }] }, width: '400px' }, { it: 'should render MultiSelect with customSuffix', props: { customSuffix: /*#__PURE__*/_react["default"].createElement("div", { __self: void 0, __source: { fileName: _jsxFileName, lineNumber: 62, columnNumber: 25 } }, "some button"), tags: [{ id: '1', label: 'aaaaaaaaaaaa' }, { id: '2', label: 'aaaaaaaaaaaa' }, { id: '3', label: 'aaaaaaaaaaaa' }] } }, { it: 'should render MultiSelect with customPrefix', props: { customPrefix: /*#__PURE__*/_react["default"].createElement("div", { __self: void 0, __source: { fileName: _jsxFileName, lineNumber: 73, columnNumber: 25 } }, "some button"), tags: [{ id: '1', label: 'aaaaaaaaaaaa' }, { id: '2', label: 'aaaaaaaaaaaa' }, { id: '3', label: 'aaaaaaaaaaaa' }] } }, { it: 'should render MultiSelect with "select" mode', props: { tags: [{ id: '1', label: 'aaaaaaaaaaaa' }, { id: '2', label: 'aaaaaaaaaaaa' }, { id: '3', label: 'aaaaaaaaaaaa' }, { id: '4', label: 'aaaaaaaaaaaa' }, { id: '5', label: 'aaaaaaaaaaaa' }, { id: '6', label: 'aaaaaaaaaaaa' }], mode: 'select' }, width: '400px' }, { it: 'should fill input with tags without breaking a line', props: { tags: [{ id: '1', label: 'a' }, { id: '2', label: 'b' }, { id: '3', label: 'c' }, { id: '4', label: 'd' }, { id: '5', label: 'e' }, { id: '6', label: 'f' }, { id: '7', label: 'f' }] }, width: '400px' }, { it: 'should render tags without remove button when readOnly mode is ON', props: { readOnly: true, tags: [{ id: '1', label: 'a' }, { id: '2', label: 'b' }] } }, { it: 'should render tags without remove button when readOnly mode is ON as onReorder function is passed', props: { readOnly: true, onReorder: function onReorder() { return null; }, tags: [{ id: '1', label: 'a' }, { id: '2', label: 'b' }] } }, { it: 'should render disabled MultiSelect', props: { disabled: true, tags: [{ id: '1', label: 'Alabama' }, { id: '2', label: 'Alaska' }, { id: '3', label: 'Arizona' }, { id: '4', label: 'Arkansas' }] }, width: '500px' }, { it: 'should render disabled MultiSelect with a placeholder', props: { disabled: true, placeholder: 'This is a MultiSelect placeholder' }, width: '500px' }, { it: 'should render readOnly MultiSelect', props: { readOnly: true }, width: '500px' }] }, { describe: 'With Status', its: [{ it: 'error', props: { mode: 'select', status: 'error' } }, { it: 'warning', props: { mode: 'select', status: 'warning' } }, { it: 'loading', props: { mode: 'select', status: 'loading' } }] }]; tests.forEach(function (_ref) { var describe = _ref.describe, its = _ref.its; its.forEach(function (_ref2) { var it = _ref2.it, props = _ref2.props, width = _ref2.width; (0, _react2.storiesOf)("MultiSelect".concat(describe ? '/' + describe : ''), module).add(it, function () { return /*#__PURE__*/_react["default"].createElement("div", { style: { width: width }, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 195, columnNumber: 9 } }, /*#__PURE__*/_react["default"].createElement(_MultiSelect["default"], (0, _extends2["default"])({}, props, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 196, columnNumber: 11 } }))); }); }); }); var interactiveTests = [{ describe: 'Directional tests', its: [{ it: 'LTR should show 2 tags', componentDidMount: function componentDidMount() { return (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee() { return _regenerator["default"].wrap(function _callee$(_context) { while (1) switch (_context.prev = _context.next) { case 0: (0, _visual.clickElement)(inputDataHook); (0, _visual.focusElement)(inputDataHook); case 2: case "end": return _context.stop(); } }, _callee); }))(); }, props: { tags: [{ id: 'AL', label: 'Alabama (AL)' }, { id: 'AZ', label: 'Arizona (AZ)' }], options: options } }, { it: 'RTL should show 2 tags', componentDidMount: function componentDidMount() { return (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee2() { return _regenerator["default"].wrap(function _callee2$(_context2) { while (1) switch (_context2.prev = _context2.next) { case 0: (0, _visual.clickElement)(inputDataHook); (0, _visual.focusElement)(inputDataHook); case 2: case "end": return _context2.stop(); } }, _callee2); }))(); }, props: { tags: [{ id: 'AL', label: 'Alabama (AL)' }, { id: 'AZ', label: 'Arizona (AZ)' }], options: options }, rtl: true }] }]; var InteractiveEyeTest = function InteractiveEyeTest(_ref3) { var componentDidMount = _ref3.componentDidMount, rtl = _ref3.rtl, props = (0, _objectWithoutProperties2["default"])(_ref3, _excluded); (0, _react.useEffect)(function () { componentDidMount(); }, [componentDidMount]); return /*#__PURE__*/_react["default"].createElement(_RTLWrapper.RTLWrapper, { rtl: rtl, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 245, columnNumber: 5 } }, /*#__PURE__*/_react["default"].createElement(_MultiSelect["default"], (0, _extends2["default"])({ dataHook: interactiveDataHook }, props, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 246, columnNumber: 7 } }))); }; interactiveTests.forEach(function (_ref4) { var describe = _ref4.describe, its = _ref4.its; its.forEach(function (_ref5) { var it = _ref5.it, props = _ref5.props, rtl = _ref5.rtl, componentDidMount = _ref5.componentDidMount; (0, _react2.storiesOf)("MultiSelect".concat(describe ? '/' + describe : ''), module).add(it, function () { return /*#__PURE__*/_react["default"].createElement(InteractiveEyeTest, (0, _extends2["default"])({}, props, { componentDidMount: componentDidMount, rtl: rtl, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 256, columnNumber: 9 } })); }); }); }); var multiselectWithFormFieldStatus = [{ describe: 'Form field status', its: [{ it: 'Error', props: { status: 'error', statusMessage: 'This is error message', options: options } }, { it: 'Warning', props: { status: 'warning', statusMessage: 'This is warning message', options: options } }, { it: 'Loading', props: { status: 'loading', statusMessage: 'This is loading message', options: options } }] }]; multiselectWithFormFieldStatus.forEach(function (_ref6) { var describe = _ref6.describe, its = _ref6.its; its.forEach(function (_ref7) { var it = _ref7.it, props = _ref7.props; (0, _react2.storiesOf)("MultiSelect".concat(describe ? '/' + describe : ''), module).add(it, function () { return /*#__PURE__*/_react["default"].createElement(_FormField["default"], { status: props.status, statusMessage: props.statusMessage, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 303, columnNumber: 9 } }, /*#__PURE__*/_react["default"].createElement(_MultiSelect["default"], { options: props.options, mode: "select", __self: _this, __source: { fileName: _jsxFileName, lineNumber: 304, columnNumber: 11 } })); }); }); });