/* * MinIO Cloud Storage (C) 2018 MinIO, Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import React from "react" import classNames from "classnames" import { connect } from "react-redux" import * as actionsObjects from "./actions" import { SORT_BY_NAME, SORT_BY_SIZE, SORT_BY_LAST_MODIFIED, SORT_ORDER_DESC, SORT_ORDER_ASC } from "../constants" export const ObjectsHeader = ({ sortedByName, sortedBySize, sortedByLastModified, sortOrder, sortObjects }) => ( <div className="feb-container"> <header className="fesl-row" data-type="folder"> <div className="fesl-item fesl-item-icon" /> <div className="fesl-item fesl-item-name" id="sort-by-name" onClick={() => sortObjects(SORT_BY_NAME)} data-sort="name" > Name <i className={classNames({ "fesli-sort": true, "fesli-sort--active": sortedByName, fas: true, "fa-sort-alpha-down-alt": sortedByName && sortOrder === SORT_ORDER_DESC, "fa-sort-alpha-down": sortedByName && sortOrder === SORT_ORDER_ASC })} /> </div> <div className="fesl-item fesl-item-size" id="sort-by-size" onClick={() => sortObjects(SORT_BY_SIZE)} data-sort="size" > Size <i className={classNames({ "fesli-sort": true, "fesli-sort--active": sortedBySize, fas: true, "fa-sort-amount-down": sortedBySize && sortOrder === SORT_ORDER_DESC, "fa-sort-amount-down-alt": sortedBySize && sortOrder === SORT_ORDER_ASC })} /> </div> <div className="fesl-item fesl-item-modified" id="sort-by-last-modified" onClick={() => sortObjects(SORT_BY_LAST_MODIFIED)} data-sort="last-modified" > Last Modified <i className={classNames({ "fesli-sort": true, "fesli-sort--active": sortedByLastModified, fas: true, "fa-sort-numeric-down-alt": sortedByLastModified && sortOrder === SORT_ORDER_DESC, "fa-sort-numeric-down": sortedByLastModified && sortOrder === SORT_ORDER_ASC })} /> </div> <div className="fesl-item fesl-item-actions" /> </header> </div> ) const mapStateToProps = state => { return { sortedByName: state.objects.sortBy == SORT_BY_NAME, sortedBySize: state.objects.sortBy == SORT_BY_SIZE, sortedByLastModified: state.objects.sortBy == SORT_BY_LAST_MODIFIED, sortOrder: state.objects.sortOrder } } const mapDispatchToProps = dispatch => { return { sortObjects: sortBy => dispatch(actionsObjects.sortObjects(sortBy)) } } export default connect( mapStateToProps, mapDispatchToProps )(ObjectsHeader)