mediawiki-extensions-Visual.../modules/ve-mw/ui/inspectors/ve.ui.MWAlienExtensionInspector.js
Ed Sanders 852e1ababe MWAlienExtensionNode: Listen to attribute changes
Also:
* Disconnect change event on this.input, which doesn't
  get destroyed on teardown
* Add padding between attributes and this.input
* Assume the alien extensions can have a rendering when
  their body is empty.

Bug: T177181
Bug: T177183
Change-Id: I2e59f8195b255f33f91901213c92ea14793635b4
2017-10-02 16:22:41 +01:00

117 lines
3 KiB
JavaScript

/*!
* VisualEditor UserInterface MWAlienExtensionInspector class.
*
* @copyright 2011-2017 VisualEditor Team and others; see AUTHORS.txt
* @license The MIT License (MIT); see LICENSE.txt
*/
/**
* Inspector for editing alienated MediaWiki extensions.
*
* @class
* @extends ve.ui.MWExtensionInspector
*
* @constructor
* @param {Object} [config] Configuration options
*/
ve.ui.MWAlienExtensionInspector = function VeUiMWAlienExtensionInspector() {
// Parent constructor
ve.ui.MWAlienExtensionInspector.super.apply( this, arguments );
// Properties
this.attributeInputs = {};
this.$attributes = null;
};
/* Inheritance */
OO.inheritClass( ve.ui.MWAlienExtensionInspector, ve.ui.MWExtensionInspector );
/* Static properties */
ve.ui.MWAlienExtensionInspector.static.name = 'alienExtension';
ve.ui.MWAlienExtensionInspector.static.allowedEmpty = true;
ve.ui.MWAlienExtensionInspector.static.modelClasses = [
ve.dm.MWAlienInlineExtensionNode,
ve.dm.MWAlienBlockExtensionNode
];
/* Methods */
/**
* @inheritdoc
*/
ve.ui.MWAlienExtensionInspector.prototype.initialize = function () {
// Parent method
ve.ui.MWAlienExtensionInspector.super.prototype.initialize.apply( this, arguments );
this.$attributes = $( '<div>' ).addClass( 've-ui-mwAlienExtensionInspector-attributes' );
this.form.$element.append( this.$attributes );
};
/**
* @inheritdoc
*/
ve.ui.MWAlienExtensionInspector.prototype.getSetupProcess = function ( data ) {
return ve.ui.MWAlienExtensionInspector.super.prototype.getSetupProcess.call( this, data )
.next( function () {
var key, attributeInput, field,
attributes = this.selectedNode.getAttribute( 'mw' ).attrs;
if ( attributes && !ve.isEmptyObject( attributes ) ) {
for ( key in attributes ) {
attributeInput = new OO.ui.TextInputWidget( {
value: attributes[ key ]
} );
attributeInput.connect( this, { change: 'onChangeHandler' } );
this.attributeInputs[ key ] = attributeInput;
field = new OO.ui.FieldLayout(
attributeInput,
{
align: 'left',
label: key
}
);
this.$attributes.append( field.$element );
}
}
this.title.setLabel( this.selectedNode.getExtensionName() );
}, this );
};
/**
* @inheritdoc
*/
ve.ui.MWAlienExtensionInspector.prototype.getTeardownProcess = function ( data ) {
return ve.ui.MWAlienExtensionInspector.super.prototype.getTeardownProcess.call( this, data )
.next( function () {
this.$attributes.empty();
this.attributeInputs = {};
}, this );
};
/**
* @inheritdoc ve.ui.MWExtensionWindow
*/
ve.ui.MWAlienExtensionInspector.prototype.updateMwData = function ( mwData ) {
var key;
// Parent method
ve.ui.MWAlienExtensionInspector.super.prototype.updateMwData.call( this, mwData );
if ( !ve.isEmptyObject( this.attributeInputs ) ) {
// Make sure we have an attrs object to populate
mwData.attrs = mwData.attrs || {};
for ( key in this.attributeInputs ) {
mwData.attrs[ key ] = this.attributeInputs[ key ].getValue();
}
}
};
/* Registration */
ve.ui.windowFactory.register( ve.ui.MWAlienExtensionInspector );