plane/apps/app/hooks/use-project-members.tsx
Aaryan Khandelwal 10f145f85c
feat: user profile analytics, views and filters (#1698)
* feat: user profile overview

* chore: profile sidebar designed

* feat: user issues filters and view options

* refactor: filters

* refactor: mutation logic

* fix: percentage calculation logic and sidebar shadow
2023-07-28 13:39:42 +05:30

47 lines
1.3 KiB
TypeScript

import useSWR from "swr";
// services
import projectService from "services/project.service";
// fetch-keys
import { PROJECT_MEMBERS } from "constants/fetch-keys";
// hooks
import useUser from "./use-user";
const useProjectMembers = (
workspaceSlug: string | undefined,
projectId: string | undefined,
fetchCondition?: boolean
) => {
fetchCondition = fetchCondition ?? true;
const { user } = useUser();
// fetching project members
const { data: members } = useSWR(
workspaceSlug && projectId && fetchCondition ? PROJECT_MEMBERS(projectId) : null,
workspaceSlug && projectId && fetchCondition
? () => projectService.projectMembers(workspaceSlug, projectId)
: null
);
const hasJoined = members?.some((item: any) => item.member.id === (user as any)?.id);
const isOwner = members?.some((item) => item.member.id === (user as any)?.id && item.role === 20);
const isMember = members?.some(
(item) => item.member.id === (user as any)?.id && item.role === 15
);
const isViewer = members?.some(
(item) => item.member.id === (user as any)?.id && item.role === 10
);
const isGuest = members?.some((item) => item.member.id === (user as any)?.id && item.role === 5);
return {
members,
hasJoined,
isOwner,
isMember,
isViewer,
isGuest,
};
};
export default useProjectMembers;