2024-04-30 14:21:54 +00:00
|
|
|
/**
|
|
|
|
* @module module:ext.echo.mobile
|
|
|
|
*/
|
|
|
|
|
2024-06-03 12:22:48 +00:00
|
|
|
const mobile = require( 'mobile.startup' ),
|
2019-10-01 20:15:25 +00:00
|
|
|
Overlay = mobile.Overlay,
|
|
|
|
list = require( './list.js' ),
|
|
|
|
promisedView = mobile.promisedView,
|
2023-11-14 18:21:46 +00:00
|
|
|
View = mobile.View;
|
2019-10-01 20:15:25 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @param {Overlay} overlay
|
|
|
|
* @param {Function} exit
|
|
|
|
*/
|
|
|
|
function onBeforeExitAnimation( overlay, exit ) {
|
2023-04-13 15:00:15 +00:00
|
|
|
if ( getComputedStyle( overlay.$el[ 0 ] ).transitionDuration !== '0s' ) {
|
2019-10-01 20:15:25 +00:00
|
|
|
// Manually detach the overlay from DOM once hide animation completes.
|
|
|
|
overlay.$el[ 0 ].addEventListener( 'transitionend', exit, { once: true } );
|
|
|
|
|
|
|
|
// Kick off animation.
|
|
|
|
overlay.$el[ 0 ].classList.remove( 'visible' );
|
|
|
|
} else {
|
|
|
|
exit();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-08-01 23:22:30 +00:00
|
|
|
/**
|
|
|
|
* @param {number} count a capped (0-99 or 99+) count.
|
|
|
|
*/
|
|
|
|
function onCountChange( count ) {
|
|
|
|
mw.hook( 'ext.echo.badge.countChange' ).fire(
|
|
|
|
'all',
|
|
|
|
count,
|
|
|
|
mw.msg( 'echo-badge-count',
|
|
|
|
mw.language.convertNumber( count )
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2019-10-01 20:15:25 +00:00
|
|
|
/**
|
|
|
|
* Make a notification overlay
|
|
|
|
*
|
|
|
|
* @param {Function} onBeforeExit
|
|
|
|
* @return {Overlay}
|
|
|
|
*/
|
2023-08-01 23:22:30 +00:00
|
|
|
function notificationsOverlay( onBeforeExit ) {
|
2024-06-03 12:22:48 +00:00
|
|
|
let markAllReadButton,
|
2019-10-01 20:15:25 +00:00
|
|
|
oouiPromise = mw.loader.using( 'oojs-ui' ).then( function () {
|
|
|
|
markAllReadButton = new OO.ui.ButtonWidget( {
|
2023-04-21 11:53:26 +00:00
|
|
|
icon: 'checkAll'
|
2019-10-01 20:15:25 +00:00
|
|
|
} );
|
|
|
|
return View.make(
|
|
|
|
{ class: 'notifications-overlay-header-markAllRead' },
|
|
|
|
[ markAllReadButton.$element ]
|
|
|
|
);
|
|
|
|
} ),
|
|
|
|
markAllReadButtonView = promisedView( oouiPromise );
|
|
|
|
// hide the button spinner as it is confusing to see in the top right corner
|
|
|
|
markAllReadButtonView.$el.hide();
|
|
|
|
|
2024-03-05 22:39:09 +00:00
|
|
|
var overlay = Overlay.make(
|
2019-10-01 20:15:25 +00:00
|
|
|
{
|
|
|
|
heading: '<strong>' + mw.message( 'notifications' ).escaped() + '</strong>',
|
2023-11-14 18:21:46 +00:00
|
|
|
footerAnchor: {
|
2019-10-01 20:15:25 +00:00
|
|
|
href: mw.util.getUrl( 'Special:Notifications' ),
|
|
|
|
progressive: true,
|
|
|
|
additionalClassNames: 'footer-link notifications-archive-link',
|
|
|
|
label: mw.msg( 'echo-overlay-link' )
|
2023-11-14 18:21:46 +00:00
|
|
|
},
|
2019-10-01 20:15:25 +00:00
|
|
|
headerActions: [ markAllReadButtonView ],
|
|
|
|
isBorderBox: false,
|
|
|
|
className: 'overlay notifications-overlay navigation-drawer',
|
|
|
|
onBeforeExit: function ( exit ) {
|
|
|
|
onBeforeExit( function () {
|
|
|
|
onBeforeExitAnimation( overlay, exit );
|
|
|
|
} );
|
|
|
|
}
|
|
|
|
},
|
|
|
|
promisedView(
|
|
|
|
oouiPromise.then( function () {
|
2023-08-01 23:22:30 +00:00
|
|
|
return list( mw.echo, markAllReadButton, onCountChange );
|
2019-10-01 20:15:25 +00:00
|
|
|
} )
|
|
|
|
)
|
|
|
|
);
|
|
|
|
return overlay;
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = notificationsOverlay;
|