This commit is contained in:
bkfox
2020-05-29 14:23:00 +02:00
parent c04c1f3a53
commit 1c44be4814
8 changed files with 30 additions and 28 deletions

View File

@ -1,3 +1,5 @@
from copy import copy
from django import forms
from django.contrib import admin
from django.utils.translation import gettext as _
@ -5,7 +7,7 @@ from django.utils.translation import gettext as _
from ..models import Episode, Diffusion
from .page import PageAdmin
from .sound import SoundInline, TracksInline
from .sound import SoundInline, TrackInline
class DiffusionBaseAdmin:
@ -14,7 +16,7 @@ class DiffusionBaseAdmin:
def get_readonly_fields(self, request, obj=None):
fields = super().get_readonly_fields(request, obj)
if not request.user.has_perm('aircox_program.scheduling'):
fields += ('program', 'start', 'end')
fields = fields + ('program', 'start', 'end')
return [field for field in fields if field in self.fields]
@ -59,6 +61,6 @@ class EpisodeAdmin(PageAdmin):
search_fields = PageAdmin.search_fields + ('parent__title',)
# readonly_fields = ('parent',)
inlines = [TracksInline, SoundInline, DiffusionInline]
inlines = [TrackInline, SoundInline, DiffusionInline]

View File

@ -33,13 +33,13 @@ class BasePageAdmin(admin.ModelAdmin):
prepopulated_filters = ('parent',)
search_fields = ('title',)
fieldsets = [
('', {
'fields': ['title', 'slug', 'cover', 'content'],
}),
(_('Publication Settings'), {
'fields': ['status', 'parent'],
# 'classes': ('collapse',),
}),
]
@ -55,12 +55,11 @@ class BasePageAdmin(admin.ModelAdmin):
data['parent'] = filters.get('parent', None)
return data
def get_common_context(self, query, extra_context=None):
def _get_common_context(self, query, extra_context=None):
extra_context = extra_context or {}
parent = query.get('parent', None)
extra_context['parent'] = None if parent is None else \
Page.objects.get_subclass(id=parent)
return extra_context
def render_change_form(self, request, context, *args, **kwargs):
@ -70,11 +69,11 @@ class BasePageAdmin(admin.ModelAdmin):
def add_view(self, request, form_url='', extra_context=None):
filters = QueryDict(request.GET.get('_changelist_filters', ''))
extra_context = self.get_common_context(filters, extra_context)
extra_context = self._get_common_context(filters, extra_context)
return super().add_view(request, form_url, extra_context)
def changelist_view(self, request, extra_context=None):
extra_context = self.get_common_context(request.GET, extra_context)
extra_context = self._get_common_context(request.GET, extra_context)
return super().changelist_view(request, extra_context)

View File

@ -1,4 +1,4 @@
from copy import deepcopy
from copy import copy
from django.contrib import admin
from django.utils.translation import gettext_lazy as _
@ -28,18 +28,21 @@ class ProgramAdmin(PageAdmin):
list_display = PageAdmin.list_display + ('schedule', 'station', 'active')
list_filter = PageAdmin.list_filter + ('station', 'active')
fieldsets = deepcopy(PageAdmin.fieldsets) + [
(_('Program Settings'), {
'fields': ['active', 'station', 'sync'],
'classes': ('collapse',),
})
]
prepopulated_fields = {'slug': ('title',)}
search_fields = ['title']
search_fields = ('title',)
inlines = [ScheduleInline, StreamInline]
def get_fieldsets(self, request, obj=None):
fields = super().get_fieldsets(request, obj)
if request.user.has_perm('aircox.program.scheduling'):
fields = fields + [
(_('Program Settings'), {
'fields': ['active', 'station', 'sync'],
})
]
return fields
@admin.register(Schedule)
class ScheduleAdmin(admin.ModelAdmin):

View File

@ -6,15 +6,18 @@ from adminsortable2.admin import SortableInlineAdminMixin
from ..models import Sound, Track
class TracksInline(SortableInlineAdminMixin, admin.TabularInline):
class TrackInline(SortableInlineAdminMixin, admin.TabularInline):
template = 'admin/aircox/playlist_inline.html'
model = Track
extra = 0
fields = ('position', 'artist', 'title', 'info', 'timestamp', 'tags')
fields = ('position', 'artist', 'title', 'info', 'tags')
list_display = ['artist', 'title', 'tags', 'related']
list_filter = ['artist', 'title', 'tags']
class SoundTrackInline(TrackInline):
fields = TrackInline.fields + ('timestamp',)
class SoundInline(admin.TabularInline):
model = Sound
@ -44,7 +47,7 @@ class SoundAdmin(admin.ModelAdmin):
(None, {'fields': ['is_good_quality']})
]
readonly_fields = ('path', 'duration',)
inlines = [TracksInline]
inlines = [SoundTrackInline]
@admin.register(Track)