Add missing constraint.
[wolnelektury.git] / src / social / admin.py
old mode 100755 (executable)
new mode 100644 (file)
index 0a634ed..cc19432
@@ -2,30 +2,52 @@
 # Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information.
 #
 from django.contrib import admin
 # Copyright © Fundacja Nowoczesna Polska. 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 django.utils.translation import gettext_lazy as _
 from admin_ordering.admin import OrderableAdmin
 from social.models import Cite, BannerGroup, Carousel, CarouselItem
 
 
 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):
 class CiteAdmin(admin.ModelAdmin):
+    form = CiteForm
     list_display = ['nonempty_text', 'created_at', 'sticky', 'vip', 'small', 'has_image']
     list_filter = ['group']
     readonly_fields = ['created_at']
     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 = (
     fieldsets = (
-        (None, {'fields': ('group', 'sticky', 'created_at')}),
-        (_('Content'), {'fields': ('book', 'text', 'small', 'vip', 'link', 'video', 'picture', 'banner')}),
+        (None, {'fields': ('group', 'sticky', 'created_at', 'book')}),
+        (_('Content'), {'fields': ('link', 'vip', 'text', 'small')}),
+        (_('Media box'), {'fields': (
+            'video',
+            'picture', 'picture_alt',
+                'picture_title', 'picture_author', 'picture_link',
+                'picture_license', 'picture_license_link'
+        )}),
         (
             _('Background'),
             {'fields': (
         (
             _('Background'),
             {'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
         )
     )
 
     def nonempty_text(self, cite):
         if cite.text.strip():
             return cite.text
-        return "(%s)" % (cite.image_title.strip() or cite.link)
+        return "(%s)" % (cite.image_title or cite.link or '-').strip()
     nonempty_text.short_description = _('text')
 
     def has_image(self, cite):
     nonempty_text.short_description = _('text')
 
     def has_image(self, cite):
@@ -48,9 +70,11 @@ admin.site.register(BannerGroup, BannerGroupAdmin)
 class CarouselItemInline(OrderableAdmin, admin.TabularInline):
     model = CarouselItem
     ordering_field = 'order'
 class CarouselItemInline(OrderableAdmin, admin.TabularInline):
     model = CarouselItem
     ordering_field = 'order'
+    autocomplete_fields = ['banner']
 
 
 class CarouselAdmin(admin.ModelAdmin):
 
 
 class CarouselAdmin(admin.ModelAdmin):
+    list_display = ['placement', 'priority', 'language']
     inlines = [CarouselItemInline]
 
 
     inlines = [CarouselItemInline]