Simplify heartbeat API.
* Move to a method to check connection errors, a better framework for future changes. * Remove start(), stop(), autostart. props carldanley. fixes #23216. git-svn-id: http://core.svn.wordpress.org/trunk@24749 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
5e1ecc90a6
commit
30344d57b8
|
@ -246,7 +246,7 @@ function autosave_loading() {
|
||||||
|
|
||||||
function autosave_enable_buttons() {
|
function autosave_enable_buttons() {
|
||||||
jQuery(document).trigger('autosave-enable-buttons');
|
jQuery(document).trigger('autosave-enable-buttons');
|
||||||
if ( ! wp.heartbeat.connectionLost ) {
|
if ( ! wp.heartbeat.hasConnectionError() ) {
|
||||||
// delay that a bit to avoid some rare collisions while the DOM is being updated.
|
// delay that a bit to avoid some rare collisions while the DOM is being updated.
|
||||||
setTimeout(function(){
|
setTimeout(function(){
|
||||||
var parent = jQuery('#submitpost');
|
var parent = jQuery('#submitpost');
|
||||||
|
|
|
@ -40,10 +40,18 @@ window.wp = window.wp || {};
|
||||||
isUserActive,
|
isUserActive,
|
||||||
userActiveEvents,
|
userActiveEvents,
|
||||||
winBlurTimeout,
|
winBlurTimeout,
|
||||||
frameBlurTimeout = -1;
|
frameBlurTimeout = -1,
|
||||||
|
hasConnectionError = false;
|
||||||
|
|
||||||
this.autostart = true;
|
/**
|
||||||
this.connectionLost = false;
|
* Returns a boolean that's indicative of whether or not there is a connection error
|
||||||
|
*
|
||||||
|
* @returns boolean
|
||||||
|
* @private
|
||||||
|
*/
|
||||||
|
this.hasConnectionError = function() {
|
||||||
|
return hasConnectionError;
|
||||||
|
};
|
||||||
|
|
||||||
if ( typeof( window.heartbeatSettings ) == 'object' ) {
|
if ( typeof( window.heartbeatSettings ) == 'object' ) {
|
||||||
settings = $.extend( {}, window.heartbeatSettings );
|
settings = $.extend( {}, window.heartbeatSettings );
|
||||||
|
@ -121,13 +129,13 @@ window.wp = window.wp || {};
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( trigger && ! self.connectionLost ) {
|
if ( trigger && ! self.hasConnectionError() ) {
|
||||||
self.connectionLost = true;
|
hasConnectionError = true;
|
||||||
$(document).trigger( 'heartbeat-connection-lost', [error] );
|
$(document).trigger( 'heartbeat-connection-lost', [error] );
|
||||||
}
|
}
|
||||||
} else if ( self.connectionLost ) {
|
} else if ( self.hasConnectionError() ) {
|
||||||
errorcount = 0;
|
errorcount = 0;
|
||||||
self.connectionLost = false;
|
hasConnectionError = false;
|
||||||
$(document).trigger( 'heartbeat-connection-restored' );
|
$(document).trigger( 'heartbeat-connection-restored' );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -152,7 +160,7 @@ window.wp = window.wp || {};
|
||||||
|
|
||||||
// If nothing to send (nothing is expecting a response),
|
// If nothing to send (nothing is expecting a response),
|
||||||
// schedule the next tick and bail
|
// schedule the next tick and bail
|
||||||
if ( empty && ! self.connectionLost ) {
|
if ( empty && ! self.hasConnectionError() ) {
|
||||||
connecting = false;
|
connecting = false;
|
||||||
next();
|
next();
|
||||||
return;
|
return;
|
||||||
|
@ -179,7 +187,7 @@ window.wp = window.wp || {};
|
||||||
return errorstate( 'empty' );
|
return errorstate( 'empty' );
|
||||||
|
|
||||||
// Clear error state
|
// Clear error state
|
||||||
if ( self.connectionLost )
|
if ( self.hasConnectionError() )
|
||||||
errorstate();
|
errorstate();
|
||||||
|
|
||||||
if ( response.nonces_expired ) {
|
if ( response.nonces_expired ) {
|
||||||
|
@ -205,7 +213,7 @@ window.wp = window.wp || {};
|
||||||
errorstate( textStatus || 'unknown' );
|
errorstate( textStatus || 'unknown' );
|
||||||
self.error( jqXHR, textStatus, error );
|
self.error( jqXHR, textStatus, error );
|
||||||
});
|
});
|
||||||
};
|
}
|
||||||
|
|
||||||
function next() {
|
function next() {
|
||||||
var delta = time() - tick, t = interval;
|
var delta = time() - tick, t = interval;
|
||||||
|
@ -332,19 +340,16 @@ window.wp = window.wp || {};
|
||||||
|
|
||||||
// Check for user activity every 30 seconds.
|
// Check for user activity every 30 seconds.
|
||||||
window.setInterval( function(){ checkUserActive(); }, 30000 );
|
window.setInterval( function(){ checkUserActive(); }, 30000 );
|
||||||
|
|
||||||
if ( this.autostart ) {
|
|
||||||
$(document).ready( function() {
|
$(document).ready( function() {
|
||||||
// Start one tick (15 sec) after DOM ready
|
// Start one tick (15 sec) after DOM ready
|
||||||
running = true;
|
running = true;
|
||||||
tick = time();
|
tick = time();
|
||||||
next();
|
next();
|
||||||
});
|
});
|
||||||
}
|
|
||||||
|
|
||||||
this.hasFocus = function() {
|
this.hasFocus = function() {
|
||||||
return hasFocus;
|
return hasFocus;
|
||||||
}
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get/Set the interval
|
* Get/Set the interval
|
||||||
|
@ -401,27 +406,6 @@ window.wp = window.wp || {};
|
||||||
return tempInterval ? tempInterval / 1000 : interval / 1000;
|
return tempInterval ? tempInterval / 1000 : interval / 1000;
|
||||||
};
|
};
|
||||||
|
|
||||||
// Start. Has no effect if heartbeat is already running
|
|
||||||
this.start = function() {
|
|
||||||
if ( running )
|
|
||||||
return false;
|
|
||||||
|
|
||||||
running = true;
|
|
||||||
connect();
|
|
||||||
return true;
|
|
||||||
};
|
|
||||||
|
|
||||||
// Stop. If a XHR is in progress, abort it
|
|
||||||
this.stop = function() {
|
|
||||||
if ( self.xhr && self.xhr.readyState != 4 )
|
|
||||||
self.xhr.abort();
|
|
||||||
|
|
||||||
// Reset the error state
|
|
||||||
errorstate();
|
|
||||||
running = false;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Enqueue data to send with the next XHR
|
* Enqueue data to send with the next XHR
|
||||||
*
|
*
|
||||||
|
@ -447,7 +431,7 @@ window.wp = window.wp || {};
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Check if data with a particular handle is queued
|
* Check if data with a particular handle is queued
|
||||||
|
@ -457,8 +441,8 @@ window.wp = window.wp || {};
|
||||||
*/
|
*/
|
||||||
this.isQueued = function( handle ) {
|
this.isQueued = function( handle ) {
|
||||||
return queue[handle];
|
return queue[handle];
|
||||||
}
|
};
|
||||||
}
|
};
|
||||||
|
|
||||||
$.extend( Heartbeat.prototype, {
|
$.extend( Heartbeat.prototype, {
|
||||||
tick: function( data, textStatus, jqXHR ) {
|
tick: function( data, textStatus, jqXHR ) {
|
||||||
|
|
Loading…
Reference in New Issue