2015-08-17 21:59:29 -07:00
|
|
|
from django.contrib.auth.models import User
|
|
|
|
from django.db import models
|
|
|
|
from snipts.utils import slugify_uniquely
|
|
|
|
|
|
|
|
|
|
|
|
class Team(models.Model):
|
2015-10-15 19:37:54 -07:00
|
|
|
|
|
|
|
PLANS = (
|
2019-01-23 15:52:55 -08:00
|
|
|
("snipt-teams-25-monthly", "25 users, monthly"),
|
|
|
|
("snipt-teams-100-monthly", "100 users, monthly"),
|
|
|
|
("snipt-teams-250-monthly", "250 users, monthly"),
|
|
|
|
("snipt-teams-unlimited-monthly", "Unlimited users, monthly"),
|
|
|
|
("snipt-teams-25-yearly", "25 users, yearly"),
|
|
|
|
("snipt-teams-100-yearly", "100 users, yearly"),
|
|
|
|
("snipt-teams-250-yearly", "250 users, yearly"),
|
|
|
|
("snipt-teams-unlimited-yearly", "Unlimited users, yearly"),
|
2015-10-15 19:37:54 -07:00
|
|
|
)
|
|
|
|
|
2015-08-17 21:59:29 -07:00
|
|
|
email = models.EmailField(max_length=255)
|
2019-01-23 15:52:55 -08:00
|
|
|
members = models.ManyToManyField(User, related_name="member", blank=True)
|
2015-09-30 18:46:11 -07:00
|
|
|
name = models.CharField(max_length=30)
|
2019-03-11 13:45:49 -07:00
|
|
|
owner = models.ForeignKey(User, related_name="owner", on_delete=models.CASCADE)
|
2015-09-30 18:46:11 -07:00
|
|
|
slug = models.SlugField(max_length=255, blank=True)
|
|
|
|
stripe_id = models.CharField(max_length=100, null=True, blank=True)
|
2019-01-23 15:52:55 -08:00
|
|
|
user = models.OneToOneField(
|
2019-03-11 13:45:49 -07:00
|
|
|
User, blank=True, null=True, on_delete=models.CASCADE
|
2019-01-23 15:52:55 -08:00
|
|
|
)
|
|
|
|
plan = models.CharField(
|
|
|
|
max_length=100,
|
|
|
|
default="snipt-teams-25-monthly",
|
|
|
|
choices=PLANS,
|
|
|
|
blank=True,
|
|
|
|
null=True,
|
|
|
|
)
|
2015-10-18 18:07:01 -07:00
|
|
|
disabled = models.BooleanField(default=False)
|
2015-08-17 21:59:29 -07:00
|
|
|
|
|
|
|
created = models.DateTimeField(auto_now_add=True, editable=False)
|
|
|
|
modified = models.DateTimeField(auto_now=True, editable=False)
|
|
|
|
|
|
|
|
def save(self, *args, **kwargs):
|
|
|
|
if not self.slug:
|
2019-01-23 15:52:55 -08:00
|
|
|
self.slug = slugify_uniquely(self.name, User, "username")
|
2015-08-17 21:59:29 -07:00
|
|
|
return super(Team, self).save(*args, **kwargs)
|
|
|
|
|
|
|
|
def __unicode__(self):
|
|
|
|
return self.name
|
2015-10-15 19:37:54 -07:00
|
|
|
|
2015-10-17 06:13:02 -07:00
|
|
|
@property
|
|
|
|
def member_count(self):
|
|
|
|
return self.members.all().count() + 1
|
|
|
|
|
2015-10-15 19:37:54 -07:00
|
|
|
@property
|
|
|
|
def member_limit(self):
|
2015-10-18 18:09:33 -07:00
|
|
|
|
|
|
|
if self.disabled:
|
|
|
|
return 0
|
|
|
|
|
2015-10-15 19:37:54 -07:00
|
|
|
plan_map = {
|
2019-01-23 15:52:55 -08:00
|
|
|
"snipt-teams-25-monthly": 25,
|
|
|
|
"snipt-teams-100-monthly": 100,
|
|
|
|
"snipt-teams-250-monthly": 250,
|
|
|
|
"snipt-teams-unlimited-monthly": float("inf"),
|
|
|
|
"snipt-teams-25-yearly": 25,
|
|
|
|
"snipt-teams-100-yearly": 100,
|
|
|
|
"snipt-teams-250-yearly": 250,
|
|
|
|
"snipt-teams-unlimited-yearly": float("inf"),
|
2015-10-15 19:37:54 -07:00
|
|
|
}
|
|
|
|
|
2019-01-23 15:52:55 -08:00
|
|
|
if plan_map[self.plan] == float("inf"):
|
|
|
|
return "Unlimited"
|
2015-10-15 19:37:54 -07:00
|
|
|
else:
|
|
|
|
return plan_map[self.plan]
|
2015-10-18 07:35:44 -07:00
|
|
|
|
|
|
|
def user_is_member(self, user):
|
2015-10-18 18:09:33 -07:00
|
|
|
if self.disabled:
|
|
|
|
return False
|
2015-10-18 08:52:44 -07:00
|
|
|
if self.owner == user or user in self.members.all():
|
2015-10-18 07:35:44 -07:00
|
|
|
return True
|
|
|
|
return False
|