from django.db import models from django.utils.translation import gettext_lazy as _ from django.utils import timezone from django.contrib.postgres.fields import ArrayField from establishment.models import Establishment from utils.models import ImageMixin, ProjectBaseMixin class PartnerQueryset(models.QuerySet): def with_base_related(self): return self.prefetch_related('establishment__establishment_type', 'establishment__establishment_subtypes', 'establishment__awards', 'establishment__schedule', 'establishment__phones', 'establishment__gallery', 'establishment__menu_set', 'establishment__menu_set__plates', 'establishment__menu_set__plates__currency', 'establishment__currency', 'establishment__address__city', 'establishment__address__city__region', 'establishment__address__city__region__country', 'establishment__address__city__country', 'country') class Partner(ProjectBaseMixin): """Partner model.""" PARTNER = 0 SPONSOR = 1 MODEL_TYPES = ( (PARTNER, _('Partner')), (SPONSOR, _('Sponsor')), ) old_id = models.PositiveIntegerField(_('old id'), blank=True, null=True, default=None) name = models.CharField(_('name'), max_length=255, blank=True, null=True) images = ArrayField( models.URLField(verbose_name=_('Partner image URL')), blank=True, null=True, default=None, ) establishment = models.ManyToManyField('establishment.Establishment', related_name='partners', through='PartnerToEstablishment', verbose_name=_('Establishments')) type = models.PositiveSmallIntegerField(choices=MODEL_TYPES, default=PARTNER) starting_date = models.DateField(_('starting date'), blank=True, null=True) expiry_date = models.DateField(_('expiry date'), blank=True, null=True) price_per_month = models.DecimalField(_('price per month'), max_digits=10, decimal_places=2, blank=True, null=True) country = models.ForeignKey('location.Country', null=True, default=None, on_delete=models.SET_NULL) objects = PartnerQueryset.as_manager() class Meta: verbose_name = _('partner') verbose_name_plural = _('partners') def __str__(self): return f'{self.name}' @property def type_display(self): return self.MODEL_TYPES[self.type][1] class PartnerToEstablishment(models.Model): partner_bind_date = models.DateTimeField(default=timezone.now, editable=False, verbose_name=_('Date partner binded')) url = models.URLField(verbose_name=_('Establishment to Partner URL'), null=True, blank=True, default=None) image = models.URLField(verbose_name=_('Partner image URL'), null=True) partner = models.ForeignKey(Partner, on_delete=models.CASCADE, null=True) establishment = models.ForeignKey('establishment.Establishment', on_delete=models.CASCADE, null=True)