fabriquedoc/frontend/app_tab3.py
François Pelletier 4a6bfc951f Gros refactoring
2024-12-31 17:00:07 -05:00

82 lines
No EOL
4.4 KiB
Python

# Importation des modules nécessaires
import datetime # Pour manipuler les dates et heures
import requests # Pour effectuer des requêtes HTTP
import streamlit as st # Pour créer l'interface utilisateur web
# Importation de la classe DocumentSpecs depuis le module models
from models import DocumentSpecs
# Définition de la fonction principale pour l'onglet 3 de l'application
def app_tab3():
# Affichage d'un en-tête dans l'interface utilisateur
st.header("Paramètres")
# Préparation des en-têtes HTTP pour l'authentification
http_headers = {"Authorization": f"Bearer {st.session_state['bearer_token']}"}
# Récupération et sélection des styles disponibles
response_styles = requests.get(f"{st.session_state['fabriquedoc_endpoint']}/styles/", headers=http_headers).json()
styles = response_styles.get("styles")
selected_style = st.selectbox("Sélectionnez un style:", styles)
# Récupération et sélection des formats disponibles pour le style choisi
response_formats = requests.get(f"{st.session_state['fabriquedoc_endpoint']}/formats/{selected_style}/", headers=http_headers).json()
formats = response_formats.get("formats")
selected_format = st.selectbox("Sélectionnez un format:", formats)
# Récupération des paramètres de format pour le style et le format choisis
response_format_parameters = requests.get(
f"{st.session_state['fabriquedoc_endpoint']}/format_parameters/{selected_style}/{selected_format}/", headers=http_headers).json()
# Création des champs de saisie pour les différents paramètres
linkcolor = st.text_input("Couleur des liens:", value=response_format_parameters.get("linkcolor"))
pdfengine = st.text_input("Moteur PDF:", value=response_format_parameters.get("pdfengine"))
fontsize = st.number_input("Taille de la police:", value=int(response_format_parameters.get("fontsize")), step=1)
paperwidth = st.number_input("Largeur du papier:", value=int(response_format_parameters.get("paperwidth")), step=30)
paperheight = st.number_input("Hauteur du papier:", value=int(response_format_parameters.get("paperheight")), step=30)
margin = st.number_input("Marge:", value=int(response_format_parameters.get("margin")), step=10)
vmargin = st.number_input("Marge verticale:", value=int(response_format_parameters.get("vmargin")), step=10)
fps = st.number_input("Images par seconde:", value=int(response_format_parameters.get("fps")), step=1)
stilltime = st.number_input("Temps d'arrêt:", value=int(response_format_parameters.get("stilltime")), step=1)
# Création d'un bouton pour générer le document
if st.button("Générer le document"):
# Création d'un objet DocumentSpecs avec les paramètres saisis
document_specs = DocumentSpecs(
format=selected_format,
style=selected_style,
linkcolor=linkcolor,
pdfengine=pdfengine,
content=st.session_state['content'],
fontsize=fontsize,
paperwidth=paperwidth,
paperheight=paperheight,
margin=margin,
vmargin=vmargin,
fps=fps,
stilltime=stilltime
)
# Préparation des en-têtes pour la requête POST
post_headers = http_headers | {"Content-Type": "application/json"}
# Envoi de la requête POST pour générer le document
response = requests.post(f"{st.session_state['fabriquedoc_endpoint']}/generer/",
json=document_specs.model_dump(),
headers=post_headers,
timeout=(30, 3000)) # 30 secondes de timeout pour la connexion, 5 minutes pour la lecture
# Vérification du code de statut de la réponse
if 200 <= response.status_code <= 299:
# Si la requête est réussie, récupération des données du fichier
file_data = response.content
datef = datetime.datetime.now().strftime("%m-%d-%Y")
# Création du nom de fichier
file_name = f"{document_specs.style}-{document_specs.format}-{datef}-output.zip"
# Affichage d'un bouton de téléchargement
st.download_button('Télécharger', file_data, file_name=file_name)
else:
# Si la requête échoue, affichage d'un message d'erreur
st.error(f"La requête a échoué avec le code d'état {response.status_code}: {response.text}")