From 203c891009f4c52c41ccefbe967d81f5d3a851b2 Mon Sep 17 00:00:00 2001 From: Leandro Roberto da Silva Date: Wed, 30 Nov 2016 14:26:21 -0200 Subject: [PATCH] Cust. crispy_layout para render. de related_name MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Nos layouts (layouts.yaml) pode-se criar layouts específicos para renderização de related_names. Veja exemplo de MateriaLegislativaDetail que renderiza numeracao_set --- sapl/crispy_layout_mixin.py | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/sapl/crispy_layout_mixin.py b/sapl/crispy_layout_mixin.py index 028301502..555a04f19 100644 --- a/sapl/crispy_layout_mixin.py +++ b/sapl/crispy_layout_mixin.py @@ -61,8 +61,12 @@ def get_field_display(obj, fieldname): try: field = obj._meta.get_field(fieldname) except: - value = getattr(obj, fieldname) - return '', str(value) + field = getattr(obj, fieldname) + if 'ManyRelatedManager' not in str(type(field))\ + and 'RelatedManager' not in str(type(field))\ + and 'GenericRelatedObjectManager' not in str(type(field)): + return '', str(field) + verbose_name = str(field.verbose_name)\ if hasattr(field, 'verbose_name') else '' if hasattr(field, 'choices') and field.choices: @@ -98,7 +102,11 @@ def get_field_display(obj, fieldname): display += '
  • %s
  • ' % str(v) display += '' if not verbose_name: - verbose_name = str(field.related_model._meta.verbose_name_plural) + if hasattr(field, 'related_model'): + verbose_name = str( + field.related_model._meta.verbose_name_plural) + elif hasattr(field, 'model'): + verbose_name = str(field.model._meta.verbose_name_plural) else: display = str(value) return verbose_name, display