YouTube Thumbnail Viewer

Adds a button to view the thumbnail of a YouTube video!

Per 10-03-2023. Zie de nieuwste versie.

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey, Greasemonkey of Violentmonkey.

Voor het installeren van scripts heb je een extensie nodig, zoals {tampermonkey_link:Tampermonkey}.

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey of Violentmonkey.

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey of Userscripts.

Voor het installeren van scripts heb je een extensie nodig, zoals {tampermonkey_link:Tampermonkey}.

Voor het installeren van scripts heb je een gebruikersscriptbeheerder nodig.

(Ik heb al een user script manager, laat me het downloaden!)

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

(Ik heb al een beheerder - laat me doorgaan met de installatie!)

// ==UserScript==
// @name         YouTube Thumbnail Viewer
// @namespace    https://www.youtube.com/
// @version      1.1
// @description  Adds a button to view the thumbnail of a YouTube video!
// @author       TrickyClock
// @match        https://www.youtube.com/*
// @license      MIT
// @grant        none
// ==/UserScript==

var showInDescription = true

function updateUrl(button) {
  // Get the video ID from the URL
  var videoId = window.location.href.split('v=')[1];
  var ampersandPosition = videoId.indexOf('&');
  if (ampersandPosition !== -1) {
    videoId = videoId.substring(0, ampersandPosition);
  }

  // Redirect to the thumbnail URL
  button.href = `https://i.ytimg.com/vi_webp/${videoId}/maxresdefault.webp`;
}

function addButton() {
  var element = document.getElementById('below');
  if (showInDescription)
    element = document.getElementById("description-inline-expander").getElementsByTagName("ytd-structured-description-content-renderer")[0]
  if (element) {
    // Update the element
    if (!showInDescription)
      element.style.marginTop = '-4px';

    // If the element exists, check if the button has already been added
    var viewThumbnailButton = document.getElementById('view-thumbnail-button');
    if (!viewThumbnailButton) {
      // If the button does not exist, create it
      viewThumbnailButton = document.createElement('a');
      viewThumbnailButton.innerHTML = 'View Thumbnail';
      viewThumbnailButton.style.textDecoration = 'none';
      viewThumbnailButton.style.display = 'inline-block';
      viewThumbnailButton.style.marginTop = showInDescription ? '10px' : '6px';
      viewThumbnailButton.style.marginBottom = '-2px';
      viewThumbnailButton.style.color = 'var(--yt-spec-text-primary)';
      viewThumbnailButton.style.backgroundColor = 'var(--yt-spec-badge-chip-background)';
      viewThumbnailButton.style.border = 'none';
      viewThumbnailButton.style.padding = '6px 8px';
      viewThumbnailButton.style.fontSize = '14px';
      viewThumbnailButton.style.borderRadius = '16px'; //'8px';
      viewThumbnailButton.id = 'view-thumbnail-button';

      element.parentNode.insertBefore(viewThumbnailButton, element);
    }

    updateUrl(viewThumbnailButton);
  }
}

setInterval(() => {
  addButton();
}, 1000);