Greasy Fork is available in English.
FMS Image Link expander!
// ==UserScript==
// @name FMS Image link replacer
// @namespace FMS Image link replacer
// @include http://127.0.0.1:8080/forumviewthread.htm*
// @version 1
// @grant none
// @description FMS Image Link expander!
// ==/UserScript==
var maxWidth = 1280
var maxHeigth = 1000
var FProxy = 'http://127.0.0.1:8888/'
function escapeRegExp(str) {
return str.replace(/[\-\[\]\/\{\}\(\)\*\+\?\.\\\^\$\|]/g, "\\$&");
}
var imageLinkRE = new RegExp('^' + escapeRegExp(FProxy) + '(?:CHK|SSK|USK|KSK)(?:@|%40).+(?:\\.|%2E)(?:jpeg|jpg|png|gif)$', 'i');
var revealImageData = ''
function $x(p, context) {
if (!context) context = document;
var i, arr = [], xpr = document.evaluate(p, context, null, XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE, null);
for (i = 0; item = xpr.snapshotItem(i); i++) arr.push(item);
return arr;
}
function testLinkToImage(link) {
return imageLinkRE.test(link.href);
}
function revealPost(post, revealImage) {
revealImage.parentNode.removeChild(revealImage);
$x('a | div[@class="postattachments"]/div[@class="attachment"]/a', post).filter(testLinkToImage).forEach(function(link) {
img = new Image();
img.src = link.href;
img.alt = 'Loading '+link.innerText;
img.addEventListener('load', function() {
var setWidth;
var setHeigth;
if(this.naturalWidth > maxWidth)
setWidth = maxWidth +"px";
else
setWidth = this.naturalWidth + "px";
if(this.naturalHeigth > maxHeigth)
setHeigth = maxHeigth +"px";
else
setHeigth = this.naturalHeigth + "px";
this.style.width = setWidth;
this.style.heigth = setHeigth;
}, false);
link.innerHTML = '';
link.appendChild(img);
});
}
function hookPost(post) {
post.hooked = true;
img = new Image;
img.src = revealImageData;
img.title = 'Show images in this post'
img.style.cursor = 'pointer';
img.addEventListener('click', function() {
revealPost(this.parentElement, this);
});
post.insertBefore(img, post.firstChild);
}
$x('//td[@class="post"]/a', document.body).filter(testLinkToImage).forEach(function(link) {
if(!link.parentElement.hooked)
hookPost(link.parentElement);
});
$x('//td[@class="post"]/div[@class="postattachments"]/div[@class="attachment"]/a', document.body).filter(testLinkToImage).forEach(function(link) {
var post = link.parentElement.parentElement.parentElement;
if(!post.hooked)
hookPost(post);
});