Merge branch 'feature/establishment-status-bar' into 'develop'

must_of_the_week behaviour for update. public_mark has been returned

See merge request gm/gm-backend!271
This commit is contained in:
Олег Хаятов 2020-02-10 09:07:31 +00:00
commit 2832c1696f
5 changed files with 64 additions and 10 deletions

View File

@ -232,6 +232,8 @@ class EstablishmentRUDSerializer(model_serializers.EstablishmentBaseSerializer):
last_review = ReviewBaseSerializer(read_only=True)
must_of_the_week = serializers.BooleanField(required=False, )
class Meta(model_serializers.EstablishmentBaseSerializer.Meta):
fields = [
'id',
@ -264,6 +266,7 @@ class EstablishmentRUDSerializer(model_serializers.EstablishmentBaseSerializer):
'must_of_the_week',
'last_update_by_gm',
'last_update_by_manager',
'public_mark',
]
def to_representation(self, instance):

View File

@ -0,0 +1,18 @@
# Generated by Django 2.2.7 on 2020-02-10 08:46
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('review', '0020_reviewtextauthor'),
]
operations = [
migrations.AddField(
model_name='review',
name='visited_at',
field=models.DateField(blank=True, null=True),
),
]

View File

@ -94,6 +94,7 @@ class Review(BaseAttributes, TranslatedFieldsMixin):
mark = models.FloatField(verbose_name=_('mark'), blank=True, null=True, default=None)
priority = models.PositiveSmallIntegerField(_('Priority'), blank=True, null=True, default=None)
old_id = models.PositiveIntegerField(_('old id'), blank=True, null=True, default=None)
visited_at = models.DateField(blank=True, null=True)
objects = ReviewQuerySet.as_manager()
@ -101,6 +102,17 @@ class Review(BaseAttributes, TranslatedFieldsMixin):
def status_display(self):
return self.REVIEW_STATUSES[self.status][1]
@property
def visited_on(self):
from account.models import User
if isinstance(self.reviewer, User):
return {
'user': self.reviewer,
'date': self.visited_at,
}
return None
class Meta:
"""Meta class."""
verbose_name = _('Review')

View File

@ -23,6 +23,7 @@ class ReviewBaseSerializer(serializers.ModelSerializer):
'country',
'content_type',
'object_id',
'visited_on',
)

View File

@ -542,22 +542,42 @@ class AwardsModelMixin:
class CarouselMixin:
@property
def must_of_the_week(self) -> bool:
"""Detects whether current item in carousel"""
from main.models import Carousel
def __must_of_the_week_info_from_self(self) -> dict:
from main.models import Country
if hasattr(self, 'pk') and (hasattr(self, 'country') or hasattr(self, 'country_id')):
kwargs = {
return {
'content_type': ContentType.objects.get_for_model(self),
'object_id': self.pk,
'country': getattr(self, 'country', getattr(self, 'country_id', None)),
'object_id': getattr(self, 'pk'),
'country': getattr(self, 'country', get_object_or_404(Country, id=getattr(self, 'country_id', 0))),
}
return Carousel.objects.filter(**kwargs).exists()
def __must_of_the_week_has_fields(self) -> bool:
return hasattr(self, 'pk') and (hasattr(self, 'country') or hasattr(self, 'country_id'))
@property
def must_of_the_week(self) -> bool:
from main import models as main_models
"""Detects whether current item in carousel"""
if self.__must_of_the_week_has_fields():
kwargs = self.__must_of_the_week_info_from_self()
return main_models.Carousel.objects.filter(**kwargs).exists()
return False
@must_of_the_week.setter
def must_of_the_week(self, status: bool):
from main import models as main_models
"""Update field by status"""
if status != self.must_of_the_week and self.__must_of_the_week_has_fields():
carousel, _ = main_models.Carousel.objects.get_or_create(
**self.__must_of_the_week_info_from_self()
)
if not status and isinstance(carousel, main_models.Carousel):
carousel.delete()
class UpdateByMixin(models.Model):
"""Modify by mixin"""