UNPKG

@wix/design-system

Version:

@wix/design-system

1,313 lines 65.4 kB
import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator"; var _jsxFileName = "/home/builduser/work/57e038ea7326c1ec/packages/wix-design-system/dist/esm/SidePanel/test/SidePanel.spec.jsx", _this = this; import _regeneratorRuntime from "@babel/runtime/regenerator"; import React from 'react'; import { createRendererWithUniDriver, cleanup } from '../../utils/test-utils/unit'; import SidePanel from '../SidePanel'; import { sidePanelPrivateDriverFactory } from './SidePanel.private.uni.driver'; import WixDesignSystemProvider from '../../WixDesignSystemProvider'; describe('SidePanel', function () { var render = createRendererWithUniDriver(sidePanelPrivateDriverFactory); afterEach(function () { cleanup(); }); it('should render', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee() { var _render, driver; return _regeneratorRuntime.wrap(function _callee$(_context) { while (1) switch (_context.prev = _context.next) { case 0: _render = render(/*#__PURE__*/React.createElement(SidePanel, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 18, columnNumber: 31 } })), driver = _render.driver; _context.t0 = expect; _context.next = 4; return driver.exists(); case 4: _context.t1 = _context.sent; (0, _context.t0)(_context.t1).toBe(true); case 6: case "end": return _context.stop(); } }, _callee); }))); it('should pass the class name', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee2() { var expectedClassName, _render2, driver; return _regeneratorRuntime.wrap(function _callee2$(_context2) { while (1) switch (_context2.prev = _context2.next) { case 0: expectedClassName = 'some-selector'; _render2 = render(/*#__PURE__*/React.createElement(SidePanel, { className: expectedClassName, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 24, columnNumber: 31 } })), driver = _render2.driver; _context2.t0 = expect; _context2.next = 5; return driver.hasClass(expectedClassName); case 5: _context2.t1 = _context2.sent; (0, _context2.t0)(_context2.t1).toBe(true); case 7: case "end": return _context2.stop(); } }, _callee2); }))); describe('SidePanel.Content', function () { it('should have content', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee3() { var content, _render3, driver; return _regeneratorRuntime.wrap(function _callee3$(_context3) { while (1) switch (_context3.prev = _context3.next) { case 0: content = 'Any Content'; _render3 = render(/*#__PURE__*/React.createElement(SidePanel, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 32, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Content, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 33, columnNumber: 11 } }, content))), driver = _render3.driver; _context3.t0 = expect; _context3.next = 5; return driver.content.exists(); case 5: _context3.t1 = _context3.sent; (0, _context3.t0)(_context3.t1).toBe(true); case 7: case "end": return _context3.stop(); } }, _callee3); }))); it('should expose content', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee4() { var content, _render4, driver; return _regeneratorRuntime.wrap(function _callee4$(_context4) { while (1) switch (_context4.prev = _context4.next) { case 0: content = 'Any Content'; _render4 = render(/*#__PURE__*/React.createElement(SidePanel, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 43, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Content, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 44, columnNumber: 11 } }, /*#__PURE__*/React.createElement("div", { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 45, columnNumber: 13 } }, content)))), driver = _render4.driver; _context4.t0 = expect; _context4.next = 5; return driver.getContent(); case 5: _context4.t1 = _context4.sent.textContent; (0, _context4.t0)(_context4.t1).toBe(content); case 7: case "end": return _context4.stop(); } }, _callee4); }))); it('should use scroll ref when passed', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee5() { var content, testRef; return _regeneratorRuntime.wrap(function _callee5$(_context5) { while (1) switch (_context5.prev = _context5.next) { case 0: content = 'Any Content'; testRef = /*#__PURE__*/React.createRef(); render(/*#__PURE__*/React.createElement(SidePanel, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 58, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Content, { scrollElementRef: testRef, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 59, columnNumber: 11 } }, /*#__PURE__*/React.createElement("div", { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 60, columnNumber: 13 } }, content)))); expect(testRef.current.textContent).toEqual(content); case 4: case "end": return _context5.stop(); } }, _callee5); }))); }); describe('SidePanel.Header', function () { it('should have header', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee6() { var _render5, driver; return _regeneratorRuntime.wrap(function _callee6$(_context6) { while (1) switch (_context6.prev = _context6.next) { case 0: _render5 = render(/*#__PURE__*/React.createElement(SidePanel, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 72, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 73, columnNumber: 11 } }))), driver = _render5.driver; _context6.t0 = expect; _context6.next = 4; return driver.header.exists(); case 4: _context6.t1 = _context6.sent; (0, _context6.t0)(_context6.t1).toBe(true); case 6: case "end": return _context6.stop(); } }, _callee6); }))); it('should have string title', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee7() { var title, _render6, driver; return _regeneratorRuntime.wrap(function _callee7$(_context7) { while (1) switch (_context7.prev = _context7.next) { case 0: title = 'some text'; _render6 = render(/*#__PURE__*/React.createElement(SidePanel, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 83, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { title: title, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 84, columnNumber: 11 } }))), driver = _render6.driver; _context7.t0 = expect; _context7.next = 5; return driver.getTitleText(); case 5: _context7.t1 = _context7.sent; (0, _context7.t0)(_context7.t1).toBe(title); case 7: case "end": return _context7.stop(); } }, _callee7); }))); it('should have string title with infoTooltipContent ', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee8() { var infoTooltipContent, _render7, driver; return _regeneratorRuntime.wrap(function _callee8$(_context8) { while (1) switch (_context8.prev = _context8.next) { case 0: infoTooltipContent = 'infoTooltipContent'; _render7 = render(/*#__PURE__*/React.createElement(SidePanel, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 94, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { title: "title", infoTooltipContent: infoTooltipContent, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 95, columnNumber: 11 } }))), driver = _render7.driver; _context8.t0 = expect; _context8.next = 5; return driver.getTooltipContent(); case 5: _context8.t1 = _context8.sent; (0, _context8.t0)(_context8.t1).toBe(infoTooltipContent); case 7: case "end": return _context8.stop(); } }, _callee8); }))); it('should have custom node title', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee9() { var title, _render8, driver; return _regeneratorRuntime.wrap(function _callee9$(_context9) { while (1) switch (_context9.prev = _context9.next) { case 0: title = 'some text'; _render8 = render(/*#__PURE__*/React.createElement(SidePanel, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 107, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { title: /*#__PURE__*/React.createElement("div", { "data-hook": "custom-node", __self: _this, __source: { fileName: _jsxFileName, lineNumber: 109, columnNumber: 20 } }, title), __self: _this, __source: { fileName: _jsxFileName, lineNumber: 108, columnNumber: 11 } }))), driver = _render8.driver; _context9.t0 = expect; _context9.next = 5; return driver.header.getCustomNodeText(); case 5: _context9.t1 = _context9.sent; (0, _context9.t0)(_context9.t1).toBe(title); case 7: case "end": return _context9.stop(); } }, _callee9); }))); it('should have custom node prefix', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee0() { var prefix, _render9, driver; return _regeneratorRuntime.wrap(function _callee0$(_context0) { while (1) switch (_context0.prev = _context0.next) { case 0: prefix = /*#__PURE__*/React.createElement("div", { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 118, columnNumber: 22 } }, "Custom Prefix"); _render9 = render(/*#__PURE__*/React.createElement(SidePanel, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 120, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { prefix: prefix, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 121, columnNumber: 11 } }))), driver = _render9.driver; _context0.t0 = expect; _context0.next = 5; return driver.getPrefix(); case 5: _context0.t1 = _context0.sent.textContent; (0, _context0.t0)(_context0.t1).toBe('Custom Prefix'); case 7: case "end": return _context0.stop(); } }, _callee0); }))); it('should have custom node suffix', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee1() { var suffix, _render0, driver; return _regeneratorRuntime.wrap(function _callee1$(_context1) { while (1) switch (_context1.prev = _context1.next) { case 0: suffix = /*#__PURE__*/React.createElement("div", { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 129, columnNumber: 22 } }, "Custom Suffix"); _render0 = render(/*#__PURE__*/React.createElement(SidePanel, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 131, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { suffix: suffix, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 132, columnNumber: 11 } }))), driver = _render0.driver; _context1.t0 = expect; _context1.next = 5; return driver.getSuffix(); case 5: _context1.t1 = _context1.sent.textContent; (0, _context1.t0)(_context1.t1).toBe('Custom Suffix'); case 7: case "end": return _context1.stop(); } }, _callee1); }))); it('should have string subtitle', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee10() { var subtitle, _render1, driver; return _regeneratorRuntime.wrap(function _callee10$(_context10) { while (1) switch (_context10.prev = _context10.next) { case 0: subtitle = 'some subtitle text'; _render1 = render(/*#__PURE__*/React.createElement(SidePanel, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 142, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { subtitle: subtitle, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 143, columnNumber: 11 } }))), driver = _render1.driver; _context10.t0 = expect; _context10.next = 5; return driver.getSubtitleText(); case 5: _context10.t1 = _context10.sent; (0, _context10.t0)(_context10.t1).toBe(subtitle); case 7: case "end": return _context10.stop(); } }, _callee10); }))); it('should have custom node subtitle', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee11() { var subtitle, _render10, driver; return _regeneratorRuntime.wrap(function _callee11$(_context11) { while (1) switch (_context11.prev = _context11.next) { case 0: subtitle = 'some subtitle text'; _render10 = render(/*#__PURE__*/React.createElement(SidePanel, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 153, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { subtitle: /*#__PURE__*/React.createElement("div", { "data-hook": "custom-node", __self: _this, __source: { fileName: _jsxFileName, lineNumber: 155, columnNumber: 23 } }, subtitle), __self: _this, __source: { fileName: _jsxFileName, lineNumber: 154, columnNumber: 11 } }))), driver = _render10.driver; _context11.t0 = expect; _context11.next = 5; return driver.header.getCustomNodeText(); case 5: _context11.t1 = _context11.sent; (0, _context11.t0)(_context11.t1).toBe(subtitle); case 7: case "end": return _context11.stop(); } }, _callee11); }))); it('should show divider by default', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee12() { var title, _render11, driver; return _regeneratorRuntime.wrap(function _callee12$(_context12) { while (1) switch (_context12.prev = _context12.next) { case 0: title = 'some text'; _render11 = render(/*#__PURE__*/React.createElement(SidePanel, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 166, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { title: title, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 167, columnNumber: 11 } }))), driver = _render11.driver; _context12.t0 = expect; _context12.next = 5; return driver.isHeaderDividerExists(); case 5: _context12.t1 = _context12.sent; (0, _context12.t0)(_context12.t1).toBe(true); case 7: case "end": return _context12.stop(); } }, _callee12); }))); it('should show divider', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee13() { var title, _render12, driver; return _regeneratorRuntime.wrap(function _callee13$(_context13) { while (1) switch (_context13.prev = _context13.next) { case 0: title = 'some text'; _render12 = render(/*#__PURE__*/React.createElement(SidePanel, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 177, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { title: title, showDivider: true, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 178, columnNumber: 11 } }))), driver = _render12.driver; _context13.t0 = expect; _context13.next = 5; return driver.isHeaderDividerExists(); case 5: _context13.t1 = _context13.sent; (0, _context13.t0)(_context13.t1).toBe(true); case 7: case "end": return _context13.stop(); } }, _callee13); }))); it('should not show divider', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee14() { var title, _render13, driver; return _regeneratorRuntime.wrap(function _callee14$(_context14) { while (1) switch (_context14.prev = _context14.next) { case 0: title = 'some text'; _render13 = render(/*#__PURE__*/React.createElement(SidePanel, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 188, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { title: title, showDivider: false, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 189, columnNumber: 11 } }))), driver = _render13.driver; _context14.t0 = expect; _context14.next = 5; return driver.isHeaderDividerExists(); case 5: _context14.t1 = _context14.sent; (0, _context14.t0)(_context14.t1).toBe(false); case 7: case "end": return _context14.stop(); } }, _callee14); }))); it('should NOT render help button when `helpButtonProps.onClick` is undefined', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee15() { var _render14, driver; return _regeneratorRuntime.wrap(function _callee15$(_context15) { while (1) switch (_context15.prev = _context15.next) { case 0: _render14 = render(/*#__PURE__*/React.createElement(SidePanel, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 198, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 199, columnNumber: 11 } }))), driver = _render14.driver; _context15.t0 = expect; _context15.next = 4; return driver.isHelpButtonExists(); case 4: _context15.t1 = _context15.sent; (0, _context15.t0)(_context15.t1).toBe(false); case 6: case "end": return _context15.stop(); } }, _callee15); }))); it('should render help button when `helpButtonProps.onClick` is provided', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee16() { var _render15, driver; return _regeneratorRuntime.wrap(function _callee16$(_context16) { while (1) switch (_context16.prev = _context16.next) { case 0: _render15 = render(/*#__PURE__*/React.createElement(SidePanel, { helpButtonProps: { onClick: function onClick() {} }, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 207, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 208, columnNumber: 11 } }))), driver = _render15.driver; _context16.t0 = expect; _context16.next = 4; return driver.isHelpButtonExists(); case 4: _context16.t1 = _context16.sent; (0, _context16.t0)(_context16.t1).toBe(true); case 6: case "end": return _context16.stop(); } }, _callee16); }))); it('should fire callback when help button is clicked', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee17() { var onHelpButtonClickSpy, _render16, driver; return _regeneratorRuntime.wrap(function _callee17$(_context17) { while (1) switch (_context17.prev = _context17.next) { case 0: onHelpButtonClickSpy = vi.fn(); _render16 = render(/*#__PURE__*/React.createElement(SidePanel, { helpButtonProps: { onClick: onHelpButtonClickSpy }, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 217, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 218, columnNumber: 11 } }))), driver = _render16.driver; _context17.next = 4; return driver.clickHelp(); case 4: expect(onHelpButtonClickSpy).toHaveBeenCalledTimes(1); case 5: case "end": return _context17.stop(); } }, _callee17); }))); it('should fire callback when help button is mouse down', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee18() { var onMouseDown, _render17, driver; return _regeneratorRuntime.wrap(function _callee18$(_context18) { while (1) switch (_context18.prev = _context18.next) { case 0: onMouseDown = vi.fn(); _render17 = render(/*#__PURE__*/React.createElement(SidePanel, { helpButtonProps: { onMouseDown: onMouseDown, onClick: function onClick() {} }, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 228, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 229, columnNumber: 11 } }))), driver = _render17.driver; _context18.next = 4; return driver.mouseDownHelp(); case 4: expect(onMouseDown).toHaveBeenCalledTimes(1); case 5: case "end": return _context18.stop(); } }, _callee18); }))); it('should NOT have close button if `closeButtonProps.onClick` is undefined', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee19() { var _render18, driver; return _regeneratorRuntime.wrap(function _callee19$(_context19) { while (1) switch (_context19.prev = _context19.next) { case 0: _render18 = render(/*#__PURE__*/React.createElement(SidePanel, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 240, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 241, columnNumber: 11 } }))), driver = _render18.driver; _context19.t0 = expect; _context19.next = 4; return driver.isCloseButtonExists(); case 4: _context19.t1 = _context19.sent; (0, _context19.t0)(_context19.t1).toBe(false); case 6: case "end": return _context19.stop(); } }, _callee19); }))); it('should have close button by default', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee20() { var _render19, driver; return _regeneratorRuntime.wrap(function _callee20$(_context20) { while (1) switch (_context20.prev = _context20.next) { case 0: _render19 = render(/*#__PURE__*/React.createElement(SidePanel, { closeButtonProps: { onClick: function onClick() {} }, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 250, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 251, columnNumber: 11 } }))), driver = _render19.driver; _context20.t0 = expect; _context20.next = 4; return driver.isCloseButtonExists(); case 4: _context20.t1 = _context20.sent; (0, _context20.t0)(_context20.t1).toBe(true); case 6: case "end": return _context20.stop(); } }, _callee20); }))); it('should call `closeButtonProps.onClick` when close button clicked', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee21() { var onCloseButtonClick, _render20, driver; return _regeneratorRuntime.wrap(function _callee21$(_context21) { while (1) switch (_context21.prev = _context21.next) { case 0: onCloseButtonClick = vi.fn(); _render20 = render(/*#__PURE__*/React.createElement(SidePanel, { closeButtonProps: { onClick: onCloseButtonClick }, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 261, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 262, columnNumber: 11 } }))), driver = _render20.driver; _context21.next = 4; return driver.clickClose(); case 4: expect(onCloseButtonClick).toHaveBeenCalled(); case 5: case "end": return _context21.stop(); } }, _callee21); }))); it('should call `closeButtonProps.onMouseDown` when close button mouse down', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee22() { var onMouseDown, _render21, driver; return _regeneratorRuntime.wrap(function _callee22$(_context22) { while (1) switch (_context22.prev = _context22.next) { case 0: onMouseDown = vi.fn(); _render21 = render(/*#__PURE__*/React.createElement(SidePanel, { closeButtonProps: { onMouseDown: onMouseDown, onClick: function onClick() {} }, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 274, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 275, columnNumber: 11 } }))), driver = _render21.driver; _context22.next = 4; return driver.mouseDownClose(); case 4: expect(onMouseDown).toHaveBeenCalled(); case 5: case "end": return _context22.stop(); } }, _callee22); }))); it('should update `closeButtonProps.onClick` when rerendering', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee23() { var onCloseButtonClick, onCloseButtonClick2, _render22, driver, rerender; return _regeneratorRuntime.wrap(function _callee23$(_context23) { while (1) switch (_context23.prev = _context23.next) { case 0: onCloseButtonClick = vi.fn(); onCloseButtonClick2 = vi.fn(); _render22 = render(/*#__PURE__*/React.createElement(SidePanel, { closeButtonProps: { onClick: onCloseButtonClick }, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 288, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 289, columnNumber: 11 } }))), driver = _render22.driver, rerender = _render22.rerender; rerender(/*#__PURE__*/React.createElement(SidePanel, { closeButtonProps: { onClick: onCloseButtonClick2 }, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 293, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 294, columnNumber: 11 } }))); _context23.next = 6; return driver.clickClose(); case 6: expect(onCloseButtonClick).not.toHaveBeenCalled(); expect(onCloseButtonClick2).toHaveBeenCalled(); case 8: case "end": return _context23.stop(); } }, _callee23); }))); it('should have children', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee24() { var title, _render23, driver; return _regeneratorRuntime.wrap(function _callee24$(_context24) { while (1) switch (_context24.prev = _context24.next) { case 0: title = 'some text'; _render23 = render(/*#__PURE__*/React.createElement(SidePanel, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 307, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 308, columnNumber: 11 } }, /*#__PURE__*/React.createElement("div", { "data-hook": "custom-node", __self: _this, __source: { fileName: _jsxFileName, lineNumber: 309, columnNumber: 13 } }, title)))), driver = _render23.driver; _context24.t0 = expect; _context24.next = 5; return driver.header.getCustomNodeText(); case 5: _context24.t1 = _context24.sent; (0, _context24.t0)(_context24.t1).toBe(title); case 7: case "end": return _context24.stop(); } }, _callee24); }))); it('should NOT have back button if `backButtonProps.onClick` is undefined', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee25() { var _render24, driver; return _regeneratorRuntime.wrap(function _callee25$(_context25) { while (1) switch (_context25.prev = _context25.next) { case 0: _render24 = render(/*#__PURE__*/React.createElement(SidePanel, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 319, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 320, columnNumber: 11 } }))), driver = _render24.driver; _context25.t0 = expect; _context25.next = 4; return driver.isBackButtonExists(); case 4: _context25.t1 = _context25.sent; (0, _context25.t0)(_context25.t1).toBe(false); case 6: case "end": return _context25.stop(); } }, _callee25); }))); it('should call `backButtonProps.onClick` when back button clicked', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee26() { var onBackButtonClick, _render25, driver; return _regeneratorRuntime.wrap(function _callee26$(_context26) { while (1) switch (_context26.prev = _context26.next) { case 0: onBackButtonClick = vi.fn(); _render25 = render(/*#__PURE__*/React.createElement(SidePanel, { backButtonProps: { onClick: onBackButtonClick }, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 330, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 331, columnNumber: 11 } }))), driver = _render25.driver; _context26.next = 4; return driver.clickBack(); case 4: expect(onBackButtonClick).toHaveBeenCalled(); case 5: case "end": return _context26.stop(); } }, _callee26); }))); it('should call `backButtonProps.onMouseDown` when back button mouse down', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee27() { var onMouseDown, _render26, driver; return _regeneratorRuntime.wrap(function _callee27$(_context27) { while (1) switch (_context27.prev = _context27.next) { case 0: onMouseDown = vi.fn(); _render26 = render(/*#__PURE__*/React.createElement(SidePanel, { backButtonProps: { onMouseDown: onMouseDown, onClick: function onClick() {} }, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 343, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 344, columnNumber: 11 } }))), driver = _render26.driver; _context27.next = 4; return driver.mouseDownBack(); case 4: expect(onMouseDown).toHaveBeenCalled(); case 5: case "end": return _context27.stop(); } }, _callee27); }))); it('should update `backButtonProps.onClick` when rerendering', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee28() { var onBackButtonClick, onBackButtonClick2, _render27, driver, rerender; return _regeneratorRuntime.wrap(function _callee28$(_context28) { while (1) switch (_context28.prev = _context28.next) { case 0: onBackButtonClick = vi.fn(); onBackButtonClick2 = vi.fn(); _render27 = render(/*#__PURE__*/React.createElement(SidePanel, { backButtonProps: { onClick: onBackButtonClick }, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 357, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 358, columnNumber: 11 } }))), driver = _render27.driver, rerender = _render27.rerender; rerender(/*#__PURE__*/React.createElement(SidePanel, { backButtonProps: { onClick: onBackButtonClick2 }, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 362, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 363, columnNumber: 11 } }))); _context28.next = 6; return driver.clickBack(); case 6: expect(onBackButtonClick).not.toHaveBeenCalled(); expect(onBackButtonClick2).toHaveBeenCalled(); case 8: case "end": return _context28.stop(); } }, _callee28); }))); it('tooltip should NOT appear when `backButtonProps.description` is undefined', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee29() { var _render28, driver; return _regeneratorRuntime.wrap(function _callee29$(_context29) { while (1) switch (_context29.prev = _context29.next) { case 0: _render28 = render(/*#__PURE__*/React.createElement(SidePanel, { backButtonProps: { onClick: function onClick() {} }, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 375, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 376, columnNumber: 11 } }))), driver = _render28.driver; _context29.t0 = expect; _context29.next = 4; return driver.header.isBackButtonTooltipExists(); case 4: _context29.t1 = _context29.sent; (0, _context29.t0)(_context29.t1).toBe(false); case 6: case "end": return _context29.stop(); } }, _callee29); }))); it('tooltip should appear when `backButtonProps.description` is defined', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee30() { var content, _render29, driver; return _regeneratorRuntime.wrap(function _callee30$(_context30) { while (1) switch (_context30.prev = _context30.next) { case 0: content = 'back'; _render29 = render(/*#__PURE__*/React.createElement(SidePanel, { backButtonProps: { onClick: function onClick() {}, description: content }, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 386, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Header, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 389, columnNumber: 11 } }))), driver = _render29.driver; _context30.t0 = expect; _context30.next = 5; return driver.getBackButtonTooltipContent(); case 5: _context30.t1 = _context30.sent; (0, _context30.t0)(_context30.t1).toBe(content); case 7: case "end": return _context30.stop(); } }, _callee30); }))); }); describe('SidePanel.Footer', function () { it('should have footer', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee31() { var content, _render30, driver; return _regeneratorRuntime.wrap(function _callee31$(_context31) { while (1) switch (_context31.prev = _context31.next) { case 0: content = 'Any Content'; _render30 = render(/*#__PURE__*/React.createElement(SidePanel, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 401, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Footer, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 402, columnNumber: 11 } }, content))), driver = _render30.driver; _context31.t0 = expect; _context31.next = 5; return driver.footer.exists(); case 5: _context31.t1 = _context31.sent; (0, _context31.t0)(_context31.t1).toBe(true); case 7: case "end": return _context31.stop(); } }, _callee31); }))); it('should show divider by default', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee32() { var _render31, driver; return _regeneratorRuntime.wrap(function _callee32$(_context32) { while (1) switch (_context32.prev = _context32.next) { case 0: _render31 = render(/*#__PURE__*/React.createElement(SidePanel, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 411, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Footer, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 412, columnNumber: 11 } }))), driver = _render31.driver; _context32.t0 = expect; _context32.next = 4; return driver.isFooterDividerExists(); case 4: _context32.t1 = _context32.sent; (0, _context32.t0)(_context32.t1).toBe(true); case 6: case "end": return _context32.stop(); } }, _callee32); }))); it('should show divider', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee33() { var _render32, driver; return _regeneratorRuntime.wrap(function _callee33$(_context33) { while (1) switch (_context33.prev = _context33.next) { case 0: _render32 = render(/*#__PURE__*/React.createElement(SidePanel, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 421, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Footer, { showDivider: true, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 422, columnNumber: 11 } }))), driver = _render32.driver; _context33.t0 = expect; _context33.next = 4; return driver.isFooterDividerExists(); case 4: _context33.t1 = _context33.sent; (0, _context33.t0)(_context33.t1).toBe(true); case 6: case "end": return _context33.stop(); } }, _callee33); }))); it('should not show divider', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee34() { var _render33, driver; return _regeneratorRuntime.wrap(function _callee34$(_context34) { while (1) switch (_context34.prev = _context34.next) { case 0: _render33 = render(/*#__PURE__*/React.createElement(SidePanel, { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 431, columnNumber: 9 } }, /*#__PURE__*/React.createElement(SidePanel.Footer, { showDivider: false, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 432, columnNumber: 11 } }))), driver = _render33.driver; _context34.t0 = expect; _context34.next = 4; return driver.isFooterDividerExists(); case 4: _context34.t1 = _context34.sent; (0, _context34.t0)(_context34.t1).toBe(false); case 6: case "end": return _context34.stop(); } }, _callee34); }))); }); describe('ac