X-Git-Url: https://git.immae.eu/?p=perso%2FDenise%2Foms.git;a=blobdiff_plain;f=app.py;fp=app.py;h=3f4da5c574350378d249a8bf71f56e40979be120;hp=5e62e10cc65f0b68886487de79270adda87fecd5;hb=8b5845ffdbffa3cf291bfef8e224c1d81bdd09de;hpb=bc1faf7cc9cf3a6c41e077c361edcc93419cc77d diff --git a/app.py b/app.py index 5e62e10..3f4da5c 100644 --- a/app.py +++ b/app.py @@ -7,7 +7,7 @@ import matplotlib.pyplot as plt import base64 from matplotlib.backends.backend_agg import FigureCanvasAgg as FigureCanvas -from configuration import config_init +from configuration import config_init,CONFIG from gestion_erreurs import * from gestion_donnees import * from gestion_unites import * @@ -44,46 +44,53 @@ def courbe_image(ext): liste_err = initialise_erreurs() data = flask.request.form - # Régler la configuration et les données - config = gere_configuration(data,liste_err) - l_jours,l_poids = gere_donneespoids(data,config["naissance"],liste_err) - - + # récupérer les données du formulaire proprement + config,listes_jours,listes_donnees = web_vers_python(data,liste_err) + debug(" * On a récupéré et traité les données du formulaire web",liste_err) - texte = donnees_vers_json(l_jours,l_poids,config) + texte = donnees_vers_json(listes_jours["poids"],listes_donnees["poids"],listes_jours["taille"],listes_donnees["taille"], config) + + debug("texte prêt à être exporté : "+texte,liste_err) # noter le nom de l'enfant pour l'export nomenfant = simplifie_nom(config['nom']) - # créer la figure + # créer les figures try: - fig = cree_figure(config,l_jours,l_poids,liste_err) + debug("création des figures...",liste_err) + textes_images = {} + for typed in CONFIG["liste_typedonnees"]: + if config["tracevide"] == "oui" or listes_jours[typed] != []: + debug("On trace la courbe de "+typed,liste_err) + fig = cree_figure(config,listes_jours[typed],listes_donnees[typed],typed,liste_err) + output = io.BytesIO() + FigureCanvas(fig).print_png(output) + plt.close(fig) + textes_images[typed] = base64.b64encode(output.getvalue()).decode("ascii") + else: + textes_images[typed] = "" + result = "success" - output = io.BytesIO() - FigureCanvas(fig).print_png(output) - - plt.close(fig) except: result = "fail" - liste_err[0].append("Impossible de générer la courbe ! Config : "+str(config)) + liste_err[0].append("Impossible de générer les courbes ! Config : "+str(config)) if ext == "b64": + reponse = { "result":result, + "export_txt": texte, + "nomenfant": nomenfant} if result == "success": - reponse = flask.jsonify({ "result":result, - "messages": liste_err[1], - "image": base64.b64encode(output.getvalue()).decode("ascii"), - "export_txt": texte, - "nomenfant": nomenfant}) + reponse["messages"] = liste_err[0] else: - reponse = flask.jsonify({ "result":result, - "messages": liste_err[2]+liste_err[1]+liste_err[0], - "image": "", - "export_txt": texte, - "nomenfant": nomenfant}) - return reponse - - elif ext == "png" and result == "success": + reponse["messages"] = liste_err[2]+liste_err[1]+liste_err[0] + + for typed in CONFIG["liste_typedonnees"]: + reponse["image_"+typed] = textes_images.get(typed,"") + + return flask.jsonify(reponse) + elif ext == "png" and result == "success": # à voir cette partie car il faudrait voir ce qu'on y renvoie... vu + # qu'il n'y a plus une courbe mais plusieurs. Là ça renverra la dernière générée. return flask.Response(output.getvalue(), mimetype='image/png') elif ext == "png": return flask.render_template("erreur_fatale.html",erreur="Impossible de générer la courbe")