mirror of
https://github.com/billsonnn/nitro-react.git
synced 2024-11-23 14:40:50 +01:00
Add RoomColorView
This commit is contained in:
parent
0e4a9c3bea
commit
79b0a8e232
@ -1,22 +0,0 @@
|
|||||||
import { Nitro } from 'nitro-renderer';
|
|
||||||
import { InitializeRoomInstanceRenderingCanvas } from './InitializeRoomInstanceRenderingCanvas';
|
|
||||||
|
|
||||||
let resizeTimer: ReturnType<typeof setTimeout> = null;
|
|
||||||
|
|
||||||
export function WindowResizeEvent(roomId: number, canvasId: number)
|
|
||||||
{
|
|
||||||
if(resizeTimer) clearTimeout(resizeTimer);
|
|
||||||
|
|
||||||
resizeTimer = setTimeout(() =>
|
|
||||||
{
|
|
||||||
Nitro.instance.renderer.resize(window.innerWidth, window.innerHeight);
|
|
||||||
|
|
||||||
InitializeRoomInstanceRenderingCanvas(roomId, canvasId, Nitro.instance.width, Nitro.instance.height);
|
|
||||||
|
|
||||||
//this._events.dispatchEvent(new RoomWidgetRoomViewUpdateEvent(RoomWidgetRoomViewUpdateEvent.SIZE_CHANGED, this.getRoomViewRect()));
|
|
||||||
|
|
||||||
//this.setRoomBackground();
|
|
||||||
|
|
||||||
Nitro.instance.render();
|
|
||||||
}, 1);
|
|
||||||
}
|
|
@ -1,5 +1,4 @@
|
|||||||
export * from './DispatchMouseEvent';
|
export * from './DispatchMouseEvent';
|
||||||
export * from './DispatchResizeEvent';
|
|
||||||
export * from './DispatchTouchEvent';
|
export * from './DispatchTouchEvent';
|
||||||
export * from './GetOwnRoomObject';
|
export * from './GetOwnRoomObject';
|
||||||
export * from './GetRoomEngine';
|
export * from './GetRoomEngine';
|
||||||
|
152
src/views/room/RoomColorView.tsx
Normal file
152
src/views/room/RoomColorView.tsx
Normal file
@ -0,0 +1,152 @@
|
|||||||
|
import { ColorConverter, Nitro, NitroAdjustmentFilter, NitroContainer, NitroSprite, NitroTexture, RoomBackgroundColorEvent, RoomEngineEvent, RoomId, RoomObjectHSLColorEnabledEvent } from 'nitro-renderer';
|
||||||
|
import { FC, useCallback, useState } from 'react';
|
||||||
|
import { GetRoomEngine } from '../../api';
|
||||||
|
import { UseMountEffect } from '../../hooks';
|
||||||
|
import { CreateEventDispatcherHook, useRoomEngineEvent } from '../../hooks/events';
|
||||||
|
import { useRoomContext } from './context/RoomContext';
|
||||||
|
import { RoomWidgetUpdateRoomViewEvent } from './events/RoomWidgetUpdateRoomViewEvent';
|
||||||
|
|
||||||
|
const ROOM_FILTER: NitroAdjustmentFilter = new NitroAdjustmentFilter();
|
||||||
|
|
||||||
|
export const RoomColorView: FC<{}> = props =>
|
||||||
|
{
|
||||||
|
const [ roomBackground, setRoomBackground ] = useState<NitroSprite>(null);
|
||||||
|
const [ roomBackgroundColor, setRoomBackgroundColor ] = useState(0x000000);
|
||||||
|
const [ roomFilter, setRoomFilter ] = useState<NitroAdjustmentFilter>(null);
|
||||||
|
const [ roomFilterColor, setRoomFilterColor ] = useState(-1);
|
||||||
|
const { roomSession = null, canvasId = -1, eventDispatcher = null } = useRoomContext();
|
||||||
|
|
||||||
|
const getRenderingCanvas = useCallback(() =>
|
||||||
|
{
|
||||||
|
return GetRoomEngine().getRoomInstanceRenderingCanvas(roomSession.roomId, canvasId);
|
||||||
|
}, [ roomSession, canvasId ]);
|
||||||
|
|
||||||
|
const getRoomBackground = useCallback(() =>
|
||||||
|
{
|
||||||
|
if(roomBackground) return roomBackground;
|
||||||
|
|
||||||
|
const canvas = getRenderingCanvas();
|
||||||
|
|
||||||
|
if(!canvas) return null;
|
||||||
|
|
||||||
|
const displayObject = (canvas.master as NitroContainer);
|
||||||
|
const background = new NitroSprite(NitroTexture.WHITE);
|
||||||
|
|
||||||
|
displayObject.addChildAt(background, 0);
|
||||||
|
|
||||||
|
setRoomBackground(background);
|
||||||
|
|
||||||
|
return background;
|
||||||
|
}, [ roomBackground, getRenderingCanvas ]);
|
||||||
|
|
||||||
|
const updateRoomBackground = useCallback(() =>
|
||||||
|
{
|
||||||
|
const background = getRoomBackground();
|
||||||
|
|
||||||
|
if(!background) return;
|
||||||
|
|
||||||
|
background.tint = roomBackgroundColor;
|
||||||
|
background.width = Nitro.instance.width;
|
||||||
|
background.height = Nitro.instance.height;
|
||||||
|
}, [ roomBackgroundColor, getRoomBackground ]);
|
||||||
|
|
||||||
|
const updateRoomBackgroundColor = useCallback((hue: number, saturation: number, lightness: number) =>
|
||||||
|
{
|
||||||
|
setRoomBackgroundColor(ColorConverter.hslToRGB(((((hue & 0xFF) << 16) + ((saturation & 0xFF) << 8)) + (lightness & 0xFF))));
|
||||||
|
|
||||||
|
const background = getRoomBackground();
|
||||||
|
|
||||||
|
if(!background) return;
|
||||||
|
|
||||||
|
if(!hue && !saturation && !lightness)
|
||||||
|
{
|
||||||
|
background.visible = false;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
updateRoomBackground();
|
||||||
|
|
||||||
|
background.visible = true;
|
||||||
|
}
|
||||||
|
}, [ getRoomBackground, updateRoomBackground ]);
|
||||||
|
|
||||||
|
const getRoomFilter = useCallback(() =>
|
||||||
|
{
|
||||||
|
if(roomFilter) return roomFilter;
|
||||||
|
|
||||||
|
const canvas = getRenderingCanvas();
|
||||||
|
|
||||||
|
if(!canvas) return null;
|
||||||
|
|
||||||
|
const display = canvas.master;
|
||||||
|
|
||||||
|
if(!display) return null;
|
||||||
|
|
||||||
|
setRoomFilter(ROOM_FILTER);
|
||||||
|
|
||||||
|
display.filters = [ ROOM_FILTER ];
|
||||||
|
|
||||||
|
return ROOM_FILTER;
|
||||||
|
}, [ roomFilter, getRenderingCanvas ]);
|
||||||
|
|
||||||
|
const updateRoomFilter = useCallback(() =>
|
||||||
|
{
|
||||||
|
const colorMatrix = getRoomFilter();
|
||||||
|
|
||||||
|
if(!colorMatrix) return;
|
||||||
|
|
||||||
|
const r = ((roomFilterColor >> 16) & 0xFF);
|
||||||
|
const g = ((roomFilterColor >> 8) & 0xFF);
|
||||||
|
const b = (roomFilterColor & 0xFF);
|
||||||
|
|
||||||
|
colorMatrix.red = (r / 255);
|
||||||
|
colorMatrix.green = (g / 255);
|
||||||
|
colorMatrix.blue = (b / 255);
|
||||||
|
}, [ roomFilterColor, getRoomFilter ]);
|
||||||
|
|
||||||
|
const updateRoomFilterColor = useCallback((color: number, brightness: number) =>
|
||||||
|
{
|
||||||
|
setRoomFilterColor(ColorConverter.hslToRGB(((ColorConverter.rgbToHSL(color) & 0xFFFF00) + brightness)));
|
||||||
|
|
||||||
|
updateRoomFilter();
|
||||||
|
}, [ updateRoomFilter ]);
|
||||||
|
|
||||||
|
const onRoomEngineEvent = useCallback((event: RoomEngineEvent) =>
|
||||||
|
{
|
||||||
|
if(!RoomId.isRoomPreviewerId(event.roomId)) return;
|
||||||
|
|
||||||
|
switch(event.type)
|
||||||
|
{
|
||||||
|
case RoomObjectHSLColorEnabledEvent.ROOM_BACKGROUND_COLOR: {
|
||||||
|
const hslColorEvent = (event as RoomObjectHSLColorEnabledEvent);
|
||||||
|
|
||||||
|
if(hslColorEvent.enable) updateRoomBackgroundColor(hslColorEvent.hue, hslColorEvent.saturation, hslColorEvent.lightness);
|
||||||
|
else updateRoomBackgroundColor(0, 0, 0);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
case RoomBackgroundColorEvent.ROOM_COLOR: {
|
||||||
|
const colorEvent = (event as RoomBackgroundColorEvent);
|
||||||
|
|
||||||
|
if(colorEvent.bgOnly) updateRoomFilterColor(0xFF0000, 0xFF);
|
||||||
|
else updateRoomFilterColor(colorEvent.color, colorEvent.brightness);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, [ updateRoomBackgroundColor, updateRoomFilterColor ]);
|
||||||
|
|
||||||
|
useRoomEngineEvent(RoomObjectHSLColorEnabledEvent.ROOM_BACKGROUND_COLOR, onRoomEngineEvent);
|
||||||
|
useRoomEngineEvent(RoomBackgroundColorEvent.ROOM_COLOR, onRoomEngineEvent);
|
||||||
|
|
||||||
|
const onRoomWidgetUpdateRoomViewEvent = useCallback((event: RoomWidgetUpdateRoomViewEvent) =>
|
||||||
|
{
|
||||||
|
updateRoomBackground();
|
||||||
|
}, [ updateRoomBackground ]);
|
||||||
|
|
||||||
|
CreateEventDispatcherHook(RoomWidgetUpdateRoomViewEvent.SIZE_CHANGED, eventDispatcher, onRoomWidgetUpdateRoomViewEvent);
|
||||||
|
|
||||||
|
UseMountEffect(updateRoomBackground);
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
@ -1,15 +1,16 @@
|
|||||||
import { EventDispatcher, Nitro, RoomEngineEvent, RoomEngineObjectEvent, RoomGeometry, RoomId, RoomObjectCategory, RoomObjectOperationType, RoomVariableEnum, Vector3d } from 'nitro-renderer';
|
import { EventDispatcher, Nitro, NitroRectangle, RoomEngineEvent, RoomEngineObjectEvent, RoomGeometry, RoomId, RoomObjectCategory, RoomObjectOperationType, RoomVariableEnum, RoomZoomEvent, Vector3d } from 'nitro-renderer';
|
||||||
import { FC, useCallback, useEffect, useState } from 'react';
|
import { FC, useCallback, useEffect, useState } from 'react';
|
||||||
import { createPortal } from 'react-dom';
|
import { createPortal } from 'react-dom';
|
||||||
import { CanManipulateFurniture, IsFurnitureSelectionDisabled, ProcessRoomObjectOperation } from '../../api';
|
import { CanManipulateFurniture, InitializeRoomInstanceRenderingCanvas, IsFurnitureSelectionDisabled, ProcessRoomObjectOperation } from '../../api';
|
||||||
import { DispatchMouseEvent } from '../../api/nitro/room/DispatchMouseEvent';
|
import { DispatchMouseEvent } from '../../api/nitro/room/DispatchMouseEvent';
|
||||||
import { WindowResizeEvent } from '../../api/nitro/room/DispatchResizeEvent';
|
|
||||||
import { DispatchTouchEvent } from '../../api/nitro/room/DispatchTouchEvent';
|
import { DispatchTouchEvent } from '../../api/nitro/room/DispatchTouchEvent';
|
||||||
import { GetRoomEngine } from '../../api/nitro/room/GetRoomEngine';
|
import { GetRoomEngine } from '../../api/nitro/room/GetRoomEngine';
|
||||||
import { useRoomEngineEvent } from '../../hooks/events';
|
import { useRoomEngineEvent } from '../../hooks/events';
|
||||||
import { RoomContextProvider } from './context/RoomContext';
|
import { RoomContextProvider } from './context/RoomContext';
|
||||||
import { RoomWidgetRoomEngineUpdateEvent, RoomWidgetRoomObjectUpdateEvent } from './events';
|
import { RoomWidgetRoomEngineUpdateEvent, RoomWidgetRoomObjectUpdateEvent } from './events';
|
||||||
|
import { RoomWidgetUpdateRoomViewEvent } from './events/RoomWidgetUpdateRoomViewEvent';
|
||||||
import { FurnitureContextMenuWidgetHandler, IRoomWidgetHandlerManager, RoomWidgetAvatarInfoHandler, RoomWidgetChatHandler, RoomWidgetChatInputHandler, RoomWidgetHandlerManager, RoomWidgetInfostandHandler } from './handlers';
|
import { FurnitureContextMenuWidgetHandler, IRoomWidgetHandlerManager, RoomWidgetAvatarInfoHandler, RoomWidgetChatHandler, RoomWidgetChatInputHandler, RoomWidgetHandlerManager, RoomWidgetInfostandHandler } from './handlers';
|
||||||
|
import { RoomColorView } from './RoomColorView';
|
||||||
import { RoomViewProps } from './RoomView.types';
|
import { RoomViewProps } from './RoomView.types';
|
||||||
import { RoomWidgetsView } from './widgets/RoomWidgetsView';
|
import { RoomWidgetsView } from './widgets/RoomWidgetsView';
|
||||||
|
|
||||||
@ -17,6 +18,7 @@ export const RoomView: FC<RoomViewProps> = props =>
|
|||||||
{
|
{
|
||||||
const { roomSession = null } = props;
|
const { roomSession = null } = props;
|
||||||
const [ roomCanvas, setRoomCanvas ] = useState<HTMLCanvasElement>(null);
|
const [ roomCanvas, setRoomCanvas ] = useState<HTMLCanvasElement>(null);
|
||||||
|
const [ canvasId, setCanvasId ] = useState(-1);
|
||||||
const [ widgetHandler, setWidgetHandler ] = useState<IRoomWidgetHandlerManager>(null);
|
const [ widgetHandler, setWidgetHandler ] = useState<IRoomWidgetHandlerManager>(null);
|
||||||
|
|
||||||
useEffect(() =>
|
useEffect(() =>
|
||||||
@ -26,6 +28,7 @@ export const RoomView: FC<RoomViewProps> = props =>
|
|||||||
window.onresize = null;
|
window.onresize = null;
|
||||||
|
|
||||||
setRoomCanvas(null);
|
setRoomCanvas(null);
|
||||||
|
setCanvasId(-1);
|
||||||
setWidgetHandler(null);
|
setWidgetHandler(null);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
@ -91,9 +94,22 @@ export const RoomView: FC<RoomViewProps> = props =>
|
|||||||
canvas.ontouchend = event => DispatchTouchEvent(roomSession.roomId, canvasId, event);
|
canvas.ontouchend = event => DispatchTouchEvent(roomSession.roomId, canvasId, event);
|
||||||
canvas.ontouchcancel = event => DispatchTouchEvent(roomSession.roomId, canvasId, event);
|
canvas.ontouchcancel = event => DispatchTouchEvent(roomSession.roomId, canvasId, event);
|
||||||
|
|
||||||
window.onresize = event => WindowResizeEvent(roomSession.roomId, canvasId);
|
window.onresize = () =>
|
||||||
|
{
|
||||||
|
Nitro.instance.renderer.resize(window.innerWidth, window.innerHeight);
|
||||||
|
|
||||||
|
InitializeRoomInstanceRenderingCanvas(roomSession.roomId, canvasId, Nitro.instance.width, Nitro.instance.height);
|
||||||
|
|
||||||
|
const bounds = canvas.getBoundingClientRect();
|
||||||
|
const rectangle = new NitroRectangle((bounds.x || 0), (bounds.y || 0), (bounds.width || 0), (bounds.height || 0));
|
||||||
|
|
||||||
|
widgetHandlerManager.eventDispatcher.dispatchEvent(new RoomWidgetUpdateRoomViewEvent(RoomWidgetUpdateRoomViewEvent.SIZE_CHANGED, rectangle));
|
||||||
|
|
||||||
|
Nitro.instance.render();
|
||||||
|
}
|
||||||
|
|
||||||
setRoomCanvas(canvas);
|
setRoomCanvas(canvas);
|
||||||
|
setCanvasId(canvasId);
|
||||||
}, [ roomSession ]);
|
}, [ roomSession ]);
|
||||||
|
|
||||||
const onRoomEngineEvent = useCallback((event: RoomEngineEvent) =>
|
const onRoomEngineEvent = useCallback((event: RoomEngineEvent) =>
|
||||||
@ -107,12 +123,24 @@ export const RoomView: FC<RoomViewProps> = props =>
|
|||||||
return;
|
return;
|
||||||
case RoomEngineEvent.GAME_MODE:
|
case RoomEngineEvent.GAME_MODE:
|
||||||
widgetHandler.eventDispatcher.dispatchEvent(new RoomWidgetRoomEngineUpdateEvent(RoomWidgetRoomEngineUpdateEvent.GAME_MODE, event.roomId));
|
widgetHandler.eventDispatcher.dispatchEvent(new RoomWidgetRoomEngineUpdateEvent(RoomWidgetRoomEngineUpdateEvent.GAME_MODE, event.roomId));
|
||||||
|
return;
|
||||||
|
case RoomZoomEvent.ROOM_ZOOM: {
|
||||||
|
const zoomEvent = (event as RoomZoomEvent);
|
||||||
|
|
||||||
|
let zoomLevel = ((zoomEvent.level < 1) ? 0.5 : (1 << (Math.floor(zoomEvent.level) - 1)));
|
||||||
|
|
||||||
|
if(zoomEvent.forceFlip || zoomEvent.asDelta) zoomLevel = zoomEvent.level;
|
||||||
|
|
||||||
|
GetRoomEngine().setRoomInstanceRenderingCanvasScale(roomSession.roomId, 1, zoomLevel, null, null, false, zoomEvent.asDelta);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}, [ widgetHandler ]);
|
}
|
||||||
|
}, [ widgetHandler, roomSession ]);
|
||||||
|
|
||||||
useRoomEngineEvent(RoomEngineEvent.NORMAL_MODE, onRoomEngineEvent);
|
useRoomEngineEvent(RoomEngineEvent.NORMAL_MODE, onRoomEngineEvent);
|
||||||
useRoomEngineEvent(RoomEngineEvent.GAME_MODE, onRoomEngineEvent);
|
useRoomEngineEvent(RoomEngineEvent.GAME_MODE, onRoomEngineEvent);
|
||||||
|
useRoomEngineEvent(RoomZoomEvent.ROOM_ZOOM, onRoomEngineEvent);
|
||||||
|
|
||||||
const onRoomEngineObjectEvent = useCallback((event: RoomEngineObjectEvent) =>
|
const onRoomEngineObjectEvent = useCallback((event: RoomEngineObjectEvent) =>
|
||||||
{
|
{
|
||||||
@ -206,11 +234,15 @@ export const RoomView: FC<RoomViewProps> = props =>
|
|||||||
if(!roomSession) return null;
|
if(!roomSession) return null;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<RoomContextProvider value={ { roomSession, eventDispatcher: (widgetHandler && widgetHandler.eventDispatcher), widgetHandler } }>
|
<RoomContextProvider value={ { roomSession, canvasId, eventDispatcher: (widgetHandler && widgetHandler.eventDispatcher), widgetHandler } }>
|
||||||
<div className="nitro-room w-100 h-100">
|
<div className="nitro-room w-100 h-100">
|
||||||
<div id="room-view" className="nitro-room-container"></div>
|
<div id="room-view" className="nitro-room-container"></div>
|
||||||
{ roomCanvas && createPortal(null, document.getElementById('room-view').appendChild(roomCanvas)) }
|
{ roomCanvas && createPortal(null, document.getElementById('room-view').appendChild(roomCanvas)) }
|
||||||
{ widgetHandler && <RoomWidgetsView /> }
|
{ widgetHandler &&
|
||||||
|
<>
|
||||||
|
<RoomColorView />
|
||||||
|
<RoomWidgetsView />
|
||||||
|
</> }
|
||||||
</div>
|
</div>
|
||||||
</RoomContextProvider>
|
</RoomContextProvider>
|
||||||
);
|
);
|
||||||
|
@ -3,6 +3,7 @@ import { IRoomContext, RoomContextProps } from './RoomContext.types';
|
|||||||
|
|
||||||
const RoomContext = createContext<IRoomContext>({
|
const RoomContext = createContext<IRoomContext>({
|
||||||
roomSession: null,
|
roomSession: null,
|
||||||
|
canvasId: -1,
|
||||||
eventDispatcher: null,
|
eventDispatcher: null,
|
||||||
widgetHandler: null
|
widgetHandler: null
|
||||||
});
|
});
|
||||||
|
@ -5,6 +5,7 @@ import { IRoomWidgetHandlerManager } from '../handlers';
|
|||||||
export interface IRoomContext
|
export interface IRoomContext
|
||||||
{
|
{
|
||||||
roomSession: IRoomSession;
|
roomSession: IRoomSession;
|
||||||
|
canvasId: number;
|
||||||
eventDispatcher: IEventDispatcher;
|
eventDispatcher: IEventDispatcher;
|
||||||
widgetHandler: IRoomWidgetHandlerManager;
|
widgetHandler: IRoomWidgetHandlerManager;
|
||||||
}
|
}
|
||||||
|
21
src/views/room/events/RoomWidgetUpdateRoomViewEvent.ts
Normal file
21
src/views/room/events/RoomWidgetUpdateRoomViewEvent.ts
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
import { NitroRectangle } from 'nitro-renderer';
|
||||||
|
import { RoomWidgetUpdateEvent } from './RoomWidgetUpdateEvent';
|
||||||
|
|
||||||
|
export class RoomWidgetUpdateRoomViewEvent extends RoomWidgetUpdateEvent
|
||||||
|
{
|
||||||
|
public static SIZE_CHANGED: string = 'RWURVE_SIZE_CHANGED';
|
||||||
|
|
||||||
|
private _roomViewRectangle: NitroRectangle;
|
||||||
|
|
||||||
|
constructor(type: string, view: NitroRectangle)
|
||||||
|
{
|
||||||
|
super(type);
|
||||||
|
|
||||||
|
this._roomViewRectangle = view;
|
||||||
|
}
|
||||||
|
|
||||||
|
public get roomViewRectangle(): NitroRectangle
|
||||||
|
{
|
||||||
|
return this._roomViewRectangle;
|
||||||
|
}
|
||||||
|
}
|
@ -1,4 +1,4 @@
|
|||||||
import { NitroEvent, RoomEngineUseProductEvent, RoomSessionChatEvent, RoomSessionDanceEvent, RoomSessionDimmerPresetsEvent, RoomSessionDoorbellEvent, RoomSessionErrorMessageEvent, RoomSessionEvent, RoomSessionFriendRequestEvent, RoomSessionPetInfoUpdateEvent, RoomSessionPresentEvent, RoomSessionUserBadgesEvent } from 'nitro-renderer';
|
import { NitroEvent, RoomEngineDimmerStateEvent, RoomEngineUseProductEvent, RoomSessionChatEvent, RoomSessionDanceEvent, RoomSessionDimmerPresetsEvent, RoomSessionDoorbellEvent, RoomSessionErrorMessageEvent, RoomSessionEvent, RoomSessionFriendRequestEvent, RoomSessionPetInfoUpdateEvent, RoomSessionPresentEvent, RoomSessionUserBadgesEvent } from 'nitro-renderer';
|
||||||
import { FC, useCallback } from 'react';
|
import { FC, useCallback } from 'react';
|
||||||
import { useRoomEngineEvent, useRoomSessionManagerEvent } from '../../../hooks/events';
|
import { useRoomEngineEvent, useRoomSessionManagerEvent } from '../../../hooks/events';
|
||||||
import { LocalizeText } from '../../../utils/LocalizeText';
|
import { LocalizeText } from '../../../utils/LocalizeText';
|
||||||
@ -13,7 +13,7 @@ import { RoomWidgetViewProps } from './RoomWidgets.types';
|
|||||||
|
|
||||||
export const RoomWidgetsView: FC<RoomWidgetViewProps> = props =>
|
export const RoomWidgetsView: FC<RoomWidgetViewProps> = props =>
|
||||||
{
|
{
|
||||||
const { eventDispatcher = null, widgetHandler = null } = useRoomContext();
|
const { widgetHandler = null } = useRoomContext();
|
||||||
|
|
||||||
const onNitroEvent = useCallback((event: NitroEvent) =>
|
const onNitroEvent = useCallback((event: NitroEvent) =>
|
||||||
{
|
{
|
||||||
@ -35,6 +35,7 @@ export const RoomWidgetsView: FC<RoomWidgetViewProps> = props =>
|
|||||||
useRoomSessionManagerEvent(RoomSessionPetInfoUpdateEvent.PET_INFO, onNitroEvent);
|
useRoomSessionManagerEvent(RoomSessionPetInfoUpdateEvent.PET_INFO, onNitroEvent);
|
||||||
useRoomEngineEvent(RoomEngineUseProductEvent.USE_PRODUCT_FROM_INVENTORY, onNitroEvent);
|
useRoomEngineEvent(RoomEngineUseProductEvent.USE_PRODUCT_FROM_INVENTORY, onNitroEvent);
|
||||||
useRoomEngineEvent(RoomEngineUseProductEvent.USE_PRODUCT_FROM_ROOM, onNitroEvent);
|
useRoomEngineEvent(RoomEngineUseProductEvent.USE_PRODUCT_FROM_ROOM, onNitroEvent);
|
||||||
|
useRoomEngineEvent(RoomEngineDimmerStateEvent.ROOM_COLOR, onNitroEvent);
|
||||||
|
|
||||||
const onRoomErrorEvent = useCallback((event: RoomSessionEvent) =>
|
const onRoomErrorEvent = useCallback((event: RoomSessionEvent) =>
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user