models.py 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  1. # coding=utf-8
  2. from django.db import models
  3. from django.conf import settings
  4. from django.utils import timezone
  5. from apps.commodity.models import Commodity
  6. from apps.option.models import Config, Student,Classes
  7. from apps.upload.models import Upload
  8. from utils.exceptions import CustomError
  9. from apps.base import Formater
  10. from apps.account.models import CustomerWechat
  11. from django.contrib.auth import get_user_model
  12. User = get_user_model()
  13. from apps.option.models import CommodityLevel, School
  14. class Coupon(models.Model):
  15. name = models.CharField(max_length=50, verbose_name='优惠券名称', unique=True, null=True)
  16. amount = models.BigIntegerField(verbose_name=u"优惠券金额", default=0)
  17. category = models.CharField(max_length=200, verbose_name='使用分类', null=True,)
  18. school = models.CharField(max_length=200, verbose_name='使用学校', null=True,)
  19. create_time = models.DateTimeField(verbose_name=u"创建时间", default=timezone.now)
  20. create_user = models.ForeignKey(settings.AUTH_USER_MODEL, verbose_name=u'创建人', related_name='coupon_create_user',
  21. on_delete=models.PROTECT, editable=False)
  22. begin_date = models.DateField(verbose_name=u"开始时间", null=True)
  23. end_date = models.DateField(verbose_name=u"结束时间", null=True)
  24. enable = models.BooleanField(verbose_name=u"是否在用", default=True)
  25. count = models.IntegerField(verbose_name=u"使用数量", default=0)
  26. class Meta:
  27. db_table = "coupon"
  28. verbose_name = u"优惠券"
  29. ordering = ('-id',)
  30. default_permissions = ()
  31. permissions = [
  32. ('view_coupon', u'查看'),
  33. ('add_coupon', u'添加修改'),
  34. ]
  35. class Pay(models.Model):
  36. WAIT = 0
  37. PAY = 1
  38. UNDO = 2
  39. STATUS_CHOICES = (
  40. (WAIT, u'待付款'),
  41. (PAY, u'已付款'),
  42. (UNDO, u'已取消'),
  43. )
  44. CUSTOMER = 1
  45. TYPE_CHOICES = (
  46. (CUSTOMER, u'客户'),
  47. )
  48. pay_no = models.CharField(max_length=25, verbose_name='支付单号', unique=True, null=True)
  49. status = models.PositiveSmallIntegerField(choices=STATUS_CHOICES, verbose_name='状态', default=WAIT)
  50. type = models.PositiveSmallIntegerField(choices=TYPE_CHOICES, verbose_name='类别', default=CUSTOMER)
  51. precreate_amount = models.BigIntegerField(verbose_name=u"预支付金额")
  52. create_time = models.DateTimeField(verbose_name=u"创建时间", default=timezone.now)
  53. amount = models.BigIntegerField(verbose_name=u"支付金额", null=True)
  54. user = models.ForeignKey(settings.AUTH_USER_MODEL, verbose_name=u'下单人', related_name='pay_user',
  55. on_delete=models.PROTECT)
  56. pay_time = models.DateTimeField(verbose_name=u"创建时间", null=True)
  57. class Meta:
  58. db_table = "pay"
  59. verbose_name = u"支付信息"
  60. ordering = ('-id',)
  61. default_permissions = ()
  62. def payClosed(self):
  63. if self.status != Pay.WAIT:
  64. return
  65. self.status = Pay.UNDO
  66. self.save()
  67. def paySuccess(self, pay_amount):
  68. if self.status != Pay.WAIT:
  69. return
  70. self.status = Pay.PAY
  71. self.amount = Formater.formatPrice(pay_amount)
  72. self.pay_time = timezone.now()
  73. self.save()
  74. order = Order.objects.filter(pay=self).first()
  75. if order:
  76. order.status = Order.FINISH
  77. order.actual_amount = self.amount
  78. order.save()
  79. if order.coupon:
  80. order.coupon.count += 1
  81. order.coupon.save()
  82. @staticmethod
  83. def getByNo(pay_no):
  84. instance = Pay.objects.filter(pay_no=pay_no).first()
  85. if not instance:
  86. raise CustomError(u'未找到相应的支付单号!')
  87. return instance
  88. # 小程序支付
  89. @staticmethod
  90. def wechatAppPay(user, amount, type=1):
  91. item = Pay._precreatePay(
  92. user,
  93. amount,
  94. type,
  95. )
  96. return item
  97. @staticmethod
  98. def _precreatePay(user, amount, type):
  99. pay_no = '{0}{1}'.format(user.id, timezone.now().strftime('%y%m%d%H%M%S'))
  100. pay = Pay.objects.create(
  101. pay_no=pay_no,
  102. status=Pay.WAIT,
  103. precreate_amount=amount,
  104. user=user,
  105. type=type,
  106. )
  107. return pay
  108. class Order(models.Model):
  109. WAIT_PAY = 1
  110. FINISH = 2
  111. CANCEL = 3
  112. STATUS_CHOICES = (
  113. (WAIT_PAY, u'待付款'),
  114. (FINISH, u'已完成'),
  115. (CANCEL, u'已取消'),
  116. )
  117. ONLINE_PAY = 1
  118. PAYMENT_CHOICES = (
  119. (ONLINE_PAY, u'在线支付'),
  120. )
  121. no = models.CharField(max_length=50, verbose_name=u'订单号', blank=True)
  122. pay = models.ForeignKey(Pay, verbose_name='支付信息', on_delete=models.PROTECT, null=True, editable=False)
  123. coupon = models.ForeignKey(Coupon, verbose_name='优惠券', editable=False, on_delete=models.PROTECT, null=True)
  124. commodity = models.ForeignKey(Commodity, verbose_name='商品', on_delete=models.PROTECT, null=True)
  125. status = models.PositiveSmallIntegerField(choices=STATUS_CHOICES, verbose_name=u"订单状态", default=WAIT_PAY)
  126. notes = models.CharField(max_length=500, verbose_name=u"备注", null=True)
  127. create_user = models.ForeignKey(settings.AUTH_USER_MODEL, related_name='order_create_user', verbose_name=u"添加人",
  128. on_delete=models.PROTECT, editable=False)
  129. create_time = models.DateTimeField(verbose_name=u'添加时间', auto_now_add=True, editable=False)
  130. student = models.ForeignKey(Student, verbose_name=u'学生', related_name='customer_order_student',
  131. on_delete=models.PROTECT, null=True)
  132. count = models.BigIntegerField(verbose_name=u'数量', default=0)
  133. total_amount = models.BigIntegerField(verbose_name=u'总金额', editable=False, default=0)
  134. coupon_deduction = models.BigIntegerField(verbose_name=u'优惠券抵扣', editable=False, default=0)
  135. actual_amount = models.BigIntegerField(verbose_name=u'实付金额', editable=False, default=0)
  136. class Meta:
  137. db_table = "order"
  138. verbose_name = u"订单管理"
  139. ordering = ('-id',)
  140. default_permissions = ()
  141. permissions = [
  142. ('view_order', u'查看'),
  143. ]
  144. def get_no(self):
  145. now = timezone.now()
  146. no = '%s%s%s' % ('C', self.create_user.id, now.strftime('%Y%m%d%H%M%S%f'))
  147. return no
  148. @staticmethod
  149. def get_instance_by_id(id):
  150. try:
  151. id = int(id)
  152. except:
  153. raise CustomError('无效的订单ID')
  154. instance = Order.objects.filter(pk=id).first()
  155. if not instance:
  156. raise CustomError('未找到对应的订单')
  157. return instance
  158. class ShoppingCart(models.Model):
  159. commodity = models.ForeignKey(Commodity, verbose_name='产品', on_delete=models.PROTECT)
  160. quantity = models.PositiveIntegerField(verbose_name="数量", default=1)
  161. create_time = models.DateTimeField(verbose_name="创建时间", auto_now_add=True)
  162. create_user = models.ForeignKey(settings.AUTH_USER_MODEL, related_name='shopping_cart_create_user',
  163. verbose_name=u"下单人",
  164. on_delete=models.PROTECT, editable=False)
  165. class Meta:
  166. db_table = "shopping_cart"
  167. verbose_name = "购物车"
  168. ordering = ['-id', ]
  169. default_permissions = ()