-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdataviz.js
79 lines (58 loc) · 2.63 KB
/
dataviz.js
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
// fetch= initie une promesse : appelle l'api
fetch("https://hubeau.eaufrance.fr/api/v1/niveaux_nappes/chroniques?code_bss=09405X0229/S3&date_debut_mesure=2014-01-20&date_fin_mesure=2024-01-20&size=20000")
// .then = quand reponse de fetch (dc de l'API): retourner l'argument en .json
.then(response => {
return response.json()
})
// aussi quand reponse fetch: executer la boucle for of (= pour chaque ligne de mesures.data, faire ces instructions)
.then((mesures)=>{
console.log(mesures)
const jaugeMax= mesures.data[0].profondeur_nappe +mesures.data[0].niveau_nappe_eau
const firstYearLevel = mesures.data[0].niveau_nappe_eau
const secondYearLevel = mesures.data[mesures.data.length-1].niveau_nappe_eau
creerJauge(firstYearLevel,jaugeMax);
creerJauge(secondYearLevel,jaugeMax);
});
function pourcentage(niveau, jaugeMax){ //recupere proportion de remplissage de l'eau sur la profondeur totale de la nappe
return Math.floor((niveau/jaugeMax)*100) // calcule taux de remplissage en eau de la nappe
}
function creerJauge(niveau,jaugeMax){ // parametre = taux de remplissage à appeler de la fonction pourcentage()
const jauges = document.getElementById('jauges') // pour se placer dans l'id "jauges" dans HTML
const eau = document.createElement("eau") // creer balise eau
const span= document.createElement("span"); // cree balise span
const niveauxEau=pourcentage(niveau,jaugeMax) //resultat fonction pourcentage()
eau.setAttribute('class', 'jauge'); // ajoute attribut class avec valeur jauge ds balise a
eau.setAttribute('href', '#') // ajoute attribut href avec valeur # ds balise a
span.setAttribute('class', 'jauge-remplissage'); //idem methode a
span.setAttribute('style', 'height: '+niveauxEau+'%');
eau.appendChild(span) // ajoute balise span dans balise eau
jauges.appendChild(eau) // ajoute balise a dans balise jauges
}
// enveloppe chaque lettre dans un spam
var textWrapper = document.querySelector('.ml1 .letters');
textWrapper.innerHTML = textWrapper.textContent.replace(/\S/g, "<span class='letter'>$&</span>");
anime.timeline({loop: true})
.add({
targets: '.ml1 .letter',
scale: [0.3,1],
opacity: [0,1],
translateZ: 0,
easing: "easeOutExpo",
duration: 3000,
}).add({
targets: '.ml1 .line',
scaleX: [0,1],
opacity: [0.5,1],
easing: "easeOutExpo",
duration: 1000,
offset: '-=875',
}).add({
targets: '.ml1',
opacity: 0,
duration: 8000,
easing: "easeOutExpo",
loopComplete: function(anim) {
loopCompleted++;
completeLogEl.value = 'loop completed : ' + loopCompleted;
}
});