RSortBtn

Redditに独自のソート機能を追加する

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला Tampermonkey, Greasemonkey किंवा Violentmonkey यासारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला Tampermonkey किंवा Violentmonkey यासारखे एक्स्टेंशन इंस्टॉल करावे लागेल..

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला Tampermonkey किंवा Violentmonkey यासारखे एक्स्टेंशन इंस्टॉल करावे लागेल..

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

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला Tampermonkey यासारखे एक्स्टेंशन इंस्टॉल करावे लागेल..

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्क्रिप्ट व्यवस्थापक एक्स्टेंशन इंस्टॉल करावे लागेल.

(माझ्याकडे आधीच युझर स्क्रिप्ट व्यवस्थापक आहे, मला इंस्टॉल करू द्या!)

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला Stylus सारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला Stylus सारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला Stylus सारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्टाईल व्यवस्थापक इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्टाईल व्यवस्थापक इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्टाईल व्यवस्थापक इंस्टॉल करावे लागेल.

(माझ्याकडे आधीच युझर स्टाईल व्यवस्थापक आहे, मला इंस्टॉल करू द्या!)

// ==UserScript==
// @name         RSortBtn
// @namespace    r-sort-btn
// @version      0.1.3
// @description  Redditに独自のソート機能を追加する
// @include      *old.reddit.com*

// @exclude      /comments/
// @exclude      /Dashboard
// @exclude      com/toolbar/
// @exclude      com/tb/
// @grant        none
// ==/UserScript==


// 強制終了URL
//var url = location.href;
//if (url.match(/\/user\//) || url.match(/\/comments/) || url.match(/\/r\/Dashboard/) || url.match(/com\/toolbar\//) || url.match(/com\/tb\//)) {
//    exit();
//}

var btnSelectedBgColor = 'red';

$(function () {
    $('#siteTable').parent().prepend('<div id="rsbtnArea"></div>');
    $('#rsbtnArea').append('<button class="rsbtn" id="rsDefaultBtn">デフォルト</button>');
    $('#rsbtnArea').append('<button class="rsbtn rsbtnTypeSort" id="rsIkioiBtn">勢い順</button>');
    $('#rsbtnArea').append('<button class="rsbtn rsbtnTypeSort" id="rsCommentBtn">コメント数順</button>');
    $('#rsbtnArea').append('<button class="rsbtn rsbtnTypeSort" id="rsScoreBtn">スコア順</button>');
    $('#rsbtnArea').append('<button class="rsbtn rsbtnTypeSort" id="rsNewBtn">新着順</button>');
    $('#rsbtnArea').append('<button class="rsbtn rsbtnTypeTime" id="rs1hBtn">~1時間</button>');
    $('#rsbtnArea').append('<button class="rsbtn rsbtnTypeTime" id="rs3hBtn">~3時間</button>');
    $('#rsbtnArea').append('<button class="rsbtn rsbtnTypeTime" id="rs12hBtn">~12時間</button>');
    $('#rsbtnArea').append('<button class="rsbtn rsbtnTypeTime" id="rs24hBtn">~24時間</button>');
    $('#rsbtnArea').append('<button class="rsbtn rsbtnTypeTime" id="rs72hBtn">~72時間</button>');
    $('#rsbtnArea').append('<button class="rsbtn rsbtnTypeTime" id="rs1wBtn">~1週間</button>');
    
var ccc = 0;
    // 各サブミにソート情報付与
    $(".linklisting > .thing").each(function(i) {
        // 投稿時間
        var post_time = new Date($(this).find('time').attr('title'));
        // コメント数
        var comment_str = $(this).find('.comments').text();
        var comment_num = parseInt(comment_str);
        if (isNaN(comment_num)) {
            comment_num = 0;
        }
        
        ccc += comment_num;
        
        // 現在時間
        var now_time = new Date();
        // 経過時間
        var keika_fun = (now_time - post_time) / (1000 * 60);
        // 勢い計算
        var ikioi = (comment_num / keika_fun) * 60 * 24;
        ikioi *= 10;
        ikioi = Math.floor(ikioi);
        ikioi /= 10;
        // デフォルト
        var rank = $(this).find('.rank').text();
        var rank_num = parseInt(rank);
        if (isNaN(rank_num)) {
            rank_num = 0;
        }
        // スコア
        var unvoted = $(this).find('.score.unvoted').text();
        var unvoted_num = parseInt(unvoted);
        if (isNaN(unvoted_num)) {
            unvoted_num = 0;
        }

        // 属性挿入
        $(this).attr('ikioi', ikioi * 10);
        $(this).find('.entry').prepend('<span style="color:red; font-size: 1.2em; float: right; margin-left: 10px;">' + ikioi + '</span>');
        $(this).attr('comment_num', comment_num);
        $(this).attr('rank_num', rank_num);
        $(this).attr('unvoted_num', unvoted_num);
        $(this).attr('keika_fun', keika_fun);
        if (keika_fun <= 60) {
            $(this).attr('rs1hBtn', 'yes');
        }
        if (keika_fun <= 180) {
            $(this).attr('rs3hBtn', 'yes');
        }
        if (keika_fun <= 720) {
            $(this).attr('rs12hBtn', 'yes');
        }
        if (keika_fun <= 1440) {
            $(this).attr('rs24hBtn', 'yes');
        }
        if (keika_fun <= 4320) {
            $(this).attr('rs72hBtn', 'yes');
        }
        if (keika_fun <= 10080) {
            $(this).attr('rs1wBtn', 'yes');
        }
    });
});






$.fn.eachsort = function(cb) {
    return this.each(function(){
        return $(this).html(
            $(this).children('.thing').sort(cb)
        );
    });
}
$(function() {
    $('#rsDefaultBtn').click(function() {
        $('.rsbtn').css('background-color', '');
        $(".linklisting > .thing").show();
        $("#siteTable").eachsort(function(a, b) {
            return parseInt($(a).attr('rank_num'), 10) - parseInt($(b).attr('rank_num'), 10);
        });
    });
    $('#rsIkioiBtn').click(function() {
        $('.rsbtnTypeSort').css('background-color', '');
        $(this).css('background-color', btnSelectedBgColor);
        $("#siteTable").eachsort(function(a, b) {
            return parseInt($(b).attr('ikioi'), 10) - parseInt($(a).attr('ikioi'), 10);
        });
    });
    $('#rsCommentBtn').click(function() {
        $('.rsbtnTypeSort').css('background-color', '');
        $(this).css('background-color', btnSelectedBgColor);
        $("#siteTable").eachsort(function(a, b) {
            return parseInt($(b).attr('comment_num'), 10) - parseInt($(a).attr('comment_num'), 10);
        });
    });
    $('#rsScoreBtn').click(function() {
        $('.rsbtnTypeSort').css('background-color', '');
        $(this).css('background-color', btnSelectedBgColor);
        $("#siteTable").eachsort(function(a, b) {
            return parseInt($(b).attr('unvoted_num'), 10) - parseInt($(a).attr('unvoted_num'), 10);
        });
    });
    $('#rsNewBtn').click(function() {
        $('.rsbtnTypeSort').css('background-color', '');
        $(this).css('background-color', btnSelectedBgColor);
        $("#siteTable").eachsort(function(a, b) {
            return parseInt($(a).attr('keika_fun'), 10) - parseInt($(b).attr('keika_fun'), 10);
        });
    });
    $('#rs1hBtn').click(function() {
        $('.rsbtnTypeTime').css('background-color', '');
        $(this).css('background-color', btnSelectedBgColor);
        $(".linklisting > .thing").show();
        $(".linklisting > .thing:not([rs1hBtn]").hide();
    });
    $('#rs3hBtn').click(function() {
        $('.rsbtnTypeTime').css('background-color', '');
        $(this).css('background-color', btnSelectedBgColor);
        $(".linklisting > .thing").show();
        $(".linklisting > .thing:not([rs3hBtn]").hide();
    });
    $('#rs12hBtn').click(function() {
        $('.rsbtnTypeTime').css('background-color', '');
        $(this).css('background-color', btnSelectedBgColor);
        $(".linklisting > .thing").show();
        $(".linklisting > .thing:not([rs12hBtn]").hide();
    });
    $('#rs24hBtn').click(function() {
        $('.rsbtnTypeTime').css('background-color', '');
        $(this).css('background-color', btnSelectedBgColor);
        $(".linklisting > .thing").show();
        $(".linklisting > .thing:not([rs24hBtn]").hide();
    });
    $('#rs72hBtn').click(function() {
        $('.rsbtnTypeTime').css('background-color', '');
        $(this).css('background-color', btnSelectedBgColor);
        $(".linklisting > .thing").show();
        $(".linklisting > .thing:not([rs72hBtn]").hide();
    });
    $('#rs1wBtn').click(function() {
        $('.rsbtnTypeTime').css('background-color', '');
        $(this).css('background-color', btnSelectedBgColor);
        $(".linklisting > .thing").show();
        $(".linklisting > .thing:not([rs1wBtn]").hide();
    });
});