mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/Echo
synced 2024-12-11 07:26:29 +00:00
cf99479468
The zero results can either be because there are no notifications at all for this user in the local wiki, or because there are no results for the specific filter. Both messages are used for either case. Also, clean up the display of push/pop pending for the inbox widget and hide the label in case the message count is 0 or 1 notifications as it is unhelpful and irrelevant in these cases. Bug: T136586 Bug: T136574 Bug: T129363 Change-Id: I1465f772bb9f5247df645d6612f951e5fd7d38cf
201 lines
6.9 KiB
JavaScript
201 lines
6.9 KiB
JavaScript
( function ( mw ) {
|
|
/**
|
|
* A class defining Echo API instructions and network operations
|
|
*
|
|
* @class
|
|
*
|
|
* @constructor
|
|
* @param {Object} config Configuration options
|
|
* @cfg {number} [limit=25] Number of notifications to fetch
|
|
*/
|
|
mw.echo.api.EchoApi = function MwEchoApiEchoApi( config ) {
|
|
config = config || {};
|
|
|
|
this.network = new mw.echo.api.NetworkHandler( config );
|
|
|
|
this.fetchingPromise = null;
|
|
this.limit = config.limit || 25;
|
|
};
|
|
|
|
OO.initClass( mw.echo.api.EchoApi );
|
|
|
|
/**
|
|
* Register a set of foreign sources.
|
|
*
|
|
* @param {Object} sources Object mapping source names to config objects
|
|
*/
|
|
mw.echo.api.EchoApi.prototype.registerForeignSources = function ( sources ) {
|
|
var s;
|
|
for ( s in sources ) {
|
|
this.network.setApiHandler( s, new mw.echo.api.ForeignAPIHandler( sources[ s ].url ) );
|
|
}
|
|
};
|
|
|
|
/**
|
|
* Register a set of local sources.
|
|
*
|
|
* @param {string[]} sources An array of source names
|
|
*/
|
|
mw.echo.api.EchoApi.prototype.registerLocalSources = function ( sources ) {
|
|
var i,
|
|
localHandler = this.network.getApiHandler( 'local' );
|
|
|
|
for ( i = 0; i < sources.length; i++ ) {
|
|
this.network.setApiHandler( sources[ i ], localHandler );
|
|
}
|
|
};
|
|
|
|
/**
|
|
* Fetch notifications from the server based on type
|
|
*
|
|
* @param {string} type Notification type to fetch: 'alert', 'message', or 'all'
|
|
* @param {string|string[]} [sources] The source from which to fetch the notifications.
|
|
* If not given, the local notifications will be fetched.
|
|
* @param {boolean} [isForced] Force a refresh on the fetch notifications promise
|
|
* @param {string} [continueValue] A value for the continue parameter, defining a page
|
|
* @param {string} [readStatus='all'] Read status of the notifications: 'read', 'unread' or 'all'
|
|
* @return {jQuery.Promise} Promise that is resolved with all notifications for the
|
|
* requested types.
|
|
*/
|
|
mw.echo.api.EchoApi.prototype.fetchNotifications = function ( type, sources, isForced, continueValue, readStatus ) {
|
|
var overrideParams = {};
|
|
sources = Array.isArray( sources ) ?
|
|
sources :
|
|
sources ?
|
|
[ sources ] :
|
|
null;
|
|
|
|
if ( continueValue ) {
|
|
overrideParams.notcontinue = continueValue;
|
|
}
|
|
|
|
if ( readStatus && readStatus !== 'all' ) {
|
|
overrideParams.notfilter = readStatus === 'read' ?
|
|
'read' :
|
|
'!read';
|
|
}
|
|
|
|
return this.network.getApiHandler( 'local' ).fetchNotifications( type, sources, isForced, overrideParams )
|
|
.then( function ( result ) {
|
|
return OO.getProp( result.query, 'notifications' );
|
|
} );
|
|
};
|
|
|
|
/**
|
|
* Fetch notifications from several sources
|
|
*
|
|
* @param {string[]} sourceArray An array of sources to fetch from the group
|
|
* @param {string} type Notification type
|
|
* @return {jQuery.Promise} A promise that resolves with an object that maps wiki
|
|
* names to an array of their items' API data objects.
|
|
*/
|
|
mw.echo.api.EchoApi.prototype.fetchNotificationGroups = function ( sourceArray, type ) {
|
|
return this.network.getApiHandler( 'local' ).fetchNotifications( type, sourceArray )
|
|
.then( function ( result ) {
|
|
var i,
|
|
items = OO.getProp( result, 'query', 'notifications', 'list' ),
|
|
groups = {};
|
|
|
|
// Split the items to groups
|
|
for ( i = 0; i < items.length; i++ ) {
|
|
groups[ items[ i ].wiki ] = groups[ items[ i ].wiki ] || [];
|
|
groups[ items[ i ].wiki ].push( items[ i ] );
|
|
}
|
|
|
|
return groups;
|
|
} );
|
|
};
|
|
|
|
/**
|
|
* Mark items as read in the API.
|
|
*
|
|
* @param {string[]} itemIds An array of item IDs to mark as read
|
|
* @param {string} source The source that these items belong to
|
|
* @param {boolean} [isRead] The read state of the item; true for marking the
|
|
* item as read, false for marking the item as unread
|
|
* @return {jQuery.Promise} A promise that is resolved when the operation
|
|
* is complete, with the number of unread notifications still remaining
|
|
* for that type in the given source
|
|
*/
|
|
mw.echo.api.EchoApi.prototype.markItemsRead = function ( itemIds, source, isRead ) {
|
|
return this.network.getApiHandler( source ).markItemsRead( itemIds, isRead );
|
|
};
|
|
|
|
/**
|
|
* Mark all notifications for a given type as read in the given source.
|
|
*
|
|
* @param {string} source Symbolic name of notifications source
|
|
* @param {string} type Notifications type
|
|
* @return {jQuery.Promise} A promise that is resolved when the operation
|
|
* is complete, with the number of unread notifications still remaining
|
|
* for that type in the given source
|
|
*/
|
|
mw.echo.api.EchoApi.prototype.markAllRead = function ( source, type ) {
|
|
// FIXME: This specific method sends an operation
|
|
// to the API that marks all notifications of the given type as read regardless
|
|
// of whether they were actually seen by the user.
|
|
// We should consider removing the use of this method and, instead,
|
|
// using strictly the 'markItemsRead' by giving the API only the
|
|
// notifications that are available to the user.
|
|
return this.network.getApiHandler( source ).markAllRead( type );
|
|
};
|
|
|
|
/**
|
|
* Fetch the number of unread notifications for the given type in the given
|
|
* source.
|
|
*
|
|
* @param {string} source Notifications source
|
|
* @param {string} type Notification type
|
|
* @return {jQuery.Promise} A promise that is resolved with the number of
|
|
* unread notifications for the given type and source.
|
|
*/
|
|
mw.echo.api.EchoApi.prototype.fetchUnreadCount = function ( source, type ) {
|
|
return this.network.getApiHandler( source ).fetchUnreadCount( type );
|
|
};
|
|
|
|
/**
|
|
* Update the seenTime property for the given type and source.
|
|
*
|
|
* @param {string} source Notification source
|
|
* @param {string} type Notification type
|
|
* @return {jQuery.Promise} A promise that is resolved when the operation is complete.
|
|
*/
|
|
mw.echo.api.EchoApi.prototype.updateSeenTime = function ( source, type ) {
|
|
return this.network.getApiHandler( source ).updateSeenTime( type );
|
|
};
|
|
|
|
/**
|
|
* Check whether the API promise for fetch notification is in an error
|
|
* state for the given source and notification type.
|
|
*
|
|
* @param {string} source Notification source.
|
|
* @param {string} type Notification type
|
|
* @return {boolean} The API response for fetching notification has
|
|
* resolved in an error state, or is rejected.
|
|
*/
|
|
mw.echo.api.EchoApi.prototype.isFetchingErrorState = function ( source, type ) {
|
|
return this.network.getApiHandler( source ).isFetchingErrorState( type, [ source ] );
|
|
};
|
|
|
|
/**
|
|
* Get the fetch notifications promise active for the current source and type.
|
|
*
|
|
* @param {string} source Notification source.
|
|
* @param {string} type Notification type
|
|
* @return {jQuery.Promise} Promise that is resolved when notifications are
|
|
* fetched from the API.
|
|
*/
|
|
mw.echo.api.EchoApi.prototype.getFetchNotificationPromise = function ( source, type ) {
|
|
return this.network.getApiHandler( source ).getFetchNotificationPromise( type );
|
|
};
|
|
|
|
/**
|
|
* Get the set limit for fetching notifications per request
|
|
*
|
|
* @return {number} Limit of notifications per request
|
|
*/
|
|
mw.echo.api.EchoApi.prototype.getLimit = function () {
|
|
return this.limit;
|
|
};
|
|
} )( mediaWiki );
|