// ==UserScript==
// @name Pogdesign-Widgets
// @namespace https://github.com/fabiencrassat
// @version 1.0.1
// @description Add links relative to the episode
// @author You
// @match https://www.pogdesign.co.uk/cat/
// @include /^https:\/\/www\.pogdesign\.co\.uk\/cat\/\d{1,}-\d{4}/
// @include /^https:\/\/www\.pogdesign\.co\.uk\/cat\/\w+(-*\w+)*\/Season-\d+\/Episode-\d+/
// @include /^https:\/\/www\.pogdesign\.co\.uk\/cat\/\w+(-*\w+)*-summary/
// @grant none
// @run-at document-start
// ==/UserScript==
/*global $, alert, console */
/*global fabiencrassat */
"use strict";
var main = function() {
var show = {
title: "",
seasonAndEpisode: "",
getTitle() { return this.title; },
setTitle(title) { this.title = title; },
getSeasonAndEpisode() { return this.seasonAndEpisode; },
setSeasonAndEpisode() {
if (arguments.length === 1) {
this.seasonAndEpisode = arguments[1];
return;
}
if (arguments.length === 2) {
var season = arguments[1];
var episode = arguments[2];
if (season.length < 2) { season = "0" + season; }
if (episode.length < 2) { episode = "0" + episode; }
this.seasonAndEpisode = "S" + season + "E" + episode;
return;
}
alert("Exception in setSeasonAndEpisode");
return;
},
getSearch() {
return this.getTitle().replace(/ /gm, ".") + "." + this.getSeasonAndEpisode();
},
};
var externalLinks = {
links: [
{site: "google",
icon: "",
url(show) { return "https://www.google.fr/search?q=" + show.getSearch() + "+vostfr+streaming"; },
},
{site: "binsearch",
icon: "",
url(show) { return "https://binsearch.info/?q=" + show.getSearch(); },
},
{site: "subscene",
icon: "",
url(show) { return "https://subscene.com/subtitles/release?q=" + show.getSearch(); },
},
],
getLinks(show) {
var links = "<span>";
for (var i = 0; i < this.links.length; i++) {
links += "<a target='_blank' href='" + this.links[i].url(show) + "'>";
links += this.links[i].site;
links += "</a><br>";
}
links += "</span>";
return links;
},
createPopup(show, element, cssClass, cssDisplay) {
var popup = "";
popup = "<div id='fcr-external-links-element' style='position: absolute; width: 350px; z-index: 97; display: " + cssDisplay + ";' class='cluetip ui-widget ui-widget-content ui-cluetip clue-right-default cluetip-default " + cssClass + "'>";
popup += "<div class='cluetip-inner ui-widget-content ui-cluetip-content'>";
popup += "<div id='pop'>";
popup += "<div id='popheader'><a class='fcr-closePopup' href='javascript:fabiencrassat.pogdesignWidget.clearLinksElement();'>X</a>";
popup += "<span>" + show.getTitle() + " " + show.getSeasonAndEpisode() + "</span>";
popup += "</div>";
popup += "<div id='poptext'>" + this.getLinks(show) + "</div>";
popup += "<div id='popfooter'>" + show.getSearch() + "</div>";
popup += "</div></div></div>";
return(popup);
},
};
var page = {
shared: {
linkImage: "",
stylesheets() {
var result = "";
result += "a.fcr-closePopup {" +
"float: right;" +
"color: #66bbff !important;" +
"}";
return(result);
},
insertStylesheets(stylesheets) {
var style = document.createElement("style");
style.appendChild(document.createTextNode(stylesheets));
(document.body || document.head || document.documentElement).appendChild(style);
},
},
calendar: {
stylesheets() {
var result = "";
result += "span.fcr-episodeContainer > :last-child {" +
"float: right;" +
"margin: 0 !important;" +
"}";
result += "span.fcr-episodeContainer > :first-child {" +
"float: left;" +
"}";
result += ".fcr-externalLink-calendar-page {" +
"height: 12px;" +
"width: 12px;" +
"background-image: url('" + page.shared.linkImage + "');" +
"}";
result += ".ep.infochecked .fcr-externalLink-calendar-page {" +
"filter: contrast(0);" +
"}";
result += page.shared.stylesheets();
return(result);
},
insertStylesheets() {
page.shared.insertStylesheets(page.calendar.stylesheets());
},
extractShow(show, element) {
this.extractTitle(show, element);
this.extractSeasonAndEpisode(show, element);
},
extractTitle(show, element) {
var title = $.trim(element.parent().prev().text());
show.setTitle(title);
},
extractSeasonAndEpisode(show, element) {
var seasonAndEpisode = element.prev().text();
show.setSeasonAndEpisode(seasonAndEpisode);
},
displayExternalLinksPopup(show, element) {
var popup = externalLinks.createPopup(show, element, "fcr-calendar-page", "block");
element.parent().parent().parent().after(popup);
},
},
summary: {
stylesheets() {
var result = "";
result += "span.fcr-episodeContainer {" +
"display: flex;" +
"}";
result += ".fcr-externalLink-summary-page {" +
"height: 12px !important;" +
"width: 12px !important;" +
"filter: contrast(0);" +
"margin: 9px -12px 9px 54px;" +
"background-image: url('" + page.shared.linkImage + "');" +
"}";
result += ".fcr-external-links-popup #pop {" +
"padding: 1px;" +
"font-size: initial;" +
"letter-spacing: initial;" +
"line-height: 1.5;" +
"border: 1px solid #000;" +
"border-radius: 10px;" +
"box-shadow: 0px 0px 21px rgba(0, 0, 0, 0.5);" +
"text-shadow: 1px 1px 0 #000;" +
"background-color: rgba(38, 38, 38, 0.9);" +
"opacity: .95;" +
"}";
result += ".fcr-external-links-popup #popheader {" +
"background-color: rgba(0, 0, 0, 0.3);" +
"color: #fff;" +
"border-radius: 9px 9px 0 0;" +
"}";
result += ".fcr-external-links-popup #poptext > span > a {" +
"color: #66bbff;" +
"}";
result += ".fcr-external-links-popup #popfooter {" +
"background-color: rgba(0, 0, 0, 0.3);" +
"color: #FF9326;" +
"border-radius: 0 0 9px 9px;" +
"}";
result += page.shared.stylesheets();
return(result);
},
insertStylesheets() {
page.shared.insertStylesheets(page.summary.stylesheets());
},
extractShow(show, element) {
this.extractTitle(show);
this.extractSeasonAndEpisode(show, element);
},
extractTitle(show) {
var title = $.trim($("h2.sumhead > a").text());
show.setTitle(title);
},
extractSeasonAndEpisode(show, element) {
var season = element.parent().parent().parent().find("[itemprop=seasonNumber]").text();
var episode = element.parent().parent().parent().find("[itemprop=episodeNumber]").text();
show.setSeasonAndEpisode(season, episode);
},
displayExternalLinksPopup(show, element) {
var popup = externalLinks.createPopup(show, element, "fcr-external-links-popup", "block");
element.parent().parent().parent().after(popup);
},
},
episode: {
stylesheets() {
var result = "";
result += page.summary.stylesheets();
return(result);
},
insertStylesheets() {
page.shared.insertStylesheets(page.episode.stylesheets());
},
extractShow(show) {
this.extractTitle(show);
this.extractSeasonAndEpisode(show);
},
extractTitle(show) {
var title = $("h3.sumunderhead").text();
show.setTitle(title);
},
extractSeasonAndEpisode(show) {
var seasonAndEpisode = $("h3.sdfsdf").children().first().text();
show.setSeasonAndEpisode(seasonAndEpisode);
},
displayExternalLinksPopup(show, element) {
var popup = externalLinks.createPopup(show, element, "fcr-external-links-popup", "inline-flex");
element.after(popup);
},
},
};
function clearLinksElement() {
var element = $("#fcr-external-links-element");
if(element) { element.remove(); }
}
function externalLinksPopupOnCalendarPage(element) {
clearLinksElement();
page.calendar.extractShow(show, element);
page.calendar.displayExternalLinksPopup(show, element);
}
function externalLinksPopupOnEpisodePage(element) {
clearLinksElement();
page.episode.extractShow(show);
page.episode.displayExternalLinksPopup(show, element);
}
function externalLinksPopupOnSummaryPage(element) {
clearLinksElement();
page.summary.extractShow(show, element);
page.summary.displayExternalLinksPopup(show, element);
}
return {
calendar: {
externalLinksPopup: externalLinksPopupOnCalendarPage,
stylesheets: page.calendar.insertStylesheets,
},
episode: {
externalLinksPopup: externalLinksPopupOnEpisodePage,
stylesheets: page.episode.insertStylesheets,
},
summary: {
externalLinksPopup: externalLinksPopupOnSummaryPage,
stylesheets: page.summary.insertStylesheets,
},
clearLinksElement,
};
};
var script = document.createElement("script");
script.appendChild(document.createTextNode("var fabiencrassat = fabiencrassat || {}; fabiencrassat.pogdesignWidget = ("+ main +")();"));
(document.body || document.head || document.documentElement).appendChild(script);
window.addEventListener("load", function() {
// Add search episode links for calendar pages
if ($("#month_box p > :last-child").length > 0) {
fabiencrassat.pogdesignWidget.calendar.stylesheets();
$("#month_box p > :last-child").wrap("<span class='fcr-episodeContainer'></span>");
$("span.fcr-episodeContainer > :last-child").after("<a href='javascript:void(0)' class='fcr-externalLink-calendar-page'></a>");
$(".fcr-externalLink-calendar-page").on("click", function(event) {
event.preventDefault();
fabiencrassat.pogdesignWidget.calendar.externalLinksPopup($(this));
});
}
// Add search episode links for episode page
else if ($("h3.sdfsdf").length === 1) {
fabiencrassat.pogdesignWidget.episode.stylesheets();
$("<span> <a href='javascript:void(0)' class='fcr-externalLink-episode-page'><Links></a></span>").appendTo("h3.sdfsdf");
$(".fcr-externalLink-episode-page").on("click", function(event) {
event.preventDefault();
fabiencrassat.pogdesignWidget.episode.externalLinksPopup($(this));
});
}
// Add search episode links for summary page
else if ($("li.ep.info").length > 0) {
fabiencrassat.pogdesignWidget.summary.stylesheets();
$("li.ep.info > strong > a").wrap("<span class='fcr-episodeContainer'></span>");
$("<a href='javascript:void(0)' class='fcr-externalLink-summary-page'></a>").appendTo("span.fcr-episodeContainer");
$(".fcr-externalLink-summary-page").on("click", function(event) {
event.preventDefault();
fabiencrassat.pogdesignWidget.summary.externalLinksPopup($(this));
});
}
// no page found
}, false);