mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/VisualEditor
synced 2024-11-28 00:00:49 +00:00
Merge "Convert save checkboxes to OOUI widgets"
This commit is contained in:
commit
14dde31998
|
@ -43,7 +43,9 @@ ve.init.mw.DesktopArticleTarget = function VeInitMwDesktopArticleTarget( config
|
||||||
this.toolbarSetupDeferred = null;
|
this.toolbarSetupDeferred = null;
|
||||||
this.welcomeDialog = null;
|
this.welcomeDialog = null;
|
||||||
this.welcomeDialogPromise = null;
|
this.welcomeDialogPromise = null;
|
||||||
this.$checkboxes = null;
|
this.checkboxFields = null;
|
||||||
|
this.checkboxesByName = null;
|
||||||
|
this.$otherFields = null;
|
||||||
|
|
||||||
// If this is true then #transformPage / #restorePage will not call pushState
|
// If this is true then #transformPage / #restorePage will not call pushState
|
||||||
// This is to avoid adding a new history entry for the url we just got from onpopstate
|
// This is to avoid adding a new history entry for the url we just got from onpopstate
|
||||||
|
@ -231,25 +233,68 @@ ve.init.mw.DesktopArticleTarget.prototype.loadSuccess = function ( response ) {
|
||||||
// Parent method
|
// Parent method
|
||||||
ve.init.mw.DesktopArticleTarget.super.prototype.loadSuccess.apply( this, arguments );
|
ve.init.mw.DesktopArticleTarget.super.prototype.loadSuccess.apply( this, arguments );
|
||||||
|
|
||||||
var data = response ? response.visualeditor : {};
|
var $checkboxes, defaults,
|
||||||
|
target = this,
|
||||||
|
data = response ? response.visualeditor : {};
|
||||||
|
|
||||||
|
this.checkboxFields = [];
|
||||||
|
this.checkboxesByName = {};
|
||||||
|
this.$otherFields = $( [] );
|
||||||
|
|
||||||
if ( data.checkboxes ) {
|
if ( data.checkboxes ) {
|
||||||
this.$checkboxes = $( ve.getObjectValues( data.checkboxes ).join( '' ) );
|
defaults = {
|
||||||
// Populate checkboxes with default values for minor and watch
|
wpMinoredit: !!mw.user.options.get( 'minordefault' ),
|
||||||
this.$checkboxes
|
wpWatchthis: !!mw.user.options.get( 'watchdefault' ) ||
|
||||||
.filter( '#wpMinoredit' )
|
( !!mw.user.options.get( 'watchcreations' ) && !this.pageExists ) ||
|
||||||
.prop( 'checked', mw.user.options.get( 'minordefault' ) )
|
|
||||||
.end()
|
|
||||||
.filter( '#wpWatchthis' )
|
|
||||||
.prop( 'checked',
|
|
||||||
mw.user.options.get( 'watchdefault' ) ||
|
|
||||||
( mw.user.options.get( 'watchcreations' ) && !this.pageExists ) ||
|
|
||||||
data.watched === ''
|
data.watched === ''
|
||||||
|
};
|
||||||
|
|
||||||
|
$checkboxes = $( '<div>' ).html( ve.getObjectValues( data.checkboxes ).join( '' ) );
|
||||||
|
$checkboxes.find( 'input[type=checkbox]' ).each( function () {
|
||||||
|
var $label, title, checkbox,
|
||||||
|
$this = $( this ),
|
||||||
|
name = $this.attr( 'name' ),
|
||||||
|
id = $this.attr( 'id' );
|
||||||
|
|
||||||
|
if ( !name ) {
|
||||||
|
// This really shouldn't happen..
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Label with for=id
|
||||||
|
if ( id ) {
|
||||||
|
$label = $checkboxes.find( 'label[for=' + id + ']' );
|
||||||
|
}
|
||||||
|
// Label wrapped input
|
||||||
|
if ( !$label ) {
|
||||||
|
$label = $this.closest( 'label' );
|
||||||
|
}
|
||||||
|
if ( $label ) {
|
||||||
|
title = $label.attr( 'title' );
|
||||||
|
$label.find( 'a' ).attr( 'target', '_blank' );
|
||||||
|
}
|
||||||
|
checkbox = new OO.ui.CheckboxInputWidget( {
|
||||||
|
value: $this.attr( 'value' ),
|
||||||
|
selected: name && defaults[name]
|
||||||
|
} );
|
||||||
|
// HACK: CheckboxInputWidget doesn't support access keys
|
||||||
|
checkbox.$input.attr( 'accesskey', $( this ).attr( 'accesskey' ) );
|
||||||
|
target.checkboxFields.push(
|
||||||
|
new OO.ui.FieldLayout( checkbox, {
|
||||||
|
align: 'inline',
|
||||||
|
label: $label ? $label.contents() : undefined,
|
||||||
|
title: title
|
||||||
|
} )
|
||||||
);
|
);
|
||||||
|
target.checkboxesByName[name] = checkbox;
|
||||||
|
} );
|
||||||
|
this.$otherFields = $checkboxes.find( 'input[type!=checkbox]' );
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handle the watch button being toggled on/off.
|
* Handle the watch button being toggled on/off.
|
||||||
|
*
|
||||||
* @param {jQuery.Event} e Event object whih triggered the event
|
* @param {jQuery.Event} e Event object whih triggered the event
|
||||||
* @param {string} actionPerformed 'watch' or 'unwatch'
|
* @param {string} actionPerformed 'watch' or 'unwatch'
|
||||||
*/
|
*/
|
||||||
|
@ -257,12 +302,13 @@ ve.init.mw.DesktopArticleTarget.prototype.onWatchToggle = function ( e, actionPe
|
||||||
if ( !this.active && !this.activating ) {
|
if ( !this.active && !this.activating ) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
this.$checkboxes.filter( '#wpWatchthis' )
|
if ( this.checkboxesByName.wpWatchthis ) {
|
||||||
.prop( 'checked',
|
this.checkboxesByName.wpWatchthis.setSelected(
|
||||||
mw.user.options.get( 'watchdefault' ) ||
|
!!mw.user.options.get( 'watchdefault' ) ||
|
||||||
( mw.user.options.get( 'watchcreations' ) && !this.pageExists ) ||
|
( !!mw.user.options.get( 'watchcreations' ) && !this.pageExists ) ||
|
||||||
actionPerformed === 'watch'
|
actionPerformed === 'watch'
|
||||||
);
|
);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -614,10 +660,7 @@ ve.init.mw.DesktopArticleTarget.prototype.saveComplete = function (
|
||||||
// Just checking for mw.page.watch is not enough because in Firefox
|
// Just checking for mw.page.watch is not enough because in Firefox
|
||||||
// there is Object.prototype.watch...
|
// there is Object.prototype.watch...
|
||||||
if ( mw.page.hasOwnProperty( 'watch' ) ) {
|
if ( mw.page.hasOwnProperty( 'watch' ) ) {
|
||||||
watchChecked = this.saveDialog.$saveOptions
|
watchChecked = this.checkboxesByName.wpWatchthis && this.checkboxesByName.wpWatchthis.isSelected();
|
||||||
.find( '.ve-ui-mwSaveDialog-checkboxes' )
|
|
||||||
.find( '#wpWatchthis' )
|
|
||||||
.prop( 'checked' );
|
|
||||||
mw.page.watch.updateWatchLink(
|
mw.page.watch.updateWatchLink(
|
||||||
$( '#ca-watch a, #ca-unwatch a' ),
|
$( '#ca-watch a, #ca-unwatch a' ),
|
||||||
watchChecked ? 'unwatch' : 'watch'
|
watchChecked ? 'unwatch' : 'watch'
|
||||||
|
@ -764,20 +807,23 @@ ve.init.mw.DesktopArticleTarget.prototype.editSource = function () {
|
||||||
* @inheritdoc
|
* @inheritdoc
|
||||||
*/
|
*/
|
||||||
ve.init.mw.DesktopArticleTarget.prototype.getSaveFields = function () {
|
ve.init.mw.DesktopArticleTarget.prototype.getSaveFields = function () {
|
||||||
var checkboxFields = {};
|
var name, fieldValues = {};
|
||||||
|
|
||||||
this.$checkboxes
|
for ( name in this.checkboxesByName ) {
|
||||||
.each( function () {
|
if ( this.checkboxesByName[name].isSelected() ) {
|
||||||
var $this = $( this );
|
fieldValues[name] = this.checkboxesByName[name].getValue();
|
||||||
// We can't just use $this.val() because .val() always returns the value attribute of
|
}
|
||||||
// a checkbox even when it's unchecked
|
}
|
||||||
if ( $this.prop( 'name' ) && ( $this.prop( 'type' ) !== 'checkbox' || $this.prop( 'checked' ) ) ) {
|
this.$otherFields.each( function () {
|
||||||
checkboxFields[$this.prop( 'name' )] = $this.val();
|
var $this = $( this ),
|
||||||
|
name = $this.prop( 'name' );
|
||||||
|
if ( name ) {
|
||||||
|
fieldValues[name] = $this.val();
|
||||||
}
|
}
|
||||||
} );
|
} );
|
||||||
|
|
||||||
return ve.extendObject(
|
return ve.extendObject(
|
||||||
checkboxFields,
|
fieldValues,
|
||||||
ve.init.mw.DesktopArticleTarget.super.prototype.getSaveFields.call( this )
|
ve.init.mw.DesktopArticleTarget.super.prototype.getSaveFields.call( this )
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
@ -886,7 +932,8 @@ ve.init.mw.DesktopArticleTarget.prototype.openSaveDialog = function () {
|
||||||
windowAction.open( 'mwSave', {
|
windowAction.open( 'mwSave', {
|
||||||
target: this,
|
target: this,
|
||||||
editSummary: this.initialEditSummary,
|
editSummary: this.initialEditSummary,
|
||||||
$checkboxes: this.$checkboxes
|
checkboxFields: this.checkboxFields,
|
||||||
|
checkboxesByName: this.checkboxesByName
|
||||||
} );
|
} );
|
||||||
this.initialEditSummary = undefined;
|
this.initialEditSummary = undefined;
|
||||||
};
|
};
|
||||||
|
|
|
@ -27,6 +27,7 @@ ve.ui.MWSaveDialog = function VeUiMwSaveDialog( config ) {
|
||||||
this.messages = {};
|
this.messages = {};
|
||||||
this.setupDeferred = $.Deferred();
|
this.setupDeferred = $.Deferred();
|
||||||
this.target = null;
|
this.target = null;
|
||||||
|
this.checkboxesByName = null;
|
||||||
|
|
||||||
// Initialization
|
// Initialization
|
||||||
this.$element.addClass( 've-ui-mwSaveDialog' );
|
this.$element.addClass( 've-ui-mwSaveDialog' );
|
||||||
|
@ -292,8 +293,9 @@ ve.ui.MWSaveDialog.prototype.reset = function () {
|
||||||
// Reset summary input
|
// Reset summary input
|
||||||
this.editSummaryInput.setValue( '' );
|
this.editSummaryInput.setValue( '' );
|
||||||
// Uncheck minoredit
|
// Uncheck minoredit
|
||||||
this.$saveOptions.find( '.ve-ui-mwSaveDialog-checkboxes' )
|
if ( this.checkboxesByName.wpMinoredit ) {
|
||||||
.find( '#wpMinoredit' ).prop( 'checked', false );
|
this.checkboxesByName.wpMinoredit.setSelected( false );
|
||||||
|
}
|
||||||
// Clear the diff
|
// Clear the diff
|
||||||
this.$reviewViewer.empty();
|
this.$reviewViewer.empty();
|
||||||
};
|
};
|
||||||
|
@ -303,19 +305,14 @@ ve.ui.MWSaveDialog.prototype.reset = function () {
|
||||||
*
|
*
|
||||||
* This method is safe to call even when the dialog hasn't been initialized yet.
|
* This method is safe to call even when the dialog hasn't been initialized yet.
|
||||||
*
|
*
|
||||||
* @param {jQuery} $checkboxes jQuery collection of checkboxes
|
* @param {OO.ui.FieldLayout[]} checkboxFields Checkbox fields
|
||||||
*/
|
*/
|
||||||
ve.ui.MWSaveDialog.prototype.setupCheckboxes = function ( $checkboxes ) {
|
ve.ui.MWSaveDialog.prototype.setupCheckboxes = function ( checkboxFields ) {
|
||||||
var dialog = this;
|
var dialog = this;
|
||||||
this.setupDeferred.done( function () {
|
this.setupDeferred.done( function () {
|
||||||
dialog.$saveOptions.find( '.ve-ui-mwSaveDialog-checkboxes' )
|
checkboxFields.forEach( function ( field ) {
|
||||||
.empty()
|
dialog.$saveCheckboxes.append( field.$element );
|
||||||
.append( $checkboxes )
|
} );
|
||||||
.find( 'a' )
|
|
||||||
.attr( 'target', '_blank' )
|
|
||||||
.end()
|
|
||||||
.find( 'input' )
|
|
||||||
.prop( 'tabIndex', 0 );
|
|
||||||
} );
|
} );
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -388,8 +385,9 @@ ve.ui.MWSaveDialog.prototype.initialize = function () {
|
||||||
);
|
);
|
||||||
} );
|
} );
|
||||||
|
|
||||||
|
this.$saveCheckboxes = $( '<div>' ).addClass( 've-ui-mwSaveDialog-checkboxes' );
|
||||||
this.$saveOptions = $( '<div>' ).addClass( 've-ui-mwSaveDialog-options' ).append(
|
this.$saveOptions = $( '<div>' ).addClass( 've-ui-mwSaveDialog-options' ).append(
|
||||||
$( '<div>' ).addClass( 've-ui-mwSaveDialog-checkboxes' ),
|
this.$saveCheckboxes,
|
||||||
this.editSummaryCountLabel.$element
|
this.editSummaryCountLabel.$element
|
||||||
);
|
);
|
||||||
this.$saveMessages = $( '<div>' );
|
this.$saveMessages = $( '<div>' );
|
||||||
|
@ -477,7 +475,8 @@ ve.ui.MWSaveDialog.prototype.getSetupProcess = function ( data ) {
|
||||||
if ( data.editSummary !== undefined ) {
|
if ( data.editSummary !== undefined ) {
|
||||||
this.setEditSummary( data.editSummary );
|
this.setEditSummary( data.editSummary );
|
||||||
}
|
}
|
||||||
this.setupCheckboxes( data.$checkboxes );
|
this.setupCheckboxes( data.checkboxFields );
|
||||||
|
this.checkboxesByName = data.checkboxesByName || {};
|
||||||
// Old messages should not persist
|
// Old messages should not persist
|
||||||
this.clearAllMessages();
|
this.clearAllMessages();
|
||||||
this.swapPanel( 'save' );
|
this.swapPanel( 'save' );
|
||||||
|
|
|
@ -35,17 +35,12 @@
|
||||||
|
|
||||||
.ve-ui-mwSaveDialog-checkboxes {
|
.ve-ui-mwSaveDialog-checkboxes {
|
||||||
margin-right: 3.25em; /* Hack to prevent overlap on edit summary count */
|
margin-right: 3.25em; /* Hack to prevent overlap on edit summary count */
|
||||||
line-height: 3em;
|
padding: 0.2em 0.75em 0 0.75em;
|
||||||
padding: 0 0.75em;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.ve-ui-mwSaveDialog-checkboxes label {
|
.ve-ui-mwSaveDialog-checkboxes .oo-ui-fieldLayout {
|
||||||
padding-right: 0.75em;
|
display: inline-block;
|
||||||
vertical-align: middle;
|
margin: 0 1.5em 0 0;
|
||||||
}
|
|
||||||
|
|
||||||
.ve-ui-mwSaveDialog-checkboxes input {
|
|
||||||
vertical-align: middle;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.ve-ui-mwSaveDialog-editSummary-count {
|
.ve-ui-mwSaveDialog-editSummary-count {
|
||||||
|
|
Loading…
Reference in a new issue