import React, { useState, useEffect } from 'react'; import Image from 'next/image'; interface MonitoringProps { objectId?: string; onClose?: () => void; onSelectModel?: (modelPath: string) => void; } const Monitoring: React.FC = ({ onClose, onSelectModel }) => { const [objectImageError, setObjectImageError] = useState(false); const [models, setModels] = useState<{ title: string; path: string }[]>([]); const [loadError, setLoadError] = useState(null); // Загружаем список доступных моделей из 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 && ( )}
{objectImageError ? (
Предпросмотр 3D недоступен
Изображение модели не найдено
) : ( Object Model setObjectImageError(true)} /> )}
{loadError && (
Ошибка загрузки списка моделей: {loadError}
)}
{models.length > 0 ? ( models.map((model, idx) => ( )) ) : (
Список моделей пуст. Добавьте файлы в assets/big-models или проверьте API /api/big-models/list.
)}
); }; export default Monitoring;