2024-07-29 11:54:38 +02:00

60 lines
1.7 KiB
TypeScript

import React, { useEffect } from "react";
import { useRouter } from "next/router";
import Module from "@Front/Config/Module";
import { IBlock } from "@Front/Components/DesignSystem/SearchBlockList/BlockList/Block";
import DefaultDashboardWithList, { IPropsDashboardWithList } from "../DefaultDashboardWithList";
import User from "le-coffre-resources/dist/Notary";
import JwtService from "@Front/Services/JwtService/JwtService";
import Users, { IGetUsersparams } from "@Front/Api/LeCoffreApi/Admin/Users/Users";
type IProps = IPropsDashboardWithList;
export default function DefaultCollaboratorDashboard(props: IProps) {
const [collaborators, setCollaborators] = React.useState<User[] | null>(null);
const router = useRouter();
const { collaboratorUid } = router.query;
useEffect(() => {
const jwt = JwtService.getInstance().decodeJwt();
if (!jwt) return;
const query: IGetUsersparams = {
where: { office_uid: jwt.office_Id },
include: {
contact: true,
seats: {
include: {
subscription: true,
},
},
},
};
Users.getInstance()
.get(query)
.then((users) => setCollaborators(users));
}, []);
const onSelectedBlock = (block: IBlock) => {
router.push(
Module.getInstance().get().modules.pages.Collaborators.pages.CollaboratorInformations.props.path.replace("[uid]", block.id),
);
};
return (
<DefaultDashboardWithList
{...props}
onSelectedBlock={onSelectedBlock}
blocks={
collaborators
? collaborators.map((collaborator) => ({
id: collaborator.uid!,
primaryText: collaborator.contact?.first_name + " " + collaborator.contact?.last_name,
isActive: collaborator.uid === collaboratorUid,
secondaryText: collaborator.contact?.email,
}))
: []
}
/>
);
}