Gelbooru Revamped

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

Ajankohdalta 8.3.2017. Katso uusin versio.

You will need to install an extension such as Tampermonkey, Greasemonkey or Violentmonkey to install this script.

You will need to install an extension such as Tampermonkey to install this script.

You will need to install an extension such as Tampermonkey or Violentmonkey to install this script.

You will need to install an extension such as Tampermonkey or Userscripts to install this script.

You will need to install an extension such as Tampermonkey to install this script.

You will need to install a user script manager extension to install this script.

(I already have a user script manager, let me install it!)

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

(I already have a user style manager, let me install it!)

// // ==UserScript==
// @name       Gelbooru Revamped
// @namespace  westerhold78
// @version    0.6
// @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>' );
    
    // 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%;",
           	"position: absolute;",
"}");*/
/*
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"));