X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/f3e8dfa015744bd72796fdd8eff0d81f863cdc46..0c502550a4f04aa016df8729af2ae2f85c0b495a:/src/chunks/models.py diff --git a/src/chunks/models.py b/src/chunks/models.py index 56166a33e..881cc529f 100644 --- a/src/chunks/models.py +++ b/src/chunks/models.py @@ -4,6 +4,8 @@ from django.conf import settings from django.core.cache import cache from django.db import models +from django.urls import reverse +from django.utils.safestring import mark_safe from django.utils.translation import ugettext_lazy as _ @@ -42,3 +44,46 @@ class Attachment(models.Model): 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('