All files / javascripts/explorev2/components GroupBy.jsx

0% Statements 0/15
100% Branches 0/0
0% Functions 0/4
0% Lines 0/14
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69                                                                                                                                         
import React from 'react';
import { bindActionCreators } from 'redux';
import * as actions from '../actions/exploreActions';
import { connect } from 'react-redux';
import SelectArray from './SelectArray';
 
const propTypes = {
  actions: React.PropTypes.object,
  metricsOpts: React.PropTypes.array,
  metrics: React.PropTypes.array,
  groupByColumnOpts: React.PropTypes.array,
  groupByColumns: React.PropTypes.array,
};
 
const defaultProps = {
  metricsOpts: [],
  metrics: [],
  groupByColumnOpts: [],
  groupByColumns: [],
};
 
const GroupBy = (props) => {
  const selects = [
    {
      key: 'groupByColumns',
      title: 'Group By',
      options: props.groupByColumnOpts,
      value: props.groupByColumns,
      multi: true,
      width: '12',
    },
    {
      key: 'metrics',
      title: 'Metrics',
      options: props.metricsOpts,
      value: props.metrics,
      multi: true,
      width: '12',
    }];
  return (
    <div className="panel">
      <div className="panel-header">GroupBy</div>
      <div className="panel-body">
        <SelectArray selectArray={selects} />
      </div>
    </div>
  );
};
 
GroupBy.propTypes = propTypes;
GroupBy.defaultProps = defaultProps;
 
function mapStateToProps(state) {
  return {
    metricsOpts: state.metricsOpts,
    metrics: state.viz.formData.metrics,
    groupByColumnOpts: state.groupByColumnOpts,
    groupByColumns: state.viz.formData.groupByColumns,
  };
}
 
function mapDispatchToProps(dispatch) {
  return {
    actions: bindActionCreators(actions, dispatch),
  };
}
 
export default connect(mapStateToProps, mapDispatchToProps)(GroupBy);