From 43bf412982baa3f669303089422e42e80827a683 Mon Sep 17 00:00:00 2001 From: Nikita Manovich Date: Thu, 25 Oct 2018 13:28:44 +0300 Subject: [PATCH 1/2] Change a task with labels and attributes in admin panel --- cvat/apps/engine/admin.py | 64 ++++++++++++++++++++++++++++++++++++++- 1 file changed, 63 insertions(+), 1 deletion(-) diff --git a/cvat/apps/engine/admin.py b/cvat/apps/engine/admin.py index af8dfc47525b..8cee62734bfc 100644 --- a/cvat/apps/engine/admin.py +++ b/cvat/apps/engine/admin.py @@ -4,6 +4,68 @@ # SPDX-License-Identifier: MIT from django.contrib import admin +from django.utils.html import format_html +from django.urls import reverse +from .models import Task, Segment, Label, AttributeSpec -# Register your models here. +class SegmentInline(admin.TabularInline): + model = Segment + readonly_fields = ('start_frame', 'stop_frame') + can_delete = False + # Don't show on admin index page + def has_add_permission(self, request, object=None): + return False + +class AttributeSpecInline(admin.TabularInline): + model = AttributeSpec + extra = 0 + max_num = None + +class LabelInline(admin.TabularInline): + model = Label + show_change_link = True + extra = 0 + max_num = None + +class LabelAdmin(admin.ModelAdmin): + # Don't show on admin index page + def has_module_permission(self, request): + return False + + inlines = [ + AttributeSpecInline + ] + + +class TaskAdmin(admin.ModelAdmin): + date_hierarchy = 'updated_date' + readonly_fields = ('size', 'path', 'created_date', 'updated_date', + 'overlap', 'flipped') + list_display = ('name', 'mode', 'owner', 'created_date', 'updated_date') + search_fields = ('name', 'mode', 'owner_username', 'owner_first_name', + 'owner_last_name', 'owner_email') + inlines = [ + SegmentInline, + LabelInline + ] + + # A callable object to use inside search_fields + def owner_first_name(self, obj): + return obj.owner.first_name + + # A callable object to use inside search_fields + def owner_last_name(self, obj): + return obj.owner.last_name + + # A callable object to use inside search_fields + def owner_email(self, obj): + return obj.owner.email + + # Don't allow to add a task because it isn't trivial operation + def has_add_permission(self, request): + return False + + +admin.site.register(Task, TaskAdmin) +admin.site.register(Label, LabelAdmin) From 9761c5d253bc965d5441dc7e824dbd681374f426 Mon Sep 17 00:00:00 2001 From: Nikita Manovich Date: Thu, 25 Oct 2018 13:31:48 +0300 Subject: [PATCH 2/2] Delete unused imports. --- cvat/apps/engine/admin.py | 2 -- 1 file changed, 2 deletions(-) diff --git a/cvat/apps/engine/admin.py b/cvat/apps/engine/admin.py index 8cee62734bfc..7a86a722a67a 100644 --- a/cvat/apps/engine/admin.py +++ b/cvat/apps/engine/admin.py @@ -4,8 +4,6 @@ # SPDX-License-Identifier: MIT from django.contrib import admin -from django.utils.html import format_html -from django.urls import reverse from .models import Task, Segment, Label, AttributeSpec class SegmentInline(admin.TabularInline):