'use strict';

const router = require('../router.js');
const api = require('../api.js');
const topNavigation = require('../models/top_navigation.js');
const LoginView = require('../views/login_view.js');

class LoginController {
    constructor() {
        api.forget();
        topNavigation.activate('login');
        topNavigation.setTitle('Login');

        this._loginView = new LoginView();
        this._loginView.addEventListener('submit', e => this._evtLogin(e));
    }

    _evtLogin(e) {
        this._loginView.clearMessages();
        this._loginView.disableForm();
        api.forget();
        api.login(e.detail.name, e.detail.password, e.detail.remember)
            .then(() => {
                const ctx = router.show('/');
                ctx.controller.showSuccess('Logged in');
            }, errorMessage => {
                this._loginView.showError(errorMessage);
                this._loginView.enableForm();
            });
    }
}

class LogoutController {
    constructor() {
        api.forget();
        api.logout();
        const ctx = router.show('/');
        ctx.controller.showSuccess('Logged out');
    }
}

module.exports = router => {
    router.enter('/login', (ctx, next) => {
        ctx.controller = new LoginController();
    });
    router.enter('/logout', (ctx, next) => {
        ctx.controller = new LogoutController();
    });
};