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.
- territories_dashboard_lib/indicators_lib/enums.py +26 -0
- territories_dashboard_lib/indicators_lib/export.py +3 -3
- territories_dashboard_lib/indicators_lib/migrations/0002_filter_color_indicator_min_mesh_and_more.py +28 -0
- territories_dashboard_lib/indicators_lib/models.py +12 -2
- territories_dashboard_lib/indicators_lib/query/commons.py +8 -2
- territories_dashboard_lib/indicators_lib/query/details.py +11 -5
- territories_dashboard_lib/indicators_lib/query/top_10.py +6 -2
- territories_dashboard_lib/indicators_lib/refresh_filters.py +1 -1
- territories_dashboard_lib/indicators_lib/views.py +10 -8
- territories_dashboard_lib/tracking_lib/enums.py +10 -0
- territories_dashboard_lib/tracking_lib/payloads.py +10 -0
- territories_dashboard_lib/tracking_lib/urls.py +9 -0
- territories_dashboard_lib/tracking_lib/views.py +43 -0
- territories_dashboard_lib/website_lib/migrations/0002_mainconf_contact_email_mainconf_newsletter_link_and_more.py +28 -0
- territories_dashboard_lib/website_lib/migrations/0003_alter_mainconf_footer_navigation_and_more.py +23 -0
- territories_dashboard_lib/website_lib/models.py +16 -2
- territories_dashboard_lib/website_lib/params.py +26 -10
- territories_dashboard_lib/website_lib/serializers.py +2 -0
- territories_dashboard_lib/website_lib/static/territories_dashboard_lib/website/css/website.css +24 -3
- territories_dashboard_lib/website_lib/static/territories_dashboard_lib/website/js/pages/indicators/comparaison/page.mjs +3 -1
- territories_dashboard_lib/website_lib/static/territories_dashboard_lib/website/js/pages/indicators/details/page.mjs +3 -1
- territories_dashboard_lib/website_lib/static/territories_dashboard_lib/website/js/pages/indicators/export-graph.mjs +10 -1
- territories_dashboard_lib/website_lib/static/territories_dashboard_lib/website/js/pages/indicators/theme/page.mjs +3 -1
- territories_dashboard_lib/website_lib/static/territories_dashboard_lib/website/js/pages/indicators/utils.mjs +3 -6
- territories_dashboard_lib/website_lib/static/territories_dashboard_lib/website/react/indicatorMap.bundle.js +1 -1
- territories_dashboard_lib/website_lib/static/territories_dashboard_lib/website/react/sankeyGraph.bundle.js +1 -1
- territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/layout/footer.html +1 -1
- territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/pages/indicators/comparaison/[theme]/components/histogram.html +28 -0
- territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/pages/indicators/comparaison/[theme]/components/indicateur-card.html +2 -23
- territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/pages/indicators/components/chart-buttons.html +1 -0
- territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/pages/indicators/details/components/histogram.html +21 -0
- territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/pages/indicators/details/components/map.html +10 -0
- territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/pages/indicators/details/components/proportions.html +21 -0
- territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/pages/indicators/details/components/sankey.html +17 -0
- territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/pages/indicators/details/components/table-flows.html +8 -0
- territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/pages/indicators/details/components/table-values.html +17 -0
- territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/pages/indicators/details/components/top10.html +19 -0
- territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/pages/indicators/details/page.html +7 -64
- territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/pages/indicators/themes/components/indicateur-card.html +22 -25
- territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/pages/indicators/themes/components/stats.html +12 -0
- territories_dashboard_lib/website_lib/templatetags/other_filters.py +8 -0
- {territories_dashboard_lib-0.1.3.dist-info → territories_dashboard_lib-0.1.5.dist-info}/METADATA +113 -11
- {territories_dashboard_lib-0.1.3.dist-info → territories_dashboard_lib-0.1.5.dist-info}/RECORD +45 -30
- {territories_dashboard_lib-0.1.3.dist-info → territories_dashboard_lib-0.1.5.dist-info}/WHEEL +0 -0
- {territories_dashboard_lib-0.1.3.dist-info → territories_dashboard_lib-0.1.5.dist-info}/top_level.txt +0 -0
territories_dashboard_lib/website_lib/templates/territories_dashboard_lib/website/layout/footer.html
CHANGED
|
@@ -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
|
-
|
|
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,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
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
{%
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
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
|
-
|
|
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
|
-
|
|
46
|
-
<
|
|
47
|
-
<
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
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
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
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
|
-
|
|
64
|
-
|
|
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
|
{territories_dashboard_lib-0.1.3.dist-info → territories_dashboard_lib-0.1.5.dist-info}/METADATA
RENAMED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: territories-dashboard-lib
|
|
3
|
-
Version: 0.1.
|
|
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
|
-
#
|
|
88
|
+
# Tableau de bord des indicateurs territoriaux
|
|
89
89
|
|
|
90
|
-
|
|
90
|
+
## Présentation
|
|
91
91
|
|
|
92
|
-
|
|
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
|
-
|
|
94
|
+
### 1. `territories_dashboard_lib`
|
|
95
95
|
|
|
96
|
-
|
|
97
|
-
|
|
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
|
-
|
|
99
|
+
### 2. `territories_dashboard_template`
|
|
101
100
|
|
|
102
|
-
|
|
103
|
-
|
|
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/*`
|