// ==UserScript== // @name Le Upboat! xD // @version 0.0.0.1 // @namespace leupboat // @description Vote on posts on /g/. // @license CC0; https://creativecommons.org/publicdomain/zero/1.0/. // @grant GM_xmlhttpRequest // @include *://boards.4chan.org/g/* // @run-at document-end // @downloadURL none // ==/UserScript== (function() { var debug = false; var imageData = { downOff: '', downOn: '', upOff: '', upOn: '' }; var debuglog = function(str) { if (debug) { console.log(str); } } var makeImage = function(src) { var image = new Image(); image.src = src; return image; } var serverRequest = function(postNumber, vote, outputElement, successCallback) { debuglog(postNumber); debuglog(vote); successCallback = successCallback || function(){}; var onloadFunc = function(request) { debuglog('onload'); if (request.status >= 200 && request.status < 400){ // Success! debuglog('ok'); data = JSON.parse(request.responseText); if (vote) { if (!data.voted) { window.alert('Already voted on this post.'); } } debuglog('request complete for ' + postNumber); outputElement.innerHTML = data.score; successCallback(); } else { debuglog('fail'); debuglog(request.status); // We reached our target server, but it returned an error } }; var onerrorFunc = function() { // There was a connection error of some sort }; debuglog('funcs'); requestUrl = "http://demo-zhmcas.webscript.io/script?id=" + postNumber; if (vote) { requestUrl += "&vote=" + vote; } GM_xmlhttpRequest({ method: "GET", url: requestUrl, onload: onloadFunc }); } var getScore = function(postNumber, outputElement) { serverRequest(postNumber, false, outputElement); } var vote = function(postNumber, vote, outputElement, successCallback) { serverRequest(postNumber, vote, outputElement, successCallback); } var makeArrow = function(postId, outputElement, t, imageOn, imageOff) { var arrow = document.createElement("a"); arrow.href = "#" + postId; var image = makeImage(imageOn); arrow.image = image; arrow.class = t + "arrow"; arrow.appendChild(image); return arrow; } var makeArrows = function(postId, outputElement) { var postNumber = postId.substring(1); var arrows = document.createElement("span"); var upArrow = makeArrow(postId, outputElement, "up", imageData.upOn, imageData.upOff); var downArrow = makeArrow(postId, outputElement, "down", imageData.downOn, imageData.downOff); var makeOnclick = function(t) { return function() { vote(postNumber, t, outputElement, function() { debuglog('callback called'); upArrow.image.src = imageData.upOff; upArrow.onclick = false; downArrow.image.src = imageData.downOff; downArrow.onclick = false; }); } } upArrow.onclick = makeOnclick("up"); downArrow.onclick = makeOnclick("down"); arrows.appendChild(upArrow); arrows.appendChild(downArrow); return arrows; } var posts = document.getElementsByClassName('post') Array.prototype.forEach.call(posts, function(el, i) { debuglog(i + ": " + el.id); var postInfo = el.querySelector('.postInfo'); var span = document.createElement("span"); var score = document.createElement("span"); getScore(el.id.substring(1), score); span.appendChild(makeArrows(el.id, score)); span.appendChild(score); postInfo.appendChild(span); }); })();