mirror of
https://github.com/WordPress/WordPress.git
synced 2025-03-02 03:19:28 +00:00
* 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
77 lines
2.0 KiB
JavaScript
77 lines
2.0 KiB
JavaScript
/*globals wp */
|
|
|
|
/**
|
|
* wp.media.controller.EditImage
|
|
*
|
|
* A state for editing (cropping, etc.) an image.
|
|
*
|
|
* @class
|
|
* @augments wp.media.controller.State
|
|
* @augments Backbone.Model
|
|
*
|
|
* @param {object} attributes The attributes hash passed to the state.
|
|
* @param {wp.media.model.Attachment} attributes.model The attachment.
|
|
* @param {string} [attributes.id=edit-image] Unique identifier.
|
|
* @param {string} [attributes.title=Edit Image] Title for the state. Displays in the media menu and the frame's title region.
|
|
* @param {string} [attributes.content=edit-image] Initial mode for the content region.
|
|
* @param {string} [attributes.toolbar=edit-image] Initial mode for the toolbar region.
|
|
* @param {string} [attributes.menu=false] Initial mode for the menu region.
|
|
* @param {string} [attributes.url] Unused. @todo Consider removal.
|
|
*/
|
|
var l10n = wp.media.view.l10n,
|
|
EditImage;
|
|
|
|
EditImage = wp.media.controller.State.extend({
|
|
defaults: {
|
|
id: 'edit-image',
|
|
title: l10n.editImage,
|
|
menu: false,
|
|
toolbar: 'edit-image',
|
|
content: 'edit-image',
|
|
url: ''
|
|
},
|
|
|
|
/**
|
|
* @since 3.9.0
|
|
*/
|
|
activate: function() {
|
|
this.listenTo( this.frame, 'toolbar:render:edit-image', this.toolbar );
|
|
},
|
|
|
|
/**
|
|
* @since 3.9.0
|
|
*/
|
|
deactivate: function() {
|
|
this.stopListening( this.frame );
|
|
},
|
|
|
|
/**
|
|
* @since 3.9.0
|
|
*/
|
|
toolbar: function() {
|
|
var frame = this.frame,
|
|
lastState = frame.lastState(),
|
|
previous = lastState && lastState.id;
|
|
|
|
frame.toolbar.set( new wp.media.view.Toolbar({
|
|
controller: frame,
|
|
items: {
|
|
back: {
|
|
style: 'primary',
|
|
text: l10n.back,
|
|
priority: 20,
|
|
click: function() {
|
|
if ( previous ) {
|
|
frame.setState( previous );
|
|
} else {
|
|
frame.close();
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}) );
|
|
}
|
|
});
|
|
|
|
module.exports = EditImage;
|