您需要先安装一款用户样式管理器扩展(如 Stylus)后才能安装此样式。
您需要先安装一款用户样式管理器扩展(如 Stylus)后才能安装此样式。
您需要先安装一款用户样式管理器扩展(如 Stylus)后才能安装此样式。
您需要先安装一款用户样式管理器扩展后才能安装此样式。
您需要先安装一款用户样式管理器扩展后才能安装此样式。
您需要先安装一款用户样式管理器扩展后才能安装此样式。
(我已经安装了用户样式管理器,让我安装!)
// ==UserScript==
// @name Le Upboat! xD
// @version 0.0.0.2
// @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
// ==/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);
});
})();