@wix/design-system
Version:
@wix/design-system
301 lines (300 loc) • 9.68 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireDefault(require("react"));
var _react2 = require("@storybook/react");
var _Breadcrumbs = _interopRequireDefault(require("../Breadcrumbs"));
var _constants = require("../constants");
var _ = require("../..");
var _visual = require("../../utils/test-utils/visual");
var _jsxFileName = "/home/builduser/work/57e038ea7326c1ec/packages/wix-design-system/dist/cjs/Breadcrumbs/test/Breadcrumbs.visual.jsx",
_this = void 0;
function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2["default"])(o), (0, _possibleConstructorReturn2["default"])(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2["default"])(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; })(); }
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) { (0, _defineProperty2["default"])(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; }
var sizes = Object.values(_constants.SIZES);
var test = function test(it, props) {
return {
it: it,
props: props
};
};
var items = [{
id: 1,
value: 'first item'
}, {
id: 2,
value: 'second item'
}, {
id: 3,
value: 'third item'
}];
var itemsWithLinks = [{
id: 1,
value: 'Wix',
link: 'http://www.wix.com'
}, {
id: 2,
value: 'Google',
customElement: /*#__PURE__*/_react["default"].createElement("a", {
style: {
color: 'inherit',
textDecoration: 'inherit'
},
href: "http://www.google.com",
__self: void 0,
__source: {
fileName: _jsxFileName,
lineNumber: 24,
columnNumber: 7
}
}, "Google")
}, {
id: 3,
value: 'Yahoo',
link: 'http://www.yahoo.com'
}];
var tests = [{
describe: 'Standard',
its: [{
it: 'without links',
props: {
items: items
}
}, {
it: 'with links',
props: {
items: itemsWithLinks
}
}]
}, {
describe: 'Sizes',
its: sizes.map(function (size) {
return test(size, {
size: size
});
})
}, {
describe: 'Items',
its: [{
it: 'single item',
props: {
items: [{
id: 1,
value: 'first item'
}]
}
}, {
it: 'multiple items',
props: {
items: items
}
}, {
it: 'customElement items',
props: {
items: items.map(function (item) {
return _objectSpread(_objectSpread({}, item), {}, {
customElement: /*#__PURE__*/_react["default"].createElement("div", {
style: {
backgroundColor: 'red'
},
__self: _this,
__source: {
fileName: _jsxFileName,
lineNumber: 70,
columnNumber: 15
}
}, "".concat(item.value, " custom"))
});
})
}
}, {
it: 'disabled items',
props: {
items: items.map(function (item) {
return _objectSpread(_objectSpread({}, item), {}, {
disabled: true
});
})
}
}, {
it: 'long text items',
props: {
items: [{
id: 1,
value: 'first item'
}, {
id: 2,
value: 'This is a very very very very long text that will be cropped by ellipsis at some point'
}]
}
}]
}, {
describe: 'skin',
its: [{
it: 'overrides theme',
props: {
theme: _constants.SKINS.onDarkBackground,
skin: _constants.SKINS.onWhiteBackground
}
}]
}];
tests.forEach(function (_ref) {
var describe = _ref.describe,
its = _ref.its;
its.forEach(function (_ref2) {
var it = _ref2.it,
props = _ref2.props;
(0, _react2.storiesOf)("Breadcrumbs".concat(describe ? '/' + describe : ''), module).add(it, function () {
return /*#__PURE__*/_react["default"].createElement(_Breadcrumbs["default"], (0, _extends2["default"])({
items: items
}, props, {
__self: _this,
__source: {
fileName: _jsxFileName,
lineNumber: 113,
columnNumber: 13
}
}));
});
});
});
var breadcrumbsWithBoxWrapper = [{
boxBackground: 'D10',
theme: _constants.SKINS.onDarkBackground
}, {
boxBackground: 'D80',
theme: _constants.SKINS.onWhiteBackground
}, {
boxBackground: 'D70',
theme: _constants.SKINS.onGrayBackground
}];
breadcrumbsWithBoxWrapper.forEach(function (_ref3) {
var theme = _ref3.theme,
boxBackground = _ref3.boxBackground;
(0, _react2.storiesOf)("Breadcrumbs/Themes", module).add(theme, function () {
return /*#__PURE__*/_react["default"].createElement(_.Box, {
backgroundColor: boxBackground,
width: "400px",
padding: "10px",
__self: _this,
__source: {
fileName: _jsxFileName,
lineNumber: 126,
columnNumber: 5
}
}, /*#__PURE__*/_react["default"].createElement(_Breadcrumbs["default"], {
items: items,
theme: theme,
__self: _this,
__source: {
fileName: _jsxFileName,
lineNumber: 127,
columnNumber: 7
}
}));
});
});
var interactiveDataHook = 'interactive-breadcrumbs';
var breadcrumbsItemDataHook = 'breadcrumb-clickable-0';
var InteractiveEyeTest = /*#__PURE__*/function (_React$Component) {
function InteractiveEyeTest() {
var _this2;
(0, _classCallCheck2["default"])(this, InteractiveEyeTest);
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
_this2 = _callSuper(this, InteractiveEyeTest, [].concat(args));
_this2.state = {
activeId: 2
};
_this2.onClick = function (_ref4) {
var id = _ref4.id;
return _this2.setState({
activeId: id
});
};
return _this2;
}
(0, _inherits2["default"])(InteractiveEyeTest, _React$Component);
return (0, _createClass2["default"])(InteractiveEyeTest, [{
key: "componentDidMount",
value: function () {
var _componentDidMount = (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:
this.props.componentDidMount();
case 1:
case "end":
return _context.stop();
}
}, _callee, this);
}));
function componentDidMount() {
return _componentDidMount.apply(this, arguments);
}
return componentDidMount;
}()
}, {
key: "render",
value: function render() {
var items = this.props.items;
var activeId = this.state.activeId;
return /*#__PURE__*/_react["default"].createElement(_Breadcrumbs["default"], {
dataHook: interactiveDataHook,
items: items,
activeId: activeId,
onClick: this.onClick,
__self: this,
__source: {
fileName: _jsxFileName,
lineNumber: 148,
columnNumber: 7
}
});
}
}]);
}(_react["default"].Component);
var interactiveTests = [{
describe: 'Active item',
its: [{
it: 'should be in bold once clicked upon',
componentDidMount: function componentDidMount() {
(0, _visual.clickElement)(breadcrumbsItemDataHook);
(0, _visual.focusElement)(breadcrumbsItemDataHook);
},
props: {
items: items
}
}]
}];
interactiveTests.forEach(function (_ref5) {
var describe = _ref5.describe,
its = _ref5.its;
its.forEach(function (_ref6) {
var it = _ref6.it,
props = _ref6.props,
componentDidMount = _ref6.componentDidMount;
(0, _react2.storiesOf)("Breadcrumbs".concat(describe ? '/' + describe : ''), module).add(it, function () {
return /*#__PURE__*/_react["default"].createElement(InteractiveEyeTest, (0, _extends2["default"])({}, props, {
componentDidMount: componentDidMount,
__self: _this,
__source: {
fileName: _jsxFileName,
lineNumber: 179,
columnNumber: 9
}
}));
});
});
});