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

30 lines
839 B
JavaScript
Raw Normal View History

import useApi from 'components/hooks/useApi';
2023-09-29 12:29:22 +00:00
import TeamMembersTable from './TeamMembersTable';
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';
2023-01-10 07:59:26 +00:00
2023-04-21 15:00:42 +00:00
export function TeamMembers({ teamId, readOnly }) {
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 (
<>
2023-10-04 08:46:00 +00:00
<DataTable queryResult={queryResult}>
{({ data }) => <TeamMembersTable data={data} teamId={teamId} readOnly={readOnly} />}
2023-10-01 23:11:12 +00:00
</DataTable>
</>
);
2023-01-10 07:59:26 +00:00
}
2023-04-21 15:00:42 +00:00
export default TeamMembers;