[TS] deviantART Gallery Pager

Auto-pager for DeviantArt gallery/favourites. On-top of FireFox, it now works with G-Chrome and Opera. NOW: With sticky paging button switch.

Versión del día 16/01/2015. Echa un vistazo a la versión más reciente.

// ==UserScript==
// @name            [TS] deviantART Gallery Pager
// @namespace       TimidScript
// @version         1.0.7
// @description     Auto-pager for DeviantArt gallery/favourites. On-top of FireFox, it now works with G-Chrome and Opera. NOW: With sticky paging button switch.
// @icon            https://i.imgur.com/1KiUR7g.png
// @author          TimidScript
// @homepageURL     https://openuserjs.org/users/TimidScript
// @copyright       © 2014 TimidScript, All Rights Reserved.
// @license         Creative Commons BY-NC-SA + Please notify me if distributing
// @include         http://*.deviantart.com/gallery/*
// @include         http://*.deviantart.com/favourites/*
// @require         https://openuserjs.org/src/libs/TimidScript/TSL_-_GM_Update.js
// @homeURL         https://openuserjs.org/scripts/TimidScript/[TS]_deviantART_Gallery_Pager
// @grant           GM_xmlhttpRequest
// @grant           GM_info
// @grant           GM_getMetadata
// @grant           GM_getValue
// @grant           GM_setValue
// @grant           GM_addStyle
// @grant           GM_deleteValue
// @grant           GM_registerMenuCommand
// ==/UserScript==


/* Information
**************************************************************************************************
Copyright © 2014 TimidScript, All Rights Reserved.
Script's Homepage:              Check homepages below

TimidScript's Homepage:         https://openuserjs.org/users/TimidScript
                                https://greasyforks.org/users/1455-timidscript
                                https://monkeyguts.com/author.php?un=timidscript

                                http://userscripts.org/users/TimidScript
                                http://userscripts-mirror.org/users/100610/scripts

From FireFox verion 34.0.5, window.scrollMaxY only returns the max scrollable value and does not return
the document height as before. Before the two were snonymous or at least that's how it use to work as far
as a I can remember.

------------------------------------
 Version History
------------------------------------
1.0.8 (2015-01-16)
 - Bug fix to paging as it did not work in high resolution.
 - Paging button added. It saves last setting.
 - Added a setting to update url to the last page loaded. Remove the commenting from: GM_setValue("UpdateURL",1);
1.0.7 (2015-01-09)
 - Big fix due favourites paging due to changes in divantArt site
 - Take into account favourites folders when working out scrollOffsetExtra.
1.0.6 (2015-01-02)
 - At least from Firefox version 34.0.5 window.scrollMaxY value no longer returns the max scrollable document
 value. Replaced it with document.documentElement.scrollHeight.
//From version 34.# of FF scrollMaxY no longer returns
1.0.5 (2014-11-01)
 - Bug fix: Check if comments are present in the gallery
 - Bug fix: Loading icon gets removed now when you change page
1.0.4 (2014-10-31)
 - Fix to support other browsers beside FireFox
1.0.3 (2014-08-29)
 - Added GM_update
1.0.2 (2014-08-19)
 - Cleaned up header for OUJS
1.0.1 (2013-02-27)
 - Initial Release
**************************************************************************************************/
console.info("DeviantScript Gallery Pager");
/************** Variable you can set **************/
//GM_setValue("UpdateURL", 1) //Turn on update URL
//GM_deleteValue("UpdateURL") //Turn off update URL
/**************************************************/

var scrollOffset = 500;
var addPagination = true; //Adds page divider
var gmi = document.querySelector("#gmi-GZone[gmi-name='top_left']");

var intervalID = 0;
var nextPageURL = null;
var galleryPager = document.getElementById("gallery_pager");
var pagerSwitch;

AddPagerSwitch();
if (pagerSwitch.value == 1 && GetNextPageURL(document)) intervalID = setInterval(CheckScrollPosition, 200);

var loading = "";


function AddPagerSwitch()
{
    var holder = document.createElement("div");
    pagerSwitch = document.createElement("button");
    holder.appendChild(pagerSwitch);
    holder.setAttribute("style", "text-align:center;");

    GM_addStyle(".smbutton-red2 {background:linear-gradient(center top , #ED7968, #EB462D) repeat scroll 0% 0% transparent;"
        + "background: -moz-linear-gradient(center top , #ED7968, #EB462D) repeat scroll 0% 0% transparent;"
        + "background: -webkit-linear-gradient(center top , #ED7968, #EB462D) repeat scroll 0% 0% transparent;"
        + "background: -o-linear-gradient(center top , #ED7968, #EB462D) repeat scroll 0% 0% transparent;}"
        + ".smbutton-red2:hover {background:linear-gradient(center top , #ED9588, #E9604B) repeat scroll 0% 0% transparent;"
        + "background: -moz-linear-gradient(center top , #ED9588, #E9604B) repeat scroll 0% 0% transparent;"
        + "background: -webkit-linear-gradient(center top , #ED9588, #E9604B) repeat scroll 0% 0% transparent;"
        + "background: -o-linear-gradient(center top , #ED9588, #E9604B) repeat scroll 0% 0% transparent;}"
        + ".smbutton-dead, .smbutton-dead:hover  {background:linear-gradient(center top , #A39F9F, #787473) repeat scroll 0% 0% transparent;"
        + "background: -moz-linear-gradient(center top , #A39F9F, #787473) repeat scroll 0% 0% transparent;"
        + "background: -webkit-linear-gradient(center top , #A39F9F, #787473) repeat scroll 0% 0% transparent;"
        + "background: -o-linear-gradient(center top , #A39F9F, #787473) repeat scroll 0% 0% transparent;}"
        );

    GM_addStyle(".smbutton-red2 {bac}");

    document.querySelector("#gmi-GZone[gmi-name='sidebar1']").insertBefore(holder, document.querySelector("#gmi-GZone[gmi-name='sidebar1']").firstElementChild);
    pagerSwitch.textContent = "Auto-Pager";
    pagerSwitch.value = GM_getValue("Paging", 1);
    pagerSwitch.className = (pagerSwitch.value == 1) ? "smbutton smbutton-green" : "smbutton smbutton-red2";

    pagerSwitch.onclick = function ()
    {
        if (pagerSwitch.value == -1) return;

        if (pagerSwitch.value == 1)
        {
            clearInterval(intervalID);
            pagerSwitch.value = 0;
            pagerSwitch.className = "smbutton smbutton-red2";
        }
        else
        {
            intervalID = setInterval(CheckScrollPosition, 200);
            pagerSwitch.value = 1;
            pagerSwitch.className = "smbutton smbutton-green";
        }
        GM_setValue("Paging", pagerSwitch.value);
    }
}

function CheckScrollPosition()
{
    var posBottom = getAbsolutePosition(gmi).top + gmi.offsetHeight;
    if (window.innerHeight + window.scrollY > posBottom - scrollOffset)
    {
        GetNextPage();
    }

    function getAbsolutePosition(element)
    {
        var x = 0;
        var y = 0;

        while (element && !isNaN(element.offsetLeft) && !isNaN(element.offsetTop))
        {
            x += element.offsetLeft;
            y += element.offsetTop;
            element = element.offsetParent;
        }
        return { top: y, left: x };
    }
}

function GetNextPageURL(doc)
{
    var next = (doc.querySelector(".folderview.ch")) ? doc.querySelector(".folderview-art > .pagination-wrapper li.next a.away") : doc.querySelector("li.next a.away");

    if (next)
    {
        nextPageURL = next.href;
        return true;
    }

    pagerSwitch.value = -1;
    pagerSwitch.className = "smbutton smbutton-dead";
    nextPageURL = null;
    return false;
}

function GetNextPage()
{
    clearInterval(intervalID);

    var div = document.createElement("div");
    div.id = "deviantscript";
    img = document.createElement("img");
    img.src = loading;
    div.appendChild(img);
    document.getElementById("gmi-GPage").appendChild(div);
    w = Math.round(img.clientWidth / 2);
    div.setAttribute("style", "position: fixed; z-index: 999; bottom: 50%; left: 50%; margin: 0 0 0 -" + w + "px;");


    var xhr = new XMLHttpRequest();
    xhr.open("GET", nextPageURL, true);
    //xhr.responseType = "document"; //Causes issues in Opera
    xhr.onload = function (e)
    {
        if (xhr.readyState == 4)
        {
            if (xhr.status == 200)
            {
                //var xdoc = xhr.response; //Causes issues in opera;
                //var xdoc = document.createElement("xml");
                //xdoc.innerHTML = xhr.responseText;

                var xdoc = document.implementation.createHTMLDocument('MPIV');
                xdoc.documentElement.innerHTML = xhr.responseText;

                if (xdoc.querySelector(".folderview.ch"))
                {
                    gmi.appendChild(xdoc.querySelector("#gmi-GZone[gmi-name='top_left'] #gmi-GMFrame_Gruser").cloneNode(true));
                }
                else
                {
                    gmi.appendChild(xdoc.querySelector("#gmi-ResourceStream, #gmi-EditableResourceStream").cloneNode(true));
                    if (addPagination) gmi.appendChild(xdoc.getElementsByClassName("pagination")[0].parentElement.cloneNode(true));
                }

                if (GM_getValue("UpdateURL")) window.history.pushState(null, "", xhr.responseURL);
                if (GetNextPageURL(xdoc)) intervalID = setInterval(CheckScrollPosition, 200);
            } else
            {
                console.error(xhr.statusText);
            }
        }
        document.getElementById("deviantscript").parentNode.removeChild(document.getElementById("deviantscript"));
    };
    xhr.onerror = function (e)
    {
        document.getElementById("deviantscript").parentNode.removeChild(document.getElementById("deviantscript"));
        console.error(xhr.statusText);
    };
    xhr.send(null);
}
长期地址
遇到问题?请前往 GitHub 提 Issues。