forked from github/cinny
* add active theme context * add chroma js library * add hook for accessible tag color * disable reply user color - temporary * render user color based on tag in room timeline * remove default tag icons * move accessible color function to plugins * render user power color in reply * increase username weight in timeline * add default color for member power level tag * show red slash in power color badge with no color * show power level color in room input reply * show power level username color in notifications * show power level color in notification reply * show power level color in message search * render power level color in room pin menu * add toggle for legacy username colors * drop over saturation from member default color * change border color of power color badge * show legacy username color in direct rooms
48 lines
1.7 KiB
TypeScript
48 lines
1.7 KiB
TypeScript
import React, { ReactNode } from 'react';
|
|
import { useParams } from 'react-router-dom';
|
|
import { useAtomValue } from 'jotai';
|
|
import { useSelectedRoom } from '../../../hooks/router/useSelectedRoom';
|
|
import { IsDirectRoomProvider, RoomProvider } from '../../../hooks/useRoom';
|
|
import { useMatrixClient } from '../../../hooks/useMatrixClient';
|
|
import { JoinBeforeNavigate } from '../../../features/join-before-navigate';
|
|
import { useSpace } from '../../../hooks/useSpace';
|
|
import { getAllParents } from '../../../utils/room';
|
|
import { roomToParentsAtom } from '../../../state/room/roomToParents';
|
|
import { allRoomsAtom } from '../../../state/room-list/roomList';
|
|
import { useSearchParamsViaServers } from '../../../hooks/router/useSearchParamsViaServers';
|
|
import { mDirectAtom } from '../../../state/mDirectList';
|
|
|
|
export function SpaceRouteRoomProvider({ children }: { children: ReactNode }) {
|
|
const mx = useMatrixClient();
|
|
const space = useSpace();
|
|
const roomToParents = useAtomValue(roomToParentsAtom);
|
|
const mDirects = useAtomValue(mDirectAtom);
|
|
const allRooms = useAtomValue(allRoomsAtom);
|
|
|
|
const { roomIdOrAlias, eventId } = useParams();
|
|
const viaServers = useSearchParamsViaServers();
|
|
const roomId = useSelectedRoom();
|
|
const room = mx.getRoom(roomId);
|
|
|
|
if (
|
|
!room ||
|
|
room.isSpaceRoom() ||
|
|
!allRooms.includes(room.roomId) ||
|
|
!getAllParents(roomToParents, room.roomId).has(space.roomId)
|
|
) {
|
|
return (
|
|
<JoinBeforeNavigate
|
|
roomIdOrAlias={roomIdOrAlias!}
|
|
eventId={eventId}
|
|
viaServers={viaServers}
|
|
/>
|
|
);
|
|
}
|
|
|
|
return (
|
|
<RoomProvider key={room.roomId} value={room}>
|
|
<IsDirectRoomProvider value={mDirects.has(room.roomId)}>{children}</IsDirectRoomProvider>
|
|
</RoomProvider>
|
|
);
|
|
}
|