mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/VisualEditor
synced 2024-11-16 19:09:29 +00:00
066c663864
Bug: T272481 Change-Id: If044e5d134f1b24f939c4786949e6ca34fb79e1e
188 lines
5.6 KiB
JavaScript
188 lines
5.6 KiB
JavaScript
/*!
|
|
* @license The MIT License (MIT); see LICENSE.txt
|
|
*/
|
|
|
|
/**
|
|
* Container for template, as rendered in the template dialog sidebar.
|
|
*
|
|
* @class
|
|
* @extends ve.ui.MWTransclusionOutlinePartWidget
|
|
*
|
|
* @constructor
|
|
* @param {ve.dm.MWTemplateModel} template
|
|
*/
|
|
ve.ui.MWTransclusionOutlineTemplateWidget = function VeUiMWTransclusionOutlineTemplateWidget( template ) {
|
|
// Parent constructor
|
|
ve.ui.MWTransclusionOutlineTemplateWidget.super.call( this, template, {
|
|
icon: 'puzzle',
|
|
label: template.getSpec().getLabel()
|
|
} );
|
|
|
|
// Initialization
|
|
this.templateModel = template.connect( this, {
|
|
add: 'onAddParameter',
|
|
remove: 'onRemoveParameter'
|
|
} );
|
|
|
|
var widget = this;
|
|
this.paramNames = [];
|
|
var checkboxes = this.templateModel
|
|
.getAllParametersOrdered()
|
|
.filter( function ( paramName ) {
|
|
// Don't create a checkbox for ve.ui.MWParameterPlaceholderPage
|
|
return paramName;
|
|
} )
|
|
.map( function ( paramName ) {
|
|
widget.paramNames.push( paramName );
|
|
return widget.createCheckbox( paramName );
|
|
} );
|
|
|
|
if ( checkboxes.length >= 1 ) {
|
|
this.searchWidget = new OO.ui.SearchInputWidget( {
|
|
placeholder: ve.msg( 'visualeditor-dialog-transclusion-filter-placeholder' )
|
|
} ).connect( this, {
|
|
change: 'onFilterChange'
|
|
} );
|
|
this.infoWidget = new OO.ui.LabelWidget( {
|
|
label: new OO.ui.HtmlSnippet( ve.msg( 'visualeditor-dialog-transclusion-filter-no-match' ) ),
|
|
classes: [ 've-ui-mwTransclusionOutlineTemplateWidget-no-match' ]
|
|
} ).toggle( false );
|
|
}
|
|
|
|
var addParameterButton = new ve.ui.MWTransclusionOutlineButtonWidget( {
|
|
icon: 'parameter',
|
|
label: ve.msg( 'visualeditor-dialog-transclusion-add-param' )
|
|
} )
|
|
.connect( this, { click: 'onAddParameterButtonClick' } );
|
|
|
|
this.parameters = new OO.ui.FieldsetLayout( {
|
|
items: checkboxes
|
|
} );
|
|
this.$element
|
|
.append( this.parameters.$element, addParameterButton.$element );
|
|
if ( this.searchWidget ) {
|
|
this.$element.prepend( this.searchWidget.$element, this.infoWidget.$element );
|
|
}
|
|
};
|
|
|
|
/* Inheritance */
|
|
|
|
OO.inheritClass( ve.ui.MWTransclusionOutlineTemplateWidget, ve.ui.MWTransclusionOutlinePartWidget );
|
|
|
|
/**
|
|
* @param {string} paramName
|
|
* @return {ve.ui.MWTemplateOutlineParameterCheckboxLayout}
|
|
*/
|
|
ve.ui.MWTransclusionOutlineTemplateWidget.prototype.createCheckbox = function ( paramName ) {
|
|
var spec = this.templateModel.getSpec();
|
|
|
|
return new ve.ui.MWTemplateOutlineParameterCheckboxLayout( {
|
|
required: spec.isParameterRequired( paramName ),
|
|
label: spec.getParameterLabel( paramName ),
|
|
data: paramName,
|
|
selected: this.templateModel.hasParameter( paramName )
|
|
} ).connect( this, {
|
|
change: 'onCheckboxChange',
|
|
select: 'onCheckboxSelect'
|
|
} );
|
|
};
|
|
|
|
/**
|
|
* Handles a template model add event {@see ve.dm.MWTemplateModel}.
|
|
* Triggered when a parameter is added to the template model.
|
|
*
|
|
* @param {ve.dm.MWParameterModel} param
|
|
*/
|
|
ve.ui.MWTransclusionOutlineTemplateWidget.prototype.onAddParameter = function ( param ) {
|
|
var paramName = param.getName(),
|
|
checkbox = this.parameters.findItemFromData( paramName );
|
|
|
|
// All parameters known via the spec already have a checkbox
|
|
if ( checkbox ) {
|
|
checkbox.setSelected( true, true );
|
|
} else if ( paramName ) {
|
|
this.parameters.addItems(
|
|
[ this.createCheckbox( paramName ) ],
|
|
this.templateModel.getAllParametersOrdered().indexOf( paramName )
|
|
);
|
|
}
|
|
};
|
|
|
|
/**
|
|
* Handles a template model remove event {@see ve.dm.MWTemplateModel}.
|
|
* Triggered when a parameter is removed from the template model.
|
|
*
|
|
* @param {ve.dm.MWParameterModel} param
|
|
*/
|
|
ve.ui.MWTransclusionOutlineTemplateWidget.prototype.onRemoveParameter = function ( param ) {
|
|
var checkbox = this.parameters.findItemFromData( param.getName() );
|
|
if ( checkbox ) {
|
|
checkbox.setSelected( false, true );
|
|
}
|
|
};
|
|
|
|
/**
|
|
* Handles a parameter checkbox change event {@see ve.ui.MWTemplateOutlineParameterCheckboxLayout}
|
|
*
|
|
* @param {string} paramName
|
|
* @param {boolean} checked New checkbox state
|
|
*/
|
|
ve.ui.MWTransclusionOutlineTemplateWidget.prototype.onCheckboxChange = function ( paramName, checked ) {
|
|
var param = this.templateModel.getParameter( paramName );
|
|
if ( !checked ) {
|
|
this.templateModel.removeParameter( param );
|
|
} else if ( !param ) {
|
|
this.templateModel.addParameter( new ve.dm.MWParameterModel( this.templateModel, paramName ) );
|
|
}
|
|
};
|
|
|
|
/**
|
|
* @param {string} paramName
|
|
*/
|
|
ve.ui.MWTransclusionOutlineTemplateWidget.prototype.onCheckboxSelect = function ( paramName ) {
|
|
var param = this.templateModel.getParameter( paramName );
|
|
if ( param ) {
|
|
// FIXME: This triggers a chain of events that (re)does way to much. Replace!
|
|
this.templateModel.addParameter( param );
|
|
}
|
|
};
|
|
|
|
ve.ui.MWTransclusionOutlineTemplateWidget.prototype.onAddParameterButtonClick = function () {
|
|
// FIXME: This triggers a chain of events that (re)does way to much. Replace!
|
|
this.templateModel.addParameter( new ve.dm.MWParameterModel( this.templateModel ) );
|
|
};
|
|
|
|
/**
|
|
* Handles a parameter filter change event
|
|
*
|
|
* @param {string} data user input
|
|
*/
|
|
ve.ui.MWTransclusionOutlineTemplateWidget.prototype.onFilterChange = function ( data ) {
|
|
|
|
var widget = this;
|
|
this.infoWidget.toggle( false );
|
|
|
|
// hide all parameter names
|
|
this.paramNames.forEach( function ( name ) {
|
|
var paramCheckbox = widget.parameters.findItemFromData( name );
|
|
paramCheckbox.toggle( false );
|
|
} );
|
|
|
|
// find matches
|
|
data = data.toLowerCase();
|
|
var matches = this.paramNames.filter( function ( paramName ) {
|
|
return paramName.toLowerCase().indexOf( data ) !== -1;
|
|
} );
|
|
|
|
// display matches only
|
|
matches.forEach( function ( match ) {
|
|
var paramCheckbox = widget.parameters.findItemFromData( match );
|
|
paramCheckbox.toggle( true );
|
|
} );
|
|
|
|
// handle no results
|
|
if ( matches.length === 0 ) {
|
|
this.infoWidget.toggle( true );
|
|
}
|
|
};
|