2023-03-13 06:47:23 -07:00
|
|
|
import { useQuery } from '@tanstack/react-query';
|
|
|
|
|
|
|
|
import { useApi } from 'soapbox/hooks';
|
|
|
|
import { normalizeAccount } from 'soapbox/normalizers';
|
2023-03-20 05:53:38 -07:00
|
|
|
import { GroupRoles } from 'soapbox/schemas/group-member';
|
2023-03-13 06:47:23 -07:00
|
|
|
|
|
|
|
const GroupMemberKeys = {
|
|
|
|
members: (id: string, role: string) => ['group', id, role] as const,
|
|
|
|
};
|
|
|
|
|
2023-03-20 05:53:38 -07:00
|
|
|
const useGroupMembers = (groupId: string, role: GroupRoles) => {
|
2023-03-13 06:47:23 -07:00
|
|
|
const api = useApi();
|
|
|
|
|
|
|
|
const getQuery = async () => {
|
|
|
|
const { data } = await api.get(`/api/v1/groups/${groupId}/memberships`, {
|
|
|
|
params: {
|
|
|
|
role,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
const result = data.map((member: any) => {
|
|
|
|
return {
|
|
|
|
...member,
|
|
|
|
account: normalizeAccount(member.account),
|
|
|
|
};
|
|
|
|
});
|
|
|
|
|
|
|
|
return result;
|
|
|
|
};
|
|
|
|
|
|
|
|
return useQuery(
|
|
|
|
GroupMemberKeys.members(groupId, role),
|
|
|
|
getQuery,
|
|
|
|
{
|
|
|
|
placeholderData: [],
|
|
|
|
},
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export { useGroupMembers };
|