mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/VisualEditor
synced 2025-01-10 12:15:08 +00:00
2a3f06676d
Bug: T367267 Change-Id: I472cfa7007b6468c88b5502162fbef2e9874712d
204 lines
6 KiB
JavaScript
204 lines
6 KiB
JavaScript
/*!
|
|
* VisualEditor MediaWiki UserInterface help list toolgroup classes.
|
|
*
|
|
* @copyright See AUTHORS.txt
|
|
* @license The MIT License (MIT); see LICENSE.txt
|
|
*/
|
|
|
|
/**
|
|
* MediaWiki UserInterface edit mode tool.
|
|
*
|
|
* This extends ListToolGroup to add a footer below the tool list.
|
|
* The footer contains the version number.
|
|
*
|
|
* @class
|
|
* @extends OO.ui.ListToolGroup
|
|
*
|
|
* @constructor
|
|
* @param {OO.ui.Toolbar} toolbar
|
|
* @param {Object} [config] Configuration options
|
|
*/
|
|
ve.ui.MWHelpListToolGroup = function VeUiMwHelpListToolGroup() {
|
|
this.$footer = $( '<div>' ).addClass( 've-ui-mwHelpListToolGroup-tools-footer' );
|
|
|
|
// Parent constructor
|
|
ve.ui.MWHelpListToolGroup.super.apply( this, arguments );
|
|
|
|
// Initialization
|
|
this.$element.addClass( 've-ui-mwHelpListToolGroup' );
|
|
this.$group.addClass( 've-ui-mwHelpListToolGroup-tools' );
|
|
};
|
|
|
|
/* Setup */
|
|
|
|
OO.inheritClass( ve.ui.MWHelpListToolGroup, OO.ui.ListToolGroup );
|
|
|
|
/* Static Properties */
|
|
|
|
/**
|
|
* @static
|
|
* @inheritdoc
|
|
*/
|
|
ve.ui.MWHelpListToolGroup.static.name = 'mwHelpList';
|
|
|
|
/* Methods */
|
|
|
|
ve.ui.MWHelpListToolGroup.prototype.insertItemElements = function () {
|
|
// Mixin method
|
|
OO.ui.mixin.GroupElement.prototype.insertItemElements.apply( this, arguments );
|
|
|
|
this.$group.append( this.$footer );
|
|
};
|
|
|
|
ve.ui.MWHelpListToolGroup.prototype.setActive = function () {
|
|
// Parent method
|
|
ve.ui.MWHelpListToolGroup.super.prototype.setActive.apply( this, arguments );
|
|
|
|
if ( this.active && !this.versionPromise ) {
|
|
const $version = $( '<div>' ).addClass( 'oo-ui-pendingElement-pending' ).text( '\u00a0' );
|
|
this.$footer.append( $version );
|
|
this.versionPromise = ve.init.target.getLocalApi().get( {
|
|
action: 'query',
|
|
meta: 'siteinfo',
|
|
siprop: 'extensions'
|
|
} ).then( ( response ) => {
|
|
const extension = response.query.extensions.filter( ( ext ) => ext.name === 'VisualEditor' )[ 0 ];
|
|
|
|
if ( extension && extension[ 'vcs-version' ] ) {
|
|
$version
|
|
.removeClass( 'oo-ui-pendingElement-pending' )
|
|
.empty()
|
|
.append( $( '<a>' )
|
|
.addClass( 've-ui-mwHelpListToolGroup-version-link' )
|
|
.attr( 'target', '_blank' )
|
|
.attr( 'rel', 'noopener' )
|
|
.attr( 'href', extension[ 'vcs-url' ] )
|
|
.append( $( '<span>' )
|
|
.addClass( 've-ui-mwHelpListToolGroup-version-label' )
|
|
.text( ve.msg( 'visualeditor-version-label' ) + ' ' + extension[ 'vcs-version' ].slice( 0, 7 ) )
|
|
)
|
|
)
|
|
.append( ' ' )
|
|
.append( $( '<span>' )
|
|
.addClass( 've-ui-mwHelpListToolGroup-version-date' )
|
|
.text( extension[ 'vcs-date' ] )
|
|
);
|
|
} else {
|
|
$version.remove();
|
|
}
|
|
}, () => {
|
|
$version.remove();
|
|
} );
|
|
}
|
|
};
|
|
|
|
/* Registration */
|
|
|
|
ve.ui.toolGroupFactory.register( ve.ui.MWHelpListToolGroup );
|
|
|
|
/**
|
|
* User guide tool.
|
|
*
|
|
* @class
|
|
* @extends ve.ui.Tool
|
|
* @constructor
|
|
* @param {OO.ui.ToolGroup} toolGroup
|
|
* @param {Object} [config] Configuration options
|
|
*/
|
|
ve.ui.MWUserGuideTool = function VeUiMWUserGuideTool() {
|
|
ve.ui.MWUserGuideTool.super.apply( this, arguments );
|
|
|
|
this.setDisabled( false );
|
|
};
|
|
OO.inheritClass( ve.ui.MWUserGuideTool, ve.ui.Tool );
|
|
ve.ui.MWUserGuideTool.static.name = 'mwUserGuide';
|
|
ve.ui.MWUserGuideTool.static.group = 'help';
|
|
ve.ui.MWUserGuideTool.static.icon = 'help';
|
|
ve.ui.MWUserGuideTool.static.title =
|
|
OO.ui.deferMsg( 'visualeditor-help-label' );
|
|
ve.ui.MWUserGuideTool.static.autoAddToCatchall = false;
|
|
|
|
// Never disabled
|
|
ve.ui.MWUserGuideTool.prototype.onUpdateState = function () {};
|
|
|
|
ve.ui.MWUserGuideTool.prototype.onSelect = function () {
|
|
this.setActive( false );
|
|
const urlOrTitle = ve.msg( 'visualeditor-help-link' );
|
|
if ( urlOrTitle.indexOf( '//' ) !== -1 ) {
|
|
window.open( urlOrTitle );
|
|
} else {
|
|
// This link used to be internal link to mw:, but that doesn't work
|
|
// on 3rd party installations (T367267). Keep support for internal
|
|
// links as many wikis have local overrides which are internal.
|
|
window.open( new mw.Title( urlOrTitle ).getUrl() );
|
|
}
|
|
};
|
|
|
|
ve.ui.toolFactory.register( ve.ui.MWUserGuideTool );
|
|
|
|
/**
|
|
* Feedback dialog tool.
|
|
*
|
|
* @class
|
|
* @extends ve.ui.Tool
|
|
* @constructor
|
|
* @param {OO.ui.ToolGroup} toolGroup
|
|
* @param {Object} [config] Configuration options
|
|
*/
|
|
ve.ui.MWFeedbackDialogTool = function VeUiMWFeedbackDialogTool() {
|
|
ve.ui.MWFeedbackDialogTool.super.apply( this, arguments );
|
|
|
|
this.setDisabled( false );
|
|
};
|
|
OO.inheritClass( ve.ui.MWFeedbackDialogTool, ve.ui.Tool );
|
|
ve.ui.MWFeedbackDialogTool.static.name = 'mwFeedbackDialog';
|
|
ve.ui.MWFeedbackDialogTool.static.group = 'help';
|
|
ve.ui.MWFeedbackDialogTool.static.icon = 'speechBubble';
|
|
ve.ui.MWFeedbackDialogTool.static.title =
|
|
OO.ui.deferMsg( 'visualeditor-feedback-tool' );
|
|
ve.ui.MWFeedbackDialogTool.static.autoAddToCatchall = false;
|
|
|
|
// Never disabled
|
|
ve.ui.MWFeedbackDialogTool.prototype.onUpdateState = function () {};
|
|
|
|
ve.ui.MWFeedbackDialogTool.prototype.onSelect = function () {
|
|
this.setActive( false );
|
|
|
|
if ( !this.feedbackPromise ) {
|
|
this.feedbackPromise = mw.loader.using( 'mediawiki.feedback' ).then( () => {
|
|
const mode = this.toolbar.getSurface().getMode();
|
|
|
|
// This can't be constructed until the editor has loaded as it uses special messages
|
|
const feedbackConfig = {
|
|
bugsLink: 'https://phabricator.wikimedia.org/maniphest/task/edit/form/1/?projects=VisualEditor',
|
|
showUseragentCheckbox: true,
|
|
useragentCheckboxMandatory: true
|
|
};
|
|
|
|
// If so configured, tell mw.feedback that we're posting to a remote wiki and set the title
|
|
const veConfig = mw.config.get( 'wgVisualEditorConfig' );
|
|
if ( veConfig.feedbackApiUrl ) {
|
|
feedbackConfig.apiUrl = veConfig.feedbackApiUrl;
|
|
feedbackConfig.title = new mw.Title(
|
|
mode === 'source' ?
|
|
veConfig.sourceFeedbackTitle : veConfig.feedbackTitle
|
|
);
|
|
} else {
|
|
feedbackConfig.title = new mw.Title(
|
|
mode === 'source' ?
|
|
ve.msg( 'visualeditor-feedback-source-link' ) : ve.msg( 'visualeditor-feedback-link' )
|
|
);
|
|
}
|
|
|
|
return new mw.Feedback( feedbackConfig );
|
|
} );
|
|
}
|
|
this.feedbackPromise.done( ( feedback ) => {
|
|
feedback.launch( {
|
|
message: ve.msg( 'visualeditor-feedback-defaultmessage', location.toString() )
|
|
} );
|
|
} );
|
|
};
|
|
|
|
ve.ui.toolFactory.register( ve.ui.MWFeedbackDialogTool );
|