// ==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("Semi")').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+'">>>'+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);