From e73efaf3807517c22ef1a70a0cec3a9e54302fc7 Mon Sep 17 00:00:00 2001 From: BurnoutDV Date: Sun, 8 Dec 2024 20:41:50 +0100 Subject: [PATCH] Added function to tree widget to find a node by the data field --- src/textual/widgets/_tree.py | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) diff --git a/src/textual/widgets/_tree.py b/src/textual/widgets/_tree.py index 40f73ba6b7..9bd44f7f7d 100644 --- a/src/textual/widgets/_tree.py +++ b/src/textual/widgets/_tree.py @@ -1046,6 +1046,30 @@ def get_node_by_id(self, node_id: NodeID) -> TreeNode[TreeDataType]: except KeyError: raise UnknownNodeID(f"Unknown NodeID ({node_id}) in tree") from None + def get_node_with_data(self, value: str | int, *keys) -> TreeNode[TreeDataType] | None: + """Returns the first node that got a matching value in the json data field + under the chain of *keys given. + + usage example: Tree.get_node_with_data(42, 'database', 'id') + Args: + value: str|int of the desired data in the data json + *keys: chain of keys to the nested value + + Returns: + The first Node with the desired value or None + """ + for treeline in self._tree_lines: + if treeline.node.data: + data = treeline.node.data + try: + for key in keys: + data = data[key] + if data == value: + return treeline.node + except(KeyError, TypeError): + continue + return None # if nothing was found + def validate_cursor_line(self, value: int) -> int: """Prevent cursor line from going outside of range.