mirror of
				https://github.com/django/django.git
				synced 2025-10-25 14:46:09 +00:00 
			
		
		
		
	Fixed #15208 - Document ModelAdmin.formfield_for_choice_field; thanks julien.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@15399 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -927,6 +927,25 @@ templates used by the :class:`ModelAdmin` views: | ||||
|                     kwargs["queryset"] = Car.objects.filter(owner=request.user) | ||||
|                 return super(MyModelAdmin, self).formfield_for_manytomany(db_field, request, **kwargs) | ||||
|  | ||||
| .. method:: ModelAdmin.formfield_for_choice_field(self, db_field, request, **kwargs) | ||||
|  | ||||
|     Like the ``formfield_for_foreignkey`` and ``formfield_for_manytomany`` | ||||
|     methods, the ``formfield_for_choice_field`` method can be overridden to | ||||
|     change the default formfield for a field that has declared choices. For | ||||
|     example, if the choices available to a superuser should be different than | ||||
|     those available to regular staff, you could proceed as follows:: | ||||
|  | ||||
|         class MyModelAdmin(admin.ModelAdmin): | ||||
|             def formfield_for_choice_field(self, db_field, request, **kwargs): | ||||
|                 if db_field.name == "status": | ||||
|                     kwargs['choices'] = ( | ||||
|                         ('accepted', 'Accepted'), | ||||
|                         ('denied', 'Denied'), | ||||
|                     ) | ||||
|                     if request.user.is_superuser: | ||||
|                         kwargs['choices'] += (('ready', 'Ready for deployment'),) | ||||
|                 return super(MyModelAdmin, self).formfield_for_choice_field(db_field, request, **kwargs) | ||||
|  | ||||
| .. method:: ModelAdmin.has_add_permission(self, request) | ||||
|  | ||||
|     Should return ``True`` if adding an object is permitted, ``False`` | ||||
|   | ||||
		Reference in New Issue
	
	Block a user