// ==UserScript==
// @name e621 Thumbnail Enhancer
// @version 1.01
// @description Resizes thumbnails on e621.net, replacing them with higher resoltion images and adding support for video previews.
// @author swordgedance
// @include http://*e621.net/post*
// @include https://*e621.net/post*
// @include http://*e621.net/pool*
// @include https://*e621.net/pool*
// @grant GM.xmlHttpRequest
// @namespace https://greasyfork.org/de/users/398891
// ==/UserScript==
//original rooshoos
//http://twitter.com/rooshoos
var sty =document.createElement("style");
sty.innerHTML=[
"div.thumbEnh_cont{"
," display: grid;"
," grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));"
,"}"
,"div.thumbEnh_cont span.thumb{"
," width:90%;"
," height:auto;"
,"}"
,"span.thumb img{"
," width:100%;"
," height:auto;"
,"}"
// ,"span.thumb {"
// ," width: 30%;" //auto;"
// ," height: auto;" //250px;"
// ," margin: 0 10px 10px 0;"
// ,"}"
,"span.thumb .preview {"
," display: block;"
," height: auto;"//220px;"
," width: 100%;"//auto;"
,"}"
,"#child-posts-expanded-thumbs span.thumb,"
,"#child-posts-expanded-thumbs span.thumb .preview {"
," width: 32%;"//180px;"
," height:auto;"
,"}"
,"span.thumb .post-score {"
," width: auto !important;"
,"}"
,"span.thumb .tooltip-thumb {"
," display: block;"
," position: relative;"
,"}"
,"span.thumb .gif,"
,"span.thumb .video {"
," position: relative;"
," display: block;"
,"}"
,"span.thumb .gif:not(:hover)::after,"
,"span.thumb .video:not(:hover)::after {"
," content: '';"
," display: block;"
," position: absolute;"
," top: 0; bottom: 0; left: 0; right: 0;"
,"}"
,"span.thumb .video:not(:hover)::after {"
," background: transparent "
," url()"
," no-repeat center/80px;"
,"}"
,"span.thumb .gif:not(:hover)::after {"
," content: 'GIF';"
," width: 60px;"
," height: 30px;"
," margin: auto;"
," font-size: 16px;"
," font-weight: bold;"
," line-height: 30px;"
," color: rgba(0,0,0,0.4);"
," background-color: rgba(255,255,255,0.8);"
," border-radius: 6px;"
," box-shadow: 0 0 13px rgba(0,0,0,0.29);"
,"}"
,"span.thumb .gif:hover .preview {"
," display: none !important;"
,"}"
,"span.thumb .gif:hover img.preview {"
," display: block !important;"
,"}"
].join("");
document.head.appendChild(sty);
(function () {
var contDiv = document.querySelector("span.thumb").parentElement;
contDiv.className = "thumbEnh_cont";
function is_gif(i) {
return /^(?!data:).*\.gif/i.test(i.src);
}
function freeze_gif(i) {
var c = document.createElement('canvas');
var w = c.width = i.naturalWidth;
var h = c.height = i.naturalHeight;
var p = i.parentNode;
c.getContext('2d').drawImage(i, 0, 0, w, h);
p.className = ['gif', p.className].join(' ');
try {
i.src = c.toDataURL("image/gif"); // if possible, retain all css aspects
} catch (e) { // cross-domain -- mimic original with all its tag attributes
replaceImg(c, i);
i.style.display = 'none';
p.insertBefore(i, p.firstChild);
}
}
function replaceImg(e, i) {
e.className = i.className;
var s = window.getComputedStyle(i);
e.style.border = s.getPropertyValue('border');
e.style.borderRadius = s.getPropertyValue('border-radius');
i.parentNode.replaceChild(e, i);
}
function setVideo(thumb, videoUrl) {
var video = document.createElement('video'),
parent = thumb.parentNode;
video.controls = false;
video.loop = true;
video.muted = true;
video.preload = 'metadata';
video.addEventListener('loadedmetadata', function () {
parent.className = ['video', parent.className].join(' ');
parent.addEventListener('mouseenter', function () {
video.play();
});
parent.addEventListener('mouseleave', function () {
video.pause();
});
replaceImg(this, thumb);
}, false);
video.src = videoUrl;
}
/* Replace video thumbnails with actual playable video */
function videoThumb(thumb, parseHTML) {
parseHTML = parseHTML || false;
var parent = thumb.parentNode;
GM.xmlHttpRequest({
method: "GET",
url: parent.href,
headers: {
"Accept": "text/xml"
},
onload: function (response) {
var videoUrl = null;
if (response.readyState !== 4) return;
if (!response.responseXML) return;
var file_url = response.responseXML.getElementsByTagName('file_url')[0];
if (!file_url) return;
videoUrl = file_url.childNodes[0].nodeValue;
setVideo(thumb, videoUrl);
}
});
}
/* Replace image thumbnails with higher resolution */
function imageThumb(thumb) {
var newThumb = new Image(),
replace = function (thumb) {
thumb.src = this.src;
if (is_gif(thumb)) {
//freeze_gif(thumb);
}
},
trynoSample = function (thumb) {
this.onerror = tryGif.bind(this, thumb);
this.src = thumb.src.replace('/preview/', '/');
},
tryGif = function (thumb) {
this.onerror = null;
this.src = thumb.src.replace('/preview/', '/').replace('.jpg', '.gif');
};
newThumb.onload = replace.bind(newThumb, thumb);
newThumb.onerror = trynoSample.bind(newThumb, thumb);
newThumb.src = thumb.src.replace('/preview/', '/sample/');
}
function imgError(image) {
image.onerror = "";
image.src = "/images/noimage.gif";
return true;
}
/* Run above on all thumbnails */
var thumbs = document.querySelectorAll('span.thumb img');
//var typ=document.querySelectorAll('span.thumb span.type-badge');
for (i = 0; i < thumbs.length; i++) {
var thumb = thumbs[i];
var badge = thumb.parentElement.querySelector("span.type-badge");
if (badge && badge.innerHTML.toLowerCase() == "webm") {
(function (thumb, i) {
setTimeout(function () {
videoThumb(thumb);
}, 100 * i);
})(thumb, i);
} else {
imageThumb(thumb);
}
}
})();