Xchan Gold Alpha

Experimental script to enhance xchan.pw

// ==UserScript==
// @name         Xchan Gold Alpha
// @version      0.0.1.0
// @description  Experimental script to enhance xchan.pw
// @include      https://xchan.pw/*
// @include      http://xchan.pw/*
// @require 	 https://cdn.jsdelivr.net/jquery.timeago/1.4.1/jquery.timeago.js
// @namespace https://greasyfork.org/users/2657
// ==/UserScript==

//////////////////////////////////////////


$("<style>").text("iframe{display:inline-block;} .canfly{position:fixed;left:-600px;}.contentview {position:fixed;top:10px;left:-2048px;} iframe{display:inline-block;} .previewbox{position:fixed;bottom:10px;left:-150px;} .mbutton:hover{color:orange;width:100%;} .mbutton, .tbutton{cursor:pointer;cursor:hand;transition: color 0.5s ease;transition: width 0.5s ease;background: black;margin: 2px;padding: 2px;color: grey;font-size: 15px;font-weight: bold;    display: inline-block;    width: 90%;    font-family: monospace;} .tbutton{color:gold;font-size: 17px;width:100%;} .woptions{width:65px;height:63px;position:fixed;top:10px;right:30px;cursor:pointer;cursor:hand;transition: background-image 0.5s ease;} .selm{color:white;width:100%;} .wmenu{position:fixed;width:250px;height:900px;top:-900px;right:100px;background:grey;}").appendTo("head");

//Menu and Options System
//Images
var wrenchhover = '';
var wrench = '';

var button = $('<div class="woptions"></div>').css("background-image", "url("+wrench+")");
$('body').append(button);

$(document).on('mouseenter', ".woptions", function () {
    $(this).css("background-image", "url("+wrenchhover+")");
});

$(document).on('mouseleave', ".woptions", function () {
    $(this).css("background-image", "url("+wrench+")");
});

//Menu
var menu = $('<div class="wmenu"><div class="tbutton">XGold:</div><br><br></div>');
var menuoptions = ['Catálogo', 'Backlinks', 'Formatador de Texto','Pré-exibir Imagens', 'Detector de Batatas','Trip Checkbox', 'Tempo Relativo', 'Exibir 50 posts', 'Fundir /e/', 'Mostrar títulos de Youtube', 'Meta Hovers'];

for (i = 0; i < menuoptions.length; i++) {
    $(menu).append('<div class="mbutton" id="m'+i+'">'+menuoptions[i]+'</div><br>');
}

$('body').append(menu);

$(document).on('click', ".woptions", function () {
    if ($(this).hasClass('wopen')){
        $('.wmenu').animate({top: "-900px", }, 1000 );
        $(this).removeClass('wopen');
    } else {
        $('.wmenu').animate({top: "0px", }, 1000 );
        $(this).addClass('wopen');
    }
});

$(document).on('click', ".mbutton", function () {
    if ($(this).hasClass('selm')){
        $(this).removeClass('selm');
        if (fun[$(this).attr('id')]){
            fun[$(this).attr('id')]('r');
        };
    }else{
        $(this).addClass('selm');
        if (fun[$(this).attr('id')]){
            fun[$(this).attr('id')]();
        };
    }

    saveoptions();
});

//OptionLoader
var activeoptions = "none,m1,m2,m3,m4,m5,m6,m9"; //Default Options

if (localStorage.getItem("xgoptions")) { activeoptions = localStorage.getItem("xgoptions");}
activeoptions = activeoptions.split(',');
for (n = 0; n < activeoptions.length; n++) {
    $('#'+activeoptions[n]+'').addClass('selm');
}

//OptionSaver
function saveoptions(){
    var ids = ["none"];
    $('.selm').each(function(){ids.push($(this).attr('id'))});
    localStorage.setItem("xgoptions", ids.toString())
}
saveoptions();

//Functions

//floatcontent
function float(){
    $('.thumb').each(function(){
        url = $(this).parent().parent().attr('href');
        $(this).parent().unwrap().wrap('<div class="nthumb" href="'+url+'" style="cursor: pointer; cursor: hand;"></div>');
    });
    $('.filesize').find('a').attr('onclick', '').attr('target', '_blank');
}



$(document).on('click', ".nthumb", function () {
    if ($(this).attr('href').indexOf('.webm') >= 1){
        var content = $('<div class="contentview"></div>')    
        $(content).css('left', '-2000px').html('').append('<div class="fimg" style="cursor: pointer; cursor: hand;color:grey;background-color:black;font-weight:bold;font-family: monospace;    font-size: 15px;    display: inline-block;    float: right;">[Fechar]</div><br><video src="'+$(this).attr('href')+'" loop controls style="min-width:50px;min-heigth:50px;max-width:99%;max-height:99vh;">').animate({left: "10px", }, 1000 );
        $('body').append(content);
    } else{
        var content = $('<div class="contentview"></div>')    
        $(content).css('left', '-2000px').html('').append('<img class="fimg" src="'+$(this).attr('href')+'" style="min-width:50px;min-heigth:50px;max-width:99%;max-height:99vh;background-color: rgba(196, 196, 196, 0.5);">').animate({left: "10px", }, 1000 );
        $('body').append(content);
    };
$('.contentview').draggable();
});

$(document).on('click', ".fimg", function () {
    //$(this).parent().animate({left: "-2000px", }, 1000 );
    //setTimeout("$(this).parent().remove()", 1000)
    $(this).parent().remove();
});

//TimeAgo

function reltime(r) {
    if (r){
        $('.time').remove();
    } else {
        $('.time').remove();
        $( "label:contains('@')" ).each(function() {
            var vovar = $(this).contents().map(function() {
                if( this.nodeType === 3 ) {
                    return this.data;
                }
            }).get().join('');

            vovar1 = vovar.split("@");
            vovardate = vovar1[0].split("/");
            vovaryear = vovardate[2].split(" ");
            vovarmonth = vovardate[1] - 1;
            vovartime = vovar1[1].split(":");
            tiem = new Date(vovaryear[0], vovarmonth, vovardate[0], vovartime[0], vovartime[1])
            tiemiso = tiem.toISOString();
            tiemago = jQuery.timeago(tiemiso); 

            $( this ).append( '<span class="time">( <bold>' + tiemago + ' </bold>)</span>' );
        });    
    };
};



//Detector de Batatas


function batata(r){ 
    if (r){
        $('.reply').css('background-image', '');
    } else {
        $('.postername:contains("Semi"), .postername:contains("Se‭‭mi")').parent().parent().css('background-image', 'url(\"http://a.pomf.se/rcqfit.png\")');
        $('.postertrip:contains("hKvr")').parent().parent().css('background-image', 'url(\"http://a.pomf.se/ndnvht.png\")');
        $('blockquote:contains("…"), blockquote:contains("daí"), blockquote:contains("Coë")' ).parent().css('background-image', 'url(\"http://a.pomf.se/aopqpg.jpg\")');
    };
}; 

//Catalogo
$("<style>").text(".catalogimg > img {max-width:100%;max-height:100%;} .catalogitem {margin-bottom:10px;}").appendTo("head");

function catalog(r){
    if (r){
        $('.catalog').remove();
    } else {
        $('.catalog').remove();
        $('body').prepend('<div class="catalog" style="background: dimgray;border: solid 1px;overflow-y:scroll;overflow-x:hidden;width:240px;height:650px;position:fixed;top:100px;left:-300px;"><table id="catalogt"><tbody><div class="closecat hov" style="font-size: 15px;font-weight: bold;position:fixed;top:80px;left:10px;color:red;font-size:11px;cursor: pointer; cursor: hand;">Abrindo catálogo...</div></tbody></table></div>');
        $.get("https://xchan.pw/b/catalog.html", function (data) {
            $(data).find('a[class^="ref|"]').each(function () {
                var href = $(this).attr('href');
                var c = $(this).attr("class").split('|'); 
                var d = $("<span></span>").addClass('catalogimg').attr({
                    style : "max-width:220px;background:#F7F7F7;"
                });
                var g = $("<div></div>").addClass('catalogtext').attr({
                    style : "overflow-x:hidden;overflow-y:scroll;max-height:200px;max-width:220px;background:#F7F7F7;"
                });
                $.get(ku_boardspath + '/read.php?b=' + c[1] + '&t=' + c[2] + '&p=' + c[3] + '&single', {}, function (a, b) {
                    if (b != "success") {
                        alert('wut')
                    } else {

                        if (a) {
                            var z = $('<img />').html(a).find('.thumb').removeClass();
                            var y = $('<blockquote>').html(a).find('blockquote');                        

                            d.html(z);
                            g.html(y);
                            $('.catalog').animate({left: "5px", }, 1000 );
                            $('.closecat').remove();

                        } else {
                            d.html(_("something went wrong (blank response)"))
                        }
                    }
                })       




                var wrap = $("<div></div>").addClass('catalogitem').append(d).wrapInner('<a href='+ href +'>').append(g);
                $('#catalogt').append(wrap);
            });

        });
    };
};



//Text Formatting
jQuery.fn.extend({
    insertAtCaret: function(myValue, myValueE){
        return this.each(function(i) {
            if (document.selection) {
                //For browsers like Internet Explorer
                this.focus();
                sel = document.selection.createRange();
                sel.text = myValue + myValueE;
                this.focus();
            }
            else if (this.selectionStart || this.selectionStart == '0') {
                //For browsers like Firefox and Webkit based
                var startPos = this.selectionStart;
                var endPos = this.selectionEnd;
                var scrollTop = this.scrollTop;
                this.value = this.value.substring(0,     startPos)+myValue+this.value.substring(startPos,endPos)+myValueE+this.value.substring(endPos,this.value.length);
                this.focus();
                this.selectionStart = startPos + myValue.length;
                this.selectionEnd = ((startPos + myValue.length) + this.value.substring(startPos,endPos).length);
                this.scrollTop = scrollTop;
            } else {
                this.value += myValue;
                this.focus();
            }
        })
    }
});

function textformat(r){
    if (r){
        $('.stylebar, .sb').remove();
    } else {
        $('textarea[id="qr_message"]').after('<br class="stylebar">');
        $('.stylebar').after('<input class="formbutton_SS sb" type="button" value="Spoiler" /><input class="formbutton_B sb" type="button" value="B" /><input class="sb formbutton_R" type="button" value=">" /><input class="sb formbutton_S" type="button" value="S" /><input class="sb formbutton_I" type="button" value="I" /><input class="sb formbutton_C" type="button" value="Code" />');
        $('.formbutton_I').css('font-style', 'italic');
        $('.formbutton_S').css('text-decoration', 'line-through');
        $('.formbutton_R').css('color', 'green');
        $('.formbutton_B').css('font-weight', 'bold');
        $('.formbutton_SS').css('font-weight', 'bold');
    };


    $('.formbutton_C').on('click', function(){ 
        $('textarea[id="qr_message"]').insertAtCaret("[code]", "[/code]");
    });
    $('.formbutton_I').on('click', function(){ 
        $('textarea[id="qr_message"]').insertAtCaret("[i]", "[/i]");
    });
    $('.formbutton_S').on('click', function(){ 
        $('textarea[id="qr_message"]').insertAtCaret("[s]", "[/s]");
    });
    $('.formbutton_R').on('click', function(){ 
        $('textarea[id="qr_message"]').insertAtCaret(">", "");
    });
    $('.formbutton_B').on('click', function(){ 
        $('textarea[id="qr_message"]').insertAtCaret("[b]", "[/b]");
    });

    $('.formbutton_SS').on('click', function(){ 
        $('textarea[id="qr_message"]').insertAtCaret("[spoiler]", "[/spoiler]");
    });
};

//Tripbox
function tripbox(r){
    if (r){
        $( '#qr_name, input[name="name"]:first' ).unwrap();
        $('.new, .qrnew, .namecheck').remove();
        //$('#qr_name, input[name="name"]').get(0).type = 'text';

    }else{


        $( 'input[name="name"]:first' ).wrap( '<span class="new"></span>' );
        $( '#qr_name' ).wrap( '<span class="qr_new"></span>' );
        $( '.new' ).append( '<input type="checkbox" class="namecheck" value="Bike" checked="checked">' );
        if (localStorage.getItem("namecheck") === null) {}else{$( ".namecheck" ).prop( "checked", false ); $( 'input[name="name"], #qr_name' ).prop('disabled',true);};

        $(document).on('change', ".namecheck", function() {
            if ( $( '.namecheck' ).prop( "checked" ) ) {$( 'input[name="name"], #qr_name' ).prop('disabled',false); localStorage.removeItem('namecheck');}else{$( 'input[name="name"], #qr_name' ).prop('disabled',true); localStorage.setItem('namecheck', '');};
        });
    };
};

//Backlinks

function showpreview(r){
    if (r){
        $('.previewbox').remove();
    } else {
        $('.previewbox').remove();
        $('body').append('<div class="previewbox"></div>');
    };
};

$('input[name="imagefile"]').change(function () {
    if ($('#m3').hasClass('selm')){
        $('.previewbox').css('left', '-150px');
        $('.previewbox').animate({left: "50px", }, 1000 );
        if (window.FileReader) {
            var Reader = new FileReader();
            var file = this.files[0];
            window.file2 = file;
            var previewarea = $('.previewbox');

            if (file.type.indexOf("video") > -1) { 

                previewarea.html('');                
                Reader.onload = function (event) {
                    previewarea.append([' <video width="200" height="200" autoplay muted controls loop><source src="'+ event.target.result +'" type="'+ window.file2.type +'">Your browser does not support the video tag.</video>'].join(''));
                }
                Reader.readAsDataURL(file);    

            } else {

                previewarea.html('');
                Reader.onload = function (event) {
                    previewarea.show().append(['<img style="max-height:200px;max-width:200px;" src="' + event.target.result + '" alt="">'].join(''));
                }
                Reader.readAsDataURL(file);
            };
        }

    };

});

function backlinks(r) {
    if (r){
        $('.protect').removeClass('protect');
        $('a[rem="1"]').remove();
    }else{
        $('#delform').find(".reply").not('.protect').each(function() {
            blink($(this));
        });
        $('.floater, .hold').find(".reply").not('.protect').each(function() {
            blink($(this));
        });
    };
};

function blink(t){   
    t.addClass('protect');
    rid = t.attr('id').replace('reply','');
    datas = t.find('.reflink').find("a:nth-child(2)").attr('href');
    t.find("a[class^='ref|']").each(function() {
        var quoted = $(this).text();            
        quoteds = quoted.replace('>>','');
        backquote(quoteds, rid, datas);
    });   
};

function backquote(quoteds, rid, datas){    
    splicer = datas.replace('.html#i','/');    
    splicer2 = splicer.split('/');
    $(".reflink:contains('" +quoteds+ "')").after('<a rem="1" href="/'+splicer2[1]+'/res/'+splicer2[3]+'.html#'+rid+'" onclick="return highlight(\''+rid+'\', true);" class="ref|'+splicer2[1]+'|'+splicer2[3]+'|'+rid+'">&gt;&gt;'+rid+'</a>');

};

// Youtube Title Loader

$(document).on('mouseenter', 'a[href*="youtube.com/watch?"], a[href*="youtu.be"]', function() {
    if ($('#m9').hasClass('selm')){
        url = extractVideoID($(this).attr('href'));
        $(this).replaceWith('<iframe src="https://www.youtube.com/v/'+url+'" width="300px" height="25px" ></iframe><div class="mask" style="display:inline-block;">OPEN </div>');
    };
});


function extractVideoID(url){
    var regExp = /^.*((youtu.be\/)|(v\/)|(\/u\/\w\/)|(embed\/)|(watch\?))\??v?=?([^#\&\?]*).*/;
    var match = url.match(regExp);
    if ( match && match[7].length == 11 ){
        return match[7];
    }else{
        return url;
    }
}

$(document).on('click', ".mask", function() {
    $('<br><div class="vp canfly" style="cursor: pointer; cursor: hand;display:inline-block;background:grey;height:500px;"></div>').appendTo('.logo');
    $(this).prev().clone().attr('height', '480x').attr('width', '600px').appendTo('.vp');
    $('.vp').prepend('<div class="killvid" style="background:orange;display:inline;">[Fechar]</div><br>');
    jQuery('html,body').animate({scrollTop:0},0);
    $('.vp').animate({left: "10px", }, 1000 ).draggable();

}); 

$(document).on('click', ".killvid", function() {
    $(this).parent().remove();
    $(this).remove();
}); 



//Save functions in Array
var fun = {
    m1:backlinks,
    m5:tripbox,
    m3:showpreview,
    m2:textformat,
    m0:catalog,
    m4:batata,
    m6:reltime,
}

function start(){
    $('.selm').each(function(){
        if (fun[$(this).attr('id')]){
            fun[$(this).attr('id')]();
        };
    });
    float();
};
start();

var funloop = {
    m1:backlinks,
    m4:batata,
    m6:reltime
};

//Run All Active Options
function loop(){
    $('.selm').each(function(){
        if (funloop[$(this).attr('id')]){
            funloop[$(this).attr('id')]();
        };
    });
    float();
};
//loop();
//Default Stuff

//Protect Trip
$('input[name="name"]').get(0).type = 'password';

$( 'input[name="name"]' ).focus(function() {
    $('#qr_name, input[name="name"]').get(0).type = 'text';
});

$( 'input[name="name"]' ).focusout(function() {
    $('#qr_name, input[name="name"]').get(0).type = 'password';
});


//Live Index

//live index

var window_focus;

$(window).focus(function() {
    window_focus = true;
    unnotify();
})
    .blur(function() {
    window_focus = false;
});


function unnotify(){
    $('link[href*="favicon"]').remove()
    $('#favicon').remove();
    $('head').append('<link href="https://i.imgur.com/AB4G76Z.png" id="favicon" rel="shortcut icon">');
};
unnotify();

function notify(){
    if (window_focus){}else{
        $('#favicon').remove();
        $('head').append('<link href="https://i.imgur.com/TirPmur.png" id="favicon" rel="shortcut icon">');
    };
};
//JavaReset

function loadjscssfile(filename, filetype){
    if (filetype=="js"){ //if filename is a external JavaScript file
        var fileref=document.createElement('script')
        fileref.setAttribute("type","text/javascript")
        fileref.setAttribute("src", filename)
    }
    else if (filetype=="css"){ //if filename is an external CSS file
        var fileref=document.createElement("link")
        fileref.setAttribute("rel", "stylesheet")
        fileref.setAttribute("type", "text/css")
        fileref.setAttribute("href", filename)
    }
    if (typeof fileref!="undefined")
        document.getElementsByTagName("head")[0].appendChild(fileref)
        }

function javareset(){
    $('script[src*="xchan.js"], script[src*="kusaba.js"]').remove();
    loadjscssfile("https://xchan.pw/lib/javascript/kusaba.js", "js")
    loadjscssfile("https://xchan.pw/lib/javascript/xchan.js", "js")
    //$('head').append('<script type="text/javascript" src="https://xchan.pw/lib/javascript/kusaba.js"></script>');
    //$('head').append('<script type="text/javascript" src="https://xchan.pw/lib/javascript/xchan.js"></script>');
};



//Updater
var highest = -Infinity;
var compareme = 99999999999999999;
window.updateid = "";

function initupdate(){    
    var highest = -Infinity;
    $('#delform').find("input[name='post[]']").each(function() {
        splice = $(this).attr('value');
        numb = parseInt(splice)
        highest = Math.max(highest, parseFloat(numb));        
    });
    return highest;
};

initupdate();

function update(){
    var compareme = 0;    
    $.get("" + document.location, function (data) {        
        $(data).find("input[name='post[]']").each(function() {
            splice = $(this).attr('value');
            numb = parseInt(splice)

            compareme = Math.max(compareme, parseFloat(numb));
            window.updateid = compareme;
        });
    });
};



setInterval(function () { 
    update();
    if (window.updateid > initupdate()){
        $.get("" + document.location, function (data) {        
            $("#delform").replaceWith($(data).filter("#delform"));
        }).done(function() {
            if (! window_focus){notify();};
            loop();
            javareset()

        });
    };
    reltime();  
}, 10000);