]> git.immae.eu Git - perso/Denise/oms.git/blobdiff - app.py
sauvegarde des dates + version de l'app dans le fichier de sauvegarde
[perso/Denise/oms.git] / app.py
diff --git a/app.py b/app.py
index 02d88c4d6d43f4d97a228e0bc9d2b6a606f3ca39..3ccabad2f57271ec1b36871da4356acaf6df3aaa 100644 (file)
--- a/app.py
+++ b/app.py
@@ -8,16 +8,28 @@ import base64
 from matplotlib.backends.backend_agg import FigureCanvasAgg as FigureCanvas
 
 from configuration import config_init,CONFIG
-from gestion_erreurs import initialise_erreurs, debug, niveau_debug
+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
 
 
+def initialise_mode_beta():
+    global beta
+    hote = flask.request.host
+    if hote[:4] == "beta":
+        print("** Mode bêta !**")
+        return True
+    else:
+        return False
+
+
 app = flask.Flask(__name__)
 
 @app.route('/',methods=['POST','GET'])
 def index():
+    beta=initialise_mode_beta()
     liste_err = initialise_erreurs()    
     val_form = config_init()
     if flask.request.method=="POST":
@@ -27,22 +39,42 @@ def index():
             chaine = fichier.read()
             val_form2 = donnees.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)
+                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)
-            #return str(val_form['nb_data'])
-    return flask.render_template("index.html",err=liste_err[1],valform=val_form)
+
+    return flask.render_template("index.html",err=liste_err[1],valform=val_form, CONFIG=CONFIG, beta=beta)
 
 @app.route('/apropos')
 def apropos():
-    
-    return flask.render_template("apropos.html",err=[])
+    beta=initialise_mode_beta()
+    return flask.render_template("apropos.html",err=[], beta=beta)
  
 
 @app.route("/courbe/<ext>", methods=['POST'])
 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)
@@ -58,10 +90,11 @@ def courbe_image(ext):
     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] != []:
                 debug("On trace la courbe de "+typed,liste_err)
-                fig = cree_figure(config,listes_jours[typed],listes_donnees[typed],typed,liste_err)
+                fig = cree_figure(config,listes_jours[typed],listes_donnees[typed],typed,liste_extracalculs, liste_err, enfants_add)
                 output = io.BytesIO()
                 FigureCanvas(fig).print_png(output)
                 plt.close(fig)
@@ -80,13 +113,16 @@ def courbe_image(ext):
             "export_txt": texte,
             "nomenfant": nomenfant}
         if result == "success":
-            reponse["messages"] = liste_err[0]
+            reponse["messages"] = liste_err[0]+liste_err[1]
+            reponse["calculextra"] = liste_extracalculs
         else:
             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.
@@ -99,22 +135,25 @@ def courbe_image(ext):
     
 @app.route("/contact")
 def contact():
-    return flask.render_template("contact.html",err=[])
+    beta=initialise_mode_beta()
+    return flask.render_template("contact.html",err=[], beta=beta)
 
 @app.route("/faq")
 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)
 
-    return flask.render_template("faq.html",lcateg=l_categ,tableqr=table_qr,err=[])
+    return flask.render_template("faq.html",lcateg=l_categ,tableqr=table_qr,err=[], beta=beta)
 
 @app.route("/changelog")
 def changelog():
+    beta=initialise_mode_beta()
     
     table_version = f.lire_fichier_csv_simple(f.fichier_changelog)
     
-    return flask.render_template("changelog.html",table = table_version,err=[])
+    return flask.render_template("changelog.html",table = table_version,err=[], beta=beta)
 
 if __name__ == "__main__":
     print("Mode debug maison : "+str(niveau_debug))