mirror of
https://github.com/fleetdm/fleet
synced 2026-04-21 21:47:20 +00:00
38 lines
824 B
TypeScript
38 lines
824 B
TypeScript
import React, { ReactNode } from "react";
|
|
|
|
import classnames from "classnames";
|
|
|
|
interface IHeaderCellProps {
|
|
value: ReactNode;
|
|
isSortedDesc?: boolean;
|
|
disableSortBy?: boolean;
|
|
}
|
|
|
|
const HeaderCell = ({
|
|
value,
|
|
isSortedDesc,
|
|
disableSortBy,
|
|
}: IHeaderCellProps): JSX.Element => {
|
|
let sortArrowClass = "";
|
|
if (isSortedDesc === undefined) {
|
|
sortArrowClass = "";
|
|
} else if (isSortedDesc) {
|
|
sortArrowClass = "descending";
|
|
} else {
|
|
sortArrowClass = "ascending";
|
|
}
|
|
|
|
return (
|
|
<div className={classnames("header-cell", sortArrowClass)}>
|
|
<span>{value}</span>
|
|
{!disableSortBy && (
|
|
<div className="sort-arrows">
|
|
<span className="ascending-arrow" />
|
|
<span className="descending-arrow" />
|
|
</div>
|
|
)}
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export default HeaderCell;
|