/*! * VisualEditor standalone demo * * @copyright 2011-2013 VisualEditor Team and others; see AUTHORS.txt * @license The MIT License (MIT); see LICENSE.txt */ /*global console, alert */ $( function () { // Widgets var startTextInput = new OO.ui.TextInputWidget( { 'readOnly': true } ), endTextInput = new OO.ui.TextInputWidget( { 'readOnly': true } ), startTextInputLabel = new OO.ui.InputLabelWidget( { 'label': 'Start', 'input': startTextInput } ), endTextInputLabel = new OO.ui.InputLabelWidget( { 'label': 'End', 'input': endTextInput } ), getRangeButton = new OO.ui.PushButtonWidget( { 'label': 'Get selected range' } ), logRangeButton = new OO.ui.PushButtonWidget( { 'label': 'Log to console', 'disabled': true } ), dumpModelButton = new OO.ui.PushButtonWidget( { 'label': 'Dump model' } ), validateButton = new OO.ui.PushButtonWidget( { 'label': 'Validate view and model' } ); // Initialization $( '.ve-demo-utilities-commands' ).append( getRangeButton.$element, startTextInputLabel.$element, startTextInput.$element, endTextInputLabel.$element, endTextInput.$element, logRangeButton.$element, $( ' ' ), dumpModelButton.$element, validateButton.$element ); // Events getRangeButton.on( 'click', function () { var range = ve.instances[0].view.model.getSelection(); startTextInput.setValue( range.start ); endTextInput.setValue( range.end ); logRangeButton.setDisabled( false ); } ); logRangeButton.on( 'click', function () { var start = startTextInput.getValue(), end = endTextInput.getValue(); // TODO: Validate input console.dir( ve.instances[0].view.documentView.model.data.slice( start, end ) ); } ); dumpModelButton.on( 'click', function () { /*jshint loopfunc:true */ // linear model dump var i, $li, $label, element, text, annotations, getKids, $ol = $( '
    ' ); for ( i = 0; i < ve.instances[0].model.documentModel.data.getLength(); i++ ) { $li = $( '
  1. ' ); $label = $( '' ); element = ve.instances[0].model.documentModel.data.getData( i ); if ( element.type ) { $label.addClass( 've-demo-dump-element' ); text = element.type; annotations = element.annotations; } else if ( ve.isArray( element ) ){ $label.addClass( 've-demo-dump-achar' ); text = element[0]; annotations = element[1]; } else { $label.addClass( 've-demo-dump-char' ); text = element; annotations = undefined; } $label.html( ( text.match( /\S/ ) ? text : ' ' ) + ' ' ); if ( annotations ) { $label.append( $( '' ).text( '[' + ve.instances[0].model.documentModel.store.values( annotations ).map( function ( ann ) { return ann.name; } ).join( ', ' ) + ']' ) ); } $li.append( $label ); $ol.append( $li ); } $( '#ve-linear-model-dump' ).html( $ol ); // tree dump getKids = function ( obj ) { var $li, i, $ol = $( '
      ' ); for ( i = 0; i < obj.children.length; i++ ) { $li = $( '
    1. ' ); $label = $( '' ).addClass( 've-demo-dump-element' ); if ( obj.children[i].length !== undefined ) { $li.append( $label .text( obj.children[i].type ) .append( $( '' ).text( ' (' + obj.children[i].length + ')' ) ) ); } else { $li.append( $label.text( obj.children[i].type ) ); } if ( obj.children[i].children ) { $li.append( getKids( obj.children[i] ) ); } $ol.append( $li ); } return $ol; }; $( '#ve-model-tree-dump' ).html( getKids( ve.instances[0].model.documentModel.getDocumentNode() ) ); $( '#ve-view-tree-dump' ).html( getKids( ve.instances[0].view.documentView.getDocumentNode() ) ); $( '#ve-dump' ).show(); } ); validateButton.on( 'click', function () { var failed = false; $( '.ve-ce-branchNode' ).each( function ( index, element ) { var nodeRange, textModel, textDom, $element = $( element ), view = $element.data( 'view' ); if ( view.canContainContent() ) { nodeRange = view.model.getRange(); textModel = ve.instances[0].view.model.getDocument().getText( nodeRange ); textDom = ve.ce.getDomText( view.$element[0] ); if ( textModel !== textDom ) { failed = true; console.log( 'Inconsistent data', { 'textModel': textModel, 'textDom': textDom, 'element': element } ); } } } ); if ( failed ) { alert( 'Not valid - check JS console for details' ); } else { alert( 'Valid' ); } } ); } );