2020-09-26 16:19:37 +02:00
|
|
|
# -*- mode: python -*-
|
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
|
|
|
##############################################################################
|
|
|
|
#
|
|
|
|
# Gestion scolarite IUT
|
|
|
|
#
|
2023-12-31 23:04:06 +01:00
|
|
|
# Copyright (c) 1999 - 2024 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
|
|
|
|
#
|
|
|
|
##############################################################################
|
|
|
|
|
|
|
|
"""Photos: trombinoscopes - Version IUT Tours
|
|
|
|
Code contribué par Jérôme Billoue, IUT de Tours, 2014
|
|
|
|
Modification Jérome Billoue,Vincent Grimaud, IUT de Tours, 2017
|
|
|
|
"""
|
|
|
|
|
2021-07-26 18:11:00 +03:00
|
|
|
import io
|
2021-06-19 23:21:37 +02:00
|
|
|
|
2020-09-26 16:19:37 +02:00
|
|
|
from reportlab.lib import colors
|
2022-03-24 09:59:44 +01:00
|
|
|
from reportlab.lib.colors import black
|
2020-09-26 16:19:37 +02:00
|
|
|
from reportlab.lib.pagesizes import A4, A3
|
2022-03-24 09:59:44 +01:00
|
|
|
from reportlab.lib import styles
|
|
|
|
from reportlab.lib.pagesizes import landscape
|
|
|
|
from reportlab.lib.units import cm
|
|
|
|
from reportlab.platypus import KeepInFrame, Paragraph, Table, TableStyle
|
|
|
|
from reportlab.platypus.doctemplate import BaseDocTemplate
|
2020-09-26 16:19:37 +02:00
|
|
|
|
2023-08-27 21:49:50 +02:00
|
|
|
from app.scodoc import sco_cal
|
2022-03-24 09:59:44 +01:00
|
|
|
from app.scodoc import sco_etud
|
|
|
|
from app.scodoc.sco_exceptions import ScoPDFFormatError
|
2021-06-19 23:21:37 +02:00
|
|
|
from app.scodoc import sco_groups
|
|
|
|
from app.scodoc import sco_groups_view
|
|
|
|
from app.scodoc import sco_preferences
|
|
|
|
from app.scodoc import sco_trombino
|
2022-03-24 09:59:44 +01:00
|
|
|
import app.scodoc.sco_utils as scu
|
|
|
|
from app.scodoc.sco_pdf import SU, ScoDocPageTemplate
|
2020-09-26 16:19:37 +02:00
|
|
|
|
|
|
|
# Paramétrage de l'aspect graphique:
|
|
|
|
PHOTOWIDTH = 2.8 * cm
|
|
|
|
COLWIDTH = 3.4 * cm
|
|
|
|
N_PER_ROW = 5
|
|
|
|
|
|
|
|
|
|
|
|
def pdf_trombino_tours(
|
2022-03-24 09:59:44 +01:00
|
|
|
group_ids=(), # liste des groupes à afficher
|
2020-09-26 16:19:37 +02:00
|
|
|
formsemestre_id=None, # utilisé si pas de groupes selectionné
|
|
|
|
):
|
2021-01-01 18:40:47 +01:00
|
|
|
"""Generation du trombinoscope en fichier PDF"""
|
2020-09-26 16:19:37 +02:00
|
|
|
# Informations sur les groupes à afficher:
|
|
|
|
groups_infos = sco_groups_view.DisplayedGroupsInfos(
|
2021-09-08 00:34:45 +02:00
|
|
|
group_ids, formsemestre_id=formsemestre_id
|
2020-09-26 16:19:37 +02:00
|
|
|
)
|
|
|
|
|
2021-07-28 18:03:54 +03:00
|
|
|
DeptName = sco_preferences.get_preference("DeptName")
|
|
|
|
DeptFullName = sco_preferences.get_preference("DeptFullName")
|
|
|
|
InstituteName = sco_preferences.get_preference("InstituteName")
|
2020-09-26 16:19:37 +02:00
|
|
|
# Generate PDF page
|
|
|
|
StyleSheet = styles.getSampleStyleSheet()
|
|
|
|
objects = []
|
|
|
|
T = Table(
|
|
|
|
[
|
|
|
|
[Paragraph(SU(InstituteName), StyleSheet["Heading3"])],
|
2022-03-18 19:33:07 +01:00
|
|
|
[
|
|
|
|
Paragraph(
|
|
|
|
SU("Département " + DeptFullName or "(?)"), StyleSheet["Heading3"]
|
|
|
|
)
|
|
|
|
],
|
2020-09-26 16:19:37 +02:00
|
|
|
[
|
|
|
|
Paragraph(
|
|
|
|
SU("Date ............ / ............ / ......................"),
|
|
|
|
StyleSheet["Normal"],
|
|
|
|
),
|
|
|
|
Paragraph(
|
|
|
|
SU(
|
|
|
|
"Module ......................................................."
|
|
|
|
),
|
|
|
|
StyleSheet["Normal"],
|
|
|
|
),
|
|
|
|
],
|
|
|
|
[
|
|
|
|
Paragraph(
|
|
|
|
SU("de ............h............ à ............h............ "),
|
|
|
|
StyleSheet["Normal"],
|
|
|
|
),
|
|
|
|
Paragraph(
|
|
|
|
SU("Enseignant ................................................."),
|
|
|
|
StyleSheet["Normal"],
|
|
|
|
),
|
|
|
|
],
|
|
|
|
[
|
|
|
|
Table(
|
|
|
|
[
|
|
|
|
[
|
|
|
|
"Séance notée :",
|
|
|
|
" ",
|
|
|
|
"DS ",
|
|
|
|
" ",
|
|
|
|
"TP Contrôle ",
|
|
|
|
" ",
|
|
|
|
"Autre cas (TD ou TP noté, QCM, etc...)",
|
|
|
|
]
|
|
|
|
],
|
|
|
|
style=TableStyle(
|
|
|
|
[
|
|
|
|
("ALIGN", (0, 0), (-1, -1), "LEFT"),
|
|
|
|
("BOX", (1, 0), (1, 0), 0.75, black),
|
|
|
|
("BOX", (3, 0), (3, 0), 0.75, black),
|
|
|
|
("BOX", (5, 0), (5, 0), 0.75, black),
|
|
|
|
]
|
|
|
|
),
|
|
|
|
)
|
|
|
|
],
|
|
|
|
],
|
|
|
|
colWidths=(COLWIDTH * N_PER_ROW) / 2,
|
|
|
|
style=TableStyle(
|
|
|
|
[
|
|
|
|
("ALIGN", (0, 0), (-1, -1), "LEFT"),
|
|
|
|
("SPAN", (0, 1), (1, 1)),
|
|
|
|
("SPAN", (0, 4), (1, 4)),
|
|
|
|
("BOTTOMPADDING", (0, -1), (-1, -1), 10),
|
|
|
|
("BOX", (0, 0), (-1, -1), 0.75, black),
|
|
|
|
]
|
|
|
|
),
|
|
|
|
)
|
|
|
|
|
|
|
|
objects.append(T)
|
|
|
|
|
|
|
|
groups = ""
|
|
|
|
|
|
|
|
for group_id in groups_infos.group_ids:
|
|
|
|
if group_id != "None":
|
2022-09-30 22:43:39 +02:00
|
|
|
members, _, group_tit, sem, _ = sco_groups.get_group_infos(
|
|
|
|
group_id, scu.INSCRIT
|
|
|
|
)
|
2020-09-26 16:19:37 +02:00
|
|
|
groups += " %s" % group_tit
|
|
|
|
L = []
|
|
|
|
currow = []
|
|
|
|
|
|
|
|
if sem["semestre_id"] != -1:
|
|
|
|
currow = [
|
|
|
|
Paragraph(
|
|
|
|
SU(
|
|
|
|
"<para align=center>Semestre %s</para>" % sem["semestre_id"]
|
|
|
|
),
|
|
|
|
StyleSheet["Normal"],
|
|
|
|
)
|
|
|
|
]
|
|
|
|
currow += [" "] * (N_PER_ROW - len(currow) - 1)
|
|
|
|
currow += [
|
|
|
|
Paragraph(
|
|
|
|
SU("<para align=center>%s</para>" % sem["anneescolaire"]),
|
|
|
|
StyleSheet["Normal"],
|
|
|
|
)
|
|
|
|
]
|
|
|
|
L.append(currow)
|
|
|
|
currow = [" "] * N_PER_ROW
|
|
|
|
L.append(currow)
|
|
|
|
|
|
|
|
currow = []
|
|
|
|
currow.append(
|
|
|
|
Paragraph(
|
|
|
|
SU("<para align=center><b>" + group_tit + "</b></para>"),
|
|
|
|
StyleSheet["Heading3"],
|
|
|
|
)
|
|
|
|
)
|
|
|
|
n = 1
|
|
|
|
for m in members:
|
2021-08-21 00:24:51 +02:00
|
|
|
img = sco_trombino._get_etud_platypus_image(m, image_width=PHOTOWIDTH)
|
2022-03-27 10:05:12 +02:00
|
|
|
etud_main_group = sco_groups.get_etud_main_group(
|
|
|
|
m["etudid"], sem["formsemestre_id"]
|
|
|
|
)
|
2020-09-26 16:19:37 +02:00
|
|
|
if group_id != etud_main_group["group_id"]:
|
|
|
|
text_group = " (" + etud_main_group["group_name"] + ")"
|
|
|
|
else:
|
|
|
|
text_group = ""
|
|
|
|
elem = Table(
|
|
|
|
[
|
|
|
|
[img],
|
|
|
|
[
|
|
|
|
Paragraph(
|
|
|
|
SU(
|
|
|
|
"<para align=center><font size=8>"
|
2023-11-22 23:31:16 +01:00
|
|
|
+ scu.format_prenom(m["prenom"])
|
2020-09-26 16:19:37 +02:00
|
|
|
+ " "
|
2023-11-22 23:31:16 +01:00
|
|
|
+ scu.format_nom(m["nom"])
|
2020-09-26 16:19:37 +02:00
|
|
|
+ text_group
|
|
|
|
+ "</font></para>"
|
|
|
|
),
|
|
|
|
StyleSheet["Normal"],
|
|
|
|
)
|
|
|
|
],
|
|
|
|
],
|
|
|
|
colWidths=[COLWIDTH],
|
|
|
|
style=TableStyle([("ALIGN", (0, 0), (-1, -1), "CENTER")]),
|
|
|
|
)
|
|
|
|
currow.append(elem)
|
|
|
|
if n == (N_PER_ROW - 1):
|
|
|
|
L.append(currow)
|
|
|
|
currow = []
|
|
|
|
n = (n + 1) % N_PER_ROW
|
|
|
|
if currow:
|
|
|
|
currow += [" "] * (N_PER_ROW - len(currow))
|
|
|
|
L.append(currow)
|
|
|
|
if not L:
|
|
|
|
T = Paragraph(SU("Aucune photo à exporter !"), StyleSheet["Normal"])
|
|
|
|
else:
|
|
|
|
T = Table(
|
|
|
|
L,
|
|
|
|
colWidths=[COLWIDTH] * N_PER_ROW,
|
|
|
|
style=TableStyle(
|
|
|
|
[
|
|
|
|
("LEFTPADDING", (0, 0), (-1, -1), 0),
|
|
|
|
("RIGHTPADDING", (0, 0), (-1, -1), 0),
|
|
|
|
("BOTTOMPADDING", (0, 0), (-1, -1), 0),
|
|
|
|
("TOPPADDING", (0, 1), (-1, -1), 0),
|
|
|
|
("TOPPADDING", (0, 0), (-1, 0), 10),
|
|
|
|
("LINEBELOW", (1, 0), (-2, 0), 0.75, black),
|
|
|
|
("VALIGN", (0, 0), (-1, 1), "MIDDLE"),
|
|
|
|
("VALIGN", (0, 2), (-1, -1), "TOP"),
|
|
|
|
("VALIGN", (0, 2), (0, 2), "MIDDLE"),
|
|
|
|
("SPAN", (0, 0), (0, 1)),
|
|
|
|
("SPAN", (-1, 0), (-1, 1)),
|
|
|
|
]
|
|
|
|
),
|
|
|
|
)
|
|
|
|
|
|
|
|
objects.append(T)
|
|
|
|
|
|
|
|
T = Table(
|
|
|
|
[
|
|
|
|
[
|
|
|
|
Paragraph(
|
|
|
|
SU(
|
|
|
|
"Nombre d'absents : ................. (Merci d'entourer les absents SVP)"
|
|
|
|
),
|
|
|
|
StyleSheet["Normal"],
|
|
|
|
)
|
|
|
|
]
|
|
|
|
],
|
|
|
|
colWidths=(COLWIDTH * N_PER_ROW),
|
|
|
|
style=TableStyle(
|
|
|
|
[
|
|
|
|
("ALIGN", (0, 0), (-1, -1), "CENTER"),
|
|
|
|
("BOTTOMPADDING", (0, -1), (-1, -1), 10),
|
|
|
|
("BOX", (0, 0), (-1, -1), 0.75, black),
|
|
|
|
]
|
|
|
|
),
|
|
|
|
)
|
|
|
|
|
|
|
|
objects.append(T)
|
|
|
|
|
|
|
|
# Réduit sur une page
|
|
|
|
objects = [KeepInFrame(0, 0, objects, mode="shrink")]
|
|
|
|
# Build document
|
2021-07-26 18:11:00 +03:00
|
|
|
report = io.BytesIO() # in-memory document, no disk file
|
2020-09-26 16:19:37 +02:00
|
|
|
filename = "trombino-%s-%s.pdf" % (DeptName, groups_infos.groups_filename)
|
|
|
|
document = BaseDocTemplate(report)
|
|
|
|
document.addPageTemplates(
|
2022-03-12 09:40:48 +01:00
|
|
|
ScoDocPageTemplate(
|
2021-06-13 19:12:20 +02:00
|
|
|
document,
|
2021-07-28 18:03:54 +03:00
|
|
|
preferences=sco_preferences.SemPreferences(),
|
2021-01-04 11:31:18 +01:00
|
|
|
)
|
2020-09-26 16:19:37 +02:00
|
|
|
)
|
2022-01-13 22:36:40 +01:00
|
|
|
try:
|
|
|
|
document.build(objects)
|
|
|
|
except (ValueError, KeyError) as exc:
|
|
|
|
raise ScoPDFFormatError(str(exc)) from exc
|
2020-09-26 16:19:37 +02:00
|
|
|
data = report.getvalue()
|
|
|
|
|
2021-09-21 15:53:33 +02:00
|
|
|
return scu.sendPDFFile(data, filename)
|
2020-09-26 16:19:37 +02:00
|
|
|
|
|
|
|
|
|
|
|
# Feuille d'absences en pdf avec photos:
|
|
|
|
|
|
|
|
|
|
|
|
def pdf_feuille_releve_absences(
|
2022-03-24 09:59:44 +01:00
|
|
|
group_ids=(), # liste des groupes à afficher
|
2020-09-26 16:19:37 +02:00
|
|
|
formsemestre_id=None, # utilisé si pas de groupes selectionné
|
|
|
|
):
|
2021-01-01 18:40:47 +01:00
|
|
|
"""Generation de la feuille d'absence en fichier PDF, avec photos"""
|
2020-09-26 16:19:37 +02:00
|
|
|
|
2021-07-28 18:03:54 +03:00
|
|
|
NB_CELL_AM = sco_preferences.get_preference("feuille_releve_abs_AM")
|
|
|
|
NB_CELL_PM = sco_preferences.get_preference("feuille_releve_abs_PM")
|
2022-03-24 09:59:44 +01:00
|
|
|
col_width = 0.85 * cm
|
2021-07-28 18:03:54 +03:00
|
|
|
if sco_preferences.get_preference("feuille_releve_abs_samedi"):
|
2023-08-27 21:49:50 +02:00
|
|
|
days = sco_cal.DAYNAMES[:6] # Lundi, ..., Samedi
|
2020-09-26 16:19:37 +02:00
|
|
|
else:
|
2023-08-27 21:49:50 +02:00
|
|
|
days = sco_cal.DAYNAMES[:5] # Lundi, ..., Vendredi
|
2020-09-26 16:19:37 +02:00
|
|
|
nb_days = len(days)
|
|
|
|
|
|
|
|
# Informations sur les groupes à afficher:
|
|
|
|
groups_infos = sco_groups_view.DisplayedGroupsInfos(
|
2021-09-08 00:34:45 +02:00
|
|
|
group_ids, formsemestre_id=formsemestre_id
|
2020-09-26 16:19:37 +02:00
|
|
|
)
|
|
|
|
|
2021-07-28 18:03:54 +03:00
|
|
|
DeptName = sco_preferences.get_preference("DeptName")
|
|
|
|
DeptFullName = sco_preferences.get_preference("DeptFullName")
|
|
|
|
InstituteName = sco_preferences.get_preference("InstituteName")
|
2020-09-26 16:19:37 +02:00
|
|
|
# Generate PDF page
|
|
|
|
StyleSheet = styles.getSampleStyleSheet()
|
|
|
|
objects = [
|
|
|
|
Table(
|
|
|
|
[
|
|
|
|
[
|
|
|
|
Paragraph(SU(InstituteName), StyleSheet["Heading3"]),
|
|
|
|
Paragraph(
|
|
|
|
SU(
|
|
|
|
"<para align=right>Semaine ..................................................................</para>"
|
|
|
|
),
|
|
|
|
StyleSheet["Normal"],
|
|
|
|
),
|
|
|
|
],
|
|
|
|
[
|
|
|
|
Paragraph(
|
2022-03-18 19:33:07 +01:00
|
|
|
SU("Département " + (DeptFullName or "(?)")),
|
|
|
|
StyleSheet["Heading3"],
|
2020-09-26 16:19:37 +02:00
|
|
|
),
|
|
|
|
"",
|
|
|
|
],
|
|
|
|
],
|
|
|
|
style=TableStyle(
|
|
|
|
[("SPAN", (0, 1), (1, 1)), ("BOTTOMPADDING", (0, -1), (-1, -1), 10)]
|
|
|
|
),
|
|
|
|
)
|
|
|
|
]
|
|
|
|
|
|
|
|
currow = [""] * (NB_CELL_AM + 1 + NB_CELL_PM + 1)
|
|
|
|
elem_day = Table(
|
|
|
|
[currow],
|
2022-03-24 09:59:44 +01:00
|
|
|
colWidths=([col_width] * (NB_CELL_AM + 1 + NB_CELL_PM + 1)),
|
2020-09-26 16:19:37 +02:00
|
|
|
style=TableStyle(
|
|
|
|
[
|
|
|
|
("GRID", (0, 0), (NB_CELL_AM - 1, 0), 0.25, black),
|
|
|
|
(
|
|
|
|
"GRID",
|
|
|
|
(NB_CELL_AM + 1, 0),
|
|
|
|
(NB_CELL_AM + NB_CELL_PM, 0),
|
|
|
|
0.25,
|
|
|
|
black,
|
|
|
|
),
|
|
|
|
]
|
|
|
|
),
|
|
|
|
)
|
|
|
|
W = []
|
|
|
|
currow = []
|
|
|
|
for n in range(nb_days):
|
|
|
|
currow.append(elem_day)
|
|
|
|
W.append(currow)
|
|
|
|
|
|
|
|
elem_week = Table(
|
|
|
|
W,
|
2022-03-24 09:59:44 +01:00
|
|
|
colWidths=([col_width * (NB_CELL_AM + 1 + NB_CELL_PM + 1)] * nb_days),
|
2020-09-26 16:19:37 +02:00
|
|
|
style=TableStyle(
|
|
|
|
[
|
|
|
|
("LEFTPADDING", (0, 0), (-1, -1), 0),
|
|
|
|
("RIGHTPADDING", (0, 0), (-1, -1), 0),
|
|
|
|
("BOTTOMPADDING", (0, 0), (-1, -1), 0),
|
|
|
|
("TOPPADDING", (0, 0), (-1, -1), 0),
|
|
|
|
]
|
|
|
|
),
|
|
|
|
)
|
|
|
|
currow = []
|
|
|
|
for n in range(nb_days):
|
|
|
|
currow += [Paragraph(SU("<b>" + days[n] + "</b>"), StyleSheet["Normal"])]
|
|
|
|
|
|
|
|
elem_day_name = Table(
|
|
|
|
[currow],
|
2022-03-24 09:59:44 +01:00
|
|
|
colWidths=([col_width * (NB_CELL_AM + 1 + NB_CELL_PM + 1)] * nb_days),
|
2020-09-26 16:19:37 +02:00
|
|
|
style=TableStyle(
|
|
|
|
[
|
|
|
|
("LEFTPADDING", (0, 0), (-1, -1), 0),
|
|
|
|
("RIGHTPADDING", (0, 0), (-1, -1), 0),
|
|
|
|
("BOTTOMPADDING", (0, 0), (-1, -1), 0),
|
|
|
|
("TOPPADDING", (0, 0), (-1, -1), 0),
|
|
|
|
]
|
|
|
|
),
|
|
|
|
)
|
|
|
|
|
|
|
|
for group_id in groups_infos.group_ids:
|
2022-09-30 22:43:39 +02:00
|
|
|
members, _, group_tit, _, _ = sco_groups.get_group_infos(group_id, scu.INSCRIT)
|
2020-09-26 16:19:37 +02:00
|
|
|
L = []
|
|
|
|
|
|
|
|
currow = [
|
|
|
|
Paragraph(SU("<b>Groupe " + group_tit + "</b>"), StyleSheet["Normal"])
|
|
|
|
]
|
|
|
|
currow.append(elem_day_name)
|
|
|
|
L.append(currow)
|
|
|
|
|
|
|
|
currow = [Paragraph(SU("Initiales enseignant :"), StyleSheet["Normal"])]
|
|
|
|
currow.append(elem_week)
|
|
|
|
L.append(currow)
|
|
|
|
|
|
|
|
currow = [Paragraph(SU("Initiales module :"), StyleSheet["Normal"])]
|
|
|
|
currow.append(elem_week)
|
|
|
|
L.append(currow)
|
|
|
|
|
|
|
|
for m in members:
|
|
|
|
currow = [
|
|
|
|
Paragraph(
|
2023-11-22 23:31:16 +01:00
|
|
|
SU(scu.format_nom(m["nom"]) + " " + scu.format_prenom(m["prenom"])),
|
2020-09-26 16:19:37 +02:00
|
|
|
StyleSheet["Normal"],
|
|
|
|
)
|
|
|
|
]
|
|
|
|
currow.append(elem_week)
|
|
|
|
L.append(currow)
|
|
|
|
|
|
|
|
if not L:
|
|
|
|
T = Paragraph(SU("Aucun étudiant !"), StyleSheet["Normal"])
|
|
|
|
else:
|
|
|
|
T = Table(
|
|
|
|
L,
|
|
|
|
colWidths=(
|
2022-03-24 09:59:44 +01:00
|
|
|
[
|
|
|
|
5.0 * cm,
|
|
|
|
(col_width * (NB_CELL_AM + 1 + NB_CELL_PM + 1) * nb_days),
|
|
|
|
]
|
2020-09-26 16:19:37 +02:00
|
|
|
),
|
|
|
|
style=TableStyle(
|
|
|
|
[
|
|
|
|
("VALIGN", (0, 0), (-1, -1), "MIDDLE"),
|
|
|
|
("LEFTPADDING", (0, 0), (-1, -1), 0),
|
|
|
|
("RIGHTPADDING", (0, 0), (-1, -1), 0),
|
|
|
|
("BOTTOMPADDING", (0, 0), (-1, -1), 3),
|
|
|
|
("TOPPADDING", (0, 0), (-1, -1), 3),
|
|
|
|
("BOTTOMPADDING", (0, -1), (-1, -1), 10),
|
|
|
|
(
|
|
|
|
"ROWBACKGROUNDS",
|
|
|
|
(0, 2),
|
|
|
|
(-1, -1),
|
|
|
|
(colors.white, colors.lightgrey),
|
|
|
|
),
|
|
|
|
]
|
|
|
|
),
|
|
|
|
)
|
|
|
|
|
|
|
|
objects.append(T)
|
|
|
|
|
|
|
|
# Réduit sur une page
|
|
|
|
objects = [KeepInFrame(0, 0, objects, mode="shrink")]
|
|
|
|
# Build document
|
2021-07-26 18:11:00 +03:00
|
|
|
report = io.BytesIO() # in-memory document, no disk file
|
2020-09-26 16:19:37 +02:00
|
|
|
filename = "absences-%s-%s.pdf" % (DeptName, groups_infos.groups_filename)
|
2021-07-28 18:03:54 +03:00
|
|
|
if sco_preferences.get_preference("feuille_releve_abs_taille") == "A3":
|
2020-09-26 16:19:37 +02:00
|
|
|
taille = A3
|
2021-07-28 18:03:54 +03:00
|
|
|
elif sco_preferences.get_preference("feuille_releve_abs_taille") == "A4":
|
2020-09-26 16:19:37 +02:00
|
|
|
taille = A4
|
2021-07-28 18:03:54 +03:00
|
|
|
if sco_preferences.get_preference("feuille_releve_abs_format") == "Paysage":
|
2020-09-26 16:19:37 +02:00
|
|
|
document = BaseDocTemplate(report, pagesize=landscape(taille))
|
|
|
|
else:
|
|
|
|
document = BaseDocTemplate(report, pagesize=taille)
|
|
|
|
document.addPageTemplates(
|
2022-03-12 09:40:48 +01:00
|
|
|
ScoDocPageTemplate(
|
2021-06-13 19:12:20 +02:00
|
|
|
document,
|
2021-07-28 18:03:54 +03:00
|
|
|
preferences=sco_preferences.SemPreferences(),
|
2021-01-04 11:31:18 +01:00
|
|
|
)
|
2020-09-26 16:19:37 +02:00
|
|
|
)
|
|
|
|
document.build(objects)
|
|
|
|
data = report.getvalue()
|
|
|
|
|
2021-09-21 15:53:33 +02:00
|
|
|
return scu.sendPDFFile(data, filename)
|