Displaying and linking to the original picture on the thumbnail container, instead of a container layout. Especially a goodie for people who were benefitted with similar function provided by Pixiv++ (and maybe now, but if they want to use this as lightweight on another place).
// ==UserScript==
// @namespace com.whoopsworkshop.hkgsherlock.userjs.pixiv_illust_full
// @id com.whoopsworkshop.hkgsherlock.userjs.pixiv_illust_full
// @icon 
// @name Pixiv illustration full size link converter
// @description Displaying and linking to the original picture on the thumbnail container, instead of a container layout. Especially a goodie for people who were benefitted with similar function provided by Pixiv++ (and maybe now, but if they want to use this as lightweight on another place).
// @author hkgsherlock
// @version 201502100051+8
// @include /^https?:\/\/www\.pixiv\.net\/member_illust\.php?.*mode=(medium|manga).*$/
// @grant none
// @license Public Domain for source code only.
// ==/UserScript==
//
// they changed the layout again lag, fack u
// YOU SEE ME TROLLIN', THEY HATIN'
//
// Well, just let users choose what they want. They're still your users even you're not creating a dynasty which controls how they behave.
// And you're not even the Facebook.
//
function pixiv_illust_full() {};
pixiv_illust_full.prototype.addFullSizePageCSS = function() {
var str = "";
str += "img.fullsize.limit600 { max-width: 600px; max-height: 600px; } \r\n";
str += "img.fullsize.limit1200 { max-width: 1200px; max-height: 1200px; } \r\n";
var addStyle = document.createElement("style");
addStyle.setAttribute('type', 'text/css');
addStyle.innerHTML = str;
document.head.appendChild(addStyle);
}
pixiv_illust_full.prototype.pageGrabDOM = function(url, uniqueSel, callback) {
/*
GM_xmlhttpRequest({
method: "GET",
url: url,
onload: function(response) {
var content = new DOMParser().parseFromString(response.responseText, "text/html");
callback(content.querySelector(uniqueSel));
}
});
*/
var xhr = new XMLHttpRequest();
xhr.onreadystatechange = function() {
if (xhr.readyState == 4 && xhr.status == 200) {
var content = new DOMParser().parseFromString(xhr.responseText, "text/html");
callback(content.querySelector(uniqueSel));
}
};
xhr.open("GET", url, true);
xhr.send();
};
pixiv_illust_full.prototype.dropThumbPutFull = function(worksDisplay, src_full) {
var thumb = worksDisplay.querySelector('._layout-thumbnail');
var medium = thumb.querySelector('img');
// creating new img for us
var full = medium.cloneNode();
full.classList.remove('medium');
full.src = src_full;
full.classList.add('fullsize');
full.classList.add('limit600');
// full.style.maxWidth = '600px';
// full.style.maxHeight = '600px';
// creating back the link
var link = document.createElement('a');
link.href = src_full;
link.target = '_blank'
link.appendChild(full);
link.classList.add('_layout-thumbnail');
// replace
thumb.remove();
worksDisplay.appendChild(link);
};
pixiv_illust_full.prototype.do = function() {
// getting params as assoc arr for detecting mode
var params = {};
document.location.search.substr(1).split('&').forEach(function(x) {
var arr = x.split('=');
arr[1] && (params[arr[0]] = arr[1]);
});
if (params.mode === undefined) return;
this.addFullSizePageCSS();
if (params.mode === "medium") {
// store references using
var wksDisp = document.querySelector('div.works_display');
if (wksDisp === null) return; // this script loads on iframe pages too! they don't have that DOM, don't waste time
// if manga then is null
var big = document.querySelector('.original-image');
if (big !== null) { // submitted as a illustration
// get the src(href) of the big (~full)
var fSrc = big.src || big.attributes['data-src'].value;
this.dropThumbPutFull(wksDisp, fSrc);
} else { // submitted as manga
var aManga = wksDisp.querySelector('a.manga:not(.multiple)');
if (aManga === null) return; // if multi-page then quit
var that = this; // trick
this.pageGrabDOM(aManga.href, 'img:not(.user-icon)', function(ee) {
var imgUrl = /* aManga.classList.contains('manga') ? ee.attributes['data-src'].value : */ ee.src;
that.dropThumbPutFull(wksDisp, imgUrl);
});
}
} else if (params.mode === "manga") {
var imgs = document.querySelectorAll('div.item-container');
// if can't select then result.length == 0 --> not loop
var that = this; // trick
Array.forEach(imgs, function(e, i) {
var apply = e.querySelector('img.image');
var leftLargeLink = e.querySelector('a.full-size-container');
if (apply === null) return;
apply.attributes.removeNamedItem('data-src'); // remove first, prevent them from adding thumb back
that.pageGrabDOM(e.querySelector('a.full-size-container').href, 'img', function(ee) {
leftLargeLink.href = apply.src = ee.src;
apply.classList.add('fullsize');
apply.classList.add('limit1200');
});
});
}
};
var pif = pif || new pixiv_illust_full();
pif.do();