mirror of
				https://github.com/django/django.git
				synced 2025-10-25 22:56:12 +00:00 
			
		
		
		
	Fixed #10059: ModelAdmin.formfield_for_dbfield now handles custom Field subclasses. Thanks, Alex Gaynor.
				
					
				
			git-svn-id: http://code.djangoproject.com/svn/django/trunk@10454 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -108,8 +108,9 @@ class BaseModelAdmin(object): | |||||||
|  |  | ||||||
|         # If we've got overrides for the formfield defined, use 'em. **kwargs |         # If we've got overrides for the formfield defined, use 'em. **kwargs | ||||||
|         # passed to formfield_for_dbfield override the defaults. |         # passed to formfield_for_dbfield override the defaults. | ||||||
|         if db_field.__class__ in self.formfield_overrides: |         for klass in db_field.__class__.mro():  | ||||||
|             kwargs = dict(self.formfield_overrides[db_field.__class__], **kwargs) |             if klass in self.formfield_overrides:  | ||||||
|  |                 kwargs = dict(self.formfield_overrides[klass], **kwargs)  | ||||||
|                 return db_field.formfield(**kwargs)  |                 return db_field.formfield(**kwargs)  | ||||||
|  |  | ||||||
|         # For any other type of field, just call its formfield() method. |         # For any other type of field, just call its formfield() method. | ||||||
|   | |||||||
| @@ -4,6 +4,9 @@ from django.db import models | |||||||
| from django.core.files.storage import default_storage | from django.core.files.storage import default_storage | ||||||
| from django.contrib.auth.models import User | from django.contrib.auth.models import User | ||||||
|  |  | ||||||
|  | class MyFileField(models.FileField):  | ||||||
|  |     pass  | ||||||
|  |  | ||||||
| class Member(models.Model): | class Member(models.Model): | ||||||
|     name = models.CharField(max_length=100) |     name = models.CharField(max_length=100) | ||||||
|     birthdate = models.DateTimeField(blank=True, null=True) |     birthdate = models.DateTimeField(blank=True, null=True) | ||||||
| @@ -23,6 +26,7 @@ class Album(models.Model): | |||||||
|     band = models.ForeignKey(Band) |     band = models.ForeignKey(Band) | ||||||
|     name = models.CharField(max_length=100) |     name = models.CharField(max_length=100) | ||||||
|     cover_art = models.FileField(upload_to='albums') |     cover_art = models.FileField(upload_to='albums') | ||||||
|  |     backside_art = MyFileField(upload_to='albums_back', null=True) | ||||||
|  |  | ||||||
|     def __unicode__(self): |     def __unicode__(self): | ||||||
|         return self.name |         return self.name | ||||||
|   | |||||||
| @@ -98,6 +98,8 @@ class AdminFormfieldForDBFieldTests(TestCase): | |||||||
|         self.assertFormfield(models.Member, 'gender', widgets.AdminRadioSelect, |         self.assertFormfield(models.Member, 'gender', widgets.AdminRadioSelect, | ||||||
|                              radio_fields={'gender':admin.VERTICAL}) |                              radio_fields={'gender':admin.VERTICAL}) | ||||||
|  |  | ||||||
|  |     def testInheritance(self): | ||||||
|  |         self.assertFormfield(models.Album, 'backside_art', widgets.AdminFileWidget) | ||||||
|  |  | ||||||
| class AdminFormfieldForDBFieldWithRequestTests(DjangoTestCase): | class AdminFormfieldForDBFieldWithRequestTests(DjangoTestCase): | ||||||
|     fixtures = ["admin-widgets-users.xml"] |     fixtures = ["admin-widgets-users.xml"] | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user