mediawiki-skins-Vector/tests/jest/stickyHeader.test.js
Jon Robson 68239ae344 Use Codex for button styles, start transitioning icons to use Codex icon mixins
Changes:
- mw-ui-button to cdx-button
- mw-ui-quiet to cdx-button--weight-quiet
- mw-ui-icon-element to cdx-button--icon-only
- mw-ui-icon to vector-icon
- mw-ui-icon-flush-right/left to vector-button-flush-right/left
- Removes $isSmallIcon param in Hooks.php

85 Visual Changes
- ~36 changes from minor pixel changes from the new button classes in the main menu, language button
- 22 from standardizing the padding of the TOC in page title
- ~10 changes from addition of .cdx-button to the TOC toggle buttons

PERFORMANCE:
This will result in an overall increase of 2.7kb of render blocking
CSS, 1kb will be reclaimed when
I6c1ed1523df8cc9e2f2ca09506f12a595b8b013d is merged.

Co-author: Bernard Wang <bwang@wikimedia.org>
Bug: T336526
Change-Id: Ibd558238a41a0d3edb981e441638f9564f43d226
2023-06-12 16:26:28 -07:00

153 lines
4.5 KiB
JavaScript

const mustache = require( 'mustache' );
const fs = require( 'fs' );
const stickyHeaderTemplate = fs.readFileSync( 'includes/templates/StickyHeader.mustache', 'utf8' );
const buttonTemplate = fs.readFileSync( 'includes/templates/Button.mustache', 'utf8' );
const iconTemplate = fs.readFileSync( 'includes/templates/Icon.mustache', 'utf8' );
const sticky = require( '../../resources/skins.vector.js/stickyHeader.js' );
const { userLinksHTML, dropdownPartials } = require( './userLinksData.js' );
const defaultButtonsTemplateData = [ {
href: '#',
id: 'ca-talk-sticky-header',
icon: 'speechBubbles',
class: 'cdx-button cdx-button--weight-quiet cdx-button--icon-only sticky-header-icon',
'array-attributes': [ {
key: 'data-event-name',
value: 'talk-sticky-header'
}, {
key: 'tabindex',
value: '-1'
} ]
}, {
href: '#',
id: 'ca-history-sticky-header',
icon: 'history',
class: 'cdx-button cdx-button--weight-quiet cdx-button--icon-only sticky-header-icon',
'array-attributes': [ {
key: 'data-event-name',
value: 'history-sticky-header'
}, {
key: 'tabindex',
value: '-1'
} ]
}, {
href: '#',
id: 'ca-watchstar-sticky-header',
icon: 'star',
class: 'cdx-button cdx-button--weight-quiet cdx-button--icon-only sticky-header-icon mw-watchlink',
'array-attributes': [ {
key: 'data-event-name',
value: 'watch-sticky-header'
}, {
key: 'tabindex',
value: '-1'
} ]
} ];
const editButtonsTemplateData = [ {
href: '#',
id: 'ca-ve-edit-sticky-header',
icon: 'edit',
class: 'cdx-button cdx-button--weight-quiet cdx-button--icon-only sticky-header-icon',
'array-attributes': [ {
key: 'data-event-name',
value: 've-edit-sticky-header'
}, {
key: 'tabindex',
value: '-1'
} ]
}, {
href: '#',
id: 'ca-edit-sticky-header',
icon: 'wikiText',
class: 'cdx-button cdx-button--weight-quiet cdx-button--icon-only sticky-header-icon',
'array-attributes': [ {
key: 'data-event-name',
value: 'wikitext-edit-sticky-header'
}, {
key: 'tabindex',
value: '-1'
} ]
}, {
href: '#',
id: 'ca-viewsource-sticky-header',
icon: 'star',
class: 'cdx-button cdx-button--weight-quiet cdx-button--icon-only sticky-header-icon',
'array-attributes': [ {
key: 'data-event-name',
value: 'editLock'
}, {
key: 'tabindex',
value: '-1'
} ]
} ];
const templateData = {
'data-toc': {
'array-sections': []
},
'data-sticky-header-toc-dropdown': {
id: 'vector-sticky-header-toc',
class: 'mw-portlet mw-portlet-sticky-header-toc vector-sticky-header-toc',
'html-items': '',
'html-vector-menu-checkbox-attributes': 'tabindex="-1"',
'html-vector-menu-heading-attributes': 'tabindex="-1"',
'heading-class': 'cdx-button cdx-button--weight-quiet cdx-button--icon-only'
},
'array-buttons': [ {
label: '0 languages',
id: 'p-lang-btn-sticky-header',
class: 'cdx-button cdx-button--weight-quiet mw-interlanguage-selector',
'array-attributes': [ {
key: 'data-event-name',
value: 'ui.dropdown-p-lang-btn-sticky-header'
}, {
key: 'tabindex',
value: '-1'
} ]
} ],
'data-button-start': {
label: 'search',
icon: 'search',
class: 'cdx-button cdx-button--weight-quiet cdx-button--icon-only vector-sticky-header-search-toggle',
'array-attributes': [ {
key: 'data-event-name',
value: 'ui.vector-sticky-search-form.icon'
}, {
key: 'tabindex',
value: '-1'
} ]
},
'data-search': {},
'array-icon-buttons': defaultButtonsTemplateData.concat( editButtonsTemplateData )
};
const renderedHTML = mustache.render(
stickyHeaderTemplate, templateData, Object.assign( {}, dropdownPartials, {
Button: buttonTemplate,
Icon: iconTemplate,
SearchBox: '<div> </div>' // ignore SearchBox for this test
} ) );
beforeEach( () => {
document.body.innerHTML = renderedHTML;
} );
test( 'Sticky header renders', () => {
expect( document.body.innerHTML ).toMatchSnapshot();
} );
describe( 'sticky header', () => {
test( 'prepareUserLinksDropdown removes gadgets from dropdown', async () => {
const menu = document.createElement( 'div' );
menu.innerHTML = userLinksHTML;
const userLinksDropdown = /** @type {Element} */ ( menu.querySelector( '#' + sticky.USER_LINKS_DROPDOWN_ID ) );
const newMenu = sticky.prepareUserLinksDropdown( userLinksDropdown );
// check classes have been updated and removed.
expect( userLinksDropdown.querySelectorAll( '.user-links-collapsible-item' ).length > 0 ).toBeTruthy();
expect( userLinksDropdown.querySelectorAll( '.mw-list-item-js' ).length > 0 ).toBeTruthy();
expect( newMenu.querySelectorAll( '.user-links-collapsible-item' ).length ).toBe( 0 );
expect( newMenu.querySelectorAll( '.mw-list-item-js' ).length ).toBe( 0 );
} );
} );