models.py 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. from django.db import models
  2. from django.contrib.auth.models import User
  3. from django.contrib.contenttypes.fields import GenericForeignKey, GenericRelation
  4. from django.contrib.contenttypes.models import ContentType
  5. from djadhere.utils import get_active_filter
  6. from banking.models import Payment
  7. class Adherent(models.Model):
  8. limit = models.Q(app_label='auth', model='user') \
  9. | models.Q(app_label='adhesions', model='corporation')
  10. id = models.AutoField(verbose_name='Numéro d’adhérent', primary_key=True, editable=True)
  11. adherent_type = models.ForeignKey(ContentType, on_delete=models.CASCADE,
  12. limit_choices_to=limit, verbose_name='Type d’adhérent')
  13. adherent_id = models.PositiveIntegerField(verbose_name='ID')
  14. adherent = GenericForeignKey('adherent_type', 'adherent_id')
  15. contributions = GenericRelation(Payment,
  16. content_type_field='reason_type',
  17. object_id_field='reason_id',
  18. related_query_name='adherent')
  19. class Meta:
  20. verbose_name = 'adhérent'
  21. unique_together = ("adherent_type", "adherent_id")
  22. @property
  23. def contribution(self):
  24. try:
  25. return self.contributions.filter(get_active_filter()).get()
  26. except Payment.DoesNotExist:
  27. return None
  28. # MultipleObjectsReturned non catché volontairement, le filtrage par la méthode clean est censé
  29. # empêcher cette possibilité, si cette exception est levé on veut recevoir un mail avec l’erreur !
  30. @property
  31. def type(self):
  32. if self.adherent_type.app_label == 'auth' and self.adherent_type.model == 'user':
  33. return 'Personne physique'
  34. else:
  35. return 'Personne morale'
  36. def get_name(self):
  37. if self.adherent_type.app_label == 'auth' and self.adherent_type.model == 'user':
  38. return str(self.adherent.profile)
  39. else:
  40. return str(self.adherent)
  41. get_name.short_description = 'Nom ou raison sociale'
  42. def __str__(self):
  43. if self.id:
  44. return 'Adhérent #%d' % self.id
  45. else:
  46. return 'Adhérent #?'
  47. class Corporation(models.Model):
  48. social_reason = models.CharField(max_length=256, verbose_name='Raison sociale', unique=True)
  49. description = models.TextField(blank=True, default='')
  50. address = models.TextField(blank=True, default='', verbose_name='Adresse')
  51. members = models.ManyToManyField(User, blank=True, verbose_name='Membres')
  52. @property
  53. def adhesion(self):
  54. ctype = ContentType.objects.get_for_model(self)
  55. try:
  56. return Adherent.objects.get(adherent_type=ctype, adherent_id=self.pk)
  57. except Adherent.DoesNotExist:
  58. return None
  59. class Meta:
  60. verbose_name = 'personne morale'
  61. verbose_name_plural = 'personnes morales'
  62. def __str__(self):
  63. return self.social_reason