import { useState } from "react"; import { useParams } from "next/navigation"; import { IWorkspaceMember } from "@plane/types"; import { EUserProjectRoles } from "@plane/types/src/enums"; import { AccountTypeColumn, NameColumn } from "@/components/project/settings/member-columns"; import { EUserWorkspaceRoles } from "@/constants/workspace"; import { useUser } from "@/hooks/store"; export interface RowData { member: IWorkspaceMember; role: EUserWorkspaceRoles; } export const useProjectColumns = () => { // states const [removeMemberModal, setRemoveMemberModal] = useState(null); const { workspaceSlug, projectId } = useParams(); const { membership: { currentProjectRole }, data: currentUser, } = useUser(); const getFormattedDate = (dateStr: string) => { const date = new Date(dateStr); const options: Intl.DateTimeFormatOptions = { year: "numeric", month: "long", day: "numeric" }; return date.toLocaleDateString("en-US", options); }; // derived values const isAdmin = currentProjectRole === EUserProjectRoles.ADMIN; const columns = [ { key: "Full Name", content: "Full Name", thClassName: "text-left", tdRender: (rowData: RowData) => ( ), }, { key: "Display Name", content: "Display Name", tdRender: (rowData: RowData) =>
{rowData.member.display_name}
, }, { key: "Account Type", content: "Account Type", tdRender: (rowData: RowData) => ( ), }, { key: "Joining Date", content: "Joining Date", tdRender: (rowData: RowData) =>
{getFormattedDate(rowData?.member?.joining_date || "")}
, }, ]; return { columns, workspaceSlug, projectId, removeMemberModal, setRemoveMemberModal }; };