umami/src/app/(main)/settings/teams/[id]/TeamMembers.tsx

28 lines
857 B
TypeScript
Raw Normal View History

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
return (
2024-01-26 07:20:53 +00:00
<DataTable queryResult={queryResult}>
{({ data }) => <TeamMembersTable data={data} teamId={teamId} readOnly={readOnly} />}
</DataTable>
);
2023-01-10 07:59:26 +00:00
}
2023-04-21 15:00:42 +00:00
export default TeamMembers;