mediawiki-extensions-Discus.../modules/mobile.js
Bartosz Dziewoński 8eadff3b0d Optimize selectors in mobile hacks
See T328452#8587912

Bug: T328452
Change-Id: I584ef836d84cfa52ed003aae217c5c3b4e4ddbdd
2023-02-07 02:56:05 +01:00

172 lines
6.7 KiB
JavaScript

var newTopicButton, $readAsWikiPage, ledeSectionDialog;
var viewportScrollContainer = null;
var wasKeyboardOpen = null;
var initialClientHeight = null;
// Copied from ve.init.Platform.static.isIos
var isIos = /ipad|iphone|ipod/i.test( navigator.userAgent );
$( document.body ).toggleClass( 'ext-discussiontools-init-ios', isIos );
function onViewportChange() {
var isKeyboardOpen;
if ( isIos ) {
isKeyboardOpen = visualViewport.height < viewportScrollContainer.clientHeight;
} else {
// TODO: Support orientation changes?
isKeyboardOpen = viewportScrollContainer.clientHeight < initialClientHeight;
}
if ( isKeyboardOpen !== wasKeyboardOpen ) {
$( document.body ).toggleClass( 'ext-discussiontools-init-virtual-keyboard-open', isKeyboardOpen );
}
wasKeyboardOpen = isKeyboardOpen;
}
function init( $container ) {
// For compatibility with Minerva click tracking (T295490)
$container.find( '.section-heading' ).attr( 'data-event-name', 'talkpage.section' );
// Keyboard body classes
if ( !viewportScrollContainer && window.visualViewport ) {
viewportScrollContainer = OO.ui.Element.static.getClosestScrollableContainer( document.body );
initialClientHeight = viewportScrollContainer.clientHeight;
var onViewportChangeThrottled = OO.ui.throttle( onViewportChange, 100 );
$( visualViewport ).on( 'resize', onViewportChangeThrottled );
}
// Mobile overflow menu
mw.loader.using( [ 'oojs-ui-widgets', 'oojs-ui.styles.icons-editing-core' ] ).then( function () {
$container.find( '.ext-discussiontools-init-section-ellipsisButton' ).each( function () {
var buttonMenu = OO.ui.infuse( this, { menu: {
horizontalPosition: 'end',
items: [
new OO.ui.MenuOptionWidget( {
data: 'edit',
icon: 'edit',
label: mw.msg( 'skin-view-edit' )
} )
]
} } );
buttonMenu.getMenu().on( 'choose', function ( menuOption ) {
switch ( menuOption.getData() ) {
case 'edit':
// Click the hidden section-edit link
buttonMenu.$element.closest( '.ext-discussiontools-init-section' ).find( '.mw-editsection > a' ).trigger( 'click' );
break;
}
} );
} );
$container.find( '.ext-discussiontools-init-section-bar' ).on( 'click', function ( e ) {
// Don't toggle section when clicking on bar
e.stopPropagation();
} );
} );
var $ledeContent = $container.find( '.mf-section-0' ).children( ':not( .ext-discussiontools-emptystate )' )
// On non-existent pages MobileFrontend wrapping isn't there
.add( $container.find( '.mw-talkpageheader' ) );
var $ledeButton = $container.find( '.ext-discussiontools-init-lede-button' );
if ( $ledeButton.length ) {
var windowManager = OO.ui.getWindowManager();
if ( !ledeSectionDialog ) {
var LedeSectionDialog = require( './LedeSectionDialog.js' );
ledeSectionDialog = new LedeSectionDialog();
windowManager.addWindows( [ ledeSectionDialog ] );
}
// Lede section popup
OO.ui.infuse( $ledeButton ).on( 'click', function () {
mw.loader.using( 'oojs-ui-windows' ).then( function () {
windowManager.openWindow( 'ledeSection', { $content: $ledeContent } );
mw.track( 'webuiactions_log.click', 'lede-button' );
} );
} );
}
if (
!newTopicButton &&
// eslint-disable-next-line no-jquery/no-global-selector
$( '.ext-discussiontools-init-new-topic-button' ).length
) {
// eslint-disable-next-line no-jquery/no-global-selector
newTopicButton = OO.ui.infuse( $( '.ext-discussiontools-init-new-topic-button' ) );
// For compatibility with Minerva click tracking (T295490)
newTopicButton.$element.attr( 'data-event-name', 'talkpage.add-topic' );
// eslint-disable-next-line no-jquery/no-global-selector
var $newTopicWrapper = $( '.ext-discussiontools-init-new-topic' );
var $scrollContainer = $( OO.ui.Element.static.getClosestScrollableContainer( document.body ) );
var $scrollListener = $scrollContainer.is( 'html, body' ) ? $( OO.ui.Element.static.getWindow( $scrollContainer[ 0 ] ) ) : $scrollContainer;
var lastScrollTop = $scrollContainer.scrollTop();
var wasScrollDown = null;
var $body = $( document.body );
// TODO: Use ve.addPassiveEventListener
$scrollListener.on( 'scroll', OO.ui.throttle( function () {
// Round negative values up to 0 to ignore iOS scroll bouncing (T323400)
var scrollTop = Math.max( $scrollContainer.scrollTop(), 0 );
var isScrollDown = scrollTop > lastScrollTop;
if ( isScrollDown !== wasScrollDown ) {
if ( !isScrollDown ) {
$newTopicWrapper.css( 'transition', 'none' );
}
$body.removeClass( [ 'ext-discussiontools-init-new-topic-closed', 'ext-discussiontools-init-new-topic-opened' ] );
requestAnimationFrame( function () {
$newTopicWrapper.css( 'transition', '' );
$body.addClass( isScrollDown ? 'ext-discussiontools-init-new-topic-close' : 'ext-discussiontools-init-new-topic-open' );
setTimeout( function () {
$body.removeClass( [ 'ext-discussiontools-init-new-topic-close', 'ext-discussiontools-init-new-topic-open' ] );
$body.addClass( isScrollDown ? 'ext-discussiontools-init-new-topic-closed' : 'ext-discussiontools-init-new-topic-opened' );
}, 250 );
} );
}
var observer = new IntersectionObserver(
function ( entries ) {
$newTopicWrapper.toggleClass( 'ext-discussiontools-init-new-topic-pinned', entries[ 0 ].intersectionRatio === 1 );
},
{ threshold: [ 1 ] }
);
observer.observe( $newTopicWrapper[ 0 ] );
lastScrollTop = scrollTop;
wasScrollDown = isScrollDown;
}, 200 ) );
}
if ( !$readAsWikiPage ) {
// Read as wiki page button, copied from renderReadAsWikiPageButton in Minerva
$readAsWikiPage = $( '<button>' )
.addClass( 'ext-discussiontools-init-readAsWikiPage' )
.attr( 'data-event-name', 'talkpage.readAsWiki' )
.text( mw.message( 'minerva-talk-full-page' ).text() )
.on( 'click', function () {
$( document.body ).removeClass( 'ext-discussiontools-visualenhancements-enabled ext-discussiontools-replytool-enabled' );
} );
}
/* eslint-disable no-jquery/no-global-selector */
if ( newTopicButton ) {
$( '.ext-discussiontools-init-new-topic' ).after( $readAsWikiPage );
} else {
$( '#mw-content-text' ).append( $readAsWikiPage );
}
// Tweak to prevent our footer buttons from overlapping Minerva skin elements (T328452).
// TODO: It would be more elegant to do this in just CSS somehow.
// BEWARE: I have wasted 4 hours here trying to make that happen. The elements are not nested in a
// helpful way, and moving them around tends to break the stickiness of the "Add topic" button.
if (
$( '.catlinks' ).filter( '[data-mw="interface"]' ).length ||
$( '#page-secondary-actions' ).children().length ||
$( '.return-link' ).length
) {
$readAsWikiPage.addClass( 'ext-discussiontools-init-button-notFlush' );
}
/* eslint-enable no-jquery/no-global-selector */
}
module.exports = {
init: init
};