diff --git a/app/scodoc/sco_groups_view.py b/app/scodoc/sco_groups_view.py
index a183be426..bfb759021 100644
--- a/app/scodoc/sco_groups_view.py
+++ b/app/scodoc/sco_groups_view.py
@@ -476,6 +476,7 @@ def groups_table(
"bourse_str": "Boursier",
"etape": "Etape",
"semestre_groupe": "Semestre-Groupe", # pour Moodle
+ "annee": "annee_admission",
}
# ajoute colonnes pour groupes
@@ -770,6 +771,7 @@ def groups_table(
"villelycee",
"codepostallycee",
"codelycee",
+ "annee",
"type_admission",
"boursier_prec",
"boursier",
@@ -793,10 +795,9 @@ def groups_table(
)
m["parcours"] = Se.get_cursus_descr()
m["code_cursus"], _ = sco_report.get_code_cursus_etud(etud)
-
- L = [[m.get(k, "") for k in keys] for m in groups_infos.members]
+ rows = [[m.get(k, "") for k in keys] for m in groups_infos.members]
title = "etudiants_%s" % groups_infos.groups_filename
- xls = sco_excel.excel_simple_table(titles=titles, lines=L, sheet_name=title)
+ xls = sco_excel.excel_simple_table(titles=titles, lines=rows, sheet_name=title)
filename = title
return scu.send_file(xls, filename, scu.XLSX_SUFFIX, scu.XLSX_MIMETYPE)
else:
diff --git a/app/scodoc/sco_report.py b/app/scodoc/sco_report.py
index 7e2e7cfde..3d8bb3c70 100644
--- a/app/scodoc/sco_report.py
+++ b/app/scodoc/sco_report.py
@@ -84,6 +84,7 @@ def formsemestre_etuds_stats(sem: dict, only_primo=False):
etudid = t[-1]
etudiant: Identite = Identite.query.get(etudid)
etud = sco_etud.get_etud_info(etudid=etudid, filled=True)[0]
+ etud["annee_admission"] = etud["annee"] # plus explicite
decision = nt.get_etud_decision_sem(etudid)
if decision:
etud["codedecision"] = decision["code"]
@@ -346,6 +347,7 @@ def formsemestre_report_counts(
"qualite",
"villelycee",
"statut",
+ "annee_admission",
"type_admission",
"boursier_prec",
]
@@ -419,6 +421,7 @@ def table_suivi_cohorte(
bac="", # selection sur type de bac
bacspecialite="",
annee_bac="",
+ annee_admission="",
civilite=None,
statut="",
only_primo=False,
@@ -457,16 +460,21 @@ def table_suivi_cohorte(
bacs = set()
bacspecialites = set()
annee_bacs = set()
+ annee_admissions = set()
civilites = set()
statuts = set()
for etudid in etudids:
etud = sco_etud.get_etud_info(etudid=etudid, filled=True)[0]
+ etud["annee_admission"] = etud["annee"]
bacspe = etud["bac"] + " / " + etud["specialite"]
# sélection sur bac:
if (
(not bac or (bac == etud["bac"]))
and (not bacspecialite or (bacspecialite == bacspe))
and (not annee_bac or (annee_bac == str(etud["annee_bac"])))
+ and (
+ not annee_admission or (annee_admission == str(etud["annee_admission"]))
+ )
and (not civilite or (civilite == etud["civilite"]))
and (not statut or (statut == etud["statut"]))
and (not only_primo or is_primo_etud(etud, sem))
@@ -481,6 +489,7 @@ def table_suivi_cohorte(
bacs.add(etud["bac"])
bacspecialites.add(bacspe)
annee_bacs.add(str(etud["annee_bac"]))
+ annee_admissions.add(str(etud["annee_admission"]))
civilites.add(etud["civilite"])
if etud["statut"]: # ne montre pas les statuts non renseignés
statuts.add(etud["statut"])
@@ -671,6 +680,8 @@ def table_suivi_cohorte(
dbac += " (spécialité %s)" % bacspecialite
if annee_bac:
dbac += " (année bac %s)" % annee_bac
+ if annee_admission:
+ dbac += " (année admission %s)" % annee_admission
if civilite:
dbac += " civilité: %s" % civilite
if statut:
@@ -707,13 +718,13 @@ def table_suivi_cohorte(
)
expl.append(", ".join(ls) + "")
expl.append("")
- logt("Z: table_suivi_cohorte done")
return (
tab,
"\n".join(expl),
bacs,
bacspecialites,
annee_bacs,
+ annee_admissions,
civilites,
statuts,
)
@@ -726,12 +737,14 @@ def formsemestre_suivi_cohorte(
bac="",
bacspecialite="",
annee_bac="",
+ annee_admission="",
civilite=None,
statut="",
only_primo=False,
):
"""Affiche suivi cohortes par numero de semestre"""
- annee_bac = str(annee_bac)
+ annee_bac = str(annee_bac or "")
+ annee_admission = str(annee_admission or "")
percent = int(percent)
(
tab,
@@ -739,6 +752,7 @@ def formsemestre_suivi_cohorte(
bacs,
bacspecialites,
annee_bacs,
+ annee_admissions,
civilites,
statuts,
) = table_suivi_cohorte(
@@ -747,6 +761,7 @@ def formsemestre_suivi_cohorte(
bac=bac,
bacspecialite=bacspecialite,
annee_bac=annee_bac,
+ annee_admission=annee_admission,
civilite=civilite,
statut=statut,
only_primo=only_primo,
@@ -795,11 +810,13 @@ def formsemestre_suivi_cohorte(
bac=bac,
bacspecialite=bacspecialite,
annee_bac=annee_bac,
+ annee_admission=annee_admission,
civilite=civilite,
statut=statut,
bacs=bacs,
bacspecialites=bacspecialites,
annee_bacs=annee_bacs,
+ annee_admissions=annee_admissions,
civilites=civilites,
statuts=statuts,
percent=percent,
@@ -819,15 +836,19 @@ def _gen_form_selectetuds(
bac=None,
bacspecialite=None,
annee_bac=None,
+ annee_admission=None,
civilite=None,
statut=None,
bacs=None,
bacspecialites=None,
annee_bacs=None,
+ annee_admissions=None,
civilites=None,
statuts=None,
):
"""HTML form pour choix criteres selection etudiants"""
+ annee_bacs = annee_bacs or []
+ annee_admissions = annee_admissions or []
bacs = list(bacs)
bacs.sort(key=scu.heterogeneous_sorting_key)
bacspecialites = list(bacspecialites)
@@ -835,6 +856,8 @@ def _gen_form_selectetuds(
# on peut avoir un mix de chaines vides et d'entiers:
annee_bacs = [int(x) if x else 0 for x in annee_bacs]
annee_bacs.sort()
+ annee_admissions = [int(x) if x else 0 for x in annee_admissions]
+ annee_admissions.sort()
civilites = list(civilites)
civilites.sort()
statuts = list(statuts)
@@ -876,23 +899,13 @@ def _gen_form_selectetuds(
F.append('' % (b, selected, b))
F.append("")
#
- if annee_bac:
- selected = ""
- else:
- selected = 'selected="selected"'
F.append(
- """ Année bac: ")
#
F.append(
""" Genre: