summaryrefslogtreecommitdiff
path: root/postgresqleu/elections/models.py
blob: a331e4aeea3bc6cef4c369f1e2553359d2cccffa (plain)
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
from django.db import models
from postgresqleu.membership.models import Member


class Election(models.Model):
    name = models.CharField(max_length=100, null=False, blank=False)
    startdate = models.DateField(null=False, blank=False)
    enddate = models.DateField(null=False, blank=False)
    slots = models.IntegerField(null=False, default=1)
    isopen = models.BooleanField(null=False, default=False, verbose_name='Voting open')
    resultspublic = models.BooleanField(null=False, default=False, verbose_name='Results public')

    def __str__(self):
        return self.name

    class Meta:
        ordering = ('-startdate', )


class Candidate(models.Model):
    election = models.ForeignKey(Election, null=False, blank=False, on_delete=models.CASCADE)
    name = models.CharField(max_length=100, null=False, blank=False)
    email = models.EmailField(max_length=200, null=False, blank=False)
    presentation = models.TextField(null=False, blank=False)

    def __str__(self):
        return "%s (%s)" % (self.name, self.election)


class Vote(models.Model):
    election = models.ForeignKey(Election, null=False, blank=False, on_delete=models.CASCADE)
    voter = models.ForeignKey(Member, null=False, blank=False, on_delete=models.CASCADE)
    candidate = models.ForeignKey(Candidate, null=False, blank=False, on_delete=models.CASCADE)
    score = models.IntegerField(null=False, blank=False)