wikimedia/mediawiki-extensions-VisualEditor

View on GitHub
modules/ve-mw/ui/toolgroups/ve.ui.MWHelpListToolGroup.js

Summary

Maintainability
B
6 hrs
Test Coverage
/*!
 * 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 );