X-Git-Url: https://git.immae.eu/?p=perso%2FDenise%2Foms.git;a=blobdiff_plain;f=app.py;h=f60d3e2ec9d76f0fcbf98003a6378dc70a284295;hp=a803d900866c8e4f4c19ea4cdb760c99333c4d0b;hb=HEAD;hpb=ca61f310d80e05ea43efc148787f214a567743f0 diff --git a/app.py b/app.py index a803d90..f60d3e2 100644 --- a/app.py +++ b/app.py @@ -26,22 +26,23 @@ def initialise_mode_beta(): 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'] 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) + 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) @@ -55,45 +56,36 @@ def apropos(): 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) - # Et le symbole - symb2 = donnees.gere_symbole(data.get("symbole_donnees_"+str(i))) - - enfant2 = donnees.eclate_donnees_additionnelles(conf2, ljours2, listes_donnees2, symb2) - 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) + 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) + # 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 = 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: 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() @@ -108,11 +100,14 @@ def courbe_image(ext): result = "fail" 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} + "nomenfant": nomenfant, + "nomsenfantsplus": nomsenfantsplus} if result == "success": reponse["messages"] = liste_err[0]+liste_err[1] reponse["calculextra"] = liste_extracalculs @@ -120,11 +115,10 @@ def courbe_image(ext): reponse["messages"] = liste_err[2]+liste_err[1]+liste_err[0] for typed in CONFIG["liste_typedonnees"]: - reponse["image_"+typed] = textes_images.get(typed,"") - + 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') @@ -144,9 +138,9 @@ 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) + 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=[], beta=beta) + return flask.render_template("faq.html",lcateg=l_categ,lcategsimple= l_categsimple, tableqr=table_qr,err=[], beta=beta) @app.route("/changelog") def changelog(): @@ -154,7 +148,7 @@ def changelog(): table_version = f.lire_fichier_csv_simple(f.fichier_changelog) - return flask.render_template("changelog.html",table = table_version,err=[], beta=beta) + 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))