]> git.immae.eu Git - perso/Denise/oms.git/blobdiff - app.py
changelog à jour (pour mise en prod)
[perso/Denise/oms.git] / app.py
diff --git a/app.py b/app.py
index 206af476ff5d56c3624dbdaee293f3730e3a1335..f60d3e2ec9d76f0fcbf98003a6378dc70a284295 100644 (file)
--- a/app.py
+++ b/app.py
@@ -10,7 +10,6 @@ from matplotlib.backends.backend_agg import FigureCanvasAgg as FigureCanvas
 from configuration import config_init,CONFIG
 from gestion_erreurs import initialise_erreurs, debug, niveau_debug, warning
 import gestion_donnees as donnees
-import gestion_couleurs as couleurs
 from trace_courbe import cree_figure
 import faq as f
 
@@ -27,22 +26,23 @@ def initialise_mode_beta():
 
 app = flask.Flask(__name__)
 
-
-
 @app.route('/',methods=['POST','GET'])
 def index():
     beta=initialise_mode_beta()
     liste_err = initialise_erreurs()    
     val_form = config_init()
+    ## Si on a chargé un fichier de données
     if flask.request.method=="POST":
         if 'fichier_donnees' in flask.request.files:
-            ## charger les donns dans le formulaire
+            ## charger les données dans le formulaire
             fichier = flask.request.files['fichier_donnees']
             chaine = fichier.read()
             val_form2 = donnees.fichier_json_vers_configdonnees(chaine,liste_err)
+            # Si jamais le formulaire est vide, c'est qu'il y a eu une erreur !
             if val_form2 == {}:
                 return flask.render_template("index.html",err=liste_err[2]+liste_err[1]+liste_err[0],valform=val_form, CONFIG=CONFIG, beta=beta)
             val_form.update(val_form2)
+            val_form["fichier_importe"] = 1 # Pour noter qu'on a importé un fichier
 
     return flask.render_template("index.html",err=liste_err[1],valform=val_form, CONFIG=CONFIG, beta=beta)
 
@@ -56,45 +56,36 @@ def apropos():
 def courbe_image(ext):
     liste_err = initialise_erreurs()
     data = flask.request.form
-    enfants_add = [] # Enfants additionnels
-    for i in range(2, 11): 
-        if 'fichier_donnees_'+str(i) in flask.request.files: # UUn enfant à ajouter
-            fichier = flask.request.files["fichier_donnees_"+str(i)]
-            chaine = fichier.read() # On récupère la chaîne
-            if len(chaine)>=5: # Si elle a une longueur à peu près raisonnable
-                debug("Un fichier de données additionnel trouvé", liste_err)
-                formulaire_2 = donnees.fichier_json_vers_configdonnees(chaine, liste_err)
-                if formulaire_2 =={}:
-                    warning("Le fichier de données additionnel est vide ou mal formaté", liste_err)
-                else:
-                    #debug("Form 2 : "+str(formulaire_2), liste_err)
-                    # Récupérer sous forme python
-                    conf2, ljours2, listes_donnees2 = donnees.web_vers_python(formulaire_2,liste_err, court=True)
-                    # Le symbole et la couleur
-                    symb2 = donnees.gere_symbole(data.get("symbole_donnees_"+str(i)))
-                    coul2 = couleurs.rgb_vers_tuple(data.get("couleur_donnees_"+str(i),""),CONFIG["couleurs"]["cadretxt"],liste_err)
-                    enfant2 = donnees.eclate_donnees_additionnelles(conf2, ljours2, listes_donnees2, symb2, coul2)
-                    enfants_add.append(enfant2)
-            
 
     # récupérer les données du formulaire proprement
     config,listes_jours,listes_donnees = donnees.web_vers_python(data,liste_err)
-    debug(" * On a récupéré et traité les données du formulaire web",liste_err)
+    debug(" * On a récupéré et traité les données du formulaire web, "+str(listes_jours)+str(listes_donnees),liste_err)
+
+    # Gérer les enfants additionnels
+    enfants_add = donnees.gere_enfants_additionnels(data, flask.request.files, liste_err)
+    debug("Enfants additionnels récupérés : "+str(enfants_add), liste_err)
 
+    # Récupérer le texte à exporter
     texte = donnees.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 = donnees.simplifie_nom(config['nom'])
+    # Les noms des autres enfants c'est sympa
+    nomsenfantsplus = ""
+    for dicoenfant in enfants_add:
+        nomsenfantsplus += "_"+donnees.simplifie_nom(dicoenfant["poids"][0]["nom"])
 
+    existe_courbe = False
     # créer les figures
     try:
         debug("création des figures...",liste_err)
         textes_images = {}
         liste_extracalculs = []
+
         for typed in CONFIG["liste_typedonnees"]:
             if config["tracevide"] == "oui" or listes_jours[typed] != []:
+                existe_courbe = True # Une courbe (au moins) a été tracée
                 debug("On trace la courbe de "+typed,liste_err)
                 fig = cree_figure(config,listes_jours[typed],listes_donnees[typed],typed,liste_extracalculs, liste_err, enfants_add)
                 output = io.BytesIO()
@@ -109,11 +100,14 @@ def courbe_image(ext):
         result = "fail"
         liste_err[0].append("Impossible de générer les courbes ! Config : "+str(config))
     
+    if not(existe_courbe):
+        warning("Aucune courbe n'a été tracée. C'est probablement parce que les données sont vides et que l'option \"tracer les courbes vides\" n'a pas été cochée.", liste_err)
     
     if ext == "b64":
         reponse = { "result":result, 
             "export_txt": texte,
-            "nomenfant": nomenfant}
+            "nomenfant": nomenfant,
+            "nomsenfantsplus": nomsenfantsplus}
         if result == "success":
             reponse["messages"] = liste_err[0]+liste_err[1]
             reponse["calculextra"] = liste_extracalculs
@@ -121,11 +115,10 @@ def courbe_image(ext):
             reponse["messages"] = liste_err[2]+liste_err[1]+liste_err[0]
 
         for typed in CONFIG["liste_typedonnees"]:
-            reponse["image_"+typed] = textes_images.get(typed,"")
-        
+            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')
@@ -145,9 +138,9 @@ def faq():
     beta=initialise_mode_beta()
     
     table_faq = f.lire_fichier_csv_simple(f.fichier_FAQ)
-    l_categ,table_qr = f.extraire_tables_par_cat(table_faq)
+    l_categ, l_categsimple, table_qr = f.extraire_tables_par_cat(table_faq)
 
-    return flask.render_template("faq.html",lcateg=l_categ,tableqr=table_qr,err=[], beta=beta)
+    return flask.render_template("faq.html",lcateg=l_categ,lcategsimple= l_categsimple, tableqr=table_qr,err=[], beta=beta)
 
 @app.route("/changelog")
 def changelog():
@@ -155,7 +148,7 @@ def changelog():
     
     table_version = f.lire_fichier_csv_simple(f.fichier_changelog)
     
-    return flask.render_template("changelog.html",table = table_version,err=[], beta=beta)
+    return flask.render_template("changelog.html",table = table_version, nblignes=CONFIG["nb_lignes_changelog"], err=[], beta=beta)
 
 if __name__ == "__main__":
     print("Mode debug maison : "+str(niveau_debug))