mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/VisualEditor
synced 2024-12-01 17:36:35 +00:00
a56e795f58
Objectives: * Split ve.Surface into ve.Editor and ve.ui.Surface * Move actions, triggers and commands to ve.ui * Move toolbar wrapping, floating, shadow and actions functionality to configurable options of ve.ui.Toolbar * Make ve.ce.Surface and ve.ui.Surface inherit ve.Element and use this.$$ for iframe friendliness * Make the toolbar separately initialized so it's possible to have a surface without one, as well as control where the toolbar is Some change notes: VisualEditor.php * Added standalone module for mediawiki integrated unit testing ve.ce.Surface.js * Remove requirement to pass in an attached container to construct object * Inherit ve.Element and use this.$$ instead of $ * Make getSelectionRect iframe friendly * Move most of the initialize stuff to a new initialize method to be called after the surface is attached to the DOM ve.init.mw.ViewPageTarget.js * Merge toolbar functions into setup/teardown methods * Add toolbar manually (since it's not added by the surface anymore) ve.init.sa.Target.js * Update new init procedure for editor, surface and toolbar separately * Move toolbar floating stuff to ve.Toolbar Change-Id: If91a9d6e76a8be8d1b5a2566394765a37d29a8a7
48 lines
1.3 KiB
JavaScript
48 lines
1.3 KiB
JavaScript
/*!
|
|
* VisualEditor UserInterface Action class.
|
|
*
|
|
* @copyright 2011-2013 VisualEditor Team and others; see AUTHORS.txt
|
|
* @license The MIT License (MIT); see LICENSE.txt
|
|
*/
|
|
|
|
/**
|
|
* Generic action.
|
|
*
|
|
* An action is built around a surface for one-time use. It is a generic way of extending the
|
|
* functionality of a surface. Actions are accessible via {ve.ui.Surface.prototype.execute}.
|
|
*
|
|
* @class
|
|
* @constructor
|
|
* @param {ve.ui.Surface} surface Surface to act on
|
|
*/
|
|
ve.ui.Action = function VeUiAction( surface ) {
|
|
// Properties
|
|
this.surface = surface;
|
|
};
|
|
|
|
/* Static Properties */
|
|
|
|
/**
|
|
* @static
|
|
* @property
|
|
* @inheritable
|
|
*/
|
|
ve.ui.Action.static = {};
|
|
|
|
/**
|
|
* List of allowed methods for the action.
|
|
*
|
|
* To avoid use of methods not intended to be executed via surface.execute(), the methods must be
|
|
* whitelisted here. This information is checked by ve.ui.Surface before executing an action.
|
|
*
|
|
* If a method returns a value, it will be cast to boolean and be used to determine if the action
|
|
* was canceled. Not returning anything, or returning undefined will be treated the same as
|
|
* returning true. A canceled action will yield to other default behavior. For example, when
|
|
* triggering an action from a keystroke, a canceled action will allow normal insertion behavior to
|
|
* be carried out.
|
|
*
|
|
* @static
|
|
* @property
|
|
*/
|
|
ve.ui.Action.static.methods = [];
|