2013-09-15 14:03:27 +10: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 >
2014-01-19 14:27:24 +01:00
* Copyright ( c ) 2013 - 2014 Marcin Łabanowski < marcin @ 6 irc . net >
2013-09-15 14:03:27 +10:00
*
* Usage :
* $config [ 'additional_javascript' ] [ ] = 'js/jquery.min.js' ;
* $config [ 'additional_javascript' ] [ ] = 'js/ajax.js' ;
*
* /
2015-03-12 12:19:30 +08:00
+ function ( ) {
2013-09-18 14:40:39 +10:00
var settings = new script _settings ( 'ajax' ) ;
2013-09-15 14:54:18 +10:00
var do _not _ajax = false ;
2013-09-15 14:03:27 +10:00
var setup _form = function ( $form ) {
$form . submit ( function ( ) {
2014-01-29 23:32:22 +01:00
if ( do _not _ajax )
2013-09-15 14:54:18 +10:00
return true ;
2015-03-11 05:43:51 -07:00
var form = $ ( this ) . find ( 'form' ) [ 0 ] ;
2013-09-15 14:03:27 +10:00
var submit _txt = $ ( this ) . find ( 'input[type="submit"]' ) . val ( ) ;
2013-09-15 14:54:18 +10:00
if ( window . FormData === undefined )
2013-09-15 14:03:27 +10:00
return true ;
2015-03-11 05:43:51 -07:00
var formData = new FormData ( form ) ;
2013-09-15 14:03:27 +10:00
formData . append ( 'json_response' , '1' ) ;
2013-09-15 15:06:29 +10:00
formData . append ( 'post' , submit _txt ) ;
2013-09-15 14:03:27 +10:00
2014-01-29 23:31:39 +01:00
$ ( document ) . trigger ( "ajax_before_post" , formData ) ;
2013-09-15 14:03:27 +10:00
var updateProgress = function ( e ) {
2013-09-17 18:54:06 -04:00
var percentage ;
if ( e . position === undefined ) { // Firefox
percentage = Math . round ( e . loaded * 100 / e . total ) ;
}
else { // Chrome?
percentage = Math . round ( e . position * 100 / e . total ) ;
}
$ ( form ) . find ( 'input[type="submit"]' ) . val ( _ ( 'Posting... (#%)' ) . replace ( '#' , percentage ) ) ;
2013-09-15 14:03:27 +10:00
} ;
$ . ajax ( {
2015-03-12 12:19:30 +08:00
url : configRoot + 'post.php' ,
2013-09-15 14:03:27 +10:00
type : 'POST' ,
xhr : function ( ) {
var xhr = $ . ajaxSettings . xhr ( ) ;
if ( xhr . upload ) {
xhr . upload . addEventListener ( 'progress' , updateProgress , false ) ;
}
return xhr ;
} ,
2014-11-21 04:05:20 -08:00
success : function ( post _response , textStatus , xhr ) {
2013-09-15 14:03:27 +10:00
if ( post _response . error ) {
2013-09-17 09:15:24 +10:00
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' ) ;
2015-02-26 18:39:16 +09:00
if ( post _response . error == 'Sorry. Tor users can\'t upload files.' ) {
$ ( form ) . find ( 'input[name="file_url"],input[type="file"]' ) . val ( '' ) . change ( ) ;
}
2013-09-17 09:15:24 +10:00
}
2013-09-15 14:03:27 +10:00
} else if ( post _response . redirect && post _response . id ) {
2013-09-18 14:40:39 +10:00
if ( ! $ ( form ) . find ( 'input[name="thread"]' ) . length
|| ( ! settings . get ( 'always_noko_replies' , true ) && ! post _response . noko ) ) {
2013-09-15 14:11:09 +10:00
document . location = post _response . redirect ;
} else {
$ . ajax ( {
2013-09-15 15:14:02 +10:00
url : document . location ,
2013-09-15 14:11:09 +10: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 ) ;
2014-01-26 18:07:34 +01:00
// watch.js & auto-reload.js retrigger
2014-01-26 18:58:42 +01:00
setTimeout ( function ( ) { $ ( window ) . trigger ( "scroll" ) ; } , 100 ) ;
2013-09-15 14:11:09 +10:00
}
} ) ;
2013-09-15 15:06:29 +10:00
2013-09-15 14:11:09 +10:00
highlightReply ( post _response . id ) ;
2013-09-15 15:06:29 +10:00
window . location . hash = post _response . id ;
$ ( window ) . scrollTop ( $ ( 'div.post#reply_' + post _response . id ) . offset ( ) . top ) ;
2013-09-15 14:11:09 +10:00
$ ( form ) . find ( 'input[type="submit"]' ) . val ( submit _txt ) ;
$ ( form ) . find ( 'input[type="submit"]' ) . removeAttr ( 'disabled' ) ;
2013-09-15 14:19:25 +10:00
$ ( form ) . find ( ' input [ name = "subject" ] , input [ name = "file_url" ] , \
2015-03-10 16:18:28 -07:00
textarea [ name = "body" ] , input [ type = "file" ] , input [ name = "embed" ] ').val(' ' ) . change ( ) ;
2013-09-15 14:11:09 +10:00
} ,
cache : false ,
contentType : false ,
processData : false
} , 'html' ) ;
}
2013-09-15 20:15:17 +10:00
$ ( form ) . find ( 'input[type="submit"]' ) . val ( _ ( 'Posted...' ) ) ;
2014-10-18 15:31:48 +02:00
$ ( document ) . trigger ( "ajax_after_post" , post _response ) ;
2013-09-15 14:03:27 +10:00
} else {
2014-11-21 04:05:20 -08:00
console . log ( xhr ) ;
2013-09-15 14:03:27 +10:00
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 ) {
2014-11-21 04:05:20 -08:00
console . log ( xhr ) ;
2015-03-11 02:58:03 -07:00
alert ( _ ( 'The server took too long to submit your post. Your post was probably still submitted. If it wasn\'t, 8chan might be experiencing issues right now -- please try your post again later. Error information: ' ) + "<div><textarea>" + JSON . stringify ( xhr ) + "</textarea></div>" ) ;
$ ( form ) . find ( 'input[type="submit"]' ) . val ( submit _txt ) ;
$ ( form ) . find ( 'input[type="submit"]' ) . removeAttr ( 'disabled' ) ;
2013-09-15 14:03:27 +10:00
} ,
data : formData ,
cache : false ,
contentType : false ,
processData : false
2013-09-15 14:11:09 +10:00
} , 'json' ) ;
2013-09-15 14:03:27 +10:00
$ ( form ) . find ( 'input[type="submit"]' ) . val ( _ ( 'Posting...' ) ) ;
$ ( form ) . find ( 'input[type="submit"]' ) . attr ( 'disabled' , true ) ;
return false ;
} ) ;
} ;
2013-09-15 14:54:18 +10:00
$ ( window ) . on ( 'quick-reply' , function ( ) {
2015-03-12 12:19:30 +08:00
$ ( 'div#quick-reply form' ) . off ( 'submit' ) ;
2015-03-11 05:43:51 -07:00
setup _form ( $ ( 'div#quick-reply' ) ) ;
2013-09-15 14:03:27 +10:00
} ) ;
2015-03-12 12:19:30 +08:00
onready ( function ( ) {
// Enable submit button if disabled (cache problem)
$ ( 'input[type="submit"]' ) . removeAttr ( 'disabled' ) ;
setup _form ( $ ( 'div#post-form-outer' ) ) ;
} ) ;
} ( ) ;