mirror of
https://github.com/ae-utbm/sith.git
synced 2025-07-11 04:19:25 +00:00
Refactor election bdd
This commit is contained in:
@ -11,13 +11,14 @@ from subscription.views import get_subscriber
|
||||
|
||||
class Election(models.Model):
|
||||
"""
|
||||
This class allow to create a new election
|
||||
This class allows to create a new election
|
||||
"""
|
||||
title = models.CharField(_('title'), max_length=255)
|
||||
description = models.TextField(_('description'), null=True, blank=True)
|
||||
start_proposal = models.DateTimeField(_('start proposal'), blank=False)
|
||||
end_proposal = models.DateTimeField(_('end proposal'), blank=False)
|
||||
start_date = models.DateTimeField(_('start date'), blank=False)
|
||||
end_date = models.DateTimeField(_('end date'), blank=False)
|
||||
electors = models.ManyToManyField(Subscriber, related_name='election', verbose_name=_("electors"), blank=True)
|
||||
|
||||
def __str__(self):
|
||||
return self.title
|
||||
@ -27,8 +28,13 @@ class Election(models.Model):
|
||||
now = timezone.now()
|
||||
return bool(now <= self.end_date and now >= self.start_date)
|
||||
|
||||
@property
|
||||
def is_proposal_active(self):
|
||||
now = timezone.now()
|
||||
return bool(now <= self.end_proposal and now >= self.start_proposal)
|
||||
|
||||
def has_voted(self, user):
|
||||
return self.electors.filter(id=user.id).exists()
|
||||
return self.vote.filter(user__id=user.id).exists()
|
||||
|
||||
def get_results(self):
|
||||
pass
|
||||
@ -36,11 +42,11 @@ class Election(models.Model):
|
||||
|
||||
class Responsability(models.Model):
|
||||
"""
|
||||
This class allows to create a new responsability
|
||||
"""
|
||||
election = models.ForeignKey(Election, related_name='responsability', verbose_name=_("election"))
|
||||
title = models.CharField(_('title'), max_length=255)
|
||||
description = models.TextField(_('description'), null=True, blank=True)
|
||||
blank_votes = models.IntegerField(_('blank votes'), default=0)
|
||||
|
||||
def __str__(self):
|
||||
return ("%s : %s") % (self.election.title, self.title)
|
||||
@ -48,11 +54,23 @@ class Responsability(models.Model):
|
||||
|
||||
class Candidate(models.Model):
|
||||
"""
|
||||
This class is a component of responsability
|
||||
"""
|
||||
responsability = models.ForeignKey(Responsability, related_name='candidate', verbose_name=_("responsability"))
|
||||
subscriber = models.ForeignKey(Subscriber, verbose_name=_('user'), related_name='candidate', blank=True)
|
||||
user = models.ForeignKey(User, verbose_name=_('user'), related_name='candidate', blank=True)
|
||||
program = models.TextField(_('description'), null=True, blank=True)
|
||||
votes = models.IntegerField(_('votes'), default=0)
|
||||
|
||||
def __str__(self):
|
||||
return ("%s : %s -> %s") % (self.election.title, self.title, self.subscriber.get_full_name())
|
||||
return ("%s : %s -> %s") % (self.election.title, self.title, self.user.get_full_name())
|
||||
|
||||
|
||||
class Vote(models.Model):
|
||||
"""
|
||||
This class allows to vote for candidates
|
||||
"""
|
||||
election = models.ForeignKey(Election, related_name='vote', verbose_name=_("election"))
|
||||
candidate = models.ManyToManyField(Candidate, related_name='vote', verbose_name=_("candidate"))
|
||||
user = models.ForeignKey(User, related_name='vote', verbose_name=_("user"))
|
||||
|
||||
def __str__(self):
|
||||
return "Vote"
|
Reference in New Issue
Block a user