Add coolui test

This commit is contained in:
Remco
2026-01-26 19:06:51 +01:00
parent 71a4c6677e
commit d872183654
1734 changed files with 56797 additions and 0 deletions
@@ -0,0 +1,108 @@
import { GetConfiguration } from '@nitrots/nitro-renderer';
import { FC, useRef, useState, useEffect } from 'react';
import { GetConfigurationValue } from '../../api';
import { RoomWidgetView } from './RoomWidgetView';
export const HotelView: FC<{}> = props => {
const backgroundColor = GetConfigurationValue('hotelview')['images']['background.colour'];
console.log('Background color:', backgroundColor);
const containerRef = useRef<HTMLDivElement>(null);
const [isDragging, setIsDragging] = useState(false);
const [startX, setStartX] = useState(0);
const [startY, setStartY] = useState(0);
const [scrollLeft, setScrollLeft] = useState(0);
const [scrollTop, setScrollTop] = useState(0);
useEffect(() => {
if (containerRef.current) {
const container = containerRef.current;
const contentWidth = 3000;
const contentHeight = 1185;
const viewportWidth = window.innerWidth;
const viewportHeight = window.innerHeight - 55;
const initialScrollLeft = (contentWidth - viewportWidth) / 2;
const initialScrollTop = (contentHeight - viewportHeight) / 2;
container.scrollLeft = Math.max(0, initialScrollLeft);
container.scrollTop = Math.max(0, initialScrollTop);
setScrollLeft(container.scrollLeft);
setScrollTop(container.scrollTop);
}
}, []);
const handleMouseDown = (e: React.MouseEvent<HTMLDivElement>) => {
if (e.button !== 0) return;
setIsDragging(true);
setStartX(e.pageX + scrollLeft);
setStartY(e.pageY + scrollTop);
if (containerRef.current) {
containerRef.current.style.cursor = 'grabbing';
}
};
const handleMouseMove = (e: React.MouseEvent<HTMLDivElement>) => {
if (!isDragging) return;
e.preventDefault();
const x = e.pageX;
const y = e.pageY;
const newScrollLeft = startX - x;
const newScrollTop = startY - y;
if (containerRef.current) {
containerRef.current.scrollLeft = newScrollLeft;
containerRef.current.scrollTop = newScrollTop;
setScrollLeft(newScrollLeft);
setScrollTop(newScrollTop);
}
};
const handleMouseUp = () => {
setIsDragging(false);
if (containerRef.current) {
containerRef.current.style.cursor = 'grab';
}
};
const handleMouseLeave = () => {
setIsDragging(false);
if (containerRef.current) {
containerRef.current.style.cursor = 'grab';
}
};
return (
<div
ref={containerRef}
className="nitro-hotel-view block fixed w-full h-[calc(100%-55px)] text-[#000]"
style={{
...(backgroundColor ? { background: backgroundColor } : {}),
overflow: 'auto',
WebkitOverflowScrolling: 'touch',
maxWidth: '100vw',
maxHeight: '100vh',
msOverflowStyle: 'none',
scrollbarWidth: 'none',
'::WebkitScrollbar': { display: 'none' },
cursor: 'grab'
}}
onMouseDown={handleMouseDown}
onMouseMove={handleMouseMove}
onMouseUp={handleMouseUp}
onMouseLeave={handleMouseLeave}
>
<div
className="hotelview position-relative"
style={{
minWidth: '2600px',
minHeight: '1425px'
}}
>
<div className="hotelview-background w-full h-full" style={{ position: 'absolute', top: 0, left: 0 }} />
<RoomWidgetView />
</div>
</div>
);
};
@@ -0,0 +1,42 @@
import { CreateLinkEvent } from '@nitrots/nitro-renderer';
import { FC } from 'react';
import { GetConfigurationValue } from '../../api';
import { Base } from '../../common';
export interface RoomWidgetViewProps {}
export const RoomWidgetView: FC<RoomWidgetViewProps> = props => {
const poolId = GetConfigurationValue<string>('hotelview')['room.pool'];
const picnicId = GetConfigurationValue<string>('hotelview')['room.picnic'];
const rooftopId = GetConfigurationValue<string>('hotelview')['room.rooftop'];
const rooftopPoolId = GetConfigurationValue<string>('hotelview')['room.rooftop.pool'];
const peacefulId = GetConfigurationValue<string>('hotelview')['room.peaceful'];
const infobusId = GetConfigurationValue<string>('hotelview')['room.infobus'];
const lobbyId = GetConfigurationValue<string>('hotelview')['room.lobby'];
return (
<>
<Base className="nitro-hotel-view-rooftop position-absolute" onClick={event => CreateLinkEvent('navigator/goto/' + rooftopId)}>
<i className="arrow" />
</Base>
<Base className="nitro-hotel-view-rooftop-pool position-absolute" onClick={event => CreateLinkEvent('navigator/goto/' + rooftopPoolId)}>
<i className="arrow" />
</Base>
<Base className="nitro-hotel-view-picnic position-absolute" onClick={event => CreateLinkEvent('navigator/goto/' + picnicId)}>
<i className="arrow" />
</Base>
<Base className="nitro-hotel-view-infobus position-absolute" onClick={event => CreateLinkEvent('navigator/goto/' + infobusId)}>
<i className="arrow-infobus" />
</Base>
<Base className="nitro-hotel-view-pool position-absolute" onClick={event => CreateLinkEvent('navigator/goto/' + poolId)}>
<i className="arrow-pool" />
</Base>
<Base className="nitro-hotel-view-lobby position-absolute" onClick={event => CreateLinkEvent('navigator/goto/' + lobbyId)}>
<i className="arrow" />
</Base>
<Base className="nitro-hotel-view-peaceful position-absolute" onClick={event => CreateLinkEvent('navigator/goto/' + peacefulId)}>
<i className="arrow-peaceful" />
</Base>
</>
);
};