territories-dashboard-lib 0.1.3__py3-none-any.whl → 0.1.5__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of territories-dashboard-lib might be problematic. Click here for more details.

Files changed (45) hide show
  1. territories_dashboard_lib/indicators_lib/enums.py +26 -0
  2. territories_dashboard_lib/indicators_lib/export.py +3 -3
  3. territories_dashboard_lib/indicators_lib/migrations/0002_filter_color_indicator_min_mesh_and_more.py +28 -0
  4. territories_dashboard_lib/indicators_lib/models.py +12 -2
  5. territories_dashboard_lib/indicators_lib/query/commons.py +8 -2
  6. territories_dashboard_lib/indicators_lib/query/details.py +11 -5
  7. territories_dashboard_lib/indicators_lib/query/top_10.py +6 -2
  8. territories_dashboard_lib/indicators_lib/refresh_filters.py +1 -1
  9. territories_dashboard_lib/indicators_lib/views.py +10 -8
  10. territories_dashboard_lib/tracking_lib/enums.py +10 -0
  11. territories_dashboard_lib/tracking_lib/payloads.py +10 -0
  12. territories_dashboard_lib/tracking_lib/urls.py +9 -0
  13. territories_dashboard_lib/tracking_lib/views.py +43 -0
  14. territories_dashboard_lib/website_lib/migrations/0002_mainconf_contact_email_mainconf_newsletter_link_and_more.py +28 -0
  15. territories_dashboard_lib/website_lib/migrations/0003_alter_mainconf_footer_navigation_and_more.py +23 -0
  16. territories_dashboard_lib/website_lib/models.py +16 -2
  17. territories_dashboard_lib/website_lib/params.py +26 -10
  18. territories_dashboard_lib/website_lib/serializers.py +2 -0
  19. territories_dashboard_lib/website_lib/static/territories_dashboard_lib/website/css/website.css +24 -3
  20. territories_dashboard_lib/website_lib/static/territories_dashboard_lib/website/js/pages/indicators/comparaison/page.mjs +3 -1
  21. territories_dashboard_lib/website_lib/static/territories_dashboard_lib/website/js/pages/indicators/details/page.mjs +3 -1
  22. territories_dashboard_lib/website_lib/static/territories_dashboard_lib/website/js/pages/indicators/export-graph.mjs +10 -1
  23. territories_dashboard_lib/website_lib/static/territories_dashboard_lib/website/js/pages/indicators/theme/page.mjs +3 -1
  24. territories_dashboard_lib/website_lib/static/territories_dashboard_lib/website/js/pages/indicators/utils.mjs +3 -6
  25. territories_dashboard_lib/website_lib/static/territories_dashboard_lib/website/react/indicatorMap.bundle.js +1 -1
  26. territories_dashboard_lib/website_lib/static/territories_dashboard_lib/website/react/sankeyGraph.bundle.js +1 -1
  27. territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/layout/footer.html +1 -1
  28. territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/pages/indicators/comparaison/[theme]/components/histogram.html +28 -0
  29. territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/pages/indicators/comparaison/[theme]/components/indicateur-card.html +2 -23
  30. territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/pages/indicators/components/chart-buttons.html +1 -0
  31. territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/pages/indicators/details/components/histogram.html +21 -0
  32. territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/pages/indicators/details/components/map.html +10 -0
  33. territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/pages/indicators/details/components/proportions.html +21 -0
  34. territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/pages/indicators/details/components/sankey.html +17 -0
  35. territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/pages/indicators/details/components/table-flows.html +8 -0
  36. territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/pages/indicators/details/components/table-values.html +17 -0
  37. territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/pages/indicators/details/components/top10.html +19 -0
  38. territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/pages/indicators/details/page.html +7 -64
  39. territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/pages/indicators/themes/components/indicateur-card.html +22 -25
  40. territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/pages/indicators/themes/components/stats.html +12 -0
  41. territories_dashboard_lib/website_lib/templatetags/other_filters.py +8 -0
  42. {territories_dashboard_lib-0.1.3.dist-info → territories_dashboard_lib-0.1.5.dist-info}/METADATA +113 -11
  43. {territories_dashboard_lib-0.1.3.dist-info → territories_dashboard_lib-0.1.5.dist-info}/RECORD +45 -30
  44. {territories_dashboard_lib-0.1.3.dist-info → territories_dashboard_lib-0.1.5.dist-info}/WHEEL +0 -0
  45. {territories_dashboard_lib-0.1.3.dist-info → territories_dashboard_lib-0.1.5.dist-info}/top_level.txt +0 -0
@@ -1,5 +1,5 @@
1
1
  <footer role="contentinfo" id="page-footer">
2
- {% if view_name != "website:superset" %}
2
+ {% if view_name != "website:superset" and main_conf.show_footer_contact_banner and main_conf.newsletter_link and main_conf.contact_email %}
3
3
  <div class="fr-follow fr-pt-8w">
4
4
  <h2 class="fr-sr-only">Contact</h2>
5
5
  <div class="fr-container">
@@ -0,0 +1,28 @@
1
+ {% load other_filters %}
2
+
3
+ <section class="fr-accordion tdbmd-indicator-accordion tdbmd-indicator-accordion-comparison">
4
+ <h3 class="fr-accordion__title">
5
+ <button
6
+ class="fr-accordion__btn border-top"
7
+ aria-expanded="false"
8
+ aria-controls="accordion-{{indicator.id}}"
9
+ aria-label="Répartition des valeurs - {{ indicator.title }}"
10
+ >
11
+ Répartition des valeurs
12
+ </button>
13
+ </h3>
14
+ <div
15
+ class="fr-collapse"
16
+ id="accordion-{{indicator.id}}"
17
+ >
18
+ {% include "territories_dashboard_lib/website/pages/indicators/components/title.html" with title="Répartition des territoires selon les valeurs de l'indicateur (graphique en “miroir”)" key=indicator.name h4=True text="Survolez les barres du graphique pour afficher le nombre de territoires dans chaque classe de valeurs (le nom des territoires s'affiche s'il y a moins de 6 territoires). Le graphique du haut correspond à la répartition pour le territoire 1 sélectionné, alors que le graphique du bas (en “miroir”) correspond à la répartition pour le territoire 2 de comparaison. Précisions : Ce graphique varie selon la maille sélectionnée." %}
19
+ {% if params|should_mesh_analysis:indicator %}
20
+ <div style="width: 100%; height: 500px; margin-top: -1rem;">
21
+ <canvas class="comparison-chart" aria-describedby="{{indicator.id}}comparison-histogram-export-csv"></canvas>
22
+ </div>
23
+ {% include "territories_dashboard_lib/website/pages/indicators/components/chart-buttons.html" with name="Comparaison de la répartition" route="comparison-histogram" indicator=indicator pattern="show" tracking_objet="comparison-histogram" %}
24
+ {% else %}
25
+ <div style="margin-top: 16px;">L'histogramme de comparaison n'est pas disponible à la maille sélectionnée.</div>
26
+ {% endif %}
27
+ </div>
28
+ </section>
@@ -16,32 +16,11 @@
16
16
  <div style="height: 300px;">
17
17
  <canvas class="history-chart" aria-describedby="{{indicator.id}}values-export-csv"></canvas>
18
18
  </div>
19
- {% include "territories_dashboard_lib/website/pages/indicators/components/chart-buttons.html" with name="Historique comparaison" route="values" indicator=indicator pattern="show" %}
19
+ {% include "territories_dashboard_lib/website/pages/indicators/components/chart-buttons.html" with name="Historique comparaison" route="values" indicator=indicator pattern="show" tracking_objet="comparaison-historique" %}
20
20
  {% endhtmlparam %}
21
21
 
22
22
  {% htmlparam footer %}
23
- <section class="fr-accordion tdbmd-indicator-accordion tdbmd-indicator-accordion-comparison">
24
- <h3 class="fr-accordion__title">
25
- <button
26
- class="fr-accordion__btn border-top"
27
- aria-expanded="false"
28
- aria-controls="accordion-{{indicator.id}}"
29
- aria-label="Répartition des valeurs - {{ indicator.title }}"
30
- >
31
- Répartition des valeurs
32
- </button>
33
- </h3>
34
- <div
35
- class="fr-collapse"
36
- id="accordion-{{indicator.id}}"
37
- >
38
- {% include "territories_dashboard_lib/website/pages/indicators/components/title.html" with title="Répartition des territoires selon les valeurs de l'indicateur (graphique en “miroir”)" key=indicator.name h4=True text="Survolez les barres du graphique pour afficher le nombre de territoires dans chaque classe de valeurs (le nom des territoires s'affiche s'il y a moins de 6 territoires). Le graphique du haut correspond à la répartition pour le territoire 1 sélectionné, alors que le graphique du bas (en “miroir”) correspond à la répartition pour le territoire 2 de comparaison. Précisions : Ce graphique varie selon la maille sélectionnée." %}
39
- <div style="width: 100%; height: 500px; margin-top: -1rem;">
40
- <canvas class="comparison-chart" aria-describedby="{{indicator.id}}comparison-histogram-export-csv"></canvas>
41
- </div>
42
- {% include "territories_dashboard_lib/website/pages/indicators/components/chart-buttons.html" with name="Comparaison de la répartition" route="comparison-histogram" indicator=indicator pattern="show" %}
43
- </div>
44
- </section>
23
+ {% include "./histogram.html" %}
45
24
  {% endhtmlparam %}
46
25
 
47
26
  {% include "territories_dashboard_lib/website/pages/indicators/components/indicator-card.html" with indicator=indicator %}
@@ -2,6 +2,7 @@
2
2
  <button
3
3
  aria-label="Exporter le graphique {{ name }} en png{% if not one_indicator %} - {{ indicator.title }}{% endif %}"
4
4
  data-title="{{ name }}"
5
+ data-trackingobjet="{{ tracking_objet }}"
5
6
  data-type="export-png"
6
7
  class="fr-btn fr-btn--secondary fr-btn--sm fr-icon-image-line fr-btn--icon-right btn-download">
7
8
  Exporter le graphique en png
@@ -0,0 +1,21 @@
1
+ {% load other_filters %}
2
+
3
+ {% if params.mesh != params.territory_mesh and params|should_mesh_analysis:indicator %}
4
+ <div id="histogramContainer" class="subtheme">
5
+ <div class="fr-px-md-4w fr-px-2w fr-py-2w">
6
+ {% include "territories_dashboard_lib/website/pages/indicators/components/title.html" with title="Répartition des territoires selon les valeurs de l'indicateur" key="repartition" text="Le nom des territoires s'affiche au survol ds'il y a moins de 6 territoires. Précisions : Ce graphique varie selon la maille sélectionnée." %}
7
+ <div style="width:100%; height: 400px;">
8
+ <canvas id="histogramChart" aria-describedby="histogram-export-csv"></canvas>
9
+ </div>
10
+ {% include "./filters-reminder.html" %}
11
+ </div>
12
+ {% include "territories_dashboard_lib/website/pages/indicators/components/chart-buttons.html" with name="Répartition par valeurs" route="histogram" one_indicator=True tracking_objet="repartition-valeurs" %}
13
+ </div>
14
+ {% else %}
15
+ <div class="subtheme">
16
+ <div class="fr-px-md-4w fr-px-2w fr-py-2w">
17
+ <h3 class="fr-mt-4w">Répartition par territoires</h3>
18
+ <div>La répartition n'est pas disponible pour la maille sélectionnée.</div>
19
+ </div>
20
+ </div>
21
+ {% endif %}
@@ -0,0 +1,10 @@
1
+ {% load other_filters %}
2
+
3
+ <div class="subtheme fr-px-md-4w fr-p-2w">
4
+ {% if params|should_mesh_analysis:indicator %}
5
+ <div id="indicator-map"></div>
6
+ {% else %}
7
+ <h3 class="fr-mt-4w">Carte</h3>
8
+ <div>La carte n'est pas disponible pour la maille sélectionnée.</div>
9
+ {% endif %}
10
+ </div>
@@ -0,0 +1,21 @@
1
+ {% load other_filters %}
2
+
3
+ {% if indicator.filters %}
4
+ <div class="subtheme">
5
+ {% if params|should_mesh_analysis:indicator %}
6
+ <div class="fr-px-md-4w fr-px-2w fr-py-2w">
7
+ {% include "territories_dashboard_lib/website/pages/indicators/components/title.html" with title="Répartition des valeurs de l'indicateur selon ses modalités" key="proportions" text="Survolez le graphique pour afficher les valeurs de l'indicateur pour chaque modalité. Cliquez sur les catégories de la légende pour afficher/masquer des modalités." %}
8
+ <div style="width:100%; height: auto;">
9
+ <canvas id="proportionsChart" aria-describedby="proportions-export-csv"></canvas>
10
+ </div>
11
+ {% include "./filters-reminder.html" %}
12
+ </div>
13
+ {% include "territories_dashboard_lib/website/pages/indicators/components/chart-buttons.html" with name="Répartition par dimensions" route="proportions" pattern="show" one_indicator=True tracking_objet="repartition-dimension" %}
14
+ {% else %}
15
+ <div class="fr-px-md-4w fr-px-2w fr-py-2w">
16
+ <h3 class="fr-mt-4w">Proportions</h3>
17
+ <div>Le graphique de proporition n'est pas disponible pour la maille sélectionnée.</div>
18
+ </div>
19
+ {% endif %}
20
+ </div>
21
+ {% endif %}
@@ -0,0 +1,17 @@
1
+ {% load other_filters %}
2
+
3
+ {% if indicator.flows_db_table_prefix %}
4
+ <div class="subtheme">
5
+ <div class="fr-px-md-4w fr-px-2w fr-py-2w">
6
+ {% include "territories_dashboard_lib/website/pages/indicators/components/title.html" with title="Top 10 des flux par origine-destination (diagramme de Sankey)" key="sankey" text="Survolez les flux sur le graphique pour afficher les valeurs. Vous pouvez filtrer selon le mode de déplacement en sélectionnant les filtres disponibles sous le titre du graphique. Précisions : Seuls les flux entre les 10 territoires qui génèrent le plus de flux depuis/vers le territoire sélectionné sont affichés." %}
7
+ <div style="width:100%; height: auto;">
8
+ <div id="sankey-graph"></div>
9
+ </div>
10
+ </div>
11
+ <button
12
+ data-title="Sankey"
13
+ class="fr-btn fr-btn--secondary fr-btn--sm fr-icon-line-chart-line fr-btn--icon-right fr-mx-4w fr-mt-4w fr-mb-4w btn-download">
14
+ <span>Exporter le graphique</span>
15
+ </button>
16
+ </div>
17
+ {% endif %}
@@ -0,0 +1,8 @@
1
+ {% if indicator.flows_db_table_prefix %}
2
+ <div class="subtheme">
3
+ <div class="fr-px-md-4w fr-px-2w fr-py-2w">
4
+ <h3 class="fr-mt-4w">Tableau des flux</h3>
5
+ <div class="data-table" data-source="flows"></div>
6
+ </div>
7
+ </div>
8
+ {% endif %}
@@ -0,0 +1,17 @@
1
+ {% load other_filters %}
2
+
3
+ {% if params|should_mesh_analysis:indicator %}
4
+ <div class="subtheme" id="values-table-section">
5
+ <div class="fr-px-md-4w fr-px-2w fr-py-2w">
6
+ <h3 class="fr-mt-4w">Tableau des valeurs de l'indicateur</h3>
7
+ <div class="data-table" data-source="indicator"></div>
8
+ </div>
9
+ </div>
10
+ {% else %}
11
+ <div class="subtheme">
12
+ <div class="fr-px-md-4w fr-px-2w fr-py-2w">
13
+ <h3 class="fr-mt-4w">Tableau des valeurs de l'indicateur</h3>
14
+ <div>Le tableau n'est pas disponible pour la maille sélectionnée.</div>
15
+ </div>
16
+ </div>
17
+ {% endif %}
@@ -0,0 +1,19 @@
1
+ {% load other_filters %}
2
+
3
+ <div class="subtheme">
4
+ {% if params.mesh != params.territory_mesh and params|should_mesh_analysis:indicator %}
5
+ <div class="fr-px-md-4w fr-px-2w fr-py-2w">
6
+ {% include "territories_dashboard_lib/website/pages/indicators/components/title.html" with title="Top 10 des territoires" key="top10" text="Survolez les graphiques pour afficher les valeurs de l'indicateur pour chaque modalité. Cliquez sur les catégories de la légende pour afficher/masquer des modalités. Précisions : Ce graphique varie selon la maille sélectionnée." %}
7
+ <div style="width:100%; height: auto;">
8
+ <canvas id="top10Chart" aria-describedby="top-10-export-csv"></canvas>
9
+ </div>
10
+ {% include "./filters-reminder.html" %}
11
+ </div>
12
+ {% include "territories_dashboard_lib/website/pages/indicators/components/chart-buttons.html" with name="Top 10" route="top-10" pattern="show" one_indicator=True tracking_objet="top_10" %}
13
+ {% else %}
14
+ <div class="fr-px-md-4w fr-px-2w fr-py-2w">
15
+ <h3 class="fr-mt-4w">Top 10</h3>
16
+ <div>Le top 10 n'est pas disponible pour la maille sélectionnée.</div>
17
+ </div>
18
+ {% endif %}
19
+ </div>
@@ -93,70 +93,13 @@
93
93
  {% endfor %}
94
94
  </div>
95
95
  </div>
96
- <div class="subtheme fr-px-md-4w fr-p-2w">
97
- <div id="indicator-map"></div>
98
- </div>
99
- {% if indicator.flows_db_table_prefix %}
100
- <div class="subtheme">
101
- <div class="fr-px-md-4w fr-px-2w fr-py-2w">
102
- {% include "territories_dashboard_lib/website/pages/indicators/components/title.html" with title="Top 10 des flux par origine-destination (diagramme de Sankey)" key="sankey" text="Survolez les flux sur le graphique pour afficher les valeurs. Vous pouvez filtrer selon le mode de déplacement en sélectionnant les filtres disponibles sous le titre du graphique. Précisions : Seuls les flux entre les 10 territoires qui génèrent le plus de flux depuis/vers le territoire sélectionné sont affichés." %}
103
- <div style="width:100%; height: auto;">
104
- <div id="sankey-graph"></div>
105
- </div>
106
- </div>
107
- <button
108
- data-title="Sankey"
109
- class="fr-btn fr-btn--secondary fr-btn--sm fr-icon-line-chart-line fr-btn--icon-right fr-mx-4w fr-mt-4w fr-mb-4w btn-download">
110
- <span>Exporter le graphique</span>
111
- </button>
112
- </div>
113
- {% endif %}
114
- {% if indicator.filters %}
115
- <div class="subtheme">
116
- <div class="fr-px-md-4w fr-px-2w fr-py-2w">
117
- {% include "territories_dashboard_lib/website/pages/indicators/components/title.html" with title="Répartition des valeurs de l'indicateur selon ses modalités" key="proportions" text="Survolez le graphique pour afficher les valeurs de l'indicateur pour chaque modalité. Cliquez sur les catégories de la légende pour afficher/masquer des modalités." %}
118
- <div style="width:100%; height: auto;">
119
- <canvas id="proportionsChart" aria-describedby="proportions-export-csv"></canvas>
120
- </div>
121
- {% include "./components/filters-reminder.html" %}
122
- </div>
123
- {% include "territories_dashboard_lib/website/pages/indicators/components/chart-buttons.html" with name="Répartition par dimensions" route="proportions" pattern="show" one_indicator=True %}
124
- </div>
125
- {% endif %}
126
- <div class="subtheme">
127
- <div class="fr-px-md-4w fr-px-2w fr-py-2w">
128
- {% include "territories_dashboard_lib/website/pages/indicators/components/title.html" with title="Top 10 des territoires" key="top10" text="Survolez les graphiques pour afficher les valeurs de l'indicateur pour chaque modalité. Cliquez sur les catégories de la légende pour afficher/masquer des modalités. Précisions : Ce graphique varie selon la maille sélectionnée." %}
129
- <div style="width:100%; height: auto;">
130
- <canvas id="top10Chart" aria-describedby="top-10-export-csv"></canvas>
131
- </div>
132
- {% include "./components/filters-reminder.html" %}
133
- </div>
134
- {% include "territories_dashboard_lib/website/pages/indicators/components/chart-buttons.html" with name="Top 10" route="top-10" pattern="show" one_indicator=True %}
135
- </div>
136
- <div id="histogramContainer" class="subtheme">
137
- <div class="fr-px-md-4w fr-px-2w fr-py-2w">
138
- {% include "territories_dashboard_lib/website/pages/indicators/components/title.html" with title="Répartition des territoires selon les valeurs de l'indicateur" key="repartition" text="Le nom des territoires s'affiche au survol ds'il y a moins de 6 territoires. Précisions : Ce graphique varie selon la maille sélectionnée." %}
139
- <div style="width:100%; height: 400px;">
140
- <canvas id="histogramChart" aria-describedby="histogram-export-csv"></canvas>
141
- </div>
142
- {% include "./components/filters-reminder.html" %}
143
- </div>
144
- {% include "territories_dashboard_lib/website/pages/indicators/components/chart-buttons.html" with name="Répartition par valeurs" route="histogram" one_indicator=True %}
145
- </div>
146
- <div class="subtheme" id="values-table-section">
147
- <div class="fr-px-md-4w fr-px-2w fr-py-2w">
148
- <h3 class="fr-mt-4w">Tableau des valeurs de l'indicateur</h3>
149
- <div class="data-table" data-source="indicator"></div>
150
- </div>
151
- </div>
152
- {% if indicator.flows_db_table_prefix %}
153
- <div class="subtheme">
154
- <div class="fr-px-md-4w fr-px-2w fr-py-2w">
155
- <h3 class="fr-mt-4w">Tableau des flux</h3>
156
- <div class="data-table" data-source="flows"></div>
157
- </div>
158
- </div>
159
- {% endif %}
96
+ {% include "./components/map.html" %}
97
+ {% include "./components/sankey.html" %}
98
+ {% include "./components/proportions.html" %}
99
+ {% include "./components/top10.html" %}
100
+ {% include "./components/histogram.html" %}
101
+ {% include "./components/table-values.html" %}
102
+ {% include "./components/table-flows.html" %}
160
103
  </div>
161
104
  {% include "territories_dashboard_lib/website/pages/indicators/components/side_panel_geo.html" %}
162
105
  {% include "territories_dashboard_lib/website/pages/indicators/components/side_panel_methodo.html" %}
@@ -33,36 +33,33 @@
33
33
  </div>
34
34
  </div>
35
35
  </div>
36
- <section class="tdbmd-indicator-card__comparisons fr-grid-row fr-grid-row--gutters">
37
- <h4 class="fr-sr-only">Statistiques</h4>
38
- {% include "./extremum.html" with title="Minimum" prefix="min" %}
39
- {% include "./extremum.html" with title="Mediane" prefix="med" %}
40
- {% include "./extremum.html" with title="Maximum" prefix="max" %}
41
- </section>
36
+ {% include "./stats.html" %}
42
37
  {% endhtmlparam %}
43
38
 
44
39
  {% htmlparam footer %}
45
- <section class="fr-accordion tdbmd-indicator-accordion">
46
- <h4 class="fr-accordion__title">
47
- <button
48
- class="fr-accordion__btn"
49
- aria-expanded="false"
50
- aria-controls="accordion-{{indicator.id}}"
51
- aria-label="Historique - {{ indicator.title }}"
40
+ {% if indicator.show_evolution %}
41
+ <section class="fr-accordion tdbmd-indicator-accordion">
42
+ <h4 class="fr-accordion__title">
43
+ <button
44
+ class="fr-accordion__btn"
45
+ aria-expanded="false"
46
+ aria-controls="accordion-{{indicator.id}}"
47
+ aria-label="Historique - {{ indicator.title }}"
48
+ >
49
+ Historique
50
+ </button>
51
+ </h4>
52
+ <div
53
+ class="fr-collapse"
54
+ id="accordion-{{indicator.id}}"
52
55
  >
53
- Historique
54
- </button>
55
- </h4>
56
- <div
57
- class="fr-collapse"
58
- id="accordion-{{indicator.id}}"
59
- >
60
- <div style="height: 300px;">
61
- <canvas class="history-chart" aria-describedby="{{indicator.id}}values-export-csv"></canvas>
56
+ <div style="height: 300px;">
57
+ <canvas class="history-chart" aria-describedby="{{indicator.id}}values-export-csv"></canvas>
58
+ </div>
59
+ {% include "territories_dashboard_lib/website/pages/indicators/components/chart-buttons.html" with name="Historique" route="values" indicator=indicator no_pb=True tracking_objet="historique" %}
62
60
  </div>
63
- {% include "territories_dashboard_lib/website/pages/indicators/components/chart-buttons.html" with name="Historique" route="values" indicator=indicator no_pb=True %}
64
- </div>
65
- </section>
61
+ </section>
62
+ {% endif %}
66
63
  <a
67
64
  class="fr-btn fr-btn--tertiary fr-icon-external-link-fill fr-btn--icon-right tdbmd-indicator-btn"
68
65
  href="/indicateurs/details/{{indicator.name}}/"
@@ -0,0 +1,12 @@
1
+ {% load other_filters %}
2
+
3
+ {% if params.mesh != params.territory_mesh and params|should_mesh_analysis:indicator %}
4
+ <section class="tdbmd-indicator-card__comparisons fr-grid-row fr-grid-row--gutters">
5
+ <h4 class="fr-sr-only">Statistiques</h4>
6
+ {% include "./extremum.html" with title="Minimum" prefix="min" %}
7
+ {% include "./extremum.html" with title="Mediane" prefix="med" %}
8
+ {% include "./extremum.html" with title="Maximum" prefix="max" %}
9
+ </section>
10
+ {% else %}
11
+ <div>Les statistiques ne sont pas disponibles à cette maille.</div>
12
+ {% endif %}
@@ -1,5 +1,6 @@
1
1
  from django import template
2
2
  from django.urls import reverse
3
+ from territories_dashboard_lib.indicators_lib.enums import get_all_meshes
3
4
 
4
5
  register = template.Library()
5
6
 
@@ -28,3 +29,10 @@ def indicator_api_urls(indicator_dict):
28
29
  )
29
30
  for view_name in view_names
30
31
  }
32
+
33
+
34
+ @register.filter
35
+ def should_mesh_analysis(params, indicator):
36
+ meshes = get_all_meshes()
37
+ above_min_mesh = meshes.index(params["mesh"]) <= meshes.index(indicator["min_mesh"])
38
+ return above_min_mesh
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: territories-dashboard-lib
3
- Version: 0.1.3
3
+ Version: 0.1.5
4
4
  Summary: Librairie pour la visualisation d'indicateurs territoriaux.
5
5
  Author-email: Bastien <bastien@prune.sh>
6
6
  License: LICENCE OUVERTE 2.0/OPEN LICENCE 2.0
@@ -85,20 +85,122 @@ Classifier: License :: Other/Proprietary License
85
85
  Requires-Python: >=3.13
86
86
  Description-Content-Type: text/markdown
87
87
 
88
- # territories-dashboard-lib
88
+ # Tableau de bord des indicateurs territoriaux
89
89
 
90
- **Librairie Python pour créer rapidement un dashboard d'indicateurs territoriaux.**
90
+ ## Présentation
91
91
 
92
- Cette librairie permet d’analyser facilement des indicateurs sur un territoire donné, ou bien de se concentrer sur un indicateur spécifique pour une analyse détaillée.
92
+ 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 :
93
93
 
94
- ## Fonctionnalités
94
+ ### 1. `territories_dashboard_lib`
95
95
 
96
- - Création rapide de dashboards interactifs
97
- - Vue globale par territoire ou focus par indicateur
98
- - Pensée pour les projets liés à l’aménagement, à la planification ou à l’analyse territoriale
96
+ 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.
97
+ 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.
99
98
 
100
- ## 🔧 Installation
99
+ ### 2. `territories_dashboard_template`
101
100
 
102
- ```bash
103
- pip install territories-dashboard-lib
101
+ 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.
102
+ 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...).
103
+
104
+ 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.
105
+
106
+ ### Prérequis
107
+
108
+ Pour utiliser la librairie ou le template, vous devez disposer de :
109
+
110
+ - Une base de données PostgreSQL contenant les données des indicateurs territoriaux.
111
+ - Une capacité à déployer une application Django (hébergement, serveur web, etc.).
112
+
113
+ Pour obtenir des informations détaillées sur les prérequis techniques ou les données :
114
+
115
+ - **Marina Ribeiro** – Directrice de projet Mission Connaissance
116
+ marina.ribeiro@developpement-durable.gouv.fr
117
+ - **Louise Columelli** – ECOLAB
118
+ louise.columelli@developpement-durable.gouv.fr
119
+ - **Olivier Rousseau** – Expert données
120
+ olivier.rousseau@i-carre.net
121
+ - **Bastien** – Développeur web
122
+ bastien@prune.sh
123
+
124
+ ### Exemples de projets utilisant ce dispositif
125
+
126
+ - [Tableau de bord des mobilités durables](https://mobilite-durable-tdb.din.developpement-durable.gouv.fr)
127
+ - [Boussole énergétique de la rénovation des logements](https://boussole-renovation.din.developpement-durable.gouv.fr)
128
+
129
+ 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.
130
+
131
+ ## Structure de la librairie
132
+
133
+ La librairie est composée de plusieurs **applications Django** indépendantes et complémentaires :
134
+
135
+ ### `website_lib`
136
+
137
+ Contient le code principal d’affichage des pages du tableau de bord :
138
+
139
+ - **Templates HTML Django** : dans `website_lib/templates`, organisés par page.
140
+ - **Fichiers statiques** (JS, CSS) : dans `website_lib/static`. Le JS est modulaire grâce à l’extension `.mjs`.
141
+ - **Vues Django** : dans `website_lib/views`, associées aux templates et fichiers statiques.
142
+
143
+ ### `tracking_lib`
144
+
145
+ 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.
146
+
147
+ ### `superset_lib`
148
+
149
+ Permet d’**intégrer des dashboards Superset** dans les pages du site.
150
+ Superset est un outil permettant à des utilisateurs non techniques de construire des visualisations depuis une base de données.
151
+
152
+ ### `geo_lib`
153
+
154
+ Permet d’**ajouter des couches géographiques** personnalisées (points, lignes, polygones) à la carte :
155
+
156
+ - Points : ex. stationnements vélo.
157
+ - Lignes : ex. pistes cyclables.
158
+ - Polygones : ex. zones ZFE.
159
+
160
+ ### `indicators_lib`
161
+
162
+ Contient le code pour l’accès et la requête des **données d’indicateurs** dans la base PostgreSQL dédiée.
163
+
164
+ ### Composants React
165
+
166
+ Certaines visualisations complexes sont développées en **React** (ex. cartes interactives, diagrammes de Sankey).
167
+
168
+ - Les composants sont dans `website_lib/react-components/`.
169
+ - Le bundling est effectué via **Webpack**
170
+ - Les composants React sont ensuite inclus dans les templates Django.
171
+ - `cd website_lib/react-components && npm install && npm run webpack`
172
+
173
+ ## Installation
174
+
175
+ La librairie est publiée sur PyPI. Elle s’installe dans un projet Django via le package manager uv :
176
+
177
+ `uv add territories_dashboard_lib`
178
+
179
+ ### Figer la version en production
180
+
181
+ Pour éviter les mises à jour inattendues, il est conseillé de figer la version dans le fichier pyproject.toml :
182
+
183
+ ```
184
+ # Par exemple :
185
+ territories_dashboard_lib == 1.0.3
104
186
  ```
187
+
188
+ ### Développement local
189
+
190
+ Pour tester une version locale de la librairie (ex : modifications en cours) :
191
+
192
+ `uv add --editable ~/territories-dashboard/territories-dashboard-lib`
193
+
194
+ ## Publication PyPI
195
+
196
+ Pour builder la librairie avant publication :
197
+
198
+ `uv run python -m build`
199
+
200
+ Pour déployer sur PyPI, vous devez :
201
+
202
+ 1. Avoir un compte PyPI.
203
+
204
+ 2. Être membre du projet sur PyPI.
205
+
206
+ 3. Lancer : `uv run twine upload dist/*`