forked from github/plane
3d7fe40035
* refactor: issue views and my issues * chore: update view dropdown options * refactor: render emoji function * refactor: api calss * fix: build errors * fix: fetch states only when dropdown is opened * chore: my issues dnd * fix: build errors * refactor: folder structure
41 lines
1.2 KiB
TypeScript
41 lines
1.2 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) => {
|
|
const { user } = useUser();
|
|
// fetching project members
|
|
const { data: members } = useSWR(
|
|
workspaceSlug && projectId ? PROJECT_MEMBERS(projectId) : null,
|
|
workspaceSlug && projectId
|
|
? () => 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;
|