File size: 948 Bytes
cb5d9d0 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 | import { useState, useRef, useCallback } from "react";
export function useRoomVisualizer() {
const [hoveredMask, setHoveredMask] = useState<string | null>(null);
const [selectedMasks, setSelectedMasks] = useState<Set<string>>(new Set());
const containerRef = useRef<HTMLDivElement>(null);
const handleMaskMouseEnter = useCallback((maskUrl: string) => {
setHoveredMask(maskUrl);
}, []);
const handleMaskMouseLeave = useCallback(() => {
setHoveredMask(null);
}, []);
const handleMaskClick = useCallback((maskUrl: string) => {
setSelectedMasks((prev) => {
const newSelected = new Set(prev);
if (newSelected.has(maskUrl)) {
newSelected.delete(maskUrl);
} else {
newSelected.add(maskUrl);
}
return newSelected;
});
}, []);
return {
containerRef,
hoveredMask,
selectedMasks,
handleMaskClick,
handleMaskMouseEnter,
handleMaskMouseLeave,
};
}
|