X-Git-Url: https://git.immae.eu/?p=perso%2FDenise%2Foms.git;a=blobdiff_plain;f=app.py;h=3ccabad2f57271ec1b36871da4356acaf6df3aaa;hp=02d88c4d6d43f4d97a228e0bc9d2b6a606f3ca39;hb=2dc9eb43142b4f96cee63ff191e429ad68efacae;hpb=a680b2f78891692be215013481e167da2fffb5d8 diff --git a/app.py b/app.py index 02d88c4..3ccabad 100644 --- 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/", 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))