Skip to content
This repository has been archived by the owner on Jan 27, 2021. It is now read-only.

Commit

Permalink
Merge pull request #13 from GeoDaCenter/rsp-data-panel
Browse files Browse the repository at this point in the history
Data panel table updates with county select
  • Loading branch information
bertday authored Apr 24, 2020
2 parents 2e2253e + f595fde commit 0b51af9
Show file tree
Hide file tree
Showing 2 changed files with 72 additions and 3 deletions.
73 changes: 70 additions & 3 deletions src/components/DataPanel.js
Original file line number Diff line number Diff line change
@@ -1,13 +1,34 @@
import React from 'react';
import { connect } from 'react-redux';
import { Table } from 'react-bootstrap';
import styles from './DataPanel.module.css';


const DataPanel = (props) => {
const { selectedCounty } = props;

// if there's no selected county, don't render
if (!selectedCounty) return null;

// to avoid NaNs or 0.000s
let deathRate = 0;
let casesPer10k = 0;
let deathsPer10k = 0;
let casesPerBed = 0;

if (props.totalCases > 0) {
deathRate = (props.totalDeaths / props.totalCases).toFixed(3);

if (props.beds > 0) {
casesPerBed = (props.totalCases / props.beds).toFixed(3);
}

if (props.population > 0) {
casesPer10k = ((props.totalCases / props.population) * 10000).toFixed(3);
deathsPer10k = ((props.totalDeaths / props.population) * 10000).toFixed(3);
}
}

return (
<div className={styles.panel}>
<header className={styles.header}>
Expand All @@ -19,7 +40,39 @@ const DataPanel = (props) => {
</p>
</header>

<p>Data goes here</p>
<p><b>Population:</b> {props.population}<br />
<b>Hospital Beds:</b> {props.beds}</p>
<hr></hr>

<h5>April 22, 2020</h5>
<Table variant="dark" striped bordered hover size="sm">
<tbody>
<tr>
<td>Cases</td>
<td>{props.totalCases}</td>
</tr>
<tr>
<td>Cases per 10k Population</td>
<td>{casesPer10k}</td>
</tr>
<tr>
<td>Cases per Hospital Bed</td>
<td>{casesPerBed}</td>
</tr>
<tr>
<td>Deaths</td>
<td>{props.totalDeaths}</td>
</tr>
<tr>
<td>Deaths per 10k Population</td>
<td>{deathsPer10k}</td>
</tr>
<tr>
<td>Deaths/Cases</td>
<td>{deathRate}</td>
</tr>
</tbody>
</Table>
</div>
);
};
Expand All @@ -29,22 +82,36 @@ const mapStateToProps = (state) => {

let stateName;
let countyName;
let population;
let beds;
let totalCases;
let totalDeaths;

if (selectedCounty) {
// get state name
const { states, counties } = state.datasets['states-and-counties'].data;
const selectedCountySnapshots = state.datasets['usafacts-counties'].data[parseInt(selectedCounty)];
const selectedCountyAttrs = counties[selectedCounty];
const { stateId } = selectedCountyAttrs;
stateName = states[stateId].name;

population = selectedCountyAttrs.population;
beds = selectedCountyAttrs.beds;
// get county name
countyName = selectedCountyAttrs.name;
// date hardcoded for now until we add slider
const recentSnapshot = selectedCountySnapshots['2020-04-22T00:00:00.000Z'];
totalDeaths = recentSnapshot.deaths;
totalCases = recentSnapshot.cases;
}

return {
selectedCounty,
countyName,
stateName
stateName,
population,
beds,
totalCases,
totalDeaths
};
};

Expand Down
2 changes: 2 additions & 0 deletions src/datasets/datasetsUtils.js
Original file line number Diff line number Diff line change
Expand Up @@ -83,6 +83,8 @@ export function tidyUsafactsCounties(counties = [], countType) {
// cache a map of dates => iso dates
const snapshotDatesIso = snapshotDates.reduce((acc, snapshotDate) => {
const snapshotDateObj = new Date(Date.parse(snapshotDate));
// clear out time zone
snapshotDateObj.setUTCHours(0, 0, 0, 0);
const snapshotDateIso = snapshotDateObj.toISOString();
acc[snapshotDate] = snapshotDateIso;

Expand Down

0 comments on commit 0b51af9

Please sign in to comment.