You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
J'ai essayé de séparer une partie "graph" (plus générale) d'une partie "statistiques" plus particulière à ce graphique particulier, mais ce n'est pas évident. Le fichier prive/stats/visites charge les JS et CSS de d3 et pour notre graphique. Il crée alors de graphique des visites. Pour cela, la fonction `spip_d3_statistiques_create(id)` va - créer un objet Spip_d3_graph() notamment en indiquant la locale désirée. Cet objet est stocké dans la balise #id par un jQuery .data() pour pouvoir le réutiliser ensuite (pour ré-actualiser le graphique avec d'autres données) - déclarer comment seront préparées et traitées les données JSON reçues (ici on remplit les dates manquantes, et on actualise le tableau html et le graphique svg) - localiser les dates de d3 avec la locale demandé - préparer le code html et svg nécessaire (appelle la fonction spip_d3_statistiques_prepare_graph() qui va préparer les axes, histogramme, ligne, etc, mais sans connaître encore les données) - executer graph.updateJson(), qui va télécharger le json de données, et appliquer dessus les traitements déclarés, ce qui va in fine exécuter spip_d3_statistiques_update_graph() qui dessinera le graphique) Une navigation au dessus du graphique permet de basculer sur différentes dates et collections de données : 3 mois (90 jours), 2 ans (730 jours), 5 ans (60 mois) et infini (en années). Jusqu'à 2 ans, les données retournées par SPIP sont quotidiennes. En demandant 5 ans, on obtient 60 mois (avec la somme cumulée des visites sur le premier jour du mois) ; en demandant infini (durée -1), on obtient des visites annuelles : ce choix n'est pas anodin car il correspond très exactement à ce qui est proposé en archivage des statistiques : les statistiques de plus de 2 ans sont regroupées en début de mois, et de plus de 5 ans en début d'année. De la sorte, il devrait être possible de mettre une tache périodique qui archive systématiquement les statistiques, pour alléger la base de données, tout en gardant un affichage des graphiques a peu près corrects, même si on perd une partie de l'information. |
3 years ago | |
---|---|---|
action | 3 years ago | |
base | 3 years ago | |
css | 3 years ago | |
exec | 3 years ago | |
formulaires | 3 years ago | |
genie | 3 years ago | |
inc | 3 years ago | |
javascript | 3 years ago | |
lang | 4 years ago | |
lib/d3 | 3 years ago | |
prive | 3 years ago | |
public | 3 years ago | |
engines-list.txt | 5 years ago | |
paquet.xml | 3 years ago | |
statistiques.csv.html | 3 years ago | |
statistiques.json.html | 3 years ago | |
statistiques.json_fonctions.php | 3 years ago | |
stats_administrations.php | 3 years ago | |
stats_autoriser.php | 5 years ago | |
stats_ieconfig.php | 5 years ago | |
stats_pipelines.php | 3 years ago |