Skip to content

Commit

Permalink
Fix time graph filtering and collapsing
Browse files Browse the repository at this point in the history
Update the filtering of empty nodes to include visible nodes even if any
of their parent is filtered-out. Recursively replace filtered-out nodes
by their visible children, if any, but only if the filtered-out parent
node is not collapsed.

In TimeGraphOutputComponent update the arrows layer after empty nodes
have been determined, and filter out empty nodes from the rowIds passed
to the arrows layer.

Fixes eclipse-cdt-cloud#1132

Signed-off-by: Patrick Tasse <[email protected]>
  • Loading branch information
PatrickTasse committed Oct 21, 2024
1 parent 6cb44fc commit 8c7ec70
Show file tree
Hide file tree
Showing 4 changed files with 22 additions and 14 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -1056,9 +1056,6 @@ export class TimegraphOutputComponent extends AbstractTreeOutputComponent<Timegr
additionalProperties
);
this.updateMarkersData(timeGraphData.rangeEvents, newRange, nbTimes);
if (fetchArrows) {
this.arrowLayer.addArrows(timeGraphData.arrows, this.getTimegraphRowIds().rowIds);
}
this.rangeEventsLayer.addRangeEvents(timeGraphData.rangeEvents);

if (document.getElementById(this.props.traceId + this.props.outputDescriptor.id + 'handleSpinner')) {
Expand All @@ -1085,6 +1082,12 @@ export class TimegraphOutputComponent extends AbstractTreeOutputComponent<Timegr
emptyNodes = [];
}

if (fetchArrows) {
this.arrowLayer.addArrows(
timeGraphData.arrows,
this.getTimegraphRowIds().rowIds.filter(rowId => !emptyNodes.includes(rowId))
);
}
this.setState({ emptyNodes });

// Apply the pending selection here since the row provider had been called before this method.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -80,7 +80,7 @@ export class Table extends React.Component<TableProps> {
let nodes = sortNodes(this.props.nodes, this.props.sortConfig);

if (this.props.hideEmptyNodes) {
nodes = filterEmptyNodes(nodes, this.props.emptyNodes);
nodes = filterEmptyNodes(nodes, this.props.emptyNodes, this.props.collapsedNodes);
}

return (
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import { TreeNode } from './tree-node';
import { Message } from './message';
import { Filter } from './filter';
import { Table } from './table';
import { getAllExpandedNodeIds, filterEmptyNodes } from './utils';
import { getAllExpandedNodeIds } from './utils';
import { SortConfig, sortNodes } from './sort';
import ColumnHeader from './column-header';
import { isEqual } from 'lodash';
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -75,26 +75,31 @@ export const validateNumArray = (arr: any | undefined): boolean => {
* Removes specified nodes from the tree structure.
* @param nodes The array of root nodes of the tree.
* @param nodesToRemove An array of node IDs to be removed.
* @param collapsedNodes The array of collapsed node IDs.
* @returns A new array of root nodes with specified nodes removed.
*/
export function filterEmptyNodes(nodes: TreeNode[], nodesToRemove: number[]): TreeNode[] {
export function filterEmptyNodes(nodes: TreeNode[], nodesToRemove: number[], collapsedNodes: number[]): TreeNode[] {
// return nodes;
return nodes.reduce((acc: TreeNode[], node) => {
// If the current node is in the removal list, don't add it to the accumulator
if (nodesToRemove.includes(node.id)) {
return acc;
}

// Create a new node object with the same properties
const newNode: TreeNode = { ...node };

// Recursively remove nodes from children
if (newNode.children.length > 0) {
newNode.children = filterEmptyNodes(newNode.children, nodesToRemove);
newNode.children = filterEmptyNodes(newNode.children, nodesToRemove, collapsedNodes);
}

if (!nodesToRemove.includes(node.id)) {
// If the new node is not in the removal list, add it to the accumulator
acc.push(newNode);
} else if (!collapsedNodes.includes(node.id)) {
// If the new node is in the removal list and expanded, add its filtered children to the accumulator
newNode.children.forEach(child => {
child.parentId = newNode.parentId;
acc.push(child);
});
}

// Add the new node to the accumulator
acc.push(newNode);
return acc;
}, []);
}

0 comments on commit 8c7ec70

Please sign in to comment.