summaryrefslogtreecommitdiff
path: root/ishtar_common
diff options
context:
space:
mode:
Diffstat (limited to 'ishtar_common')
-rw-r--r--ishtar_common/data_importer.py5
-rw-r--r--ishtar_common/models.py8
2 files changed, 12 insertions, 1 deletions
diff --git a/ishtar_common/data_importer.py b/ishtar_common/data_importer.py
index b5fc9b0c6..27714458b 100644
--- a/ishtar_common/data_importer.py
+++ b/ishtar_common/data_importer.py
@@ -437,7 +437,7 @@ class Importer(object):
u"and encoding are similar to the ones used by the reference "
u"file."),
'too_many_cols':_(u"Too many cols (%(user_col)d) when "
- u"maximum is %(ref_col)d"),
+ u"maximum is %(ref_col)d"),
'no_data':_(u"No data provided"),
'value_required':_(u"Value is required"),
'not_enough_cols':_(u"At least %d columns must be filled"),
@@ -794,6 +794,8 @@ class Importer(object):
model = field_object.rel.to
elif hasattr(field_object, 'to'):
model = field_object.to
+ elif hasattr(field_object, 'model'):
+ model = field_object.model
if type(many_values) not in (list, tuple):
many_values = [many_values]
for val in many_values:
@@ -808,6 +810,7 @@ class Importer(object):
for key in val.keys():
if type(val[key]) not in (list, tuple):
default_dict[key] = val[key]
+ vals.append(default_dict.copy())
## manage multiple values
for key in val.keys():
if type(val[key]) in (list, tuple):
diff --git a/ishtar_common/models.py b/ishtar_common/models.py
index a57e814f0..9f7261010 100644
--- a/ishtar_common/models.py
+++ b/ishtar_common/models.py
@@ -40,6 +40,7 @@ from django.core.validators import validate_slug
from django.core.urlresolvers import reverse, NoReverseMatch
from django.db.utils import DatabaseError
from django.db.models import Q, Max, Count
+from django.db.models.base import ModelBase
from django.db.models.signals import post_save, pre_delete
from django.utils.translation import ugettext_lazy as _, ugettext
from django.utils.safestring import SafeUnicode, mark_safe
@@ -993,6 +994,8 @@ def get_model_fields(model):
options = model._meta
for field in sorted(options.fields + options.many_to_many):
fields[field.name] = field
+ if hasattr(model, 'get_extra_fields'):
+ fields.update(model.get_extra_fields())
return fields
def import_class(full_path_classname):
@@ -1075,6 +1078,8 @@ def get_associated_model(parent_model, keys):
field = get_model_fields(OBJECT_CLS)[item]
if hasattr(field, 'rel') and hasattr(field.rel, 'to'):
model = field.rel.to
+ if type(field) == ModelBase:
+ model = field
else:
return get_associated_model(model, keys[1:])
return model
@@ -1259,6 +1264,9 @@ TARGET_MODELS = [
('archaeological_operations.models.OperationType', _(u"Operation type")),
('archaeological_operations.models.Period', _(u"Period")),
('archaeological_context_records.models.Unit', _(u"Unit")),
+ ('archaeological_finds.models.MaterialType', _(u"Material")),
+ ('archaeological_finds.models.ConservatoryState', _(u"Conservatory state")),
+ ('archaeological_finds.models.PreservationType', _(u"Preservation type")),
]
TARGET_MODELS_KEYS = [tm[0] for tm in TARGET_MODELS]