import { useState } from "react"; import { useParams } from "next/navigation"; import { EUserPermissions, EUserPermissionsLevel } from "@plane/constants"; import { useTranslation } from "@plane/i18n"; import { renderFormattedDate } from "@plane/utils"; import { MemberHeaderColumn } from "@/components/project/member-header-column"; import type { RowData } from "@/components/workspace/settings/member-columns"; import { AccountTypeColumn, NameColumn } from "@/components/workspace/settings/member-columns"; import { useMember } from "@/hooks/store/use-member"; import { useUser, useUserPermissions } from "@/hooks/store/user"; import type { IMemberFilters } from "@/store/member/utils"; export const useMemberColumns = () => { // states const [removeMemberModal, setRemoveMemberModal] = useState(null); const { workspaceSlug } = useParams(); const { data: currentUser } = useUser(); const { allowPermissions } = useUserPermissions(); const { workspace: { filtersStore: { filters, updateFilters }, }, } = useMember(); const { t } = useTranslation(); // derived values const isAdmin = allowPermissions([EUserPermissions.ADMIN], EUserPermissionsLevel.WORKSPACE); const isSuspended = (rowData: RowData) => rowData.is_active === false; // handlers const handleDisplayFilterUpdate = (filterUpdates: Partial) => { updateFilters(filterUpdates); }; const columns = [ { key: "Full name", content: t("workspace_settings.settings.members.details.full_name"), thClassName: "text-left", thRender: () => ( ), tdRender: (rowData: RowData) => ( ), }, { key: "Display name", content: t("workspace_settings.settings.members.details.display_name"), tdRender: (rowData: RowData) => (
{rowData.member.display_name}
), thRender: () => ( ), }, { key: "Email address", content: t("workspace_settings.settings.members.details.email_address"), tdRender: (rowData: RowData) => (
{rowData.member.email}
), thRender: () => ( ), }, { key: "Account type", content: t("workspace_settings.settings.members.details.account_type"), thRender: () => ( ), tdRender: (rowData: RowData) => , }, { key: "Authentication", content: t("workspace_settings.settings.members.details.authentication"), tdRender: (rowData: RowData) => isSuspended(rowData) ? null : (
{rowData.member.last_login_medium?.replace("-", " ")}
), }, { key: "Joining date", content: t("workspace_settings.settings.members.details.joining_date"), tdRender: (rowData: RowData) => isSuspended(rowData) ? null :
{renderFormattedDate(rowData?.member?.joining_date)}
, thRender: () => ( ), }, ]; return { columns, workspaceSlug, removeMemberModal, setRemoveMemberModal }; };