2020-09-26 16:19:37 +02:00
|
|
|
# -*- mode: python -*-
|
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
|
|
|
##############################################################################
|
|
|
|
#
|
|
|
|
# Gestion scolarite IUT
|
|
|
|
#
|
2021-01-01 17:51:08 +01:00
|
|
|
# Copyright (c) 1999 - 2021 Emmanuel Viennet. All rights reserved.
|
2020-09-26 16:19:37 +02:00
|
|
|
#
|
|
|
|
# This program is free software; you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation; either version 2 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with this program; if not, write to the Free Software
|
|
|
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
#
|
|
|
|
# Emmanuel Viennet emmanuel.viennet@viennet.net
|
|
|
|
#
|
|
|
|
##############################################################################
|
|
|
|
|
|
|
|
"""Form. pour inscription rapide des etudiants d'un semestre dans un autre
|
|
|
|
Utilise les autorisations d'inscription délivrées en jury.
|
|
|
|
"""
|
2021-02-04 20:02:44 +01:00
|
|
|
import datetime
|
2021-07-09 23:19:30 +02:00
|
|
|
from operator import itemgetter
|
2020-09-26 16:19:37 +02:00
|
|
|
|
2021-07-11 17:37:12 +02:00
|
|
|
from flask import url_for, g
|
|
|
|
|
2021-06-19 23:21:37 +02:00
|
|
|
import app.scodoc.notesdb as ndb
|
|
|
|
import app.scodoc.sco_utils as scu
|
|
|
|
from app.scodoc.notes_log import log
|
|
|
|
from app.scodoc.gen_tables import GenTable
|
|
|
|
from app.scodoc import html_sco_header
|
|
|
|
from app.scodoc import sco_codes_parcours
|
|
|
|
from app.scodoc import sco_preferences
|
|
|
|
from app.scodoc import sco_pvjury
|
|
|
|
from app.scodoc import sco_formsemestre
|
|
|
|
from app.scodoc import sco_formsemestre_inscriptions
|
|
|
|
from app.scodoc import sco_formations
|
|
|
|
from app.scodoc import sco_groups
|
|
|
|
from app.scodoc import sco_etud
|
|
|
|
from app.scodoc.sco_exceptions import ScoValueError
|
2020-09-26 16:19:37 +02:00
|
|
|
|
|
|
|
|
|
|
|
def list_authorized_etuds_by_sem(context, sem, delai=274):
|
|
|
|
"""Liste des etudiants autorisés à s'inscrire dans sem.
|
|
|
|
delai = nb de jours max entre la date de l'autorisation et celle de debut du semestre cible.
|
|
|
|
"""
|
|
|
|
src_sems = list_source_sems(context, sem, delai=delai)
|
|
|
|
inscrits = list_inscrits(context, sem["formsemestre_id"])
|
|
|
|
r = {}
|
|
|
|
candidats = {} # etudid : etud (tous les etudiants candidats)
|
|
|
|
nb = 0 # debug
|
|
|
|
for src in src_sems:
|
|
|
|
liste = list_etuds_from_sem(context, src, sem)
|
|
|
|
liste_filtree = []
|
|
|
|
for e in liste:
|
|
|
|
# Filtre ceux qui se sont déjà inscrit dans un semestre APRES le semestre src
|
|
|
|
auth_used = False # autorisation deja utilisée ?
|
2021-06-19 23:21:37 +02:00
|
|
|
etud = sco_etud.get_etud_info(etudid=e["etudid"], filled=True)[0]
|
2020-09-26 16:19:37 +02:00
|
|
|
for isem in etud["sems"]:
|
2021-02-03 22:00:41 +01:00
|
|
|
if ndb.DateDMYtoISO(isem["date_debut"]) >= ndb.DateDMYtoISO(
|
|
|
|
src["date_fin"]
|
|
|
|
):
|
2020-09-26 16:19:37 +02:00
|
|
|
auth_used = True
|
|
|
|
if not auth_used:
|
|
|
|
candidats[e["etudid"]] = etud
|
|
|
|
liste_filtree.append(e)
|
|
|
|
nb += 1
|
|
|
|
r[src["formsemestre_id"]] = {
|
|
|
|
"etuds": liste_filtree,
|
|
|
|
"infos": {
|
|
|
|
"id": src["formsemestre_id"],
|
|
|
|
"title": src["titreannee"],
|
|
|
|
"title_target": "formsemestre_status?formsemestre_id=%s"
|
|
|
|
% src["formsemestre_id"],
|
|
|
|
},
|
|
|
|
}
|
|
|
|
# ajoute attribut inscrit qui indique si l'étudiant est déjà inscrit dans le semestre dest.
|
|
|
|
for e in r[src["formsemestre_id"]]["etuds"]:
|
2021-07-09 17:47:06 +02:00
|
|
|
e["inscrit"] = e["etudid"] in inscrits
|
2020-09-26 16:19:37 +02:00
|
|
|
|
|
|
|
# Ajoute liste des etudiants actuellement inscrits
|
|
|
|
for e in inscrits.values():
|
|
|
|
e["inscrit"] = True
|
|
|
|
r[sem["formsemestre_id"]] = {
|
2021-07-09 17:47:06 +02:00
|
|
|
"etuds": list(inscrits.values()),
|
2020-09-26 16:19:37 +02:00
|
|
|
"infos": {
|
|
|
|
"id": sem["formsemestre_id"],
|
|
|
|
"title": "Semestre cible: " + sem["titreannee"],
|
|
|
|
"title_target": "formsemestre_status?formsemestre_id=%s"
|
|
|
|
% sem["formsemestre_id"],
|
|
|
|
"comment": " actuellement inscrits dans ce semestre",
|
|
|
|
"help": "Ces étudiants sont actuellement inscrits dans ce semestre. Si vous les décochez, il seront désinscrits.",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
return r, inscrits, candidats
|
|
|
|
|
|
|
|
|
|
|
|
def list_inscrits(context, formsemestre_id, with_dems=False):
|
|
|
|
"""Etudiants déjà inscrits à ce semestre
|
|
|
|
{ etudid : etud }
|
|
|
|
"""
|
|
|
|
if not with_dems:
|
2021-06-21 10:17:16 +02:00
|
|
|
ins = sco_formsemestre_inscriptions.do_formsemestre_inscription_listinscrits(
|
|
|
|
context, formsemestre_id
|
2020-09-26 16:19:37 +02:00
|
|
|
) # optimized
|
|
|
|
else:
|
|
|
|
args = {"formsemestre_id": formsemestre_id}
|
2021-06-19 23:21:37 +02:00
|
|
|
ins = sco_formsemestre_inscriptions.do_formsemestre_inscription_list(
|
|
|
|
context, args=args
|
|
|
|
)
|
2020-09-26 16:19:37 +02:00
|
|
|
inscr = {}
|
|
|
|
for i in ins:
|
|
|
|
etudid = i["etudid"]
|
2021-06-19 23:21:37 +02:00
|
|
|
inscr[etudid] = sco_etud.get_etud_info(etudid=etudid, filled=True)[0]
|
2020-09-26 16:19:37 +02:00
|
|
|
return inscr
|
|
|
|
|
|
|
|
|
|
|
|
def list_etuds_from_sem(context, src, dst):
|
2020-12-02 01:00:23 +01:00
|
|
|
"""Liste des etudiants du semestre src qui sont autorisés à passer dans le semestre dst."""
|
2020-09-26 16:19:37 +02:00
|
|
|
target = dst["semestre_id"]
|
|
|
|
dpv = sco_pvjury.dict_pvjury(context, src["formsemestre_id"])
|
|
|
|
if not dpv:
|
|
|
|
return []
|
|
|
|
etuds = [
|
|
|
|
x["identite"]
|
|
|
|
for x in dpv["decisions"]
|
|
|
|
if target in [a["semestre_id"] for a in x["autorisations"]]
|
|
|
|
]
|
|
|
|
return etuds
|
|
|
|
|
|
|
|
|
|
|
|
def list_inscrits_date(context, sem):
|
|
|
|
"""Liste les etudiants inscrits dans n'importe quel semestre
|
|
|
|
SAUF sem à la date de début de sem.
|
|
|
|
"""
|
2021-06-15 13:59:56 +02:00
|
|
|
cnx = ndb.GetDBConnexion()
|
2021-02-03 22:00:41 +01:00
|
|
|
cursor = cnx.cursor(cursor_factory=ndb.ScoDocCursor)
|
|
|
|
sem["date_debut_iso"] = ndb.DateDMYtoISO(sem["date_debut"])
|
2020-09-26 16:19:37 +02:00
|
|
|
cursor.execute(
|
|
|
|
"""select I.etudid
|
|
|
|
from notes_formsemestre_inscription I, notes_formsemestre S
|
|
|
|
where I.formsemestre_id = S.formsemestre_id
|
|
|
|
and I.formsemestre_id != %(formsemestre_id)s
|
|
|
|
and S.date_debut <= %(date_debut_iso)s
|
|
|
|
and S.date_fin >= %(date_debut_iso)s""",
|
|
|
|
sem,
|
|
|
|
)
|
|
|
|
return [x[0] for x in cursor.fetchall()]
|
|
|
|
|
|
|
|
|
|
|
|
def do_inscrit(context, sem, etudids, REQUEST=None, inscrit_groupes=False):
|
|
|
|
"""Inscrit ces etudiants dans ce semestre
|
|
|
|
(la liste doit avoir été vérifiée au préalable)
|
|
|
|
En option: inscrit aux mêmes groupes que dans le semestre origine
|
|
|
|
"""
|
|
|
|
log("do_inscrit (inscrit_groupes=%s): %s" % (inscrit_groupes, etudids))
|
|
|
|
for etudid in etudids:
|
|
|
|
sco_formsemestre_inscriptions.do_formsemestre_inscription_with_modules(
|
|
|
|
context,
|
|
|
|
sem["formsemestre_id"],
|
|
|
|
etudid,
|
|
|
|
etat="I",
|
|
|
|
REQUEST=REQUEST,
|
|
|
|
method="formsemestre_inscr_passage",
|
|
|
|
)
|
|
|
|
if inscrit_groupes:
|
|
|
|
# Inscription dans les mêmes groupes que ceux du semestre d'origine,
|
|
|
|
# s'ils existent.
|
|
|
|
# (mise en correspondance à partir du nom du groupe, sans tenir compte
|
|
|
|
# du nom de la partition: évidemment, cela ne marche pas si on a les
|
|
|
|
# même noms de groupes dans des partitions différentes)
|
2021-06-19 23:21:37 +02:00
|
|
|
etud = sco_etud.get_etud_info(etudid=etudid, filled=True)[0]
|
2020-09-26 16:19:37 +02:00
|
|
|
log("cherche groupes de %(nom)s" % etud)
|
|
|
|
|
|
|
|
# recherche le semestre origine (il serait plus propre de l'avoir conservé!)
|
|
|
|
if len(etud["sems"]) < 2:
|
|
|
|
continue
|
|
|
|
prev_formsemestre = etud["sems"][1]
|
|
|
|
sco_groups.etud_add_group_infos(context, etud, prev_formsemestre)
|
|
|
|
|
|
|
|
cursem_groups_by_name = dict(
|
|
|
|
[
|
|
|
|
(g["group_name"], g)
|
|
|
|
for g in sco_groups.get_sem_groups(context, sem["formsemestre_id"])
|
|
|
|
if g["group_name"]
|
|
|
|
]
|
|
|
|
)
|
|
|
|
|
|
|
|
# forme la liste des groupes présents dans les deux semestres:
|
|
|
|
partition_groups = [] # [ partition+group ] (ds nouveau sem.)
|
|
|
|
for partition_id in etud["partitions"]:
|
|
|
|
prev_group_name = etud["partitions"][partition_id]["group_name"]
|
|
|
|
if prev_group_name in cursem_groups_by_name:
|
|
|
|
new_group = cursem_groups_by_name[prev_group_name]
|
|
|
|
partition_groups.append(new_group)
|
|
|
|
|
|
|
|
# inscrit aux groupes
|
|
|
|
for partition_group in partition_groups:
|
|
|
|
sco_groups.change_etud_group_in_partition(
|
|
|
|
context,
|
|
|
|
etudid,
|
|
|
|
partition_group["group_id"],
|
|
|
|
partition_group,
|
|
|
|
REQUEST=REQUEST,
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def do_desinscrit(context, sem, etudids, REQUEST):
|
|
|
|
log("do_desinscrit: %s" % etudids)
|
|
|
|
for etudid in etudids:
|
2021-06-21 10:17:16 +02:00
|
|
|
sco_formsemestre_inscriptions.do_formsemestre_desinscription(
|
|
|
|
context, etudid, sem["formsemestre_id"], REQUEST=REQUEST
|
2020-09-26 16:19:37 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def list_source_sems(context, sem, delai=None):
|
|
|
|
"""Liste des semestres sources
|
|
|
|
sem est le semestre destination
|
|
|
|
"""
|
|
|
|
# liste des semestres débutant a moins
|
|
|
|
# de delai (en jours) de la date de fin du semestre d'origine.
|
|
|
|
sems = sco_formsemestre.do_formsemestre_list(context)
|
|
|
|
othersems = []
|
|
|
|
d, m, y = [int(x) for x in sem["date_debut"].split("/")]
|
|
|
|
date_debut_dst = datetime.date(y, m, d)
|
|
|
|
|
|
|
|
delais = datetime.timedelta(delai)
|
|
|
|
for s in sems:
|
|
|
|
if s["formsemestre_id"] == sem["formsemestre_id"]:
|
|
|
|
continue # saute le semestre destination
|
|
|
|
if s["date_fin"]:
|
|
|
|
d, m, y = [int(x) for x in s["date_fin"].split("/")]
|
|
|
|
date_fin = datetime.date(y, m, d)
|
|
|
|
if date_debut_dst - date_fin > delais:
|
|
|
|
continue # semestre trop ancien
|
|
|
|
if date_fin > date_debut_dst:
|
|
|
|
continue # semestre trop récent
|
|
|
|
# Elimine les semestres de formations speciales (sans parcours)
|
|
|
|
if s["semestre_id"] == sco_codes_parcours.NO_SEMESTRE_ID:
|
|
|
|
continue
|
|
|
|
#
|
2021-06-19 23:21:37 +02:00
|
|
|
F = sco_formations.formation_list(
|
|
|
|
context, args={"formation_id": s["formation_id"]}
|
|
|
|
)[0]
|
2020-09-26 16:19:37 +02:00
|
|
|
parcours = sco_codes_parcours.get_parcours_from_code(F["type_parcours"])
|
|
|
|
if not parcours.ALLOW_SEM_SKIP:
|
|
|
|
if s["semestre_id"] < (sem["semestre_id"] - 1):
|
|
|
|
continue
|
|
|
|
othersems.append(s)
|
|
|
|
return othersems
|
|
|
|
|
|
|
|
|
|
|
|
def formsemestre_inscr_passage(
|
|
|
|
context,
|
|
|
|
formsemestre_id,
|
|
|
|
etuds=[],
|
|
|
|
inscrit_groupes=False,
|
|
|
|
submitted=False,
|
|
|
|
dialog_confirmed=False,
|
|
|
|
REQUEST=None,
|
|
|
|
):
|
|
|
|
"""Form. pour inscription des etudiants d'un semestre dans un autre
|
|
|
|
(donné par formsemestre_id).
|
|
|
|
Permet de selectionner parmi les etudiants autorisés à s'inscrire.
|
|
|
|
Principe:
|
|
|
|
- trouver liste d'etud, par semestre
|
|
|
|
- afficher chaque semestre "boites" avec cases à cocher
|
|
|
|
- si l'étudiant est déjà inscrit, le signaler (gras, nom de groupes): il peut être désinscrit
|
|
|
|
- on peut choisir les groupes TD, TP, TA
|
|
|
|
- seuls les etudiants non inscrits changent (de groupe)
|
|
|
|
- les etudiants inscrit qui se trouvent décochés sont désinscrits
|
2020-12-02 01:00:23 +01:00
|
|
|
- Confirmation: indiquer les étudiants inscrits et ceux désinscrits, le total courant.
|
2020-09-26 16:19:37 +02:00
|
|
|
|
|
|
|
"""
|
|
|
|
inscrit_groupes = int(inscrit_groupes)
|
|
|
|
sem = sco_formsemestre.get_formsemestre(context, formsemestre_id)
|
|
|
|
# -- check lock
|
2021-08-10 12:57:38 +02:00
|
|
|
if not sem["etat"]:
|
2020-09-26 16:19:37 +02:00
|
|
|
raise ScoValueError("opération impossible: semestre verrouille")
|
2021-07-29 17:31:15 +03:00
|
|
|
header = html_sco_header.sco_header(page_title="Passage des étudiants")
|
2021-07-29 11:19:00 +03:00
|
|
|
footer = html_sco_header.sco_footer()
|
2020-09-26 16:19:37 +02:00
|
|
|
H = [header]
|
|
|
|
if type(etuds) == type(""):
|
|
|
|
etuds = etuds.split(",") # vient du form de confirmation
|
|
|
|
|
|
|
|
auth_etuds_by_sem, inscrits, candidats = list_authorized_etuds_by_sem(context, sem)
|
2020-12-02 01:00:23 +01:00
|
|
|
etuds_set = set(etuds)
|
|
|
|
candidats_set = set(candidats)
|
|
|
|
inscrits_set = set(inscrits)
|
2020-09-26 16:19:37 +02:00
|
|
|
candidats_non_inscrits = candidats_set - inscrits_set
|
2020-12-02 01:00:23 +01:00
|
|
|
inscrits_ailleurs = set(list_inscrits_date(context, sem))
|
2020-09-26 16:19:37 +02:00
|
|
|
|
|
|
|
def set_to_sorted_etud_list(etudset):
|
|
|
|
etuds = [candidats[etudid] for etudid in etudset]
|
2021-07-09 23:19:30 +02:00
|
|
|
etuds.sort(key=itemgetter("nom"))
|
2020-09-26 16:19:37 +02:00
|
|
|
return etuds
|
|
|
|
|
|
|
|
if submitted:
|
|
|
|
a_inscrire = etuds_set.intersection(candidats_set) - inscrits_set
|
|
|
|
a_desinscrire = inscrits_set - etuds_set
|
|
|
|
else:
|
|
|
|
a_inscrire = a_desinscrire = []
|
|
|
|
# log('formsemestre_inscr_passage: a_inscrire=%s' % str(a_inscrire) )
|
|
|
|
# log('formsemestre_inscr_passage: a_desinscrire=%s' % str(a_desinscrire) )
|
|
|
|
|
|
|
|
if not submitted:
|
|
|
|
H += build_page(
|
|
|
|
context,
|
|
|
|
REQUEST,
|
|
|
|
sem,
|
|
|
|
auth_etuds_by_sem,
|
|
|
|
inscrits,
|
|
|
|
candidats_non_inscrits,
|
|
|
|
inscrits_ailleurs,
|
|
|
|
inscrit_groupes=inscrit_groupes,
|
|
|
|
)
|
|
|
|
else:
|
|
|
|
if not dialog_confirmed:
|
|
|
|
# Confirmation
|
|
|
|
if a_inscrire:
|
|
|
|
H.append("<h3>Etudiants à inscrire</h3><ol>")
|
|
|
|
for etud in set_to_sorted_etud_list(a_inscrire):
|
|
|
|
H.append("<li>%(nomprenom)s</li>" % etud)
|
|
|
|
H.append("</ol>")
|
|
|
|
a_inscrire_en_double = inscrits_ailleurs.intersection(a_inscrire)
|
|
|
|
if a_inscrire_en_double:
|
|
|
|
H.append("<h3>dont étudiants déjà inscrits:</h3><ul>")
|
|
|
|
for etud in set_to_sorted_etud_list(a_inscrire_en_double):
|
|
|
|
H.append('<li class="inscrailleurs">%(nomprenom)s</li>' % etud)
|
|
|
|
H.append("</ul>")
|
|
|
|
if a_desinscrire:
|
|
|
|
H.append("<h3>Etudiants à désinscrire</h3><ol>")
|
|
|
|
for etudid in a_desinscrire:
|
|
|
|
H.append(
|
|
|
|
'<li class="desinscription">%(nomprenom)s</li>'
|
|
|
|
% inscrits[etudid]
|
|
|
|
)
|
|
|
|
H.append("</ol>")
|
|
|
|
if not a_inscrire and not a_desinscrire:
|
|
|
|
H.append("""<h3>Il n'y a rien à modifier !</h3>""")
|
|
|
|
H.append(
|
2021-06-02 22:40:34 +02:00
|
|
|
scu.confirm_dialog(
|
2020-09-26 16:19:37 +02:00
|
|
|
dest_url="formsemestre_inscr_passage",
|
|
|
|
add_headers=False,
|
|
|
|
cancel_url="formsemestre_inscr_passage?formsemestre_id="
|
2021-08-10 17:12:10 +02:00
|
|
|
+ str(formsemestre_id),
|
2020-09-26 16:19:37 +02:00
|
|
|
OK="Effectuer l'opération",
|
|
|
|
parameters={
|
|
|
|
"formsemestre_id": formsemestre_id,
|
|
|
|
"etuds": ",".join(etuds),
|
|
|
|
"inscrit_groupes": inscrit_groupes,
|
|
|
|
"submitted": 1,
|
|
|
|
},
|
|
|
|
)
|
|
|
|
)
|
|
|
|
else:
|
|
|
|
# Inscription des étudiants au nouveau semestre:
|
|
|
|
do_inscrit(
|
|
|
|
context,
|
|
|
|
sem,
|
|
|
|
a_inscrire,
|
|
|
|
REQUEST=REQUEST,
|
|
|
|
inscrit_groupes=inscrit_groupes,
|
|
|
|
)
|
|
|
|
|
|
|
|
# Desincriptions:
|
|
|
|
do_desinscrit(context, sem, a_desinscrire, REQUEST)
|
|
|
|
|
|
|
|
H.append(
|
|
|
|
"""<h3>Opération effectuée</h3>
|
|
|
|
<ul><li><a class="stdlink" href="formsemestre_inscr_passage?formsemestre_id=%s">Continuer les inscriptions</a></li>
|
|
|
|
<li><a class="stdlink" href="formsemestre_status?formsemestre_id=%s">Tableau de bord du semestre</a></li>"""
|
|
|
|
% (formsemestre_id, formsemestre_id)
|
|
|
|
)
|
|
|
|
partition = sco_groups.formsemestre_get_main_partition(
|
|
|
|
context, formsemestre_id
|
|
|
|
)
|
|
|
|
if (
|
|
|
|
partition["partition_id"]
|
|
|
|
!= sco_groups.formsemestre_get_main_partition(context, formsemestre_id)[
|
|
|
|
"partition_id"
|
|
|
|
]
|
|
|
|
): # il y a au moins une vraie partition
|
|
|
|
H.append(
|
2021-08-16 08:33:12 +02:00
|
|
|
f"""<li><a class="stdlink" href="{
|
|
|
|
url_for("scolar.affectGroups",
|
|
|
|
scodoc_dept=g.scodoc_dept, partition_id=partition["partition_id"])
|
|
|
|
}">Répartir les groupes de {partition["partition_name"]}</a></li>
|
2020-09-26 16:19:37 +02:00
|
|
|
"""
|
|
|
|
)
|
|
|
|
|
|
|
|
#
|
|
|
|
H.append(footer)
|
|
|
|
return "\n".join(H)
|
|
|
|
|
|
|
|
|
|
|
|
def build_page(
|
|
|
|
context,
|
|
|
|
REQUEST,
|
|
|
|
sem,
|
|
|
|
auth_etuds_by_sem,
|
|
|
|
inscrits,
|
|
|
|
candidats_non_inscrits,
|
|
|
|
inscrits_ailleurs,
|
|
|
|
inscrit_groupes=False,
|
|
|
|
):
|
|
|
|
inscrit_groupes = int(inscrit_groupes)
|
|
|
|
if inscrit_groupes:
|
|
|
|
inscrit_groupes_checked = " checked"
|
|
|
|
else:
|
|
|
|
inscrit_groupes_checked = ""
|
|
|
|
|
|
|
|
H = [
|
2021-06-13 19:12:20 +02:00
|
|
|
html_sco_header.html_sem_header(
|
|
|
|
context, REQUEST, "Passages dans le semestre", sem, with_page_header=False
|
2020-09-26 16:19:37 +02:00
|
|
|
),
|
|
|
|
"""<form method="post" action="%s">""" % REQUEST.URL0,
|
|
|
|
"""<input type="hidden" name="formsemestre_id" value="%(formsemestre_id)s"/>
|
|
|
|
<input type="submit" name="submitted" value="Appliquer les modifications"/>
|
|
|
|
<a href="#help">aide</a>
|
|
|
|
"""
|
|
|
|
% sem, # "
|
|
|
|
"""<input name="inscrit_groupes" type="checkbox" value="1" %s>inscrire aux mêmes groupes</input>"""
|
|
|
|
% inscrit_groupes_checked,
|
|
|
|
"""<div class="pas_recap">Actuellement <span id="nbinscrits">%s</span> inscrits
|
|
|
|
et %d candidats supplémentaires
|
|
|
|
</div>"""
|
|
|
|
% (len(inscrits), len(candidats_non_inscrits)),
|
|
|
|
etuds_select_boxes(context, auth_etuds_by_sem, inscrits_ailleurs),
|
|
|
|
"""<p/><input type="submit" name="submitted" value="Appliquer les modifications"/>""",
|
|
|
|
formsemestre_inscr_passage_help(sem),
|
|
|
|
"""</form>""",
|
|
|
|
]
|
|
|
|
|
|
|
|
# Semestres sans etudiants autorisés
|
|
|
|
empty_sems = []
|
|
|
|
for formsemestre_id in auth_etuds_by_sem.keys():
|
|
|
|
if not auth_etuds_by_sem[formsemestre_id]["etuds"]:
|
|
|
|
empty_sems.append(auth_etuds_by_sem[formsemestre_id]["infos"])
|
|
|
|
if empty_sems:
|
|
|
|
H.append(
|
|
|
|
"""<div class="pas_empty_sems"><h3>Autres semestres sans candidats :</h3><ul>"""
|
|
|
|
)
|
|
|
|
for infos in empty_sems:
|
|
|
|
H.append("""<li><a href="%(title_target)s">%(title)s</a></li>""" % infos)
|
|
|
|
H.append("""</ul></div>""")
|
|
|
|
|
|
|
|
return H
|
|
|
|
|
|
|
|
|
|
|
|
def formsemestre_inscr_passage_help(sem):
|
|
|
|
return (
|
2021-07-13 09:38:31 +02:00
|
|
|
"""<div class="pas_help"><h3><a name="help">Explications</a></h3>
|
2020-09-26 16:19:37 +02:00
|
|
|
<p>Cette page permet d'inscrire des étudiants dans le semestre destination
|
|
|
|
<a class="stdlink"
|
|
|
|
href="formsemestre_status?formsemestre_id=%(formsemestre_id)s">%(titreannee)s</a>,
|
|
|
|
et d'en désincrire si besoin.
|
|
|
|
</p>
|
|
|
|
<p>Les étudiants sont groupés par semestres d'origines. Ceux qui sont en caractères
|
|
|
|
<span class="inscrit">gras</span> sont déjà inscrits dans le semestre destination.
|
|
|
|
Ceux qui sont en <span class"inscrailleurs">gras et en rouge</span> sont inscrits
|
|
|
|
dans un <em>autre</em> semestre.</p>
|
|
|
|
<p>Au départ, les étudiants déjà inscrits sont sélectionnés; vous pouvez ajouter d'autres
|
|
|
|
étudiants à inscrire dans le semestre destination.</p>
|
|
|
|
<p>Si vous dé-selectionnez un étudiant déjà inscrit (en gras), il sera désinscrit.</p>
|
|
|
|
<p class="help">Aucune action ne sera effectuée si vous n'appuyez pas sur le bouton "Appliquer les modifications" !</p>
|
|
|
|
</div>"""
|
|
|
|
% sem
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def etuds_select_boxes(
|
|
|
|
context,
|
|
|
|
auth_etuds_by_cat,
|
|
|
|
inscrits_ailleurs={},
|
|
|
|
sel_inscrits=True,
|
|
|
|
show_empty_boxes=False,
|
|
|
|
export_cat_xls=None,
|
|
|
|
base_url="",
|
|
|
|
read_only=False,
|
|
|
|
):
|
|
|
|
"""Boites pour selection étudiants par catégorie
|
|
|
|
auth_etuds_by_cat = { category : { 'info' : {}, 'etuds' : ... }
|
|
|
|
inscrits_ailleurs =
|
2020-12-02 01:00:23 +01:00
|
|
|
sel_inscrits=
|
2020-09-26 16:19:37 +02:00
|
|
|
export_cat_xls =
|
|
|
|
"""
|
|
|
|
if export_cat_xls:
|
|
|
|
return etuds_select_box_xls(context, auth_etuds_by_cat[export_cat_xls])
|
|
|
|
|
|
|
|
H = [
|
|
|
|
"""<script type="text/javascript">
|
|
|
|
function sem_select(formsemestre_id, state) {
|
|
|
|
var elems = document.getElementById(formsemestre_id).getElementsByTagName("input");
|
|
|
|
for (var i =0; i < elems.length; i++) { elems[i].checked=state; }
|
|
|
|
}
|
|
|
|
function sem_select_inscrits(formsemestre_id) {
|
|
|
|
var elems = document.getElementById(formsemestre_id).getElementsByTagName("input");
|
|
|
|
for (var i =0; i < elems.length; i++) {
|
|
|
|
if (elems[i].parentNode.className.indexOf('inscrit') >= 0) {
|
|
|
|
elems[i].checked=true;
|
|
|
|
} else {
|
|
|
|
elems[i].checked=false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
<div class="etuds_select_boxes">"""
|
|
|
|
] # "
|
|
|
|
|
|
|
|
for src_cat in auth_etuds_by_cat.keys():
|
|
|
|
infos = auth_etuds_by_cat[src_cat]["infos"]
|
|
|
|
infos["comment"] = infos.get("comment", "") # commentaire dans sous-titre boite
|
|
|
|
help = infos.get("help", "")
|
|
|
|
etuds = auth_etuds_by_cat[src_cat]["etuds"]
|
2021-07-09 23:19:30 +02:00
|
|
|
etuds.sort(key=itemgetter("nom"))
|
2020-09-26 16:19:37 +02:00
|
|
|
with_checkbox = (not read_only) and auth_etuds_by_cat[src_cat]["infos"].get(
|
|
|
|
"with_checkbox", True
|
|
|
|
)
|
|
|
|
checkbox_name = auth_etuds_by_cat[src_cat]["infos"].get(
|
|
|
|
"checkbox_name", "etuds"
|
|
|
|
)
|
|
|
|
etud_key = auth_etuds_by_cat[src_cat]["infos"].get("etud_key", "etudid")
|
|
|
|
if etuds or show_empty_boxes:
|
|
|
|
infos["nbetuds"] = len(etuds)
|
|
|
|
H.append(
|
|
|
|
"""<div class="pas_sembox" id="%(id)s">
|
|
|
|
<div class="pas_sembox_title"><a href="%(title_target)s" """
|
|
|
|
% infos
|
|
|
|
)
|
|
|
|
if help: # bubble
|
|
|
|
H.append('title="%s"' % help)
|
|
|
|
H.append(
|
|
|
|
""">%(title)s</a></div>
|
|
|
|
<div class="pas_sembox_subtitle">(%(nbetuds)d étudiants%(comment)s)"""
|
|
|
|
% infos
|
|
|
|
)
|
|
|
|
if with_checkbox:
|
|
|
|
H.append(
|
|
|
|
""" (Select.
|
|
|
|
<a href="#" onclick="sem_select('%(id)s', true);">tous</a>
|
|
|
|
<a href="#" onclick="sem_select('%(id)s', false );">aucun</a>""" # "
|
|
|
|
% infos
|
|
|
|
)
|
|
|
|
if sel_inscrits:
|
|
|
|
H.append(
|
|
|
|
"""<a href="#" onclick="sem_select_inscrits('%(id)s');">inscrits</a>"""
|
|
|
|
% infos
|
|
|
|
)
|
|
|
|
if with_checkbox or sel_inscrits:
|
|
|
|
H.append(")")
|
|
|
|
if base_url and etuds:
|
|
|
|
H.append(
|
2021-05-11 11:48:32 +02:00
|
|
|
'<a href="%s&export_cat_xls=%s">%s</a> '
|
2021-02-04 20:02:44 +01:00
|
|
|
% (base_url, src_cat, scu.ICON_XLS)
|
2020-09-26 16:19:37 +02:00
|
|
|
)
|
|
|
|
H.append("</div>")
|
|
|
|
for etud in etuds:
|
|
|
|
if etud.get("inscrit", False):
|
|
|
|
c = " inscrit"
|
|
|
|
checked = 'checked="checked"'
|
|
|
|
else:
|
|
|
|
checked = ""
|
|
|
|
if etud["etudid"] in inscrits_ailleurs:
|
|
|
|
c = " inscrailleurs"
|
|
|
|
else:
|
|
|
|
c = ""
|
2021-06-19 23:21:37 +02:00
|
|
|
sco_etud.format_etud_ident(etud)
|
2020-09-26 16:19:37 +02:00
|
|
|
if etud["etudid"]:
|
2021-07-11 17:37:12 +02:00
|
|
|
elink = """<a class="discretelink %s" href="%s">%s</a>""" % (
|
|
|
|
c,
|
|
|
|
url_for(
|
|
|
|
"scolar.ficheEtud",
|
|
|
|
scodoc_dept=g.scodoc_dept,
|
|
|
|
etudid=etud["etudid"],
|
|
|
|
),
|
|
|
|
etud["nomprenom"],
|
2020-09-26 16:19:37 +02:00
|
|
|
)
|
|
|
|
else:
|
|
|
|
# ce n'est pas un etudiant ScoDoc
|
|
|
|
elink = etud["nomprenom"]
|
|
|
|
|
|
|
|
if etud.get("datefinalisationinscription", None):
|
|
|
|
elink += (
|
|
|
|
'<span class="finalisationinscription">'
|
|
|
|
+ " : inscription finalisée le "
|
|
|
|
+ etud["datefinalisationinscription"].strftime("%d/%m/%Y")
|
|
|
|
+ "</span>"
|
|
|
|
)
|
|
|
|
|
|
|
|
if not etud.get("paiementinscription", True):
|
|
|
|
elink += '<span class="paspaye"> (non paiement)</span>'
|
|
|
|
|
|
|
|
H.append("""<div class="pas_etud%s">""" % c)
|
|
|
|
if "etape" in etud:
|
|
|
|
etape_str = etud["etape"] or ""
|
|
|
|
else:
|
|
|
|
etape_str = ""
|
|
|
|
H.append("""<span class="sp_etape">%s</span>""" % etape_str)
|
|
|
|
if with_checkbox:
|
|
|
|
H.append(
|
|
|
|
"""<input type="checkbox" name="%s:list" value="%s" %s>"""
|
|
|
|
% (checkbox_name, etud[etud_key], checked)
|
|
|
|
)
|
|
|
|
H.append(elink)
|
|
|
|
if with_checkbox:
|
|
|
|
H.append("""</input>""")
|
|
|
|
H.append("</div>")
|
|
|
|
H.append("</div>")
|
|
|
|
|
|
|
|
H.append("</div>")
|
|
|
|
return "\n".join(H)
|
|
|
|
|
|
|
|
|
|
|
|
def etuds_select_box_xls(context, src_cat):
|
|
|
|
"export a box to excel"
|
|
|
|
etuds = src_cat["etuds"]
|
2021-02-13 17:28:55 +01:00
|
|
|
columns_ids = ["etudid", "civilite_str", "nom", "prenom", "etape"]
|
2020-12-02 01:00:23 +01:00
|
|
|
titles = {x: x for x in columns_ids}
|
|
|
|
|
2020-09-26 16:19:37 +02:00
|
|
|
# Ajoute colonne paiement inscription
|
|
|
|
columns_ids.append("paiementinscription_str")
|
|
|
|
titles["paiementinscription_str"] = "paiement inscription"
|
|
|
|
for e in etuds:
|
|
|
|
if not e.get("paiementinscription", True):
|
|
|
|
e["paiementinscription_str"] = "NON"
|
|
|
|
else:
|
|
|
|
e["paiementinscription_str"] = "-"
|
|
|
|
tab = GenTable(
|
|
|
|
titles=titles,
|
|
|
|
columns_ids=columns_ids,
|
|
|
|
rows=etuds,
|
|
|
|
caption="%(title)s. %(help)s" % src_cat["infos"],
|
2021-07-28 18:03:54 +03:00
|
|
|
preferences=sco_preferences.SemPreferences(),
|
2020-09-26 16:19:37 +02:00
|
|
|
)
|
|
|
|
return tab.excel()
|