mediawiki-extensions-Visual.../modules/ve/ui/tools/ve.ui.HistoryButtonTool.js

81 lines
1.9 KiB
JavaScript
Raw Normal View History

/**
* VisualEditor user interface HistoryButtonTool class.
*
* @copyright 2011-2012 VisualEditor Team and others; see AUTHORS.txt
* @license The MIT License (MIT); see LICENSE.txt
*/
2011-12-05 21:10:19 +00:00
/**
* Creates an ve.ui.HistoryButtonTool object.
*
2011-12-05 21:10:19 +00:00
* @class
* @constructor
* @extends {ve.ui.ButtonTool}
* @param {ve.ui.Toolbar} toolbar
2011-12-05 21:10:19 +00:00
* @param {String} name
*/
ve.ui.HistoryButtonTool = function ( toolbar, name, title, data ) {
2011-12-05 21:10:19 +00:00
// Inheritance
ve.ui.ButtonTool.call( this, toolbar, name, title );
2011-12-05 21:10:19 +00:00
// Properties
2011-12-04 02:59:53 +00:00
this.data = data;
this.enabled = false;
this.toolbar.getSurfaceView().model.on( 'history', ve.proxy( this.updateState, this ) );
2011-12-04 02:59:53 +00:00
};
2011-12-05 21:10:19 +00:00
/* Methods */
ve.ui.HistoryButtonTool.prototype.onClick = function () {
2011-12-04 02:59:53 +00:00
switch ( this.name ) {
case 'undo':
case 'redo':
if ( this.isButtonEnabled( this.name ) ) {
var surfaceView = this.toolbar.getSurfaceView();
surfaceView.stopPolling();
surfaceView.showSelection(
surfaceView.getModel()[this.name]( 1 ) || surfaceView.model.selection
);
surfaceView.clearPollData();
surfaceView.startPolling();
}
2011-12-04 02:59:53 +00:00
break;
}
};
ve.ui.HistoryButtonTool.prototype.updateState = function ( annotations ) {
this.enabled = this.isButtonEnabled( this.name );
this.updateEnabled();
};
ve.ui.HistoryButtonTool.prototype.isButtonEnabled = function ( name ) {
var surfaceModel = this.toolbar.getSurfaceView().getModel();
switch( name ) {
case 'undo':
return surfaceModel.bigStack.length - surfaceModel.undoIndex > 0;
case 'redo':
return surfaceModel.undoIndex > 0;
default:
return false;
}
};
2011-12-05 21:10:19 +00:00
/* Registration */
ve.ui.Tool.tools.undo = {
'constructor': ve.ui.HistoryButtonTool,
'name': 'undo',
'title': ve.msg( 'visualeditor-historybutton-undo-tooltip' )
2011-12-04 02:59:53 +00:00
};
ve.ui.Tool.tools.redo = {
'constructor': ve.ui.HistoryButtonTool,
'name': 'redo',
'title': ve.msg( 'visualeditor-historybutton-redo-tooltip' )
2011-12-04 02:59:53 +00:00
};
2011-12-05 21:10:19 +00:00
/* Inhertiance */
2011-12-04 02:59:53 +00:00
ve.extendClass( ve.ui.HistoryButtonTool, ve.ui.ButtonTool );