From 48bce333299640dc1e6f684c80130b686dae22b6 Mon Sep 17 00:00:00 2001 From: Emmanuel Viennet Date: Fri, 15 Dec 2023 18:53:38 +0100 Subject: [PATCH] Fix formsemestre_pvjury html (classic) --- app/pe/pe_settag.py | 8 ++++---- app/scodoc/sco_pv_forms.py | 32 +++++++++++++++++++++++++------- 2 files changed, 29 insertions(+), 11 deletions(-) diff --git a/app/pe/pe_settag.py b/app/pe/pe_settag.py index 792175bb3..94e80cd9c 100644 --- a/app/pe/pe_settag.py +++ b/app/pe/pe_settag.py @@ -52,20 +52,21 @@ class SetTag(pe_tagtable.TableTag): # ------------------------------------------------------------------------------------------------------------------- def __init__(self, nom_combinaison, parcours): - pe_tagtable.TableTag.__init__(self, nom=nom_combinaison) self.combinaison = nom_combinaison self.parcours = parcours # Le groupe de semestres/parcours à aggréger # ------------------------------------------------------------------------------------------- - def set_Etudiants(self, etudiants, juryPEDict, etudInfoDict, nom_sem_final=None): + def set_Etudiants( + self, etudiants: list[dict], juryPEDict, etudInfoDict, nom_sem_final=None + ): """Détermine la liste des étudiants à prendre en compte, en partant de la liste en paramètre et en vérifiant qu'ils ont tous un parcours valide.""" if nom_sem_final: self.nom += "_" + nom_sem_final for etudid in etudiants: parcours_incomplet = ( - sum([juryPEDict[etudid][nom_sem] == None for nom_sem in self.parcours]) + sum([juryPEDict[etudid][nom_sem] is None for nom_sem in self.parcours]) > 0 ) # manque-t-il des formsemestre_id validant aka l'étudiant n'a pas été inscrit dans tous les semestres de l'aggrégat if not parcours_incomplet: @@ -209,7 +210,6 @@ class SetTagInterClasse(pe_tagtable.TableTag): # ------------------------------------------------------------------------------------------------------------------- def __init__(self, nom_combinaison, diplome): - pe_tagtable.TableTag.__init__(self, nom=f"{nom_combinaison}_{diplome or ''}") self.combinaison = nom_combinaison self.parcoursDict = {} diff --git a/app/scodoc/sco_pv_forms.py b/app/scodoc/sco_pv_forms.py index 4441b5d6d..97d94c5c1 100644 --- a/app/scodoc/sco_pv_forms.py +++ b/app/scodoc/sco_pv_forms.py @@ -247,9 +247,7 @@ def formsemestre_pvjury(formsemestre_id, fmt="html", publish=True): titles=titles, columns_ids=columns_ids, filename=scu.make_filename("decisions " + sem["titreannee"]), - origin="Généré par %s le " % scu.sco_version.SCONAME - + scu.timedate_human_repr() - + "", + origin=f"Généré par {scu.sco_version.SCONAME} le {scu.timedate_human_repr()}", caption="Décisions jury pour " + sem["titreannee"], html_class="table_leftalign", html_sortable=True, @@ -292,7 +290,8 @@ def formsemestre_pvjury(formsemestre_id, fmt="html", publish=True): # Légende des codes codes = list(counts.keys()) codes.sort() - H.append("

Explication des codes

") + + H.append("""

Explication des codes

""") lines = [] for code in codes: lines.append( @@ -308,12 +307,31 @@ def formsemestre_pvjury(formsemestre_id, fmt="html", publish=True): rows=lines, titles={"code": "Code", "count": "Nombre", "expl": ""}, columns_ids=("code", "count", "expl"), - html_class="table_leftalign", + html_class="table_leftalign codes-jury", + html_class_ignore_default=True, # pas une DataTable html_sortable=True, + html_with_td_classes=True, preferences=sco_preferences.SemPreferences(formsemestre_id), ).html() ) - H.append("

") # force space at bottom + H.append( + """ + """ + ) + H.append("
") # /codes return "\n".join(H) + footer @@ -542,7 +560,7 @@ def formsemestre_lettres_individuelles(formsemestre_id, group_ids=[]): init_qtip=True, ), f"""

Utiliser cette page pour éditer des versions provisoires des PV. - Il est recommandé d'archiver les versions définitives: Il est recommandé d'archiver les versions définitives: