330 |
aurelien |
1 |
<?php
|
|
|
2 |
|
|
|
3 |
function mb_ucfirst($str) {
|
|
|
4 |
$fc = mb_strtoupper(mb_substr($str, 0, 1));
|
|
|
5 |
return $fc.mb_substr($str, 1);
|
|
|
6 |
}
|
|
|
7 |
|
|
|
8 |
$config = parse_ini_file('config.ini');
|
|
|
9 |
$url_jrest = $config['url_jrest'];
|
|
|
10 |
|
|
|
11 |
$url_infos_especes = $url_jrest.'OdsEspece/ToutesEspeces';
|
|
|
12 |
$especes = json_decode(file_get_contents($url_infos_especes), true);
|
|
|
13 |
|
|
|
14 |
$url_infos_stades = $url_jrest.'OdsEvenement/TousEvenements';
|
|
|
15 |
$stades = json_decode(file_get_contents($url_infos_stades), true);
|
|
|
16 |
|
|
|
17 |
$url_annee_min_obs = $url_jrest.'OdsObservation/AnneeMinimumObservation';
|
|
|
18 |
$annee_min_obs = json_decode(file_get_contents($url_annee_min_obs), true);
|
|
|
19 |
|
|
|
20 |
$stades_par_type_evenement = [];
|
|
|
21 |
foreach($stades as $id_stade => $stade) {
|
|
|
22 |
if(empty($stades_par_type_evenement[$stade['nom']])) {
|
|
|
23 |
$stades_par_type_evenement[$stade['nom']] = [];
|
|
|
24 |
}
|
|
|
25 |
$stades_par_type_evenement[$stade['nom']][] = $id_stade;
|
|
|
26 |
}
|
333 |
aurelien |
27 |
|
|
|
28 |
$espece_defaut = !empty($_GET['espece']) ? $_GET['espece'] : null;
|
|
|
29 |
$stades_defaut = !empty($_GET['stades']) ? $_GET['stades'] : 0;
|
330 |
aurelien |
30 |
?>
|
|
|
31 |
|
|
|
32 |
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
|
|
|
33 |
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
|
|
34 |
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr" lang="fr">
|
|
|
35 |
<head>
|
|
|
36 |
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
|
|
|
37 |
<meta http-equiv="Content-style-type" content="text/css" />
|
|
|
38 |
<meta http-equiv="Content-script-type" content="text/javascript" />
|
|
|
39 |
<meta http-equiv="Content-language" content="fr" />
|
|
|
40 |
|
|
|
41 |
<base href="<?= dirname($_SERVER['PHP_SELF'])."/"; ?>" />
|
|
|
42 |
|
|
|
43 |
<title>Graphiques</title>
|
|
|
44 |
|
|
|
45 |
<meta name="revisit-after" content="15 days" />
|
|
|
46 |
<meta name="robots" content="index,follow" />
|
|
|
47 |
<meta name="author" content="Tela Botanica" />
|
|
|
48 |
|
|
|
49 |
<script type="text/javascript" src="<?= dirname($_SERVER['PHP_SELF'])."/"; ?>js/jquery-3.2.1.min.js"></script>
|
|
|
50 |
<script type="text/javascript" src="<?= dirname($_SERVER['PHP_SELF'])."/"; ?>js/plotly.min.js"></script>
|
|
|
51 |
<script type="text/javascript" src="<?= dirname($_SERVER['PHP_SELF'])."/"; ?>js/evolution-evenements.js"></script>
|
333 |
aurelien |
52 |
<link href="<?= dirname($_SERVER['PHP_SELF'])."/"; ?>css/graphiques.css" type="text/css" rel="stylesheet" />
|
330 |
aurelien |
53 |
|
|
|
54 |
<script type="text/javascript">
|
|
|
55 |
var url_jrest = <?= json_encode($url_jrest, true) ?>;
|
|
|
56 |
var global_evenements = <?= json_encode($stades, true) ?>;
|
|
|
57 |
var annees_observations = <?= json_encode(range($annee_min_obs, date('Y')), true) ?>;
|
333 |
aurelien |
58 |
var espece_defaut = <?= json_encode($espece_defaut, true) ?>;
|
|
|
59 |
var stades_defaut = <?= json_encode($stades_defaut, true) ?>;
|
330 |
aurelien |
60 |
</script>
|
|
|
61 |
</head>
|
|
|
62 |
<body>
|
|
|
63 |
<div class="conteneur">
|
|
|
64 |
<div class="conteneur-criteres">
|
|
|
65 |
|
|
|
66 |
<div class="conteneur_selecteur_especes">
|
|
|
67 |
<select id="selecteur_liste_especes">
|
333 |
aurelien |
68 |
<option value="0" class="espece_type_0" <?= $espece_defaut == null ? 'selected="selected"' : '' ?>> Choisissez une espèce </option>
|
330 |
aurelien |
69 |
<?php foreach($especes as $id_espece => $infos_espece) : ?>
|
333 |
aurelien |
70 |
<option <?= $espece_defaut == $id_espece ? 'selected="selected"' : '' ?> data-id-evenements="[<?= $infos_espece['evenements'] ?>]" value="<?= $id_espece; ?>"><?= mb_ucfirst($infos_espece['nom_vernaculaire']); ?></option>
|
330 |
aurelien |
71 |
<?php endforeach; ?>
|
|
|
72 |
</select>
|
|
|
73 |
</div>
|
|
|
74 |
|
|
|
75 |
<div class="conteneur_selecteur_stades">
|
333 |
aurelien |
76 |
<select id="selecteur_stade" class="<?= $espece_defaut == null ? 'hide' : '' ?>">
|
|
|
77 |
<option data-evenements="[]" value="0" class="stade" <?= $stades_defaut == 0 ? 'selected="selected"' : '' ?>> Choisissez un évènement </option>
|
330 |
aurelien |
78 |
<?php foreach($stades_par_type_evenement as $nom_stade => $ids_stades) : ?>
|
333 |
aurelien |
79 |
<option <?= $stades_defaut == implode(',', $ids_stades) ? 'selected="selected"' : '' ?> data-evenements="[<?= implode(',', $ids_stades); ?>]" value="<?= implode(',', $ids_stades); ?>"><?= mb_ucfirst($nom_stade); ?></option>
|
330 |
aurelien |
80 |
<?php endforeach; ?>
|
|
|
81 |
</select>
|
|
|
82 |
</div>
|
|
|
83 |
|
|
|
84 |
|
|
|
85 |
</div>
|
335 |
aurelien |
86 |
<div class="aucune-donnee hide">Aucune donnée pour les critères demandés</div>
|
330 |
aurelien |
87 |
<div id="conteneur-graphique" class="conteneur-graphique"></div>
|
|
|
88 |
</div>
|
|
|
89 |
</body>
|
|
|
90 |
</html>
|