Booru Revamped

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

Versão de: 20/01/2021. Veja: a última versão.

Você precisará instalar uma extensão como Tampermonkey, Greasemonkey ou Violentmonkey para instalar este script.

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

Você precisará instalar uma extensão como Tampermonkey ou Violentmonkey para instalar este script.

Você precisará instalar uma extensão como Tampermonkey ou Userscripts para instalar este script.

Você precisará instalar uma extensão como o Tampermonkey para instalar este script.

Você precisará instalar um gerenciador de scripts de usuário para instalar este script.

(Eu já tenho um gerenciador de scripts de usuário, me deixe instalá-lo!)

Você precisará instalar uma extensão como o Stylus para instalar este estilo.

Você precisará instalar uma extensão como o Stylus para instalar este estilo.

Você precisará instalar uma extensão como o Stylus para instalar este estilo.

Você precisará instalar um gerenciador de estilos de usuário para instalar este estilo.

Você precisará instalar um gerenciador de estilos de usuário para instalar este estilo.

Você precisará instalar um gerenciador de estilos de usuário para instalar este estilo.

(Eu já possuo um gerenciador de estilos de usuário, me deixar fazer a instalação!)

// ==UserScript==
// @name       Booru Revamped
// @namespace  westerhold78
// @version    1.2.0
// @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/*
// @include     *://yande.re/*
// @include     *yande.re/*
// @include     *://www.yande.re/*
// @require     http://code.jquery.com/jquery-3.5.1.min.js
// @icon        
// @copyright  2017, westerhold78
// @grant    GM_addStyle
// @grant    GM_xmlhttpRequest
// ==/UserScript==

var jQuery = window.jQuery;
var style = [];
var newTabForDetailPage = true;
var zoomScale = 2.0;
var zoomDelay = 0.4
var imageTypes = ['.jpg', '.png','.jpeg','.gif'];
var thumbnailPreviewClass = 'thumbnail-preview';
var hostname = window.location.hostname;

function loadImage(image, url, imageWidth = 0, extension = 0) {
    var downloadingImage = new Image();

    downloadingImage.onload = function(){
        jQuery(image).attr('src', this.src);
        jQuery(image).attr('width', imageWidth);
        jQuery(image).addClass('loaded');
    }
    downloadingImage.onerror = function() {
        var newExtension = ++extension;
        if(newExtension < imageTypes.length){
            loadImage(image, url, imageWidth, newExtension);
        }
    }
    downloadingImage.src = url.substring(0, url.lastIndexOf('.')) + imageTypes[extension];
}

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

// If you need to use another JavaScript library alongside jQuery, return control of $ back to the other library with a call to $.noConflict(). Old references of $ are saved during jQuery initialization; noConflict() simply restores them.
jQuery.noConflict();
(function( $ ) {
  $(function() {
    // Code that uses jQuery's $ can follow here.
    'use strict';

    if(urlParam('s') == 'view') {
        var image = $('#image');
        var top = image.offset().top;
        var url = $(image).attr('src');
        if(url.includes('samples/')) {
            url = url.replace('samples', 'images')
            .replace('sample_', '');
            loadImage(image, url);
        }
        window.scrollTo({ top: top, behavior: 'smooth' });
    }

    //Replace thumbnails
    $(`.${thumbnailPreviewClass} img, #post-list-posts img`).hover(function(event) {
        var image = $(event.target);
        if (!$(image).hasClass("loaded")) {
            var imageInnerWidth = $(image).innerWidth();

            // remove tooltip
            $(image).attr('title','');

            //replace url
            var patternFileExtension = /(\.[0-9a-z]+$)/i;
            //var patternDomain = /^https:\/\/((?:[\w\-\_]+\.)+(?:gelbooru|yande).(com|re))/;
            var patternDomain = /^(http:\/\/www\.|https:\/\/www\.|http:\/\/|https:\/\/)?(.*).(gelbooru|yande).(com|re)/;
            var url = $(image).attr('src');
            switch (hostname) {
                case 'yande.re':
                    url = url
                        .replace(patternDomain, '$1files.$3.$4/')
                        .replace(/\/data\/preview\/(.*)\/(.*)\//, 'sample/')
                        .replace(patternFileExtension, '/$1');
                    break;
                case 'gelbooru.com':
                    url = url
                        .replace(patternDomain, '$1img2.$3.$4/images')
                        .replace('thumbnails', 'images')
                        .replace('thumbnail_', '');
                    break;
            }
            loadImage(image, url, imageInnerWidth);
        }
    });

    // Open image in new tab
    $('#image').click(function() {
        window.open($(this)[0].src, '_self');
    });

    // Open detail page in new tab
    if(newTabForDetailPage) {
        $('.thumbnail-preview a, #post-list-posts li .thumb').on('click', function(e){
            e.preventDefault();
            var url = $(this).attr('href');
            window.open(url, '_blank');
        });
    }
  });
})(jQuery);

style.push(
    `.${thumbnailPreviewClass}:hover, #post-list-posts img:hover { transform: scale(${zoomScale}); -moz-transform: scale(${zoomScale}); -webkit-transform: scale(${zoomScale}); transition-delay: ${zoomDelay}s; transition-property: transform; }`,
    `#post-list-posts .inner { overflow: visible !important; }`,
    `img#image { cursor: pointer; width: unset !important; max-width: 100%; max-height: 90vh; }`
);

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