All files / components/header-bar/header-tasks header-tasks.jsx

61.11% Statements 11/18
40% Branches 10/25
75% Functions 3/4
61.11% Lines 11/18
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 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84            1x 1x 1x                     1x 1x   1x 1x           1x                     1x                                                               1x           1x          
import React from 'react';
import TaskItem from './task-item.jsx';
import PropTypes from 'prop-types';
 
class HeaderTasks extends React.Component {
  constructor(props) {
    super(props);
    this.state = { open: false };
    this.toggleDropdown = this.toggleDropdown.bind(this);
  }
 
  toggleDropdown(e) {
    if ((e.type === 'blur' && this.state.open) || e.type !== 'blur') {
      this.setState({ open: !this.state.open });
    }
  }
 
  render() {
    let progressBarColor;
    const taskList = this.props.tasks.map((taskDetails, i) => {
      Iif (taskDetails.percentage < 21) {
        progressBarColor = 'bg-red';
      } else Eif (taskDetails.percentage > 20 && taskDetails.percentage < 41) {
        progressBarColor = 'bg-yellow';
      } else if (taskDetails.percentage > 40 && taskDetails.percentage < 61) {
        progressBarColor = 'bg-green';
      } else if (taskDetails.percentage > 60) {
        progressBarColor = 'bg-aqua';
      }
      return (
        <TaskItem
          key={i}
          percentage={taskDetails.percentage}
          content={taskDetails.subject}
          theme={progressBarColor}
          link={taskDetails.link}
          onClick={taskDetails.onClick}
        />
      );
    });
    return (
      <li className={`dropdown tasks-menu${this.state.open ? ' open' : ''}`} tabIndex="0" onBlur={this.toggleDropdown}>
        <a className="dropdown-toggle" data-toggle="dropdown-menu" onClick={this.toggleDropdown}>
          <i className="fa fa-flag-o" />
          <span className="label label-danger">{this.props.count || this.props.tasks.length}</span>
        </a>
        <ul className="dropdown-menu">
          <li className="header">
            You have {this.props.count || this.props.tasks.length} tasks.
          </li>
          <li>
            <div className="slimScrollDiv">
              <ul className="menu">
                {taskList}
              </ul>
              <div className="slimScrollBar" />
              <div className="slimScrollRail" />
            </div>
          </li>
          {this.props.clickHandler ? (
            <li className="footer">
              <a onClick={this.props.clickHandler}>
                View all tasks
              </a>
            </li>
          ) : ''}
        </ul>
      </li>
    );
  }
}
 
HeaderTasks.propTypes = {
  count: PropTypes.number,
  tasks: PropTypes.array,
  clickHandler: PropTypes.func
};
 
HeaderTasks.defaultProps = {
  tasks: []
};
 
export default HeaderTasks;