2018-11-12 13:56:38 +00:00
|
|
|
( function () {
|
2016-11-18 21:16:43 +00:00
|
|
|
/* global moment:false */
|
2015-08-13 00:54:16 +00:00
|
|
|
/**
|
2016-04-10 13:31:02 +00:00
|
|
|
* Notification item data structure.
|
2015-08-13 00:54:16 +00:00
|
|
|
*
|
|
|
|
* @class
|
2024-04-30 14:21:54 +00:00
|
|
|
* @mixes OO.EventEmitter
|
|
|
|
* @mixes OO.SortedEmitterList
|
2015-08-13 00:54:16 +00:00
|
|
|
*
|
|
|
|
* @constructor
|
|
|
|
* @param {number} id Notification id,
|
|
|
|
* @param {Object} [config] Configuration object
|
2024-05-27 01:43:21 +00:00
|
|
|
* @param {string} [config.iconUrl] A URL for the given icon.
|
|
|
|
* @param {string} [config.iconType] A string noting the icon type.
|
|
|
|
* @param {Object} [config.content] The message object defining the text for the header and,
|
2015-10-16 23:18:25 +00:00
|
|
|
* optionally, the body of the notification.
|
2024-05-27 01:43:21 +00:00
|
|
|
* @param {string} [config.content.header=''] The header text of the notification
|
|
|
|
* @param {string} [config.content.body=''] The body text of the notification
|
|
|
|
* @param {string} [config.category] The category of this notification. The category identifies
|
2015-08-13 00:54:16 +00:00
|
|
|
* where the notification originates from.
|
2024-05-27 01:43:21 +00:00
|
|
|
* @param {string} [config.type='message'] The notification type 'message' or 'alert'
|
|
|
|
* @param {boolean} [config.read=false] State the read state of the option
|
|
|
|
* @param {boolean} [config.seen=false] State the seen state of the option
|
|
|
|
* @param {string} [config.timestamp] Notification timestamp in ISO 8601 format
|
|
|
|
* @param {string} [config.primaryUrl] Notification primary link in raw url format
|
|
|
|
* @param {boolean} [config.foreign=false] This notification is from a foreign source
|
|
|
|
* @param {boolean} [config.bundled=false] This notification is part of a bundle
|
|
|
|
* @param {number[]} [config.bundledIds] IDs of notifications bundled with this one
|
|
|
|
* @param {string} [config.modelName='local'] The name of the model this item belongs to
|
|
|
|
* @param {string} [config.source] The source this notification is coming from, if it is foreign
|
|
|
|
* @param {Object[]} [config.secondaryUrls] An array of objects defining the secondary URLs
|
2015-10-16 23:18:25 +00:00
|
|
|
* for this notification. The secondary URLs are expected to have this structure:
|
2024-05-27 01:43:21 +00:00
|
|
|
* ```
|
2018-11-27 22:48:32 +00:00
|
|
|
* {
|
|
|
|
* "iconType": "userAvatar", // A symbolic name for the icon.
|
|
|
|
* // Will render as oo-ui-icon-* class.
|
|
|
|
* "label": "", // The label for the link
|
|
|
|
* "prioritized": true/false, // Prioritized links are outside of the popup
|
|
|
|
* // menu, whenever possible.
|
|
|
|
* "url": "..." // The url for the secondary link
|
|
|
|
* }
|
2024-05-27 01:43:21 +00:00
|
|
|
* ```
|
2015-08-13 00:54:16 +00:00
|
|
|
*/
|
2016-04-10 13:31:02 +00:00
|
|
|
mw.echo.dm.NotificationItem = function MwEchoDmNotificationItem( id, config ) {
|
|
|
|
config = config || {};
|
|
|
|
|
2015-08-13 00:54:16 +00:00
|
|
|
// Mixin constructor
|
|
|
|
OO.EventEmitter.call( this );
|
|
|
|
|
2016-04-10 13:31:02 +00:00
|
|
|
// Properties
|
|
|
|
this.id = id;
|
2016-06-08 23:53:20 +00:00
|
|
|
this.modelName = config.modelName || 'local';
|
2024-06-13 14:34:07 +00:00
|
|
|
this.content = Object.assign( { header: '', body: '' }, config.content );
|
2015-08-13 00:54:16 +00:00
|
|
|
this.category = config.category || '';
|
2016-04-10 13:31:02 +00:00
|
|
|
this.type = config.type || 'message';
|
2015-11-25 04:07:54 +00:00
|
|
|
this.foreign = !!config.foreign;
|
2016-05-19 20:55:21 +00:00
|
|
|
this.bundled = !!config.bundled;
|
2015-12-23 18:33:59 +00:00
|
|
|
this.source = config.source || '';
|
2015-10-16 23:18:25 +00:00
|
|
|
this.iconType = config.iconType;
|
2024-08-16 22:09:41 +00:00
|
|
|
this.iconUrl = config.iconUrl;
|
2015-08-13 00:54:16 +00:00
|
|
|
|
2015-10-16 23:18:25 +00:00
|
|
|
this.read = !!config.read;
|
|
|
|
this.seen = !!config.seen;
|
2015-08-13 00:54:16 +00:00
|
|
|
|
2024-03-05 22:39:09 +00:00
|
|
|
this.timestamp = config.timestamp || moment.utc().format( 'YYYY-MM-DD[T]HH:mm:ss[Z]' );
|
2015-08-13 00:54:16 +00:00
|
|
|
this.setPrimaryUrl( config.primaryUrl );
|
2015-10-16 23:18:25 +00:00
|
|
|
this.setSecondaryUrls( config.secondaryUrls );
|
2016-06-02 14:00:48 +00:00
|
|
|
this.bundledIds = config.bundledIds;
|
2015-08-13 00:54:16 +00:00
|
|
|
};
|
|
|
|
|
2016-04-10 13:31:02 +00:00
|
|
|
/* Initialization */
|
2015-08-13 00:54:16 +00:00
|
|
|
|
2016-04-10 13:31:02 +00:00
|
|
|
OO.initClass( mw.echo.dm.NotificationItem );
|
2015-08-13 00:54:16 +00:00
|
|
|
OO.mixinClass( mw.echo.dm.NotificationItem, OO.EventEmitter );
|
|
|
|
|
|
|
|
/* Events */
|
|
|
|
|
|
|
|
/**
|
2016-04-10 13:31:02 +00:00
|
|
|
* Item details have changed or were updated
|
2024-04-30 14:21:54 +00:00
|
|
|
*
|
|
|
|
* @event mw.echo.dm.NotificationItem#update
|
2015-08-13 00:54:16 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
/* Methods */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get NotificationItem id
|
2016-03-07 13:29:15 +00:00
|
|
|
*
|
2015-08-13 00:54:16 +00:00
|
|
|
* @return {string} NotificationItem Id
|
|
|
|
*/
|
|
|
|
mw.echo.dm.NotificationItem.prototype.getId = function () {
|
|
|
|
return this.id;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
2015-10-16 23:18:25 +00:00
|
|
|
* Get NotificationItem content header
|
2016-03-07 13:29:15 +00:00
|
|
|
*
|
2015-10-16 23:18:25 +00:00
|
|
|
* @return {string} NotificationItem content
|
2015-08-13 00:54:16 +00:00
|
|
|
*/
|
2015-10-16 23:18:25 +00:00
|
|
|
mw.echo.dm.NotificationItem.prototype.getContentHeader = function () {
|
|
|
|
return this.content.header;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get NotificationItem content body
|
2016-03-07 13:29:15 +00:00
|
|
|
*
|
2015-10-16 23:18:25 +00:00
|
|
|
* @return {string} NotificationItem content body
|
|
|
|
*/
|
|
|
|
mw.echo.dm.NotificationItem.prototype.getContentBody = function () {
|
|
|
|
return this.content.body;
|
2015-08-13 00:54:16 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get NotificationItem category
|
2016-03-07 13:29:15 +00:00
|
|
|
*
|
2015-08-13 00:54:16 +00:00
|
|
|
* @return {string} NotificationItem category
|
|
|
|
*/
|
|
|
|
mw.echo.dm.NotificationItem.prototype.getCategory = function () {
|
|
|
|
return this.category;
|
|
|
|
};
|
2016-04-10 13:31:02 +00:00
|
|
|
|
2015-09-29 00:07:37 +00:00
|
|
|
/**
|
|
|
|
* Get NotificationItem type
|
2016-03-07 13:29:15 +00:00
|
|
|
*
|
2015-09-29 00:07:37 +00:00
|
|
|
* @return {string} NotificationItem type
|
|
|
|
*/
|
|
|
|
mw.echo.dm.NotificationItem.prototype.getType = function () {
|
|
|
|
return this.type;
|
|
|
|
};
|
2015-08-13 00:54:16 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Check whether this notification item is read
|
2016-03-07 13:29:15 +00:00
|
|
|
*
|
2015-08-13 00:54:16 +00:00
|
|
|
* @return {boolean} Notification item is read
|
|
|
|
*/
|
|
|
|
mw.echo.dm.NotificationItem.prototype.isRead = function () {
|
|
|
|
return this.read;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Check whether this notification item is seen
|
2016-03-07 13:29:15 +00:00
|
|
|
*
|
2015-08-13 00:54:16 +00:00
|
|
|
* @return {boolean} Notification item is seen
|
|
|
|
*/
|
|
|
|
mw.echo.dm.NotificationItem.prototype.isSeen = function () {
|
|
|
|
return this.seen;
|
|
|
|
};
|
|
|
|
|
2015-10-16 23:18:25 +00:00
|
|
|
/**
|
2015-11-25 04:07:54 +00:00
|
|
|
* Check whether this notification item is foreign
|
2016-03-07 13:29:15 +00:00
|
|
|
*
|
2015-11-25 04:07:54 +00:00
|
|
|
* @return {boolean} Notification item is foreign
|
2015-10-16 23:18:25 +00:00
|
|
|
*/
|
2015-11-25 04:07:54 +00:00
|
|
|
mw.echo.dm.NotificationItem.prototype.isForeign = function () {
|
|
|
|
return this.foreign;
|
2015-10-16 23:18:25 +00:00
|
|
|
};
|
|
|
|
|
2016-05-19 20:55:21 +00:00
|
|
|
/**
|
|
|
|
* Check whether this notification item is part of a bundle
|
|
|
|
*
|
|
|
|
* @return {boolean} Notification item is part of a bundle
|
|
|
|
*/
|
|
|
|
mw.echo.dm.NotificationItem.prototype.isBundled = function () {
|
|
|
|
return this.bundled;
|
|
|
|
};
|
|
|
|
|
2016-04-10 13:31:02 +00:00
|
|
|
/**
|
|
|
|
* Set this notification item as foreign
|
|
|
|
*
|
|
|
|
* @param {boolean} isForeign Notification item is foreign
|
|
|
|
*/
|
|
|
|
mw.echo.dm.NotificationItem.prototype.setForeign = function ( isForeign ) {
|
|
|
|
this.foreign = isForeign;
|
|
|
|
};
|
|
|
|
|
2015-08-13 00:54:16 +00:00
|
|
|
/**
|
|
|
|
* Toggle the read state of the widget
|
|
|
|
*
|
|
|
|
* @param {boolean} [read] The current read state. If not given, the state will
|
|
|
|
* become the opposite of its current state.
|
2024-04-30 14:21:54 +00:00
|
|
|
* @fires mw.echo.dm.NotificationItem#update
|
|
|
|
* @fires OO.EventEmitter#sortChange
|
2015-08-13 00:54:16 +00:00
|
|
|
*/
|
|
|
|
mw.echo.dm.NotificationItem.prototype.toggleRead = function ( read ) {
|
|
|
|
read = read !== undefined ? read : !this.read;
|
|
|
|
if ( this.read !== read ) {
|
|
|
|
this.read = read;
|
2016-04-10 13:31:02 +00:00
|
|
|
this.emit( 'update' );
|
2015-10-28 20:47:54 +00:00
|
|
|
this.emit( 'sortChange' );
|
2015-08-13 00:54:16 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Toggle the seen state of the widget
|
|
|
|
*
|
|
|
|
* @param {boolean} [seen] The current seen state. If not given, the state will
|
|
|
|
* become the opposite of its current state.
|
2024-04-30 14:21:54 +00:00
|
|
|
* @fires mw.echo.dm.NotificationItem#update
|
2015-08-13 00:54:16 +00:00
|
|
|
*/
|
|
|
|
mw.echo.dm.NotificationItem.prototype.toggleSeen = function ( seen ) {
|
|
|
|
seen = seen !== undefined ? seen : !this.seen;
|
2016-09-13 23:18:29 +00:00
|
|
|
if (
|
|
|
|
this.seen !== seen &&
|
|
|
|
// Do not change the state of a read item, since its
|
|
|
|
// seen state (never 'unseen') never changes
|
|
|
|
!this.isRead()
|
|
|
|
) {
|
2015-08-13 00:54:16 +00:00
|
|
|
this.seen = seen;
|
2016-04-10 13:31:02 +00:00
|
|
|
this.emit( 'update' );
|
2015-08-13 00:54:16 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the notification timestamp
|
|
|
|
*
|
2024-03-12 15:24:58 +00:00
|
|
|
* @return {number} Notification timestamp in MediaWiki timestamp format
|
2015-08-13 00:54:16 +00:00
|
|
|
*/
|
|
|
|
mw.echo.dm.NotificationItem.prototype.getTimestamp = function () {
|
|
|
|
return this.timestamp;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the notification link
|
|
|
|
*
|
|
|
|
* @param {string} link Notification url
|
|
|
|
*/
|
|
|
|
mw.echo.dm.NotificationItem.prototype.setPrimaryUrl = function ( link ) {
|
|
|
|
this.primaryUrl = link;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the notification link
|
|
|
|
*
|
|
|
|
* @return {string} Notification url
|
|
|
|
*/
|
|
|
|
mw.echo.dm.NotificationItem.prototype.getPrimaryUrl = function () {
|
|
|
|
return this.primaryUrl;
|
|
|
|
};
|
|
|
|
|
2015-10-16 23:18:25 +00:00
|
|
|
/**
|
|
|
|
* Get the notification icon URL
|
|
|
|
*
|
|
|
|
* @return {string} Notification icon URL
|
|
|
|
*/
|
2024-08-16 22:09:41 +00:00
|
|
|
mw.echo.dm.NotificationItem.prototype.getIconUrl = function () {
|
|
|
|
return this.iconUrl;
|
2015-10-16 23:18:25 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the notification icon type
|
|
|
|
*
|
|
|
|
* @return {string} Notification icon type
|
|
|
|
*/
|
|
|
|
mw.echo.dm.NotificationItem.prototype.getIconType = function () {
|
|
|
|
return this.iconType;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the notification's secondary links
|
|
|
|
* See constructor documentation for the structure of these links objects.
|
|
|
|
*
|
|
|
|
* @param {Object[]} links Secondary url definitions
|
|
|
|
*/
|
|
|
|
mw.echo.dm.NotificationItem.prototype.setSecondaryUrls = function ( links ) {
|
|
|
|
this.secondaryUrls = links || [];
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the notification's secondary links
|
|
|
|
*
|
|
|
|
* @return {Object[]} Secondary url definitions
|
|
|
|
*/
|
|
|
|
mw.echo.dm.NotificationItem.prototype.getSecondaryUrls = function () {
|
|
|
|
return this.secondaryUrls;
|
|
|
|
};
|
2015-12-23 18:33:59 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the notification's source
|
|
|
|
*
|
|
|
|
* @return {string} Notification source
|
|
|
|
*/
|
|
|
|
mw.echo.dm.NotificationItem.prototype.getSource = function () {
|
|
|
|
return this.source;
|
|
|
|
};
|
2016-06-02 14:00:48 +00:00
|
|
|
|
2016-06-08 23:53:20 +00:00
|
|
|
/**
|
|
|
|
* Get the notification's model name
|
|
|
|
*
|
|
|
|
* @return {string} Notification model name
|
|
|
|
*/
|
|
|
|
mw.echo.dm.NotificationItem.prototype.getModelName = function () {
|
|
|
|
return this.modelName;
|
|
|
|
};
|
|
|
|
|
2016-06-02 14:00:48 +00:00
|
|
|
/**
|
2020-06-12 22:13:31 +00:00
|
|
|
* Get the all ids contained in this notification
|
|
|
|
*
|
|
|
|
* @return {number[]}
|
|
|
|
*/
|
2016-06-02 14:00:48 +00:00
|
|
|
mw.echo.dm.NotificationItem.prototype.getAllIds = function () {
|
|
|
|
return [ this.getId() ].concat( this.bundledIds || [] );
|
|
|
|
};
|
|
|
|
|
2018-11-12 13:56:38 +00:00
|
|
|
}() );
|