forked from github/plane
10f145f85c
* 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
47 lines
1.3 KiB
TypeScript
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;
|