From 150b22e898fa0e3fb17fa8ecdd13b70bed58f596 Mon Sep 17 00:00:00 2001 From: Edan Bainglass <45081142+edan-bainglass@users.noreply.github.com> Date: Mon, 11 Nov 2024 12:40:15 +0100 Subject: [PATCH] Fix bug w.r.t #921 (#924) Added a `refresh` parameter to allow bypassing the node view cache when triggering a manual update --- src/aiidalab_qe/app/result/__init__.py | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/src/aiidalab_qe/app/result/__init__.py b/src/aiidalab_qe/app/result/__init__.py index f9a56019d..3fc6e36ba 100644 --- a/src/aiidalab_qe/app/result/__init__.py +++ b/src/aiidalab_qe/app/result/__init__.py @@ -199,8 +199,7 @@ def _on_click_clean_scratch_button(self, _=None): def _on_click_update_result_button(self, _=None): """Trigger the update of the results tabs.""" # change the node to trigger the update of the view. - self.node_view.node = None - self.node_view.node = orm.load_node(self.process) + self._update_node_view({"new": self.process_tree.selected_nodes}, refresh=True) @tl.observe("process") def _observe_process(self, _): @@ -211,7 +210,7 @@ def _observe_process(self, _): self._update_kill_button_layout() self._update_clean_scratch_button_layout() - def _update_node_view(self, change): + def _update_node_view(self, change, refresh=False): """Callback for when the a new node is selected.""" from aiidalab_widgets_base.viewers import viewer @@ -221,7 +220,7 @@ def _update_node_view(self, change): # only show the first selected node node = nodes[0] # check if the viewer is already added - if node.uuid in self.node_views: + if node.uuid in self.node_views and not refresh: node_view = self.node_views[node.uuid] else: node_view = viewer(node)