Opened 15 years ago
Closed 14 years ago
#13942 closed (invalid)
ModelChoiceField fix to_field_name fix
Reported by: | edcrewe | Owned by: | nobody |
---|---|---|---|
Component: | Forms | Version: | 1.2 |
Severity: | Keywords: | ModelChoiceField | |
Cc: | Triage Stage: | Unreviewed | |
Has patch: | no | Needs documentation: | no |
Needs tests: | no | Patch needs improvement: | no |
Easy pickings: | no | UI/UX: | no |
Description
line 989 in http://code.djangoproject.com/browser/django/trunk/django/forms/models.py
ModelChoiceField
986 def to_python(self, value):
985 if value in EMPTY_VALUES:
986 return None
987 try:
988 key = self.to_field_name or 'pk'
989 value = self.queryset.get({key: value})
990 except self.queryset.model.DoesNotExist:
991 raise ValidationError(self.error_messagesinvalid_choice)
992 return value
If you supply a to_field_name argument then the value that would be used from that field name is replaced here.
Suggest replacing this with dummy object variable ...
989 object = self.queryset.get({key: value})
... so you get back the original field value, then this works for generating choices with different option values to labels.
Change History (1)
comment:1 by , 14 years ago
Has patch: | unset |
---|---|
Resolution: | → invalid |
Status: | new → closed |
Replying to edcrewe:
It's not at all clear what you are asking for here. I can't see what your code example is supposed to do.
If you have a test case or can expand on what you are actually trying to achieve then feel free to reopen.