Fix member are not sorted correctly after last js-sdk update (#2504)
This commit is contained in:
@@ -27,7 +27,7 @@ import { Page, PageContent, PageHeader } from '../../../components/page';
|
|||||||
import { useRoom } from '../../../hooks/useRoom';
|
import { useRoom } from '../../../hooks/useRoom';
|
||||||
import { useRoomMembers } from '../../../hooks/useRoomMembers';
|
import { useRoomMembers } from '../../../hooks/useRoomMembers';
|
||||||
import { useMatrixClient } from '../../../hooks/useMatrixClient';
|
import { useMatrixClient } from '../../../hooks/useMatrixClient';
|
||||||
import { usePowerLevels } from '../../../hooks/usePowerLevels';
|
import { useGetMemberPowerLevel, usePowerLevels } from '../../../hooks/usePowerLevels';
|
||||||
import { VirtualTile } from '../../../components/virtualizer';
|
import { VirtualTile } from '../../../components/virtualizer';
|
||||||
import { MemberTile } from '../../../components/member-tile';
|
import { MemberTile } from '../../../components/member-tile';
|
||||||
import { useMediaAuthentication } from '../../../hooks/useMediaAuthentication';
|
import { useMediaAuthentication } from '../../../hooks/useMediaAuthentication';
|
||||||
@@ -87,12 +87,13 @@ export function Members({ requestClose }: MembersProps) {
|
|||||||
const powerLevels = usePowerLevels(room);
|
const powerLevels = usePowerLevels(room);
|
||||||
const creators = useRoomCreators(room);
|
const creators = useRoomCreators(room);
|
||||||
const getPowerTag = useGetMemberPowerTag(room, creators, powerLevels);
|
const getPowerTag = useGetMemberPowerTag(room, creators, powerLevels);
|
||||||
|
const getPowerLevel = useGetMemberPowerLevel(powerLevels);
|
||||||
|
|
||||||
const [membershipFilterIndex, setMembershipFilterIndex] = useState(0);
|
const [membershipFilterIndex, setMembershipFilterIndex] = useState(0);
|
||||||
const [sortFilterIndex, setSortFilterIndex] = useSetting(settingsAtom, 'memberSortFilterIndex');
|
const [sortFilterIndex, setSortFilterIndex] = useSetting(settingsAtom, 'memberSortFilterIndex');
|
||||||
const membershipFilter = useMembershipFilter(membershipFilterIndex, useMembershipFilterMenu());
|
const membershipFilter = useMembershipFilter(membershipFilterIndex, useMembershipFilterMenu());
|
||||||
const memberSort = useMemberSort(sortFilterIndex, useMemberSortMenu());
|
const memberSort = useMemberSort(sortFilterIndex, useMemberSortMenu());
|
||||||
const memberPowerSort = useMemberPowerSort(creators);
|
const memberPowerSort = useMemberPowerSort(creators, getPowerLevel);
|
||||||
|
|
||||||
const scrollRef = useRef<HTMLDivElement>(null);
|
const scrollRef = useRef<HTMLDivElement>(null);
|
||||||
const searchInputRef = useRef<HTMLInputElement>(null);
|
const searchInputRef = useRef<HTMLInputElement>(null);
|
||||||
|
|||||||
@@ -51,7 +51,7 @@ import { useRoomTypingMember } from '../../hooks/useRoomTypingMembers';
|
|||||||
import { useMediaAuthentication } from '../../hooks/useMediaAuthentication';
|
import { useMediaAuthentication } from '../../hooks/useMediaAuthentication';
|
||||||
import { useMembershipFilter, useMembershipFilterMenu } from '../../hooks/useMemberFilter';
|
import { useMembershipFilter, useMembershipFilterMenu } from '../../hooks/useMemberFilter';
|
||||||
import { useMemberPowerSort, useMemberSort, useMemberSortMenu } from '../../hooks/useMemberSort';
|
import { useMemberPowerSort, useMemberSort, useMemberSortMenu } from '../../hooks/useMemberSort';
|
||||||
import { usePowerLevelsContext } from '../../hooks/usePowerLevels';
|
import { useGetMemberPowerLevel, usePowerLevelsContext } from '../../hooks/usePowerLevels';
|
||||||
import { MembershipFilterMenu } from '../../components/MembershipFilterMenu';
|
import { MembershipFilterMenu } from '../../components/MembershipFilterMenu';
|
||||||
import { MemberSortMenu } from '../../components/MemberSortMenu';
|
import { MemberSortMenu } from '../../components/MemberSortMenu';
|
||||||
import { useOpenUserRoomProfile, useUserRoomProfileState } from '../../state/hooks/userRoomProfile';
|
import { useOpenUserRoomProfile, useUserRoomProfileState } from '../../state/hooks/userRoomProfile';
|
||||||
@@ -185,6 +185,7 @@ export function MembersDrawer({ room, members }: MembersDrawerProps) {
|
|||||||
const powerLevels = usePowerLevelsContext();
|
const powerLevels = usePowerLevelsContext();
|
||||||
const creators = useRoomCreators(room);
|
const creators = useRoomCreators(room);
|
||||||
const getPowerTag = useGetMemberPowerTag(room, creators, powerLevels);
|
const getPowerTag = useGetMemberPowerTag(room, creators, powerLevels);
|
||||||
|
const getPowerLevel = useGetMemberPowerLevel(powerLevels);
|
||||||
|
|
||||||
const fetchingMembers = members.length < room.getJoinedMemberCount();
|
const fetchingMembers = members.length < room.getJoinedMemberCount();
|
||||||
const openUserRoomProfile = useOpenUserRoomProfile();
|
const openUserRoomProfile = useOpenUserRoomProfile();
|
||||||
@@ -198,7 +199,7 @@ export function MembersDrawer({ room, members }: MembersDrawerProps) {
|
|||||||
|
|
||||||
const membershipFilter = useMembershipFilter(membershipFilterIndex, membershipFilterMenu);
|
const membershipFilter = useMembershipFilter(membershipFilterIndex, membershipFilterMenu);
|
||||||
const memberSort = useMemberSort(sortFilterIndex, sortFilterMenu);
|
const memberSort = useMemberSort(sortFilterIndex, sortFilterMenu);
|
||||||
const memberPowerSort = useMemberPowerSort(creators);
|
const memberPowerSort = useMemberPowerSort(creators, getPowerLevel);
|
||||||
|
|
||||||
const typingMembers = useRoomTypingMember(room.roomId);
|
const typingMembers = useRoomTypingMember(room.roomId);
|
||||||
|
|
||||||
|
|||||||
@@ -47,7 +47,10 @@ export const useMemberSort = (index: number, memberSort: MemberSortItem[]): Memb
|
|||||||
return item;
|
return item;
|
||||||
};
|
};
|
||||||
|
|
||||||
export const useMemberPowerSort = (creators: Set<string>): MemberSortFn => {
|
export const useMemberPowerSort = (
|
||||||
|
creators: Set<string>,
|
||||||
|
getPowerLevel: (userId: string) => number
|
||||||
|
): MemberSortFn => {
|
||||||
const sort: MemberSortFn = useCallback(
|
const sort: MemberSortFn = useCallback(
|
||||||
(a, b) => {
|
(a, b) => {
|
||||||
if (creators.has(a.userId) && creators.has(b.userId)) {
|
if (creators.has(a.userId) && creators.has(b.userId)) {
|
||||||
@@ -56,7 +59,7 @@ export const useMemberPowerSort = (creators: Set<string>): MemberSortFn => {
|
|||||||
if (creators.has(a.userId)) return -1;
|
if (creators.has(a.userId)) return -1;
|
||||||
if (creators.has(b.userId)) return 1;
|
if (creators.has(b.userId)) return 1;
|
||||||
|
|
||||||
return b.powerLevel - a.powerLevel;
|
return getPowerLevel(b.userId) - getPowerLevel(a.userId);
|
||||||
},
|
},
|
||||||
[creators]
|
[creators]
|
||||||
);
|
);
|
||||||
|
|||||||
Reference in New Issue
Block a user