1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
|
function appelle_image()
{
var formData = new FormData( document.getElementById("donnees_enfant") );
var requete = new XMLHttpRequest();
requete.responseType = "json";
requete.onreadystatechange = function()
{
if (this.readyState == 4 && this.status == 200) {
// On nettoie
nettoie_erreurs()
// on récupère les différents champs de la réponse
var result = this.response.result ;
var image = this.response.image ;
var liste_warnings = this.response.messages
var texte = this.response.export_txt;
var nomenfant = this.response.nomenfant ;
// on affiche l'export des données
document.getElementById('export').innerHTML = texte;
document.getElementById('sectionexport').style.display = "block";
var boutondl = document.getElementById("export_dl") ;
boutondl.setAttribute('onclick',"download_file('donnees_"+nomenfant+".json', 'application/json;charset=utf-8','"+encodeURIComponent(texte) +"')")
if(result == "success")
{
// On affiche l'image
document.getElementById('courbe').src = 'data:image/png;base64,'+(image);
document.getElementById('sectioncourbe').style.display = "block";
//document.getElementById("courbe_dl").setAttribute('href', 'data:image/png;base64,' + image);
boutondl = document.getElementById("courbe_dl") ;
boutondl.setAttribute('onclick',"download_file('courbe_"+nomenfant+".png', 'image/png;base64','"+image +"')")
// Si y'a eu des warnings, faut les afficher
if(liste_warnings.length != 0)
{
// afficher la liste des warnings
var elem_div = document.getElementById('courbe_warnings') ;
elem_div.style.display = "block" ;
var ul = elem_div.children[1] ;
for(i=0; i<liste_warnings.length; i++) {
var li = document.createElement("li");
li.appendChild(document.createTextNode(liste_warnings[i]));
ul.appendChild(li);
}
}
}
else{ // si la génération de l'image a merdé
// afficher la liste des erreurs
var elem_div = document.getElementById('courbe_erreurs') ;
elem_div.style.display = "block" ;
var ul = elem_div.children[1] ;
for(i=0; i<liste_warnings.length; i++) {
var li = document.createElement("li");
li.appendChild(document.createTextNode(liste_warnings[i]));
ul.appendChild(li);
}
}
}
}
requete.open("POST","courbe/b64",true)
requete.send(formData)
}
function nettoie_erreurs()
{
// fonction qui nettoie les erreurs affichées sur la page
// vider les warnings
var elem_div = document.getElementById('courbe_warnings') ;
elem_div.style.display = "none" ;
var ul = elem_div.children[1] ;
ul.innerHTML = "";
// vider les erreurs
elem_div = document.getElementById('courbe_erreurs') ;
elem_div.style.display = "none" ;
ul = elem_div.children[1] ;
ul.innerHTML = "" ;
}
function download_file(filename,mimetype,data) {
var element = document.createElement('a');
element.setAttribute('href', 'data:'+mimetype+',' + data);
element.setAttribute('download', filename);
element.style.display = 'none';
document.body.appendChild(element);
element.click();
document.body.removeChild(element);
}
function upload_file(data) {
document.getElementById('form_import_donnees').submit();
}
|