import React, { PropTypes } from 'react'; import { connect } from 'react-redux'; import PureComponent from 'react-pure-render/component'; import { InputGroup, FormControl, Button, Row } from 'react-bootstrap'; import classnames from 'classnames'; import { clearFilter, updateFilter, collapseAll, expandAll } from '../../redux/actions'; const ESC = 27; const clearIcon = ; const searchIcon = ; const bindableActions = { clearFilter, updateFilter, collapseAll, expandAll }; const mapStateToProps = state => ({ isAllCollapsed: state.challengesApp.mapUi.isAllCollapsed, filter: state.challengesApp.filter }); const propTypes = { clearFilter: PropTypes.func, collapseAll: PropTypes.func, expandAll: PropTypes.func, filter: PropTypes.string, isAllCollapsed: PropTypes.bool, updateFilter: PropTypes.func }; export class Header extends PureComponent { constructor(...props) { super(...props); this.handleKeyDown = this.handleKeyDown.bind(this); this.handleClearButton = this.handleClearButton.bind(this); } handleKeyDown(e) { if (e.keyCode === ESC) { e.preventDefault(); this.props.clearFilter(); } } handleClearButton(e) { e.preventDefault(); this.props.clearFilter(); } renderSearchAddon(filter) { if (!filter) { return searchIcon; } return { clearIcon }; } render() { const { filter, updateFilter, collapseAll, expandAll, isAllCollapsed } = this.props; const inputClass = classnames({ 'map-filter': true, filled: !!filter }); const buttonClass = classnames({ 'center-block': true, active: isAllCollapsed }); const buttonCopy = isAllCollapsed ? 'Expand all challenges' : 'Hide all challenges'; return (
Challenges required for certifications are marked with a *