############################################### Evaluations ###########################################################
from flask import jsonify

import app

from app import models
from app.api import bp
from app.api.auth import token_permission_required
from app.api.errors import error_response
from app.scodoc.sco_evaluation_db import do_evaluation_get_all_notes
from app.scodoc.sco_permissions import Permission


@bp.route("/evaluations/<int:moduleimpl_id>", methods=["GET"])
@token_permission_required(Permission.APIView)
def evaluations(moduleimpl_id: int):
    """
    Retourne la liste des évaluations à partir de l'id d'un moduleimpl

    moduleimpl_id : l'id d'un moduleimpl

    Exemple de résultat :
        [
          {
            "moduleimpl_id": 1,
            "jour": "20/04/2022",
            "heure_debut": "08h00",
            "description": "eval1",
            "coefficient": 1.0,
            "publish_incomplete": false,
            "numero": 0,
            "id": 1,
            "heure_fin": "09h00",
            "note_max": 20.0,
            "visibulletin": true,
            "evaluation_type": 0,
            "evaluation_id": 1,
            "jouriso": "2022-04-20",
            "duree": "1h",
            "descrheure": " de 08h00 \u00e0 09h00",
            "matin": 1,
            "apresmidi": 0
          },
          ...
        ]
    """
    # Récupération de toutes les évaluations
    evals = models.Evaluation.query.filter_by(id=moduleimpl_id)

    # Mise en forme des données
    data = [d.to_dict() for d in evals]

    return jsonify(data)


@bp.route("/evaluations/eval_notes/<int:evaluation_id>", methods=["GET"])
@token_permission_required(Permission.APIView)
def evaluation_notes(evaluation_id: int):
    """
    Retourne la liste des notes à partir de l'id d'une évaluation donnée

    evaluation_id : l'id d'une évaluation

    Exemple de résultat :
        {
          "1": {
            "id": 1,
            "etudid": 10,
            "evaluation_id": 1,
            "value": 15.0,
            "comment": "",
            "date": "Wed, 20 Apr 2022 06:49:05 GMT",
            "uid": 2
          },
          "2": {
            "id": 2,
            "etudid": 1,
            "evaluation_id": 1,
            "value": 12.0,
            "comment": "",
            "date": "Wed, 20 Apr 2022 06:49:06 GMT",
            "uid": 2
          },
          ...
        }
    """
    # Fonction utilisée : app.scodoc.sco_evaluation_db.do_evaluation_get_all_notes()

    eval = models.Evaluation.query.filter_by(id=evaluation_id).first_or_404()

    moduleimpl = models.ModuleImpl.query.filter_by(id=eval.moduleimpl_id).first_or_404()

    formsemestre = models.FormSemestre.query.filter_by(
        id=moduleimpl.formsemestre_id
    ).first_or_404()

    dept = models.Departement.query.filter_by(id=formsemestre.dept_id).first_or_404()

    app.set_sco_dept(dept.acronym)

    try:
        # Utilisation de la fonction do_evaluation_get_all_notes
        data = do_evaluation_get_all_notes(evaluation_id)
    except AttributeError:
        return error_response(
            409,
            message="La requête ne peut être traitée en l’état actuel. \n"
            "Veillez vérifier la conformité du 'evaluation_id'",
        )

    return jsonify(data)