Sort direct messages by activity (#393)
* Add sort util Signed-off-by: Ajay Bura <ajbura@gmail.com> * Use sort util for members Signed-off-by: Ajay Bura <ajbura@gmail.com> * Sort dms by activity Signed-off-by: Ajay Bura <ajbura@gmail.com> * Sort dms activily Signed-off-by: Ajay Bura <ajbura@gmail.com> * Chanege roomIdByLastActive func name Signed-off-by: Ajay Bura <ajbura@gmail.com>
This commit is contained in:
parent
bb90f11ec8
commit
5a299b21c5
7 changed files with 100 additions and 95 deletions
src
app
molecules/room-members
organisms
util
|
@ -9,6 +9,7 @@ import colorMXID from '../../../util/colorMXID';
|
||||||
import { openProfileViewer } from '../../../client/action/navigation';
|
import { openProfileViewer } from '../../../client/action/navigation';
|
||||||
import { getUsernameOfRoomMember, getPowerLabel } from '../../../util/matrixUtil';
|
import { getUsernameOfRoomMember, getPowerLabel } from '../../../util/matrixUtil';
|
||||||
import AsyncSearch from '../../../util/AsyncSearch';
|
import AsyncSearch from '../../../util/AsyncSearch';
|
||||||
|
import { memberByAtoZ, memberByPowerLevel } from '../../../util/sort';
|
||||||
|
|
||||||
import Text from '../../atoms/text/Text';
|
import Text from '../../atoms/text/Text';
|
||||||
import Button from '../../atoms/button/Button';
|
import Button from '../../atoms/button/Button';
|
||||||
|
@ -19,26 +20,6 @@ import PeopleSelector from '../people-selector/PeopleSelector';
|
||||||
|
|
||||||
const PER_PAGE_MEMBER = 50;
|
const PER_PAGE_MEMBER = 50;
|
||||||
|
|
||||||
function AtoZ(m1, m2) {
|
|
||||||
const aName = m1.name;
|
|
||||||
const bName = m2.name;
|
|
||||||
|
|
||||||
if (aName.toLowerCase() < bName.toLowerCase()) {
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
if (aName.toLowerCase() > bName.toLowerCase()) {
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
function sortByPowerLevel(m1, m2) {
|
|
||||||
const pl1 = m1.powerLevel;
|
|
||||||
const pl2 = m2.powerLevel;
|
|
||||||
|
|
||||||
if (pl1 > pl2) return -1;
|
|
||||||
if (pl1 < pl2) return 1;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
function normalizeMembers(members) {
|
function normalizeMembers(members) {
|
||||||
const mx = initMatrix.matrixClient;
|
const mx = initMatrix.matrixClient;
|
||||||
return members.map((member) => ({
|
return members.map((member) => ({
|
||||||
|
@ -65,7 +46,7 @@ function useMemberOfMembership(roomId, membership) {
|
||||||
if (event && event?.getRoomId() !== roomId) return;
|
if (event && event?.getRoomId() !== roomId) return;
|
||||||
const memberOfMembership = normalizeMembers(
|
const memberOfMembership = normalizeMembers(
|
||||||
room.getMembersWithMembership(membership)
|
room.getMembersWithMembership(membership)
|
||||||
.sort(AtoZ).sort(sortByPowerLevel),
|
.sort(memberByAtoZ).sort(memberByPowerLevel),
|
||||||
);
|
);
|
||||||
setMembers(memberOfMembership);
|
setMembers(memberOfMembership);
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,18 +1,38 @@
|
||||||
import React, { useEffect } from 'react';
|
import React, { useState, useEffect } from 'react';
|
||||||
|
|
||||||
import initMatrix from '../../../client/initMatrix';
|
import initMatrix from '../../../client/initMatrix';
|
||||||
import cons from '../../../client/state/cons';
|
import cons from '../../../client/state/cons';
|
||||||
import navigation from '../../../client/state/navigation';
|
import navigation from '../../../client/state/navigation';
|
||||||
import Postie from '../../../util/Postie';
|
import Postie from '../../../util/Postie';
|
||||||
|
import { roomIdByActivity } from '../../../util/sort';
|
||||||
|
|
||||||
import RoomsCategory from './RoomsCategory';
|
import RoomsCategory from './RoomsCategory';
|
||||||
|
|
||||||
import { AtoZ } from './common';
|
|
||||||
|
|
||||||
const drawerPostie = new Postie();
|
const drawerPostie = new Postie();
|
||||||
function Directs() {
|
function Directs() {
|
||||||
|
const mx = initMatrix.matrixClient;
|
||||||
const { roomList, notifications } = initMatrix;
|
const { roomList, notifications } = initMatrix;
|
||||||
const directIds = [...roomList.directs].sort(AtoZ);
|
const [directIds, setDirectIds] = useState([]);
|
||||||
|
|
||||||
|
useEffect(() => setDirectIds([...roomList.directs].sort(roomIdByActivity)), []);
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
const handleTimeline = (event, room, toStartOfTimeline, removed, data) => {
|
||||||
|
if (!roomList.directs.has(room.roomId)) return;
|
||||||
|
if (!data.liveEvent) return;
|
||||||
|
if (directIds[0] === room.roomId) return;
|
||||||
|
const newDirectIds = [room.roomId];
|
||||||
|
directIds.forEach((id) => {
|
||||||
|
if (id === room.roomId) return;
|
||||||
|
newDirectIds.push(id);
|
||||||
|
});
|
||||||
|
setDirectIds(newDirectIds);
|
||||||
|
};
|
||||||
|
mx.on('Room.timeline', handleTimeline);
|
||||||
|
return () => {
|
||||||
|
mx.removeListener('Room.timeline', handleTimeline);
|
||||||
|
};
|
||||||
|
}, [directIds]);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
const selectorChanged = (selectedRoomId, prevSelectedRoomId) => {
|
const selectorChanged = (selectedRoomId, prevSelectedRoomId) => {
|
||||||
|
|
|
@ -5,11 +5,11 @@ import initMatrix from '../../../client/initMatrix';
|
||||||
import cons from '../../../client/state/cons';
|
import cons from '../../../client/state/cons';
|
||||||
import navigation from '../../../client/state/navigation';
|
import navigation from '../../../client/state/navigation';
|
||||||
import Postie from '../../../util/Postie';
|
import Postie from '../../../util/Postie';
|
||||||
|
import { roomIdByActivity, roomIdByAtoZ } from '../../../util/sort';
|
||||||
|
|
||||||
import RoomsCategory from './RoomsCategory';
|
import RoomsCategory from './RoomsCategory';
|
||||||
|
|
||||||
import { useCategorizedSpaces } from '../../hooks/useCategorizedSpaces';
|
import { useCategorizedSpaces } from '../../hooks/useCategorizedSpaces';
|
||||||
import { AtoZ, RoomToDM } from './common';
|
|
||||||
|
|
||||||
const drawerPostie = new Postie();
|
const drawerPostie = new Postie();
|
||||||
function Home({ spaceId }) {
|
function Home({ spaceId }) {
|
||||||
|
@ -34,10 +34,6 @@ function Home({ spaceId }) {
|
||||||
roomIds = roomList.getOrphanRooms();
|
roomIds = roomList.getOrphanRooms();
|
||||||
}
|
}
|
||||||
|
|
||||||
spaceIds.sort(AtoZ);
|
|
||||||
roomIds.sort(AtoZ);
|
|
||||||
directIds.sort(AtoZ);
|
|
||||||
|
|
||||||
if (isCategorized) {
|
if (isCategorized) {
|
||||||
categories = roomList.getCategorizedSpaces(spaceIds);
|
categories = roomList.getCategorizedSpaces(spaceIds);
|
||||||
categories.delete(spaceId);
|
categories.delete(spaceId);
|
||||||
|
@ -73,26 +69,36 @@ function Home({ spaceId }) {
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
{ !isCategorized && spaceIds.length !== 0 && (
|
{ !isCategorized && spaceIds.length !== 0 && (
|
||||||
<RoomsCategory name="Spaces" roomIds={spaceIds} drawerPostie={drawerPostie} />
|
<RoomsCategory name="Spaces" roomIds={spaceIds.sort(roomIdByAtoZ)} drawerPostie={drawerPostie} />
|
||||||
)}
|
)}
|
||||||
|
|
||||||
{ roomIds.length !== 0 && (
|
{ roomIds.length !== 0 && (
|
||||||
<RoomsCategory name="Rooms" roomIds={roomIds} drawerPostie={drawerPostie} />
|
<RoomsCategory name="Rooms" roomIds={roomIds.sort(roomIdByAtoZ)} drawerPostie={drawerPostie} />
|
||||||
)}
|
)}
|
||||||
|
|
||||||
{ directIds.length !== 0 && (
|
{ directIds.length !== 0 && (
|
||||||
<RoomsCategory name="People" roomIds={directIds} drawerPostie={drawerPostie} />
|
<RoomsCategory name="People" roomIds={directIds.sort(roomIdByActivity)} drawerPostie={drawerPostie} />
|
||||||
)}
|
)}
|
||||||
|
|
||||||
{ isCategorized && [...categories].map(([catId, childIds]) => (
|
{ isCategorized && [...categories].map(([catId, childIds]) => {
|
||||||
|
const rms = [];
|
||||||
|
const dms = [];
|
||||||
|
childIds.forEach((id) => {
|
||||||
|
if (directs.has(id)) dms.push(id);
|
||||||
|
else rms.push(id);
|
||||||
|
});
|
||||||
|
rms.sort(roomIdByAtoZ);
|
||||||
|
dms.sort(roomIdByActivity);
|
||||||
|
return (
|
||||||
<RoomsCategory
|
<RoomsCategory
|
||||||
key={catId}
|
key={catId}
|
||||||
spaceId={catId}
|
spaceId={catId}
|
||||||
name={mx.getRoom(catId).name}
|
name={mx.getRoom(catId).name}
|
||||||
roomIds={[...childIds].sort(AtoZ).sort(RoomToDM)}
|
roomIds={rms.concat(dms)}
|
||||||
drawerPostie={drawerPostie}
|
drawerPostie={drawerPostie}
|
||||||
/>
|
/>
|
||||||
))}
|
);
|
||||||
|
})}
|
||||||
</>
|
</>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,30 +0,0 @@
|
||||||
import initMatrix from '../../../client/initMatrix';
|
|
||||||
|
|
||||||
function AtoZ(aId, bId) {
|
|
||||||
let aName = initMatrix.matrixClient.getRoom(aId).name;
|
|
||||||
let bName = initMatrix.matrixClient.getRoom(bId).name;
|
|
||||||
|
|
||||||
// remove "#" from the room name
|
|
||||||
// To ignore it in sorting
|
|
||||||
aName = aName.replaceAll('#', '');
|
|
||||||
bName = bName.replaceAll('#', '');
|
|
||||||
|
|
||||||
if (aName.toLowerCase() < bName.toLowerCase()) {
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
if (aName.toLowerCase() > bName.toLowerCase()) {
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
const RoomToDM = (aId, bId) => {
|
|
||||||
const { directs } = initMatrix.roomList;
|
|
||||||
const aIsDm = directs.has(aId);
|
|
||||||
const bIsDm = directs.has(bId);
|
|
||||||
if (aIsDm && !bIsDm) return 1;
|
|
||||||
if (!aIsDm && bIsDm) return -1;
|
|
||||||
return 0;
|
|
||||||
};
|
|
||||||
|
|
||||||
export { AtoZ, RoomToDM };
|
|
|
@ -9,6 +9,7 @@ import { getPowerLabel, getUsernameOfRoomMember } from '../../../util/matrixUtil
|
||||||
import colorMXID from '../../../util/colorMXID';
|
import colorMXID from '../../../util/colorMXID';
|
||||||
import { openInviteUser, openProfileViewer } from '../../../client/action/navigation';
|
import { openInviteUser, openProfileViewer } from '../../../client/action/navigation';
|
||||||
import AsyncSearch from '../../../util/AsyncSearch';
|
import AsyncSearch from '../../../util/AsyncSearch';
|
||||||
|
import { memberByAtoZ, memberByPowerLevel } from '../../../util/sort';
|
||||||
|
|
||||||
import Text from '../../atoms/text/Text';
|
import Text from '../../atoms/text/Text';
|
||||||
import Header, { TitleWrapper } from '../../atoms/header/Header';
|
import Header, { TitleWrapper } from '../../atoms/header/Header';
|
||||||
|
@ -24,26 +25,6 @@ import AddUserIC from '../../../../public/res/ic/outlined/add-user.svg';
|
||||||
import SearchIC from '../../../../public/res/ic/outlined/search.svg';
|
import SearchIC from '../../../../public/res/ic/outlined/search.svg';
|
||||||
import CrossIC from '../../../../public/res/ic/outlined/cross.svg';
|
import CrossIC from '../../../../public/res/ic/outlined/cross.svg';
|
||||||
|
|
||||||
function AtoZ(m1, m2) {
|
|
||||||
const aName = m1.name;
|
|
||||||
const bName = m2.name;
|
|
||||||
|
|
||||||
if (aName.toLowerCase() < bName.toLowerCase()) {
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
if (aName.toLowerCase() > bName.toLowerCase()) {
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
function sortByPowerLevel(m1, m2) {
|
|
||||||
const pl1 = m1.powerLevel;
|
|
||||||
const pl2 = m2.powerLevel;
|
|
||||||
|
|
||||||
if (pl1 > pl2) return -1;
|
|
||||||
if (pl1 < pl2) return 1;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
function simplyfiMembers(members) {
|
function simplyfiMembers(members) {
|
||||||
const mx = initMatrix.matrixClient;
|
const mx = initMatrix.matrixClient;
|
||||||
return members.map((member) => ({
|
return members.map((member) => ({
|
||||||
|
@ -111,7 +92,7 @@ function PeopleDrawer({ roomId }) {
|
||||||
setMemberList(
|
setMemberList(
|
||||||
simplyfiMembers(
|
simplyfiMembers(
|
||||||
getMembersWithMembership(membership)
|
getMembersWithMembership(membership)
|
||||||
.sort(AtoZ).sort(sortByPowerLevel),
|
.sort(memberByAtoZ).sort(memberByPowerLevel),
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
|
@ -6,6 +6,7 @@ import cons from '../../../client/state/cons';
|
||||||
import navigation from '../../../client/state/navigation';
|
import navigation from '../../../client/state/navigation';
|
||||||
import { createSpaceShortcut, deleteSpaceShortcut } from '../../../client/action/accountData';
|
import { createSpaceShortcut, deleteSpaceShortcut } from '../../../client/action/accountData';
|
||||||
import { joinRuleToIconSrc } from '../../../util/matrixUtil';
|
import { joinRuleToIconSrc } from '../../../util/matrixUtil';
|
||||||
|
import { roomIdByAtoZ } from '../../../util/sort';
|
||||||
|
|
||||||
import Text from '../../atoms/text/Text';
|
import Text from '../../atoms/text/Text';
|
||||||
import Button from '../../atoms/button/Button';
|
import Button from '../../atoms/button/Button';
|
||||||
|
@ -20,7 +21,6 @@ import PinFilledIC from '../../../../public/res/ic/filled/pin.svg';
|
||||||
import CrossIC from '../../../../public/res/ic/outlined/cross.svg';
|
import CrossIC from '../../../../public/res/ic/outlined/cross.svg';
|
||||||
|
|
||||||
import { useSpaceShortcut } from '../../hooks/useSpaceShortcut';
|
import { useSpaceShortcut } from '../../hooks/useSpaceShortcut';
|
||||||
import { AtoZ } from '../navigation/common';
|
|
||||||
|
|
||||||
function ShortcutSpacesContent() {
|
function ShortcutSpacesContent() {
|
||||||
const mx = initMatrix.matrixClient;
|
const mx = initMatrix.matrixClient;
|
||||||
|
@ -29,7 +29,7 @@ function ShortcutSpacesContent() {
|
||||||
const [spaceShortcut] = useSpaceShortcut();
|
const [spaceShortcut] = useSpaceShortcut();
|
||||||
const spaceWithoutShortcut = [...spaces].filter(
|
const spaceWithoutShortcut = [...spaces].filter(
|
||||||
(spaceId) => !spaceShortcut.includes(spaceId),
|
(spaceId) => !spaceShortcut.includes(spaceId),
|
||||||
).sort(AtoZ);
|
).sort(roomIdByAtoZ);
|
||||||
|
|
||||||
const [process, setProcess] = useState(null);
|
const [process, setProcess] = useState(null);
|
||||||
const [selected, setSelected] = useState([]);
|
const [selected, setSelected] = useState([]);
|
||||||
|
|
47
src/util/sort.js
Normal file
47
src/util/sort.js
Normal file
|
@ -0,0 +1,47 @@
|
||||||
|
import initMatrix from '../client/initMatrix';
|
||||||
|
|
||||||
|
export function roomIdByActivity(id1, id2) {
|
||||||
|
const room1 = initMatrix.matrixClient.getRoom(id1);
|
||||||
|
const room2 = initMatrix.matrixClient.getRoom(id2);
|
||||||
|
|
||||||
|
return room2.getLastActiveTimestamp() - room1.getLastActiveTimestamp();
|
||||||
|
}
|
||||||
|
|
||||||
|
export function roomIdByAtoZ(aId, bId) {
|
||||||
|
let aName = initMatrix.matrixClient.getRoom(aId).name;
|
||||||
|
let bName = initMatrix.matrixClient.getRoom(bId).name;
|
||||||
|
|
||||||
|
// remove "#" from the room name
|
||||||
|
// To ignore it in sorting
|
||||||
|
aName = aName.replaceAll('#', '');
|
||||||
|
bName = bName.replaceAll('#', '');
|
||||||
|
|
||||||
|
if (aName.toLowerCase() < bName.toLowerCase()) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
if (aName.toLowerCase() > bName.toLowerCase()) {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
export function memberByAtoZ(m1, m2) {
|
||||||
|
const aName = m1.name;
|
||||||
|
const bName = m2.name;
|
||||||
|
|
||||||
|
if (aName.toLowerCase() < bName.toLowerCase()) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
if (aName.toLowerCase() > bName.toLowerCase()) {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
export function memberByPowerLevel(m1, m2) {
|
||||||
|
const pl1 = m1.powerLevel;
|
||||||
|
const pl2 = m2.powerLevel;
|
||||||
|
|
||||||
|
if (pl1 > pl2) return -1;
|
||||||
|
if (pl1 < pl2) return 1;
|
||||||
|
return 0;
|
||||||
|
}
|
Loading…
Add table
Reference in a new issue