views.py 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290
  1. #coding=utf-8
  2. import traceback
  3. import json
  4. from django.utils import timezone
  5. from libs import utils
  6. from libs.http import JSONError, JSONResponse,DataGridJSONResponse
  7. from apps.account.decorators import token_required
  8. from django.db import transaction, IntegrityError
  9. from apps.exceptions import CustomError
  10. from apps.foundation.models import BizLog
  11. from django.db.models import Q
  12. from django.conf import settings
  13. from .models import *
  14. from .serializers import *
  15. from .filters import *
  16. from apps.customer.models import Customer
  17. from apps.account.models import Branch
  18. @token_required
  19. def branch_list(request):
  20. f = BranchFilter(request.GET, queryset=Branch.objects.filter())
  21. rows, total = utils.get_page_data(request, f.qs)
  22. serializer = BranchSerializer(rows, many=True)
  23. return DataGridJSONResponse(serializer.data, total)
  24. @token_required
  25. def branch_save(request):
  26. id = request.GET.get('id')
  27. data = json.loads(request.body)
  28. try:
  29. with transaction.atomic():
  30. serializer = BranchSerializer.factory(request.user, data, id)
  31. serializer.validSave()
  32. return JSONResponse(serializer.data)
  33. except CustomError as e:
  34. return JSONError(e.get_error_msg())
  35. except Exception as e:
  36. traceback.print_exc()
  37. return JSONError(u'保存失败!')
  38. @token_required
  39. def self_branch(request):
  40. order = Branch.objects.filter(id=request.user.branch_id).first()
  41. data = {}
  42. if order:
  43. data = {'name': order.name, 'tel': order.tel, 'address': order.address}
  44. return JSONResponse({'data': data})
  45. @token_required
  46. def member_list(request):
  47. f = CustomerFilter(request.GET, queryset=Customer.objects.filter(branch=request.user.branch))
  48. rows, total = utils.get_page_data(request, f.qs)
  49. serializer = CustomerSerializer(rows, many=True)
  50. return DataGridJSONResponse(serializer.data, total)
  51. @token_required
  52. def member_coupon_list(request):
  53. f = MemberCouponFilter(request.GET, queryset=MemberCoupon.objects.filter(member__branch=request.user.branch))
  54. rows, total = utils.get_page_data(request, f.qs)
  55. serializer = MemberCouponSerializer(rows, many=True)
  56. return DataGridJSONResponse(serializer.data, total)
  57. @token_required
  58. def coupon_write_off(request):
  59. id = request.GET.get('id')
  60. try:
  61. with transaction.atomic():
  62. instance = MemberCoupon.getById(id)
  63. if instance.member.branch and instance.member.branch_id != request.user.branch_id:
  64. raise CustomError(u'禁止跨店操作!')
  65. instance.writeOff()
  66. BizLog.objects.addnew(request.user, BizLog.CHECK, u"核销会员优惠券,id=%d" % instance.id)
  67. except CustomError as e:
  68. return JSONError(e.get_error_msg())
  69. except Exception as e:
  70. traceback.print_exc()
  71. return JSONError(u'核销失败!')
  72. return JSONResponse()
  73. @token_required
  74. def coupon_cancel_write_off(request):
  75. id = request.GET.get('id')
  76. try:
  77. with transaction.atomic():
  78. instance = MemberCoupon.getById(id)
  79. if instance.member.branch and instance.member.branch_id != request.user.branch_id:
  80. raise CustomError(u'禁止跨店操作!')
  81. instance.cancelWriteOff()
  82. BizLog.objects.addnew(request.user, BizLog.CHECK, u"撤销核销会员优惠券,id=%d" % instance.id)
  83. except CustomError as e:
  84. return JSONError(e.get_error_msg())
  85. except Exception as e:
  86. traceback.print_exc()
  87. return JSONError(u'撤销核销失败!')
  88. return JSONResponse()
  89. @token_required
  90. def order_list(request):
  91. f = OrderFilter(request.GET, queryset=Order.objects.filter(branch=request.user.branch))
  92. rows, total = utils.get_page_data(request, f.qs)
  93. serializer = OrderSerializer(rows, many=True)
  94. return DataGridJSONResponse(serializer.data, total)
  95. @token_required
  96. def coupon_list(request):
  97. f = BranchFilter(request.GET, queryset=Coupon.objects.filter(branch=request.user.branch))
  98. rows, total = utils.get_page_data(request, f.qs)
  99. serializer = CouponSerializer(rows, many=True)
  100. return DataGridJSONResponse(serializer.data, total)
  101. @token_required
  102. def coupon_save(request):
  103. id = request.GET.get('id')
  104. data = json.loads(request.body)
  105. try:
  106. with transaction.atomic():
  107. data['branch'] = request.user.branch_id
  108. serializer = CouponSerializer.factory(request.user, data, id)
  109. serializer.validSave()
  110. return JSONResponse(serializer.data)
  111. except CustomError as e:
  112. return JSONError(e.get_error_msg())
  113. except Exception as e:
  114. traceback.print_exc()
  115. return JSONError(u'保存失败!')
  116. @token_required
  117. def coupon_dict(request):
  118. rows = Coupon.objects.filter(
  119. Q(branch=request.user.branch, enabled=True) &
  120. Q(
  121. Q(end_date__isnull=False) & Q(end_date__gt=timezone.now().date()) |
  122. Q(end_date__isnull=True)
  123. )
  124. )
  125. serializer = CouponComboboxSerializer(rows, many=True)
  126. return DataGridJSONResponse(serializer.data, rows.count())
  127. @token_required
  128. def activity_list(request):
  129. if request.user.is_superuser:
  130. rows = Activity.objects.filter(delete=False)
  131. else:
  132. rows = Activity.objects.filter(branch_id=request.user.branch_id, delete=False)
  133. f = ActivityFilter(request.GET, queryset=rows)
  134. rows, total = utils.get_page_data(request, f.qs)
  135. serializer = ActivitySerializer(rows, many=True)
  136. return DataGridJSONResponse(serializer.data, total)
  137. @token_required
  138. def activity_save(request):
  139. id = request.GET.get('id')
  140. data = json.loads(request.body)
  141. try:
  142. with transaction.atomic():
  143. data['branch'] = request.user.branch_id
  144. serializer = ActivitySerializer.factory(request.user, data, id)
  145. serializer.validSave()
  146. return JSONResponse(serializer.data)
  147. except CustomError as e:
  148. return JSONError(e.get_error_msg())
  149. except Exception as e:
  150. traceback.print_exc()
  151. return JSONError(u'保存失败!')
  152. @token_required
  153. def activity_delete(request):
  154. id = request.GET.get('id')
  155. try:
  156. with transaction.atomic():
  157. order = Activity.objects.filter(id=id).first()
  158. if order.check_status == settings.PASS:
  159. raise CustomError(u'该活动已审核')
  160. order.delete = True
  161. order.save()
  162. BizLog.objects.addnew(request.user, BizLog.INSERT, u"删除活动[%s],id=%s" % (order.title, order.id))
  163. return JSONResponse({})
  164. except CustomError as e:
  165. return JSONError(e.get_error_msg())
  166. except Exception as e:
  167. traceback.print_exc()
  168. return JSONError(u'保存失败!')
  169. @token_required
  170. def activity_check(request):
  171. id = request.GET.get('id')
  172. status = request.GET.get('status')
  173. try:
  174. with transaction.atomic():
  175. order = Activity.objects.filter(id=id).first()
  176. if order.delete:
  177. raise CustomError(u'该活动已删除')
  178. if order.check_status == int(status):
  179. raise CustomError(u'该活动已当前状态不允许执行此操作')
  180. if int(status) == settings.PASS:
  181. order.check_status = settings.PASS
  182. order.save()
  183. BizLog.objects.addnew(request.user, BizLog.INSERT, u"审核活动[%s],id=%s" % (order.title, order.id))
  184. else:
  185. order.check_status = settings.DEFAULT
  186. order.save()
  187. BizLog.objects.addnew(request.user, BizLog.INSERT, u"活动撤销审核[%s],id=%s" % (order.title, order.id))
  188. return JSONResponse({})
  189. except CustomError as e:
  190. return JSONError(e.get_error_msg())
  191. except Exception as e:
  192. traceback.print_exc()
  193. return JSONError(u'保存失败!')
  194. @token_required
  195. def activity_signs_save(request):
  196. id = request.GET.get('id')
  197. signs = request.POST.get('signs')
  198. try:
  199. with transaction.atomic():
  200. signs = json.loads(signs)
  201. order = Activity.objects.filter(id=id).first()
  202. if order.delete:
  203. raise CustomError(u'该活动已删除')
  204. save_sign = ''
  205. for sign in signs:
  206. save_sign += sign + ','
  207. order.required_signs = save_sign
  208. order.save()
  209. BizLog.objects.addnew(request.user, BizLog.INSERT, u"活动设置必填项[%s],id=%s" % (order.title, order.id),signs )
  210. return JSONResponse({})
  211. except CustomError as e:
  212. return JSONError(e.get_error_msg())
  213. except Exception as e:
  214. traceback.print_exc()
  215. return JSONError(u'保存失败!')
  216. @token_required
  217. def activity_coupon_save(request):
  218. id = request.GET.get('id')
  219. coupon_ids = request.POST.get('coupons')
  220. try:
  221. with transaction.atomic():
  222. coupons = json.loads(coupon_ids)
  223. order = Activity.objects.filter(id=id).first()
  224. if order.delete:
  225. raise CustomError(u'该活动已删除')
  226. ActivityCoupon.objects.filter(activity=order).delete()
  227. for coupon in coupons:
  228. ActivityCoupon.objects.create(
  229. activity=order,
  230. coupon_id=coupon
  231. )
  232. BizLog.objects.addnew(request.user, BizLog.INSERT, u"活动添加优惠券[%s],id=%s" % (order.title, order.id),coupon_ids )
  233. return JSONResponse({})
  234. except CustomError as e:
  235. return JSONError(e.get_error_msg())
  236. except Exception as e:
  237. traceback.print_exc()
  238. return JSONError(u'保存失败!')