Youtube removes clickbait from thumbnails

Removes clickbait from thumbnails changing to start/middle/end thumb of video

이 스크립트를 설치하려면 Tampermonkey, Greasemonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

You will need to install an extension such as Tampermonkey to install this script.

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Userscripts와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 유저 스크립트 관리자 확장 프로그램이 필요합니다.

(이미 유저 스크립트 관리자가 설치되어 있습니다. 설치를 진행합니다!)

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

(이미 유저 스타일 관리자가 설치되어 있습니다. 설치를 진행합니다!)

// ==UserScript==
// @name            	Youtube removes clickbait from thumbnails
// @namespace       	https://greasyfork.org/users/821661
// @match           	https://www.youtube.com/*
// @grant           	GM_registerMenuCommand
// @grant           	GM_setValue
// @grant           	GM_getValue
// @version         	0.2
// @author          	hdyzen
// @description     	Removes clickbait from thumbnails changing to start/middle/end thumb of video
// @license         	MIT
// ==/UserScript==
'use strict';

const optionsMenu = {
    start: 'hq1',
    middle: 'hq2',
    end: 'hq3',
    default: 'hqdefault',
};

let optionSelected = GM_getValue('optionSelected', optionsMenu['start']);

const regexThumbName = /(?<=\/)hq.*(?=\.)/;

function createMenu() {
    Object.keys(optionsMenu).forEach(id => {
        let optionAtual = optionsMenu[id];
        GM_registerMenuCommand(
            `${optionAtual === optionSelected ? '[⬤]' : '[◯]'} Use thumbnail from ${id}`,
            e => {
                GM_setValue('optionSelected', optionAtual);
                optionSelected = optionAtual;
                createMenu();
                changeThumbsAfter();
            },
            { autoClose: false, id: optionAtual },
        );
    });
}

function changeThumbsAfter() {
    const thumbs = document.querySelectorAll('a#thumbnail > .ytd-thumbnail > img[src]');
    thumbs.forEach(thumb => {
        thumb.src = thumb.src.replace(regexThumbName, optionSelected);
    });
}

function changeThumbsOnInit() {
    document.addEventListener('image-loaded', e => {
        if (!e.target.src.includes(`${optionSelected}.`)) {
            e.target.src = e.target.src.replace(regexThumbName, optionSelected);
        }
    });
}

createMenu();
changeThumbsOnInit();