MediaWiki:Test.js
Страница интерфейса MediaWiki
Дополнительные действия
Замечание: Возможно, после публикации вам придётся очистить кэш своего браузера, чтобы увидеть изменения.
- Firefox / Safari: Удерживая клавишу Shift, нажмите на панели инструментов Обновить либо нажмите Ctrl+F5 или Ctrl+R (⌘+R на Mac)
- Google Chrome: Нажмите Ctrl+Shift+R (⌘+Shift+R на Mac)
- Edge: Удерживая Ctrl, нажмите Обновить либо нажмите Ctrl+F5
- Opera: Нажмите Ctrl+F5.
(function() {
if (typeof mw === 'undefined' || !window.document) return;
function initCollapse() {
var headings = document.querySelectorAll('.chem-heading');
var hi = 0;
var len = headings.length;
for (; hi < len; hi++) {
(function(node) {
if (node.getAttribute('data-chem-attached')) return;
node.setAttribute('data-chem-attached', '1');
node.style.cursor = 'pointer';
node.addEventListener('click', function() {
var kind = node.getAttribute('data-kind') || '';
var wrapper = findWrapper(node, kind);
if (!wrapper) return;
var btn = node.querySelector('.collapse-btn');
if (wrapper.classList.contains('collapsed')) {
wrapper.classList.remove('collapsed');
wrapper.classList.add('expanded');
wrapper.style.maxHeight = wrapper.scrollHeight + 'px';
if (btn) btn.textContent = 'свернуть';
var cleanup = function() {
wrapper.style.maxHeight = '';
wrapper.removeEventListener('transitionend', cleanup);
};
wrapper.addEventListener('transitionend', cleanup);
} else {
var currentHeight = wrapper.scrollHeight;
wrapper.style.maxHeight = currentHeight + 'px';
wrapper.offsetHeight;
wrapper.classList.remove('expanded');
wrapper.classList.add('collapsed');
wrapper.style.maxHeight = '0px';
if (btn) btn.textContent = 'развернуть';
}
});
})(headings[hi]);
}
}
function findWrapper(node, kind) {
var parent = node.parentNode;
if (!parent) return null;
var wrappers = parent.querySelectorAll('.collapsible');
var wi = 0;
var wlen = wrappers.length;
for (; wi < wlen; wi++) {
if (wrappers[wi].getAttribute('data-kind') === kind) {
return wrappers[wi];
}
}
return null;
}
if (document.readyState === 'complete' || document.readyState === 'interactive') {
initCollapse();
} else {
document.addEventListener('DOMContentLoaded', initCollapse);
}
})();