diff --git a/src/Draco.Trace.Visualizer/src/TimelineGraph.tsx b/src/Draco.Trace.Visualizer/src/TimelineGraph.tsx index 8c19ec52e..1127ff3ff 100644 --- a/src/Draco.Trace.Visualizer/src/TimelineGraph.tsx +++ b/src/Draco.Trace.Visualizer/src/TimelineGraph.tsx @@ -1,7 +1,7 @@ import * as d3 from "d3"; import React from "react"; import { MessageModel, ThreadModel, TraceModel } from "./Model"; -import { TimelineLayoutSettings, focusVisualsOnNode, layoutTimeline } from "./graph_utils"; +import { HierarchicalBarGraphNode, TimelineLayoutSettings, focusVisualsOnNode, layoutTimeline } from "./graph_utils"; type Props = { width: number; @@ -103,8 +103,17 @@ function buildGraph(domRef: React.MutableRefObject, props: Props) { svg.call(zoom as any); + let lastFocused: HierarchicalBarGraphNode | undefined = undefined; allRects.on('click', function (element, node) { - focusVisualsOnNode(node); + if (lastFocused === node) { + // Focus on root + focusVisualsOnNode(laidOutMessages.root); + lastFocused = undefined; + } + else { + focusVisualsOnNode(node); + lastFocused = node; + } const transition = d3 .transition()