Skip to content

Latest commit

 

History

History
155 lines (94 loc) · 3.61 KB

README.md

File metadata and controls

155 lines (94 loc) · 3.61 KB

Etude des centres de recherche en Sciences Politiques

Réalisée par la Bibliothèque de Sciences Po Paris en collaboration avec le Medialab

Site public: https://cartosciencepolitique.sciencespo.fr

Installation

À la racine du projet :

npm install

À la racine du projet :

npx bower install

Copier le fichier app/conf/conf.default.js vers app/conf/conf.js.

Editer app/conf/conf.js et remplacer :

  • GOOGLE_ANALYTICS_ID par votre Id Google Analytics de la forme UA-XXXXXXX-XX
  • BACK_OFFICE_BASEURL par l'url sur laquelle sera servie le backoffice, exemple http://localhost:42000

Selon l'environnement, initialiser le dossier des logos :

  • Copier app/img/logos-default vers app/img/logos
  • Vérifier que ce dossier sera bien accessible en écriture par le processus du backoffice
  • Note pour Docker : initialiser le volume correspondant avec les images par défaut

Lancement de l'app (front)

npm start

Par défaut, gulp effectue les tâches de concaténations et minification js puis des css, copie les assets et finalement lance l'application en démarrant un serveur qui possède le livereload.

Concaténation et minification de tous les JS

npx gulp js

Conversion du fichier de style principal du less en CSS

npx gulp less

Concaténation et minificaton de tous les css

npx gulp css

Copie une image ainsi les polices d'écriture dans le dossier "assets"

npx gulp assets

Démarre le serveur avec livereload

npx gulp serve

Création des données

npm run parse

Long version:

Ajouter dans /app/data tous les CSV générés à partir des onglets du spreadsheet du drive.

Dans le dossier /app/data, lancer le script suivant (requiert l'installation de NodeJS) :

node script_data_csv_to_json.js

La sortie est app/data/data.json qui comprend :

  • Un objet avec tous les centres en clés qui contiennent eux-mêmes leurs onglets en clés.
  • Un index de toutes les propriétés de tous les centres afin de faciliter la recherche fulltext.
  • Un tableau de tous les mots de toutes ces propriétés pour l'auto-complétion dans la recherche fulltext.

Création des métadonnées

Ajouter dans /app/data le csv listant les props et le nommer metadata.csv

Lancer le script suivant dans /app/data :

node script_metadata_csv_to_json.js

La sortie est app/data/metadata.json.

Parsing des csv issus de la collecte des données

Réalisé avec BabyParse https://github.com/Rich-Harris/BabyParse

Création de l'index de recherche fulltext

Réalisé avec lunr http://lunrjs.com/


Détails du fonctionnement du site

La carte

Le tableau des données

Réalisé avec angular ui-grid http://ui-grid.info/

Intéractions carte <-> liste

app/services/map.services

  • Tri liste <-> tri carte
  • Click sur centre de la liste <-> click sur un centre sur la carte (overture de popup)

Recherche par mots-clés

Navigation entre les centres

Détails d'un centre

Configuration des données sur le site

Il est possible d'éditer une configuration afin de paramétrer :

  • les onglets à agréger
  • la taille des centres sur la carte
  • les champs de recherches disponibles dans la recherche fulltext
  • les mots à prendre en compte dans l'auto-complétion

Backoffice

Documentation

Docker

Documentation