import { useState } from "react"; import { useParams } from "next/navigation"; import { AccountTypeColumn, NameColumn, RowData } from "@/components/workspace/settings/member-columns"; import { useUser, useUserPermissions } from "@/hooks/store"; import { EUserPermissions, EUserPermissionsLevel } from "@/plane-web/constants/user-permissions"; export const useMemberColumns = () => { // states const [removeMemberModal, setRemoveMemberModal] = useState(null); const { workspaceSlug } = useParams(); const { data: currentUser } = useUser(); const { allowPermissions } = useUserPermissions(); 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 = allowPermissions([EUserPermissions.ADMIN], EUserPermissionsLevel.WORKSPACE); 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: "Email address", content: "Email address", tdRender: (rowData: RowData) =>
{rowData.member.email}
, }, { key: "Account type", content: "Account type", tdRender: (rowData: RowData) => , }, { key: "Authentication", content: "Authentication", tdRender: (rowData: RowData) => (
{rowData.member.last_login_medium?.replace("-", " ")}
), }, { key: "Joining date", content: "Joining date", tdRender: (rowData: RowData) =>
{getFormattedDate(rowData?.member?.joining_date || "")}
, }, ]; return { columns, workspaceSlug, removeMemberModal, setRemoveMemberModal }; };