Merge pull request #3104 from Seraf/master

Adding recursion on child of List Field
This commit is contained in:
Tom Christie 2015-07-02 13:30:28 +01:00
commit c3507552d5
2 changed files with 24 additions and 0 deletions

View File

@ -131,6 +131,9 @@ class SimpleMetadata(BaseMetadata):
if value is not None and value != '':
field_info[attr] = force_text(value, strings_only=True)
if getattr(field, 'child', None):
field_info['child'] = self.get_field_info(field.child)
if not field_info.get('read_only') and hasattr(field, 'choices'):
field_info['choices'] = [
{

View File

@ -67,6 +67,11 @@ class TestMetadata:
char_field = serializers.CharField(
required=False, min_length=3, max_length=40
)
list_field = serializers.ListField(
child=serializers.ListField(
child=serializers.IntegerField()
)
)
class ExampleView(views.APIView):
"""Example view."""
@ -119,6 +124,22 @@ class TestMetadata:
'label': 'Char field',
'min_length': 3,
'max_length': 40
},
'list_field': {
'type': 'list',
'required': True,
'read_only': False,
'label': 'List field',
'child': {
'type': 'list',
'required': True,
'read_only': False,
'child': {
'type': 'integer',
'required': True,
'read_only': False
}
}
}
}
}