Add banner style.
[wolnelektury.git] / src / social / admin.py
old mode 100755 (executable)
new mode 100644 (file)
index bceb890..ac5fbd2
@@ -1,36 +1,57 @@
-# This file is part of Wolnelektury, licensed under GNU Affero GPLv3 or later.
-# Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information.
+# This file is part of Wolne Lektury, licensed under GNU Affero GPLv3 or later.
+# Copyright © Fundacja Wolne Lektury. See NOTICE for more information.
 #
 from django.contrib import admin
-from django.utils.translation import ugettext_lazy as _
+from django.forms import ModelForm
+from django.forms.widgets import TextInput
 from admin_ordering.admin import OrderableAdmin
 from social.models import Cite, BannerGroup, Carousel, CarouselItem
 
 
+class CiteForm(ModelForm):
+    class Meta:
+        model = Cite
+        fields = '__all__'
+        widgets = {
+            'background_color': TextInput(attrs={'type': 'color'}),
+        }
+
 class CiteAdmin(admin.ModelAdmin):
+    form = CiteForm
     list_display = ['nonempty_text', 'created_at', 'sticky', 'vip', 'small', 'has_image']
     list_filter = ['group']
     readonly_fields = ['created_at']
+    autocomplete_fields = ['book']
+    search_fields = ['text', 'link', 'picture_alt', 'picture_author', 'picture_link', 'image_title', 'image_author', 'image_link']
     fieldsets = (
-        (None, {'fields': ('group', 'sticky', 'created_at')}),
-        (_('Content'), {'fields': ('book', 'text', 'small', 'vip', 'link', 'video', 'picture', 'banner')}),
+        (None, {'fields': ('group', 'sticky', 'created_at', 'book')}),
+        ('Zawartość', {'fields': ('link', 'vip', 'text', 'small')}),
+        ('Media', {'fields': (
+            'video',
+            'picture', 'picture_alt',
+                'picture_title', 'picture_author', 'picture_link',
+                'picture_license', 'picture_license_link'
+        )}),
         (
-            _('Background'),
+            'Tło',
             {'fields': (
-                'image', 'image_shift', 'image_title', 'image_author',
-                'image_link', 'image_license', 'image_license_link')},
+                ('background_plain', 'background_color'),
+                'image',
+                'image_title', 'image_author', 'image_link',
+                'image_license', 'image_license_link'
+            )},
         )
     )
 
     def nonempty_text(self, cite):
         if cite.text.strip():
             return cite.text
-        return "(%s)" % ((cite.image_title or '').strip() or cite.link)
-    nonempty_text.short_description = _('text')
+        return "(%s)" % (cite.image_title or cite.link or '-').strip()
+    nonempty_text.short_description = 'tekst'
 
     def has_image(self, cite):
         return bool(cite.image)
-    has_image.short_description = _('image')
+    has_image.short_description = 'obraz'
     has_image.boolean = True
 
 
@@ -48,9 +69,11 @@ admin.site.register(BannerGroup, BannerGroupAdmin)
 class CarouselItemInline(OrderableAdmin, admin.TabularInline):
     model = CarouselItem
     ordering_field = 'order'
+    autocomplete_fields = ['banner']
 
 
 class CarouselAdmin(admin.ModelAdmin):
+    list_display = ['placement', 'priority', 'language']
     inlines = [CarouselItemInline]