Theme Customizer: In JavaScript, add the ability to execute a callback once a set of values have been initialized. see #19910.
git-svn-id: http://svn.automattic.com/wordpress/trunk@20257 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
6ae2e315fa
commit
34fb54887d
|
@ -377,10 +377,14 @@ if ( typeof wp === 'undefined' )
|
|||
|
||||
initialize: function( options ) {
|
||||
api.Value.prototype.initialize.call( this, {}, options || {} );
|
||||
this._deferreds = {};
|
||||
},
|
||||
|
||||
instance: function( id ) {
|
||||
if ( arguments.length === 1 )
|
||||
return this.value( id );
|
||||
|
||||
return this.when.apply( this, arguments );
|
||||
},
|
||||
|
||||
value: function( id ) {
|
||||
|
@ -397,6 +401,10 @@ if ( typeof wp === 'undefined' )
|
|||
|
||||
this._value[ id ] = value;
|
||||
this._value[ id ]._parent = this._value;
|
||||
|
||||
if ( this._deferreds[ id ] )
|
||||
this._deferreds[ id ].resolve();
|
||||
|
||||
return this._value[ id ];
|
||||
},
|
||||
|
||||
|
@ -409,6 +417,7 @@ if ( typeof wp === 'undefined' )
|
|||
|
||||
remove: function( id ) {
|
||||
delete this._value[ id ];
|
||||
delete this._deferreds[ id ];
|
||||
},
|
||||
|
||||
pass: function( fn, args ) {
|
||||
|
@ -422,6 +431,41 @@ if ( typeof wp === 'undefined' )
|
|||
|
||||
value = this.value( id );
|
||||
return value[ fn ].apply( value, args );
|
||||
},
|
||||
|
||||
/**
|
||||
* Runs a callback once all requested values exist.
|
||||
*
|
||||
* when( ids*, callback );
|
||||
*
|
||||
* For example:
|
||||
* when( id1, id2, id3, function( value1, value2, value3 ) {} );
|
||||
*/
|
||||
when: function() {
|
||||
var self = this,
|
||||
ids = slice.call( arguments ),
|
||||
callback = ids.pop();
|
||||
|
||||
$.when.apply( $, $.map( ids, function( id ) {
|
||||
if ( self.has( id ) )
|
||||
return;
|
||||
|
||||
return self._deferreds[ id ] || ( self._deferreds[ id ] = $.Deferred() );
|
||||
})).done( function() {
|
||||
var values = $.map( ids, function( id ) {
|
||||
return self( id );
|
||||
});
|
||||
|
||||
// If a value is missing, we've used at least one expired deferred.
|
||||
// Call Values.when again to update our master deferred.
|
||||
if ( values.length !== ids.length ) {
|
||||
ids.push( callback );
|
||||
self.when.apply( self, ids );
|
||||
return;
|
||||
}
|
||||
|
||||
callback.apply( self, values );
|
||||
});
|
||||
}
|
||||
});
|
||||
|
||||
|
|
Loading…
Reference in New Issue