UNPKG

office-ui-fabric-react

Version:

Reusable React components for building experiences for Office 365.

128 lines (126 loc) • 6.82 kB
define(["require", "exports", 'react', 'react-addons-test-utils', '../../Utilities', '../../FocusZone', './ContextualMenu'], function (require, exports, React, ReactTestUtils, Utilities_1, FocusZone_1, ContextualMenu_1) { "use strict"; var expect = chai.expect; describe('ContextualMenu', function () { afterEach(function () { while (window.document.body.children.length) { window.document.body.removeChild(window.document.body.children[0]); } }); it('does not have a scrollbar due to an overflowing icon', function () { var items = [ { name: 'TestText 1', key: 'TestKey1', canCheck: true, isChecked: true }, { name: 'TestText 2', key: 'TestKey2', canCheck: true, isChecked: true }, { name: 'TestText 3', key: 'TestKey3', canCheck: true, isChecked: true }, { name: 'TestText 4', key: 'TestKey4', canCheck: true, isChecked: true }, ]; ReactTestUtils.renderIntoDocument(React.createElement(ContextualMenu_1.ContextualMenu, {items: items})); var menuList = document.querySelector('.ms-ContextualMenu-list'); expect(menuList.scrollHeight).to.be.lte(menuList.offsetHeight, 'ContextualMenu is showing a scrollbar due to checkmark'); }); it('closes on left arrow if it is a submenu', function () { var items = [ { name: 'TestText 1', key: 'TestKey1' }, { name: 'TestText 2', key: 'TestKey2' }, { name: 'TestText 3', key: 'TestKey3' }, { name: 'TestText 4', key: 'TestKey4' }, ]; var spyCalled = false; var onDismissSpy = function (ev, dismissAll) { spyCalled = true; }; ReactTestUtils.renderIntoDocument(React.createElement(ContextualMenu_1.ContextualMenu, {items: items, isSubMenu: true, onDismiss: onDismissSpy})); var menuList = document.querySelector('ul.ms-ContextualMenu-list'); ReactTestUtils.Simulate.keyDown(menuList, { which: Utilities_1.KeyCodes.left }); expect(spyCalled).to.be.true; }); it('does not close on left arrow if it is a submenu with horizontal arrowDirection', function () { var items = [ { name: 'TestText 1', key: 'TestKey1' }, { name: 'TestText 2', key: 'TestKey2' }, { name: 'TestText 3', key: 'TestKey3' }, { name: 'TestText 4', key: 'TestKey4' }, ]; var spyCalled = false; var onDismissSpy = function (ev, dismissAll) { spyCalled = true; }; ReactTestUtils.renderIntoDocument(React.createElement(ContextualMenu_1.ContextualMenu, {items: items, isSubMenu: true, onDismiss: onDismissSpy, arrowDirection: FocusZone_1.FocusZoneDirection.horizontal})); var menuList = document.querySelector('ul.ms-ContextualMenu-list'); ReactTestUtils.Simulate.keyDown(menuList, { which: Utilities_1.KeyCodes.left }); expect(spyCalled).to.be.false; }); it('does not close on left arrow if it is a submenu with bidirectional arrowDirection', function () { var items = [ { name: 'TestText 1', key: 'TestKey1' }, { name: 'TestText 2', key: 'TestKey2' }, { name: 'TestText 3', key: 'TestKey3' }, { name: 'TestText 4', key: 'TestKey4' }, ]; var spyCalled = false; var onDismissSpy = function (ev, dismissAll) { spyCalled = true; }; ReactTestUtils.renderIntoDocument(React.createElement(ContextualMenu_1.ContextualMenu, {items: items, isSubMenu: true, onDismiss: onDismissSpy, arrowDirection: FocusZone_1.FocusZoneDirection.horizontal})); var menuList = document.querySelector('ul.ms-ContextualMenu-list'); ReactTestUtils.Simulate.keyDown(menuList, { which: Utilities_1.KeyCodes.left }); expect(spyCalled).to.be.false; }); it('opens a submenu item on right arrow', function () { var items = [ { name: 'TestText 1', key: 'TestKey1', subMenuProps: { items: [ { name: 'SubmenuText 1', key: 'SubmenuKey1', className: 'SubMenuClass' } ] } }, ]; ReactTestUtils.renderIntoDocument(React.createElement(ContextualMenu_1.ContextualMenu, {items: items})); var menuItem = document.querySelector('button.ms-ContextualMenu-link'); ReactTestUtils.Simulate.keyDown(menuItem, { which: Utilities_1.KeyCodes.right }); expect(document.querySelector('.SubMenuClass')).to.exist; }); it('opens a submenu item on click', function () { var items = [ { name: 'TestText 1', key: 'TestKey1', subMenuProps: { items: [ { name: 'SubmenuText 1', key: 'SubmenuKey1', className: 'SubMenuClass' } ] } }, ]; ReactTestUtils.renderIntoDocument(React.createElement(ContextualMenu_1.ContextualMenu, {items: items})); var menuItem = document.querySelector('button.ms-ContextualMenu-link'); ReactTestUtils.Simulate.click(menuItem); expect(document.querySelector('.SubMenuClass')).to.exist; }); it('still works with deprecated IContextualMenuItem.items property', function () { var items = [ { name: 'TestText 1', key: 'TestKey1', items: [ { name: 'SubmenuText 1', key: 'SubmenuKey1', className: 'SubMenuClass' } ] }, ]; ReactTestUtils.renderIntoDocument(React.createElement(ContextualMenu_1.ContextualMenu, {items: items})); var menuItem = document.querySelector('button.ms-ContextualMenu-link'); ReactTestUtils.Simulate.keyDown(menuItem, { which: Utilities_1.KeyCodes.right }); expect(document.querySelector('.SubMenuClass')).to.exist; }); }); }); //# sourceMappingURL=ContextualMenu.test.js.map