User:Mike Dillon/Scripts/navbox.js

From Wikipedia, the free encyclopedia

Note: After saving, you have to bypass your browser's cache to see the changes. In Internet Explorer and Firefox, hold down the Ctrl key and click the Refresh or Reload button. Opera users have to clear their caches through Tools→Preferences, see the instructions for Opera. Konqueror and Safari users can just click the Reload button.

// Requires: [[User:Mike Dillon/Scripts/easydom.js]]
 
// <pre><nowiki>
 
function addNavbox(id, title, refId, refMode) {
    // Find the toolbox
    var oldBox = document.getElementById('p-tb');
    if (!oldBox) return;
 
    // Clone the toolbox and change its DOM id
    var newBox = oldBox.cloneNode(true);
    newBox.id = id;
 
    // Find the header and list components
    var oldHeader = newBox.getElementsByTagName('h5')[0];
    var oldList = newBox.getElementsByTagName('ul')[0];
    if (!(oldHeader && oldList)) return;
 
    // Create the new header and list
    var newHeader = easyDom.h5(title);
    var newList = easyDom.ul();
 
    // Replace the header and list
    oldHeader.parentNode.replaceChild(newHeader, oldHeader);
    oldList.parentNode.replaceChild(newList, oldList);
 
    var parent = oldBox.parentNode;
    if (refId) {
        var refElement = toolbox.parentNode.getElementById(refId);
        if (refElement) {
            if (refMode && refMode == 'replace') {
                parent.replaceChild(newBox, refElement);
            } else {
                parent.insertBefore(newBox, refElement);
            }
        } else {
            parent.appendChild(newBox);
        }
    } else {
        parent.appendChild(newBox);
    }
 
    return newList;
}
 
function addToggleNavbox(id, title, closed, refId, refMode) {
    with (easyDom) {
        var toggle = a({ "href": "#" }, "+/-");
        var toggleTitle = span(title, ' ', toggle);
    }
    var list = addNavbox(id, toggleTitle, refId, refMode);
 
    if (!list.parentNode.style.maxHeight) {
        list.parentNode.style.maxHeight = "15em";
    }
 
    var overflowProperty = list.parentNode.style.overflowX
        ? "overflowX" : "overflow";
    var origDisplay = list.style.display;
    var origOverflow = list.parentNode.style[overflowProperty];
    var toggleListDisplay = function (closed) {
        if (typeof closed != typeof false) {
            closed = list.style.display == origDisplay;
        }
        var newDisplay;
        var newOverflow; 
        if (!closed) {
            newDisplay = origDisplay;
            newOverflow = 'scroll';
        } else {
            newDisplay = 'none';
            newOverflow = origOverflow;
        }
 
        list.style.display = newDisplay;
        list.parentNode.style[overflowProperty] = newOverflow;
 
        return false;
    };
    toggle.onclick = toggleListDisplay;
    toggleListDisplay(closed);
 
    return list;
}
 
// </nowiki></pre>