mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/Echo
synced 2024-11-12 09:26:05 +00:00
7942a2de79
Notifications were being marked as read in response to a click event in JavaScript, but that causes a jarring effect in the UI, and it's not reliable (the browser could abort the AJAX request). Instead, add ?markasread=XYZ to the end of every primary link URL, where XYZ is the event ID. Bug: T133975 Depends-On: Icb99d5479836fea25a47451b5a758dd71f642f71 Change-Id: I8047d121584b43e6172463a50ad0e0de5f7fa73c
79 lines
2 KiB
PHP
79 lines
2 KiB
PHP
<?php
|
|
|
|
/**
|
|
* A formatter for the notification flyout popup
|
|
*
|
|
* Ideally we wouldn't need this and we'd just pass the
|
|
* presentation model to the client, but we need to continue
|
|
* sending HTML for backwards compatibility.
|
|
*/
|
|
class EchoFlyoutFormatter extends EchoEventFormatter {
|
|
protected function formatModel( EchoEventPresentationModel $model ) {
|
|
$icon = Html::element(
|
|
'img',
|
|
array(
|
|
'class' => 'mw-echo-icon',
|
|
'src' => $this->getIconURL( $model ),
|
|
)
|
|
);
|
|
|
|
$html = Xml::tags(
|
|
'div',
|
|
array( 'class' => 'mw-echo-title' ),
|
|
$model->getHeaderMessage()->parse()
|
|
) . "\n";
|
|
|
|
$body = $model->getBodyMessage();
|
|
if ( $body ) {
|
|
$html .= Xml::tags(
|
|
'div',
|
|
array( 'class' => 'mw-echo-payload' ),
|
|
$body->parse()
|
|
) . "\n";
|
|
}
|
|
|
|
$ts = $this->language->getHumanTimestamp(
|
|
new MWTimestamp( $model->getTimestamp() ),
|
|
null,
|
|
$this->user
|
|
);
|
|
|
|
$footerItems = array( $ts );
|
|
$secondaryLinks = array_filter( $model->getSecondaryLinks() );
|
|
foreach ( $secondaryLinks as $link ) {
|
|
$footerItems[] = Html::element( 'a', array( 'href' => $link['url'] ), $link['label'] );
|
|
}
|
|
$html .= Xml::tags(
|
|
'div',
|
|
array( 'class' => 'mw-echo-notification-footer' ),
|
|
$this->language->pipeList( $footerItems )
|
|
) . "\n";
|
|
|
|
// Add the primary link afterwards, if it has one
|
|
$primaryLink = $model->getPrimaryLinkWithMarkAsRead();
|
|
if ( $primaryLink !== false ) {
|
|
$html .= Html::element(
|
|
'a',
|
|
array( 'class' => 'mw-echo-notification-primary-link', 'href' => $primaryLink['url'] ),
|
|
$primaryLink['label']
|
|
) . "\n";
|
|
}
|
|
|
|
// Wrap everything in mw-echo-content class
|
|
$html = Xml::tags( 'div', array( 'class' => 'mw-echo-content' ), $html );
|
|
|
|
// And then add the icon in front and wrap with mw-echo-state class.
|
|
$html = Xml::tags( 'div', array( 'class' => 'mw-echo-state' ), $icon . $html );
|
|
|
|
return $html;
|
|
}
|
|
|
|
private function getIconURL( EchoEventPresentationModel $model ) {
|
|
return EchoNotificationFormatter::getIconUrl(
|
|
$model->getIconType(),
|
|
$this->language->getDir()
|
|
);
|
|
}
|
|
|
|
}
|