Pixiv illustration full size link converter

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).

您需要先安装一个扩展,例如 篡改猴Greasemonkey暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴Userscripts ,之后才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。

您需要先安装用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==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();