From e399897535515555b6432084b1ed6619a352f9c0 Mon Sep 17 00:00:00 2001 From: Jusong Yu Date: Fri, 19 May 2023 12:15:36 +0000 Subject: [PATCH] fix the computer_setup update with dict copy --- aiidalab_widgets_base/computational_resources.py | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/aiidalab_widgets_base/computational_resources.py b/aiidalab_widgets_base/computational_resources.py index 65e5580d7..3f3ce1630 100644 --- a/aiidalab_widgets_base/computational_resources.py +++ b/aiidalab_widgets_base/computational_resources.py @@ -29,7 +29,7 @@ class QuickSetupWidget(ipw.VBox): default_calc_job_plugin = traitlets.Unicode(allow_none=True) - computer_setup = traitlets.Dict() + computer_setup = traitlets.Dict().tag(sync=True) code_setup = traitlets.Dict() def __init__(self, **kwargs): @@ -114,9 +114,10 @@ def quick_setup(self, _=None): The actual setup will be triggered from DetailedSetupWidget from ComputationalResourcesWidget. """ from jinja2 import ChainableUndefined, Environment, meta + import copy # From the remote original setup, fill the template - computer_setup = self.computer_setup + computer_setup = copy.deepcopy(self.computer_setup) # The dict is nested, so we need deepcopy for key, value in computer_setup.get("setup", {}).items(): env = Environment(undefined=ChainableUndefined) @@ -134,12 +135,12 @@ def quick_setup(self, _=None): else: computer_setup["setup"][key] = value - self.computer_setup = {**self.computer_setup} + self.computer_setup = computer_setup print(self.computer_setup) class DetailedSetupWidget(ipw.VBox): - computer_setup = traitlets.Dict() + computer_setup = traitlets.Dict().tag(sync=True) code_setup = traitlets.Dict() def __init__(self, **kargs): @@ -318,7 +319,9 @@ def __init__(self, description="Select code:", path_to_root="../", **kwargs): def _quick_setup(self, change): if change["new"] is not None: + print("HETNNNNN") self.detailed_setup.aiida_computer_setup.computer_setup = change["new"] + self.detailed_setup.aiida_computer_setup._observe_computer_setup() # self.detailed_setup.code_setup = self.comp_resources_database.code_setup def quick_setup(self, _=None): @@ -814,7 +817,7 @@ def _observe_ssh_config(self, _=None): class AiidaComputerSetup(ipw.VBox): """Inform AiiDA about a computer.""" - computer_setup = traitlets.Dict(allow_none=True) + computer_setup = traitlets.Dict(allow_none=True).tag(sync=True) message = traitlets.Unicode() def __init__(self, **kwargs):