mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/VisualEditor
synced 2024-11-28 00:00:49 +00:00
Fix for default sort key crash
The existing default sort key was being cached when the dialog was constructed, but on the 2nd time launching it the reference was broken. This change gets rid of the caching and always grabs a fresh copy when we need one. Also, the flag indicating the default sort key has changed wasn't being reset properly. Change-Id: I8fb3b088f25212b8c542df65bb5a248550ff6f27
This commit is contained in:
parent
d97114ad10
commit
79df2232a5
|
@ -22,7 +22,6 @@ ve.ui.MWMetaDialog = function VeUiMWMetaDialog( surface ) {
|
|||
|
||||
// Properties
|
||||
this.metaList = surface.getModel().metaList;
|
||||
this.defaultSortKeyItem = this.getDefaultSortKeyItem();
|
||||
this.defaultSortKeyChanged = false;
|
||||
this.fallbackDefaultSortKey = mw.config.get( 'wgTitle' );
|
||||
|
||||
|
@ -83,9 +82,6 @@ ve.ui.MWMetaDialog.prototype.initialize = function () {
|
|||
} );
|
||||
|
||||
// Initialization
|
||||
this.defaultSortInput.setValue(
|
||||
this.defaultSortKeyItem ? this.defaultSortKeyItem.getAttribute( 'content' ) : ''
|
||||
);
|
||||
this.categoryWidget.addItems( this.getCategoryItems() );
|
||||
this.addPage( 'categories', 'Categories', 'tag' )
|
||||
.addPage( 'languages', 'Languages', 'language' );
|
||||
|
@ -103,7 +99,13 @@ ve.ui.MWMetaDialog.prototype.initialize = function () {
|
|||
*/
|
||||
ve.ui.MWMetaDialog.prototype.onOpen = function () {
|
||||
var surfaceModel = this.surface.getModel(),
|
||||
categoryWidget = this.categoryWidget;
|
||||
categoryWidget = this.categoryWidget,
|
||||
defaultSortKeyItem = this.getDefaultSortKeyItem();
|
||||
|
||||
this.defaultSortInput.setValue(
|
||||
defaultSortKeyItem ? defaultSortKeyItem.getAttribute( 'content' ) : ''
|
||||
);
|
||||
this.defaultSortKeyChanged = false;
|
||||
|
||||
// Force all previous transactions to be separate from this history state
|
||||
surfaceModel.breakpoint();
|
||||
|
@ -125,8 +127,9 @@ ve.ui.MWMetaDialog.prototype.onOpen = function () {
|
|||
* @param {string} action Action that caused the window to be closed
|
||||
*/
|
||||
ve.ui.MWMetaDialog.prototype.onClose = function ( action ) {
|
||||
var surfaceModel = this.surface.getModel(),
|
||||
defaultSortKeyItem;
|
||||
var newDefaultSortKeyItem,
|
||||
surfaceModel = this.surface.getModel(),
|
||||
currentDefaultSortKeyItem = this.getDefaultSortKeyItem();
|
||||
|
||||
// Parent method
|
||||
ve.ui.PagedDialog.prototype.onClose.call( this );
|
||||
|
@ -141,14 +144,14 @@ ve.ui.MWMetaDialog.prototype.onClose = function ( action ) {
|
|||
}
|
||||
|
||||
if ( this.defaultSortKeyChanged ) {
|
||||
defaultSortKeyItem = new ve.dm.MWDefaultSortMetaItem( {
|
||||
newDefaultSortKeyItem = new ve.dm.MWDefaultSortMetaItem( {
|
||||
'type': 'MWdefaultSort',
|
||||
'attributes': { 'content': this.defaultSortInput.getValue() }
|
||||
} );
|
||||
if ( this.defaultSortKeyItem ) {
|
||||
this.defaultSortKeyItem.replaceWith( defaultSortKeyItem );
|
||||
if ( currentDefaultSortKeyItem ) {
|
||||
currentDefaultSortKeyItem.replaceWith( newDefaultSortKeyItem );
|
||||
} else {
|
||||
this.metaList.insertMeta( defaultSortKeyItem );
|
||||
this.metaList.insertMeta( newDefaultSortKeyItem );
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue