forked from ScoDoc/ScoDoc
Refactoring: remove useless public zmethods
This commit is contained in:
parent
76d7a21ec7
commit
d6fa3e57de
94
ZAbsences.py
94
ZAbsences.py
@ -666,21 +666,6 @@ class ZAbsences(
|
|||||||
if self.CountAbs(etudid, jour, jour, matin, moduleimpl_id) == 0:
|
if self.CountAbs(etudid, jour, jour, matin, moduleimpl_id) == 0:
|
||||||
self._AddAbsence(etudid, jour, matin, 0, REQUEST, "", moduleimpl_id)
|
self._AddAbsence(etudid, jour, matin, 0, REQUEST, "", moduleimpl_id)
|
||||||
|
|
||||||
#
|
|
||||||
security.declareProtected(ScoView, "CalSelectWeek")
|
|
||||||
|
|
||||||
def CalSelectWeek(self, year=None, REQUEST=None):
|
|
||||||
"display calendar allowing week selection"
|
|
||||||
if not year:
|
|
||||||
year = scu.AnneeScolaire(REQUEST)
|
|
||||||
sems = sco_formsemestre.do_formsemestre_list(self)
|
|
||||||
if not sems:
|
|
||||||
js = ""
|
|
||||||
else:
|
|
||||||
js = 'onmouseover="highlightweek(this);" onmouseout="deselectweeks();" onclick="wclick(this);"'
|
|
||||||
C = sco_abs.YearTable(self, int(year), dayattributes=js)
|
|
||||||
return C
|
|
||||||
|
|
||||||
# --- Misc tools.... ------------------
|
# --- Misc tools.... ------------------
|
||||||
|
|
||||||
def _isFarFutur(self, jour):
|
def _isFarFutur(self, jour):
|
||||||
@ -691,65 +676,6 @@ class ZAbsences(
|
|||||||
# 6 mois ~ 182 jours:
|
# 6 mois ~ 182 jours:
|
||||||
return j - datetime.date.today() > datetime.timedelta(182)
|
return j - datetime.date.today() > datetime.timedelta(182)
|
||||||
|
|
||||||
security.declareProtected(ScoView, "is_work_saturday")
|
|
||||||
|
|
||||||
def is_work_saturday(self):
|
|
||||||
"Vrai si le samedi est travaillé"
|
|
||||||
return int(self.get_preference("work_saturday"))
|
|
||||||
|
|
||||||
security.declareProtected(ScoView, "day_names")
|
|
||||||
|
|
||||||
def day_names(self):
|
|
||||||
"""Returns week day names.
|
|
||||||
If work_saturday property is set, include saturday
|
|
||||||
"""
|
|
||||||
if self.is_work_saturday():
|
|
||||||
return ["Lundi", "Mardi", "Mercredi", "Jeudi", "Vendredi", "Samedi"]
|
|
||||||
else:
|
|
||||||
return ["Lundi", "Mardi", "Mercredi", "Jeudi", "Vendredi"]
|
|
||||||
|
|
||||||
security.declareProtected(ScoView, "ListMondays")
|
|
||||||
|
|
||||||
def ListMondays(self, year=None, REQUEST=None):
|
|
||||||
"""return list of mondays (ISO dates), from september to june"""
|
|
||||||
if not year:
|
|
||||||
year = scu.AnneeScolaire(REQUEST)
|
|
||||||
d = ddmmyyyy("1/9/%d" % year, work_saturday=self.is_work_saturday())
|
|
||||||
while d.weekday != 0:
|
|
||||||
d = d.next()
|
|
||||||
end = ddmmyyyy("1/7/%d" % (year + 1), work_saturday=self.is_work_saturday())
|
|
||||||
L = [d]
|
|
||||||
while d < end:
|
|
||||||
d = d.next(days=7)
|
|
||||||
L.append(d)
|
|
||||||
return map(lambda x: x.ISO(), L)
|
|
||||||
|
|
||||||
security.declareProtected(ScoView, "NextISODay")
|
|
||||||
|
|
||||||
def NextISODay(self, date):
|
|
||||||
"return date after date"
|
|
||||||
d = ddmmyyyy(date, fmt="iso", work_saturday=self.is_work_saturday())
|
|
||||||
return d.next().ISO()
|
|
||||||
|
|
||||||
security.declareProtected(ScoView, "DateRangeISO")
|
|
||||||
|
|
||||||
def DateRangeISO(self, date_beg, date_end, workable=1):
|
|
||||||
"""returns list of dates in [date_beg,date_end]
|
|
||||||
workable = 1 => keeps only workable days"""
|
|
||||||
if not date_beg:
|
|
||||||
raise ScoValueError("pas de date spécifiée !")
|
|
||||||
if not date_end:
|
|
||||||
date_end = date_beg
|
|
||||||
r = []
|
|
||||||
cur = ddmmyyyy(date_beg, work_saturday=self.is_work_saturday())
|
|
||||||
end = ddmmyyyy(date_end, work_saturday=self.is_work_saturday())
|
|
||||||
while cur <= end:
|
|
||||||
if (not workable) or cur.iswork():
|
|
||||||
r.append(cur)
|
|
||||||
cur = cur.next()
|
|
||||||
|
|
||||||
return map(lambda x: x.ISO(), r)
|
|
||||||
|
|
||||||
# ------------ HTML Interfaces
|
# ------------ HTML Interfaces
|
||||||
security.declareProtected(ScoAbsChange, "SignaleAbsenceGrHebdo")
|
security.declareProtected(ScoAbsChange, "SignaleAbsenceGrHebdo")
|
||||||
|
|
||||||
@ -801,8 +727,8 @@ class ZAbsences(
|
|||||||
# calcule dates jours de cette semaine
|
# calcule dates jours de cette semaine
|
||||||
# liste de dates iso "yyyy-mm-dd"
|
# liste de dates iso "yyyy-mm-dd"
|
||||||
datessem = [notesdb.DateDMYtoISO(datelundi)]
|
datessem = [notesdb.DateDMYtoISO(datelundi)]
|
||||||
for _ in self.day_names()[1:]:
|
for _ in sco_abs.day_names(self)[1:]:
|
||||||
datessem.append(self.NextISODay(datessem[-1]))
|
datessem.append(sco_abs.next_iso_day(self, datessem[-1]))
|
||||||
#
|
#
|
||||||
if groups_infos.tous_les_etuds_du_sem:
|
if groups_infos.tous_les_etuds_du_sem:
|
||||||
gr_tit = "en"
|
gr_tit = "en"
|
||||||
@ -944,12 +870,12 @@ class ZAbsences(
|
|||||||
sem = sco_formsemestre.do_formsemestre_list(
|
sem = sco_formsemestre.do_formsemestre_list(
|
||||||
self, {"formsemestre_id": formsemestre_id}
|
self, {"formsemestre_id": formsemestre_id}
|
||||||
)[0]
|
)[0]
|
||||||
|
work_saturday = sco_abs.is_work_saturday(self)
|
||||||
jourdebut = ddmmyyyy(datedebut, work_saturday=self.is_work_saturday())
|
jourdebut = ddmmyyyy(datedebut, work_saturday=work_saturday)
|
||||||
jourfin = ddmmyyyy(datefin, work_saturday=self.is_work_saturday())
|
jourfin = ddmmyyyy(datefin, work_saturday=work_saturday)
|
||||||
today = ddmmyyyy(
|
today = ddmmyyyy(
|
||||||
time.strftime("%d/%m/%Y", time.localtime()),
|
time.strftime("%d/%m/%Y", time.localtime()),
|
||||||
work_saturday=self.is_work_saturday(),
|
work_saturday=work_saturday,
|
||||||
)
|
)
|
||||||
today.next()
|
today.next()
|
||||||
if jourfin > today: # ne propose jamais les semaines dans le futur
|
if jourfin > today: # ne propose jamais les semaines dans le futur
|
||||||
@ -964,7 +890,7 @@ class ZAbsences(
|
|||||||
)
|
)
|
||||||
# calcule dates
|
# calcule dates
|
||||||
dates = [] # ddmmyyyy instances
|
dates = [] # ddmmyyyy instances
|
||||||
d = ddmmyyyy(datedebut, work_saturday=self.is_work_saturday())
|
d = ddmmyyyy(datedebut, work_saturday=work_saturday)
|
||||||
while d <= jourfin:
|
while d <= jourfin:
|
||||||
dates.append(d)
|
dates.append(d)
|
||||||
d = d.next(7) # avance d'une semaine
|
d = d.next(7) # avance d'une semaine
|
||||||
@ -982,7 +908,7 @@ class ZAbsences(
|
|||||||
url_link_semaines += "&moduleimpl_id=" + moduleimpl_id
|
url_link_semaines += "&moduleimpl_id=" + moduleimpl_id
|
||||||
#
|
#
|
||||||
dates = [x.ISO() for x in dates]
|
dates = [x.ISO() for x in dates]
|
||||||
dayname = self.day_names()[jourdebut.weekday]
|
dayname = sco_abs.day_names(self)[jourdebut.weekday]
|
||||||
|
|
||||||
if groups_infos.tous_les_etuds_du_sem:
|
if groups_infos.tous_les_etuds_du_sem:
|
||||||
gr_tit = "en"
|
gr_tit = "en"
|
||||||
@ -1119,7 +1045,7 @@ class ZAbsences(
|
|||||||
odates = [datetime.date(*[int(x) for x in d.split("-")]) for d in dates]
|
odates = [datetime.date(*[int(x) for x in d.split("-")]) for d in dates]
|
||||||
# Titres colonnes
|
# Titres colonnes
|
||||||
noms_jours = [] # eg [ "Lundi", "mardi", "Samedi", ... ]
|
noms_jours = [] # eg [ "Lundi", "mardi", "Samedi", ... ]
|
||||||
jn = self.day_names()
|
jn = sco_abs.day_names(self)
|
||||||
for d in odates:
|
for d in odates:
|
||||||
idx_jour = d.weekday()
|
idx_jour = d.weekday()
|
||||||
noms_jours.append(jn[idx_jour])
|
noms_jours.append(jn[idx_jour])
|
||||||
@ -1844,7 +1770,7 @@ ou entrez une date pour visualiser les absents un jour donné :
|
|||||||
# 1-- ajout des absences (et justifs)
|
# 1-- ajout des absences (et justifs)
|
||||||
datedebut = billet["abs_begin"].strftime("%d/%m/%Y")
|
datedebut = billet["abs_begin"].strftime("%d/%m/%Y")
|
||||||
datefin = billet["abs_end"].strftime("%d/%m/%Y")
|
datefin = billet["abs_end"].strftime("%d/%m/%Y")
|
||||||
dates = self.DateRangeISO(datedebut, datefin)
|
dates = sco_abs.DateRangeISO(self, datedebut, datefin)
|
||||||
# commence après-midi ?
|
# commence après-midi ?
|
||||||
if dates and billet["abs_begin"].hour > 11:
|
if dates and billet["abs_begin"].hour > 11:
|
||||||
self._AddAbsence(
|
self._AddAbsence(
|
||||||
|
643
ZEntreprises.py
643
ZEntreprises.py
File diff suppressed because it is too large
Load Diff
@ -599,7 +599,7 @@ UE11 Découverte métiers <span class="ue_code">(code UCOD46, 16 ECTS, Apo <span
|
|||||||
FA.append('<input type="submit" value="Saisir absences du" />')
|
FA.append('<input type="submit" value="Saisir absences du" />')
|
||||||
FA.append('<select name="datedebut" class="noprint">')
|
FA.append('<select name="datedebut" class="noprint">')
|
||||||
date = first_monday
|
date = first_monday
|
||||||
for jour in self.Absences.day_names():
|
for jour in sco_abs.day_names(self):
|
||||||
FA.append('<option value="%s">%s</option>' % (date, jour))
|
FA.append('<option value="%s">%s</option>' % (date, jour))
|
||||||
date = date.next()
|
date = date.next()
|
||||||
FA.append("</select>")
|
FA.append("</select>")
|
||||||
|
40
sco_abs.py
40
sco_abs.py
@ -43,6 +43,11 @@ import sco_formsemestre
|
|||||||
import sco_compute_moy
|
import sco_compute_moy
|
||||||
|
|
||||||
|
|
||||||
|
def is_work_saturday(context):
|
||||||
|
"Vrai si le samedi est travaillé"
|
||||||
|
return int(context.get_preference("work_saturday"))
|
||||||
|
|
||||||
|
|
||||||
def MonthNbDays(month, year):
|
def MonthNbDays(month, year):
|
||||||
"returns nb of days in month"
|
"returns nb of days in month"
|
||||||
if month > 7:
|
if month > 7:
|
||||||
@ -173,6 +178,39 @@ class ddmmyyyy:
|
|||||||
|
|
||||||
|
|
||||||
# d = ddmmyyyy( '21/12/99' )
|
# d = ddmmyyyy( '21/12/99' )
|
||||||
|
def DateRangeISO(context, date_beg, date_end, workable=1):
|
||||||
|
"""returns list of dates in [date_beg,date_end]
|
||||||
|
workable = 1 => keeps only workable days"""
|
||||||
|
if not date_beg:
|
||||||
|
raise ScoValueError("pas de date spécifiée !")
|
||||||
|
if not date_end:
|
||||||
|
date_end = date_beg
|
||||||
|
r = []
|
||||||
|
work_saturday = is_work_saturday(context)
|
||||||
|
cur = ddmmyyyy(date_beg, work_saturday=work_saturday)
|
||||||
|
end = ddmmyyyy(date_end, work_saturday=work_saturday)
|
||||||
|
while cur <= end:
|
||||||
|
if (not workable) or cur.iswork():
|
||||||
|
r.append(cur)
|
||||||
|
cur = cur.next()
|
||||||
|
|
||||||
|
return map(lambda x: x.ISO(), r)
|
||||||
|
|
||||||
|
|
||||||
|
def day_names(context):
|
||||||
|
"""Returns week day names.
|
||||||
|
If work_saturday property is set, include saturday
|
||||||
|
"""
|
||||||
|
if is_work_saturday(context):
|
||||||
|
return ["Lundi", "Mardi", "Mercredi", "Jeudi", "Vendredi", "Samedi"]
|
||||||
|
else:
|
||||||
|
return ["Lundi", "Mardi", "Mercredi", "Jeudi", "Vendredi"]
|
||||||
|
|
||||||
|
|
||||||
|
def next_iso_day(context, date):
|
||||||
|
"return date after date"
|
||||||
|
d = ddmmyyyy(date, fmt="iso", work_saturday=is_work_saturday(context))
|
||||||
|
return d.next().ISO()
|
||||||
|
|
||||||
|
|
||||||
def YearTable(
|
def YearTable(
|
||||||
@ -207,7 +245,7 @@ def YearTable(
|
|||||||
events,
|
events,
|
||||||
halfday,
|
halfday,
|
||||||
dayattributes,
|
dayattributes,
|
||||||
context.is_work_saturday(),
|
is_work_saturday(context),
|
||||||
pad_width=pad_width,
|
pad_width=pad_width,
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
@ -28,12 +28,16 @@
|
|||||||
"""Pages HTML gestion absences
|
"""Pages HTML gestion absences
|
||||||
(la plupart portées du DTML)
|
(la plupart portées du DTML)
|
||||||
"""
|
"""
|
||||||
|
import datetime
|
||||||
|
|
||||||
from stripogram import html2text, html2safehtml
|
from stripogram import html2text, html2safehtml
|
||||||
|
|
||||||
from gen_tables import GenTable
|
from gen_tables import GenTable
|
||||||
|
|
||||||
from notesdb import *
|
from notesdb import DateISOtoDMY
|
||||||
from sco_utils import *
|
import sco_utils as scu
|
||||||
|
from sco_exceptions import ScoValueError
|
||||||
|
from sco_permissions import ScoAbsChange
|
||||||
from notes_log import log
|
from notes_log import log
|
||||||
import sco_groups
|
import sco_groups
|
||||||
import sco_find_etud
|
import sco_find_etud
|
||||||
@ -58,7 +62,7 @@ def doSignaleAbsence(
|
|||||||
etudid = etud["etudid"]
|
etudid = etud["etudid"]
|
||||||
|
|
||||||
description_abs = description
|
description_abs = description
|
||||||
dates = context.DateRangeISO(datedebut, datefin)
|
dates = sco_abs.DateRangeISO(context, datedebut, datefin)
|
||||||
nbadded = 0
|
nbadded = 0
|
||||||
for jour in dates:
|
for jour in dates:
|
||||||
if demijournee == "2":
|
if demijournee == "2":
|
||||||
@ -248,7 +252,7 @@ def doJustifAbsence(
|
|||||||
etud = context.getEtudInfo(filled=1, REQUEST=REQUEST)[0]
|
etud = context.getEtudInfo(filled=1, REQUEST=REQUEST)[0]
|
||||||
etudid = etud["etudid"]
|
etudid = etud["etudid"]
|
||||||
description_abs = description
|
description_abs = description
|
||||||
dates = context.DateRangeISO(datedebut, datefin)
|
dates = sco_abs.DateRangeISO(context, datedebut, datefin)
|
||||||
nbadded = 0
|
nbadded = 0
|
||||||
for jour in dates:
|
for jour in dates:
|
||||||
if demijournee == "2":
|
if demijournee == "2":
|
||||||
@ -371,7 +375,7 @@ def doAnnuleAbsence(
|
|||||||
etud = context.getEtudInfo(filled=1, REQUEST=REQUEST)[0]
|
etud = context.getEtudInfo(filled=1, REQUEST=REQUEST)[0]
|
||||||
etudid = etud["etudid"]
|
etudid = etud["etudid"]
|
||||||
|
|
||||||
dates = context.DateRangeISO(datedebut, datefin)
|
dates = sco_abs.DateRangeISO(context, datedebut, datefin)
|
||||||
nbadded = 0
|
nbadded = 0
|
||||||
for jour in dates:
|
for jour in dates:
|
||||||
if demijournee == "2":
|
if demijournee == "2":
|
||||||
@ -506,7 +510,7 @@ def doAnnuleJustif(
|
|||||||
"""Annulation d'une justification"""
|
"""Annulation d'une justification"""
|
||||||
etud = context.getEtudInfo(filled=1, REQUEST=REQUEST)[0]
|
etud = context.getEtudInfo(filled=1, REQUEST=REQUEST)[0]
|
||||||
etudid = etud["etudid"]
|
etudid = etud["etudid"]
|
||||||
dates = context.DateRangeISO(datedebut0, datefin0)
|
dates = sco_abs.DateRangeISO(context, datedebut0, datefin0)
|
||||||
nbadded = 0
|
nbadded = 0
|
||||||
for jour in dates:
|
for jour in dates:
|
||||||
# Attention: supprime matin et après-midi
|
# Attention: supprime matin et après-midi
|
||||||
@ -571,7 +575,7 @@ def EtatAbsences(context, REQUEST=None):
|
|||||||
|
|
||||||
</td></tr></table>
|
</td></tr></table>
|
||||||
</form>"""
|
</form>"""
|
||||||
% (AnneeScolaire(REQUEST), datetime.datetime.now().strftime("%d/%m/%Y")),
|
% (scu.AnneeScolaire(REQUEST), datetime.datetime.now().strftime("%d/%m/%Y")),
|
||||||
context.sco_footer(REQUEST),
|
context.sco_footer(REQUEST),
|
||||||
]
|
]
|
||||||
return "\n".join(H)
|
return "\n".join(H)
|
||||||
@ -610,7 +614,7 @@ def CalAbs(context, REQUEST=None): # etud implied
|
|||||||
# crude portage from 1999 DTML
|
# crude portage from 1999 DTML
|
||||||
etud = context.getEtudInfo(filled=1, REQUEST=REQUEST)[0]
|
etud = context.getEtudInfo(filled=1, REQUEST=REQUEST)[0]
|
||||||
etudid = etud["etudid"]
|
etudid = etud["etudid"]
|
||||||
anneescolaire = int(AnneeScolaire(REQUEST))
|
anneescolaire = int(scu.AnneeScolaire(REQUEST))
|
||||||
datedebut = str(anneescolaire) + "-08-31"
|
datedebut = str(anneescolaire) + "-08-31"
|
||||||
datefin = str(anneescolaire + 1) + "-07-31"
|
datefin = str(anneescolaire + 1) + "-07-31"
|
||||||
nbabs = context.CountAbs(etudid=etudid, debut=datedebut, fin=datefin)
|
nbabs = context.CountAbs(etudid=etudid, debut=datedebut, fin=datefin)
|
||||||
@ -693,7 +697,7 @@ def ListeAbsEtud(
|
|||||||
En format 'text': texte avec liste d'absences (pour mails).
|
En format 'text': texte avec liste d'absences (pour mails).
|
||||||
"""
|
"""
|
||||||
absjust_only = int(absjust_only) # si vrai, table absjust seule (export xls ou pdf)
|
absjust_only = int(absjust_only) # si vrai, table absjust seule (export xls ou pdf)
|
||||||
datedebut = "%s-08-31" % AnneeScolaire(REQUEST)
|
datedebut = "%s-08-31" % scu.AnneeScolaire(REQUEST)
|
||||||
|
|
||||||
etud = context.getEtudInfo(etudid=etudid, filled=True)[0]
|
etud = context.getEtudInfo(etudid=etudid, filled=True)[0]
|
||||||
|
|
||||||
@ -714,7 +718,7 @@ def ListeAbsEtud(
|
|||||||
html_class="table_leftalign",
|
html_class="table_leftalign",
|
||||||
table_id="tab_absnonjust",
|
table_id="tab_absnonjust",
|
||||||
base_url=base_url_nj,
|
base_url=base_url_nj,
|
||||||
filename="abs_" + make_filename(etud["nomprenom"]),
|
filename="abs_" + scu.make_filename(etud["nomprenom"]),
|
||||||
caption="Absences non justifiées de %(nomprenom)s" % etud,
|
caption="Absences non justifiées de %(nomprenom)s" % etud,
|
||||||
preferences=context.get_preferences(),
|
preferences=context.get_preferences(),
|
||||||
)
|
)
|
||||||
@ -725,7 +729,7 @@ def ListeAbsEtud(
|
|||||||
html_class="table_leftalign",
|
html_class="table_leftalign",
|
||||||
table_id="tab_absjust",
|
table_id="tab_absjust",
|
||||||
base_url=base_url_j,
|
base_url=base_url_j,
|
||||||
filename="absjust_" + make_filename(etud["nomprenom"]),
|
filename="absjust_" + scu.make_filename(etud["nomprenom"]),
|
||||||
caption="Absences justifiées de %(nomprenom)s" % etud,
|
caption="Absences justifiées de %(nomprenom)s" % etud,
|
||||||
preferences=context.get_preferences(),
|
preferences=context.get_preferences(),
|
||||||
)
|
)
|
||||||
@ -830,7 +834,7 @@ def absences_index_html(context, REQUEST=None):
|
|||||||
% REQUEST.URL0,
|
% REQUEST.URL0,
|
||||||
formChoixSemestreGroupe(context),
|
formChoixSemestreGroupe(context),
|
||||||
"</p>",
|
"</p>",
|
||||||
context.CalSelectWeek(REQUEST=REQUEST),
|
cal_select_week(context, REQUEST=REQUEST),
|
||||||
"""<p class="help">Sélectionner le groupe d'étudiants, puis cliquez sur une semaine pour
|
"""<p class="help">Sélectionner le groupe d'étudiants, puis cliquez sur une semaine pour
|
||||||
saisir les absences de toute cette semaine.</p>
|
saisir les absences de toute cette semaine.</p>
|
||||||
</form>""",
|
</form>""",
|
||||||
@ -843,3 +847,16 @@ saisir les absences de toute cette semaine.</p>
|
|||||||
|
|
||||||
H.append(context.sco_footer(REQUEST))
|
H.append(context.sco_footer(REQUEST))
|
||||||
return "\n".join(H)
|
return "\n".join(H)
|
||||||
|
|
||||||
|
|
||||||
|
def cal_select_week(context, year=None, REQUEST=None):
|
||||||
|
"display calendar allowing week selection"
|
||||||
|
if not year:
|
||||||
|
year = scu.AnneeScolaire(REQUEST)
|
||||||
|
sems = sco_formsemestre.do_formsemestre_list(context)
|
||||||
|
if not sems:
|
||||||
|
js = ""
|
||||||
|
else:
|
||||||
|
js = 'onmouseover="highlightweek(this);" onmouseout="deselectweeks();" onclick="wclick(this);"'
|
||||||
|
C = sco_abs.YearTable(context, int(year), dayattributes=js)
|
||||||
|
return C
|
||||||
|
326
sco_entreprises.py
Normal file
326
sco_entreprises.py
Normal file
@ -0,0 +1,326 @@
|
|||||||
|
# -*- mode: python -*-
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
|
||||||
|
##############################################################################
|
||||||
|
#
|
||||||
|
# Gestion scolarite IUT
|
||||||
|
#
|
||||||
|
# Copyright (c) 1999 - 2021 Emmanuel Viennet. All rights reserved.
|
||||||
|
#
|
||||||
|
# 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
|
||||||
|
#
|
||||||
|
##############################################################################
|
||||||
|
|
||||||
|
"""Fonctions sur les entreprises
|
||||||
|
"""
|
||||||
|
# codes anciens déplacés de ZEntreprise
|
||||||
|
import datetime
|
||||||
|
|
||||||
|
import sco_utils as scu
|
||||||
|
from notesdb import ScoDocCursor, EditableTable, DateISOtoDMY, DateDMYtoISO
|
||||||
|
|
||||||
|
|
||||||
|
def _format_nom(nom):
|
||||||
|
"formatte nom (filtre en entree db) d'une entreprise"
|
||||||
|
if not nom:
|
||||||
|
return nom
|
||||||
|
nom = nom.decode(scu.SCO_ENCODING)
|
||||||
|
return (nom[0].upper() + nom[1:]).encode(scu.SCO_ENCODING)
|
||||||
|
|
||||||
|
|
||||||
|
class EntreprisesEditor(EditableTable):
|
||||||
|
def delete(self, cnx, oid):
|
||||||
|
"delete correspondants and contacts, then self"
|
||||||
|
# first, delete all correspondants and contacts
|
||||||
|
cursor = cnx.cursor(cursor_factory=ScoDocCursor)
|
||||||
|
cursor.execute(
|
||||||
|
"delete from entreprise_contact where entreprise_id=%(entreprise_id)s",
|
||||||
|
{"entreprise_id": oid},
|
||||||
|
)
|
||||||
|
cursor.execute(
|
||||||
|
"delete from entreprise_correspondant where entreprise_id=%(entreprise_id)s",
|
||||||
|
{"entreprise_id": oid},
|
||||||
|
)
|
||||||
|
cnx.commit()
|
||||||
|
EditableTable.delete(self, cnx, oid)
|
||||||
|
|
||||||
|
def list(
|
||||||
|
self,
|
||||||
|
cnx,
|
||||||
|
args={},
|
||||||
|
operator="and",
|
||||||
|
test="=",
|
||||||
|
sortkey=None,
|
||||||
|
sort_on_contact=False,
|
||||||
|
context=None,
|
||||||
|
limit="",
|
||||||
|
offset="",
|
||||||
|
):
|
||||||
|
# list, then sort on date of last contact
|
||||||
|
R = EditableTable.list(
|
||||||
|
self,
|
||||||
|
cnx,
|
||||||
|
args=args,
|
||||||
|
operator=operator,
|
||||||
|
test=test,
|
||||||
|
sortkey=sortkey,
|
||||||
|
limit=limit,
|
||||||
|
offset=offset,
|
||||||
|
)
|
||||||
|
if sort_on_contact:
|
||||||
|
for r in R:
|
||||||
|
c = do_entreprise_contact_list(
|
||||||
|
context,
|
||||||
|
args={"entreprise_id": r["entreprise_id"]},
|
||||||
|
disable_formatting=True,
|
||||||
|
)
|
||||||
|
if c:
|
||||||
|
r["date"] = max([x["date"] or datetime.date.min for x in c])
|
||||||
|
else:
|
||||||
|
r["date"] = datetime.date.min
|
||||||
|
# sort
|
||||||
|
R.sort(lambda r1, r2: cmp(r2["date"], r1["date"]))
|
||||||
|
for r in R:
|
||||||
|
r["date"] = DateISOtoDMY(r["date"])
|
||||||
|
return R
|
||||||
|
|
||||||
|
def list_by_etud(
|
||||||
|
self, cnx, args={}, sort_on_contact=False, disable_formatting=False
|
||||||
|
):
|
||||||
|
"cherche rentreprise ayant eu contact avec etudiant"
|
||||||
|
cursor = cnx.cursor(cursor_factory=ScoDocCursor)
|
||||||
|
cursor.execute(
|
||||||
|
"select E.*, I.nom as etud_nom, I.prenom as etud_prenom, C.date from entreprises E, entreprise_contact C, identite I where C.entreprise_id = E.entreprise_id and C.etudid = I.etudid and I.nom ~* %(etud_nom)s ORDER BY E.nom",
|
||||||
|
args,
|
||||||
|
)
|
||||||
|
_, res = [x[0] for x in cursor.description], cursor.dictfetchall()
|
||||||
|
R = []
|
||||||
|
for r in res:
|
||||||
|
r["etud_prenom"] = r["etud_prenom"] or ""
|
||||||
|
d = {}
|
||||||
|
for key in r:
|
||||||
|
v = r[key]
|
||||||
|
# format value
|
||||||
|
if not disable_formatting and self.output_formators.has_key(key):
|
||||||
|
v = self.output_formators[key](v)
|
||||||
|
d[key] = v
|
||||||
|
R.append(d)
|
||||||
|
# sort
|
||||||
|
if sort_on_contact:
|
||||||
|
R.sort(
|
||||||
|
lambda r1, r2: cmp(
|
||||||
|
r2["date"] or datetime.date.min, r1["date"] or datetime.date.min
|
||||||
|
)
|
||||||
|
)
|
||||||
|
for r in R:
|
||||||
|
r["date"] = DateISOtoDMY(r["date"] or datetime.date.min)
|
||||||
|
return R
|
||||||
|
|
||||||
|
|
||||||
|
_entreprisesEditor = EntreprisesEditor(
|
||||||
|
"entreprises",
|
||||||
|
"entreprise_id",
|
||||||
|
(
|
||||||
|
"entreprise_id",
|
||||||
|
"nom",
|
||||||
|
"adresse",
|
||||||
|
"ville",
|
||||||
|
"codepostal",
|
||||||
|
"pays",
|
||||||
|
"contact_origine",
|
||||||
|
"secteur",
|
||||||
|
"privee",
|
||||||
|
"localisation",
|
||||||
|
"qualite_relation",
|
||||||
|
"plus10salaries",
|
||||||
|
"note",
|
||||||
|
"date_creation",
|
||||||
|
),
|
||||||
|
sortkey="nom",
|
||||||
|
input_formators={"nom": _format_nom},
|
||||||
|
)
|
||||||
|
|
||||||
|
# ----------- Correspondants
|
||||||
|
_entreprise_correspEditor = EditableTable(
|
||||||
|
"entreprise_correspondant",
|
||||||
|
"entreprise_corresp_id",
|
||||||
|
(
|
||||||
|
"entreprise_corresp_id",
|
||||||
|
"entreprise_id",
|
||||||
|
"civilite",
|
||||||
|
"nom",
|
||||||
|
"prenom",
|
||||||
|
"fonction",
|
||||||
|
"phone1",
|
||||||
|
"phone2",
|
||||||
|
"mobile",
|
||||||
|
"fax",
|
||||||
|
"mail1",
|
||||||
|
"mail2",
|
||||||
|
"note",
|
||||||
|
),
|
||||||
|
sortkey="nom",
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
# ----------- Contacts
|
||||||
|
_entreprise_contactEditor = EditableTable(
|
||||||
|
"entreprise_contact",
|
||||||
|
"entreprise_contact_id",
|
||||||
|
(
|
||||||
|
"entreprise_contact_id",
|
||||||
|
"date",
|
||||||
|
"type_contact",
|
||||||
|
"entreprise_id",
|
||||||
|
"entreprise_corresp_id",
|
||||||
|
"etudid",
|
||||||
|
"description",
|
||||||
|
"enseignant",
|
||||||
|
),
|
||||||
|
sortkey="date",
|
||||||
|
output_formators={"date": DateISOtoDMY},
|
||||||
|
input_formators={"date": DateDMYtoISO},
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def do_entreprise_create(context, args):
|
||||||
|
"entreprise_create"
|
||||||
|
cnx = context.GetDBConnexion()
|
||||||
|
r = _entreprisesEditor.create(cnx, args)
|
||||||
|
return r
|
||||||
|
|
||||||
|
|
||||||
|
def do_entreprise_delete(context, oid):
|
||||||
|
"entreprise_delete"
|
||||||
|
cnx = context.GetDBConnexion()
|
||||||
|
_entreprisesEditor.delete(cnx, oid)
|
||||||
|
|
||||||
|
|
||||||
|
def do_entreprise_list(context, **kw):
|
||||||
|
"entreprise_list"
|
||||||
|
cnx = context.GetDBConnexion()
|
||||||
|
kw["context"] = context
|
||||||
|
return _entreprisesEditor.list(cnx, **kw)
|
||||||
|
|
||||||
|
|
||||||
|
def do_entreprise_list_by_etud(context, **kw):
|
||||||
|
"entreprise_list_by_etud"
|
||||||
|
cnx = context.GetDBConnexion()
|
||||||
|
return _entreprisesEditor.list_by_etud(cnx, **kw)
|
||||||
|
|
||||||
|
|
||||||
|
def do_entreprise_edit(context, *args, **kw):
|
||||||
|
"entreprise_edit"
|
||||||
|
cnx = context.GetDBConnexion()
|
||||||
|
_entreprisesEditor.edit(cnx, *args, **kw)
|
||||||
|
|
||||||
|
|
||||||
|
def do_entreprise_correspondant_create(context, args):
|
||||||
|
"entreprise_correspondant_create"
|
||||||
|
cnx = context.GetDBConnexion()
|
||||||
|
r = _entreprise_correspEditor.create(cnx, args)
|
||||||
|
return r
|
||||||
|
|
||||||
|
|
||||||
|
def do_entreprise_correspondant_delete(context, oid):
|
||||||
|
"entreprise_correspondant_delete"
|
||||||
|
cnx = context.GetDBConnexion()
|
||||||
|
_entreprise_correspEditor.delete(cnx, oid)
|
||||||
|
|
||||||
|
|
||||||
|
def do_entreprise_correspondant_list(context, **kw):
|
||||||
|
"entreprise_correspondant_list"
|
||||||
|
cnx = context.GetDBConnexion()
|
||||||
|
return _entreprise_correspEditor.list(cnx, **kw)
|
||||||
|
|
||||||
|
|
||||||
|
def do_entreprise_correspondant_edit(context, *args, **kw):
|
||||||
|
"entreprise_correspondant_edit"
|
||||||
|
cnx = context.GetDBConnexion()
|
||||||
|
_entreprise_correspEditor.edit(cnx, *args, **kw)
|
||||||
|
|
||||||
|
|
||||||
|
def do_entreprise_correspondant_listnames(context, args={}):
|
||||||
|
"-> liste des noms des correspondants (pour affichage menu)"
|
||||||
|
C = do_entreprise_correspondant_list(context, args=args)
|
||||||
|
return [(x["prenom"] + " " + x["nom"], str(x["entreprise_corresp_id"])) for x in C]
|
||||||
|
|
||||||
|
|
||||||
|
def do_entreprise_contact_delete(context, oid):
|
||||||
|
"entreprise_contact_delete"
|
||||||
|
cnx = context.GetDBConnexion()
|
||||||
|
_entreprise_contactEditor.delete(cnx, oid)
|
||||||
|
|
||||||
|
|
||||||
|
def do_entreprise_contact_list(context, **kw):
|
||||||
|
"entreprise_contact_list"
|
||||||
|
cnx = context.GetDBConnexion()
|
||||||
|
return _entreprise_contactEditor.list(cnx, **kw)
|
||||||
|
|
||||||
|
|
||||||
|
def do_entreprise_contact_edit(context, *args, **kw):
|
||||||
|
"entreprise_contact_edit"
|
||||||
|
cnx = context.GetDBConnexion()
|
||||||
|
_entreprise_contactEditor.edit(cnx, *args, **kw)
|
||||||
|
|
||||||
|
|
||||||
|
def do_entreprise_contact_create(context, args):
|
||||||
|
"entreprise_contact_create"
|
||||||
|
cnx = context.GetDBConnexion()
|
||||||
|
r = _entreprise_contactEditor.create(cnx, args)
|
||||||
|
return r
|
||||||
|
|
||||||
|
|
||||||
|
def do_entreprise_check_etudiant(context, etudiant):
|
||||||
|
"""Si etudiant est vide, ou un ETUDID valide, ou un nom unique,
|
||||||
|
retourne (1, ETUDID).
|
||||||
|
Sinon, retourne (0, 'message explicatif')
|
||||||
|
"""
|
||||||
|
etudiant = etudiant.strip().translate(
|
||||||
|
None, "'()"
|
||||||
|
) # suppress parens and quote from name
|
||||||
|
if not etudiant:
|
||||||
|
return 1, None
|
||||||
|
cnx = context.GetDBConnexion()
|
||||||
|
cursor = cnx.cursor(cursor_factory=ScoDocCursor)
|
||||||
|
cursor.execute(
|
||||||
|
"select etudid, nom, prenom from identite where upper(nom) ~ upper(%(etudiant)s) or etudid=%(etudiant)s",
|
||||||
|
{"etudiant": etudiant},
|
||||||
|
)
|
||||||
|
r = cursor.fetchall()
|
||||||
|
if len(r) < 1:
|
||||||
|
return 0, 'Aucun etudiant ne correspond à "%s"' % etudiant
|
||||||
|
elif len(r) > 10:
|
||||||
|
return (
|
||||||
|
0,
|
||||||
|
"<b>%d etudiants</b> correspondent à ce nom (utilisez le code)" % len(r),
|
||||||
|
)
|
||||||
|
elif len(r) > 1:
|
||||||
|
e = ['<ul class="entreprise_etud_list">']
|
||||||
|
for x in r:
|
||||||
|
e.append(
|
||||||
|
"<li>%s %s (code %s)</li>"
|
||||||
|
% (scu.strupper(x[1]), x[2] or "", x[0].strip())
|
||||||
|
)
|
||||||
|
e.append("</ul>")
|
||||||
|
return (
|
||||||
|
0,
|
||||||
|
"Les étudiants suivants correspondent: préciser le nom complet ou le code\n"
|
||||||
|
+ "\n".join(e),
|
||||||
|
)
|
||||||
|
else: # une seule reponse !
|
||||||
|
return 1, r[0][0].strip()
|
@ -30,8 +30,16 @@
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
# Re-ecriture en 2014 (re-organisation de l'interface, modernisation du code)
|
# Re-ecriture en 2014 (re-organisation de l'interface, modernisation du code)
|
||||||
|
import datetime
|
||||||
|
import cgi
|
||||||
|
import urllib
|
||||||
|
import time
|
||||||
|
import collections
|
||||||
|
import operator
|
||||||
|
|
||||||
from sco_utils import *
|
import sco_utils as scu
|
||||||
|
from sco_permissions import ScoEtudInscrit, ScoEtudAddAnnotations, ScoAbsChange
|
||||||
|
from sco_exceptions import ScoValueError
|
||||||
import html_sco_header
|
import html_sco_header
|
||||||
from gen_tables import GenTable
|
from gen_tables import GenTable
|
||||||
import scolars
|
import scolars
|
||||||
@ -441,8 +449,6 @@ def groups_table(
|
|||||||
# "enter groups_table %s: %s"
|
# "enter groups_table %s: %s"
|
||||||
# % (groups_infos.members[0]["nom"], groups_infos.members[0].get("etape", "-"))
|
# % (groups_infos.members[0]["nom"], groups_infos.members[0].get("etape", "-"))
|
||||||
# )
|
# )
|
||||||
authuser = REQUEST.AUTHENTICATED_USER
|
|
||||||
|
|
||||||
with_codes = int(with_codes)
|
with_codes = int(with_codes)
|
||||||
with_paiement = int(with_paiement)
|
with_paiement = int(with_paiement)
|
||||||
with_archives = int(with_archives)
|
with_archives = int(with_archives)
|
||||||
@ -891,7 +897,7 @@ def form_choix_jour_saisie_hebdo(
|
|||||||
FA.append("""<select name="datedebut">""")
|
FA.append("""<select name="datedebut">""")
|
||||||
date = first_monday
|
date = first_monday
|
||||||
i = 0
|
i = 0
|
||||||
for jour in context.Absences.day_names():
|
for jour in sco_abs.day_names(context):
|
||||||
if i == today_idx:
|
if i == today_idx:
|
||||||
sel = "selected"
|
sel = "selected"
|
||||||
else:
|
else:
|
||||||
@ -910,7 +916,6 @@ def form_choix_saisie_semaine(context, groups_infos, REQUEST=None):
|
|||||||
authuser = REQUEST.AUTHENTICATED_USER
|
authuser = REQUEST.AUTHENTICATED_USER
|
||||||
if not authuser.has_permission(ScoAbsChange, context):
|
if not authuser.has_permission(ScoAbsChange, context):
|
||||||
return ""
|
return ""
|
||||||
sem = groups_infos.formsemestre
|
|
||||||
# construit l'URL "destination"
|
# construit l'URL "destination"
|
||||||
# (a laquelle on revient apres saisie absences)
|
# (a laquelle on revient apres saisie absences)
|
||||||
query_args = cgi.parse_qs(REQUEST.QUERY_STRING)
|
query_args = cgi.parse_qs(REQUEST.QUERY_STRING)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user