X-Git-Url: https://git.immae.eu/?p=perso%2FDenise%2Foms.git;a=blobdiff_plain;f=app.py;h=5e62e10cc65f0b68886487de79270adda87fecd5;hp=7baef86c03fd113bba7850ff607ac854ebe63699;hb=9297f44a695bd97cd058d79b9a3564fab414dce5;hpb=a46e126967995e8483b4da81a1f3b586266ee86d diff --git a/app.py b/app.py index 7baef86..5e62e10 100644 --- a/app.py +++ b/app.py @@ -3,18 +3,17 @@ import flask import io -from configuration import * +import matplotlib.pyplot as plt +import base64 +from matplotlib.backends.backend_agg import FigureCanvasAgg as FigureCanvas + +from configuration import config_init from gestion_erreurs import * from gestion_donnees import * from gestion_unites import * from trace_courbe import * from faq import * -import matplotlib.pyplot as plt - -import base64 - -from matplotlib.backends.backend_agg import FigureCanvasAgg as FigureCanvas app = flask.Flask(__name__) @@ -26,9 +25,12 @@ def index(): if 'fichier_donnees' in flask.request.files: ## charger les donneés dans le formulaire fichier = flask.request.files['fichier_donnees'] - - val_form = fichier_texte_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) @app.route('/apropos') @@ -45,10 +47,13 @@ def courbe_image(ext): # 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) + - # préparer l'export - texte = configuration_vers_texte(config) - texte += donnees_poids_vers_texte(l_jours,l_poids) + + texte = donnees_vers_json(l_jours,l_poids,config) + + # noter le nom de l'enfant pour l'export + nomenfant = simplifie_nom(config['nom']) # créer la figure try: @@ -56,10 +61,11 @@ def courbe_image(ext): 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 !") + liste_err[0].append("Impossible de générer la courbe ! Config : "+str(config)) if ext == "b64": @@ -67,14 +73,16 @@ def courbe_image(ext): reponse = flask.jsonify({ "result":result, "messages": liste_err[1], "image": base64.b64encode(output.getvalue()).decode("ascii"), - "export_txt": texte}) + "export_txt": texte, + "nomenfant": nomenfant}) else: reponse = flask.jsonify({ "result":result, - "messages": liste_err[1]+liste_err[0], + "messages": liste_err[2]+liste_err[1]+liste_err[0], "image": "", - "export_txt": texte}) + "export_txt": texte, + "nomenfant": nomenfant}) return reponse - #return flask.Response(base64.b64encode(output.getvalue()), mimetype='text/plain') + elif ext == "png" and result == "success": return flask.Response(output.getvalue(), mimetype='image/png') elif ext == "png": @@ -82,21 +90,10 @@ def courbe_image(ext): else: return flask.render_template("erreur_fatale.html",erreur="Le type d'image demandé n'est pas reconnu") - #return flask.Response(base64.b64encode(output.getvalue()), mimetype='text/plain') - -@app.route("/export_donnees",methods=['POST']) -def export_donnees(): - # exporte les données au format texte - liste_err = initialise_erreurs() - data = flask.request.form - - config = gere_configuration(data,liste_err) - l_jours,l_poids = gere_donneespoids(data,config["naissance"],liste_err) - - texte = configuration_vers_texte(config) - texte += donnees_poids_vers_texte(l_jours,l_poids) - return flask.Response(texte,mimetype="text/plain") +@app.route("/contact") +def contact(): + return flask.render_template("contact.html",err=[]) @app.route("/faq") def faq(): @@ -113,6 +110,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