diff --git a/desktop/plugins/public/ui-debugger/components/visualizer/Visualization2D.tsx b/desktop/plugins/public/ui-debugger/components/visualizer/Visualization2D.tsx index bcde80ef5..2ee0b0ce2 100644 --- a/desktop/plugins/public/ui-debugger/components/visualizer/Visualization2D.tsx +++ b/desktop/plugins/public/ui-debugger/components/visualizer/Visualization2D.tsx @@ -9,7 +9,12 @@ import React, {useEffect, useMemo, useRef, useState} from 'react'; import {Bounds, Coordinate, Id, ClientNode} from '../../ClientTypes'; -import {NestedNode, OnSelectNode, WireFrameMode} from '../../DesktopTypes'; +import { + NestedNode, + OnSelectNode, + TraversalMode, + WireFrameMode, +} from '../../DesktopTypes'; import { produce, @@ -46,6 +51,7 @@ export const Visualization2D: React.FC< const hoveredNodes = useValue(instance.uiState.hoveredNodes); const hoveredNodeId = head(hoveredNodes); const wireFrameMode = useValue(instance.uiState.wireFrameMode); + const traversalMode = useValue(instance.uiState.currentTraversalMode); const [targetMode, setTargetMode] = useState({ state: 'disabled', @@ -245,6 +251,7 @@ export const Visualization2D: React.FC< selectedNode={selectedNodeId?.id} node={focusState.focusedRoot} onSelectNode={onSelectNode} + traversalMode={traversalMode} /> @@ -275,12 +282,16 @@ function Visualization2DNode({ selectedNode, node, onSelectNode, + runThroughIndex, + traversalMode, }: { wireframeMode: WireFrameMode; isSelectedOrChildOrSelected: boolean; selectedNode?: Id; node: NestedNode; onSelectNode: OnSelectNode; + runThroughIndex?: number; + traversalMode: TraversalMode; }) { const instance = usePlugin(plugin); @@ -300,7 +311,7 @@ function Visualization2DNode({ nestedChildren = node.children; } - const children = nestedChildren.map((child) => ( + const children = nestedChildren.map((child, index) => ( )); @@ -319,6 +332,7 @@ function Visualization2DNode({ wireframeMode === 'All' || (wireframeMode === 'SelectedAndChildren' && isSelectedOrChildOrSelected) || (wireframeMode === 'SelectedOnly' && isSelected); + const showOrdinalIndices = traversalMode == 'accessibility-hierarchy'; return (
} {children} + {showOrdinalIndices && ( +
+ {runThroughIndex} +
+ )}
); }