from app.auth.forms import LoginForm
from app.models import User
from flask import flash, redirect, render_template, url_for
from flask_login import login_required, login_user
from . import bp


@bp.route('/', methods=['GET', 'POST'])
def index():
    form = LoginForm(prefix='login-form')
    if form.validate_on_submit():
        user = User.query.filter_by(username=form.user.data).first()
        if user is None:
            user = User.query.filter_by(email=form.user.data.lower()).first()
        if user is not None and user.verify_password(form.password.data):
            login_user(user, form.remember_me.data)
            return redirect(url_for('.dashboard'))
        flash('Invalid email/username or password.')
    return render_template('main/index.html.j2', form=form, title='nopaque')


@bp.route('/faq')
def faq():
    return render_template(
        'main/faq.html.j2',
        title='Frequently Asked Questions'
    )


@bp.route('/dashboard')
@login_required
def dashboard():
    return render_template('main/dashboard.html.j2', title='Dashboard')


@bp.route('/user_manual')
def user_manual():
    return render_template('main/user_manual.html.j2', title='User manual')


@bp.route('/news')
def news():
    return render_template('main/news.html.j2', title='News')


@bp.route('/privacy_policy')
def privacy_policy():
    return render_template(
        'main/privacy_policy.html.j2',
        title='Privacy statement (GDPR)'
    )


@bp.route('/terms_of_use')
def terms_of_use():
    return render_template('main/terms_of_use.html.j2', title='Terms of Use')