2024-09-20 14:47:01 +00:00
|
|
|
import React, { ReactNode } from "react";
|
2021-02-25 12:05:08 +00:00
|
|
|
|
2023-04-04 17:25:07 +00:00
|
|
|
import classnames from "classnames";
|
|
|
|
|
|
2021-03-03 16:51:39 +00:00
|
|
|
interface IHeaderCellProps {
|
2024-09-20 14:47:01 +00:00
|
|
|
value: ReactNode;
|
2021-03-03 16:51:39 +00:00
|
|
|
isSortedDesc?: boolean;
|
2022-01-13 17:06:32 +00:00
|
|
|
disableSortBy?: boolean;
|
2021-03-03 16:51:39 +00:00
|
|
|
}
|
|
|
|
|
|
2022-01-13 17:06:32 +00:00
|
|
|
const HeaderCell = ({
|
|
|
|
|
value,
|
|
|
|
|
isSortedDesc,
|
|
|
|
|
disableSortBy,
|
|
|
|
|
}: IHeaderCellProps): JSX.Element => {
|
2021-04-12 13:32:25 +00:00
|
|
|
let sortArrowClass = "";
|
2021-02-25 12:05:08 +00:00
|
|
|
if (isSortedDesc === undefined) {
|
2021-04-12 13:32:25 +00:00
|
|
|
sortArrowClass = "";
|
2021-02-25 12:05:08 +00:00
|
|
|
} else if (isSortedDesc) {
|
2021-04-12 13:32:25 +00:00
|
|
|
sortArrowClass = "descending";
|
2021-02-25 12:05:08 +00:00
|
|
|
} else {
|
2021-04-12 13:32:25 +00:00
|
|
|
sortArrowClass = "ascending";
|
2021-02-25 12:05:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return (
|
2023-11-07 21:15:49 +00:00
|
|
|
<div className={classnames("header-cell", sortArrowClass)}>
|
2021-02-25 12:05:08 +00:00
|
|
|
<span>{value}</span>
|
2022-01-13 17:06:32 +00:00
|
|
|
{!disableSortBy && (
|
|
|
|
|
<div className="sort-arrows">
|
|
|
|
|
<span className="ascending-arrow" />
|
|
|
|
|
<span className="descending-arrow" />
|
|
|
|
|
</div>
|
|
|
|
|
)}
|
2021-02-25 12:05:08 +00:00
|
|
|
</div>
|
|
|
|
|
);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
export default HeaderCell;
|