mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/DiscussionTools
synced 2024-11-25 00:38:33 +00:00
d36ffeaa3d
Remove variable shadowing, and fix some documentation. Change-Id: I08a7cbbdc0a1a409f9c4415b36c62c89535e12eb
57 lines
1.5 KiB
JavaScript
57 lines
1.5 KiB
JavaScript
var ThreadItem = require( './ThreadItem.js' );
|
|
|
|
/**
|
|
* @external moment
|
|
* @external HeadingItem
|
|
*/
|
|
|
|
/**
|
|
* A comment item
|
|
*
|
|
* @class CommentItem
|
|
* @extends ThreadItem
|
|
* @constructor
|
|
* @param {number} level
|
|
* @param {Object} range
|
|
* @param {Object[]} [signatureRanges] Objects describing the extent of signatures (plus
|
|
* timestamps) for this comment. There is always at least one signature, but there may be
|
|
* multiple. The author and timestamp of the comment is determined from the first signature.
|
|
* The last node in every signature range is a node containing the timestamp.
|
|
* @param {moment} [timestamp] Timestamp (Moment object)
|
|
* @param {string} [author] Comment author's username
|
|
*/
|
|
function CommentItem( level, range, signatureRanges, timestamp, author ) {
|
|
// Parent constructor
|
|
CommentItem.super.call( this, 'comment', level, range );
|
|
|
|
this.signatureRanges = signatureRanges || [];
|
|
this.timestamp = timestamp || null;
|
|
this.author = author || null;
|
|
|
|
/**
|
|
* @member {string[]} Comment warnings
|
|
*/
|
|
// TODO: Should probably initialise, but our tests assert it is unset
|
|
// this.warnings = [];
|
|
|
|
/**
|
|
* @member {ThreadItem} Parent thread item
|
|
*/
|
|
this.parent = null;
|
|
}
|
|
|
|
OO.inheritClass( CommentItem, ThreadItem );
|
|
|
|
/**
|
|
* @return {HeadingItem} Closest ancestor which is a HeadingItem
|
|
*/
|
|
CommentItem.prototype.getHeading = function () {
|
|
var parent = this;
|
|
while ( parent && parent.type !== 'heading' ) {
|
|
parent = parent.parent;
|
|
}
|
|
return parent;
|
|
};
|
|
|
|
module.exports = CommentItem;
|