2024-02-08 06:19:00 +00:00
|
|
|
import { useRef } from "react";
|
|
|
|
//types
|
|
|
|
import { IIssueDisplayFilterOptions, IIssueDisplayProperties } from "@plane/types";
|
|
|
|
//components
|
|
|
|
import { WithDisplayPropertiesHOC } from "../properties/with-display-properties-HOC";
|
|
|
|
import { HeaderColumn } from "./columns/header-column";
|
|
|
|
import { observer } from "mobx-react";
|
|
|
|
|
|
|
|
interface Props {
|
|
|
|
displayProperties: IIssueDisplayProperties;
|
|
|
|
property: keyof IIssueDisplayProperties;
|
|
|
|
isEstimateEnabled: boolean;
|
|
|
|
displayFilters: IIssueDisplayFilterOptions;
|
|
|
|
handleDisplayFilterUpdate: (data: Partial<IIssueDisplayFilterOptions>) => void;
|
|
|
|
}
|
|
|
|
export const SpreadsheetHeaderColumn = observer((props: Props) => {
|
|
|
|
const { displayProperties, displayFilters, property, isEstimateEnabled, handleDisplayFilterUpdate } = props;
|
|
|
|
|
|
|
|
//hooks
|
|
|
|
const tableHeaderCellRef = useRef<HTMLTableCellElement | null>(null);
|
|
|
|
|
|
|
|
const shouldRenderProperty = property === "estimate" ? isEstimateEnabled : true;
|
|
|
|
|
|
|
|
return (
|
|
|
|
<WithDisplayPropertiesHOC
|
|
|
|
displayProperties={displayProperties}
|
|
|
|
displayPropertyKey={property}
|
|
|
|
shouldRenderProperty={shouldRenderProperty}
|
|
|
|
>
|
|
|
|
<th
|
2024-02-08 12:19:45 +00:00
|
|
|
className="h-11 w-full min-w-[8rem] items-center bg-custom-background-90 text-sm font-medium px-4 py-1 border border-b-0 border-t-0 border-neutral-border-subtle focus:border-custom-primary-70"
|
2024-02-08 06:19:00 +00:00
|
|
|
ref={tableHeaderCellRef}
|
|
|
|
tabIndex={0}
|
|
|
|
>
|
|
|
|
<HeaderColumn
|
|
|
|
displayFilters={displayFilters}
|
|
|
|
handleDisplayFilterUpdate={handleDisplayFilterUpdate}
|
|
|
|
property={property}
|
|
|
|
onClose={() => {
|
|
|
|
tableHeaderCellRef?.current?.focus();
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
</th>
|
|
|
|
</WithDisplayPropertiesHOC>
|
|
|
|
);
|
|
|
|
});
|