- // ==UserScript==
- // @name [TS] Youtube Filter
- // @namespace TimidScript
- // @version 1.1.43
- // @description Filter out users and channels from search with GUI. Include Auto-Paging and ScreenShot Links.
- // @author TimidScript
- // @homepageURL https://github.com/TimidScript
- // @copyright © 2013+ TimidScript, Some Rights Reserved.
- // @license https://github.com/TimidScript/UserScripts/blob/master/license.txt
- // @include *//www.youtube.*
- // @exclude *//www.youtube.*/embed/*
- // @require https://greasyfork.org/scripts/19967/code/TSL - GM_update.js
- // @require https://greasyfork.org/scripts/19968/code/TSLibrary - Generic.js
- // @homeURL https://greasyfork.org/en/scripts/4687
- // @grant GM_xmlhttpRequest
- // @grant GM_info
- // @grant GM_getMetadata
- // @grant GM_getValue
- // @grant GM_setValue
- // @grant GM_deleteValue
- // @grant GM_registerMenuCommand
- // @icon 
- // ==/UserScript==
-
- /* License + Copyright Notice
- ********************************************************************************************
- License can be found at: https://github.com/TimidScript/UserScripts/blob/master/license.txt
- Below is a copy of the license the may not be up-to-date.
-
- Copyright © TimidScript, Some Rights Reserved.
-
- Redistribution and use in source and binary forms, with or without modification, are permitted provided that the
- following conditions are met:
-
- 1) GPL-3 License is met that does not conflict with the rest of the license (http://www.gnu.org/licenses/gpl-3.0.en.html)
- 2) This notice must be included
- 3) Due credits and link to original author's homepage (included in this notice).
- 4) Notify the original author of redistribution
- 5) Clear clarification of the License and Notice to the end user
- 6) Do not upload on OpenUserJS.org or any other site that infringes on this license
-
- TimidScript's Homepages: GitHub: https://github.com/TimidScript
- GreasyFork: https://greasyfork.org/users/1455
- */
- /* Information
- ********************************************************************************************
- Known Issues:
- - Support for paged front page is not implemented as it seems to cause infinite loop
- ----------------------------------------------
- Version History
- ----------------------------------------------
- 1.1.43 (2017-01-27)
- - Bugfix: Support other URLs
- 1.1.42 (2016-06-19)
- - Fix auto-paging
- 1.1.41 (2016-05-27)
- - Altered license
- 1.1.40 (2016-05-25)
- - Moving to GreasyFork and preparing to remove OUJS files
- 1.1.39 (2016-04-10)
- - updateURL added
- 1.1.38 (2016-04-03)
- - Changed license to GPL-3
- - A delay on load more videos added
- 1.1.37 (2015-11-20)
- - Load more videos permanent fix
- 1.1.36 (2015-10-05)
- - Larger delay on Load More Videos on video page
- 1.1.35 (2015-10-05)
- - Replaced base64 bmp icon with png version
- 1.1.34 (2015-09-12)
- - Make filter compatible with "Youtube Center"
- - Bug Fix: Corrections to changes made in Youtube video page syntax
- 1.1.33 (2015-08-18)
- - Bug Fix: Corrections to changes made in Youtube page syntax
- - Added fullscreen link
- - Removal of tags occurs on mouseover and mouseout
- 1.1.32 (2015-06-20)
- - Remove link tag on mouse down
- 1.1.31 (2015-06-19)
- - Added tag "?timidscript_youtube" to screenshot links.
- 1.1.30 (2015-04-25)
- - Bug Fix: Make it compatible with "Youtube Center" as it changes some of the classes script queries.
- 1.1.29 (2015-04-06)
- - Bug Fix: Removed monitor of search result
- - Bug Fix: Search results checks item count before parsing.
- 1.1.28 (2015-04-04)
- - Bug Fix: Now able to pickup changes in main page and by extension search result page.
- 1.1.27 (2015-01-18)
- - Bug fixes to changes in youtube layout (front page and user channel)
- - Bug fix filter button added to the side of video panel
- - Added script setting to change the icon size. Search for "VYCS" to get to the Section
- - Changed the scroll functionality
- - Generic Library added
- - Show all video setting is now stored
- 1.0.26 (2015-01-04)
- - Bug fix to front page due to changes in youtube
- 1.0.25 (2014-12-11)
- - Delay to handle delayed video recommendations
- 1.0.24 (2014-08-29)
- - Added GM_update
- 1.0.23 (2014-08-19)
- - Cleaned up header for OUJS
- 1.0.22 (2014-07-16)
- - @exclude iframe embed videos
- 1.0.21 (2014-07-15)
- - Added image link to channel videos
- - Added necessary @grant header
- - Altered the CSS
- - Remove MutationObserver from most page types
- 1.0.20 (2014-07-03)
- - Bug Fix: Fixed issues caused by change in youtube layout
- - Added option to turn off auto-paging
- - Removed img.youtube include
- 1.0.19 (2014-06-14)
- - Scrollable FilterWindow
- - Use port 8080 for require on userscripts.org
- 1.0.18 (2014-06-07)
- - Bug fix on pager when spelling correction is applied
- 1.0.17 (2014-05-31)
- - Updated so main page includes "Recommended" in the filter
- 1.0.16 (2014-05-30)
- - Modified CSS and link text
- 1.0.15 (2014-05-25)
- - Moved options button beside upload button if it exists.
- 1.0.14 (2014-05-21)
- - Bug Fix: Not checking for maxresdefault.jpg.
- 1.0.13 (2014-05-20)
- - Video screenshot link now points to "hqdefault.jpg" by default.
- Checks if "maxresdefault.jpg" and re-links if necessary
- 1.0.12 (2014-05-17)
- - Added link to max res screenshot
- 1.0.11 (2014-05-09)
- - Made options button invisible unless you hover over top, right corner.
- 1.0.10 (2014-03-28)
- - Updated broken script due to changes in youtube
- 1.0.9 (2014-01-16)
- - Bug not getting page type when type changes.
- 1.0.8 (2014-01-01)
- - Option button alternates filter window display
- 1.0.7b (2013-12-21)
- - Removed redundant code
- - Highlights blocked users and options buttonQ
- - Button now is an Icon
- - Bug fixes due to changes in Youtube
- - Captures changes in URL
- 1.0.6
- - Added block button on all thumbnails
- - Information stored now only contains the name of the user-channel and nothing else
- 1.0.5
- - Main X button now also removes filter
- 1.0.4
- - Colours added
- 1.0.3 (2013-10-16)
- - Extended the filter to work on main page
- 1.0.2 (2013-08-25)
- - Bug Fix: Filter observer added
- 1.0.1 (2013-08-24)
- - Initial Release
- ********************************************************************************************/
-
-
- /************** [VYCS] Variable you can set **************/
- //CSS Style for video page. It uses smaller text and icon for the block button and image link
- //GM_setValue("PageType2",".blockBox .blockBTN32 {width: 24px; height: 24px;} .blockBox a {font-size: 10px;}"
- // + "body #watch7-sidebar-contents {padding: 15px 0px 15px 5px !important;}"
- // + "#watch7-sidebar-contents .video-list-item.related-list-item {padding-right: 24px;}");
-
- //CSS Style that limites the size of the search list width, if increased by "Youtube Center"
- //GM_setValue("PageType1",".ytcenter-site-search .yt-card.clearfix{width: 700px !important;}");
- /**************************************************/
-
- ////if (window.self !== window.top) return;
- console.info("Youtube Filter");
- var intervalID;
- var AutoPaging = GM_getValue("AutoPaging", true);
- //0 Main Page; 1 Search Result; 2 Video Page; 3 Channel Video Page
- var PageTYPE = null; //Video Page
- var FilteredUsers = new Array();
-
- //*****************
- ///
- function IsMouseEventInClientArea(event, element)
- {
- var rect = element.getBoundingClientRect();
- var minX = rect.left + element.clientLeft;
-
- var x = event.clientX;
- if (x < minX || x >= minX + element.clientWidth) return false;
- var minY = rect.top + element.clientTop;
- var y = event.clientY;
- if (y < minY || y >= minY + element.clientHeight) return false;
- return true;
- }
-
- function GetPageType()
- {
- PageTYPE = null;
- if (document.URL.match(/\.youtube\.[^\/]+\/?$/i)) PageTYPE = 0; //Main Page
- else if (document.URL.match(/youtube\.[^\/]+\/result/gi)) PageTYPE = 1; //Search Result
- else if (document.URL.match(/youtube\.[^\/]+\/watch/gi)) PageTYPE = 2; //Video Page
- else if (document.URL.match(/youtube\.[^\/]+\/(user|channel\/)?.+\/videos/gi)) PageTYPE = 3; //User Channel
- }
-
- function GetUserData(link)
- {
- var user = new Object();
- user.name = link.textContent;
- user.url = link.href.replace(/.+youtube\.[a-z]+/, "");
-
- return user;
- }
-
- function IsFilteredUser(user)
- {
- var userFilters = GetFilters();
- for (var i = 0; i < userFilters.length; i++)
- {
- if (userFilters[i] == user) return true;
- }
-
- return false;
- }
-
- function BlockUser(e)
- {
- e.stopImmediatePropagation();
- e.preventDefault();
- var user = this.title;
-
- if (!IsFilteredUser(user))
- {
- var filters = GetFilters();
- filters.push(user);
- GM_setValue("Filters", JSON.stringify(filters));
- }
-
- HideUnwantedUsers();
- if (document.getElementById("FilterWindow")) CreateFilterWindow();
- return false;
- }
-
-
- function CreateScreenshotLink(videoID)
- {
- var ss = document.createElement("a");
- ss.textContent = "[SH]";
- ss.href = "https://img.youtube.com/vi/" + videoID + "/hqdefault.jpg?timidscript_youtube";
-
- GM_xmlhttpRequest(
- {
- url: "https://img.youtube.com/vi/" + videoID + "/maxresdefault.jpg",
- method: "HEAD",
- onload: function (response)
- {
- if (response.status == 200)
- {
- //var contentLength = parseInt(response.responseHeaders.replace(/(Content-Length: (\d+)|.*\r?)/gi, "$2"));
- ss.href = "https://img.youtube.com/vi/" + videoID + "/maxresdefault.jpg?timidscript_youtube";
- ss.textContent = "[SM]";
- }
- }
- });
-
- ss.addEventListener("mouseover", RemoveLinkTag, true);
- ss.addEventListener("mouseout", AddLinkTag, false);
-
- return ss;
- }
-
- function AddLinkTag(e)
- {
- var link = e.target;
- link.href += link.postfix;
- //if (link.postfix)
- // setTimeout(function () { link.href += link.postfix; }, 250);
- }
- function RemoveLinkTag(e)
- {
- var s, m = this.href.match(/\?timidscript_[_a-z0-9]+/i);
- if (m)
- {
- this.postfix = m[0];
- this.href = this.href.replace(/\?timidscript_[_a-z0-9]+/i, "");
- }
- }
-
- function AddBlockButton(li)
- {
- var btn = document.createElement("span");
- btn.className = "blockBTN32";
-
- //if (PageTYPE == 1) btn.title = li.getElementsByClassName("g-hovercard")[0].textContent;
- //else btn.title = li.getElementsByClassName("g-hovercard")[1].textContent;
- btn.title = li.getElementsByClassName("g-hovercard")[0].textContent;
- var span = document.createElement("span");
-
- if (PageTYPE == 2)
- {
- span.setAttribute("style", "position:absolute; right:0px;");
- li.insertBefore(span, li.firstElementChild);
- }
- else
- {
- span.setAttribute("style", "float:right;");
- li.firstElementChild.insertBefore(span, li.firstElementChild.firstElementChild);
- }
-
- btn.onclick = BlockUser;
- span.appendChild(btn);
- span.className = "blockBox";
-
- var href = li.getElementsByTagName("a")[0].href;
- if (href.indexOf("/watch?v=") > 0)
- {
- var ss = CreateScreenshotLink(href.replace(/.+watch\?v=(([a-z0-9]|_|-)+).*/gi, "$1"));
- ss.setAttribute("style", "display:block;text-align:center;");
- span.appendChild(ss);
- }
- }
-
- function NextPageURL()
- {
- var nextpage = document.querySelector(".branded-page-box > [disabled=true]");
-
- if (nextpage) nextpage = nextpage.nextElementSibling;
- if (!nextpage) return null;
-
- return nextpage.href;
- }
-
-
- function ScrollCheck()
- {
- var pager = document.querySelector(".branded-page-box");
- var loc = pager.offsetTop + pager.offsetHeight - document.documentElement.offsetHeight;
-
- if (loc < document.documentElement.scrollTop)
- {
- clearInterval(intervalID);
- var url = NextPageURL();
-
- var xhr = new XMLHttpRequest();
- xhr.open("GET", url, true);
- xhr.responseType = "document";
- xhr.onload = function (e)
- {
- var pager = document.querySelector(".branded-page-box");
- var doc = xhr.response;
- var pagerNew = doc.querySelector(".branded-page-box");
- pager.outerHTML = pagerNew.outerHTML;
-
- var result = document.getElementsByClassName("item-section")[0];
- var resultNew = doc.getElementsByClassName("item-section")[0];
-
- //Removes spell correction from result
- if (resultNew.getElementsByClassName("spell-correction")[0])
- {
- resultNew.removeChild(resultNew.getElementsByClassName("spell-correction")[0].parentElement);
- }
- var lis = resultNew.children;
-
-
- while (lis.length > 0)
- {
- var li = lis[0];
- result.appendChild(li);
- var imgs = li.getElementsByTagName("img");
-
- for (var i = 0; i < imgs.length; i++)
- {
- var src = imgs[i].getAttribute("data-thumb");
- if (src) imgs[i].src = src;
- }
-
- AddBlockButton(li);
- }
-
- HideUnwantedUsers();
- setTimeout(EnablePager, 1500);
- };
- xhr.send();
- }
- }
-
- function EnablePager()
- {
- if (AutoPaging && NextPageURL()) intervalID = setInterval(ScrollCheck, 500);
- else clearInterval(intervalID);
- }
-
- function HideUnwantedUsers()
- {
- FilteredUsers = new Array();
-
- if (PageTYPE == 0) //Main Page
- {
- //var items = document.getElementsByClassName("channels-content-item");
- var items = document.getElementsByClassName("yt-lockup-video");
-
- for (var i = 0; i < items.length; i++)
- {
- var thumbdata = items[i],
- user = thumbdata.querySelector(".yt-uix-sessionlink.spf-link.g-hovercard, .yt-uix-sessionlink.g-hovercard").textContent,
- filtered = IsFilteredUser(user),
- notice = thumbdata.parentNode.querySelector(".banNotice");
-
- if (filtered && !notice)
- {
- FilteredUsers.push(user);
- TSL.addClass(thumbdata, "blockedVideoBG");
-
- notice = document.createElement("div");
- notice.className = "banNotice";
- notice.style.left = thumbdata.offsetLeft + "px";
-
- notice.style.height = thumbdata.clientHeight + "px";
- notice.style.width = thumbdata.clientWidth + "px";
- notice.setAttribute("name", "YTF");
-
- var txt = document.createElement("span");
- txt.textContent = user;
- txt.style.height = thumbdata.clientHeight + "px";
- txt.style.width = thumbdata.clientWidth + "px";
- notice.appendChild(txt);
- thumbdata.parentNode.insertBefore(notice, thumbdata);
- }
- else if (!filtered && notice)
- {
- TSL.removeClass(thumbdata, "blockedVideoBG");
- TSL.removeNode(notice);
- }
- }
- }
- else //Search Result & Video Page
- {
- var results, user;
- if (PageTYPE == 1) results = document.getElementsByClassName("item-section")[0].children;
- else results = document.getElementsByClassName("video-list-item");
- console.log(results.length);
- for (var i = 0; i < results.length; i++)
- {
- try
- {
- var vid = results[i];
- if (vid.getElementsByClassName("g-hovercard").length == 0) continue;
- var user = vid.getElementsByClassName("g-hovercard")[0].textContent;
- //if (PageTYPE == 1) user = vid.getElementsByClassName("g-hovercard")[0].textContent;
- //else user = vid.getElementsByClassName("g-hovercard")[1].textContent;
-
- var filtered = IsFilteredUser(user);
- if (filtered)
- {
- FilteredUsers.push(user);
- TSL.addClass(vid, "blockedVideo");
- }
- else
- {
- TSL.removeClass(vid, "blockedVideo");
- }
- }
- catch (e) { console.warn(e); }
- }
- }
-
- if (FilteredUsers.length > 0) TSL.addStyle("OptSelect", "#OptionsButton, #OptionsButton2{background-color: #FBE8E5;} #OptionsButton:hover{background-color: #FBD5CF}");
- else TSL.removeNode("OptSelect");
- }
-
- function GetFilters()
- {
- var filters = GM_getValue("Filters", null);
- if (!filters) return new Array();
-
- return JSON.parse(filters);
- }
-
-
- function ShowAllVideos()
- {
- if (Boolean(GM_getValue("ShowAllVideos", false)))
- {
- TSL.removeNode("BlockVideos");
- TSL.addStyle("ShowAllVideos", ".banNotice {display: none;}");
- }
- else
- {
- TSL.addStyle("BlockVideos", ".blockedVideo {display:none;}");
- TSL.removeNode("ShowAllVideos");
- }
- }
-
- function CreateFilterWindow()
- {
- var fwin = document.getElementById("FilterWindow");
- if (fwin) TSL.removeNode(fwin);
-
- var userFilters = GetFilters();
-
- fwin = document.createElement("span");
- var tbHolder = document.createElement("div");
- tbHolder.setAttribute("style", "overflow-x:hidden; overflow-y:auto; max-height: 500px;");
- var table = document.createElement("table");
- table.style.maxHeight
- tbHolder.appendChild(table);
- fwin.appendChild(tbHolder);
-
-
- for (var i = 0; i < userFilters.length; i++)
- {
- var user = userFilters[i];
- var btn = document.createElement("a");
- btn.className = "unblockBTN";
- btn.title = user;
-
- btn.onclick = function (e)
- {
- e.stopImmediatePropagation();
- var user = this.title;
- var filters = GetFilters();
-
- for (var i = 0; i < filters.length; i++)
- {
- if (filters[i] == user)
- {
- filters.splice(i, 1);
- GM_setValue("Filters", JSON.stringify(filters));
- break;
- }
- }
-
- TSL.removeNode(this.parentElement.parentElement);
- HideUnwantedUsers();
- };
-
- var r = table.insertRow(-1);
- var td = document.createElement("td");
- r.appendChild(td);
- td.appendChild(btn);
-
- var a = document.createElement("a");
- a.href = "results?search_query=" + user + "&sm=3";
-
- var d = document.createElement("div");
- d.textContent = user;
-
- for (var j = 0; j < FilteredUsers.length; j++)
- {
- if (user == FilteredUsers[j])
- {
- r.style.backgroundColor = "#FBE8E5";
- //d.style.color = "red";
- break;
- }
- }
-
- td = document.createElement("td");
- a.appendChild(d);
- td.appendChild(a);
- r.appendChild(td);
- }
-
-
- var d = document.createElement("div");
- d.style.textAlign = "center";
- var b = document.createElement("input");
-
- if (PageTYPE == 1)
- {
- b.type = "button";
- b.value = "Auto-Page";
- b.style.backgroundColor = (AutoPaging) ? "lime" : "gray";
- b.onclick = function ()
- {
- AutoPaging = !AutoPaging;
- this.style.backgroundColor = (AutoPaging) ? "lime" : "gray";
- EnablePager();
-
- GM_setValue("AutoPaging", AutoPaging);
- };
- d.appendChild(b);
- }
-
- b = document.createElement("input");
- b.type = "button";
- b.value = "Show All";
- b.style.backgroundColor = Boolean(GM_getValue("ShowAllVideos", false)) ? "lime" : "gray";
- b.onclick = function ()
- {
- var show = !Boolean(GM_getValue("ShowAllVideos", false));
- this.style.backgroundColor = show ? "lime" : "gray";
- GM_setValue("ShowAllVideos", show);
- ShowAllVideos(show);
- };
- d.appendChild(b);
-
- b = document.createElement("input");
- b.type = "button";
- b.value = "Close";
- b.onclick = function () { TSL.removeNode("FilterWindow"); };
-
- d.appendChild(b);
- fwin.appendChild(d);
-
-
-
- fwin.id = "FilterWindow";
- document.body.appendChild(fwin);
- return fwin;
- }
-
-
- var SearchCount = 0;
- function AdjustSearchResult()
- {
- var results;
- if (PageTYPE == 1) results = document.getElementsByClassName("item-section")[0].children;
- else results = document.getElementsByClassName("video-list-item");
-
- if (SearchCount == results.length) return;
- SearchCount = results.length;
-
- for (var i = 0; i < results.length; i++)
- {
- if (results[i].getElementsByClassName("blockBTN32").length == 0)
- {
- try
- {
- AddBlockButton(results[i]);
- }
- catch (e) { };
- }
- }
-
- HideUnwantedUsers();
- if (PageTYPE == 1) EnablePager();
- }
-
- function AddOptions()
- {
- if (document.getElementById("OptionsButton")) return;
- var masthead = document.getElementById("yt-masthead-signin");
-
- if (masthead)
- {
- var options = document.createElement("button");
- options.id = "OptionsButton";
- options.className = "yt-uix-button yt-uix-button-default";
- //options.textContent = "Options";
- options.onclick = function ()
- {
- var fwin = document.getElementById("FilterWindow");
- if (fwin) TSL.removeNode(fwin);
- else CreateFilterWindow();
- };
- masthead.insertBefore(options, masthead.firstElementChild);
-
- //var el = document.createElement("button");
- //el.id = "ViewAllButton";
- //el.className = "yt-uix-button yt-uix-button-default";
- //masthead.insertBefore(el, options);
- }
- else
- {
- var placer = document.createElement("div");
- placer.id = "FloatArea";
- document.body.appendChild(placer);
-
-
- var options = document.createElement("div");
- options.id = "OptionsButton";
- //options.textContent = "Options";
- options.onclick = function ()
- {
- var fwin = document.getElementById("FilterWindow");
- if (fwin) TSL.removeNode(fwin);
- else CreateFilterWindow();
- };
-
- document.onmousemove = function (e)
- {
- options.style.display = (IsMouseEventInClientArea(e, placer)) ? null : "none";
- }
-
- document.body.appendChild(options);
- }
- }
-
- //Mutation Observer
- var MO =
- {
- monitorBody: function ()
- {
- var mo = window.MutationObserver || window.MozMutationObserver || window.WebKitMutationObserver;
- if (mo)
- {
- MO.Observer = new mo(
- function ()
- {
- setTimeout(MainFunc, 500);
- });
-
- MO.Observer.observe(document.body, { characterData: true, attributes: true, childList: true, subtree: true });
- }
- },
-
- disconnect: function ()
- {
- if (MO.Observer) MO.Observer.disconnect();
- MO.Observer = null;
- }
- };
-
- var MainItemPageCount = 0;
- function MainFunc()
- {
- GetPageType();
- switch (PageTYPE)
- {
- case 0: //Main Page
- console.info("YTF: Main Page");
- MO.disconnect();
- AddOptions();
-
- var items = document.getElementsByClassName("yt-lockup");
- if (MainItemPageCount != items.length)
- {
- MainItemPageCount = items.length;
- for (var i = 0; i < items.length; i++)
- {
- var thumbdata = items[i];
- if (thumbdata.parsed) continue;
- thumbdata.parsed = true;
-
- var user = thumbdata.querySelector(".yt-uix-sessionlink.g-hovercard").textContent;
- var filters = GetFilters();
-
- var block = document.createElement("span");
- block.className = "blockLINKS";
-
- var blockBtn = document.createElement("a");
- blockBtn.className = "blockBTN16";
- blockBtn.title = user;
- blockBtn.onclick = BlockUser;
- block.appendChild(blockBtn);
-
- var link = thumbdata.getElementsByTagName("a")[0];
- link.appendChild(block);
- link.className += " aaTT";
-
- var ss = CreateScreenshotLink(link.href.replace(/.+watch\?v=(([a-z0-9]|_|-)+).*/gi, "$1"));
- block.appendChild(ss);
- }
-
- HideUnwantedUsers();
- }
- //setTimeout(MO.monitorBody, 1000);
- MO.monitorBody();
- break;
- case 1: //Search Result
- console.info("YTF: Search Result");
- //MO.disconnect();
- AddOptions();
- AdjustSearchResult();
- //MO.monitorBody();
- break;
- case 2: // Video Page
- //TSL.addStyle("YT_RELATED",".related-list-item .content-link {width:170px; background-color:red;}");
- console.info("YTF: Video Page");
- AddOptions();
- AdjustSearchResult();
-
- //Adds sceenshot
- var player = document.getElementById("watch7-headline");
- if (!player.getAttribute("screenshot"))
- {
- player.setAttribute("screenshot", "added");
- var ss = CreateScreenshotLink(document.URL.replace(/.+watch\?v=(([a-z0-9]|_|-)+).*/gi, "$1"));
- player.insertBefore(ss, player.firstElementChild);
- var fs = document.createElement("a");
- fs.textContent = "[FT]";
- fs.href = "https://www.youtube.com/v/" + document.location.search.match(/v=([-_\w]+)/)[1];
- fs.style.marginLeft = "10px";
- player.insertBefore(fs, ss.nextElementSibling);
- }
-
- setTimeout(LoadMoreVideos, 5000);
- break;
- case 3: //User Channel
- console.info("YTF: User Channel");
- MO.disconnect();
- var vthumbs = document.getElementsByClassName("ux-thumb-wrap");
-
- for (var i = 0, thumb; i < vthumbs.length, thumb = vthumbs[i]; i++)
- {
- if (!thumb.className.match("aaTT"))
- {
- thumb.className += " aaTT";
-
- var block = document.createElement("span");
- block.className = "blockLINKS";
- block.style.visibility = "visible";
- block.style.top = "10px";
- thumb.appendChild(block);
-
- var ss = CreateScreenshotLink(thumb.querySelector("a").href.replace(/.+watch\?v=(([a-z0-9]|_|-)+).*/gi, "$1"));
- ss.style.backgroundColor = "yellow";
- ss.style.border = "1px solid black";
- block.appendChild(ss);
- }
- }
-
- MO.monitorBody();
- break;
- }
-
- //Loads more side videos and filters them
- function LoadMoreVideos()
- {
- var wmv = document.getElementById("watch-more-related-button");
- AdjustSearchResult();
-
- if (!wmv || wmv.style.display == "none") return;
-
- document.getElementById("watch-more-related-button").click();
- setTimeout(LoadMoreVideos, 2500);
- }
- }
-
- var URL = document.URL;
- (function ()
- {
- GetPageType();
- if (PageTYPE == null) return;
- //Replace old saved syntax
- CURRENTVERSION = 1;
- if (GM_getValue("Version", 0) != CURRENTVERSION)
- {
- var filters = GM_getValue("Filters", null);
-
- if (filters)
- {
- filters = filters.split("|");
- for (var i = 0; i < filters.length; i++)
- {
- filters[i] = filters[i];
- }
-
- GM_setValue("Filters", JSON.stringify(filters));
- }
-
- GM_setValue("Version", CURRENTVERSION);
- }
-
- TSL.addStyle(null, "#OptionsButton {background-image: url(); background-size:24px 24px; background-repeat:no-repeat; background-position:center;}");
- TSL.addStyle(null, "#ViewAllButton {background-image: url(); background-size:24px 24px; background-repeat:no-repeat; background-position:center;}");
- //TSL.addStyle(null, "#OptionsButton {background-image: url(); background-size:24px 24px; background-repeat:no-repeat; background-position:center;}");
-
- if (document.getElementById("yt-masthead-signin"))
- {
- TSL.addStyle("YTF_FW", "#FilterWindow{position: fixed;z-index: 9999999999999; right: 50px;top: 50px;background-color: #E9EAEA;border: 1px solid black;}#FilterWindow div{color: gray;text-decoration-style: none;padding: 3px 5px;}#FilterWindow tr:hover{text-decoration-style: none;background-color: lightgray;color: black;}");
- TSL.addStyle(null, "#ViewAllButton, #OptionsButton {margin-right: 10px; height: 28px; width: 32px; background-size:15px 15px; background-repeat:no-repeat; background-position:center;}");
- }
- else
- {
- TSL.addStyle("YTF_FW", "#FilterWindow{position: fixed;z-index: 9999999999999; right: 10px;top: 95px;background-color: #E9EAEA;border: 1px solid black;}#FilterWindow div{color: gray;text-decoration-style: none;padding: 3px 5px;}#FilterWindow tr:hover{text-decoration-style: none;background-color: lightgray;color: black;}");
- TSL.addStyle(null, "#OptionsButton{height: 32px; width: 32px; margin: 0; padding: 0; position: fixed;color: #777979; right: 10px;top: 60px;border-radius: 3px;background-color: lightgray;border: 1px solid darkgray;cursor: pointer; z-index:99999999999999999;}#OptionsButton:hover{background-color: darkgray;color: black;}");
- }
- TSL.addStyle(null, ".blockBTN32, .blockBTN16, .unblockBTN{background-repeat:no-repeat; cursor:pointer; background-image: url();background-size: contain;z-index: 100;}");
- TSL.addStyle("YTF_BT", ".unblockBTN{display: inline-block;width: 16px;height: 16px; padding-right: 3px;} .blockBTN32{display: block;width: 32px;height: 32px;}a.aaTT:hover .blockLINKS{visibility: visible;} .blockBTN16 {display:block; background-color: black;border: 1px solid red;height: 24px;width: 24px;}");
- TSL.addStyle("YTF_BL", ".blockLINKS{position: absolute;top: 2px;visibility: hidden; z-index: 100; right: 2px;} .blockLINKS a:nth-child(2){line-height:normal; background-color:yellow; border: 1px solid blue; display:block;text-align:center;}");
- TSL.addStyle("YTF_NB", ".banNotice {position:absolute; z-index: 1000; font-size:medium;} .banNotice > span { display:table-cell; background-color:yellow; text-align: center; vertical-align: middle; }");
- TSL.addStyle("YTF_PC", "#FloatArea{position: fixed; right: 0px; top:10px; border: none; visibility:hidden; height: 200px; width:140px;}");
- TSL.addStyle("YTF_BX", ".blockBox {text-align:center;}");
-
-
- ShowAllVideos();
- TSL.addStyle("BlockVideoBG", ".blockedVideo, .blockedVideoBG {background-color:#FBE8E5;}");
-
-
- if (PageTYPE == 2)
- {
- if (GM_getValue("PageType2", false))
- TSL.addStyle("", GM_getValue("PageType2"));
- else TSL.addStyle("", "body #watch7-sidebar-contents {padding: 15px 0px 15px 5px !important;}"
- + "#watch7-sidebar-contents .video-list-item.related-list-item {padding-right: 35px;}");
- }
- else if (PageTYPE == 1 && GM_getValue("PageType1", false))
- {
- TSL.addStyle("", GM_getValue("PageType1"));
- }
-
- MainFunc();
- })();
-
- /*
- 1-3, Default is same as HQdefault but thumbnail size
- http://img.youtube.com/vi/<insert-youtube-video-id-here>/<1-3>.jpg
- http://img.youtube.com/vi/<insert-youtube-video-id-here>/default.jpg
-
- 0 & HQ default are the same
- http://img.youtube.com/vi/<insert-youtube-video-id-here>/0.jpg
- http://img.youtube.com/vi/<insert-youtube-video-id-here>/hqdefault.jpg
-
- http://img.youtube.com/vi/<insert-youtube-video-id-here>/maxresdefault.jpg
- https://developers.google.com/youtube/2.0/developers_guide_php?csw=1
- */