|
@@ -1,4 +1,5 @@
|
|
from django.db import models
|
|
from django.db import models
|
|
|
|
+from django.utils import timezone
|
|
from django.contrib.auth.models import User
|
|
from django.contrib.auth.models import User
|
|
|
|
|
|
|
|
|
|
@@ -36,6 +37,36 @@ class Location(models.Model):
|
|
def all_google_review(self):
|
|
def all_google_review(self):
|
|
return self.review_set.all()
|
|
return self.review_set.all()
|
|
|
|
|
|
|
|
+ @property
|
|
|
|
+ def last_week_pos_google_review_count(self):
|
|
|
|
+ end_date = timezone.now() - timezone.timedelta(days=7)
|
|
|
|
+ return self.review_set.filter(create_time__gte=end_date, star_rating__gte=4).count()
|
|
|
|
+
|
|
|
|
+ @property
|
|
|
|
+ def last_week_pos_facebook_review_count(self):
|
|
|
|
+ end_date = timezone.now() - timezone.timedelta(days=7)
|
|
|
|
+ return self.facebookpage.facebookreview_set.filter(create_time__gte=end_date, recommendation_type=True).count()
|
|
|
|
+
|
|
|
|
+ @property
|
|
|
|
+ def last_week_pos_yelp_review_count(self):
|
|
|
|
+ end_date = timezone.now() - timezone.timedelta(days=7)
|
|
|
|
+ return self.yelplocation.yelpreview_set.filter(date_posted__gte=end_date, rating__gte=4).count()
|
|
|
|
+
|
|
|
|
+ @property
|
|
|
|
+ def last_week_neg_google_review_count(self):
|
|
|
|
+ end_date = timezone.now() - timezone.timedelta(days=7)
|
|
|
|
+ return self.review_set.filter(create_time__gte=end_date, star_rating__lte=3).count()
|
|
|
|
+
|
|
|
|
+ @property
|
|
|
|
+ def last_week_neg_facebook_review_count(self):
|
|
|
|
+ end_date = timezone.now() - timezone.timedelta(days=7)
|
|
|
|
+ return self.facebookpage.facebookreview_set.filter(create_time__gte=end_date, recommendation_type=False).count()
|
|
|
|
+
|
|
|
|
+ @property
|
|
|
|
+ def last_week_neg_yelp_review_count(self):
|
|
|
|
+ end_date = timezone.now() - timezone.timedelta(days=7)
|
|
|
|
+ return self.yelplocation.yelpreview_set.filter(date_posted__gte=end_date, rating__lte=3).count()
|
|
|
|
+
|
|
|
|
|
|
class LocationManager(models.Model):
|
|
class LocationManager(models.Model):
|
|
name = models.CharField(max_length=255)
|
|
name = models.CharField(max_length=255)
|