models.py 7.2 KB

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