forked from github/plane
32 lines
907 B
TypeScript
32 lines
907 B
TypeScript
|
import useSWR from "swr";
|
||
|
import { useRouter } from "next/router";
|
||
|
// types
|
||
|
import { IProject } from "types";
|
||
|
// services
|
||
|
import projectService from "services/project.service";
|
||
|
// constants
|
||
|
import { PROJECTS_LIST } from "constants/fetch-keys";
|
||
|
|
||
|
const useProjects = () => {
|
||
|
// router
|
||
|
const router = useRouter();
|
||
|
const { workspaceSlug } = router.query;
|
||
|
// api fetching
|
||
|
const { data: projects, mutate: mutateProjects } = useSWR<IProject[]>(
|
||
|
workspaceSlug ? PROJECTS_LIST(workspaceSlug as string) : null,
|
||
|
workspaceSlug ? () => projectService.getProjects(workspaceSlug as string) : null
|
||
|
);
|
||
|
|
||
|
const recentProjects = projects
|
||
|
?.sort((a, b) => Date.parse(`${a.updated_at}`) - Date.parse(`${b.updated_at}`))
|
||
|
.filter((_item, index) => index < 3);
|
||
|
|
||
|
return {
|
||
|
projects: projects || [],
|
||
|
recentProjects: recentProjects || [],
|
||
|
mutateProjects,
|
||
|
};
|
||
|
};
|
||
|
|
||
|
export default useProjects;
|