zero negative crop values (resulting from mark overlapping frame border)
[wolnelektury.git] / apps / pdcounter / models.py
1 # -*- coding: utf-8 -*-
2 # This file is part of Wolnelektury, licensed under GNU Affero GPLv3 or later.
3 # Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information.
4 #
5 from django.conf import settings
6 from django.db import models
7 from django.db.models import permalink
8 from django.utils.translation import ugettext as _
9 from datetime import datetime
10 from django.db.models.signals import post_save, post_delete
11
12 class Author(models.Model):
13     name = models.CharField(_('name'), max_length=50, db_index=True)
14     slug = models.SlugField(_('slug'), max_length=120, db_index=True, unique=True)
15     sort_key = models.CharField(_('sort key'), max_length=120, db_index=True)
16     description = models.TextField(_('description'), blank=True)
17     death = models.IntegerField(_(u'year of death'), blank=True, null=True)
18     gazeta_link = models.CharField(blank=True, max_length=240)
19     wiki_link = models.CharField(blank=True, max_length=240)
20
21     class Meta:
22         ordering = ('sort_key',)
23         verbose_name = _('author')
24         verbose_name_plural = _('authors')
25
26     @property
27     def category(self):
28         return "author"
29
30     def __unicode__(self):
31         return self.name
32
33     def __repr__(self):
34         return "Author(slug=%r)" % self.slug
35
36     @permalink
37     def get_absolute_url(self):
38         return ('catalogue.views.tagged_object_list', [self.url_chunk])
39
40     def has_description(self):
41         return len(self.description) > 0
42     has_description.short_description = _('description')
43     has_description.boolean = True
44
45     def alive(self):
46         return self.death is None
47
48     def in_pd(self):
49         """ tests whether an author is in public domain """
50         return self.death is not None and self.goes_to_pd() <= datetime.now().year
51
52     def goes_to_pd(self):
53         """ calculates the year of public domain entry for an author """
54         return self.death + 71 if self.death is not None else None
55
56     @property
57     def url_chunk(self):
58         return '/'.join(('autor', self.slug))
59
60
61 class BookStub(models.Model):
62     title = models.CharField(_('title'), max_length=120)
63     author = models.CharField(_('author'), max_length=120)
64     pd = models.IntegerField(_('goes to public domain'), null=True, blank=True)
65     slug = models.SlugField(_('slug'), max_length=120, unique=True, db_index=True)
66     translator = models.TextField(_('translator'), blank=True)
67
68     class Meta:
69         ordering = ('title',)
70         verbose_name = _('book stub')
71         verbose_name_plural = _('book stubs')
72
73     def __unicode__(self):
74         return self.title
75
76     @permalink
77     def get_absolute_url(self):
78         return ('catalogue.views.book_detail', [self.slug])
79
80     def in_pd(self):
81         return self.pd is not None and self.pd <= datetime.now().year
82
83     @property
84     def name(self):
85         return self.title
86
87     def pretty_title(self, html_links=False):
88         return ', '.join((self.author, self.title))
89
90
91 if not settings.NO_SEARCH_INDEX:
92     def update_index(sender, instance, **kwargs):
93         import search
94         idx = search.Index()
95         idx.index_tags(instance, remove_only=not 'created' in kwargs)
96     
97     post_delete.connect(update_index, Author)
98     post_delete.connect(update_index, BookStub)
99     post_save.connect(update_index, Author)
100     post_save.connect(update_index, BookStub)