Spectator Mode

This commit is contained in:
MyNameIsBatman 2022-04-23 16:00:14 -03:00
parent f20fb698bc
commit ed211519a7
13 changed files with 42 additions and 1 deletions

Binary file not shown.

After

Width:  |  Height:  |  Size: 461 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 456 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 98 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 94 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 94 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 95 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 408 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 412 B

View File

@ -1 +1,2 @@
@import "./spectator/RoomSpectatorView";
@import "./widgets/RoomWidgets"; @import "./widgets/RoomWidgets";

View File

@ -5,12 +5,14 @@ import { Base } from '../../common';
import { UseRoomEngineEvent, UseRoomSessionManagerEvent } from '../../hooks'; import { UseRoomEngineEvent, UseRoomSessionManagerEvent } from '../../hooks';
import { RoomColorView } from './RoomColorView'; import { RoomColorView } from './RoomColorView';
import { RoomContextProvider } from './RoomContext'; import { RoomContextProvider } from './RoomContext';
import { RoomSpectatorView } from './spectator/RoomSpectatorView';
import { RoomWidgetsView } from './widgets/RoomWidgetsView'; import { RoomWidgetsView } from './widgets/RoomWidgetsView';
export const RoomView: FC<{}> = props => export const RoomView: FC<{}> = props =>
{ {
const [ roomSession, setRoomSession ] = useState<IRoomSession>(null); const [ roomSession, setRoomSession ] = useState<IRoomSession>(null);
const [ widgetHandler, setWidgetHandler ] = useState<IRoomWidgetHandlerManager>(null); const [ widgetHandler, setWidgetHandler ] = useState<IRoomWidgetHandlerManager>(null);
const [ isSpectator, setIsSpectator ] = useState<boolean>(false);
const elementRef = useRef<HTMLDivElement>(); const elementRef = useRef<HTMLDivElement>();
const onRoomEngineEvent = useCallback((event: RoomEngineEvent) => const onRoomEngineEvent = useCallback((event: RoomEngineEvent) =>
@ -143,6 +145,7 @@ export const RoomView: FC<{}> = props =>
stage.addChild(displayObject); stage.addChild(displayObject);
SetActiveRoomId(roomSession.roomId); SetActiveRoomId(roomSession.roomId);
setIsSpectator(roomSession.isSpectator);
}, [ roomSession, resize ]); }, [ roomSession, resize ]);
useEffect(() => useEffect(() =>
@ -184,6 +187,7 @@ export const RoomView: FC<{}> = props =>
<> <>
<RoomColorView /> <RoomColorView />
<RoomWidgetsView /> <RoomWidgetsView />
{ isSpectator && <RoomSpectatorView /> }
</> } </> }
</Base> </Base>
</RoomContextProvider> </RoomContextProvider>

View File

@ -0,0 +1,26 @@
.room-spectator {
position: fixed;
top: 0;
left: 0;
width: 100%;
height: calc(100% - 50px);
user-select: none;
pointer-events: none;
opacity: 0.8;
background: url("../../../assets/images/room-spectator/room_spectator_top_left.png") no-repeat top left,
url("../../../assets/images/room-spectator/room_spectator_top_right.png") no-repeat top right,
url("../../../assets/images/room-spectator/room_spectator_bottom_right.png") no-repeat bottom right,
url("../../../assets/images/room-spectator/room_spectator_bottom_left.png") no-repeat bottom left,
url("../../../assets/images/room-spectator/room_spectator_middle_left.png") repeat-y left,
url("../../../assets/images/room-spectator/room_spectator_middle_top.png") repeat-x top,
url("../../../assets/images/room-spectator/room_spectator_middle_right.png") repeat-y right,
url("../../../assets/images/room-spectator/room_spectator_middle_bottom.png") repeat-x bottom
;
}
/*
border-image-slice: 91 91 110 91 fill;
border-image-width: 79px 79px 79px 79px;
border-image-outset: 0px 0px 0px 0px;
border-image-repeat: repeat repeat;
border-image-source: url("../../../assets/images/room-spectator/room_spectator.png");
*/

View File

@ -0,0 +1,8 @@
import { FC } from 'react';
export const RoomSpectatorView: FC<{}> = props =>
{
return (
<div className="room-spectator"></div>
);
};

View File

@ -1,7 +1,7 @@
import { HabboClubLevelEnum, RoomControllerLevel } from '@nitrots/nitro-renderer'; import { HabboClubLevelEnum, RoomControllerLevel } from '@nitrots/nitro-renderer';
import { FC, useCallback, useEffect, useMemo, useRef, useState } from 'react'; import { FC, useCallback, useEffect, useMemo, useRef, useState } from 'react';
import { createPortal } from 'react-dom'; import { createPortal } from 'react-dom';
import { GetClubMemberLevel, GetConfiguration, GetSessionDataManager, LocalizeText, RoomWidgetChatMessage, RoomWidgetChatTypingMessage, RoomWidgetFloodControlEvent, RoomWidgetUpdateChatInputContentEvent, RoomWidgetUpdateInfostandUserEvent, RoomWidgetUpdateRoomObjectEvent } from '../../../../api'; import { GetClubMemberLevel, GetConfiguration, GetRoomSession, GetSessionDataManager, LocalizeText, RoomWidgetChatMessage, RoomWidgetChatTypingMessage, RoomWidgetFloodControlEvent, RoomWidgetUpdateChatInputContentEvent, RoomWidgetUpdateInfostandUserEvent, RoomWidgetUpdateRoomObjectEvent } from '../../../../api';
import { Text } from '../../../../common'; import { Text } from '../../../../common';
import { UseEventDispatcherHook } from '../../../../hooks'; import { UseEventDispatcherHook } from '../../../../hooks';
import { useRoomContext } from '../../RoomContext'; import { useRoomContext } from '../../RoomContext';
@ -355,6 +355,8 @@ export const ChatInputView: FC<{}> = props =>
inputRef.current.parentElement.dataset.value = chatValue; inputRef.current.parentElement.dataset.value = chatValue;
}, [ chatValue ]); }, [ chatValue ]);
if(GetRoomSession().isSpectator) return null;
return ( return (
createPortal( createPortal(
<div className="nitro-chat-input-container"> <div className="nitro-chat-input-container">