// ==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. // @downloadURL https://update.greasyfork.icu/scripts/3812/Pixiv%20illustration%20full%20size%20link%20converter.user.js // @updateURL https://update.greasyfork.icu/scripts/3812/Pixiv%20illustration%20full%20size%20link%20converter.meta.js // ==/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();