'use strict';

const events = require('../events.js');
const views = require('../util/views.js');
const CommentListControl = require('../controls/comment_list_control.js');

const template = views.getTemplate('comments-page');

class CommentsPageView extends events.EventTarget {
    constructor(ctx) {
        super();
        this._hostNode = ctx.hostNode;

        const sourceNode = template(ctx);

        for (let post of ctx.response.results) {
            const commentListControl = new CommentListControl(
                sourceNode.querySelector(
                    `.comments-container[data-for="${post.id}"]`),
                post.comments,
                true);
            events.proxyEvent(commentListControl, this, 'submit');
            events.proxyEvent(commentListControl, this, 'score');
            events.proxyEvent(commentListControl, this, 'delete');
        }

        views.replaceContent(this._hostNode, sourceNode);
    }
}

module.exports = CommentsPageView;