mediawiki-extensions-Visual.../modules/ve/ui/tools/ve.ui.DialogTool.js
Trevor Parscal 7297108a48 Make toolbars, toolgroups and tools toolFactory independent
Objectives:
* Pass a specific tool factory into a toolbar, allowing it to be used
  with different collections of tools and not depend on the
  ve.ui.toolFactory global
* Move syntax highlight editor tools to their own factory

Change-Id: I307bf180bd6817bc044bc474a77861e13f431ddb
2013-10-03 21:49:36 +00:00

84 lines
1.8 KiB
JavaScript

/*!
* VisualEditor UserInterface DialogTool class.
*
* @copyright 2011-2013 VisualEditor Team and others; see AUTHORS.txt
* @license The MIT License (MIT); see LICENSE.txt
*/
/**
* UserInterface dialog tool.
*
* @abstract
* @class
* @extends ve.ui.Tool
* @constructor
* @param {ve.ui.SurfaceToolbar} toolbar
* @param {Object} [config] Configuration options
*/
ve.ui.DialogTool = function VeUiDialogTool( toolbar, config ) {
// Parent constructor
ve.ui.Tool.call( this, toolbar, config );
};
/* Inheritance */
ve.inheritClass( ve.ui.DialogTool, ve.ui.Tool );
/* Static Properties */
/**
* Symbolic name of dialog the tool opens.
*
* @abstract
* @static
* @property {string}
* @inheritable
*/
ve.ui.DialogTool.static.dialog = '';
/**
* Annotation or node models this tool is related to.
*
* Used by #canEditModel.
*
* @static
* @property {Function[]}
* @inheritable
*/
ve.ui.DialogTool.static.modelClasses = [];
/**
* @inheritdoc
*/
ve.ui.DialogTool.static.canEditModel = function ( model ) {
return ve.isInstanceOfAny( model, this.modelClasses );
};
/* Methods */
/**
* Handle the tool being selected.
*
* @method
*/
ve.ui.DialogTool.prototype.onSelect = function () {
this.toolbar.getSurface().getDialogs().open( this.constructor.static.dialog );
this.setActive( false );
};
/**
* Handle the toolbar state being updated.
*
* @method
* @param {ve.dm.Node[]} nodes List of nodes covered by the current selection
* @param {ve.dm.AnnotationSet} full Annotations that cover all of the current selection
* @param {ve.dm.AnnotationSet} partial Annotations that cover some or all of the current selection
*/
ve.ui.DialogTool.prototype.onUpdateState = function ( nodes ) {
if ( nodes.length ) {
this.setActive(
this.toolbar.getToolFactory().getToolForNode( nodes[0] ) === this.constructor
);
}
};