import { useCallback, useMemo, useState } from 'react'; import { useMapRootState } from '@/hooks/Mapper/mapRootProvider'; import { Widget } from '@/hooks/Mapper/components/mapInterface/components'; import { SystemKillsList } from './SystemKillsList'; import { KillsHeader } from './components/SystemKillsHeader'; import { useSystemKills } from './hooks/useSystemKills'; import { KillsSettingsDialog } from './components/SystemKillsSettingsDialog'; import { isWormholeSpace } from '@/hooks/Mapper/components/map/helpers/isWormholeSpace'; import { getSystemStaticInfo } from '@/hooks/Mapper/mapRootProvider/hooks/useLoadSystemStatic'; const SystemKillsContent = () => { const { data: { selectedSystems, isSubscriptionActive }, outCommand, storedSettings: { settingsKills }, } = useMapRootState(); const [systemId] = selectedSystems || []; const systemStaticInfo = getSystemStaticInfo(systemId)!; const { kills, isLoading, error } = useSystemKills({ systemId, outCommand, showAllVisible: settingsKills.showAll, sinceHours: settingsKills.timeRange, }); const isNothingSelected = !systemId && !settingsKills.showAll; const showLoading = isLoading && kills.length === 0; const filteredKills = useMemo(() => { if (!settingsKills.whOnly || !settingsKills.showAll) return kills; return kills.filter(kill => { if (!systemStaticInfo) { console.warn(`System with id ${kill.solar_system_id} not found.`); return false; } return isWormholeSpace(systemStaticInfo.system_class); }); }, [kills, settingsKills.whOnly, systemStaticInfo, settingsKills.showAll]); if (!isSubscriptionActive) { return (