'use strict';

const events = require('../events.js');
const api = require('../api.js');
const views = require('../util/views.js');

const template = views.getTemplate('password-reset');

class PasswordResetView extends events.EventTarget {
    constructor() {
        super();
        this._hostNode = document.getElementById('content-holder');

        views.replaceContent(this._hostNode, template({
            canSendMails: api.canSendMails(),
            contactEmail: api.getContactEmail(),
        }));
        views.syncScrollPosition();

        views.decorateValidator(this._formNode);
        this._formNode.addEventListener('submit', e => {
            e.preventDefault();
            this.dispatchEvent(new CustomEvent('submit', {
                detail: {
                    userNameOrEmail: this._userNameOrEmailFieldNode.value,
                },
            }));
        });
    }

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

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

    clearMessages() {
        views.clearMessages(this._hostNode);
    }

    enableForm() {
        views.enableForm(this._formNode);
    }

    disableForm() {
        views.disableForm(this._formNode);
    }

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

    get _userNameOrEmailFieldNode() {
        return this._formNode.querySelector('[name=user-name]');
    }
}

module.exports = PasswordResetView;