X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/165161a173154072eb7b999386a13562e110bd0a..ca8f4e8fef80cb603117ed579da8554f503698e5:/src/chunks/models.py?ds=sidebyside diff --git a/src/chunks/models.py b/src/chunks/models.py index f5fdbbf77..fc03c1be0 100644 --- a/src/chunks/models.py +++ b/src/chunks/models.py @@ -1,11 +1,11 @@ -# 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.conf import settings from django.core.cache import cache from django.db import models from django.urls import reverse -from django.utils.translation import ugettext_lazy as _ +from django.utils.safestring import mark_safe class Chunk(models.Model): @@ -13,15 +13,15 @@ class Chunk(models.Model): A Chunk is a piece of content associated with a unique key that can be inserted into any template with the use of a special template tag. """ - key = models.CharField(_('key'), help_text=_('A unique name for this chunk of content'), primary_key=True, + key = models.CharField('klucz', help_text='Unikalna nazwa dla tego kawaÅka treÅci', primary_key=True, max_length=255) - description = models.CharField(_('description'), blank=True, max_length=255) - content = models.TextField(_('content'), blank=True) + description = models.CharField('opis', blank=True, max_length=255) + content = models.TextField('zawartoÅÄ', blank=True) class Meta: ordering = ('key',) - verbose_name = _('chunk') - verbose_name_plural = _('chunks') + verbose_name = 'kawaÅek' + verbose_name_plural = 'kawaÅki' def __str__(self): return self.key @@ -34,15 +34,57 @@ class Chunk(models.Model): class Attachment(models.Model): - key = models.CharField(_('key'), help_text=_('A unique name for this attachment'), primary_key=True, max_length=255) + key = models.CharField( + 'klucz', help_text='Unikalna nazwa dla tego zaÅÄ cznika', + primary_key=True, max_length=255) attachment = models.FileField(upload_to='chunks/attachment') class Meta: ordering = ('key',) - verbose_name, verbose_name_plural = _('attachment'), _('attachments') + verbose_name, verbose_name_plural = 'zaÅÄ cznik', 'zaÅÄ czniki' def __str__(self): return self.key def get_absolute_url(self): return reverse('chunks_attachment', args=[self.key, self.attachment.name.rsplit('.', 1)[-1]]) + + +class Menu(models.Model): + identifier = models.CharField(max_length=255, unique=True) + + def __str__(self): + return self.identifier + + +class MenuItem(models.Model): + menu = models.ForeignKey(Menu, models.CASCADE) + order = models.SmallIntegerField() + highlight = models.BooleanField() + infopage = models.ForeignKey( + 'infopages.InfoPage', models.PROTECT, null=True, blank=True) + url = models.CharField(max_length=255, blank=True) + name = models.CharField(max_length=255, blank=True) + + class Meta: + ordering = ('order',) + + @property + def final_name(self): + if self.name == '-': + return mark_safe('