2011-11-30 23:05:06 +00:00
|
|
|
es.AnnotationButtonTool = function( toolbar, name, data ) {
|
|
|
|
es.ButtonTool.call( this, toolbar, name );
|
|
|
|
this.data = data;
|
|
|
|
};
|
|
|
|
|
|
|
|
es.AnnotationButtonTool.prototype.onClick = function() {
|
2011-12-01 00:37:17 +00:00
|
|
|
var method = this.$.hasClass( 'es-toolbarButtonTool-down' ) ? 'clear' : 'set';
|
2011-11-30 23:05:06 +00:00
|
|
|
|
|
|
|
var tx = this.toolbar.surfaceView.model.getDocument().prepareContentAnnotation(
|
|
|
|
this.toolbar.surfaceView.currentSelection,
|
|
|
|
method,
|
|
|
|
this.data
|
|
|
|
);
|
|
|
|
this.toolbar.surfaceView.model.transact( tx );
|
2011-12-01 00:37:17 +00:00
|
|
|
return false;
|
|
|
|
};
|
|
|
|
|
|
|
|
es.AnnotationButtonTool.prototype.updateState = function( annotations ) {
|
|
|
|
for ( var i = 0; i < annotations.length; i++ ) {
|
|
|
|
if ( annotations[i].type === this.data.type ) {
|
|
|
|
this.$.addClass( 'es-toolbarButtonTool-down' );
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
this.$.removeClass( 'es-toolbarButtonTool-down' );
|
2011-11-30 23:05:06 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
es.Tool.tools.bold = {
|
|
|
|
constructor: es.AnnotationButtonTool,
|
|
|
|
name: 'bold',
|
|
|
|
data: { 'type': 'textStyle/bold' }
|
|
|
|
};
|
|
|
|
|
|
|
|
es.Tool.tools.italic = {
|
|
|
|
constructor: es.AnnotationButtonTool,
|
|
|
|
name: 'italic',
|
|
|
|
data: { 'type': 'textStyle/italic' }
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
es.extendClass( es.AnnotationButtonTool, es.ButtonTool );
|