MediaWiki:Common.js

From Weegeepie Wiki
Revision as of 19:26, 10 December 2024 by Weegeepie (talk | contribs)
Jump to navigation Jump to search

Note: After publishing, you may have to bypass your browser's cache to see the changes.

  • Firefox / Safari: Hold Shift while clicking Reload, or press either Ctrl-F5 or Ctrl-R (⌘-R on a Mac)
  • Google Chrome: Press Ctrl-Shift-R (⌘-Shift-R on a Mac)
  • Internet Explorer / Edge: Hold Ctrl while clicking Refresh, or press Ctrl-F5
  • Opera: Press Ctrl-F5.
/* Any JavaScript here will be loaded for all users on every page load. */

setTimeout(500);

function isMobile() {
return /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent);
}

if (!isMobile()) {

/* Taken from MD wiki lol */
$(document).ready(function() {
    // YouTube API configuration
    var apiKey = 'AIzaSyA4iL2YEMH7m1vNZPkAhCKpPcEd-A0VIA4'; // Replace with your YouTube Data API key
    var channelId = 'UChratm8_g--6XGqSAz7KF8g'; // Replace with your channel's ID
    var apiURL = 'https://www.googleapis.com/youtube/v3/search?key=' + apiKey + '&channelId=' + channelId + '&part=snippet,id&order=date&maxResults=1';

    // Fetch the latest video
    $.getJSON(apiURL, function(data) {
        if (data.items && data.items.length > 0) {
            var videoId = data.items[0].id.videoId;
            var videoUrl = 'https://www.youtube.com/watch?v=' + videoId + '&t=0s';

            // Append the link dynamically
            $('#ca-talk').append(
                $('<a/>')
                    .addClass('hover-community-header-wrapper')
                    .append($('<div/>')
                        .addClass('wgp-ep-msg')
                        .text('Click here to view the latest episode!')
                    )
                    .attr('href', videoUrl)
            );
        } else {
            console.error('No videos found for the channel.');
        }
    }).fail(function(jqXHR, textStatus, errorThrown) {
        console.error('YouTube API request failed:', textStatus, errorThrown);
    });
});


}

var toc, toggleLink;
try {
  toc = document.getElementById('toc').getElementsByTagName('ul')[0];
  toggleLink = document.getElementById('toctogglecheckbox');
  // if (tocIsHidden()) {
  toggleToc();
  // }
} catch (error) {
  console.log('erred', error);
}
function tocIsHidden () {
    return !toc || !toggleLink || window.getComputedStyle(toc).display !== 'block';
}

function toggleToc() {
  var hidden = tocIsHidden();
  if (hidden && document.cookie.indexOf('hidetoc=0') > -1) {
    toggleLink.click();
    // changeText(toggleLink, tocShowText);
    // toc.style.display = 'none';
  } else if (!hidden && document.cookie.indexOf('hidetoc=1') > -1) {
    toggleLink.click();
    // changeText(toggleLink, tocHideText);
    // toc.style.display = 'block';
  }
}
toggleLink && toggleLink.addEventListener('click', function () {
  var isHidden = tocIsHidden();
  document.cookie = isHidden
    ? "hidetoc=1"
    : "hidetoc=0";
});