From f90ff70e8619202befeca9a55bfde43ecf200595 Mon Sep 17 00:00:00 2001 From: Jake Mensch Date: Sun, 15 Mar 2020 09:33:01 -0700 Subject: [PATCH] add live data to TimeToClose chart --- src/components/Visualizations/Chart.jsx | 5 ++- src/components/Visualizations/TimeToClose.jsx | 40 +++++++++---------- src/redux/rootSaga.js | 8 +++- 3 files changed, 28 insertions(+), 25 deletions(-) diff --git a/src/components/Visualizations/Chart.jsx b/src/components/Visualizations/Chart.jsx index 62f5df4ab..6e929c6ba 100644 --- a/src/components/Visualizations/Chart.jsx +++ b/src/components/Visualizations/Chart.jsx @@ -115,10 +115,11 @@ class Chart extends React.Component { } componentDidUpdate(prevProps) { - const { data } = this.props; + const { data, options } = this.props; - if (prevProps.data !== data) { + if (prevProps.data !== data || prevProps.options !== options) { this.chart.data = data; + this.chart.options = options; this.chart.update(); } } diff --git a/src/components/Visualizations/TimeToClose.jsx b/src/components/Visualizations/TimeToClose.jsx index 8912e777b..0a5f5df12 100644 --- a/src/components/Visualizations/TimeToClose.jsx +++ b/src/components/Visualizations/TimeToClose.jsx @@ -5,28 +5,30 @@ import { REQUEST_TYPES } from '@components/common/CONSTANTS'; import Chart from './Chart'; const TimeToClose = ({ - requestTypes, + timeToClose, }) => { // // DATA //// - const randomSeries = (count, min, max) => Array.from({ length: count }) - .map(() => Math.random() * (max - min) + min); - - const dummyData = REQUEST_TYPES.reduce((p, c) => { - const acc = p; - acc[c.type] = randomSeries(8, 0, 11); - return acc; - }, {}); - - const selectedTypes = REQUEST_TYPES.filter(el => requestTypes[el.type]); + const boxes = Object.keys(timeToClose).map(key => { + const requestType = REQUEST_TYPES.find(t => t.type === key); + return { + abbrev: requestType?.abbrev, + color: requestType?.color, + stats: { + ...timeToClose[key], + outliers: [], + }, + }; + }); const chartData = { - labels: selectedTypes.map(t => t.abbrev), + labels: boxes.map(b => b.abbrev), datasets: [{ - data: selectedTypes.map(t => dummyData[t.type]), - backgroundColor: selectedTypes.map(t => t.color), + data: boxes.map(b => b.stats), + backgroundColor: boxes.map(b => b.color), borderColor: '#000', borderWidth: 1, + outlierColor: '#000', }], }; @@ -36,9 +38,6 @@ const TimeToClose = ({ const chartOptions = { maintainAspectRatio: false, - title: { - text: 'Time to Close', - }, scales: { xAxes: [{ scaleLabel: { @@ -47,8 +46,7 @@ const TimeToClose = ({ }, ticks: { beginAtZero: true, - stepSize: 1, - coef: 0, + maxStats: 'whiskerMax', }, }], yAxes: [{ @@ -78,11 +76,11 @@ const TimeToClose = ({ }; const mapStateToProps = state => ({ - requestTypes: state.filters.requestTypes, + timeToClose: state.data.timeToClose, }); export default connect(mapStateToProps)(TimeToClose); TimeToClose.propTypes = { - requestTypes: PropTypes.shape({}).isRequired, + timeToClose: PropTypes.shape({}).isRequired, }; diff --git a/src/redux/rootSaga.js b/src/redux/rootSaga.js index 0439bafe7..5818ce90e 100644 --- a/src/redux/rootSaga.js +++ b/src/redux/rootSaga.js @@ -50,8 +50,12 @@ function* getFrequency() { return yield {}; } -function* getTimeToClose() { - return yield {}; +function* getTimeToClose(filters) { + const ttcUrl = `${BASE_URL}/timetoclose`; + + const { data: { data } } = yield call(axios.post, ttcUrl, filters); + + return data; } /* //////////// COMBINED API CALL //////////// */