Opened 7 years ago

Closed 6 years ago

Last modified 6 years ago

#28831 closed Cleanup/optimization (fixed)

Document that InlineModelAdmin methods' obj argument is the parent object.

Reported by: Artem Skoretskiy Owned by: Parth Patil
Component: Documentation Version: dev
Severity: Normal Keywords:
Cc: tonn81@…, Manel Clos Triage Stage: Accepted
Has patch: yes Needs documentation: no
Needs tests: no Patch needs improvement: no
Easy pickings: no UI/UX: no

Description

When I use ModelAdmin.get_fieldsets, I receive current object. In my example that would be -- when I call AccountAdmin.get_fieldsets -- I receive Account. That enable me to generate different field sets for different cases.

BUT when I use InlineModelAdmin.get_fieldsets, I receive parent object. In my example that would be -- when I call
AccountInline.get_fieldsets -- I receive Customer object instead of `Account. That prevents me from configuring formsets to the account I have.

If I received Account, I could extract Customer from it. But if I receive Customer, I cannot adapt form for each row.

Also, it seems strange that class explicitly linked to Account receives Customer object as input.

Code:

# in models.py

class Customer(models.Model):
    num = models.IntegerField()


class Account(models.Model):
    ACCOUNT_TYPES = (
        (1, 'A'),
        (2, 'B'),
    )
    customer = models.ForeignKey(Customer)
    account_type = models.IntegerField(choices=ACCOUNT_TYPES)

    a = models.CharField(max_length=255, blank=True) # should be edited when type = "A"
    b = models.CharField(max_length=255, blank=True) # should be edited when type = "B"

# in admin.py

class AccountInline(admin.TabularInline):
    model = models.Account

    def get_fieldsets(self, request, obj=None):
        print(repr(obj)) # => <Customer>
        """
        if obj and obj.account_type == 1:
            return ((None, {'fields': ('account_type', 'a')}),)
        elif obj and obj.account_type == 2:
            return ((None, {'fields': ('account_type', 'b')}),)
        """
        return ((None, {'fields': ('account_type',)}),)

@admin.register(models.Customer)
class CustomerAdmin(admin.ModelAdmin):
    inlines = (AccountInline,)

@admin.register(models.Account)
class AccountAdmin(admin.ModelAdmin):
    def get_fieldsets(self, request, obj=None):
        print(repr(obj)) # => <Account>
        if obj and obj.account_type == 1:
            return ((None, {'fields': ('account_type', 'a')}),)
        elif obj and obj.account_type == 2:
            return ((None, {'fields': ('account_type', 'b')}),)
        return ((None, {'fields': ('account_type',)}),)

Change History (7)

comment:1 by Artem Skoretskiy, 7 years ago

By the way, custom fields on inline admins receive correct object:

class AccountInline(admin.TabularInline):
    ...

    def type_verbose(self, obj):
         return "Account is {}".format(obj.get_account_type_display())

    type_verbose.short_description = "Account type"

comment:2 by Tim Graham, 7 years ago

Component: contrib.adminDocumentation
Summary: InlineModelAdmin.get_fieldsets should receive own object, not parentDocument that InlineModelAdmin methods' obj argument is the parent object
Triage Stage: UnreviewedAccepted
Type: BugCleanup/optimization

I don't believe changing the behavior is possible and of course it would also be backwards incompatible. Perhaps the documentation could clarify the current behavior.

comment:3 by Manel Clos, 7 years ago

Cc: Manel Clos added

comment:4 by Parth Patil, 6 years ago

Owner: changed from nobody to Parth Patil
Status: newassigned

comment:5 by Mariusz Felisiak, 6 years ago

Has patch: set
Summary: Document that InlineModelAdmin methods' obj argument is the parent objectDocument that InlineModelAdmin methods' obj argument is the parent object.
Version: 2.0master

comment:6 by Mariusz Felisiak <felisiak.mariusz@…>, 6 years ago

Resolution: fixed
Status: assignedclosed

In 8543647:

Fixed #28831 -- Doc'd that InlineModelAdmin methods' obj argument is the parent object.

comment:7 by Mariusz Felisiak <felisiak.mariusz@…>, 6 years ago

In 5c85244:

[2.2.x] Fixed #28831 -- Doc'd that InlineModelAdmin methods' obj argument is the parent object.

Backport of 85436473066aae5d793caeced010ea4f45da4e79 from master

Note: See TracTickets for help on using tickets.
Back to Top