From 9506fb493ebdf22674f7fee54712bbd5890d55c0 Mon Sep 17 00:00:00 2001 From: Étienne Loks Date: Tue, 9 Apr 2019 01:26:27 +0200 Subject: Importers: fix default management - allow arbitrary values - allow values directly related to the main model of the import - add a "get_default" in attribute configuration in order to force use of default settings --- ishtar_common/models_imports.py | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) (limited to 'ishtar_common/models_imports.py') diff --git a/ishtar_common/models_imports.py b/ishtar_common/models_imports.py index a774cef6d..315feba7b 100644 --- a/ishtar_common/models_imports.py +++ b/ishtar_common/models_imports.py @@ -241,7 +241,9 @@ def get_associated_model(parent_model, keys): OBJECT_CLS = parent_model fields = get_model_fields(OBJECT_CLS) for idx, item in enumerate(keys): - if not idx: + if item in (u"-", u""): + model = None + elif not idx: if item not in fields: raise ImporterError( unicode( @@ -286,7 +288,7 @@ class ImporterDefault(models.Model): @property def keys(self): - return tuple(self.target.split('__')) + return tuple(t for t in self.target.split('__') if t not in (u"-", u"")) @property def associated_model(self): @@ -297,7 +299,10 @@ class ImporterDefault(models.Model): def values(self): values = {} for default_value in self.default_values.all(): - values[default_value.target] = default_value.get_value() + target = default_value.target + if target == u"-": + target = u"" + values[target] = default_value.get_value() return values @@ -341,7 +346,7 @@ class ImporterDefaultValues(models.Model): return field = fields[target] if not hasattr(field, 'rel') or not hasattr(field.rel, 'to'): - return + return self.value model = field.rel.to # if value is an id try: -- cgit v1.2.3