mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/VisualEditor
synced 2024-11-26 23:31:02 +00:00
d8359da409
Change-Id: I894835a0178beddce480c48917700090b31c80b2
116 lines
2.8 KiB
JavaScript
116 lines
2.8 KiB
JavaScript
/**
|
|
* Creates an ve.ui.IndentationButtonTool object.
|
|
*
|
|
* @class
|
|
* @constructor
|
|
* @extends {ve.ui.ButtonTool}
|
|
* @param {ve.ui.Toolbar} toolbar
|
|
* @param {String} name
|
|
*/
|
|
ve.ui.IndentationButtonTool = function( toolbar, name, title, data ) {
|
|
ve.ui.ButtonTool.call( this, toolbar, name, title );
|
|
this.data = data;
|
|
};
|
|
|
|
/* Methods */
|
|
|
|
ve.ui.IndentationButtonTool.prototype.onClick = function() {
|
|
if ( !this.$.hasClass( 'es-toolbarButtonTool-disabled' ) ) {
|
|
var listItems = [],
|
|
listItem,
|
|
i;
|
|
for ( i = 0; i < this.nodes.length; i++ ) {
|
|
listItem = this.nodes[i].getParent();
|
|
if ( listItems.length > 0 ) {
|
|
if (listItem != listItems[listItems.length - 1]) {
|
|
listItems.push( listItem );
|
|
}
|
|
} else {
|
|
listItems.push( listItem );
|
|
}
|
|
}
|
|
if ( this.name === 'indent' ) {
|
|
this.indent( listItems );
|
|
} else if ( this.name === 'outdent' ) {
|
|
this.outdent( listItems );
|
|
}
|
|
}
|
|
};
|
|
|
|
ve.ui.IndentationButtonTool.prototype.indent = function( listItems ) {
|
|
var surface = this.toolbar.surfaceView,
|
|
styles,
|
|
i;
|
|
|
|
for ( i = 0; i < listItems.length; i++ ) {
|
|
styles = listItems[i].getElementAttribute( 'styles' );
|
|
if ( styles.length < 6 ) {
|
|
tx = surface.model.getDocument().prepareElementAttributeChange(
|
|
surface.documentView.model.getOffsetFromNode( listItems[i], false ),
|
|
'styles',
|
|
styles.concat( styles[styles.length - 1] )
|
|
);
|
|
surface.model.transact( tx );
|
|
}
|
|
}
|
|
surface.emitCursor();
|
|
};
|
|
|
|
ve.ui.IndentationButtonTool.prototype.outdent = function( listItems ) {
|
|
var surface = this.toolbar.surfaceView,
|
|
styles,
|
|
i;
|
|
|
|
for ( i = 0; i < listItems.length; i++ ) {
|
|
styles = listItems[i].getElementAttribute( 'styles' );
|
|
if ( styles.length > 1 ) {
|
|
tx = surface.model.getDocument().prepareElementAttributeChange(
|
|
surface.documentView.model.getOffsetFromNode( listItems[i], false ),
|
|
'styles',
|
|
styles.slice( 0, styles.length - 1 )
|
|
);
|
|
surface.model.transact( tx );
|
|
}
|
|
}
|
|
surface.emitCursor();
|
|
};
|
|
|
|
ve.ui.IndentationButtonTool.prototype.updateState = function( annotations, nodes ) {
|
|
function areListItems( nodes ) {
|
|
for( var i = 0; i < nodes.length; i++ ) {
|
|
if (
|
|
nodes[i].parent !== null &&
|
|
nodes[i].getParent().getType() !== 'listItem' )
|
|
{
|
|
return false;
|
|
}
|
|
}
|
|
return true;
|
|
}
|
|
|
|
this.nodes = nodes;
|
|
if ( areListItems( this.nodes ) ) {
|
|
this.$.removeClass( 'es-toolbarButtonTool-disabled' );
|
|
} else {
|
|
this.$.addClass( 'es-toolbarButtonTool-disabled' );
|
|
}
|
|
};
|
|
|
|
/* Registration */
|
|
|
|
ve.ui.Tool.tools.indent = {
|
|
'constructor': ve.ui.IndentationButtonTool,
|
|
'name': 'indent',
|
|
'title': 'Increase indentation'
|
|
};
|
|
|
|
ve.ui.Tool.tools.outdent = {
|
|
'constructor': ve.ui.IndentationButtonTool,
|
|
'name': 'outdent',
|
|
'title': 'Reduce indentation'
|
|
};
|
|
|
|
/* Inheritance */
|
|
|
|
ve.extendClass( ve.ui.IndentationButtonTool, ve.ui.ButtonTool );
|