|
|
Строка 7: |
Строка 7: |
| importScript('MediaWiki:Search.js') | | importScript('MediaWiki:Search.js') |
| | | |
− | /******************************************************************************************
| |
− | *
| |
− | * Сворачивающиеся блоки для шаблонов {{Навигационная таблица}}, {{Навигационная полоса}}
| |
− | * и для таблиц class="collapsible" (см. на [[Справка:Оформление таблиц]] пример).
| |
− | *
| |
− | * Код полностью переписал Mithgol the Webmaster на основе jQuery в начале августа 2009 г.
| |
− | *
| |
− | */
| |
− |
| |
− | var autoCollapse = 2;
| |
− | var collapseCaption = 'скрыть';
| |
− | var expandCaption = 'показать';
| |
− |
| |
− | function collapsibleTables(){
| |
− | var allTables = $('#content table.collapsible');
| |
− |
| |
− | allTables.each(function(tblIdx){
| |
− | var HRow = $('tr:first', this);
| |
− | if (HRow.length == 0){
| |
− | $(this).addClass('wontCollapse'); // no rows
| |
− | return true; // continue next iteration of each()
| |
− | }
| |
− | if (HRow.parent().children().filter('tr').not(':first').length == 0){
| |
− | $(this).addClass('wontCollapse'); // no rows after the first
| |
− | return true; // continue next iteration of each()
| |
− | }
| |
− |
| |
− | var Header = $('th:last', HRow);
| |
− | if (Header.length == 0){
| |
− | $(this).addClass('wontCollapse'); // no TH in the first row
| |
− | return true; // continue next iteration of each()
| |
− | }
| |
− |
| |
− | $(this).data('collapseIndex', tblIdx);
| |
− | Header.prepend(
| |
− | '<span style="float: right; font-weight: normal;">'+
| |
− | '[<a id="collapseButton' + tblIdx + '" href="#" onClick="collapseTable(this); return false;">'+
| |
− | collapseCaption + '</a>]</span>');
| |
− | });
| |
− |
| |
− | var processedTables = allTables.not('.wontCollapse');
| |
− | if (processedTables.length > autoCollapse){
| |
− | processedTables.filter('.autocollapse').each(function(i){
| |
− | var linkIDX = $(this).data('collapseIndex');
| |
− | collapseTable($('a#collapseButton' + linkIDX, this).eq(0));
| |
− | });
| |
− | }
| |
− | processedTables.filter('.collapsed').each(function(i){
| |
− | var linkIDX = $(this).data('collapseIndex');
| |
− | collapseTable($('a#collapseButton' + linkIDX, this).eq(0));
| |
− | });
| |
− | }
| |
− |
| |
− | function collapseTable(linkObject){ // accepts both raw and jQuery-wrapped objects
| |
− | var TheLink = $(linkObject);
| |
− | var TableRows = TheLink.closest('tr').parent().children().filter('tr').not(':first');
| |
− | if (TableRows.length == 0) return;
| |
− |
| |
− | var isShown = (TheLink.text() == collapseCaption);
| |
− | if (isShown) {
| |
− | TheLink.text(expandCaption);
| |
− | TableRows.each(function(i){
| |
− | $(this).fadeOut(1000);
| |
− | });
| |
− | } else {
| |
− | TheLink.text(collapseCaption);
| |
− | TableRows.each(function(i){
| |
− | $(this).fadeIn(1000);
| |
− | });
| |
− | };
| |
− | }
| |
− | addOnloadHook(collapsibleTables);
| |
− |
| |
− | var NavigationBarHide = '[' + collapseCaption + ']';
| |
− | var NavigationBarShow = '[' + expandCaption + ']';
| |
− | var NavigationBarShowDefault = autoCollapse;
| |
− |
| |
− | function collapsibleDivs(){
| |
− | var NavFrameList = $('#content div.NavFrame');
| |
− | NavFrameList.each(function(navIdx){
| |
− | var TheNavHead = $('.NavHead:first', this);
| |
− | if (TheNavHead.length == 0) {
| |
− | $(this).addClass('wontCollapse'); // no NavHead inside!
| |
− | return true; // continue next iteration of each()
| |
− | }
| |
− | $(this).data('NavFrameIndex', navIdx);
| |
− | TheNavHead.prepend('<a class="NavToggle" '+
| |
− | 'id="NavToggle' + navIdx + '" href="#" '+
| |
− | 'onClick="collapseDiv(this); return false;">'+
| |
− | NavigationBarHide + '</a>'
| |
− | );
| |
− | });
| |
− |
| |
− | var processedDivs = NavFrameList.not('.wontCollapse');
| |
− | if (processedDivs.length > NavigationBarShowDefault){
| |
− | processedDivs.not('.expanded').each(function(i){
| |
− | var linkIDX = $(this).data('NavFrameIndex');
| |
− | collapseDiv($('a#NavToggle' + linkIDX, this).eq(0));
| |
− | });
| |
− | }
| |
− | processedDivs.filter('.collapsed').each(function(i){
| |
− | var linkIDX = $(this).data('NavFrameIndex');
| |
− | collapseDiv($('a#NavToggle' + linkIDX, this).eq(0));
| |
− | });
| |
− | }
| |
− |
| |
− | function collapseDiv(toggleObject){ // accepts both raw and jQuery-wrapped objects
| |
− | var TheToggle = $(toggleObject);
| |
− | var TheFrame = TheToggle.closest('div.NavFrame');
| |
− | if (TheFrame.length == 0) return false;
| |
− |
| |
− | TheToggle.text( (TheToggle.text() == NavigationBarHide) ? NavigationBarShow : NavigationBarHide);
| |
− |
| |
− | TheFrame.children().filter('.NavPic, .NavContent').each(function(i){
| |
− | $(this).slideToggle(1000);
| |
− | });
| |
− | }
| |
− | addOnloadHook(collapsibleDivs);
| |
− |
| |
− |
| |
| //</source> | | //</source> |