You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
57 lines
1.8 KiB
57 lines
1.8 KiB
import { useDevice } from "../../core/stores/deviceStore.ts";
|
|
import {
|
|
Dialog,
|
|
DialogClose,
|
|
DialogContent,
|
|
DialogDescription,
|
|
DialogHeader,
|
|
DialogTitle,
|
|
} from "../UI/Dialog.tsx";
|
|
import type { Protobuf, Types } from "@meshtastic/core";
|
|
import { numberToHexUnpadded } from "@noble/curves/abstract/utils";
|
|
|
|
import { TraceRoute } from "../PageComponents/Messages/TraceRoute.tsx";
|
|
|
|
export interface TracerouteResponseDialogProps {
|
|
traceroute: Types.PacketMetadata<Protobuf.Mesh.RouteDiscovery> | undefined;
|
|
open: boolean;
|
|
onOpenChange: () => void;
|
|
}
|
|
|
|
export const TracerouteResponseDialog = ({
|
|
traceroute,
|
|
open,
|
|
onOpenChange,
|
|
}: TracerouteResponseDialogProps) => {
|
|
const { nodes } = useDevice();
|
|
const route: number[] = traceroute?.data.route ?? [];
|
|
const routeBack: number[] = traceroute?.data.routeBack ?? [];
|
|
const snrTowards = traceroute?.data.snrTowards ?? [];
|
|
const snrBack = traceroute?.data.snrBack ?? [];
|
|
const from = nodes.get(traceroute?.from ?? 0);
|
|
const longName = from?.user?.longName ??
|
|
(from ? `!${numberToHexUnpadded(from?.num)}` : "Unknown");
|
|
const shortName = from?.user?.shortName ??
|
|
(from ? `${numberToHexUnpadded(from?.num).substring(0, 4)}` : "UNK");
|
|
const to = nodes.get(traceroute?.to ?? 0);
|
|
return (
|
|
<Dialog open={open} onOpenChange={onOpenChange}>
|
|
<DialogContent>
|
|
<DialogClose />
|
|
<DialogHeader>
|
|
<DialogTitle>{`Traceroute: ${longName} (${shortName})`}</DialogTitle>
|
|
</DialogHeader>
|
|
<DialogDescription>
|
|
<TraceRoute
|
|
route={route}
|
|
routeBack={routeBack}
|
|
from={from}
|
|
to={to}
|
|
snrTowards={snrTowards}
|
|
snrBack={snrBack}
|
|
/>
|
|
</DialogDescription>
|
|
</DialogContent>
|
|
</Dialog>
|
|
);
|
|
};
|
|
|