|
15 | 15 | from ..geo import GeoMixin
|
16 | 16 | from ..permissions import BaseAuthRequired, get_required_scopes
|
17 | 17 | from ..search import is_search_view
|
18 |
| -from ..serializers import FoutSerializer, ValidatieFoutSerializer |
| 18 | +from ..serializers import ( |
| 19 | + FoutSerializer, |
| 20 | + ValidatieFoutSerializer, |
| 21 | + add_choice_values_help_text, |
| 22 | +) |
19 | 23 |
|
20 | 24 | logger = logging.getLogger(__name__)
|
21 | 25 |
|
@@ -232,10 +236,23 @@ def get_request_serializer(self):
|
232 | 236 | )
|
233 | 237 |
|
234 | 238 | filters = {}
|
235 |
| - for filter_field in filter_fields: |
236 |
| - FieldClass = TYPE_TO_FIELDMAPPING[filter_field.type] |
237 |
| - filters[filter_field.name] = FieldClass( |
238 |
| - help_text=filter_field.description, required=filter_field.required |
| 239 | + for parameter in filter_fields: |
| 240 | + help_text = parameter.description |
| 241 | + # we can't get the verbose_label back from the enum, so the inspector |
| 242 | + # in vng_api_common.inspectors.fields leaves a filter field reference behind |
| 243 | + _filter_field = getattr(parameter, "_filter_field", None) |
| 244 | + choices = getattr(_filter_field, "extra", {}).get("choices", []) |
| 245 | + if choices: |
| 246 | + FieldClass = serializers.ChoiceField |
| 247 | + extra = {"choices": choices} |
| 248 | + value_display_mapping = add_choice_values_help_text(choices) |
| 249 | + help_text += f"\n\n{value_display_mapping}" |
| 250 | + else: |
| 251 | + FieldClass = TYPE_TO_FIELDMAPPING[parameter.type] |
| 252 | + extra = {} |
| 253 | + |
| 254 | + filters[parameter.name] = FieldClass( |
| 255 | + help_text=help_text, required=parameter.required, **extra |
239 | 256 | )
|
240 | 257 |
|
241 | 258 | SearchSerializer = type(Base.__name__, (Base,), filters)
|
|
0 commit comments