Bierdopje Move

Allows you to move and position the blocks on the homepage.

Dovrai installare un'estensione come Tampermonkey, Greasemonkey o Violentmonkey per installare questo script.

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

Dovrai installare un'estensione come Tampermonkey o Violentmonkey per installare questo script.

Dovrai installare un'estensione come Tampermonkey o Userscripts per installare questo script.

Dovrai installare un'estensione come ad esempio Tampermonkey per installare questo script.

Dovrai installare un gestore di script utente per installare questo script.

(Ho già un gestore di script utente, lasciamelo installare!)

Dovrai installare un'estensione come ad esempio Stylus per installare questo stile.

Dovrai installare un'estensione come ad esempio Stylus per installare questo stile.

Dovrai installare un'estensione come ad esempio Stylus per installare questo stile.

Dovrai installare un'estensione per la gestione degli stili utente per installare questo stile.

Dovrai installare un'estensione per la gestione degli stili utente per installare questo stile.

Dovrai installare un'estensione per la gestione degli stili utente per installare questo stile.

(Ho già un gestore di stile utente, lasciamelo installare!)

// ==UserScript==
// @name         Bierdopje Move
// @namespace    http://www.bierdopje.com
// @version      1.1
// @description  Allows you to move and position the blocks on the homepage.
// @match        http://*.bierdopje.com/
// @grant        unsafeWindow
// @require      http://code.jquery.com/jquery-1.10.2.js
// @require      http://code.jquery.com/ui/1.11.4/jquery-ui.js
// @author       Tom
// @copyright    2016+, Tom
// ==/UserScript==
/* jshint -W097 */
/* global $, console */
'use strict';

$(function() {
    // Change cursor on block headers
    $(".header").css('cursor', 'pointer');

    // Fix position of the billboard.
    const billboardStyle = {
        position: "relative",
        top:      "5px",
        left:     "15px"
    };
    $("#billboards").css(billboardStyle);

    // Identify and add appropriate classes to the columns and blocks.
    const col1 = $("#col1");
    const col2 = $("#col2");

    col1.addClass("sortable1");
    col2.addClass("sortable2");

    // Find each block and add their state + make them serializable.
    $('.sortable1 .block').each((i, obj) => {
        $(obj).addClass("ui-state-default");
        $(obj).attr('id', "i_" + (i+1));
    });
    $('.sortable2 .block').each((j, obj) => {
        $(obj).addClass("ui-state-default");
        $(obj).attr('id', "j_" + (j+1));
    });

    // Load the blocks collapse state.
    var collapsedBlocks = getCollapsedBlocks();
    restoreCollapsedBlocks(collapsedBlocks);

    // Load the blocks in the right order.
    restoreOrder();

    col1.addClass("connectedSortable");
    col2.addClass("connectedSortable");

    // Collapsing feature
    $('.sortable1 > .block > .header').click(function() {
        collapseFeature($(this));

        return false;
    });
    $('.sortable2 > .block > .header').click(function() {
        collapseFeature($(this));

        return false;
    });

    function collapseFeature(me) {
        var body = me.next();
        var blockId = me.parent().attr("id");

        body.slideToggle("slow", function() {
            if (body.is(":hidden")) {
                collapsedBlocks.push(blockId);
                console.log("hiddenarray: " + collapsedBlocks);
            } else {
                collapsedBlocks = deleteFromArrayByValue(collapsedBlocks, blockId);
                console.log("visiblearray: " + collapsedBlocks);
            }

            const jsonValue = JSON.stringify(collapsedBlocks);
            localStorage.setItem("collapsedBlocks", jsonValue);
        });
    }

    function getCollapsedBlocks() {
        const collapsedBlocks = localStorage.getItem("collapsedBlocks");

        if (collapsedBlocks == null) {
            console.log("Found no collapsedBlocks.");
            return [];
        }

        console.log("Found data in collapsedBlocks: " + collapsedBlocks);
        return JSON.parse(collapsedBlocks);
    }

    function restoreCollapsedBlocks(cBlocks) {
        for (let i = 0; i < cBlocks.length; i++) {
            var target = document.getElementById(cBlocks[i]);
            $(target).children(".body").hide();
        }
    }

    function deleteFromArrayByValue(array, value) {
        // todo?:
        // https://api.jquery.com/jQuery.inArray/
        var i = array.length;
        while (i--) {
            if (array[i] === value) {
                array.splice(i, 1);
            }
        }

        return array;
    }

    // Actual sorting.
    $(".sortable1, .sortable2").sortable({
        connectWith: ".connectedSortable",
        cursor:    "move",
        handle:    ".block_title",
        items :    ".ui-state-default",
        update: function (event, ui) {
            var cooked1 = [];
            var cooked2 = [];
            $(".sortable1").each(function(index, domEle) {
                    cooked1[index] = $(domEle).sortable('toArray', {key: 'i', attribute: 'id'});
                }
            );
            $(".sortable2").each(function(index, domEle) {
                    cooked2[index] = $(domEle).sortable('toArray', {key: 'j', attribute: 'id'});
                }
            );
            localStorage.setItem("blockOrder1", cooked1.join('|'));
            localStorage.setItem("blockOrder2", cooked2.join('|'));
        }
    });

    function restoreOrder() {
        const order1 = localStorage.getItem("blockOrder1");
        const order2 = localStorage.getItem("blockOrder2");
        if (!order1 || !order2) return;

        console.log("order1: " + order1);
        console.log("order2: " + order2);

        var SavedID1 = order1.split('|');
        var SavedID2 = order2.split('|');

        for (let u = 0, ul=SavedID1.length; u < ul; u++) {
            SavedID1[u] = SavedID1[u].split(',');
        }
        for (let u = 0, ul=SavedID2.length; u < ul; u++) {
            SavedID2[u] = SavedID2[u].split(',');
        }
        for (let Scolumn = 0, n = SavedID1.length; Scolumn < n; Scolumn++) {
            for (let Sitem = 0, m = SavedID1[Scolumn].length; Sitem < m; Sitem++) {
                console.log(" checking first column " + SavedID1[Scolumn][Sitem]);

                if (SavedID1[Scolumn][Sitem].indexOf("i") >= 0) {
                    console.log("found i");
                    $(".sortable1").eq(Scolumn).append($(".sortable1").children("#" + SavedID1[Scolumn][Sitem]));
                } else {
                    console.log("found j (other column)");
                    $(".sortable1").eq(Scolumn).append($(".sortable2").children("#" + SavedID1[Scolumn][Sitem]));
                }
            }
        }
        for (let Scolumn = 0, n = SavedID2.length; Scolumn < n; Scolumn++) {
            for (let Sitem = 0, m = SavedID2[Scolumn].length; Sitem < m; Sitem++) {
                console.log(" checking second column " + SavedID2[Scolumn][Sitem]);

                if (SavedID2[Scolumn][Sitem].indexOf("i") >= 0) {
                    console.log("found i (other column)");
                    $(".sortable2").eq(Scolumn).append($(".sortable1").children("#" + SavedID2[Scolumn][Sitem]));
                } else {
                    console.log("found j");
                    $(".sortable2").eq(Scolumn).append($(".sortable2").children("#" + SavedID2[Scolumn][Sitem]));
                }
            }
        }
    }
});