Skip to main content

Librairie pour la visualisation d'indicateurs territoriaux.

Project description

Tableau de bord des indicateurs territoriaux

Présentation

Bienvenue dans ce projet visant à faciliter la création de tableaux de bord territoriaux interactifs à partir de données d’indicateurs. Ce dispositif est composé de deux briques complémentaires :

1. territories_dashboard_lib

Une librairie Django réutilisable, contenant des applications modulaires pour afficher rapidement un tableau de bord d'indicateurs territoriaux. Elle permet d’analyser des données à différentes mailles géographiques : nationale, régionale, départementale, et communale.
Elle comprend des fonctionnalités prêtes à l'emploi pour visualiser des données sur des thématiques comme la mobilité durable, la rénovation énergétique ou d'autres indicateurs liés au développement territorial.

2. territories_dashboard_template

Un template de projet Django clef en main, conçu pour permettre à des équipes techniques de démarrer rapidement leur propre tableau de bord. Ce template utilise la librairie territories_dashboard_lib comme fondation.
Les utilisateurs peuvent cloner ce dépôt, l’adapter à leurs besoins, et configurer leur tableau de bord directement depuis l’interface d’administration (titre, organisme, pages de contenu statique, indicateurs à afficher...).

Le template constitue un point de départ standard, mais n’impose aucune restriction technique en dehors du choix de Django comme framework. Les développeurs sont libres d'étendre ou de modifier les composants selon leurs besoins.

Prérequis

Pour utiliser la librairie ou le template, vous devez disposer de :

  • Une base de données PostgreSQL contenant les données des indicateurs territoriaux.
  • Une capacité à déployer une application Django (hébergement, serveur web, etc.).

Pour obtenir des informations détaillées sur les prérequis techniques ou les données :

Exemples de projets utilisant ce dispositif

L’objectif de ce projet est d’encourager la réutilisation et l’essaimage de nouveaux tableaux de bord territoriaux, en mettant à disposition un socle technique commun, facilement adaptable et extensible.

Structure de la librairie

La librairie est composée de plusieurs applications Django indépendantes et complémentaires :

website_lib

Contient le code principal d’affichage des pages du tableau de bord :

  • Templates HTML Django : dans website_lib/templates, organisés par page.
  • Fichiers statiques (JS, CSS) : dans website_lib/static. Le JS est modulaire grâce à l’extension .mjs.
  • Vues Django : dans website_lib/views, associées aux templates et fichiers statiques.

tracking_lib

Gère le tracking backend : enregistrement en base de données des visites de pages, avec leurs paramètres (indicateur sélectionné, territoire, etc.) pour permettre des analyses d’usage.

superset_lib

Permet d’intégrer des dashboards Superset dans les pages du site.
Superset est un outil permettant à des utilisateurs non techniques de construire des visualisations depuis une base de données.

geo_lib

Permet d’ajouter des couches géographiques personnalisées (points, lignes, polygones) à la carte :

  • Points : ex. stationnements vélo.
  • Lignes : ex. pistes cyclables.
  • Polygones : ex. zones ZFE.

indicators_lib

Contient le code pour l’accès et la requête des données d’indicateurs dans la base PostgreSQL dédiée.

Composants React

Certaines visualisations complexes sont développées en React (ex. cartes interactives, diagrammes de Sankey).

  • Les composants sont dans website_lib/react-components/.
  • Le bundling est effectué via Webpack
  • Les composants React sont ensuite inclus dans les templates Django.
  • cd website_lib/react-components && npm install && npm run webpack

Installation

La librairie est publiée sur PyPI. Elle s’installe dans un projet Django via le package manager uv :

uv add territories_dashboard_lib

Figer la version en production

Pour éviter les mises à jour inattendues, il est conseillé de figer la version dans le fichier pyproject.toml :

# Par exemple :
territories_dashboard_lib == 1.0.3

Développement local

Pour tester une version locale de la librairie (ex : modifications en cours) :

uv add --editable ~/territories-dashboard/territories-dashboard-lib

Publication PyPI

Pour builder la librairie avant publication :

uv run python -m build

Pour déployer sur PyPI, vous devez :

  1. Avoir un compte PyPI.

  2. Être membre du projet sur PyPI.

  3. Lancer : uv run twine upload dist/*

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

territories_dashboard_lib-0.1.8.tar.gz (1.4 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

territories_dashboard_lib-0.1.8-py3-none-any.whl (1.5 MB view details)

Uploaded Python 3

File details

Details for the file territories_dashboard_lib-0.1.8.tar.gz.

File metadata

File hashes

Hashes for territories_dashboard_lib-0.1.8.tar.gz
Algorithm Hash digest
SHA256 061c0e98366ac6fe41d1314abf3c45d8624c3e3f4bb9c598576d3f06353de95f
MD5 0f6a81e1f9c8949e520e23ac784e3282
BLAKE2b-256 692657f70a180366b89d3305fd68eec4409334dadb8bf338f4e06c7dc3c9cc59

See more details on using hashes here.

File details

Details for the file territories_dashboard_lib-0.1.8-py3-none-any.whl.

File metadata

File hashes

Hashes for territories_dashboard_lib-0.1.8-py3-none-any.whl
Algorithm Hash digest
SHA256 a3e50c7f523175281a5bd46b258db5e3faccb6ab9e3633254cb375a98722bc37
MD5 1c972017a7ae0102cc8d670828292342
BLAKE2b-256 dd51796b9e01e5098c8c4305dff5fd582c96f773d8c4452291b81cb5638fce37

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page