nitro-react/src/views/main/MainView.tsx

57 lines
2.1 KiB
TypeScript
Raw Normal View History

2021-04-18 06:58:57 +02:00
import { Nitro, RoomSessionEvent } from 'nitro-renderer';
2021-04-15 08:24:12 +02:00
import { useCallback, useEffect, useState } from 'react';
2021-04-14 23:47:02 +02:00
import { useRoomSessionManagerEvent } from '../../hooks/events/nitro/session/room-session-manager-event';
2021-04-21 05:36:39 +02:00
import { TransitionAnimation } from '../../transitions/TransitionAnimation';
2021-04-22 08:45:47 +02:00
import { TransitionAnimationTypes } from '../../transitions/TransitionAnimation.types';
2021-04-22 05:26:30 +02:00
import { CatalogView } from '../catalog/CatalogView';
2021-04-14 20:24:24 +02:00
import { HotelView } from '../hotel-view/HotelView';
2021-04-22 05:18:44 +02:00
import { InventoryView } from '../inventory/InventoryView';
2021-04-18 06:58:57 +02:00
import { NavigatorView } from '../navigator/NavigatorView';
2021-04-15 19:29:48 +02:00
import { RightSideView } from '../right-side/RightSideView';
2021-04-18 06:58:57 +02:00
import { RoomHostView } from '../room-host/RoomHostView';
2021-04-14 20:24:24 +02:00
import { ToolbarView } from '../toolbar/ToolbarView';
import { MainViewProps } from './MainView.types';
export function MainView(props: MainViewProps): JSX.Element
{
2021-04-15 08:24:12 +02:00
const [ isReady, setIsReady ] = useState(false);
2021-04-18 06:58:57 +02:00
const [ landingViewVisible, setLandingViewVisible ] = useState(true);
2021-04-14 23:47:02 +02:00
2021-04-15 08:24:12 +02:00
const onRoomSessionEvent = useCallback((event: RoomSessionEvent) =>
2021-04-14 23:47:02 +02:00
{
2021-04-18 06:58:57 +02:00
switch(event.type)
{
case RoomSessionEvent.CREATED:
setLandingViewVisible(false);
return;
case RoomSessionEvent.ENDED:
setLandingViewVisible(event.openLandingView);
return;
}
2021-04-15 08:24:12 +02:00
}, []);
2021-04-14 23:47:02 +02:00
useRoomSessionManagerEvent(RoomSessionEvent.CREATED, onRoomSessionEvent);
useRoomSessionManagerEvent(RoomSessionEvent.ENDED, onRoomSessionEvent);
2021-04-14 20:24:24 +02:00
useEffect(() =>
{
2021-04-15 08:24:12 +02:00
setIsReady(true);
2021-04-14 20:24:24 +02:00
Nitro.instance.communication.connection.onReady();
2021-04-15 08:24:12 +02:00
}, []);
2021-04-14 20:24:24 +02:00
return (
2021-04-19 18:34:31 +02:00
<div className="nitro-main">
2021-04-18 06:58:57 +02:00
{ landingViewVisible && <HotelView /> }
<RoomHostView />
2021-04-22 08:45:47 +02:00
<TransitionAnimation className="nitro-toolbar" type={ TransitionAnimationTypes.SLIDE_LEFT } inProp={ isReady } timeout={ 300 }>
2021-04-19 18:34:31 +02:00
<ToolbarView isInRoom={ !landingViewVisible } />
2021-04-21 05:36:39 +02:00
</TransitionAnimation>
2021-04-19 18:34:31 +02:00
<NavigatorView />
2021-04-22 05:18:44 +02:00
<InventoryView />
2021-04-22 05:26:30 +02:00
<CatalogView />
2021-04-19 18:34:31 +02:00
<RightSideView />
2021-04-14 20:24:24 +02:00
</div>
);
}