diff options
Diffstat (limited to 'lib/scripts/locktimer.js')
-rw-r--r-- | lib/scripts/locktimer.js | 103 |
1 files changed, 55 insertions, 48 deletions
diff --git a/lib/scripts/locktimer.js b/lib/scripts/locktimer.js index f5ba1c60d..ad3e7ff62 100644 --- a/lib/scripts/locktimer.js +++ b/lib/scripts/locktimer.js @@ -1,61 +1,60 @@ /** - * Class managing the timer to display a warning on a expiring lock - */ +* Class managing the timer to display a warning on a expiring lock +*/ var locktimer = { - sack: null, - timeout: 0, - timerID: null, + sack: null, + timeout: 0, + timerID: null, lasttime: null, - msg: '', - pageid: '', + msg: '', + pageid: '', init: function(timeout,msg,draft){ // init values - locktimer.timeout = timeout*1000; - locktimer.msg = msg; - locktimer.draft = draft; - locktimer.lasttime = new Date(); + this.timeout = timeout*1000; + this.msg = msg; + this.draft = draft; + this.lasttime = new Date(); - if(!$('dw__editform')) return; - locktimer.pageid = $('dw__editform').elements.id.value; - if(!locktimer.pageid) return; - if($('wiki__text').readOnly) return; - - // init ajax component - locktimer.sack = new sack(DOKU_BASE + 'lib/exe/ajax.php'); - locktimer.sack.AjaxFailedAlert = ''; - locktimer.sack.encodeURIString = false; - locktimer.sack.onCompletion = locktimer.refreshed; + if(jQuery('#dw__editform').length == 0) return; + this.pageid = jQuery('#dw__editform input[name=id]').val(); + if(!this.pageid) return; + + if(jQuery('#wiki__text').attr('readonly')) return; // register refresh event - addEvent($('dw__editform'),'keypress',function(){locktimer.refresh();}); + jQuery('#dw__editform').keypress( + function() { + locktimer.refresh(); + } + ); // start timer - locktimer.reset(); + this.reset(); }, /** * (Re)start the warning timer */ reset: function(){ - locktimer.clear(); - locktimer.timerID = window.setTimeout("locktimer.warning()", locktimer.timeout); + this.clear(); + this.timerID = window.setTimeout("locktimer.warning()", this.timeout); }, /** * Display the warning about the expiring lock */ warning: function(){ - locktimer.clear(); - alert(locktimer.msg); + this.clear(); + alert(this.msg); }, /** * Remove the current warning timer */ clear: function(){ - if(locktimer.timerID !== null){ - window.clearTimeout(locktimer.timerID); - locktimer.timerID = null; + if(this.timerID !== null){ + window.clearTimeout(this.timerID); + this.timerID = null; } }, @@ -66,34 +65,42 @@ var locktimer = { */ refresh: function(){ var now = new Date(); + var params = {}; // refresh every minute only - if(now.getTime() - locktimer.lasttime.getTime() > 30*1000){ - var params = 'call=lock&id='+encodeURIComponent(locktimer.pageid); - var dwform = $('dw__editform'); - if(locktimer.draft && dwform.elements.wikitext){ - params += '&prefix='+encodeURIComponent(dwform.elements.prefix.value); - params += '&wikitext='+encodeURIComponent(dwform.elements.wikitext.value); - params += '&suffix='+encodeURIComponent(dwform.elements.suffix.value); - if(dwform.elements.date){ - params += '&date='+encodeURIComponent(dwform.elements.date.value); + if(now.getTime() - this.lasttime.getTime() > 30*1000){ + params['call'] = 'lock'; + params['id'] = locktimer.pageid; + + if(locktimer.draft && jQuery('#dw__editform textarea[name=wikitext]').length > 0){ + params['prefix'] = jQuery('#dw__editform input[name=prefix]').val(); + params['wikitext'] = jQuery('#dw__editform textarea[name=wikitext]').val(); + params['suffix'] = jQuery('#dw__editform input[name=suffix]').val(); + if(jQuery('#dw__editform input[name=date]').length > 0) { + params['date'] = jQuery('#dw__editform input[name=id]').val(); } } - locktimer.sack.runAJAX(params); - locktimer.lasttime = now; + + jQuery.post( + DOKU_BASE + 'lib/exe/ajax.php', + params, + function (data) { + locktimer.refreshed(data); + }, + 'html' + ); + this.lasttime = now; } }, /** * Callback. Resets the warning timer */ - refreshed: function(){ - var data = this.response; + refreshed: function(data){ var error = data.charAt(0); - data = data.substring(1); + data = data.substring(1); - $('draft__status').innerHTML=data; + jQuery('#draft__status').html(data); if(error != '1') return; // locking failed - locktimer.reset(); + this.reset(); } -}; - +};
\ No newline at end of file |