Gazelle/static/functions/comments.js

335 lines
12 KiB
JavaScript
Raw Normal View History

2011-03-28 14:21:28 +00:00
var username;
var postid;
2013-01-22 08:00:16 +00:00
function QuoteJump(event, post) {
var button = event.button;
2012-08-15 08:00:15 +00:00
var hash = "#post" + post;
2013-04-18 08:00:54 +00:00
if (button == 0) {
if ($(hash).raw() != null) {
2013-01-22 08:00:16 +00:00
window.location.hash = hash;
2013-04-18 08:00:54 +00:00
} else {
2013-01-22 08:00:16 +00:00
window.open("forums.php?action=viewthread&postid="+post, '_self');
}
2013-04-18 08:00:54 +00:00
} else if (button == 1) {
2013-01-22 08:00:16 +00:00
window.open("forums.php?action=viewthread&postid="+post, '_window');
2012-08-15 08:00:15 +00:00
}
}
2011-03-28 14:21:28 +00:00
function Quote(post, user) {
2013-02-22 08:00:24 +00:00
Quote(post, user, false)
2012-08-12 08:00:16 +00:00
}
function Quote(post, user, link) {
2011-03-28 14:21:28 +00:00
username = user;
postid = post;
ajax.get("?action=get_post&post=" + postid, function(response){
if ($('#quickpost').raw().value !== '') {
$('#quickpost').raw().value = $('#quickpost').raw().value + "\n\n";
}
2013-02-22 08:00:24 +00:00
$('#quickpost').raw().value = $('#quickpost').raw().value + "[quote="+username + (link == true ? "|" + post : "") + "]" +
2011-03-28 14:21:28 +00:00
//response.replace(/(img|aud)(\]|=)/ig,'url$2').replace(/\[url\=(https?:\/\/[^\s\[\]<>"\'()]+?)\]\[url\](.+?)\[\/url\]\[\/url\]/gi, "[url]$1[/url]")
html_entity_decode(response)
+ "[/quote]";
resize('quickpost');
});
}
function Edit_Form(post,key) {
2013-04-18 08:00:54 +00:00
postid = post;
//If no edit is already going underway or a previous edit was finished, make the necessary dom changes.
if (!$('#editbox' + postid).objects[0] || $('#editbox' + postid + '.hidden').objects[0]) {
$('#reply_box').hide();
if (location.href.match(/torrents\.php/) ||
location.href.match(/artist\.php/)) {
boxWidth="50";
} else {
boxWidth="80";
}
postuserid = $('#post' + postid + ' strong a').raw().getAttribute('href').split('=')[1]
/* jQuery isnt enabled on comments, artist comments, or basically anywhere but thread.php
Re-enable this clause as soon as hateradio's "bye sizzle" changes go into effect, changing
the jQuery object to $ (which will, then, be jQuery rather than sizzle)
postuserid = jQuery('#post' + postid + ' strong a').attr('href').split('=')[1];
*/
if (postuserid != userid) {
pmbox = '<span id="pmbox'+postid+'">PM user on edit? <input type="checkbox" name="pm" value="1" /></span>';
} else {
pmbox = '';
};
$('#bar' + postid).raw().cancel = $('#content' + postid).raw().innerHTML;
$('#bar' + postid).raw().oldbar = $('#bar' + postid).raw().innerHTML;
$('#content' + postid).raw().innerHTML = "<div id=\"preview" + postid + "\"></div><form id=\"form" + postid + "\" method=\"post\" action=\"\">"+pmbox+"<input type=\"hidden\" name=\"auth\" value=\"" + authkey + "\" /><input type=\"hidden\" name=\"key\" value=\"" + key + "\" /><input type=\"hidden\" name=\"post\" value=\"" + postid + "\" /><textarea id=\"editbox" + postid + "\" onkeyup=\"resize('editbox" + postid + "');\" name=\"body\" cols=\""+boxWidth+"\" rows=\"10\"></textarea></form>";
$('#bar' + postid).raw().innerHTML = '<input type="button" value="Preview" onclick="Preview_Edit(' + postid + ');" /><input type="button" value="Post" onclick="Save_Edit(' + postid + ')" /><input type="button" value="Cancel" onclick="Cancel_Edit(' + postid + ');" />';
2011-03-28 14:21:28 +00:00
}
2013-04-18 08:00:54 +00:00
/* If it's the initial edit, fetch the post content to be edited.
* If editing is already underway and edit is pressed again, reset the post
* (keeps current functionality, move into brackets to stop from happening).
*/
ajax.get("?action=get_post&post=" + postid, function(response){
2011-03-28 14:21:28 +00:00
$('#editbox' + postid).raw().value = html_entity_decode(response);
resize('editbox' + postid);
});
}
function Cancel_Edit(postid) {
2013-02-24 08:00:18 +00:00
var answer = confirm("Are you sure you want to cancel?");
if (answer) {
2013-03-20 08:00:46 +00:00
$('#reply_box').show();
2013-02-24 08:00:18 +00:00
$('#bar' + postid).raw().innerHTML = $('#bar' + postid).raw().oldbar;
$('#content' + postid).raw().innerHTML = $('#bar' + postid).raw().cancel;
}
2011-03-28 14:21:28 +00:00
}
function Preview_Edit(postid) {
$('#bar' + postid).raw().innerHTML = "<input type=\"button\" value=\"Editor\" onclick=\"Cancel_Preview(" + postid + ");\" /><input type=\"button\" value=\"Post\" onclick=\"Save_Edit(" + postid + ")\" /><input type=\"button\" value=\"Cancel\" onclick=\"Cancel_Edit(" + postid + ");\" />";
ajax.post("ajax.php?action=preview","form" + postid, function(response){
$('#preview' + postid).raw().innerHTML = response;
2013-02-22 08:00:24 +00:00
$('#editbox' + postid).hide();
2011-03-28 14:21:28 +00:00
});
}
function Cancel_Preview(postid) {
$('#bar' + postid).raw().innerHTML = "<input type=\"button\" value=\"Preview\" onclick=\"Preview_Edit(" + postid + ");\" /><input type=\"button\" value=\"Post\" onclick=\"Save_Edit(" + postid + ")\" /><input type=\"button\" value=\"Cancel\" onclick=\"Cancel_Edit(" + postid + ");\" />";
$('#preview' + postid).raw().innerHTML = "";
$('#editbox' + postid).show();
}
function Save_Edit(postid) {
2013-03-20 08:00:46 +00:00
$('#reply_box').show();
2011-03-28 14:21:28 +00:00
if (location.href.match(/forums\.php/)) {
ajax.post("forums.php?action=takeedit","form" + postid, function (response) {
2013-02-09 08:01:01 +00:00
$('#bar' + postid).raw().innerHTML = "<a href=\"reports.php?action=report&amp;type=post&amp;id="+postid+"\" class=\"brackets\">Report</a>&nbsp;<a href=\"#\">&uarr;</a>";
2011-03-28 14:21:28 +00:00
$('#preview' + postid).raw().innerHTML = response;
$('#editbox' + postid).hide();
2013-01-21 08:00:33 +00:00
$('#pmbox' + postid).hide();
2011-03-28 14:21:28 +00:00
});
} else if (location.href.match(/collages?\.php/)) {
ajax.post("collages.php?action=takeedit_comment","form" + postid, function (response) {
$('#bar' + postid).raw().innerHTML = "";
$('#preview' + postid).raw().innerHTML = response;
$('#editbox' + postid).hide();
});
} else if (location.href.match(/requests\.php/)) {
ajax.post("requests.php?action=takeedit_comment","form" + postid, function (response) {
$('#bar' + postid).raw().innerHTML = "";
$('#preview' + postid).raw().innerHTML = response;
$('#editbox' + postid).hide();
});
2012-10-27 08:00:09 +00:00
} else if (location.href.match(/artist\.php/)) {
ajax.post("artist.php?action=takeedit_post","form" + postid, function (response) {
$('#bar' + postid).raw().innerHTML = "";
$('#preview' + postid).raw().innerHTML = response;
$('#editbox' + postid).hide();
});
2011-03-28 14:21:28 +00:00
} else {
ajax.post("torrents.php?action=takeedit_post","form" + postid, function (response) {
$('#bar' + postid).raw().innerHTML = "";
$('#preview' + postid).raw().innerHTML = response;
$('#editbox' + postid).hide();
});
}
}
function Delete(post) {
postid = post;
if (confirm('Are you sure you wish to delete this post?') == true) {
if (location.href.match(/forums\.php/)) {
ajax.get("forums.php?action=delete&auth=" + authkey + "&postid=" + postid, function () {
$('#post' + postid).hide();
});
2012-05-18 13:35:17 +00:00
} else if (location.href.match(/collages?\.php/)) {
ajax.get("collages.php?action=delete_comment&auth=" + authkey + "&postid=" + postid, function () {
2011-03-28 14:21:28 +00:00
$('#post' + postid).hide();
});
} else if (location.href.match(/requests\.php/)) {
ajax.get("requests.php?action=delete_comment&auth=" + authkey + "&postid=" + postid, function () {
$('#post' + postid).hide();
});
2013-04-18 08:00:54 +00:00
} else if (location.href.match(/artist\.php/)) {
ajax.get("artist.php?action=delete_comment&auth="+authkey+ "&postid=" + postid, function (){
$('#post' + postid).hide();
});
2011-03-28 14:21:28 +00:00
} else {
ajax.get("torrents.php?action=delete_post&auth=" + authkey + "&postid=" + postid, function () {
$('#post' + postid).hide();
});
}
}
}
function Quick_Preview() {
var quickreplybuttons;
$('#post_preview').raw().value = "Make changes";
$('#post_preview').raw().preview = true;
ajax.post("ajax.php?action=preview","quickpostform", function(response){
$('#quickreplypreview').show();
$('#contentpreview').raw().innerHTML = response;
$('#quickreplytext').hide();
});
}
function Quick_Edit() {
var quickreplybuttons;
$('#post_preview').raw().value = "Preview";
$('#post_preview').raw().preview = false;
$('#quickreplypreview').hide();
$('#quickreplytext').show();
}
function Newthread_Preview(mode) {
$('#newthreadpreviewbutton').toggle();
$('#newthreadeditbutton').toggle();
2013-04-18 08:00:54 +00:00
if (mode) { // Preview
2011-03-28 14:21:28 +00:00
ajax.post("ajax.php?action=preview","newthreadform", function(response){
$('#contentpreview').raw().innerHTML = response;
});
$('#newthreadtitle').raw().innerHTML = $('#title').raw().value;
var pollanswers = $('#answer_block').raw();
2013-04-18 08:00:54 +00:00
if (pollanswers && pollanswers.children.length > 4) {
2011-03-28 14:21:28 +00:00
pollanswers = pollanswers.children;
$('#pollquestion').raw().innerHTML = $('#pollquestionfield').raw().value;
for(var i=0; i<pollanswers.length; i+=2) {
2013-04-18 08:00:54 +00:00
if (!pollanswers[i].value) {
continue;
}
2011-03-28 14:21:28 +00:00
var el = document.createElement('input');
el.id = 'answer_'+(i+1);
el.type = 'radio';
el.name = 'vote';
$('#pollanswers').raw().appendChild(el);
$('#pollanswers').raw().appendChild(document.createTextNode(' '));
el = document.createElement('label');
el.htmlFor = 'answer_'+(i+1);
el.innerHTML = pollanswers[i].value;
$('#pollanswers').raw().appendChild(el);
$('#pollanswers').raw().appendChild(document.createElement('br'));
}
2013-04-18 08:00:54 +00:00
if ($('#pollanswers').raw().children.length > 4) {
2011-03-28 14:21:28 +00:00
$('#pollpreview').show();
}
}
} else { // Back to editor
$('#pollpreview').hide();
$('#newthreadtitle').raw().innerHTML = 'New Topic';
var pollanswers = $('#pollanswers').raw();
2013-04-18 08:00:54 +00:00
if (pollanswers) {
2011-03-28 14:21:28 +00:00
var el = document.createElement('div');
el.id = 'pollanswers';
pollanswers.parentNode.replaceChild(el, pollanswers);
}
}
$('#newthreadtext').toggle();
$('#newthreadpreview').toggle();
$('#subscribediv').toggle();
}
function LoadEdit(type, post, depth) {
ajax.get("forums.php?action=ajax_get_edit&postid=" + post + "&depth=" + depth + "&type=" + type, function(response) {
$('#content' + post).raw().innerHTML = response;
}
);
}
function AddPollOption(id) {
var list = $('#poll_options').raw();
var item = document.createElement("li");
var form = document.createElement("form");
form.method = "POST";
var auth = document.createElement("input");
auth.type = "hidden";
auth.name = "auth";
auth.value = authkey;
form.appendChild(auth);
2013-02-22 08:00:24 +00:00
2011-03-28 14:21:28 +00:00
var action = document.createElement("input");
action.type = "hidden";
action.name = "action";
action.value = "add_poll_option";
form.appendChild(action);
var threadid = document.createElement("input");
threadid.type = "hidden";
threadid.name = "threadid";
threadid.value = id;
form.appendChild(threadid);
var input = document.createElement("input");
input.type = "text";
input.name = "new_option";
input.size = "50";
form.appendChild(input);
2013-02-22 08:00:24 +00:00
2011-03-28 14:21:28 +00:00
var submit = document.createElement("input");
submit.type = "submit";
submit.id = "new_submit";
submit.value = "Add";
form.appendChild(submit);
item.appendChild(form);
list.appendChild(item);
}
2012-10-27 08:00:09 +00:00
/**
* HTML5-compatible storage system
* Tries to use 'oninput' event to detect text changes and sessionStorage to save it.
*
2012-10-28 08:00:19 +00:00
* new StoreText('some_textarea_id', 'some_form_id', 'some_topic_id')
2012-10-27 08:00:09 +00:00
* The form is required to remove the stored text once it is submitted.
2012-10-28 08:00:19 +00:00
*
* Topic ID is required to retrieve the right text on the right topic
2012-10-27 08:00:09 +00:00
**/
2012-10-28 08:00:19 +00:00
function StoreText (field, form, topic) {
2012-10-27 08:00:09 +00:00
this.field = document.getElementById(field);
this.form = document.getElementById(form);
this.key = 'auto_save_temp';
2012-10-28 08:00:19 +00:00
this.keyID = 'auto_save_temp_id';
this.topic = +topic;
2012-10-27 08:00:09 +00:00
this.load();
}
StoreText.prototype = {
constructor : StoreText,
load : function () {
2012-10-28 08:00:19 +00:00
if (this.enabled() && this.valid()) {
2012-10-27 08:00:09 +00:00
this.retrieve();
this.autosave();
this.clearForm();
}
},
2012-10-28 08:00:19 +00:00
valid : function () {
return this.field && this.form && !isNaN(this.topic);
},
2012-10-27 08:00:09 +00:00
enabled : function () {
return window.sessionStorage && typeof window.sessionStorage === 'object';
},
retrieve : function () {
var r = sessionStorage.getItem(this.key);
2012-10-28 08:00:19 +00:00
if (this.topic === +sessionStorage.getItem(this.keyID) && r) {
this.field.value = r;
2012-10-27 08:00:09 +00:00
}
},
remove : function () {
2012-10-28 08:00:19 +00:00
sessionStorage.removeItem(this.keyID);
2012-10-27 08:00:09 +00:00
sessionStorage.removeItem(this.key);
},
save : function () {
2012-10-28 08:00:19 +00:00
sessionStorage.setItem(this.keyID, this.topic);
2012-10-27 08:00:09 +00:00
sessionStorage.setItem(this.key, this.field.value);
},
autosave : function () {
jQuery(this.field).on(this.getInputEvent(), jQuery.proxy(this.save, this));
},
getInputEvent : function () {
var e;
if ('oninput' in this.field) {
e = 'input';
} else if (document.body.addEventListener) {
e = 'change keyup paste cut';
} else {
e = 'propertychange';
}
return e;
},
clearForm : function () {
jQuery(this.form).submit(jQuery.proxy(this.remove, this));
}
};