mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/VisualEditor
synced 2024-12-01 17:36:35 +00:00
a232147b11
Change-Id: I75ac4b378ef485feead9d0eff34ed7877b94b5d0
357 lines
11 KiB
JavaScript
357 lines
11 KiB
JavaScript
/*!
|
||
* VisualEditor user interface MWAdvancedSettingsPage class.
|
||
*
|
||
* @copyright 2011-2014 VisualEditor Team and others; see AUTHORS.txt
|
||
* @license The MIT License (MIT); see LICENSE.txt
|
||
*/
|
||
|
||
/**
|
||
* MediaWiki meta dialog advanced settings page.
|
||
*
|
||
* @class
|
||
* @extends OO.ui.PageLayout
|
||
*
|
||
* @constructor
|
||
* @param {string} name Unique symbolic name of page
|
||
* @param {Object} [config] Configuration options
|
||
*/
|
||
ve.ui.MWAdvancedSettingsPage = function VeUiMWAdvancedSettingsPage( name, config ) {
|
||
var advancedSettingsPage = this;
|
||
|
||
// Parent constructor
|
||
OO.ui.PageLayout.call( this, name, config );
|
||
|
||
// Properties
|
||
this.metaList = null;
|
||
this.indexingOptionTouched = false;
|
||
this.newSectionEditLinkOptionTouched = false;
|
||
|
||
this.advancedSettingsFieldset = new OO.ui.FieldsetLayout( {
|
||
$: this.$,
|
||
label: ve.msg( 'visualeditor-dialog-meta-advancedsettings-label' ),
|
||
icon: 'advanced'
|
||
} );
|
||
|
||
// Initialization
|
||
|
||
// Indexing items
|
||
this.indexing = new OO.ui.FieldLayout(
|
||
new OO.ui.ButtonSelectWidget( { $: this.$ } )
|
||
.addItems( [
|
||
new OO.ui.ButtonOptionWidget(
|
||
'mwIndexForce',
|
||
{ label: ve.msg( 'visualeditor-dialog-meta-settings-index-force' ) }
|
||
),
|
||
new OO.ui.ButtonOptionWidget(
|
||
'default',
|
||
{ label: ve.msg( 'visualeditor-dialog-meta-settings-index-default' ) }
|
||
),
|
||
new OO.ui.ButtonOptionWidget(
|
||
'mwIndexDisable',
|
||
{ label: ve.msg( 'visualeditor-dialog-meta-settings-index-disable' ) }
|
||
)
|
||
] )
|
||
.connect( this, { select: 'onIndexingOptionChange' } ),
|
||
{
|
||
$: this.$,
|
||
align: 'top',
|
||
label: ve.msg( 'visualeditor-dialog-meta-settings-index-label' )
|
||
}
|
||
);
|
||
|
||
// New edit section link items
|
||
this.newEditSectionLink = new OO.ui.FieldLayout(
|
||
new OO.ui.ButtonSelectWidget( { $: this.$ } )
|
||
.addItems( [
|
||
new OO.ui.ButtonOptionWidget(
|
||
'mwNewSectionEditForce',
|
||
{ label: ve.msg( 'visualeditor-dialog-meta-settings-newsectioneditlink-force' ) }
|
||
),
|
||
new OO.ui.ButtonOptionWidget(
|
||
'default',
|
||
{ label: ve.msg( 'visualeditor-dialog-meta-settings-newsectioneditlink-default' ) }
|
||
),
|
||
new OO.ui.ButtonOptionWidget(
|
||
'mwNewSectionEditDisable',
|
||
{ label: ve.msg( 'visualeditor-dialog-meta-settings-newsectioneditlink-disable' ) }
|
||
)
|
||
] )
|
||
.connect( this, { select: 'onNewSectionEditLinkOptionChange' } ),
|
||
{
|
||
$: this.$,
|
||
align: 'top',
|
||
label: ve.msg( 'visualeditor-dialog-meta-settings-newsectioneditlink-label' )
|
||
}
|
||
);
|
||
|
||
this.displayTitleTouched = false;
|
||
this.enableDisplayTitleInput = new OO.ui.CheckboxInputWidget( { $: this.$ } );
|
||
this.enableDisplayTitleInput.connect( this, { change: 'onEnableDisplayTitleInputChange' } );
|
||
this.enableDisplayTitleField = new OO.ui.FieldLayout(
|
||
this.enableDisplayTitleInput,
|
||
{
|
||
$: this.$,
|
||
align: 'inline',
|
||
label: ve.msg( 'visualeditor-dialog-meta-settings-displaytitle-enable' )
|
||
}
|
||
);
|
||
this.displayTitleInput = new OO.ui.TextInputWidget( {
|
||
$: this.$,
|
||
placeholder: ve.msg( 'visualeditor-dialog-meta-settings-displaytitle' )
|
||
} );
|
||
this.displayTitleInput.connect( this, { change: 'onDisplayTitleInputChange' } );
|
||
this.displayTitleField = new OO.ui.FieldLayout(
|
||
this.displayTitleInput,
|
||
{
|
||
$: this.$,
|
||
align: 'inline'
|
||
}
|
||
);
|
||
|
||
this.advancedSettingsFieldset.addItems( [ this.indexing, this.newEditSectionLink, this.enableDisplayTitleField, this.displayTitleField ] );
|
||
|
||
this.metaItemCheckboxes = [];
|
||
if ( mw.config.get( 'wgVariantArticlePath' ) ) {
|
||
this.metaItemCheckboxes.push(
|
||
{
|
||
metaName: 'mwNoContentConvert',
|
||
label: ve.msg( 'visualeditor-dialog-meta-settings-nocontentconvert-label' )
|
||
},
|
||
{
|
||
metaName: 'mwNoTitleConvert',
|
||
label: ve.msg( 'visualeditor-dialog-meta-settings-notitleconvert-label' )
|
||
}
|
||
);
|
||
}
|
||
|
||
$.each( this.metaItemCheckboxes, function () {
|
||
this.fieldLayout = new OO.ui.FieldLayout(
|
||
new OO.ui.CheckboxInputWidget( { $: this.$ } ),
|
||
{
|
||
$: advancedSettingsPage.$,
|
||
align: 'inline',
|
||
label: this.label
|
||
}
|
||
);
|
||
advancedSettingsPage.advancedSettingsFieldset.addItems( [ this.fieldLayout ] );
|
||
} );
|
||
|
||
this.$element.append( this.advancedSettingsFieldset.$element );
|
||
};
|
||
|
||
/* Inheritance */
|
||
|
||
OO.inheritClass( ve.ui.MWAdvancedSettingsPage, OO.ui.PageLayout );
|
||
|
||
/* Methods */
|
||
|
||
/**
|
||
* Handle redirect state change events.
|
||
*
|
||
* @param {boolean} value Whether a redirect is to be set for this page
|
||
*/
|
||
ve.ui.MWAdvancedSettingsPage.prototype.onEnableDisplayTitleInputChange = function ( value ) {
|
||
this.displayTitleInput.setDisabled( !value );
|
||
if ( !value ) {
|
||
this.displayTitleInput.setValue( '' );
|
||
this.enableDisplayTitleInput.setValue( false );
|
||
}
|
||
this.displayTitleTouched = true;
|
||
};
|
||
|
||
/**
|
||
* Handle redirect state change events.
|
||
*
|
||
* @param {boolean} value Whether a redirect is to be set for this page
|
||
*/
|
||
ve.ui.MWAdvancedSettingsPage.prototype.onDisplayTitleInputChange = function () {
|
||
this.displayTitleTouched = true;
|
||
};
|
||
|
||
/**
|
||
* @inheritdoc
|
||
*/
|
||
ve.ui.MWAdvancedSettingsPage.prototype.setOutlineItem = function ( outlineItem ) {
|
||
// Parent method
|
||
OO.ui.PageLayout.prototype.setOutlineItem.call( this, outlineItem );
|
||
|
||
if ( this.outlineItem ) {
|
||
this.outlineItem
|
||
.setIcon( 'advanced' )
|
||
.setLabel( ve.msg( 'visualeditor-dialog-meta-advancedsettings-section' ) );
|
||
}
|
||
};
|
||
|
||
/* Indexing option methods */
|
||
|
||
/**
|
||
* Handle indexing option state change events.
|
||
*/
|
||
ve.ui.MWAdvancedSettingsPage.prototype.onIndexingOptionChange = function () {
|
||
this.indexingOptionTouched = true;
|
||
};
|
||
|
||
/**
|
||
* Get the first meta item of a given name
|
||
*
|
||
* @param {string} name Name of the meta item
|
||
* @returns {Object|null} Meta item, if any
|
||
*/
|
||
ve.ui.MWAdvancedSettingsPage.prototype.getMetaItem = function ( name ) {
|
||
return this.metaList.getItemsInGroup( name )[0] || null;
|
||
};
|
||
|
||
/* New edit section link option methods */
|
||
|
||
/**
|
||
* Handle new edit section link change events.
|
||
*/
|
||
ve.ui.MWAdvancedSettingsPage.prototype.onNewSectionEditLinkOptionChange = function () {
|
||
this.newSectionEditLinkOptionTouched = true;
|
||
};
|
||
|
||
/**
|
||
* Setup settings page.
|
||
*
|
||
* @param {ve.dm.MetaList} metaList Meta list
|
||
* @param {Object} [data] Dialog setup data
|
||
*/
|
||
ve.ui.MWAdvancedSettingsPage.prototype.setup = function ( metaList ) {
|
||
this.metaList = metaList;
|
||
|
||
var // Indexing items
|
||
indexingField = this.indexing.getField(),
|
||
indexingOption = this.getMetaItem( 'mwIndex' ),
|
||
indexingType = indexingOption && indexingOption.element.type || 'default',
|
||
|
||
// New section edit link items
|
||
newSectionEditField = this.newEditSectionLink.getField(),
|
||
newSectionEditLinkOption = this.getMetaItem( 'mwNewSectionEdit' ),
|
||
newSectionEditLinkType = newSectionEditLinkOption && newSectionEditLinkOption.element.type || 'default',
|
||
|
||
displayTitleItem = this.getMetaItem( 'mwDisplayTitle' ),
|
||
displayTitle = displayTitleItem && displayTitleItem.getAttribute( 'content' ) || '',
|
||
|
||
advancedSettingsPage = this;
|
||
|
||
// Indexing items
|
||
indexingField.selectItem( indexingField.getItemFromData( indexingType ) );
|
||
this.indexingOptionTouched = false;
|
||
|
||
// New section edit link items
|
||
newSectionEditField.selectItem( newSectionEditField.getItemFromData( newSectionEditLinkType ) );
|
||
this.newSectionEditLinkOptionTouched = false;
|
||
|
||
this.enableDisplayTitleInput.setValue( !!displayTitleItem );
|
||
this.displayTitleInput.setValue( displayTitle );
|
||
this.displayTitleInput.setDisabled( !displayTitle );
|
||
this.displayTitleTouched = false;
|
||
|
||
// Simple checkbox items
|
||
$.each( this.metaItemCheckboxes, function () {
|
||
var currentValue = !!advancedSettingsPage.getMetaItem( this.metaName );
|
||
this.fieldLayout.getField().setValue( currentValue );
|
||
} );
|
||
};
|
||
|
||
/**
|
||
* Tear down settings page.
|
||
*
|
||
* @param {Object} [data] Dialog tear down data
|
||
*/
|
||
ve.ui.MWAdvancedSettingsPage.prototype.teardown = function ( data ) {
|
||
// Data initialization
|
||
data = data || {};
|
||
|
||
var // Indexing items
|
||
currentIndexingItem = this.getMetaItem( 'mwIndex' ),
|
||
newIndexingData = this.indexing.getField().getSelectedItem(),
|
||
|
||
// New section edit link items
|
||
currentNewSectionEditLinkItem = this.getMetaItem( 'mwNewSectionEdit' ),
|
||
newNewSectionEditLinkOptionData = this.newEditSectionLink.getField().getSelectedItem(),
|
||
|
||
currentDisplayTitleItem = this.getMetaItem( 'mwDisplayTitle' ),
|
||
newDisplayTitle = this.displayTitleInput.getValue(),
|
||
newDisplayTitleItemData = { type: 'mwDisplayTitle', attributes: { content: newDisplayTitle } },
|
||
|
||
advancedSettingsPage = this;
|
||
|
||
// Alter the indexing option flag iff it's been touched & is actually different
|
||
if ( this.indexingOptionTouched ) {
|
||
if ( newIndexingData.data === 'default' ) {
|
||
if ( currentIndexingItem ) {
|
||
currentIndexingItem.remove();
|
||
}
|
||
} else {
|
||
if ( !currentIndexingItem ) {
|
||
this.metaList.insertMeta( { type: newIndexingData.data } );
|
||
} else if ( currentIndexingItem.element.type !== newIndexingData.data ) {
|
||
currentIndexingItem.replaceWith(
|
||
ve.extendObject( true, {},
|
||
currentIndexingItem.getElement(),
|
||
{ type: newIndexingData.data }
|
||
)
|
||
);
|
||
}
|
||
}
|
||
}
|
||
|
||
// Alter the new section edit option flag iff it's been touched & is actually different
|
||
if ( this.newSectionEditLinkOptionTouched ) {
|
||
if ( newNewSectionEditLinkOptionData.data === 'default' ) {
|
||
if ( currentNewSectionEditLinkItem ) {
|
||
currentNewSectionEditLinkItem.remove();
|
||
}
|
||
} else {
|
||
if ( !currentNewSectionEditLinkItem ) {
|
||
this.metaList.insertMeta( { type: newNewSectionEditLinkOptionData.data } );
|
||
} else if ( currentNewSectionEditLinkItem.element.type !== newNewSectionEditLinkOptionData.data ) {
|
||
currentNewSectionEditLinkItem.replaceWith(
|
||
ve.extendObject( true, {},
|
||
currentNewSectionEditLinkItem.getElement(),
|
||
{ type: newNewSectionEditLinkOptionData.data }
|
||
)
|
||
);
|
||
}
|
||
}
|
||
}
|
||
|
||
if ( this.displayTitleTouched ) {
|
||
if ( currentDisplayTitleItem ) {
|
||
if ( newDisplayTitle ) {
|
||
if ( currentDisplayTitleItem.getAttribute( 'content' ) !== newDisplayTitle ) {
|
||
// There was a display title and is a new one, but they differ, so replace
|
||
currentDisplayTitleItem.replaceWith(
|
||
ve.extendObject( true, {},
|
||
currentDisplayTitleItem.getElement(),
|
||
newDisplayTitleItemData
|
||
) );
|
||
}
|
||
} else {
|
||
// There was a display title and is no new one, so remove
|
||
currentDisplayTitleItem.remove();
|
||
}
|
||
} else {
|
||
if ( newDisplayTitle ) {
|
||
// There's no existing display title but there is a new one, so create
|
||
// HACK: Putting this at index 0, offset 0 so that it works – bug 61862
|
||
this.metaList.insertMeta( newDisplayTitleItemData, 0, 0 );
|
||
}
|
||
}
|
||
}
|
||
|
||
$.each( this.metaItemCheckboxes, function () {
|
||
var currentItem = advancedSettingsPage.getMetaItem( this.metaName ),
|
||
newValue = this.fieldLayout.getField().getValue();
|
||
|
||
if ( currentItem && !newValue ) {
|
||
currentItem.remove();
|
||
} else if ( !currentItem && newValue ) {
|
||
advancedSettingsPage.metaList.insertMeta( { type: this.metaName } );
|
||
}
|
||
} );
|
||
|
||
this.metaList = null;
|
||
};
|