mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/VisualEditor
synced 2025-01-20 00:45:49 +00:00
9ffbfc77cd
Bug: T250843 Change-Id: I53ef4fa4a65b017eec90cc1f2cbb7e7f0681e317
134 lines
3.8 KiB
JavaScript
134 lines
3.8 KiB
JavaScript
/*!
|
|
* VisualEditor UserInterface MediaWiki EducationPopup class.
|
|
*
|
|
* @copyright See AUTHORS.txt
|
|
* @license The MIT License (MIT); see LICENSE.txt
|
|
*/
|
|
|
|
/**
|
|
* UserInterface education popup.
|
|
*
|
|
* Shows a pulsating blue dot which, when you click,
|
|
* reveals a popup with useful information.
|
|
*
|
|
* @class
|
|
*
|
|
* @constructor
|
|
* @extends OO.ui.Widget
|
|
* @param {jQuery} $target Element to attach to
|
|
* @param {Object} config Configuration options
|
|
* @param {string} config.popupTitle
|
|
* @param {string|jQuery} config.popupText
|
|
* @param {string} [config.popupImage] Popup image class
|
|
* @param {string} [config.trackingName]
|
|
*/
|
|
ve.ui.MWEducationPopupWidget = function VeUiMwEducationPopup( $target, config ) {
|
|
config = config || {};
|
|
|
|
// HACK: Do not display on platforms other than desktop
|
|
if ( !( ve.init.mw.DesktopArticleTarget && ve.init.target instanceof ve.init.mw.DesktopArticleTarget ) ) {
|
|
return;
|
|
}
|
|
|
|
// Do not display if the user already acknowledged the popups
|
|
if ( !mw.libs.ve.shouldShowEducationPopups() ) {
|
|
return;
|
|
}
|
|
|
|
// Parent method
|
|
ve.ui.MWEducationPopupWidget.super.call( this, config );
|
|
|
|
// Properties
|
|
this.$target = $target;
|
|
this.popupCloseButton = new OO.ui.ButtonWidget( {
|
|
label: ve.msg( 'visualeditor-educationpopup-dismiss' ),
|
|
flags: [ 'progressive', 'primary' ],
|
|
classes: [ 've-ui-educationPopup-dismiss' ]
|
|
} );
|
|
this.trackingName = config.trackingName;
|
|
this.$pulsatingDot = $( '<div>' ).addClass( 'mw-pulsating-dot' );
|
|
|
|
const $popupContent = $( '<div>' ).append(
|
|
$( '<h3>' ).text( config.popupTitle ),
|
|
// eslint-disable-next-line no-jquery/no-append-html
|
|
$( '<p>' ).append(
|
|
config.popupText instanceof $ ?
|
|
config.popupText :
|
|
document.createTextNode( config.popupText )
|
|
),
|
|
this.popupCloseButton.$element
|
|
);
|
|
ve.targetLinksToNewWindow( $popupContent[ 0 ] );
|
|
if ( config.popupImage ) {
|
|
$popupContent.prepend(
|
|
// The following classes can be generated here:
|
|
// * ve-ui-educationPopup-image-link
|
|
// * others generated by extensions
|
|
$( '<div>' ).addClass( 've-ui-educationPopup-image ve-ui-educationPopup-image-' + config.popupImage )
|
|
);
|
|
}
|
|
|
|
this.popup = new OO.ui.PopupWidget( {
|
|
$floatableContainer: this.$target,
|
|
$content: $popupContent,
|
|
padded: true,
|
|
width: 300
|
|
} );
|
|
|
|
this.onTargetMouseDownHandler = this.onTargetMouseDown.bind( this );
|
|
|
|
// Events
|
|
this.$target.on( 'mousedown', this.onTargetMouseDownHandler );
|
|
this.popupCloseButton.connect( this, { click: 'onPopupCloseButtonClick' } );
|
|
|
|
// DOME
|
|
this.$element.addClass( 've-ui-educationPopup' ).append( this.$pulsatingDot, this.popup.$element );
|
|
};
|
|
|
|
/* Inheritance */
|
|
|
|
OO.inheritClass( ve.ui.MWEducationPopupWidget, OO.ui.Widget );
|
|
|
|
/* Methods */
|
|
|
|
/**
|
|
* Handle mouse down events on the handle
|
|
*
|
|
* @param {jQuery.Event} e
|
|
* @return {boolean|undefined}
|
|
*/
|
|
ve.ui.MWEducationPopupWidget.prototype.onTargetMouseDown = function () {
|
|
if ( ve.init.target.openEducationPopup ) {
|
|
ve.init.target.openEducationPopup.popup.toggle( false );
|
|
ve.init.target.openEducationPopup.$pulsatingDot.removeClass( 'oo-ui-element-hidden' );
|
|
}
|
|
ve.init.target.openEducationPopup = this;
|
|
|
|
this.$pulsatingDot.addClass( 'oo-ui-element-hidden' );
|
|
this.popup.toggle( true );
|
|
this.popupCloseButton.focus();
|
|
|
|
if ( this.trackingName ) {
|
|
ve.track( 'activity.' + this.trackingName + 'EducationPopup', { action: 'show' } );
|
|
}
|
|
return false;
|
|
};
|
|
|
|
/**
|
|
* Click handler for the popup close button
|
|
*/
|
|
ve.ui.MWEducationPopupWidget.prototype.onPopupCloseButtonClick = function () {
|
|
this.$target.off( 'mousedown', this.onTargetMouseDownHandler );
|
|
this.popup.toggle( false );
|
|
|
|
ve.init.target.openEducationPopup = null;
|
|
mw.libs.ve.stopShowingEducationPopups();
|
|
|
|
const mouseLeft = { which: OO.ui.MouseButtons.LEFT };
|
|
this.$target
|
|
.trigger( $.Event( 'mousedown', mouseLeft ) )
|
|
.trigger( $.Event( 'mouseup', mouseLeft ) )
|
|
.trigger( $.Event( 'click', mouseLeft ) );
|
|
|
|
};
|