Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

abstract_models.py 3.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. from decimal import Decimal
  2. from django.db import models
  3. from django.utils.translation import ugettext_lazy as _
  4. from oscar.core.compat import AUTH_USER_MODEL
  5. class AbstractProductRecord(models.Model):
  6. """
  7. A record of a how popular a product is.
  8. This used be auto-merchandising to display the most popular
  9. products.
  10. """
  11. product = models.OneToOneField(
  12. 'catalogue.Product', verbose_name=_("Product"),
  13. related_name='stats')
  14. # Data used for generating a score
  15. num_views = models.PositiveIntegerField(_('Views'), default=0)
  16. num_basket_additions = models.PositiveIntegerField(
  17. _('Basket Additions'), default=0)
  18. num_purchases = models.PositiveIntegerField(
  19. _('Purchases'), default=0, db_index=True)
  20. # Product score - used within search
  21. score = models.FloatField(_('Score'), default=0.00)
  22. class Meta:
  23. abstract = True
  24. app_label = 'analytics'
  25. ordering = ['-num_purchases']
  26. verbose_name = _('Product record')
  27. verbose_name_plural = _('Product records')
  28. def __unicode__(self):
  29. return _("Record for '%s'") % self.product
  30. class AbstractUserRecord(models.Model):
  31. """
  32. A record of a user's activity.
  33. """
  34. user = models.OneToOneField(AUTH_USER_MODEL, verbose_name=_("User"))
  35. # Browsing stats
  36. num_product_views = models.PositiveIntegerField(
  37. _('Product Views'), default=0)
  38. num_basket_additions = models.PositiveIntegerField(
  39. _('Basket Additions'), default=0)
  40. # Order stats
  41. num_orders = models.PositiveIntegerField(
  42. _('Orders'), default=0, db_index=True)
  43. num_order_lines = models.PositiveIntegerField(
  44. _('Order Lines'), default=0, db_index=True)
  45. num_order_items = models.PositiveIntegerField(
  46. _('Order Items'), default=0, db_index=True)
  47. total_spent = models.DecimalField(_('Total Spent'), decimal_places=2,
  48. max_digits=12, default=Decimal('0.00'))
  49. date_last_order = models.DateTimeField(
  50. _('Last Order Date'), blank=True, null=True)
  51. class Meta:
  52. abstract = True
  53. app_label = 'analytics'
  54. verbose_name = _('User record')
  55. verbose_name_plural = _('User records')
  56. class AbstractUserProductView(models.Model):
  57. user = models.ForeignKey(AUTH_USER_MODEL, verbose_name=_("User"))
  58. product = models.ForeignKey('catalogue.Product', verbose_name=_("Product"))
  59. date_created = models.DateTimeField(_("Date Created"), auto_now_add=True)
  60. class Meta:
  61. abstract = True
  62. app_label = 'analytics'
  63. verbose_name = _('User product view')
  64. verbose_name_plural = _('User product views')
  65. def __unicode__(self):
  66. return _("%(user)s viewed '%(product)s'") % {
  67. 'user': self.user, 'product': self.product}
  68. class AbstractUserSearch(models.Model):
  69. user = models.ForeignKey(AUTH_USER_MODEL, verbose_name=_("User"))
  70. query = models.CharField(_("Search term"), max_length=255, db_index=True)
  71. date_created = models.DateTimeField(_("Date Created"), auto_now_add=True)
  72. class Meta:
  73. abstract = True
  74. app_label = 'analytics'
  75. verbose_name = _("User search query")
  76. verbose_name_plural = _("User search queries")
  77. def __unicode__(self):
  78. return _("%(user)s searched for '%(query)s'") % {
  79. 'user': self.user,
  80. 'query': self.query}