2023-08-21 09:06:09 +00:00
|
|
|
import useApi from 'components/hooks/useApi';
|
2023-10-01 23:11:12 +00:00
|
|
|
import useFilterQuery from 'components/hooks/useFilterQuery';
|
|
|
|
|
import DataTable from 'components/common/DataTable';
|
2023-10-08 07:15:29 +00:00
|
|
|
import useCache from 'store/cache';
|
2024-01-26 07:20:53 +00:00
|
|
|
import TeamMembersTable from './TeamMembersTable';
|
2023-01-10 07:59:26 +00:00
|
|
|
|
2023-12-03 11:07:03 +00:00
|
|
|
export function TeamMembers({ teamId, readOnly }: { teamId: string; readOnly: boolean }) {
|
2023-10-01 23:11:12 +00:00
|
|
|
const { get } = useApi();
|
2023-10-08 07:15:29 +00:00
|
|
|
const modified = useCache(state => state?.['team:members']);
|
2023-12-02 04:27:59 +00:00
|
|
|
const queryResult = useFilterQuery({
|
|
|
|
|
queryKey: ['team:members', { teamId, modified }],
|
|
|
|
|
queryFn: params => {
|
2023-10-01 23:11:12 +00:00
|
|
|
return get(`/teams/${teamId}/users`, {
|
|
|
|
|
...params,
|
|
|
|
|
});
|
|
|
|
|
},
|
2023-12-02 04:27:59 +00:00
|
|
|
enabled: !!teamId,
|
|
|
|
|
});
|
2023-01-10 07:59:26 +00:00
|
|
|
|
2023-03-10 07:21:19 +00:00
|
|
|
return (
|
2024-01-26 07:20:53 +00:00
|
|
|
<DataTable queryResult={queryResult}>
|
|
|
|
|
{({ data }) => <TeamMembersTable data={data} teamId={teamId} readOnly={readOnly} />}
|
|
|
|
|
</DataTable>
|
2023-03-10 07:21:19 +00:00
|
|
|
);
|
2023-01-10 07:59:26 +00:00
|
|
|
}
|
2023-04-21 15:00:42 +00:00
|
|
|
|
|
|
|
|
export default TeamMembers;
|