import React, { useEffect, useState } from "react"; import RenameInput from "../inputs/RenameInput"; import { useSelectedZoneStore } from "../../../store/visualization/useZoneStore"; import { getZoneData } from "../../../services/visulization/zone/getZones"; import useModuleStore, { useSubModuleStore, } from "../../../store/useModuleStore"; import { ArrowIcon, EyeIcon, LockIcon, RemoveIcon, } from "../../icons/ExportCommonIcons"; import { useFloorItems, useZoneAssetId, useZones } from "../../../store/store"; import { zoneCameraUpdate } from "../../../services/visulization/zone/zoneCameraUpdation"; import { setFloorItemApi } from "../../../services/factoryBuilder/assest/floorAsset/setFloorItemApi"; interface Asset { id: string; name: string; position?: [number, number, number]; // Proper 3D vector rotation?: { x: number; y: number; z: number }; // Proper rotation format } interface ZoneItem { id: string; name: string; assets?: Asset[]; } interface ListProps { items?: ZoneItem[]; remove?: boolean; } const List: React.FC = ({ items = [], remove }) => { const { activeModule } = useModuleStore(); const { selectedZone, setSelectedZone } = useSelectedZoneStore(); const { zoneAssetId, setZoneAssetId } = useZoneAssetId(); const { zones } = useZones(); const { setSubModule } = useSubModuleStore(); const [expandedZones, setExpandedZones] = useState>( {} ); const { setFloorItems } = useFloorItems(); useEffect(() => { useSelectedZoneStore.getState().setSelectedZone({ zoneName: "", activeSides: [], panelOrder: [], lockedPanels: [], zoneId: "", zoneViewPortTarget: [], zoneViewPortPosition: [], widgets: [], }); }, [activeModule]); const toggleZoneExpansion = (zoneId: string) => { setExpandedZones((prev) => ({ ...prev, [zoneId]: !prev[zoneId], })); }; async function handleSelectZone(id: string) { try { if (selectedZone?.zoneId === id) { return; } setSubModule("zoneProperties"); const email = localStorage.getItem("email"); const organization = email?.split("@")[1]?.split(".")[0] ?? ""; let response = await getZoneData(id, organization); setSelectedZone({ zoneName: response?.zoneName, activeSides: response?.activeSides ?? [], panelOrder: response?.panelOrder ?? [], lockedPanels: response?.lockedPanels ?? [], widgets: response?.widgets ?? [], zoneId: response?.zoneId, zoneViewPortTarget: response?.viewPortCenter ?? [], zoneViewPortPosition: response?.viewPortposition ?? [], }); } catch (error) { console.log(error); } } function handleAssetClick(asset: Asset) { setZoneAssetId(asset); } async function handleZoneNameChange(newName: string) { const email = localStorage.getItem("email") ?? ""; const organization = email?.split("@")[1]?.split(".")[0]; const isDuplicate = zones.some( (zone: any) => zone.zoneName.trim().toLowerCase() === newName.trim().toLowerCase() && zone.zoneId !== selectedZone.zoneId ); if (isDuplicate) { alert("Zone name already exists. Please choose a different name."); return; // DO NOT update state } const zonesdata = { zoneId: selectedZone.zoneId, zoneName: newName, }; const response = await zoneCameraUpdate(zonesdata, organization); if (response.message === "updated successfully") { setSelectedZone((prev) => ({ ...prev, zoneName: newName })); } } async function handleZoneAssetName(newName: string) { const email = localStorage.getItem("email") ?? ""; const organization = email?.split("@")[1]?.split(".")[0]; if (zoneAssetId?.id) { let response = await setFloorItemApi( organization, zoneAssetId.id, newName ); console.log("response: ", response); setFloorItems((prevFloorItems: any[]) => prevFloorItems.map((floorItems) => floorItems.modeluuid === zoneAssetId.id ? { ...floorItems, modelname: response.modelname } : floorItems ) ); } } const checkZoneNameDuplicate = (name: string) => { return zones.some( (zone: any) => zone.zoneName.trim().toLowerCase() === name.trim().toLowerCase() && zone.zoneId !== selectedZone.zoneId ); }; return ( <> {items?.length > 0 ? ( ) : (
No items to display
)} ); }; export default List;