views.py 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292
  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. if request.user.is_superuser:
  90. rows = Order.objects.filter()
  91. else:
  92. rows = Order.objects.filter(branch=request.user.branch)
  93. f = OrderFilter(request.GET, queryset=rows)
  94. rows, total = utils.get_page_data(request, f.qs)
  95. serializer = OrderSerializer(rows, many=True)
  96. return DataGridJSONResponse(serializer.data, total)
  97. @token_required
  98. def coupon_list(request):
  99. f = BranchFilter(request.GET, queryset=Coupon.objects.filter(branch=request.user.branch))
  100. rows, total = utils.get_page_data(request, f.qs)
  101. serializer = CouponSerializer(rows, many=True)
  102. return DataGridJSONResponse(serializer.data, total)
  103. @token_required
  104. def coupon_save(request):
  105. id = request.GET.get('id')
  106. data = json.loads(request.body)
  107. try:
  108. with transaction.atomic():
  109. data['branch'] = request.user.branch_id
  110. serializer = CouponSerializer.factory(request.user, data, id)
  111. serializer.validSave()
  112. return JSONResponse(serializer.data)
  113. except CustomError as e:
  114. return JSONError(e.get_error_msg())
  115. except Exception as e:
  116. traceback.print_exc()
  117. return JSONError(u'保存失败!')
  118. @token_required
  119. def coupon_dict(request):
  120. rows = Coupon.objects.filter(
  121. Q(branch=request.user.branch, enabled=True) &
  122. Q(
  123. Q(end_date__isnull=False) & Q(end_date__gt=timezone.now().date()) |
  124. Q(end_date__isnull=True)
  125. )
  126. )
  127. serializer = CouponComboboxSerializer(rows, many=True)
  128. return DataGridJSONResponse(serializer.data, rows.count())
  129. @token_required
  130. def activity_list(request):
  131. if request.user.is_superuser:
  132. rows = Activity.objects.filter(delete=False)
  133. else:
  134. rows = Activity.objects.filter(branch_id=request.user.branch_id, delete=False)
  135. f = ActivityFilter(request.GET, queryset=rows)
  136. rows, total = utils.get_page_data(request, f.qs)
  137. serializer = ActivitySerializer(rows, many=True)
  138. return DataGridJSONResponse(serializer.data, total)
  139. @token_required
  140. def activity_save(request):
  141. id = request.GET.get('id')
  142. data = json.loads(request.body)
  143. try:
  144. with transaction.atomic():
  145. data['branch'] = request.user.branch_id
  146. serializer = ActivitySerializer.factory(request.user, data, id)
  147. serializer.validSave()
  148. return JSONResponse(serializer.data)
  149. except CustomError as e:
  150. return JSONError(e.get_error_msg())
  151. except Exception as e:
  152. traceback.print_exc()
  153. return JSONError(u'保存失败!')
  154. @token_required
  155. def activity_delete(request):
  156. id = request.GET.get('id')
  157. try:
  158. with transaction.atomic():
  159. order = Activity.objects.filter(id=id).first()
  160. if order.check_status == settings.PASS:
  161. raise CustomError(u'该活动已审核')
  162. order.delete = True
  163. order.save()
  164. BizLog.objects.addnew(request.user, BizLog.INSERT, u"删除活动[%s],id=%s" % (order.title, order.id))
  165. return JSONResponse({})
  166. except CustomError as e:
  167. return JSONError(e.get_error_msg())
  168. except Exception as e:
  169. traceback.print_exc()
  170. return JSONError(u'保存失败!')
  171. @token_required
  172. def activity_check(request):
  173. id = request.GET.get('id')
  174. status = request.GET.get('status')
  175. try:
  176. with transaction.atomic():
  177. order = Activity.objects.filter(id=id).first()
  178. if order.delete:
  179. raise CustomError(u'该活动已删除')
  180. if order.check_status == int(status):
  181. raise CustomError(u'该活动已当前状态不允许执行此操作')
  182. if int(status) == settings.PASS:
  183. order.check_status = settings.PASS
  184. order.save()
  185. BizLog.objects.addnew(request.user, BizLog.INSERT, u"审核活动[%s],id=%s" % (order.title, order.id))
  186. else:
  187. order.check_status = settings.DEFAULT
  188. order.save()
  189. BizLog.objects.addnew(request.user, BizLog.INSERT, u"活动撤销审核[%s],id=%s" % (order.title, order.id))
  190. return JSONResponse({})
  191. except CustomError as e:
  192. return JSONError(e.get_error_msg())
  193. except Exception as e:
  194. traceback.print_exc()
  195. return JSONError(u'保存失败!')
  196. @token_required
  197. def activity_signs_save(request):
  198. id = request.GET.get('id')
  199. signs = request.POST.get('signs')
  200. try:
  201. with transaction.atomic():
  202. signs = json.loads(signs)
  203. order = Activity.objects.filter(id=id).first()
  204. if order.delete:
  205. raise CustomError(u'该活动已删除')
  206. save_sign = ''
  207. for sign in signs:
  208. save_sign += sign + ','
  209. order.required_signs = save_sign
  210. order.save()
  211. BizLog.objects.addnew(request.user, BizLog.INSERT, u"活动设置必填项[%s],id=%s" % (order.title, order.id),signs )
  212. return JSONResponse({})
  213. except CustomError as e:
  214. return JSONError(e.get_error_msg())
  215. except Exception as e:
  216. traceback.print_exc()
  217. return JSONError(u'保存失败!')
  218. @token_required
  219. def activity_coupon_save(request):
  220. id = request.GET.get('id')
  221. coupon_ids = request.POST.get('coupons')
  222. try:
  223. with transaction.atomic():
  224. coupons = json.loads(coupon_ids)
  225. order = Activity.objects.filter(id=id).first()
  226. if order.delete:
  227. raise CustomError(u'该活动已删除')
  228. ActivityCoupon.objects.filter(activity=order).delete()
  229. for coupon in coupons:
  230. ActivityCoupon.objects.create(
  231. activity=order,
  232. coupon_id=coupon
  233. )
  234. BizLog.objects.addnew(request.user, BizLog.INSERT, u"活动添加优惠券[%s],id=%s" % (order.title, order.id),coupon_ids )
  235. return JSONResponse({})
  236. except CustomError as e:
  237. return JSONError(e.get_error_msg())
  238. except Exception as e:
  239. traceback.print_exc()
  240. return JSONError(u'保存失败!')