mirror of
https://git.mirrors.martin98.com/https://github.com/SigNoz/signoz
synced 2025-08-12 12:49:06 +08:00
adds tooltip on hover
This commit is contained in:
parent
8b0abbec79
commit
55a7b5b1b3
@ -10,7 +10,7 @@ import {
|
|||||||
import { Spin } from "antd";
|
import { Spin } from "antd";
|
||||||
import styled from "styled-components";
|
import styled from "styled-components";
|
||||||
import { StoreState } from "../../store/reducers";
|
import { StoreState } from "../../store/reducers";
|
||||||
import { getGraphData } from "./utils";
|
import { getGraphData, getTooltip } from "./utils";
|
||||||
import SelectService from "./SelectService";
|
import SelectService from "./SelectService";
|
||||||
import { ForceGraph2D } from "react-force-graph";
|
import { ForceGraph2D } from "react-force-graph";
|
||||||
|
|
||||||
@ -90,7 +90,7 @@ const ServiceMap = (props: ServiceMapProps) => {
|
|||||||
fgRef.current.zoomToFit(100, 120);
|
fgRef.current.zoomToFit(100, 120);
|
||||||
}}
|
}}
|
||||||
graphData={graphData}
|
graphData={graphData}
|
||||||
nodeLabel="id"
|
nodeLabel={getTooltip}
|
||||||
linkAutoColorBy={(d) => d.target}
|
linkAutoColorBy={(d) => d.target}
|
||||||
linkDirectionalParticles="value"
|
linkDirectionalParticles="value"
|
||||||
linkDirectionalParticleSpeed={(d) => d.value}
|
linkDirectionalParticleSpeed={(d) => d.value}
|
||||||
@ -112,21 +112,7 @@ const ServiceMap = (props: ServiceMapProps) => {
|
|||||||
onNodeClick={(node) => {
|
onNodeClick={(node) => {
|
||||||
const tooltip = document.querySelector(".graph-tooltip");
|
const tooltip = document.querySelector(".graph-tooltip");
|
||||||
if (tooltip && node) {
|
if (tooltip && node) {
|
||||||
tooltip.innerHTML = `<div style="color:#333333;padding:12px;background: white;border-radius: 2px;">
|
tooltip.innerHTML = getTooltip(node);
|
||||||
<div style="font-weight:bold; margin-bottom:16px;">${node.id}</div>
|
|
||||||
<div class="keyval">
|
|
||||||
<div class="key">P99 latency:</div>
|
|
||||||
<div class="val">${node.p99 / 1000000}ms</div>
|
|
||||||
</div>
|
|
||||||
<div class="keyval">
|
|
||||||
<div class="key">Request:</div>
|
|
||||||
<div class="val">${node.callRate}/sec</div>
|
|
||||||
</div>
|
|
||||||
<div class="keyval">
|
|
||||||
<div class="key">Error Rate:</div>
|
|
||||||
<div class="val">${node.errorRate}%</div>
|
|
||||||
</div>
|
|
||||||
</div>`;
|
|
||||||
}
|
}
|
||||||
}}
|
}}
|
||||||
nodePointerAreaPaint={(node, color, ctx) => {
|
nodePointerAreaPaint={(node, color, ctx) => {
|
||||||
|
@ -73,3 +73,26 @@ export const getGraphData = (serviceMap: serviceMapStore): graphDataType => {
|
|||||||
links,
|
links,
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
export const getTooltip = (node: {
|
||||||
|
p99: number;
|
||||||
|
errorRate: number;
|
||||||
|
callRate: number;
|
||||||
|
id: string;
|
||||||
|
}) => {
|
||||||
|
return `<div style="color:#333333;padding:12px;background: white;border-radius: 2px;">
|
||||||
|
<div style="font-weight:bold; margin-bottom:16px;">${node.id}</div>
|
||||||
|
<div class="keyval">
|
||||||
|
<div class="key">P99 latency:</div>
|
||||||
|
<div class="val">${node.p99 / 1000000}ms</div>
|
||||||
|
</div>
|
||||||
|
<div class="keyval">
|
||||||
|
<div class="key">Request:</div>
|
||||||
|
<div class="val">${node.callRate}/sec</div>
|
||||||
|
</div>
|
||||||
|
<div class="keyval">
|
||||||
|
<div class="key">Error Rate:</div>
|
||||||
|
<div class="val">${node.errorRate}%</div>
|
||||||
|
</div>
|
||||||
|
</div>`;
|
||||||
|
};
|
||||||
|
Loading…
x
Reference in New Issue
Block a user