2016-04-30 12:25:15 -04:00
|
|
|
|
|
|
|
function getReplyTo() {
|
2016-05-03 14:27:07 -04:00
|
|
|
if(!document.dynreply) {
|
2016-04-30 12:56:24 -04:00
|
|
|
var e = document.getElementById("postform_container");
|
2016-04-30 12:25:15 -04:00
|
|
|
if (e) {
|
|
|
|
// use existing postform
|
2016-05-03 14:27:07 -04:00
|
|
|
document.dynreply = new DynReply(e);
|
2016-04-30 12:25:15 -04:00
|
|
|
} else {
|
|
|
|
// build a new postform
|
2016-05-03 14:27:07 -04:00
|
|
|
document.dynreply = new DynReply();
|
2016-04-30 12:25:15 -04:00
|
|
|
}
|
2016-05-04 13:12:46 -04:00
|
|
|
e = document.dynreply.elem;
|
2016-05-04 13:10:46 -04:00
|
|
|
e.style.position = "fixed";
|
|
|
|
e.setAttribute("class", "shadow");
|
2016-04-30 12:25:15 -04:00
|
|
|
}
|
2016-05-03 14:27:07 -04:00
|
|
|
return document.dynreply;
|
2016-04-30 12:25:15 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
function table_insert_row(table, header, items) {
|
|
|
|
var tr = document.createElement("tr");
|
|
|
|
// insert header element
|
|
|
|
var th = document.createElement("th");
|
|
|
|
th.appendChild(header);
|
|
|
|
tr.appendChild(th);
|
|
|
|
// insert the rest of the elements
|
|
|
|
for (var idx = 0; idx < items.length; idx ++ ) {
|
|
|
|
var elem = document.createElement("td");
|
|
|
|
elem.appendChild(items[idx]);
|
|
|
|
tr.appendChild(elem);
|
|
|
|
}
|
2016-04-30 12:41:23 -04:00
|
|
|
table.appendChild(tr);
|
2016-04-30 12:25:15 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
build dynamic reply box
|
|
|
|
*/
|
|
|
|
function DynReply(existingElem) {
|
|
|
|
if (existingElem) {
|
|
|
|
// wrap existing post form
|
2016-05-03 15:20:08 -04:00
|
|
|
// XXX: wrap it here
|
2016-04-30 12:25:15 -04:00
|
|
|
this.elem = existingElem;
|
|
|
|
this.form = this.elem.querySelector("form");
|
2016-04-30 16:03:39 -04:00
|
|
|
this._error = document.getElementById("postform_msg");
|
2016-04-30 16:09:59 -04:00
|
|
|
this.url = this.form.action + "?t=json";
|
2016-05-03 14:22:10 -04:00
|
|
|
this.x = 1;
|
|
|
|
this.y = 1;
|
2016-04-30 12:25:15 -04:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// build new post form
|
|
|
|
|
|
|
|
var elem = document.createElement("div");
|
2016-04-30 12:56:24 -04:00
|
|
|
elem.setAttribute("id", "postform_container");
|
2016-04-30 12:25:15 -04:00
|
|
|
this.elem = elem;
|
|
|
|
// build post form
|
|
|
|
this.form = document.createElement("form");
|
|
|
|
this.form.enctype = "multipart/form-data";
|
|
|
|
this.form.name = "post";
|
|
|
|
this.form.method = "post";
|
|
|
|
// reference
|
|
|
|
elem = document.createElement("input");
|
|
|
|
elem.setAttribute("id", "postform_reference");
|
|
|
|
elem.name = "reference";
|
|
|
|
elem.type = "hidden";
|
|
|
|
this.form.appendChild(elem);
|
|
|
|
|
|
|
|
var table = document.createElement("table");
|
|
|
|
table.setAttribute("class", "postform");
|
|
|
|
var tbody = document.createElement("tbody");
|
|
|
|
|
2016-05-03 12:17:08 -04:00
|
|
|
var span = document.createElement("span");
|
2016-04-30 12:25:15 -04:00
|
|
|
// name
|
|
|
|
elem = document.createElement("input");
|
|
|
|
elem.setAttribute("name", "name");
|
|
|
|
elem.setAttribute("value", "Anonymous");
|
2016-05-01 10:42:06 -04:00
|
|
|
elem.setAttribute("id", "postform_name");
|
2016-05-03 12:17:08 -04:00
|
|
|
span.appendChild(elem);
|
|
|
|
// error message
|
2016-04-30 16:03:39 -04:00
|
|
|
var err_elem = document.createElement("span");
|
|
|
|
err_elem.setAttribute("id", "postform_msg");
|
2016-05-03 12:17:08 -04:00
|
|
|
span.appendChild(err_elem);
|
2016-04-30 16:36:21 -04:00
|
|
|
this._error = err_elem;
|
2016-05-03 12:17:08 -04:00
|
|
|
table_insert_row(tbody, document.createTextNode("Name"), [span])
|
2016-04-30 12:25:15 -04:00
|
|
|
|
|
|
|
// subject
|
|
|
|
elem = document.createElement("input");
|
|
|
|
elem.setAttribute("name", "subject");
|
|
|
|
elem.setAttribute("value", "");
|
2016-05-01 10:42:06 -04:00
|
|
|
elem.setAttribute("id", "postform_subject");
|
2016-04-30 12:25:15 -04:00
|
|
|
// submit
|
|
|
|
var submit = document.createElement("input");
|
|
|
|
submit.setAttribute("value", "reply");
|
|
|
|
submit.setAttribute("class", "button");
|
2016-05-01 10:31:14 -04:00
|
|
|
submit.setAttribute("type", "submit");
|
2016-04-30 16:03:39 -04:00
|
|
|
submit.setAttribute("id", "postform_submit");
|
2016-04-30 12:25:15 -04:00
|
|
|
table_insert_row(tbody, document.createTextNode("Subject"), [elem, submit]);
|
|
|
|
|
2016-04-30 16:03:39 -04:00
|
|
|
|
2016-04-30 12:25:15 -04:00
|
|
|
// Comment
|
|
|
|
elem = document.createElement("textarea");
|
|
|
|
elem.setAttribute("id", "postform_message");
|
|
|
|
elem.setAttribute("name", "message");
|
|
|
|
elem.setAttribute("cols", "40");
|
|
|
|
elem.setAttribute("rows", "5");
|
|
|
|
table_insert_row(tbody, document.createTextNode("Comment"), [elem]);
|
|
|
|
|
|
|
|
// file
|
|
|
|
elem = document.createElement("input");
|
|
|
|
elem.setAttribute("class", "postform_attachment");
|
|
|
|
elem.setAttribute("id", "postform_attachments");
|
|
|
|
elem.setAttribute("type", "file");
|
|
|
|
elem.setAttribute("name", "attachment_uploaded");
|
|
|
|
elem.setAttribute("multiple", "multiple");
|
|
|
|
table_insert_row(tbody, document.createTextNode("Files"), [elem]);
|
|
|
|
|
|
|
|
// dubs
|
|
|
|
elem = document.createElement("input");
|
|
|
|
elem.setAttribute("type", "checkbox");
|
|
|
|
elem.setAttribute("name", "dubs");
|
|
|
|
table_insert_row(tbody, document.createTextNode("Get Dubs"), [elem]);
|
|
|
|
|
|
|
|
// captcha
|
|
|
|
elem = document.createElement("img");
|
|
|
|
elem.setAttribute("id", "captcha_img");
|
|
|
|
elem.alt = "captcha";
|
|
|
|
table_insert_row(tbody, document.createTextNode("Captcha"), [elem]);
|
|
|
|
|
|
|
|
// captcha solution
|
|
|
|
elem = document.createElement("input");
|
|
|
|
elem.name = "captcha";
|
|
|
|
elem.autocomplete = "off";
|
2016-05-01 10:42:06 -04:00
|
|
|
elem.setAttribute("id", "captcha_solution");
|
2016-05-01 10:31:14 -04:00
|
|
|
table_insert_row(tbody, document.createTextNode("Solution"), [elem])
|
2016-04-30 12:25:15 -04:00
|
|
|
|
|
|
|
table.appendChild(tbody);
|
|
|
|
this.form.appendChild(table);
|
|
|
|
this.elem.appendChild(this.form);
|
2016-04-30 12:39:46 -04:00
|
|
|
document.body.appendChild(this.elem);
|
2016-04-30 12:25:15 -04:00
|
|
|
this.board = null;
|
|
|
|
this.roothash = null;
|
|
|
|
this.prefix = null;
|
2016-04-30 16:03:39 -04:00
|
|
|
this.url = null;
|
2016-05-03 14:22:10 -04:00
|
|
|
this.x = 1;
|
|
|
|
this.y = 1;
|
|
|
|
|
2016-04-30 12:25:15 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
DynReply.prototype.update = function() {
|
|
|
|
if (this.prefix) {
|
|
|
|
// update captcha
|
|
|
|
this.updateCaptcha();
|
2016-05-04 13:03:32 -04:00
|
|
|
if (this.board) {
|
2016-04-30 12:25:15 -04:00
|
|
|
// update post form
|
|
|
|
var ref = document.getElementById("postform_reference");
|
2016-05-04 13:03:32 -04:00
|
|
|
|
|
|
|
if (this.roothash) {
|
|
|
|
ref.setAttribute("value", this.roothash);
|
|
|
|
} else {
|
|
|
|
ref.setAttribute("value", "");
|
|
|
|
}
|
2016-04-30 16:03:39 -04:00
|
|
|
this.url = this.prefix + "post/" + this.board + "?t=json";
|
2016-04-30 12:25:15 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
DynReply.prototype.show = function() {
|
2016-04-30 12:29:51 -04:00
|
|
|
console.log("show dynreply");
|
2016-04-30 12:25:15 -04:00
|
|
|
this.update();
|
|
|
|
this.elem.style.display = 'inline';
|
|
|
|
}
|
|
|
|
|
2016-04-30 16:03:39 -04:00
|
|
|
DynReply.prototype.hide = function() {
|
|
|
|
console.log("hide dynreply");
|
|
|
|
this.elem.style.display = "none";
|
|
|
|
}
|
|
|
|
|
2016-05-01 10:42:06 -04:00
|
|
|
// clear all fields
|
|
|
|
DynReply.prototype.clear = function() {
|
|
|
|
this.clearSolution();
|
|
|
|
this.clearPostbox();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// clear captcha solution
|
|
|
|
DynReply.prototype.clearSolution = function() {
|
|
|
|
var e = document.getElementById("captcha_solution");
|
|
|
|
// reset value
|
|
|
|
e.value = "";
|
|
|
|
}
|
|
|
|
|
|
|
|
// clear postform elements
|
|
|
|
DynReply.prototype.clearPostbox = function() {
|
|
|
|
var e = document.getElementById("postform_subject");
|
|
|
|
e.value = "";
|
|
|
|
e = document.getElementById("postform_message");
|
|
|
|
e.value = "";
|
2016-05-01 17:38:37 -04:00
|
|
|
e = document.getElementById("postform_attachments");
|
2016-05-01 17:48:17 -04:00
|
|
|
e.value = null;
|
2016-05-01 10:42:06 -04:00
|
|
|
}
|
|
|
|
|
2016-04-30 16:03:39 -04:00
|
|
|
DynReply.prototype.post = function(cb, err_cb) {
|
|
|
|
if (this.url && this.form) {
|
|
|
|
var data = new FormData(this.form);
|
|
|
|
var ajax = new XMLHttpRequest();
|
|
|
|
ajax.onreadystatechange = function(ev) {
|
|
|
|
if (ajax.readyState == XMLHttpRequest.DONE) {
|
|
|
|
var j = null;
|
|
|
|
try {
|
|
|
|
j = JSON.parse(ajax.responseText);
|
|
|
|
cb(j);
|
|
|
|
} catch (e) {
|
|
|
|
if(err_cb) {
|
|
|
|
err_cb(e);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
ajax.open("POST", this.url);
|
|
|
|
ajax.send(data);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-04-30 12:25:15 -04:00
|
|
|
DynReply.prototype.updateCaptcha = function() {
|
|
|
|
if (this.prefix) {
|
|
|
|
var captcha_img = document.getElementById("captcha_img");
|
|
|
|
captcha_img.src = this.prefix + "captcha/img";
|
|
|
|
}
|
2016-05-01 10:42:06 -04:00
|
|
|
this.clearSolution();
|
2016-04-30 12:25:15 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
DynReply.prototype.setPrefix = function(prefix) {
|
|
|
|
this.prefix = prefix;
|
|
|
|
}
|
|
|
|
|
|
|
|
DynReply.prototype.hide = function() {
|
|
|
|
this.elem.style.display = 'none';
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
DynReply.prototype.setBoard = function(boardname) {
|
|
|
|
if (boardname) {
|
|
|
|
this.board = boardname;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
DynReply.prototype.setRoot = function(roothash) {
|
|
|
|
if (roothash) {
|
|
|
|
this.roothash = roothash;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-04-30 16:03:39 -04:00
|
|
|
DynReply.prototype.showError = function(msg) {
|
|
|
|
console.log("error in dynreply: "+msg);
|
2016-05-03 12:28:19 -04:00
|
|
|
this._error.setAttribute("class", "error message");
|
2016-04-30 16:14:47 -04:00
|
|
|
this._error.appendChild(document.createTextNode(msg));
|
2016-04-30 16:20:27 -04:00
|
|
|
this.updateCaptcha();
|
2016-04-30 16:03:39 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
DynReply.prototype.showMessage = function(msg) {
|
|
|
|
this._error.setAttribute("class", "message");
|
2016-05-01 17:25:08 -04:00
|
|
|
this._error.innerHTML = "";
|
2016-04-30 16:14:47 -04:00
|
|
|
this._error.appendChild(document.createTextNode(msg));
|
2016-04-30 16:11:20 -04:00
|
|
|
var e = this._error;
|
2016-04-30 16:03:39 -04:00
|
|
|
setTimeout(function() {
|
|
|
|
// clear it
|
2016-04-30 16:11:20 -04:00
|
|
|
e.innerHTML = "";
|
2016-04-30 16:03:39 -04:00
|
|
|
}, 2000);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2016-04-30 12:25:15 -04:00
|
|
|
// reply box function
|
2016-04-30 14:44:06 -04:00
|
|
|
function nntpchan_reply(parent, shorthash) {
|
2016-05-04 13:14:57 -04:00
|
|
|
if (parent && document.dynreply) {
|
2016-04-30 12:35:21 -04:00
|
|
|
var boardname = parent.getAttribute("boardname");
|
2016-04-30 13:03:18 -04:00
|
|
|
var roothash = parent.getAttribute("root");
|
2016-04-30 12:25:15 -04:00
|
|
|
var replyto = getReplyTo();
|
|
|
|
// set target
|
|
|
|
replyto.setBoard(boardname);
|
|
|
|
replyto.setRoot(roothash);
|
|
|
|
// show it
|
|
|
|
replyto.show();
|
|
|
|
}
|
2016-04-27 14:21:12 +02:00
|
|
|
var elem = document.getElementById("postform_message");
|
|
|
|
if ( elem )
|
|
|
|
{
|
2016-04-30 12:25:15 -04:00
|
|
|
elem.value += ">>" + shorthash.substr(0,10) + "\n";
|
2016-04-27 14:21:12 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// inject post hover behavior
|
|
|
|
function inject_hover(prefix, el, parent) {
|
|
|
|
if (!prefix) { throw "prefix is not defined"; }
|
|
|
|
var linkhash = el.getAttribute("backlinkhash");
|
|
|
|
if (!linkhash) { throw "linkhash undefined"; }
|
|
|
|
console.log("rewrite linkhash "+linkhash);
|
|
|
|
|
|
|
|
var elem = document.createElement("span");
|
|
|
|
elem.setAttribute("class", "backlink_rewritten");
|
|
|
|
elem.appendChild(document.createTextNode(">>"+linkhash.substr(0,10)));
|
|
|
|
if (!parent) {
|
|
|
|
parent = el.parentNode;
|
|
|
|
}
|
|
|
|
parent.removeChild(el);
|
|
|
|
parent.appendChild(elem);
|
|
|
|
|
|
|
|
elem.onclick = function(ev) {
|
|
|
|
if(parent.backlink) {
|
|
|
|
nntpchan_apicall(prefix+"api/find?hash="+linkhash, function(j) {
|
|
|
|
var wrapper = document.createElement("div");
|
|
|
|
wrapper.setAttribute("class", "hover "+linkhash);
|
|
|
|
if (j == null) {
|
|
|
|
// not found?
|
|
|
|
wrapper.setAttribute("class", "hover notfound-hover "+linkhash);
|
|
|
|
wrapper.appendChild(document.createTextNode("not found"));
|
|
|
|
} else {
|
|
|
|
// wrap backlink
|
|
|
|
nntpchan_buildpost(wrapper, j);
|
|
|
|
}
|
|
|
|
parent.appendChild(wrapper);
|
|
|
|
parent.backlink = false;
|
|
|
|
}, function(msg) {
|
|
|
|
var wrapper = document.createElement("div");
|
|
|
|
wrapper.setAttribute("class", "hover "+linkhash);
|
|
|
|
wrapper.appendChild(document.createTextNode(msg));
|
|
|
|
parent.appendChild(wrapper);
|
|
|
|
parent.backlink = false;
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
var elems = document.getElementsByClassName(linkhash);
|
|
|
|
if (!elems) throw "bad state, no backlinks open?";
|
|
|
|
for (var idx = 0 ; idx < elems.length; idx ++ ) {
|
|
|
|
elems[idx].parentNode.removeChild(elems[idx]);
|
|
|
|
}
|
|
|
|
parent.backlink = true;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
parent.backlink = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
// inject post hover for all backlinks in an element
|
|
|
|
function inject_hover_for_element(elem) {
|
|
|
|
var elems = elem.getElementsByClassName("backlink");
|
|
|
|
var ls = [];
|
|
|
|
var l = elems.length;
|
|
|
|
for ( var idx = 0 ; idx < l ; idx ++ ) {
|
|
|
|
var e = elems[idx];
|
|
|
|
ls.push(e);
|
|
|
|
}
|
|
|
|
for( var elem in ls ) {
|
|
|
|
inject_hover(prefix, ls[elem]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function init(prefix) {
|
|
|
|
// inject posthover ...
|
|
|
|
inject_hover_for_element(document);
|
2016-05-04 14:03:48 -04:00
|
|
|
if ( /\.html$/.test(document.location.pathname) && ! (/ukko/.test(document.location.pathname)) ) {
|
2016-05-04 13:03:32 -04:00
|
|
|
// board / thread page
|
2016-05-04 13:06:15 -04:00
|
|
|
console.log("not loading reply widget");
|
2016-05-04 13:03:32 -04:00
|
|
|
} else {
|
|
|
|
// ukko / livechan page
|
|
|
|
var rpl = getReplyTo();
|
|
|
|
rpl.setPrefix(prefix);
|
|
|
|
// set livechan
|
|
|
|
rpl.setBoard("overchan.random");
|
|
|
|
rpl.update();
|
|
|
|
rpl.updateCaptcha();
|
|
|
|
|
|
|
|
// position replyto widget
|
|
|
|
var e = rpl.elem;
|
|
|
|
var mouseDownX, mouseDownY;
|
|
|
|
|
|
|
|
var $dragging = null;
|
|
|
|
|
|
|
|
$(rpl.elem).on("mousemove", function(ev) {
|
|
|
|
if ($dragging) {
|
|
|
|
var x = ev.pageX - $(this).width() / 2,
|
|
|
|
y = ev.pageY - $(this).height() / 2;
|
|
|
|
$dragging.offset({
|
|
|
|
top: y,
|
|
|
|
left: x
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
2016-05-03 14:58:57 -04:00
|
|
|
|
|
|
|
|
2016-05-04 13:03:32 -04:00
|
|
|
$(rpl.elem).on("mousedown", e, function (ev) {
|
|
|
|
$dragging = $(rpl.elem);
|
|
|
|
});
|
2016-05-03 14:58:57 -04:00
|
|
|
|
2016-05-04 13:03:32 -04:00
|
|
|
$(rpl.elem).on("mouseup", function (e) {
|
|
|
|
$dragging = null;
|
2016-04-30 16:03:39 -04:00
|
|
|
});
|
2016-05-04 13:03:32 -04:00
|
|
|
|
|
|
|
// add replyto post handlers
|
|
|
|
e = document.getElementById("postform_submit");
|
|
|
|
var postit = function() {
|
|
|
|
var f = document.querySelector("form");
|
|
|
|
// do ajax request to post data
|
|
|
|
var r = getReplyTo();
|
|
|
|
r.showMessage("posting... ");
|
|
|
|
r.post(function(j) {
|
|
|
|
if(j.error) {
|
|
|
|
// an error happened
|
|
|
|
r.showError(j.error);
|
|
|
|
} else {
|
|
|
|
// we're good
|
|
|
|
r.showMessage("posted :^)");
|
|
|
|
r.updateCaptcha();
|
|
|
|
r.clear();
|
|
|
|
}
|
|
|
|
}, function(err) {
|
|
|
|
r.showError(err);
|
|
|
|
r.clearSolution();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
var f = document.querySelector("form");
|
|
|
|
f.onsubmit = function() {
|
|
|
|
postit();
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
2016-04-27 14:21:12 +02:00
|
|
|
}
|
|
|
|
|