Extracted sorting dropdown to its own component

This commit is contained in:
Alejandro Celaya
2018-10-28 21:26:47 +01:00
parent 56ad6d9e1b
commit 4ad8e909d4
9 changed files with 168 additions and 61 deletions

View File

@@ -0,0 +1,43 @@
import React from 'react';
import { UncontrolledDropdown, DropdownToggle, DropdownMenu, DropdownItem } from 'reactstrap';
import { toPairs } from 'ramda';
import PropTypes from 'prop-types';
import FontAwesomeIcon from '@fortawesome/react-fontawesome';
import caretUpIcon from '@fortawesome/fontawesome-free-solid/faCaretUp';
import caretDownIcon from '@fortawesome/fontawesome-free-solid/faCaretDown';
import { determineOrderDir } from '../utils/utils';
import './SortingDropdown.scss';
const propTypes = {
items: PropTypes.object,
orderField: PropTypes.string,
orderDir: PropTypes.oneOf([ 'ASC', 'DESC' ]),
onChange: PropTypes.func,
};
const SortingDropdown = ({ items, orderField, orderDir, onChange }) => (
<UncontrolledDropdown>
<DropdownToggle caret className="btn-block">Order by</DropdownToggle>
<DropdownMenu className="sorting-dropdown__menu">
{toPairs(items).map(([ fieldKey, fieldValue ]) => (
<DropdownItem
key={fieldKey}
active={orderField === fieldKey}
onClick={() => onChange(fieldKey, determineOrderDir(fieldKey, orderField, orderDir))}
>
{fieldValue}
{orderField === fieldKey && (
<FontAwesomeIcon
icon={orderDir === 'ASC' ? caretUpIcon : caretDownIcon}
className="sorting-dropdown__sort-icon"
/>
)}
</DropdownItem>
))}
</DropdownMenu>
</UncontrolledDropdown>
);
SortingDropdown.propTypes = propTypes;
export default SortingDropdown;