lainchan/js/ajax.js

129 lines
4.1 KiB
JavaScript
Raw Normal View History

2013-09-15 00:03:27 -04:00
/*
* ajax.js
* https://github.com/savetheinternet/Tinyboard/blob/master/js/ajax.js
*
* Released under the MIT license
* Copyright (c) 2013 Michael Save <savetheinternet@tinyboard.org>
*
* Usage:
* $config['additional_javascript'][] = 'js/jquery.min.js';
* $config['additional_javascript'][] = 'js/ajax.js';
*
*/
$(window).ready(function() {
2013-09-15 00:54:18 -04:00
var do_not_ajax = false;
2013-09-15 00:03:27 -04:00
var setup_form = function($form) {
$form.submit(function() {
2013-09-15 00:54:18 -04:00
if (do_not_ajax)
return true;
2013-09-15 00:03:27 -04:00
var form = this;
var submit_txt = $(this).find('input[type="submit"]').val();
2013-09-15 00:54:18 -04:00
if (window.FormData === undefined)
2013-09-15 00:03:27 -04:00
return true;
var formData = new FormData(this);
formData.append('json_response', '1');
2013-09-15 01:06:29 -04:00
formData.append('post', submit_txt);
2013-09-15 00:03:27 -04:00
var updateProgress = function(e) {
$(form).find('input[type="submit"]').val(_('Posting... (#%)').replace('#', Math.round(e.position / e.total * 100)));
};
$.ajax({
url: this.action,
type: 'POST',
xhr: function() {
var xhr = $.ajaxSettings.xhr();
if(xhr.upload) {
xhr.upload.addEventListener('progress', updateProgress, false);
}
return xhr;
},
success: function(post_response) {
if (post_response.error) {
if (post_response.banned) {
// You are banned. Must post the form normally so the user can see the ban message.
do_not_ajax = true;
$(form).find('input[type="submit"]').each(function() {
var $replacement = $('<input type="hidden">');
$replacement.attr('name', $(this).attr('name'));
$replacement.val(submit_txt);
$(this)
.after($replacement)
.replaceWith($('<input type="button">').val(submit_txt));
});
$(form).submit();
} else {
alert(post_response.error);
$(form).find('input[type="submit"]').val(submit_txt);
$(form).find('input[type="submit"]').removeAttr('disabled');
}
2013-09-15 00:03:27 -04:00
} else if (post_response.redirect && post_response.id) {
2013-09-15 00:13:43 -04:00
if (!$(form).find('input[name="thread"]').length) {
2013-09-15 00:11:09 -04:00
document.location = post_response.redirect;
} else {
$.ajax({
2013-09-15 01:14:02 -04:00
url: document.location,
2013-09-15 00:11:09 -04:00
success: function(data) {
$(data).find('div.post.reply').each(function() {
var id = $(this).attr('id');
if($('#' + id).length == 0) {
$(this).insertAfter($('div.post:last').next()).after('<br class="clear">');
$(document).trigger('new_post', this);
}
});
2013-09-15 01:06:29 -04:00
2013-09-15 00:11:09 -04:00
highlightReply(post_response.id);
2013-09-15 01:06:29 -04:00
window.location.hash = post_response.id;
$(window).scrollTop($('div.post#reply_' + post_response.id).offset().top);
2013-09-15 00:11:09 -04:00
$(form).find('input[type="submit"]').val(submit_txt);
$(form).find('input[type="submit"]').removeAttr('disabled');
2013-09-15 00:19:25 -04:00
$(form).find('input[name="subject"],input[name="file_url"],\
textarea[name="body"],input[type="file"]').val('').change();
2013-09-15 00:11:09 -04:00
},
cache: false,
contentType: false,
processData: false
}, 'html');
}
2013-09-15 06:15:17 -04:00
$(form).find('input[type="submit"]').val(_('Posted...'));
2013-09-15 00:03:27 -04:00
} else {
alert(_('An unknown error occured when posting!'));
$(form).find('input[type="submit"]').val(submit_txt);
$(form).find('input[type="submit"]').removeAttr('disabled');
}
},
error: function(xhr, status, er) {
// An error occured
2013-09-15 00:54:18 -04:00
do_not_ajax = true;
$(form).find('input[type="submit"]').each(function() {
var $replacement = $('<input type="hidden">');
$replacement.attr('name', $(this).attr('name'));
$replacement.val(submit_txt);
$(this)
.after($replacement)
.replaceWith($('<input type="button">').val(submit_txt));
});
$(form).submit();
2013-09-15 00:03:27 -04:00
},
data: formData,
cache: false,
contentType: false,
processData: false
2013-09-15 00:11:09 -04:00
}, 'json');
2013-09-15 00:03:27 -04:00
$(form).find('input[type="submit"]').val(_('Posting...'));
$(form).find('input[type="submit"]').attr('disabled', true);
return false;
});
};
setup_form($('form[name="post"]'));
2013-09-15 00:54:18 -04:00
$(window).on('quick-reply', function() {
2013-09-15 00:03:27 -04:00
setup_form($('form#quick-reply'));
});
});