import React, { useState, useEffect } from 'react';
import initMatrix from '../../../client/initMatrix';
import cons from '../../../client/state/cons';
import navigation from '../../../client/state/navigation';
import { openNavigation } from '../../../client/action/navigation';
import Welcome from '../../organisms/welcome/Welcome';
import { RoomBaseView } from '../../organisms/room/Room';
export function ClientContent() {
const [roomInfo, setRoomInfo] = useState({
room: null,
eventId: null,
});
const mx = initMatrix.matrixClient;
useEffect(() => {
const handleRoomSelected = (rId, pRoomId, eId) => {
roomInfo.roomTimeline?.removeInternalListeners();
const r = mx.getRoom(rId);
if (r) {
setRoomInfo({
room: r,
eventId: eId ?? null,
});
} else {
setRoomInfo({
room: null,
eventId: null,
});
}
};
navigation.on(cons.events.navigation.ROOM_SELECTED, handleRoomSelected);
return () => {
navigation.removeListener(cons.events.navigation.ROOM_SELECTED, handleRoomSelected);
};
}, [roomInfo, mx]);
const { room, eventId } = roomInfo;
if (!room) {
setTimeout(() => openNavigation());
return ;
}
return ;
}