import { useState } from "react"; // plane imports import { EUserPermissions, EUserPermissionsLevel } from "@plane/constants"; import { IWorkspaceMember, TProjectMembership } from "@plane/types"; import { renderFormattedDate } from "@plane/utils"; // components import { MemberHeaderColumn } from "@/components/project/member-header-column"; import { AccountTypeColumn, NameColumn } from "@/components/project/settings/member-columns"; // hooks import { useMember } from "@/hooks/store/use-member"; import { useUser, useUserPermissions } from "@/hooks/store/user"; import { IMemberFilters } from "@/store/member/utils"; export interface RowData extends Pick { member: IWorkspaceMember; } type TUseProjectColumnsProps = { projectId: string; workspaceSlug: string; }; export const useProjectColumns = (props: TUseProjectColumnsProps) => { const { projectId, workspaceSlug } = props; // states const [removeMemberModal, setRemoveMemberModal] = useState(null); // store hooks const { data: currentUser } = useUser(); const { allowPermissions, getProjectRoleByWorkspaceSlugAndProjectId } = useUserPermissions(); const { project: { filters: { getFilters, updateFilters }, }, } = useMember(); // derived values const isAdmin = allowPermissions( [EUserPermissions.ADMIN], EUserPermissionsLevel.PROJECT, workspaceSlug.toString(), projectId.toString() ); const currentProjectRole = getProjectRoleByWorkspaceSlugAndProjectId(workspaceSlug.toString(), projectId.toString()) ?? EUserPermissions.GUEST; const displayFilters = getFilters(projectId); // handlers const handleDisplayFilterUpdate = (filters: Partial) => { updateFilters(projectId, filters); }; const columns = [ { key: "Full Name", content: "Full name", thClassName: "text-left", thRender: () => ( ), tdRender: (rowData: RowData) => ( ), }, { key: "Display Name", content: "Display name", thRender: () => ( ), tdRender: (rowData: RowData) =>
{rowData.member.display_name}
, }, { key: "Email", content: "Email", thRender: () => ( ), tdRender: (rowData: RowData) =>
{rowData.member.email}
, }, { key: "Account Type", content: "Account type", thRender: () => ( ), tdRender: (rowData: RowData) => ( ), }, { key: "Joining Date", content: "Joining date", thRender: () => ( ), tdRender: (rowData: RowData) =>
{renderFormattedDate(rowData?.member?.joining_date)}
, }, ]; return { columns, removeMemberModal, setRemoveMemberModal, displayFilters, handleDisplayFilterUpdate, }; };