From 3d0f8b792ffcd85702f917de59cf51d21c9f6b43 Mon Sep 17 00:00:00 2001 From: Michael Shepanski Date: Sun, 4 Nov 2012 12:31:37 -0500 Subject: [PATCH] Fix for bug #363: ChoiceField missing in renderers.py --- rest_framework/renderers.py | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/rest_framework/renderers.py b/rest_framework/renderers.py index 73ae6edc8..0a659bd1f 100644 --- a/rest_framework/renderers.py +++ b/rest_framework/renderers.py @@ -281,6 +281,7 @@ class BrowsableAPIRenderer(BaseRenderer): serializers.DateField: forms.DateField, serializers.EmailField: forms.EmailField, serializers.CharField: forms.CharField, + serializers.ChoiceField: forms.ChoiceField, serializers.BooleanField: forms.BooleanField, serializers.PrimaryKeyRelatedField: forms.ChoiceField, serializers.ManyPrimaryKeyRelatedField: forms.MultipleChoiceField, @@ -316,7 +317,10 @@ class BrowsableAPIRenderer(BaseRenderer): try: fields[k] = field_mapping[v.__class__](**kwargs) except KeyError: - fields[k] = forms.CharField(**kwargs) + if getattr(v, 'choices', None) is not None: + fields[k] = forms.ChoiceField(**kwargs) + else: + fields[k] = forms.CharField(**kwargs) return fields def get_form(self, view, method, request):