Bierdopje Move

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

スクリプトをインストールするには、Tampermonkey, GreasemonkeyViolentmonkey のような拡張機能のインストールが必要です。

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

スクリプトをインストールするには、TampermonkeyViolentmonkey のような拡張機能のインストールが必要です。

スクリプトをインストールするには、TampermonkeyUserscripts のような拡張機能のインストールが必要です。

このスクリプトをインストールするには、Tampermonkeyなどの拡張機能をインストールする必要があります。

このスクリプトをインストールするには、ユーザースクリプト管理ツールの拡張機能をインストールする必要があります。

(ユーザースクリプト管理ツールは設定済みなのでインストール!)

このスタイルをインストールするには、Stylusなどの拡張機能をインストールする必要があります。

このスタイルをインストールするには、Stylus などの拡張機能をインストールする必要があります。

このスタイルをインストールするには、Stylus tなどの拡張機能をインストールする必要があります。

このスタイルをインストールするには、ユーザースタイル管理用の拡張機能をインストールする必要があります。

このスタイルをインストールするには、ユーザースタイル管理用の拡張機能をインストールする必要があります。

このスタイルをインストールするには、ユーザースタイル管理用の拡張機能をインストールする必要があります。

(ユーザースタイル管理ツールは設定済みなのでインストール!)

このスクリプトの質問や評価の投稿はこちら通報はこちらへお寄せください
// ==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]));
                }
            }
        }
    }
});