From 32ecf1b79605ba4db0c83d02ffec0730dbda7600 Mon Sep 17 00:00:00 2001 From: Andrew Watkins Date: Tue, 27 Jun 2017 15:12:16 -0700 Subject: [PATCH] Add ability to sort numerically and alphabetically --- ui/src/shared/components/Dygraph.js | 34 ++++++++++++++++++++++- ui/src/shared/components/DygraphLegend.js | 17 ++++++++---- 2 files changed, 45 insertions(+), 6 deletions(-) diff --git a/ui/src/shared/components/Dygraph.js b/ui/src/shared/components/Dygraph.js index 8fb92c6a76..c5b85d2fbb 100644 --- a/ui/src/shared/components/Dygraph.js +++ b/ui/src/shared/components/Dygraph.js @@ -19,10 +19,13 @@ export default class Dygraph extends Component { x: null, series: [], }, + sortType: null, + legendOrder: 'asc', } this.getTimeSeries = ::this.getTimeSeries this.sync = ::this.sync + this.handleSortLegend = ::this.handleSortLegend } static defaultProps = { @@ -38,6 +41,35 @@ export default class Dygraph extends Component { return timeSeries.length ? timeSeries : [[0]] } + handleSortLegend(sortType) { + const {legend, legendOrder} = this.state + const ascending = this.sortByType(legend.series, sortType) + + if (legendOrder === 'asc') { + return this.setState({ + legend: {...legend, series: ascending}, + sortType, + legendOrder: 'desc', + }) + } + + this.setState({ + legend: {...legend, series: ascending.reverse()}, + sortType, + legendOrder: 'asc', + }) + } + + sortByType(list, sortType) { + return _.sortBy(list, ({y, label}) => { + if (sortType === 'numeric') { + return y + } + + return label + }) + } + componentDidMount() { const timeSeries = this.getTimeSeries() // dygraphSeries is a legend label and its corresponding y-axis e.g. {legendLabel1: 'y', legendLabel2: 'y2'}; @@ -201,7 +233,7 @@ export default class Dygraph extends Component { return (
- +
{ this.graphContainer = r diff --git a/ui/src/shared/components/DygraphLegend.js b/ui/src/shared/components/DygraphLegend.js index b162ac39d3..f03f918bc7 100644 --- a/ui/src/shared/components/DygraphLegend.js +++ b/ui/src/shared/components/DygraphLegend.js @@ -1,18 +1,24 @@ import React, {PropTypes} from 'react' -const DygraphLegend = ({series}) => ( +const DygraphLegend = ({series, onSort}) => (
- -
- {series.map(({label, color, yHTML}) => { + {series.map(({label, color, yHTML, isHighlighted}) => { return ( @@ -27,7 +33,7 @@ const DygraphLegend = ({series}) => (
) -const {arrayOf, bool, number, shape, string} = PropTypes +const {arrayOf, bool, func, number, shape, string} = PropTypes DygraphLegend.propTypes = { x: number, @@ -43,6 +49,7 @@ DygraphLegend.propTypes = { }) ), dygraph: shape(), + onSort: func.isRequired, } export default DygraphLegend