-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathindex.php
143 lines (115 loc) · 5.02 KB
/
index.php
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
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
<?php
// import des fonctions PHP
include_once './functions.php';
?>
<!DOCTYPE html>
<html lang="fr">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Opendata Census</title>
<!-- LIBRAIRIES -->
<link rel="stylesheet" href="./libs/bootstrap/css/bootstrap-reboot.min.css">
<link rel="stylesheet" href="./libs/bootstrap/css/bootstrap.min.css">
<link rel="stylesheet" href="./libs/datatables/datatables.css">
<link rel="stylesheet" href="./assets/style.css">
<link href="https://fonts.googleapis.com/css?family=Montserrat:600|Oswald:600&display=swap" rel="stylesheet">
</head>
<body>
<?php include_once './include/navigation.php'; ?>
<?php
// Obtenir le nom de tous les fichiers contenus dans le repertoire 'data'
$content_repo = get_all_file_names('./data/');
// Avec chacun des fichiers, remplir le tableau '$all_JSON_content',
// il contient dorénavant l'ensemble de la data issue de tous les fichiers
$all_JSON_content = [];
foreach ($content_repo as $tab_index => $JSON_file_name) {
$json_content = JSON_file_to_array('./data/' . $JSON_file_name);
// si le fichier n'existe pas
// si les champs 'lieu' ou 'categorie' du JSON sont vides, le fichier n'est pas
// enregistré pour être affiché dans le tableau
if (!$json_content || empty($json_content['ville']) || empty($json_content['categorie'])) {
continue;
}
array_push($all_JSON_content, $json_content);
}
// Extraire la liste des catégories et villes stockées,
// en fonction de leur clé
$tab_categories = find_all_keys($all_JSON_content, 'categorie');
$tab_villes = find_all_keys($all_JSON_content, 'ville');
?>
<div class="cParallaxe">
<div class="d-flex flex-column justify-content-around align-items-center petitbouton">
<h1 class="titre-site">Opendata Census France</h1>
<button type="button" class="btn btn-dark" onclick="scrollToTable();">Accéder aux données</button>
<p class="text-intro col-md-5">Analyse de <span class="badge badge-secondary"><?= count($content_repo); ?> jeux de données</span> ouverts portés par <span class="badge badge-secondary"><?= count($tab_villes); ?> communes françaises</span> de plus de 100 000 habitants : Horaires des transports en commun, budget administratif… 15 thématiques sont analysées dans un tableau dynamique donnant une vue d’ensemble sur l’open-data en France.</p>
</div>
</div>
<table class="table" id="tab">
<thead class="thead-dark">
<tr>
<th scope="col">Ville</th>
<?php foreach ($tab_categories as $categorie): ?>
<th><span class="text-rotate"><?= $categorie ?></span></th>
<?php endforeach; ?>
<th>Total</th>
<th>Taux<br/>d'ouverture</th>
</tr>
</thead>
<tbody>
<?php foreach ($tab_villes as $ville): ?>
<tr>
<th scope="row"><?= $ville ?></th>
<?php foreach ($tab_categories as $categorie): ?>
<td class="sum-cell">
<?php
$infos = find_infos($all_JSON_content, $ville, $categorie);
echo $infos['HTML']; // lien et Poppover du set de données
echo $infos['score']; // score du set de données
?>
</td>
<?php endforeach; ?>
<th class="total-row">0</th>
<th class="total-open-row">0</th>
</tr>
<?php endforeach; ?>
</tbody>
<tfoot>
<tr>
<th>Moyenne : </th>
<?php foreach ($tab_categories as $categorie): ?>
<th class="total-col">0</th>
<?php endforeach; ?>
<th></th>
</tr>
</tfoot>
</table>
<?php include_once './include/footer.html' ?>
<!-- LIBRAIRIES -->
<script src="./libs/jquery.min.js"></script>
<script src="./libs/popper.min.js"></script>
<script src="./libs/bootstrap/js/bootstrap.bundle.min.js"></script>
<script src="./libs/bootstrap/js/bootstrap.min.js"></script>
<script src="https://cdn.datatables.net/1.10.20/js/jquery.dataTables.min.js"></script>
<script src="./assets/table.js"></script>
<script>
$(document).ready( function () {
// activation du tableau
var table = $('#tab').DataTable({
paging: false,
searching: false
});
// calcul et affichage des totaux
showTotals();
});
function scrollToTable() {
window.scrollTo({
top: document.querySelector('#tab').offsetTop - 50,
behavior: 'smooth'
});
}
// activation des Poppovers
$('[data-toggle="popover"]').popover({ trigger: "hover", html:true });
</script>
</body>
</html>