diff --git a/app/scodoc/sco_bulletins.py b/app/scodoc/sco_bulletins.py index 83a51293f3..989c7bd5cf 100644 --- a/app/scodoc/sco_bulletins.py +++ b/app/scodoc/sco_bulletins.py @@ -347,23 +347,23 @@ def formsemestre_bulletinetud_dict(formsemestre_id, etudid, version="long"): u[ "modules_capitalized" ] = [] # modules de l'UE capitalisée (liste vide si pas capitalisée) - if ue_status["is_capitalized"]: - sem_origin = sco_formsemestre.get_formsemestre(ue_status["formsemestre_id"]) - u["ue_descr_txt"] = "capitalisée le %s" % ndb.DateISOtoDMY( - ue_status["event_date"] - ) + if ue_status["is_capitalized"] and ue_status["formsemestre_id"] is not None: + sem_origin = FormSemestre.query.get(ue_status["formsemestre_id"]) u[ - "ue_descr_html" - ] = f"""{u["ue_descr_txt"]} pouet + "ue_descr_txt" + ] = f'capitalisée le {ndb.DateISOtoDMY(ue_status["event_date"])}' + u["ue_descr_html"] = ( + f"""{u["ue_descr_txt"]} """ - if ue_status["moy"] != "NA" and ue_status["formsemestre_id"]: + if sem_origin + else "" + ) + if ue_status["moy"] != "NA": # détail des modules de l'UE capitalisée - formsemestre_cap = FormSemestre.query.get_or_404( - ue_status["formsemestre_id"] - ) + formsemestre_cap = FormSemestre.query.get(ue_status["formsemestre_id"]) nt_cap: NotesTableCompat = res_sem.load_formsemestre_results( formsemestre_cap ) @@ -712,7 +712,6 @@ def etud_descr_situation_semestre( infos = scu.DictDefault(defaultvalue="") # --- Situation et décisions jury - # démission/inscription ? events = sco_etud.scolar_events_list( cnx, args={"etudid": etudid, "formsemestre_id": formsemestre_id} @@ -763,11 +762,17 @@ def etud_descr_situation_semestre( infos["descr_inscription"] = "" infos["situation"] = infos["descr_inscription"] + # Décision: valeurs par defaut vides: + infos["decision_jury"] = infos["descr_decision_jury"] = "" + infos["decision_sem"] = "" + infos["decisions_ue"] = infos["descr_decisions_ue"] = "" + infos["descr_decisions_niveaux"] = infos["descr_decisions_rcue"] = "" + infos["descr_decision_annee"] = "" if date_dem: infos["descr_demission"] = f"Démission le {date_dem}." infos["date_demission"] = date_dem - infos["descr_decision_jury"] = "Démission" + infos["decision_jury"] = infos["descr_decision_jury"] = "Démission" infos["situation"] += " " + infos["descr_demission"] return infos, None # ne donne pas les dec. de jury pour les demissionnaires if date_def: @@ -779,8 +784,6 @@ def etud_descr_situation_semestre( dpv = sco_pvjury.dict_pvjury(formsemestre_id, etudids=[etudid]) if dpv: infos["decision_sem"] = dpv["decisions"][0]["decision_sem"] - else: - infos["decision_sem"] = "" if not show_decisions: return infos, dpv @@ -803,7 +806,7 @@ def etud_descr_situation_semestre( infos["descr_decisions_ue"] = " UE acquises: " + pv["decisions_ue_descr"] + ". " dec += infos["descr_decisions_ue"] else: - # infos['decisions_ue'] = None + infos["decisions_ue"] = "" infos["descr_decisions_ue"] = "" infos["mention"] = pv["mention"] @@ -842,9 +845,20 @@ def formsemestre_bulletinetud( force_publishing=False, # force publication meme si semestre non publie sur "portail" prefer_mail_perso=False, ): - """Page bulletin de notes - pour les formations classiques hors BUT (page HTML) - ou le format "oldjson". + """Page bulletin de notes pour + - HTML des formations classiques (non BUT) + - le format "oldjson" (les "json" sont générés à part, voir get_formsemestre_bulletin_etud_json) + - les formats PDF, XML et mail pdf (toutes formations) + + Note: le format XML n'est plus maintenu et pour les BUT ne contient pas + toutes les informations. Privilégier le format JSON. + + Paramètres: + - version: pour les formations classqiues, versions short/selectedevals/long + - xml_with_decisions: inclue ou non les + - force_publishing: renvoie le bulletin même si semestre non publie sur "portail" + - prefer_mail_perso: pour pdfmail, utilise adresse mail perso en priorité. + """ format = format or "html" formsemestre: FormSemestre = FormSemestre.query.get(formsemestre_id) @@ -903,7 +917,12 @@ def do_formsemestre_bulletinetud( prefer_mail_perso=False, # mails envoyés sur adresse perso si non vide ): """Génère le bulletin au format demandé. - Retourne: (bul, filigranne) + Utilisé pour: + - HTML des formations classiques (non BUT) + - le format "oldjson" (les json sont générés à part, voir get_formsemestre_bulletin_etud_json) + - les formats PDF, XML et mail pdf (toutes formations) + + Résultat: (bul, filigranne) où bul est str ou bytes au format demandé (html, pdf, pdfmail, pdfpart, xml, json) et filigranne est un message à placer en "filigranne" (eg "Provisoire"). """ @@ -919,7 +938,7 @@ def do_formsemestre_bulletinetud( return bul, "" - elif format == "json": + elif format == "json": # utilisé pour classic et "oldjson" bul = sco_bulletins_json.make_json_formsemestre_bulletinetud( formsemestre.id, etudid, @@ -932,20 +951,20 @@ def do_formsemestre_bulletinetud( if formsemestre.formation.is_apc(): etudiant = Identite.query.get(etudid) r = bulletin_but.BulletinBUT(formsemestre) - I = r.bulletin_etud_complet(etudiant, version=version) + infos = r.bulletin_etud_complet(etudiant, version=version) else: - I = formsemestre_bulletinetud_dict(formsemestre.id, etudid) - etud = I["etud"] + infos = formsemestre_bulletinetud_dict(formsemestre.id, etudid) + etud = infos["etud"] if format == "html": htm, _ = sco_bulletins_generator.make_formsemestre_bulletinetud( - I, version=version, format="html" + infos, version=version, format="html" ) - return htm, I["filigranne"] + return htm, infos["filigranne"] elif format == "pdf" or format == "pdfpart": bul, filename = sco_bulletins_generator.make_formsemestre_bulletinetud( - I, + infos, version=version, format="pdf", stand_alone=(format != "pdfpart"), @@ -953,10 +972,10 @@ def do_formsemestre_bulletinetud( if format == "pdf": return ( scu.sendPDFFile(bul, filename), - I["filigranne"], + infos["filigranne"], ) # unused ret. value else: - return bul, I["filigranne"] + return bul, infos["filigranne"] elif format == "pdfmail": # format pdfmail: envoie le pdf par mail a l'etud, et affiche le html @@ -965,7 +984,7 @@ def do_formsemestre_bulletinetud( raise AccessDenied("Vous n'avez pas le droit d'effectuer cette opération !") pdfdata, filename = sco_bulletins_generator.make_formsemestre_bulletinetud( - I, version=version, format="pdf" + infos, version=version, format="pdf" ) if prefer_mail_perso: @@ -975,21 +994,21 @@ def do_formsemestre_bulletinetud( if not recipient_addr: flash(f"{etud['nomprenom']} n'a pas d'adresse e-mail !") - return False, I["filigranne"] + return False, infos["filigranne"] else: - mail_bulletin(formsemestre.id, I, pdfdata, filename, recipient_addr) + mail_bulletin(formsemestre.id, infos, pdfdata, filename, recipient_addr) flash(f"mail envoyé à {recipient_addr}") - return True, I["filigranne"] + return True, infos["filigranne"] raise ValueError("do_formsemestre_bulletinetud: invalid format (%s)" % format) -def mail_bulletin(formsemestre_id, I, pdfdata, filename, recipient_addr): +def mail_bulletin(formsemestre_id, infos, pdfdata, filename, recipient_addr): """Send bulletin by email to etud If bul_mail_list_abs pref is true, put list of absences in mail body (text). """ - etud = I["etud"] + etud = infos["etud"] webmaster = sco_preferences.get_preference("bul_mail_contact_addr", formsemestre_id) dept = scu.unescape_html( sco_preferences.get_preference("DeptName", formsemestre_id) @@ -1016,7 +1035,7 @@ def mail_bulletin(formsemestre_id, I, pdfdata, filename, recipient_addr): etud["etudid"], with_evals=False, format="text" ) - subject = "Relevé de notes de %s" % etud["nomprenom"] + subject = f"""Relevé de notes de {etud["nomprenom"]}""" recipients = [recipient_addr] sender = sco_preferences.get_preference("email_from_addr", formsemestre_id) if copy_addr: @@ -1025,7 +1044,7 @@ def mail_bulletin(formsemestre_id, I, pdfdata, filename, recipient_addr): bcc = "" # Attach pdf - log("mail bulletin a %s" % recipient_addr) + log(f"""mail bulletin a {recipient_addr}""") email.send_email( subject, sender,