MediaWiki:Common.js: различия между версиями

Материал из Ботвапедии
Перейти к: навигация, поиск
Строка 104: Строка 104:
 
         };
 
         };
 
})();
 
})();
 
var offsetfromcursorY=15 // y offset of tooltip
 
var ie=document.all && !window.opera;
 
var ns6=document.getElementById && !document.all;
 
var popup;
 
function Popup(el, title, img, text){
 
popup = document.getElementById('popup');
 
el.onmousemove = positiontip;
 
popup.style.display = 'block';
 
text = text.replace(/\[GOLD\]/g,  "<img alt='золото' src='/ico/ico_gold1.png' align='absmiddle' />");
 
text = text.replace(/\[GREEN\]/g,  "<img alt='зелень' src='/ico/ico_green1.png' align='absmiddle' />");
 
text = text.replace(/\[CRYST\]/g,  "<img alt='кристаллы' src='/ico/ico_krist1.png' align='absmiddle' />");
 
document.getElementById('popup_title').innerHTML = title;
 
document.getElementById('popup_img').innerHTML = "<img alt='"+title+"' src='/"+img+"' />";
 
document.getElementById('popup_body').innerHTML = text;
 
}
 
function HidePopup(el){
 
popup.style.display = 'none';
 
el.onmousemove = '';
 
}
 
function positiontip(e) {
 
var curX=(ns6)?e.pageX : event.clientX+ietruebody().scrollLeft;
 
var curY=(ns6)?e.pageY : event.clientY+ietruebody().scrollTop;
 
var winwidth=ie? ietruebody().clientWidth : window.innerWidth-20
 
var winheight=ie? ietruebody().clientHeight : window.innerHeight-20
 
 
var rightedge=ie? winwidth-event.clientX : winwidth-e.clientX;
 
var bottomedge=ie? winheight-event.clientY-offsetfromcursorY : winheight-e.clientY-offsetfromcursorY;
 
 
if (rightedge < popup.offsetWidth) popup.style.left=curX-popup.offsetWidth+"px";
 
else popup.style.left=curX+15+"px";
 
 
if (bottomedge < popup.offsetHeight) popup.style.top=curY-popup.offsetHeight-offsetfromcursorY+"px"
 
else popup.style.top=curY+offsetfromcursorY+15+"px";
 
 
}
 
function ietruebody(){
 
return (document.compatMode && document.compatMode!="BackCompat")? document.documentElement : document.body
 
}
 

Версия 00:45, 6 сентября 2012

/* Размещённый здесь JavaScript код будет загружаться всем пользователям при обращении к каждой странице */
/** Collapsible tables *********************************************************
 *
 *  Description: Allows tables to be collapsed, showing only the header. See
 *                         http://www.mediawiki.org/wiki/Manual:Collapsible_tables.
 *  Maintainers: [[en:User:R. Koot]]
 */
 
var autoCollapse = 2;
var collapseCaption = 'Скрыть';
var expandCaption = 'Показать';
 
function collapseTable( tableIndex ) {
        var Button = document.getElementById( 'collapseButton' + tableIndex );
        var Table = document.getElementById( 'collapsibleTable' + tableIndex );
 
        if ( !Table || !Button ) {
                return false;
        }
 
        var Rows = Table.rows;
 
        if ( Button.firstChild.data == collapseCaption ) {
                for ( var i = 1; i < Rows.length; i++ ) {
                        Rows[i].style.display = 'none';
                }
                Button.firstChild.data = expandCaption;
        } else {
                for ( var i = 1; i < Rows.length; i++ ) {
                        Rows[i].style.display = Rows[0].style.display;
                }
                Button.firstChild.data = collapseCaption;
        }
}
 
function createCollapseButtons() {
        var tableIndex = 0;
        var NavigationBoxes = new Object();
        var Tables = document.getElementsByTagName( 'table' );
 
        for ( var i = 0; i < Tables.length; i++ ) {
                if ( hasClass( Tables[i], 'collapsible' ) ) {
 
                        /* only add button and increment count if there is a header row to work with */
                        var HeaderRow = Tables[i].getElementsByTagName( 'tr' )[0];
                        if ( !HeaderRow ) {
                                continue;
                        }
                        var Header = HeaderRow.getElementsByTagName( 'th' )[0];
                        if ( !Header ) {
                                continue;
                        }
 
                        NavigationBoxes[tableIndex] = Tables[i];
                        Tables[i].setAttribute( 'id', 'collapsibleTable' + tableIndex );
 
                        var Button = document.createElement( 'span' );
                        var ButtonLink = document.createElement( 'a' );
                        var ButtonText = document.createTextNode( collapseCaption );
 
                        Button.className = 'collapseButton'; // Styles are declared in [[MediaWiki:Common.css]]
 
                        ButtonLink.style.color = Header.style.color;
                        ButtonLink.setAttribute( 'id', 'collapseButton' + tableIndex );
                        ButtonLink.setAttribute( 'href', "javascript:collapseTable(" + tableIndex + ");" );
                        ButtonLink.appendChild( ButtonText );
 
                        Button.appendChild( document.createTextNode( '[' ) );
                        Button.appendChild( ButtonLink );
                        Button.appendChild( document.createTextNode( ']' ) );
 
                        Header.insertBefore( Button, Header.childNodes[0] );
                        tableIndex++;
                }
        }
 
        for ( var i = 0;  i < tableIndex; i++ ) {
                if ( hasClass( NavigationBoxes[i], 'collapsed' ) || ( tableIndex >= autoCollapse && hasClass( NavigationBoxes[i], 'autocollapse' ) ) ) {
                        collapseTable( i );
                } else if ( hasClass( NavigationBoxes[i], 'innercollapse' ) ) {
                        var element = NavigationBoxes[i];
                        while ( element = element.parentNode ) {
                                if ( hasClass( element, 'outercollapse' ) ) {
                                        collapseTable( i );
                                        break;
                                }
                        }
                }
        }
}
 
addOnloadHook( createCollapseButtons );
 
/** Test if an element has a certain class **************************************
 *
 * Description: Uses regular expressions and caching for better performance.
 * Maintainers: [[User:Mike Dillon]], [[User:R. Koot]], [[User:SG]]
 */
 
var hasClass = ( function() {
        var reCache = {};
        return function( element, className ) {
                return ( reCache[className] ? reCache[className] : ( reCache[className] = new RegExp( "(?:\\s|^)" + className + "(?:\\s|$)" ) ) ).test( element.className );
        };
})();