Difference between revisions of "MediaWiki:Common.js"

From Future Of Mankind
Line 1: Line 1:
/* Any JavaScript here will be loaded for all users on every page load. */
 
 
//collapsible table column test, based on: https://codepen.io/feger/pen/eDybC
 
$(".btnHideEnglish").click(function() {
 
  console.log ('Hiding first column of table with an id of report');
 
  $( "table#collapsible_report > tbody:last-child > tr > th:first-child" ).toggle();
 
  $( "table#collapsible_report > tbody:last-child > tr > td:first-child" ).toggle();
 
  if ($(this).text() == "Hide English") {
 
    $(this).text("Show English");
 
    $("table#collapsible_report").css({"width": "80%", "margin": "0 auto"});
 
  } else {
 
    $(this).text("Hide English");
 
    $("table#collapsible_report").css({"width": "", "border-spacing": "1.5em 0", "margin": "0 -1.5em"});
 
  }
 
});
 
 
$(".btnHideHigh-German").click(function() {
 
  console.log ('Hiding second column of table with an id of report');
 
  $("table#collapsible_report > tbody:last-child > tr > th:last-child").toggle();
 
  $("table#collapsible_report > tbody:last-child > tr > td:last-child").toggle();
 
  if ($(this).text() == "Hide High German") {
 
    $(this).text("Show High German");
 
    $("table#collapsible_report").css({"width": "80%", "margin": "0 auto"});
 
  } else {
 
    $(this).text("Hide High German");
 
    $("table#collapsible_report").css({"width": "", "border-spacing": "1.5em 0", "margin": "0 -1.5em"});
 
  }
 
});
 
 
$(".btnHideGerman").click(function() {
 
  console.log ('Hiding second column of table with an id of report');
 
  $("table#collapsible_report > tbody:last-child > tr > th:last-child").toggle();
 
  $("table#collapsible_report > tbody:last-child > tr > td:last-child").toggle();
 
  if ($(this).text() == "Hide German") {
 
    $(this).text("Show German");
 
    $("table#collapsible_report").css({"width": "80%", "margin": "0 auto"});
 
  } else {
 
    $(this).text("Hide German");
 
    $("table#collapsible_report").css({"width": "", "border-spacing": "1.5em 0", "margin": "0 -1.5em"});
 
  }
 
});
 
 
// hide the german by default, on page load, but only if the btnHideGerman element exists on the page
 
if (document.getElementById("btnHideGerman")) {
 
  console.log('btnHideGerman exists');
 
  //$("#btnHideGerman").click();
 
} else {
 
  // do stuff
 
  console.log('btnHideGerman does not exist');
 
}
 
 
 
 
 
$(document).ready(function() {
 
$(document).ready(function() {
   var term = '<span class="footnote">Jschwjsch</span>';
+
   var term = 'Jschwjsch';
 
   var footnoteContent = 'The term is applied only to men and means King of Wisdom.';
 
   var footnoteContent = 'The term is applied only to men and means King of Wisdom.';
  
Line 59: Line 6:
 
     var text = $(this).html();
 
     var text = $(this).html();
 
     var regex = new RegExp('\\b' + term + '\\b', 'g');
 
     var regex = new RegExp('\\b' + term + '\\b', 'g');
     var newText = text.replace(regex, '<span class="footnote">' + term + '</span>');
+
     var newText = text.replace(regex, '<span class="footnote">' + term + '<div class="footnote-content">' + footnoteContent + '</div></span>');
  
 
     $(this).html(newText);
 
     $(this).html(newText);
 
   });
 
   });
  
   $('.footnote').hover(function() {
+
   $(".btnHideEnglish").click(function() {
     $(this).attr('title', footnoteContent);
+
    console.log('Hiding first column of table with an id of report');
 +
    $("table#collapsible_report > tbody:last-child > tr > th:first-child").toggle();
 +
    $("table#collapsible_report > tbody:last-child > tr > td:first-child").toggle();
 +
    if ($(this).text() == "Hide English") {
 +
      $(this).text("Show English");
 +
      $("table#collapsible_report").css({"width": "80%", "margin": "0 auto"});
 +
     } else {
 +
      $(this).text("Hide English");
 +
      $("table#collapsible_report").css({"width": "", "border-spacing": "1.5em 0", "margin": "0 -1.5em"});
 +
    }
 
   });
 
   });
});
 
  
 +
  $(".btnHideHigh-German").click(function() {
 +
    console.log('Hiding second column of table with an id of report');
 +
    $("table#collapsible_report > tbody:last-child > tr > th:last-child").toggle();
 +
    $("table#collapsible_report > tbody:last-child > tr > td:last-child").toggle();
 +
    if ($(this).text() == "Hide High German") {
 +
      $(this).text("Show High German");
 +
      $("table#collapsible_report").css({"width": "80%", "margin": "0 auto"});
 +
    } else {
 +
      $(this).text("Hide High German");
 +
      $("table#collapsible_report").css({"width": "", "border-spacing": "1.5em 0", "margin": "0 -1.5em"});
 +
    }
 +
  });
  
$(document).ready(function() {
+
  $(".btnHideGerman").click(function() {
  var term = 'Jschwjsch';
+
    console.log('Hiding second column of table with an id of report');
  var footnoteContent = 'The term is applied only to men and means King of Wisdom.';
+
    $("table#collapsible_report > tbody:last-child > tr > th:last-child").toggle();
 +
    $("table#collapsible_report > tbody:last-child > tr > td:last-child").toggle();
 +
    if ($(this).text() == "Hide German") {
 +
      $(this).text("Show German");
 +
      $("table#collapsible_report").css({"width": "80%", "margin": "0 auto"});
 +
    } else {
 +
      $(this).text("Hide German");
 +
      $("table#collapsible_report").css({"width": "", "border-spacing": "1.5em 0", "margin": "0 -1.5em"});
 +
    }
 +
  });
  
   $('body').each(function() {
+
   // hide the german by default, on page load, but only if the btnHideGerman element exists on the page
     var text = $(this).html();
+
  if (document.getElementById("btnHideGerman")) {
    var regex = new RegExp('\\b' + term + '\\b', 'g');
+
     console.log('btnHideGerman exists');
     var newText = text.replace(regex, '<span class="footnote">' + term + '<div class="footnote-content">' + footnoteContent + '</div></span>');
+
     //$("#btnHideGerman").click();
 
+
  } else {
     $(this).html(newText);
+
    // do stuff
   });
+
     console.log('btnHideGerman does not exist');
 +
   }
 
});
 
});

Revision as of 07:08, 10 October 2023

$(document).ready(function() {
  var term = 'Jschwjsch';
  var footnoteContent = 'The term is applied only to men and means King of Wisdom.';

  $('body').each(function() {
    var text = $(this).html();
    var regex = new RegExp('\\b' + term + '\\b', 'g');
    var newText = text.replace(regex, '<span class="footnote">' + term + '<div class="footnote-content">' + footnoteContent + '</div></span>');

    $(this).html(newText);
  });

  $(".btnHideEnglish").click(function() {
    console.log('Hiding first column of table with an id of report');
    $("table#collapsible_report > tbody:last-child > tr > th:first-child").toggle();
    $("table#collapsible_report > tbody:last-child > tr > td:first-child").toggle();
    if ($(this).text() == "Hide English") {
      $(this).text("Show English");
      $("table#collapsible_report").css({"width": "80%", "margin": "0 auto"});
    } else {
      $(this).text("Hide English");
      $("table#collapsible_report").css({"width": "", "border-spacing": "1.5em 0", "margin": "0 -1.5em"});
    }
  });

  $(".btnHideHigh-German").click(function() {
    console.log('Hiding second column of table with an id of report');
    $("table#collapsible_report > tbody:last-child > tr > th:last-child").toggle();
    $("table#collapsible_report > tbody:last-child > tr > td:last-child").toggle();
    if ($(this).text() == "Hide High German") {
      $(this).text("Show High German");
      $("table#collapsible_report").css({"width": "80%", "margin": "0 auto"});
    } else {
      $(this).text("Hide High German");
      $("table#collapsible_report").css({"width": "", "border-spacing": "1.5em 0", "margin": "0 -1.5em"});
    }
  });

  $(".btnHideGerman").click(function() {
    console.log('Hiding second column of table with an id of report');
    $("table#collapsible_report > tbody:last-child > tr > th:last-child").toggle();
    $("table#collapsible_report > tbody:last-child > tr > td:last-child").toggle();
    if ($(this).text() == "Hide German") {
      $(this).text("Show German");
      $("table#collapsible_report").css({"width": "80%", "margin": "0 auto"});
    } else {
      $(this).text("Hide German");
      $("table#collapsible_report").css({"width": "", "border-spacing": "1.5em 0", "margin": "0 -1.5em"});
    }
  });

  // hide the german by default, on page load, but only if the btnHideGerman element exists on the page
  if (document.getElementById("btnHideGerman")) {
    console.log('btnHideGerman exists');
    //$("#btnHideGerman").click();
  } else {
    // do stuff
    console.log('btnHideGerman does not exist');
  }
});