mirror of
https://github.com/wanderer-industries/wanderer
synced 2025-11-28 03:53:26 +00:00
* fix(Map): fix design of kills widget, fix design of signatures widget - refactor a lot of code, fixed problem with tooltip blinking * fix(Map): refactor Tracking dialog, refactor Activity tracker, refactor codebase and some styles * fix(Core): don't count character passage on manual add connection * refactor(Core): improved characters tracking API * fix(Core): fixed link signature to system on 'leads to' set * fix(Map): Refactor map settings and prepared it to easier using * fix(Map): Add support new command for following update * fix(Map): Add support new command for main update * refactor(Core): Reduce map init data by using cached system static data * refactor(Core): Reduce map init data by extract signatures loading to a separate event * fix(Core): adjusted IP rate limits * fix(Map): Update design of tracking characters. Added icons for following and main. Added ability to see that character on the station or structure --------- Co-authored-by: achichenkov <aleksei.chichenkov@telleqt.ai> Co-authored-by: Dmitry Popov <dmitriypopovsamara@gmail.com>
44 lines
1.3 KiB
TypeScript
44 lines
1.3 KiB
TypeScript
import { useMemo } from 'react';
|
|
import { useMapRootState } from '@/hooks/Mapper/mapRootProvider';
|
|
import { useSystemKills } from '@/hooks/Mapper/components/mapInterface/widgets/WSystemKills/hooks/useSystemKills.ts';
|
|
|
|
interface UseKillsCounterProps {
|
|
realSystemId: string;
|
|
}
|
|
|
|
export function useKillsCounter({ realSystemId }: UseKillsCounterProps) {
|
|
const { data: mapData, outCommand } = useMapRootState();
|
|
const { systems } = mapData;
|
|
|
|
const systemNameMap = useMemo(() => {
|
|
const m: Record<string, string> = {};
|
|
systems.forEach(sys => {
|
|
m[sys.id] = sys.temporary_name || sys.name || '???';
|
|
});
|
|
return m;
|
|
}, [systems]);
|
|
|
|
const { kills: allKills, isLoading } = useSystemKills({
|
|
systemId: realSystemId,
|
|
outCommand,
|
|
showAllVisible: false,
|
|
});
|
|
|
|
const filteredKills = useMemo(() => {
|
|
if (!allKills || allKills.length === 0) return [];
|
|
|
|
// Sort kills by time, most recent first, but don't limit the number of kills
|
|
return [...allKills].sort((a, b) => {
|
|
const aTime = a.kill_time ? new Date(a.kill_time).getTime() : 0;
|
|
const bTime = b.kill_time ? new Date(b.kill_time).getTime() : 0;
|
|
return bTime - aTime;
|
|
});
|
|
}, [allKills]);
|
|
|
|
return {
|
|
isLoading,
|
|
kills: filteredKills,
|
|
systemNameMap,
|
|
};
|
|
}
|