views.py 9.4 KB

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