-
Notifications
You must be signed in to change notification settings - Fork 102
/
Copy pathmodels.py
101 lines (82 loc) · 3.57 KB
/
models.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
from django.db import models
from django.utils.translation import ugettext_lazy as _
from django.contrib.auth import get_user_model
from django.template.defaultfilters import slugify
from managers import QuestionManager
from django.conf import settings
if settings.USE_TZ:
from django.utils.timezone import now as datetime_now
else:
import datetime
datetime_now = datetime.datetime.now
User = get_user_model()
class Topic(models.Model):
"""
Generic Topics for FAQ question grouping
"""
name = models.CharField(_('name'), max_length=150)
slug = models.SlugField(_('slug'), max_length=150)
sort_order = models.IntegerField(_('sort order'), default=0,
help_text=_('The order you would like the topic to be displayed.'))
def get_absolute_url(self):
return '/faq/' + self.slug
class Meta:
verbose_name = _("Topic")
verbose_name_plural = _("Topics")
ordering = ['sort_order', 'name']
def __unicode__(self):
return self.name
class Question(models.Model):
HEADER = 2
ACTIVE = 1
INACTIVE = 0
STATUS_CHOICES = (
(ACTIVE, _('Active')),
(INACTIVE, _('Inactive')),
(HEADER, _('Group Header')),
)
text = models.TextField(_('question'), help_text=_('The actual question itself.'))
answer = models.TextField(_('answer'), blank=True, help_text=_('The answer text.'))
topic = models.ForeignKey(Topic, verbose_name=_('topic'), related_name='questions')
slug = models.SlugField(_('slug'), max_length=100)
status = models.IntegerField(_('status'),
choices=STATUS_CHOICES, default=INACTIVE,
help_text=_("Only questions with their status set to 'Active' will be "
"displayed. Questions marked as 'Group Header' are treated "
"as such by views and templates that are set up to use them."))
protected = models.BooleanField(_('is protected'), default=False,
help_text=_("Set true if this question is only visible by authenticated users."))
sort_order = models.IntegerField(_('sort order'), default=0,
help_text=_('The order you would like the question to be displayed.'))
created_on = models.DateTimeField(_('created on'), default=datetime_now)
updated_on = models.DateTimeField(_('updated on'))
created_by = models.ForeignKey(User, verbose_name=_('created by'),
null=True, related_name="+")
updated_by = models.ForeignKey(User, verbose_name=_('updated by'),
null=True, related_name="+")
objects = QuestionManager()
class Meta:
verbose_name = _("Frequent asked question")
verbose_name_plural = _("Frequently asked questions")
ordering = ['sort_order', 'created_on']
def __unicode__(self):
return self.text
def save(self, *args, **kwargs):
# Set the date updated.
self.updated_on = datetime_now()
# Create a unique slug, if needed.
if not self.slug:
suffix = 0
potential = base = slugify(self.text[:90])
while not self.slug:
if suffix:
potential = "%s-%s" % (base, suffix)
if not Question.objects.filter(slug=potential).exists():
self.slug = potential
# We hit a conflicting slug; increment the suffix and try again.
suffix += 1
super(Question, self).save(*args, **kwargs)
def is_header(self):
return self.status == Question.HEADER
def is_active(self):
return self.status == Question.ACTIVE