'use strict';

const router = require('../router.js');
const misc = require('../util/misc.js');
const views = require('../util/views.js');
const PostContentControl = require('../controls/post_content_control.js');
const PostNotesOverlayControl
    = require('../controls/post_notes_overlay_control.js');
const TagAutoCompleteControl =
    require('../controls/tag_auto_complete_control.js');

const template = views.getTemplate('home');
const footerTemplate = views.getTemplate('home-footer');
const featuredPostTemplate = views.getTemplate('home-featured-post');

class HomeView {
    constructor(ctx) {
        this._hostNode = document.getElementById('content-holder');
        this._ctx = ctx;

        const sourceNode = template(ctx);
        views.replaceContent(this._hostNode, sourceNode);
        views.syncScrollPosition();

        if (this._formNode) {
            this._tagAutoCompleteControl = new TagAutoCompleteControl(
                this._searchInputNode);
            this._formNode.addEventListener(
                'submit', e => this._evtFormSubmit(e));
        }

    }

    showSuccess(text) {
        views.showSuccess(this._hostNode, text);
    }

    showError(text) {
        views.showError(this._hostNode, text);
    }

    setStats(stats) {
        views.replaceContent(
            this._footerContainerNode,
            footerTemplate(Object.assign({}, stats, this._ctx)));
    }

    setFeaturedPost(postInfo) {
        views.replaceContent(
            this._postInfoContainerNode, featuredPostTemplate(postInfo));
        if (this._postContainerNode && postInfo.featuredPost) {
            this._postContentControl = new PostContentControl(
                this._postContainerNode,
                postInfo.featuredPost,
                () => {
                    return [
                        window.innerWidth * 0.8,
                        window.innerHeight * 0.7,
                    ];
                });

            this._postNotesOverlay = new PostNotesOverlayControl(
                this._postContainerNode.querySelector('.post-overlay'),
                postInfo.featuredPost);
        }
    }

    get _footerContainerNode() {
        return this._hostNode.querySelector('.footer-container');
    }

    get _postInfoContainerNode() {
        return this._hostNode.querySelector('.post-info-container');
    }

    get _postContainerNode() {
        return this._hostNode.querySelector('.post-container');
    }

    get _formNode() {
        return this._hostNode.querySelector('form');
    }

    get _searchInputNode() {
        return this._formNode.querySelector('input[name=search-text]');
    }

    _evtFormSubmit(e) {
        e.preventDefault();
        this._searchInputNode.blur();
        router.show('/posts/' + misc.formatUrlParameters({
            query: this._searchInputNode.value}));
    }
}

module.exports = HomeView;