59 lines
1.8 KiB
JavaScript
59 lines
1.8 KiB
JavaScript
'use strict';
|
|
|
|
const events = require('../events.js');
|
|
const views = require('../util/views.js');
|
|
const CommentControl = require('../controls/comment_control.js');
|
|
|
|
const template = views.getTemplate('comment-list');
|
|
|
|
class CommentListControl extends events.EventTarget {
|
|
constructor(hostNode, comments, reversed) {
|
|
super();
|
|
this._hostNode = hostNode;
|
|
this._comments = comments;
|
|
this._commentIdToNode = {};
|
|
|
|
comments.addEventListener('add', e => this._evtAdd(e));
|
|
comments.addEventListener('remove', e => this._evtRemove(e));
|
|
|
|
views.replaceContent(this._hostNode, template());
|
|
|
|
const commentList = Array.from(comments);
|
|
if (reversed) {
|
|
commentList.reverse();
|
|
}
|
|
for (let comment of commentList) {
|
|
this._installCommentNode(comment);
|
|
}
|
|
}
|
|
|
|
get _commentListNode() {
|
|
return this._hostNode.querySelector('ul');
|
|
}
|
|
|
|
_installCommentNode(comment) {
|
|
const commentListItemNode = document.createElement('li');
|
|
const commentControl = new CommentControl(
|
|
commentListItemNode, comment, false);
|
|
events.proxyEvent(commentControl, this, 'submit');
|
|
events.proxyEvent(commentControl, this, 'score');
|
|
events.proxyEvent(commentControl, this, 'delete');
|
|
this._commentIdToNode[comment.id] = commentListItemNode;
|
|
this._commentListNode.appendChild(commentListItemNode);
|
|
}
|
|
|
|
_uninstallCommentNode(comment) {
|
|
const commentListItemNode = this._commentIdToNode[comment.id];
|
|
commentListItemNode.parentNode.removeChild(commentListItemNode);
|
|
}
|
|
|
|
_evtAdd(e) {
|
|
this._installCommentNode(e.detail.comment);
|
|
}
|
|
|
|
_evtRemove(e) {
|
|
this._uninstallCommentNode(e.detail.comment);
|
|
}
|
|
};
|
|
|
|
module.exports = CommentListControl;
|