2018-11-18 19:32:07 +00:00
|
|
|
import random
|
|
|
|
|
2015-03-09 00:40:24 +00:00
|
|
|
from django.db import models
|
|
|
|
|
|
|
|
class FundraisingGoal(models.Model):
|
|
|
|
"""Conservancy fundraiser Goal"""
|
|
|
|
|
|
|
|
fundraiser_code_name = models.CharField(max_length=200, blank=False, unique=True)
|
|
|
|
fundraiser_goal_amount = models.DecimalField(max_digits=10, decimal_places=2)
|
|
|
|
fundraiser_so_far_amount = models.DecimalField(max_digits=10, decimal_places=2)
|
2015-03-12 01:10:28 +00:00
|
|
|
fundraiser_donation_count = models.IntegerField()
|
|
|
|
fundraiser_donation_count_disclose_threshold = models.IntegerField()
|
2015-03-09 00:40:24 +00:00
|
|
|
|
|
|
|
def __unicode__(self):
|
|
|
|
return self.fundraiser_code_name
|
|
|
|
|
2015-03-09 04:21:58 +00:00
|
|
|
def percentage_there(self):
|
2018-11-18 19:07:37 +00:00
|
|
|
return (self.fundraiser_so_far_amount / self.fundraiser_goal_amount ) * 100
|
2015-03-09 04:21:58 +00:00
|
|
|
|
2015-03-09 00:40:24 +00:00
|
|
|
class Meta:
|
|
|
|
ordering = ('fundraiser_code_name',)
|
2018-11-18 18:59:53 +00:00
|
|
|
|
2018-11-18 19:32:07 +00:00
|
|
|
def providers(self):
|
|
|
|
return GoalProvider.objects.filter(fundraising_goal=self)
|
|
|
|
|
|
|
|
def random_providers(self, k=None):
|
|
|
|
providers = self.providers()
|
|
|
|
if not providers.exists():
|
|
|
|
return None
|
|
|
|
elif k is None:
|
|
|
|
return random.choice(providers)
|
|
|
|
else:
|
|
|
|
return random.sample(providers, k)
|
|
|
|
|
2018-11-18 18:59:53 +00:00
|
|
|
|
|
|
|
class GoalProvider(models.Model):
|
|
|
|
fundraising_goal = models.ForeignKey(
|
|
|
|
'FundraisingGoal',
|
|
|
|
on_delete=models.CASCADE,
|
|
|
|
)
|
|
|
|
provider_name = models.CharField(max_length=512)
|
|
|
|
|
|
|
|
def __unicode__(self):
|
|
|
|
return self.provider_name
|