Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to add readonly inline on django admin

I am using django 1.4 and I have a many2many field, so when creating the admin site I wanted to add this field as an inline, here is some code:

class SummaryInline(admin.TabularInline):
    model = ParserError.summaries.through


class MyClassAdmin(admin.ModelAdmin):
    list_display = ('classifier', 'name', 'err_count', 'supported')
    fields = ('classifier', 'name', 'err_count', 'err_classifier', 'supported')
    inlines = (SummaryInline,)
    readonly_fields = ('classifier', 'err_count')

So my question is, how can I make the inline field readonly?

like image 352
Hassek Avatar asked Jun 14 '13 22:06

Hassek


3 Answers

After a while of trying to find the name I figured out thanks to this answer, so I checked the names at self.opts.local_fields and found the name of the middle table and added it to readonly_fields, setting can_delete to False.

class SummaryInline(admin.TabularInline):
    model = ParserError.summaries.through
    readonly_fields = ('myclasssummary',)
    can_delete = False

pretty simple but took me a while so I figured out it was a good idea to add it here.

like image 164
Hassek Avatar answered Oct 14 '22 10:10

Hassek


Additionally, if you do not want the ability to add/delete the rows, you can add these definitions.

def has_add_permission(self, request, obj=None):
    return False

def has_delete_permission(self, request, obj=None):
    return False
like image 20
Keval Prabhu Avatar answered Oct 14 '22 08:10

Keval Prabhu


You can make the entire inline readonly by adding:

class UnitsInline(admin.TabularInline):

    def has_change_permission(self, request, obj=None):
        return False

This will prevent anyone from editing the entry from the admin.

Another example that prevents, adding, deletion and displays all the inline fields as readonly:

class ReadOnlyInline(admin.TabularInline):
    def has_change_permission(self, request, obj=None):
        return False

    def has_add_permission(self, request, obj=None):
        return False

    def has_delete_permission(self, request, obj=None):
        return False

    def get_readonly_fields(self, request, obj=None):
        return list(super().get_fields(request, obj))
like image 29
tamarabyte Avatar answered Oct 14 '22 09:10

tamarabyte