Difference between revisions of "MediaWiki:Common.js"

(More work on pinyin table collapsing columns)
m (Fixes for pinyin table collapsing)
Line 26: Line 26:
 
     $('th.col-a, th.col-e, th.col-o, th.col-i, th.col-u, th.col-v').hover( function() {
 
     $('th.col-a, th.col-e, th.col-o, th.col-i, th.col-u, th.col-v').hover( function() {
 
         var thClass = 'col' + $(this).attr('id').substr(0,2);
 
         var thClass = 'col' + $(this).attr('id').substr(0,2);
         thClass = thClass.replace('ü','v');
+
         console.log(thClass);
 +
        if (thClass.indexOf('ü')!==-1) { thClass='col-v'; };
 +
        console.log(thClass);
 
         $('th.'+thClass).addClass('table-selected');
 
         $('th.'+thClass).addClass('table-selected');
 
     }, function() {
 
     }, function() {
Line 32: Line 34:
 
     }).click( function() {
 
     }).click( function() {
 
         var thClass = 'col' + $(this).attr('id').substr(0,2);
 
         var thClass = 'col' + $(this).attr('id').substr(0,2);
         thClass = thClass.replace('ü','v');
+
         if (thClass.indexOf('ü')!==-1) { thClass='col-v'; };
 
         $('#pinyin-table .'+thClass).css('display','none');
 
         $('#pinyin-table .'+thClass).css('display','none');
         if ($(this).hasClass('table-placeholder')) {
+
         if ($(this).hasClass('col-placeholder')) {
             $('#pinyin-table .'+thClass+' :not(.table-placeholder)').css('display','initial');
+
             $('#pinyin-table .'+thClass+' :not(.col-placeholder)').css('display','initial');
 
         } else {
 
         } else {
             $('#pinyin-table .'+thClass+'.table-placeholder').css('display','initial');
+
             $('#pinyin-table .'+thClass+'.col-placeholder').css('display','initial');
 
         };
 
         };
 
     });
 
     });

Revision as of 08:42, 9 January 2015

/* Any JavaScript here will be loaded for all users on every page load. */

/*pinyin table scripts*/
$(document).ready( function() {

    $('#table-settings').append('<p>Show IPA <input type="checkbox" id="table-toggle-ipa"/> Show zhuyin <input type="checkbox" id="table-toggle-zhuyin"/> Show Wade-Giles <input type="checkbox" id="table-toggle-wade-giles"/></p>');

    $('.table-ipa').hide();
    $('.table-zhuyin').hide();
    $('.table-wade-giles').hide();
    $('.col-placeholder').hide();

    //highlight row and col of hovered cell
    $('#pinyin-table td').hover( function() {
        if ($(this).children('div.table-pinyin').length) {
            $(this).addClass('table-highlight');
            $(this).siblings().addClass('table-highlight');
            var rowIndex = $(this).prevAll().length+1;
            $('#pinyin-table tr :nth-child('+rowIndex+')').addClass('table-highlight');
        };
    }, function() {
        $('.table-highlight').removeClass('table-highlight');
    });

    //collapse column groups
    $('th.col-a, th.col-e, th.col-o, th.col-i, th.col-u, th.col-v').hover( function() {
        var thClass = 'col' + $(this).attr('id').substr(0,2);
        console.log(thClass);
        if (thClass.indexOf('ü')!==-1) { thClass='col-v'; };
        console.log(thClass);
        $('th.'+thClass).addClass('table-selected');
    }, function() {
        $('.table-selected').removeClass('table-selected');
    }).click( function() {
        var thClass = 'col' + $(this).attr('id').substr(0,2);
        if (thClass.indexOf('ü')!==-1) { thClass='col-v'; };
        $('#pinyin-table .'+thClass).css('display','none');
        if ($(this).hasClass('col-placeholder')) {
            $('#pinyin-table .'+thClass+' :not(.col-placeholder)').css('display','initial');
        } else {
            $('#pinyin-table .'+thClass+'.col-placeholder').css('display','initial');
        };
    });

    //toggle showing ipa, zhuyin, wade-giles
    $('#table-toggle-ipa').click( function() {
        if ($(this).prop('checked')) {
            $('.table-ipa').show();
        } else {
            $('.table-ipa').hide();
        };
    });
    $('#table-toggle-zhuyin').click( function() {
        if ($(this).prop('checked')) {
            $('.table-zhuyin').show();
        } else {
            $('.table-zhuyin').hide();
        };
    });
    $('#table-toggle-wade-giles').click( function() {
        if ($(this).prop('checked')) {
            $('.table-wade-giles').show();
        } else {
            $('.table-wade-giles').hide();
        };
    });
});