This project aims to provide interactive visualizations for exploring and analyzing health investment cases. Click here to see the interface.
- Link for the visualization
- Deployment
- Steps to integrate the vis in static page
- Pages on DFP where This Viz is Used
- Related Repos
- Global CSS Files and Repo
- Build With
- Installation
- Local Deployment
- Available Scripts
- Tooling Setup
- Contact
https://gray-flower-008fd9910.4.azurestaticapps.net
The Production site deployed using Azure Static Web App and work flow can be found here.
Main visualization Health Investment Case
will be rendered within the following div on a static page:
<div data-bucket-embed class="focusArea~Tobacco"></div>
Cards for the Featured Indicators section will be rendered within the following div on a static page:
<div id="root" data-bucket-embed-top-card class="focusArea~Tobacco_control"></div>
Top graphs for the focus area pages will be rendered within the following div on a static page:
<div data-bucket-top-graphs-embed class="focusArea~Tobacco_control"></div>
Please note that there are three focus areas available right now: ~Tobacco_control, ~NCDs, ~All (Tobacco control + NCDs combined)
Apart from the mentioned div
above the following script
and link
needs to be added to the head
or in the embed code
<script defer src="<https://gray-flower-008fd9910.4.azurestaticapps.net/index.js"></script>
<link rel="stylesheet" href="https://undp-data.github.io/stylesheets-for-viz/style/mainStyleSheet.css" />
<link rel="stylesheet" href="https://undp-data.github.io/stylesheets-for-viz/style/StyleForGraphingInterface.css" />
<link rel="stylesheet" href="https://undp-data.github.io/stylesheets-for-viz/style/StyleForGraph.css" />
- stylesheet-for-viz: Repo which defines the css settings for the project
- dv-health-investment-case-data-repo: Repo which has all the data used in the visualization
- dv-health-investment-case-metadata: Repo which has meta data for the data
Git Repo: https://github.com/UNDP-Data/stylesheets-for-viz
Link for stylesheets
- https://undp-data.github.io/stylesheets-for-viz/style/mainStyleSheet.css
- https://undp-data.github.io/stylesheets-for-viz/style/StyleForGraphingInterface.css
- https://undp-data.github.io/stylesheets-for-viz/style/StyleForGraph.css
- React: Used as MVC framework.
- styled-components: Utilizes tagged template literals and the power of CSS, allows to write actual CSS code to style the components in JS/TS.
- Various D3 Libraries: Used for visualizations, adding interaction and reading the csv data file.
- AntD: For UI elements like dropdown, buttons, checkbox, and slider.
- dom-to-image: Used to allow users to download images of various visualization views they create.
- lodash: Used for manipulating and iterating arrays and objects.
- xlsx: Used to allow users download xlsx format for data.
- react-csv: Used to allow users download csv format for data.
- undp-viz-colors: This is package for defining the visualization color palette.
This project uses npm
. For installation you will need to install node
and npm
, if you don't already have it. node
and npm
can be installed from here.
To install the project, simply clone the the repo and them run npm install
in the project folder. You can use terminal on Mac and Command Prompt on Windows.
This project is bootstrapped with Vite
and was created using npm create vite@latest
command.
Run the terminal or command prompt and then run the following
git clone https://github.com/UNDP-Data/dv-health-investment-case.git
cd dv-health-investment-case
npm install
To start the project locally, you can run npm run dev
in the project folder in terminal or command prompt.
This is run the app in development mode. Open http://localhost:5173/ to view it in the browser.
The page will reload if you make edits. You will also see any lint errors in the console.
npm run dev
: Executesvite
and start the local server for local deployment.npm run build
: Executestsc && vite build
and builds the app for production and deployment.
This project uses ESLint integrated with prettier, which verifies and formats your code so you don't have to do it manually. You should have your editor set up to display lint errors and automatically fix those which it is possible to fix. See http://eslint.org/docs/user-guide/integrations.
This project is build in Visual Studio Code, therefore the project is already set up to work with. Install it from here and then install this eslint plugin and you should be good to go.