youtube video progressbar outline & color replacement
// ==UserScript==
// @name YouTube restyle
// @namespace http://tampermonkey.net/
// @version 1.0
// @description youtube video progressbar outline & color replacement
// @author Roman Sergeev aka naxombl4 aka Brutal Doomer
// @match https://www.youtube.com/*
// @grant GM_addStyle
// @license MIT
// ==/UserScript==
/**
* v1.0 added comments, added --vars, removed timeout function changing svg path fill
* added surveyLoadProgresses from another script
* added replacer of YT logos
* v0.1 original script
*/
(function() {
'use strict';
// replace youtube logo on the browser tab with image of corresponding color (changing the theme, you have to upload your own)
document.getElementsByTagName('link')[1].setAttribute("href", "https://dl.dropboxusercontent.com/s/9avoipkut6ydydu/32.png");
document.getElementsByTagName('link')[2].setAttribute("href", "https://dl.dropboxusercontent.com/s/8mujk3poo7nvxsm/48.png");
document.getElementsByTagName('link')[3].setAttribute("href", "https://dl.dropboxusercontent.com/s/5zrmlvm9uy1zran/96.png");
document.getElementsByTagName('link')[4].setAttribute("href", "https://dl.dropboxusercontent.com/s/6goosuv17qzvgit/144.png");
//var notificationImageSrc = "https://www.dropbox.com/scl/fi/uxal14y48igxdp02hy8n9/notification.png"; // dropbox has changed their storing method, yet old links still work. You can't modify links due to CORB policy, so...
// Here's the replacement image in Base64, size 64x64px. If you change the theme - change this as well
// Original image is at https://www.gstatic.com/images/branding/product/2x/youtube_96in128dp.png
var notificationImageSrc64 = "";
var colour = "#558",
darken = "#447",
bright = "#669",
prgbar = "#0f06",
prgend = "#0f0";
GM_addStyle(`
:root {
--colour: `+colour+`;
--darken: `+darken+`;
--bright: `+bright+`;
--prgbar: `+prgbar+`;
--prgend: `+prgend+`;
}
html[refresh],
[refresh] {
--yt-spec-static-brand-red: var(--colour);
--yt-spec-red-indicator: var(--colour);
}
span.mention.yt-live-chat-text-message-renderer {
background: var(--colour) !important; /* live chat mention background replacement (doesn't work) */
}
div.ytp-chapter-hover-container,
div.ytp-chapter-hover-container>div {
outline: none;
}
div.ytp-load-progress {
background-color: var(--prgbar);
}
div.ytp-load-progress div.progressBarAfter {
position: absolute;
height: 100%;
right: 0;
background-color: var(--prgend);
}
.ytp-hover-progress.ytp-hover-progress-light {
background-color: var(--prgbar);
}
div.ytp-swatch-background-color,
button.ytp-settings-button.ytp-hd-quality-badge::after {
background-color: var(--darken);
}
html:not(.style-scope)[dark], :not(.style-scope)[dark] {
--yt-spec-static-overlay-background-brand: var(--colour);
--yt-spec-brand-button-background: var(--darken);
--yt-spec-light-blue: var(--colour);
--yt-spec-call-to-action: var(--colour);
--yt-live-chat-mention-background-color: var(--colour);
}
sup.ytp-swatch-color {
color: var(--colour);
}
div.ytp-cairo-refresh-signature-moments .ytp-play-progress {
background: var(--colour);
}
span.badge-style-type-live-now.ytd-badge-supported-renderer {
--yt-spec-brand-link-text: var(--bright);
}
span.mention.style-scope.yt-live-chat-text-message-renderer,
.mention.yt-live-chat-text-message-renderer {
background: var(--colour) !important;
}
ytd-thumbnail-overlay-resume-playback-renderer[enable-refresh-signature-moments-web] #progress.ytd-thumbnail-overlay-resume-playback-renderer {
background: linear-gradient(to right, var(--darken) 80%, var(--colour) 100%);
}
span.mention.yt-live-chat-text-message-renderer {
background: none;
border: 2px solid var(--colour);
border-radius: 9px;
}
.guide-entry-badge.ytd-guide-entry-renderer {
--yt-spec-static-brand-red: #77a;
}
#newness-dot.ytd-guide-entry-renderer {
--yt-spec-themed-blue: var(--colour);
}
yt-icon#logo-icon svg>g:first-child>path:first-child {
fill: var(--colour);
}
svg>g>g.style-scope.ytd-topbar-logo-renderer>path {
fill: var(--colour);
}
div#title-container svg>path:first-child {
fill: var(--colour);
}
button.ytp-live-badge[disabled]:before {
background: var(--colour);
}
#progress.ytd-thumbnail-overlay-resume-playback-renderer {
--yt-spec-static-brand-red: var(--colour);
}
.ytp-menuitem[aria-checked="true"] .ytp-menuitem-toggle-checkbox {
background: var(--colour);
}
.badge-style-type-live-now.ytd-badge-supported-renderer {
--yt-spec-brand-link-text: var(--bright);
}
ytd-thumbnail-overlay-toggle-button-renderer[aria-label="Добавить в очередь"] {
display: none !important;
pointer-events: none !important;
}
.yt-spec-avatar-shape--cairo-refresh.yt-spec-avatar-shape--live-ring::after {
background: linear-gradient(to top right, var(--darken) 60%, var(--bright) 85%);
}
.yt-spec-avatar-shape--cairo-refresh .yt-spec-avatar-shape__live-badge {
background: var(--darken);
}
.yt-spec-icon-badge-shape--type-notification-refresh .yt-spec-icon-badge-shape__badge {
background: var(--darken);
}
/*#item-scroller path.style-scope.yt-icon {
fill: var(--colour);
}*/`);
// update marker position
function surveyLoadProgresses() {
var targets = Array.from(document.getElementsByClassName("ytp-load-progress"));
for (var i = 0; i < targets.length; i++) {
var target = targets[i];
if (target.children.length == 0) {
var div = document.createElement("div");
div.className = "progressBarAfter";
target.appendChild(div);
}
div = target.children[0];
var progress = /\d+(\.\d+)?/.exec(target.style.transform)[0];
div.style.width = (7 / progress) + "px"; // I don't remember why, but ok
if (progress == 0 || progress == 1 && i != targets.length - 1)
div.style.width = 0;
}
//console.log(targets.map(x => /\d+(\.\d+)?/.exec(x.style.transform)[0]).join(" "));
}
setInterval(surveyLoadProgresses, 1000);
var imagesFetched = 0;
function surveyYTImages() {
var list = document.querySelectorAll('[id=img]');
for (var i = imagesFetched; i < list.length; ++i)
if (list[i].src.startsWith("https://www.gstatic.com/images/branding/product/"))
list[i].src = notificationImageSrc64;
//imagesFetched = Math.max(imagesFetched, list.length); // sometimes is skipped
}
setInterval(surveyYTImages, 1000);
})();