const Overlay = require( 'mobile.startup' ).Overlay; /** * @module module:ext.echo.mobile */ /** * Overlay for notifications filter * * @class NotificationsFilterOverlay * @param {Object} options * @param {Function} options.onBeforeExit executes before overlay closes * @param {jQuery} options.$notifReadState - notification read status widgets * @param {jQuery} options.$crossWikiUnreadFilter - notification unread filter */ function notificationsFilterOverlay( options ) { // Don't call overlay.hide(), because that doesn't invoke the onBeforeExit callback (T258954) // Instead, change the hash, so that the OverlayManager hides the overlay for us function hideOverlay() { location.hash = '#'; } // Close overlay when a selection is made options.$crossWikiUnreadFilter.on( 'click', hideOverlay ); options.$notifReadState.find( '.oo-ui-buttonElement' ).on( 'click', hideOverlay ); const $content = $( '
' ).append( $( '
' ) .addClass( 'notifications-filter-overlay-read-state' ) .append( options.$notifReadState ), options.$crossWikiUnreadFilter ); const overlay = Overlay.make( { onBeforeExit: options.onBeforeExit, heading: '' + mw.message( 'echo-mobile-notifications-filter-title' ).escaped() + '', className: 'overlay notifications-filter-overlay notifications-overlay navigation-drawer' }, { $el: $content } ); return overlay; } module.exports = notificationsFilterOverlay;