import React, { useState, useEffect, useCallback } from 'react'; import Image from 'next/image'; interface MonitoringProps { objectId?: string; onClose?: () => void; onSelectModel?: (modelPath: string) => void; } const Monitoring: React.FC = ({ onClose, onSelectModel }) => { const [models, setModels] = useState<{ title: string; path: string }[]>([]); const [loadError, setLoadError] = useState(null); const handleSelectModel = useCallback((modelPath: string) => { console.log(`[NavigationPage] Model selected: ${modelPath}`); onSelectModel?.(modelPath); }, [onSelectModel]); console.log('[Monitoring] Models:', models, 'Error:', loadError); // Загружаем список доступных моделей из assets/big-models через API useEffect(() => { const fetchModels = async () => { try { setLoadError(null); const res = await fetch('/api/big-models/list'); if (!res.ok) { const text = await res.text(); throw new Error(text || 'Failed to fetch models list'); } const data = await res.json(); const items: { name: string; path: string }[] = Array.isArray(data?.models) ? data.models : []; // Приоритизируем указанную модель, чтобы она была первой карточкой const preferred = 'AerBIM-Monitor_ASM-HT-Viewer_Expo2017Astana_20250910'; const formatted = items .map((it) => ({ title: it.name, path: it.path })) .sort((a, b) => { const ap = a.path.includes(preferred) ? -1 : 0; const bp = b.path.includes(preferred) ? -1 : 0; if (ap !== bp) return ap - bp; return a.title.localeCompare(b.title); }); setModels(formatted); } catch (error) { console.error('[Monitoring] Error loading models list:', error); setLoadError(error instanceof Error ? error.message : String(error)); setModels([]); } }; fetchModels(); }, []); return (

Зоны мониторинга

{onClose && ( )}
{loadError && (
Ошибка загрузки списка моделей: {loadError}
)} {models.length > 0 && ( <> {/* Большая панорамная карточка для приоритетной модели */} {models[0] && ( )} {/* Сетка маленьких карточек для остальных моделей */} {models.length > 1 && (
{models.slice(1).map((model, idx) => ( ))}
)} )} {models.length === 0 && (
Список моделей пуст. Добавьте файлы в assets/big-models или проверьте API /api/big-models/list.
)}
); }; export default Monitoring;