mirror of
https://github.com/WordPress/WordPress.git
synced 2025-01-23 00:31:28 +01:00
a5478d7adb
* The way that the JS modules for media are currently set up turns the existing global `wp.media` namespace into a read-only API, this is bad. * For the existing module implementation to work with plugins, those looking to override or extend a class would have to modify their own plugin to use `browserify` - we can't expect this to happen * Because the general way that plugins override media classes is via machete (resetting them to something else), we cannot use `require( 'module' )` in the internal code for media modules We CAN continue to use `require( 'fun/js' )` in the manifests for media. Future code/projects should carefully consider what is made to be public API. In 3.5, EVERYTHING was made public, so everything shall remain public. See #31684, #28510. Built from https://develop.svn.wordpress.org/trunk@31935 git-svn-id: http://core.svn.wordpress.org/trunk@31914 1a063a9b-81f0-0310-95a4-ce76da25c4cd
98 lines
1.9 KiB
JavaScript
98 lines
1.9 KiB
JavaScript
/*globals _, Backbone */
|
|
|
|
/**
|
|
* wp.media.view.PriorityList
|
|
*
|
|
* @class
|
|
* @augments wp.media.View
|
|
* @augments wp.Backbone.View
|
|
* @augments Backbone.View
|
|
*/
|
|
var PriorityList = wp.media.View.extend({
|
|
tagName: 'div',
|
|
|
|
initialize: function() {
|
|
this._views = {};
|
|
|
|
this.set( _.extend( {}, this._views, this.options.views ), { silent: true });
|
|
delete this.options.views;
|
|
|
|
if ( ! this.options.silent ) {
|
|
this.render();
|
|
}
|
|
},
|
|
/**
|
|
* @param {string} id
|
|
* @param {wp.media.View|Object} view
|
|
* @param {Object} options
|
|
* @returns {wp.media.view.PriorityList} Returns itself to allow chaining
|
|
*/
|
|
set: function( id, view, options ) {
|
|
var priority, views, index;
|
|
|
|
options = options || {};
|
|
|
|
// Accept an object with an `id` : `view` mapping.
|
|
if ( _.isObject( id ) ) {
|
|
_.each( id, function( view, id ) {
|
|
this.set( id, view );
|
|
}, this );
|
|
return this;
|
|
}
|
|
|
|
if ( ! (view instanceof Backbone.View) ) {
|
|
view = this.toView( view, id, options );
|
|
}
|
|
view.controller = view.controller || this.controller;
|
|
|
|
this.unset( id );
|
|
|
|
priority = view.options.priority || 10;
|
|
views = this.views.get() || [];
|
|
|
|
_.find( views, function( existing, i ) {
|
|
if ( existing.options.priority > priority ) {
|
|
index = i;
|
|
return true;
|
|
}
|
|
});
|
|
|
|
this._views[ id ] = view;
|
|
this.views.add( view, {
|
|
at: _.isNumber( index ) ? index : views.length || 0
|
|
});
|
|
|
|
return this;
|
|
},
|
|
/**
|
|
* @param {string} id
|
|
* @returns {wp.media.View}
|
|
*/
|
|
get: function( id ) {
|
|
return this._views[ id ];
|
|
},
|
|
/**
|
|
* @param {string} id
|
|
* @returns {wp.media.view.PriorityList}
|
|
*/
|
|
unset: function( id ) {
|
|
var view = this.get( id );
|
|
|
|
if ( view ) {
|
|
view.remove();
|
|
}
|
|
|
|
delete this._views[ id ];
|
|
return this;
|
|
},
|
|
/**
|
|
* @param {Object} options
|
|
* @returns {wp.media.View}
|
|
*/
|
|
toView: function( options ) {
|
|
return new wp.media.View( options );
|
|
}
|
|
});
|
|
|
|
module.exports = PriorityList;
|