Taz (обсуждение | вклад) (Новая страница: «/* Размещённый здесь код JavaScript будет загружаться пользователям при обращении к каждой ст...») |
Taz (обсуждение | вклад) |
||
Строка 1: | Строка 1: | ||
var tocImgHid = stylepath + '/common/images/Arr_r.png'; | var tocImgHid = stylepath + '/common/images/Arr_r.png'; | ||
var tocImgSho = stylepath + '/common/images/Arr_d.png'; | var tocImgSho = stylepath + '/common/images/Arr_d.png'; | ||
function tocTree() { | function tocTree() { | ||
appendCSS('a.toctogHidden img, a.toctogShown img, a.toctogNull img {width:12px;height:12px;} #toc li a {padding-right:3px;} a.toctogNull img {visibility:hidden;}'); | |||
var toc = document.getElementById('toc'); | var toc = document.getElementById('toc'); | ||
Строка 27: | Строка 26: | ||
} | } | ||
} | } | ||
if(wgNamespaceNumber != -1 && wgArticleId != 0) | if(wgNamespaceNumber != -1 && wgArticleId != 0) addOnloadHook(tocTree) | ||
function tocTreeToggle(id) { | function tocTreeToggle(id) { | ||
Строка 49: | Строка 47: | ||
} | } | ||
/* | /** Collapsible tables ********************************************************* | ||
* | * | ||
* Description: Allows tables to be collapsed, showing only the header. See | * Description: Allows tables to be collapsed, showing only the header. See | ||
* | * http://www.mediawiki.org/wiki/Manual:Collapsible_tables. | ||
* Maintainers: [[User:R. Koot]] | * Maintainers: [[en:User:R. Koot]] | ||
*/ | */ | ||
var autoCollapse = 2; | var autoCollapse = 2; | ||
var collapseCaption = 'hide'; | var collapseCaption = 'hide'; | ||
var expandCaption = 'show'; | var expandCaption = 'show'; | ||
function collapseTable( tableIndex ) { | |||
var Button = document.getElementById( 'collapseButton' + tableIndex ); | var Button = document.getElementById( 'collapseButton' + tableIndex ); | ||
var Table = document.getElementById( 'collapsibleTable' + tableIndex ); | var Table = document.getElementById( 'collapsibleTable' + tableIndex ); | ||
if ( !Table || !Button ) { | if ( !Table || !Button ) { | ||
return false; | return false; | ||
} | } | ||
var Rows = Table.rows; | var Rows = Table.rows; | ||
if ( Button.firstChild.data == collapseCaption ) { | |||
if ( Button.firstChild.data | for ( var i = 1; i < Rows.length; i++ ) { | ||
for ( i = 1; i < Rows.length; i++ ) { | |||
Rows[i].style.display = 'none'; | Rows[i].style.display = 'none'; | ||
} | } | ||
Button.firstChild.data = expandCaption; | Button.firstChild.data = expandCaption; | ||
} else { | } else { | ||
for ( i = 1; i < Rows.length; i++ ) { | for ( var i = 1; i < Rows.length; i++ ) { | ||
Rows[i].style.display = Rows[0].style.display; | Rows[i].style.display = Rows[0].style.display; | ||
} | } | ||
Button.firstChild.data = collapseCaption; | Button.firstChild.data = collapseCaption; | ||
} | } | ||
} | return false; | ||
} | |||
function createCollapseButtons() { | function createCollapseButtons() { | ||
var tableIndex = 0; | var tableIndex = 0; | ||
var NavigationBoxes = | var NavigationBoxes = new Object(); | ||
var Tables = document.getElementsByTagName( 'table' ); | var Tables = document.getElementsByTagName( 'table' ); | ||
for ( var i = 0; i < Tables.length; i++ ) { | |||
if ( hasClass( Tables[i], 'collapsible' ) ) { | |||
for ( i = 0; i < Tables.length; i++ ) { | |||
if ( | |||
/* only add button and increment count if there is a header row to work with */ | /* only add button and increment count if there is a header row to work with */ | ||
var HeaderRow = Tables[i].getElementsByTagName( 'tr' )[0]; | var HeaderRow = Tables[i].getElementsByTagName( 'tr' )[0]; | ||
if ( !HeaderRow ) continue; | if ( !HeaderRow ) { | ||
continue; | |||
} | |||
var Header = HeaderRow.getElementsByTagName( 'th' )[0]; | var Header = HeaderRow.getElementsByTagName( 'th' )[0]; | ||
if ( !Header ) continue; | if ( !Header ) { | ||
continue; | |||
NavigationBoxes[ tableIndex ] = Tables[i]; | } | ||
NavigationBoxes[tableIndex] = Tables[i]; | |||
Tables[i].setAttribute( 'id', 'collapsibleTable' + tableIndex ); | Tables[i].setAttribute( 'id', 'collapsibleTable' + tableIndex ); | ||
var Button | var Button = document.createElement( 'span' ); | ||
var ButtonLink = document.createElement( 'a' ); | var ButtonLink = document.createElement( 'a' ); | ||
var ButtonText = document.createTextNode( collapseCaption ); | var ButtonText = document.createTextNode( collapseCaption ); | ||
Button.className = 'collapseButton'; | Button.className = 'collapseButton'; // Styles are declared in [[MediaWiki:Common.css]] | ||
ButtonLink.style.color = Header.style.color; | ButtonLink.style.color = Header.style.color; | ||
ButtonLink.setAttribute( 'id', 'collapseButton' + tableIndex ); | ButtonLink.setAttribute( 'id', 'collapseButton' + tableIndex ); | ||
ButtonLink.setAttribute( 'href', '#' ); | ButtonLink.setAttribute( 'href', '#collapsibleTable'+tableIndex ); | ||
addHandler( ButtonLink, 'click', new Function( 'evt', 'collapseTable(' + tableIndex + ' ); return killEvt( evt );' ) ); | |||
ButtonLink.appendChild( ButtonText ); | ButtonLink.appendChild( ButtonText ); | ||
Button.appendChild( document.createTextNode( '[' ) ); | Button.appendChild( document.createTextNode( '[' ) ); | ||
Button.appendChild( ButtonLink ); | Button.appendChild( ButtonLink ); | ||
Button.appendChild( document.createTextNode( ']' ) ); | Button.appendChild( document.createTextNode( ']' ) ); | ||
Header.insertBefore( Button, Header. | Header.insertBefore( Button, Header.childNodes[0] ); | ||
tableIndex++; | tableIndex++; | ||
} | } | ||
} | } | ||
for ( i = 0; i < tableIndex; i++ ) { | for ( var i = 0; i < tableIndex; i++ ) { | ||
if ( | if ( hasClass( NavigationBoxes[i], 'collapsed' ) || ( tableIndex >= autoCollapse && hasClass( NavigationBoxes[i], 'autocollapse' ) ) ) { | ||
collapseTable( i ); | |||
} | } else if ( hasClass( NavigationBoxes[i], 'innercollapse' ) ) { | ||
var element = NavigationBoxes[i]; | var element = NavigationBoxes[i]; | ||
while | while ( element = element.parentNode ) { | ||
if ( | if ( hasClass( element, 'outercollapse' ) ) { | ||
collapseTable( i ); | |||
break; | break; | ||
} | } | ||
Строка 144: | Строка 138: | ||
} | } | ||
} | } | ||
addOnloadHook( createCollapseButtons ); | |||
/** Test if an element has a certain class ************************************** | /** Test if an element has a certain class ************************************** | ||
Строка 159: | Строка 153: | ||
}; | }; | ||
})(); | })(); | ||
// Navi Copy JQuery Code by Kaddy! | // Navi Copy JQuery Code by Kaddy! | ||
Строка 245: | Строка 163: | ||
var x = $(element).children().get(1).innerHTML; | var x = $(element).children().get(1).innerHTML; | ||
var y = $(element).children().get(2).innerHTML; | var y = $(element).children().get(2).innerHTML; | ||
var newhtml = "<div class=\"navi-copy-text | var newhtml = "<div class=\"navi-copy-text\" onclick=\"CopyNaviLink(this, '"+map+"','"+x+"','"+y+"');\">("+map+" "+x+", "+y+")</div><div class=\"navi-copied\" style=\"display:none;\">Copied!</div>"; | ||
$(element).html(newhtml); | |||
}); | }); | ||
function CopyNaviLink(ele, map, x, y) { | function CopyNaviLink(ele, map, x, y) { |
Версия 08:54, 8 августа 2021
var tocImgHid = stylepath + '/common/images/Arr_r.png';
var tocImgSho = stylepath + '/common/images/Arr_d.png';
function tocTree() {
appendCSS('a.toctogHidden img, a.toctogShown img, a.toctogNull img {width:12px;height:12px;} #toc li a {padding-right:3px;} a.toctogNull img {visibility:hidden;}');
var toc = document.getElementById('toc');
if(!toc) return
var li = toc.getElementsByTagName('li');
for(var i=0;i<li.length;i++) {
var cul = li[i].getElementsByTagName('ul');
var a = document.createElement('a');
if(cul.length == 0) {
a.setAttribute('class','toctogNull');
} else {
a.setAttribute('class','toctogShown');
a.setAttribute('id','toctog-a-' + i );
a.setAttribute('href','javascript:tocTreeToggle("' + i + '");');
}
var img = document.createElement('img');
img.setAttribute('src',tocImgHid);
img.setAttribute('id','toctog-i-' + i );
a.appendChild(img);
li[i].insertBefore(a,li[i].firstChild);
if(cul.length != 0) tocTreeToggle(i)
}
}
if(wgNamespaceNumber != -1 && wgArticleId != 0) addOnloadHook(tocTree)
function tocTreeToggle(id) {
var a = document.getElementById('toctog-a-' + id);
var img = document.getElementById('toctog-i-' + id);
var cul = a.parentNode.getElementsByTagName('ul');
var disp;
if(a.getAttribute('class') == 'toctogShown') {
disp = 'none';
a.setAttribute('class','toctogHidden');
img.setAttribute('src',tocImgHid);
} else {
disp = 'block';
a.setAttribute('class','toctogShown');
img.setAttribute('src',tocImgSho);
}
for(var j=0;j<cul.length;j++) {
if(cul[j].parentNode == a.parentNode) cul[j].style.display = disp
}
}
/** 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 = 'hide';
var expandCaption = 'show';
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;
}
return false;
}
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', '#collapsibleTable'+tableIndex );
addHandler( ButtonLink, 'click', new Function( 'evt', 'collapseTable(' + tableIndex + ' ); return killEvt( evt );' ) );
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 );
};
})();
// Navi Copy JQuery Code by Kaddy!
$('.navi-copy').each(function(index, element) {
if ($("#navi-copy-textarea").attr('exists') != "true") {
txtdiv = '<textarea style="height:1px;width:1px; position:absolute;left:-1000px;" id="navi-copy-textarea" exists="true">Filler Text</textarea><style>.navi-copy-text { cursor:pointer; color:#2899e8; padding:1px; display:inline-block; } .navi-copy-text:hover { color:#c1a1f1; } .navi-copied { text-align:center; border:1px dotted #2899e8; border-radius:3px; color:#2899e8; display:inline-block; } .navi-copy { display:inline-block; } </style>';
$("body").append(txtdiv);
}
var map = $(element).children().get(0).innerHTML;
var x = $(element).children().get(1).innerHTML;
var y = $(element).children().get(2).innerHTML;
var newhtml = "<div class=\"navi-copy-text\" onclick=\"CopyNaviLink(this, '"+map+"','"+x+"','"+y+"');\">("+map+" "+x+", "+y+")</div><div class=\"navi-copied\" style=\"display:none;\">Copied!</div>";
$(element).html(newhtml);
});
function CopyNaviLink(ele, map, x, y) {
element = $(ele);
sibling = element.siblings();
width = element.width();
height = element.height()+0;
sibling.css('width',width);
sibling.css('height',height);
element.css('display','none');
sibling.css('display','inline-block');
setTimeout(function() {
sibling.fadeOut().delay(300).css('display','none');
element.css('display','inline-block');
}, 1400);
var ClipBoardText = "/navi "+map+" "+x+"/"+y;
var textarea = document.getElementById('navi-copy-textarea');
$('#navi-copy-textarea').text(ClipBoardText);
$("#navi-copy-textarea").select();
document.execCommand('copy');
}