Gelbooru Revamped

This adds a couple of changes to the layout and behaviour of the site

As of 2017-04-08. See the latest version.

// // ==UserScript==
// @name       Gelbooru Revamped
// @namespace  westerhold78
// @version    0.7.1
// @description  This adds a couple of changes to the layout and behaviour of the site
// @include     *://gelbooru.com/*
// @include     *gelbooru.com/*
// @include     *://www.gelbooru.com/*
// @require     http://code.jquery.com/jquery-latest.js
// @icon        
// @copyright  2017, westerhold78
// @grant    GM_addStyle
// @grant    GM_xmlhttpRequest
// ==/UserScript==
// 
var style = [];

$.urlParam = function(name){
    var results = new RegExp('[\?&]' + name + '=([^&#]*)').exec(window.location.href);
    if (results==null){
       return null;
    }
    else{
       return results[1] || 0;
    }
};

$.loadImage = function(url) {
  // Define a "worker" function that should eventually resolve or reject the deferred object.
  var loadImage = function(deferred) {
    var image = new Image();
     
    // Set up event handlers to know when the image has loaded
    // or fails to load due to an error or abort.
    image.onload = loaded;
    image.onerror = errored; // URL returns 404, etc
    image.onabort = errored; // IE may call this if user clicks "Stop"
     
    // Setting the src property begins loading the image.
    image.src = url;
     
    function loaded() {
      unbindEvents();
      // Calling resolve means the image loaded sucessfully and is ready to use.
      deferred.resolve(image);
    }
    function errored() {
      unbindEvents();
      // Calling reject means we failed to load the image (e.g. 404, server offline, etc).
      deferred.reject(image);
    }
    function unbindEvents() {
      // Ensures the event callbacks only get called once.
      image.onload = null;
      image.onerror = null;
      image.onabort = null;
    }
  };
   
  // Create the deferred object that will contain the loaded image.
  // We don't want callers to have access to the resolve() and reject() methods, 
  // so convert to "read-only" by calling `promise()`.
  return $.Deferred(loadImage).promise();
};

// Images Gallery: Replace images when hovered (thumbnail -> original)
var timerObj;
var delay = 500;

$('article a, span.thumb a, div.inner a.thumb img').mouseover(function(event) {
    timerObj = setTimeout(timer, delay);
    
    function timer() {
            
        var object = $(event.target);

       // $(event.target).each("img", function(){
            
        $(object).removeAttr("alt").removeAttr("title");
        var currentHeight = $(object).height();
        var origSource = $(object).attr('src');
        var source = origSource.replace('thumbnails','/images').replace('thumbnail_','');
        var types = ['.jpg','.png','.jpeg'];

        $.loadImage(source.replace(/.jpg|.png|.jpeg/g, types[0]))
            .done(function(image) {
            //alert("Loaded image: " + image.width + "x" + image.height);
            $(object).attr('src', source.replace(/.jpg|.png|.jpeg/g, types[0]));
        })
            .fail(function(image) {
            $.loadImage(source.replace(/.jpg|.png|.jpeg/g, types[1]))
                .done(function(image) {
                //alert("Loaded image: " + image.width + "x" + image.height);
                $(object).attr('src', source.replace(/.jpg|.png|.jpeg/g, types[1]));
            })
                .fail(function(image) {
                $.loadImage(source.replace(/.jpg|.png|.jpeg/g, types[2]))
                    .done(function(image) {
                    //alert("Loaded image: " + image.width + "x" + image.height);
                    $(object).attr('src', source.replace(/.jpg|.png|.jpeg/g, types[2]));
                })
                    .fail(function(image) {
                    //alert("Failed to load image");
                });
            });
        });
        
        $(object).height(currentHeight);
        
        //});
    }
})
.mouseout(function (event) {
        clearTimeout(timerObj);
});

// Image Detail Page: click on image to open it
if(($.urlParam('page') == 'post') && $.urlParam('s') == 'view')
{
    // Make image clickable and set the url to full size image
    var imgElement = $( "div#post-view > div#right-col > div > img" );
    //$(imgElement).replaceWith( '<a href="' + image.domain + '/' + image.base_dir + '/' + image.dir + '/' + image.img + '"><div id="img-container"><img src="'+ $(imgElement).attr('src') +'" /></div></a>' );
    $(imgElement).replaceWith( '<a href="' + image.domain + '/' + image.base_dir + '/' + image.dir + '/' + image.img + '"><div id="img-container"><img src="'+ image.domain + '/' + image.base_dir + '/' + image.dir + '/' + image.img +'" /></div></a>' );
    
    // Hide notice about image resizing
    $( "#resized_notice" ).hide();
}



// Image Detail Page: Rescale image to fill screen
style.push("div#content div.content #img-container {",
			"background-size: contain;",
			"background-repeat: no-repeat;",
			"height: 100%;",
"}");

style.push("div#content div.content #img-container img {",
			"max-height: 90%;",
"}");
       


// Common design fixes
style.push("div#page aside#sidebar div.sidebar3, div#content div.sidebar div.sidebar3 {width: auto;}",
"div#content div.sidebar input.secondary_search { max-width: 160px; width: 93%; }",
"div#content div.sidebar input.search_list { max-width: 154px !important; width: 90%; }",
//"div#content div.content#right-col, div#content div.content {float: right;}",
//"div#content div#post-view {display: flex;}",
"div#post-list { display: flex; }",
"div.sidebar { width: inherit; }",
"div#header table td { width: 100% }");

// Images Gallery: scale images to 250% when hovering //taken from dxbooru: dx's random tweaks to boorus
var val = 2.5;
style.push(
    "article:hover, span.thumb:hover, div.inner:hover {overflow: visible !important;}",
    "article:hover img, span.thumb:hover img, div.inner:hover a.thumb img.preview {",
    "  position: relative;",
    "  transform: scale("+val+");",
    "  -moz-trqansform: scale("+val+");",
    "  -webkit-transform: scale("+val+");",
    "  box-shadow: 0 0 5px rgba(0,0,0, 0.3), 0 0 15px 8px white;",
    "  z-index: 100;",
    "}"
);

GM_addStyle(style.join("\n"));