]> git.immae.eu Git - perso/Denise/oms.git/blobdiff - app.py
petites modifs sur le texte de la page
[perso/Denise/oms.git] / app.py
diff --git a/app.py b/app.py
index d6f8507022a861e653ba1e151920fae9a2550af5..3f4da5c574350378d249a8bf71f56e40979be120 100644 (file)
--- 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 *
+from configuration import config_init,CONFIG
 from gestion_erreurs import *
 from gestion_donnees import *
 from gestion_unites import *
@@ -15,8 +15,6 @@ from trace_courbe import *
 from faq import *
 
 
-
-
 app = flask.Flask(__name__)
 
 @app.route('/',methods=['POST','GET'])
@@ -27,8 +25,10 @@ def index():
         if 'fichier_donnees' in flask.request.files:
             ## charger les donneés dans le formulaire
             fichier = flask.request.files['fichier_donnees']
-        
-            val_form2 = fichier_json_vers_configdonnees(fichier,liste_err)
+            chaine = fichier.read()
+            val_form2 = fichier_json_vers_configdonnees(chaine,liste_err)
+            if val_form2 == {}:
+                return flask.render_template("index.html",err=liste_err[2]+liste_err[1]+liste_err[0],valform=val_form)
             val_form.update(val_form2)
             #return str(val_form['nb_data'])
     return flask.render_template("index.html",err=liste_err[1],valform=val_form)
@@ -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")
@@ -110,6 +117,6 @@ def changelog():
     
     return flask.render_template("changelog.html",table = table_version,err=[])
 
-
 if __name__ == "__main__":
+    print("Mode debug maison : "+str(niveau_debug))
     app.run(host='0.0.0.0',debug=True)
\ No newline at end of file