X-Git-Url: https://git.immae.eu/?p=perso%2FDenise%2Foms.git;a=blobdiff_plain;f=app.py;h=49a47a34746ab50d8013a29a4cf03a2ccbcc9283;hp=4f330d9204c715f64c2fea39ce1b3705112be69e;hb=61020126080c00be471ea41a0b25109469d8bda1;hpb=66a3e38cc085dc000776d3e2ad3acd7ef57068a3 diff --git a/app.py b/app.py index 4f330d9..49a47a3 100644 --- a/app.py +++ b/app.py @@ -3,6 +3,10 @@ import flask import io +import matplotlib.pyplot as plt +import base64 +from matplotlib.backends.backend_agg import FigureCanvasAgg as FigureCanvas + from configuration import * from gestion_erreurs import * from gestion_donnees import * @@ -10,11 +14,8 @@ 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__) @@ -27,8 +28,9 @@ def index(): ## charger les donneés dans le formulaire fichier = flask.request.files['fichier_donnees'] - val_form = fichier_texte_vers_configdonnees(fichier,liste_err) - + val_form2 = fichier_json_vers_configdonnees(fichier,liste_err) + 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,44 +47,53 @@ 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 - fig = cree_figure(config,l_jours,l_poids,liste_err) - output = io.BytesIO() - FigureCanvas(fig).print_png(output) - plt.close(fig) + try: + fig = cree_figure(config,l_jours,l_poids,liste_err) + 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)) + if ext == "b64": - reponse = flask.jsonify({ "result":"success", - "messages": liste_err[1], - "image": base64.b64encode(output.getvalue()).decode("ascii"), - "export_txt": texte}) + if result == "success": + reponse = flask.jsonify({ "result":result, + "messages": liste_err[1], + "image": base64.b64encode(output.getvalue()).decode("ascii"), + "export_txt": texte, + "nomenfant": nomenfant}) + else: + reponse = flask.jsonify({ "result":result, + "messages": liste_err[1]+liste_err[0], + "image": "", + "export_txt": texte, + "nomenfant": nomenfant}) return reponse - #return flask.Response(base64.b64encode(output.getvalue()), mimetype='text/plain') - elif ext == "png": + + elif ext == "png" and result == "success": 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") 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(): @@ -92,6 +103,13 @@ def faq(): return flask.render_template("faq.html",lcateg=l_categ,tableqr=table_qr,err=[]) +@app.route("/changelog") +def changelog(): + + table_version = lire_fichier_csv_simple(fichier_changelog) + + return flask.render_template("changelog.html",table = table_version,err=[]) + if __name__ == "__main__": app.run(host='0.0.0.0',debug=True) \ No newline at end of file