models.py 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. from django.db import models
  2. from django.contrib.contenttypes.fields import GenericForeignKey
  3. from django.contrib.contenttypes.models import ContentType
  4. from django.core.validators import MaxValueValidator
  5. from django.core.urlresolvers import reverse
  6. class Payment(models.Model):
  7. TRANSFERT = 0
  8. WITHDRAWAL = 1
  9. PAYMENT_CHOICES = (
  10. (TRANSFERT, 'Virement'),
  11. (WITHDRAWAL, 'Prélèvement'),
  12. )
  13. limit = models.Q(app_label='adhesions', model='Adherent') \
  14. | models.Q(app_label='services', model='Service')
  15. reason_type = models.ForeignKey(ContentType, on_delete=models.CASCADE,
  16. limit_choices_to=limit)
  17. reason_id = models.PositiveIntegerField()
  18. reason = GenericForeignKey('reason_type', 'reason_id')
  19. amount = models.DecimalField(max_digits=9, decimal_places=2, verbose_name='Montant')
  20. period = models.PositiveIntegerField(validators=[MaxValueValidator(12)],
  21. verbose_name='Période (mois)')
  22. payment_method = models.IntegerField(choices=PAYMENT_CHOICES,
  23. verbose_name='Méthode de paiement')
  24. date = models.DateField(verbose_name='Date de paiement ou de début de paiement')
  25. validated = models.BooleanField(default=False, verbose_name='Paiement validé')
  26. class Meta:
  27. verbose_name = 'paiement'
  28. permissions = (
  29. ('validate_payment', 'Peut valider les paiements'),
  30. )
  31. def payment_type_verbose(self):
  32. if self.reason_type.app_label == 'adhesions' \
  33. and self.reason_type.model == 'adherent':
  34. return 'Cotisation'
  35. if self.reason_type.app_label == 'services' \
  36. and self.reason_type.model == 'service':
  37. return 'Service (%s)' % self.reason.service_type
  38. payment_type_verbose.short_description = 'Type'
  39. def period_verbose(self):
  40. if self.period == 0:
  41. return 'non récurrent'
  42. elif self.period == 1:
  43. return 'mensuel'
  44. elif self.period == 3:
  45. return 'trimestriel'
  46. elif self.period == 6:
  47. return 'biannuel'
  48. elif self.period == 12:
  49. return 'annuel'
  50. else:
  51. return '%d mois' % self.period
  52. # Note: 'adherent' is already used as the related_query_name
  53. # of the GenericRelation on Adherent
  54. def get_adherent(self):
  55. if self.reason_type.app_label == 'adhesions' \
  56. and self.reason_type.model == 'adherent':
  57. return self.reason
  58. if self.reason_type.app_label == 'services' \
  59. and self.reason_type.model == 'service':
  60. return self.reason.adherent
  61. get_adherent.short_description = 'Adhérent'
  62. def __str__(self):
  63. s = str(self.amount) + '€'
  64. if self.period:
  65. if self.period == 1:
  66. s += '/mois'
  67. elif self.period == 12:
  68. s += '/an'
  69. else:
  70. s += '/%d mois' % self.period
  71. if self.payment_method == self.TRANSFERT:
  72. s += ' (virement)'
  73. elif self.payment_method == self.WITHDRAWAL:
  74. s += ' (prélèvement)'
  75. return s