2015-02-22 07:56:27 +01:00
|
|
|
/*globals _ */
|
|
|
|
|
2015-02-09 01:43:50 +01:00
|
|
|
/**
|
|
|
|
* wp.media.view.AttachmentCompat
|
|
|
|
*
|
|
|
|
* A view to display fields added via the `attachment_fields_to_edit` filter.
|
|
|
|
*
|
|
|
|
* @class
|
|
|
|
* @augments wp.media.View
|
|
|
|
* @augments wp.Backbone.View
|
|
|
|
* @augments Backbone.View
|
|
|
|
*/
|
|
|
|
var View = require( './view.js' ),
|
|
|
|
AttachmentCompat;
|
|
|
|
|
|
|
|
AttachmentCompat = View.extend({
|
|
|
|
tagName: 'form',
|
|
|
|
className: 'compat-item',
|
|
|
|
|
|
|
|
events: {
|
|
|
|
'submit': 'preventDefault',
|
|
|
|
'change input': 'save',
|
|
|
|
'change select': 'save',
|
|
|
|
'change textarea': 'save'
|
|
|
|
},
|
|
|
|
|
|
|
|
initialize: function() {
|
|
|
|
this.listenTo( this.model, 'change:compat', this.render );
|
|
|
|
},
|
|
|
|
/**
|
|
|
|
* @returns {wp.media.view.AttachmentCompat} Returns itself to allow chaining
|
|
|
|
*/
|
|
|
|
dispose: function() {
|
|
|
|
if ( this.$(':focus').length ) {
|
|
|
|
this.save();
|
|
|
|
}
|
|
|
|
/**
|
|
|
|
* call 'dispose' directly on the parent class
|
|
|
|
*/
|
|
|
|
return View.prototype.dispose.apply( this, arguments );
|
|
|
|
},
|
|
|
|
/**
|
|
|
|
* @returns {wp.media.view.AttachmentCompat} Returns itself to allow chaining
|
|
|
|
*/
|
|
|
|
render: function() {
|
|
|
|
var compat = this.model.get('compat');
|
|
|
|
if ( ! compat || ! compat.item ) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
this.views.detach();
|
|
|
|
this.$el.html( compat.item );
|
|
|
|
this.views.render();
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
/**
|
|
|
|
* @param {Object} event
|
|
|
|
*/
|
|
|
|
preventDefault: function( event ) {
|
|
|
|
event.preventDefault();
|
|
|
|
},
|
|
|
|
/**
|
|
|
|
* @param {Object} event
|
|
|
|
*/
|
|
|
|
save: function( event ) {
|
|
|
|
var data = {};
|
|
|
|
|
|
|
|
if ( event ) {
|
|
|
|
event.preventDefault();
|
|
|
|
}
|
|
|
|
|
|
|
|
_.each( this.$el.serializeArray(), function( pair ) {
|
|
|
|
data[ pair.name ] = pair.value;
|
|
|
|
});
|
|
|
|
|
|
|
|
this.controller.trigger( 'attachment:compat:waiting', ['waiting'] );
|
|
|
|
this.model.saveCompat( data ).always( _.bind( this.postSave, this ) );
|
|
|
|
},
|
|
|
|
|
|
|
|
postSave: function() {
|
|
|
|
this.controller.trigger( 'attachment:compat:ready', ['ready'] );
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2015-02-09 17:01:29 +01:00
|
|
|
module.exports = AttachmentCompat;
|