X-Git-Url: https://git.immae.eu/?p=perso%2FDenise%2Foms.git;a=blobdiff_plain;f=app.py;h=f60d3e2ec9d76f0fcbf98003a6378dc70a284295;hp=93c5b309ead261fa4ca6694cb6d6c6de842af264;hb=HEAD;hpb=915e90bbf0bee1d69c51a749a4f2be85b9fda091 diff --git a/app.py b/app.py index 93c5b30..f60d3e2 100644 --- a/app.py +++ b/app.py @@ -3,88 +3,124 @@ import flask import io -from configuration import * -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 +from configuration import config_init,CONFIG +from gestion_erreurs import initialise_erreurs, debug, niveau_debug, warning +import gestion_donnees as donnees +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() + ## Si on a chargé un fichier de données if flask.request.method=="POST": if 'fichier_donnees' in flask.request.files: - ## charger les donneés dans le formulaire + ## charger les données dans le formulaire fichier = flask.request.files['fichier_donnees'] - - val_form2 = fichier_json_vers_configdonnees(fichier,liste_err) + 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) - #return str(val_form['nb_data']) - return flask.render_template("index.html",err=liste_err[1],valform=val_form) + 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) @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/", methods=['POST']) 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 = donnees.web_vers_python(data,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) - texte = donnees_vers_json(l_jours,l_poids,config) + # 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 = simplifie_nom(config['nom']) - - #warning(str(config),liste_err) - - # créer la figure + 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: - fig = cree_figure(config,l_jours,l_poids,liste_err) + 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() + 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() - #warning("Là ça va",liste_err) - 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 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, + "nomsenfantsplus": nomsenfantsplus} 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]+liste_err[1] + reponse["calculextra"] = liste_extracalculs 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" 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") @@ -94,23 +130,26 @@ 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 = lire_fichier_csv_simple(fichier_FAQ) - l_categ,table_qr = extraire_tables_par_cat(table_faq) + table_faq = f.lire_fichier_csv_simple(f.fichier_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=[]) + return flask.render_template("faq.html",lcateg=l_categ,lcategsimple= l_categsimple, tableqr=table_qr,err=[], beta=beta) @app.route("/changelog") def changelog(): + beta=initialise_mode_beta() - table_version = lire_fichier_csv_simple(fichier_changelog) + 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, nblignes=CONFIG["nb_lignes_changelog"], err=[], beta=beta) 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