views.py 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445
  1. # coding=utf-8
  2. import json
  3. from django.db.models import Sum, F
  4. from django.db import transaction
  5. from django.db.models import Q
  6. from rest_framework.views import APIView
  7. from rest_framework.generics import ListAPIView
  8. from utils.custom_modelviewset import CustomModelViewSet
  9. from .serializers import *
  10. from .filters import *
  11. from apps.log.models import BizLog
  12. from utils import response_ok, response_error
  13. from utils.permission import isLogin
  14. from apps.order.models import Order
  15. from rest_framework.decorators import action
  16. from django.contrib.auth import get_user_model
  17. User = get_user_model()
  18. from utils.format import strftime
  19. class ProductView(APIView):
  20. permission_classes = [isLogin, ]
  21. def get(self, request):
  22. data = []
  23. queryset = Product.objects.filter(enable=True)
  24. for row in queryset:
  25. item = {
  26. 'id': row.id,
  27. 'name': row.name,
  28. 'month': row.month,
  29. }
  30. data.append(item)
  31. return response_ok(data)
  32. class DeleteProductImageView(APIView):
  33. permission_classes = [isLogin, ]
  34. def post(self, request, *args, **kwargs):
  35. # 商品图片 删除
  36. id = request.GET.get('id')
  37. try:
  38. instance = ProductImages.getById(id)
  39. image = Upload.objects.filter(id=instance.image_id).first()
  40. with transaction.atomic():
  41. instance.delete()
  42. image.del_images()
  43. except CustomError as e:
  44. return response_error(e.get_error_msg())
  45. except Exception as e:
  46. return response_error(str(e))
  47. return response_ok()
  48. class ProductViewSet(CustomModelViewSet):
  49. permission_classes = [isLogin, ]
  50. queryset = Product.objects.filter()
  51. serializer_class = ProductSerializer
  52. def filter_queryset(self, queryset):
  53. f = ProductFilter(self.request.GET, queryset=queryset)
  54. return f.qs
  55. @action(methods=['post'], detail=True)
  56. def upload_image(self, request, pk):
  57. banner_img = request.FILES.get('banner_img')
  58. try:
  59. with transaction.atomic():
  60. instance = self.get_object()
  61. upload = Upload.objects._addnew(banner_img, 'commodity_image')
  62. if upload:
  63. if instance.main_image_id:
  64. img = Upload.objects.filter(id=instance.main_image_id).first()
  65. img.del_images()
  66. instance.main_image_id = upload.id
  67. instance.save()
  68. return response_ok(upload.id)
  69. return response_error('上传失败,请重新上传!')
  70. except CustomError as e:
  71. return response_error(e.get_error_msg())
  72. except Exception as e:
  73. return response_error(str(e))
  74. @action(methods=['post'], detail=True)
  75. def upload_detail_img(self, request, pk):
  76. # 上传详情、参数图片
  77. try:
  78. with transaction.atomic():
  79. instance = self.get_object()
  80. for i in range(10):
  81. file = request.data.get('file{}'.format(i))
  82. if file:
  83. upload = Upload.objects._addnew(file, 'commodity_image')
  84. ProductImages.objects.create(product_id=instance.id,
  85. image_id=upload.id)
  86. if not upload:
  87. return response_error('上传失败,请重新上传!')
  88. except CustomError as e:
  89. return response_error(e.get_error_msg())
  90. except Exception as e:
  91. return response_error(str(e))
  92. return response_ok()
  93. @action(methods=['post'], detail=True)
  94. def query_detail_img(self, request, pk):
  95. # 查看 详情图片
  96. instance = self.get_object()
  97. data = []
  98. commodity_images = ProductImages.objects.filter(product_id=instance.id)
  99. for commodity_image in commodity_images:
  100. image = Upload.objects.filter(id=commodity_image.image_id).first()
  101. image_path = image.get_path()
  102. commodity_image_item = {
  103. 'id': commodity_image.id,
  104. 'name': commodity_image.name,
  105. 'src': image_path,
  106. }
  107. data.append(commodity_image_item)
  108. return response_ok(data)
  109. class ProductListView(ListAPIView):
  110. queryset = Product.objects.filter(enable=True, main_image__isnull=False)
  111. serializer_class = ProductListSerializer
  112. def filter_queryset(self, queryset, ):
  113. f = ProductFilter(self.request.GET, queryset=queryset)
  114. return f.qs
  115. class OrderListView(ListAPIView):
  116. permission_classes = [isLogin, ]
  117. queryset = Order.objects.filter()
  118. serializer_class = OrderListSerializer
  119. def filter_queryset(self, queryset, ):
  120. queryset = queryset.filter(Q(create_user=self.request.user) | Q(seller=self.request.user))
  121. f = OrderFilter(self.request.GET, queryset=queryset)
  122. return f.qs
  123. class OrderViewSet(CustomModelViewSet):
  124. permission_classes = [isLogin, ]
  125. queryset = Order.objects.filter()
  126. serializer_class = OrderSerializer
  127. def filter_queryset(self, queryset):
  128. if self.request.user.type != User.EMPLOYEE:
  129. queryset = queryset.filter(Q(create_user=self.request.user) | Q(seller=self.request.user))
  130. f = OrderFilter(self.request.GET, queryset=queryset)
  131. return f.qs
  132. def retrieve(self, request, *args, **kwargs):
  133. # 小程序草稿箱、已上报修改,调用明细
  134. instance = self.get_object()
  135. serializer = self.get_serializer(instance)
  136. # 草稿的数据
  137. if instance.category == order.ZERO:
  138. edit_file2 = []
  139. images = OrderImages.objects.filter(order=instance)
  140. for image in images:
  141. item2 = {
  142. 'upload_id': image.image.id,
  143. 'url': image.image.get_path(),
  144. 'type': image.type,
  145. }
  146. edit_file2.append(item2)
  147. result = {
  148. 'data': serializer.data,
  149. 'edit_file2': edit_file2,
  150. }
  151. return response_ok(result)
  152. else:
  153. # 已上报修改,返回需要修改的字段列表
  154. edit_data = []
  155. edit_file = []
  156. edit_file2 = []
  157. edit_values = OrderDetailEdit.objects.filter(order=instance).values('value', 'reason', 'type')
  158. for r in edit_values:
  159. item = {
  160. 'name': r['value'],
  161. 'reason': r['reason'],
  162. }
  163. if r['type'] == OrderDetailEdit.ZERO:
  164. edit_data.append(item)
  165. else:
  166. edit_file.append(item)
  167. # 待审核,加载图片使用
  168. if instance.status == order.ZERO:
  169. images = OrderImages.objects.filter(order=instance)
  170. for image in images:
  171. item2 = {
  172. 'upload_id': image.image.id,
  173. 'url': image.image.get_path(),
  174. 'type': image.type,
  175. }
  176. edit_file2.append(item2)
  177. result = {
  178. 'data': serializer.data,
  179. 'edit_values': edit_data,
  180. 'edit_file': edit_file,
  181. 'edit_file2': edit_file2,
  182. }
  183. return response_ok(result)
  184. def create(self, request, *args, **kwargs):
  185. try:
  186. with transaction.atomic():
  187. serializer = self.get_serializer(data=request.data)
  188. if serializer.is_valid(raise_exception=True):
  189. instance = serializer.save()
  190. BizLog.objects.addnew(self.request.user, BizLog.INSERT,
  191. u'添加订单[%s],id=%d' % (instance.name, instance.id), request.data)
  192. return response_ok(instance.id)
  193. except CustomError as e:
  194. return response_error(e.get_error_msg())
  195. except Exception as e:
  196. return response_error(str(e))
  197. def update(self, request, *args, **kwargs):
  198. data = request.POST
  199. try:
  200. instance = self.get_object()
  201. if instance.status == order.ONE:
  202. raise CustomError('该客户信息已审核通过,禁止操作')
  203. if instance.status == order.THREE:
  204. raise CustomError('该客户信息被拒绝审批,禁止操作')
  205. with transaction.atomic():
  206. serializer = self.get_serializer(instance, data=request.data)
  207. if serializer.is_valid(raise_exception=True):
  208. instance = serializer.save()
  209. # 已上报的,修改,记录修改时间
  210. if instance.category == order.ONE:
  211. for key in data:
  212. edit = OrderDetailEdit.objects.filter(type=OrderDetailEdit.ZERO, order=instance,
  213. value=key).first()
  214. if edit:
  215. edit.edit_time = datetime.datetime.now()
  216. edit.save()
  217. instance.status = order.ZERO
  218. instance.save()
  219. BizLog.objects.addnew(self.request.user, BizLog.INSERT,
  220. u'修改订单[%s],id=%d' % (instance.name, instance.id), request.data)
  221. return response_ok(instance.id)
  222. except CustomError as e:
  223. return response_error(e.get_error_msg())
  224. except Exception as e:
  225. return response_error(str(e))
  226. @action(methods=['post'], detail=True)
  227. def checkEdit(self, request, pk):
  228. data = request.POST.get('items')
  229. reason = request.POST.get('reason')
  230. status = request.GET.get('statu')
  231. try:
  232. instance = self.get_object()
  233. if instance.status == order.ONE:
  234. raise CustomError('该客户信息已审核通过,禁止操作')
  235. if instance.status == order.THREE:
  236. raise CustomError('该客户信息被拒绝审批,禁止操作')
  237. with transaction.atomic():
  238. if status == '1':
  239. # 审核通过, 删除修改信息
  240. instance.status = order.ONE
  241. OrderDetailEdit.objects.filter(order=instance).delete()
  242. elif status == '3':
  243. # 拒绝审批
  244. instance.status = order.THREE
  245. instance.cancel_reason = reason
  246. else:
  247. # 返回修改
  248. if not len(data):
  249. raise CustomError('请填写返回修改原因')
  250. # 删除已修改过的历史修改信息
  251. OrderDetailEdit.objects.filter(order=instance, edit_time__isnull=False).delete()
  252. for item in json.loads(data):
  253. OrderDetailEdit.objects.create(order=instance, value=item['name'], reason=item['reason'],
  254. type=item['type'])
  255. if int(item['type']) == OrderDetailEdit.ONE:
  256. OrderImages.objects.filter(order=instance, type=item['name']).update(enable=False)
  257. instance.status = order.TOW
  258. instance.save()
  259. BizLog.objects.addnew(self.request.user, BizLog.INSERT,
  260. u'审批订单[%s],状态=%s,id=%d' % (instance.name, status, instance.id), request.data)
  261. return response_ok()
  262. except CustomError as e:
  263. return response_error(e.get_error_msg())
  264. except Exception as e:
  265. return response_error(str(e))
  266. @action(methods=['post'], detail=True)
  267. def upload_image(self, request, pk):
  268. file = self.request.FILES.get('file')
  269. type = self.request.POST.get('type')
  270. # 上传图片,order_id必填。更新图片时,upload_id必填
  271. # / order / 2 / upload_image /
  272. # post
  273. # file
  274. # type 0身份证, 1驾驶证, 2收入类, 3流水类, 4营业执照, 5挂靠协议
  275. # order_id 订单id
  276. # upload_id 图片id
  277. try:
  278. instance = self.get_object()
  279. if instance.status == order.ONE:
  280. raise CustomError('该客户信息已审核通过,禁止操作')
  281. if instance.status == order.THREE:
  282. raise CustomError('该客户信息被拒绝审批,禁止操作')
  283. with transaction.atomic():
  284. if type:
  285. # 上传图片时,把不在使用的同类别图片删除。
  286. images = OrderImages.objects.filter(order=instance, type=type, enable=False)
  287. for image in images:
  288. image.image.del_images()
  289. image.delete()
  290. upload = Upload.objects._addnew(file, 'user_image')
  291. if upload:
  292. OrderImages.objects.create(order=instance, type=type, image=upload, )
  293. edit = OrderDetailEdit.objects.filter(type=OrderDetailEdit.ONE, order=instance,
  294. value=type).first()
  295. if edit:
  296. edit.edit_time = datetime.datetime.now()
  297. edit.save()
  298. dict = {
  299. 'id': upload.id,
  300. 'path': upload.get_path(),
  301. }
  302. return response_ok(dict)
  303. return response_error('上传失败,请重新上传!')
  304. except CustomError as e:
  305. return response_error(e.get_error_msg())
  306. except Exception as e:
  307. return response_error(str(e))
  308. @action(methods=['post'], detail=True)
  309. def deleteImage(self, request, pk):
  310. upload_id = request.POST.get('id')
  311. try:
  312. instance = self.get_object()
  313. if instance.status == order.ONE:
  314. raise CustomError('该客户信息已审核通过,禁止操作')
  315. if instance.status == order.THREE:
  316. raise CustomError('该客户信息被拒绝审批,禁止操作')
  317. with transaction.atomic():
  318. if upload_id:
  319. upload = Upload.objects.filter(id=upload_id).first()
  320. if upload:
  321. OrderImages.objects.filter(order=instance, image_id=upload_id).delete()
  322. upload.del_images()
  323. return response_ok()
  324. return response_error('图片参数错误,删除失败')
  325. except CustomError as e:
  326. return response_error(e.get_error_msg())
  327. except Exception as e:
  328. return response_error(str(e))
  329. @action(methods=['get'], detail=True)
  330. def get_detail(self, request, pk):
  331. # 后端审核业务,获取客户信息和部分字段修改时间
  332. instance = self.get_object()
  333. serializer = self.get_serializer(instance)
  334. # y已上报修改,返回需要修改的字段列表
  335. # 不显示字段
  336. show = [
  337. 'vmodel', 'invioce', 'ptax', 'insurance', 'boutique', 'wextension', 'upkeep', 'dpratio', 'lamount',
  338. 'laompany_text', 'name', 'sex_text', 'bdate', 'rpr_text', 'nationality_text', 'ntype_text', 'inumber',
  339. 'dincome', 'mstatus_text',
  340. 'elevel_text', 'naddress', 'hptype_text', 'maddress_text', 'email', 'wx', 'phone', 'tel', 'wname', 'wphone',
  341. 'waddress', 'itype_text', 'otype_text', 'position', 'wbst_text', 'bstname', 'bstcode', 'bsttel',
  342. 'bstaddress',
  343. 'cname', 'ctel', 'relation_text', 'caddress', 'ctname', 'cttel', 'thesame_text', 'tsname', 'tsbdate',
  344. 'tsitype_text', 'tsinumber', 'tstel', 'tsrelation_text', 'tsnaddress', 'tsmaddress', 'tsemail', 'tswx',
  345. 'tswname', 'tswphone', 'tswaddress', 'tsmincome',
  346. ]
  347. result = []
  348. for s in show:
  349. key = serializer[s]
  350. edit_values = OrderDetailEdit.objects.filter(order=instance, type=OrderDetailEdit.ZERO,
  351. value=key.name).first()
  352. edit_time = reason = ''
  353. if edit_values:
  354. edit_time = edit_values.edit_time and strftime(edit_values.edit_time) or ''
  355. reason = edit_values.reason
  356. item = {
  357. 'name': key.name, # tel
  358. 'label': key.label, # 电话
  359. 'value': key.value, # 13566
  360. 'edit_time': edit_time,
  361. 'reason': reason,
  362. 'type': '0',
  363. }
  364. result.append(item)
  365. files = []
  366. types = OrderImages.TYPE_CHOICE
  367. for t in types:
  368. edit_values = OrderDetailEdit.objects.filter(order=instance, type=OrderDetailEdit.ONE,
  369. value=t[0]).first()
  370. edit_time = reason = ''
  371. if edit_values:
  372. edit_time = edit_values.edit_time and strftime(edit_values.edit_time) or ''
  373. reason = edit_values.reason
  374. item = {
  375. 'name': t[0], # 身份证
  376. 'label': t[1], # 身份证
  377. 'images': [], # 1
  378. 'edit_time': edit_time,
  379. 'reason': reason,
  380. 'type': '1',
  381. }
  382. images = OrderImages.objects.filter(order=instance, type=t[0])
  383. for image in images:
  384. item['images'].append(image.image.get_path())
  385. files.append(item)
  386. edit_dict = {
  387. 'order_info':result,
  388. 'image_info':files,
  389. }
  390. return response_ok(edit_dict)
  391. def destroy(self, request, *args, **kwargs):
  392. try:
  393. instance = self.get_object()
  394. if instance.category == order.ONE:
  395. raise CustomError('已上报信息,禁止删除!')
  396. if instance.status == order.THREE:
  397. raise CustomError('该客户信息被拒绝审批,禁止操作')
  398. with transaction.atomic():
  399. OrderDetailEdit.objects.filter(order=instance).delete()
  400. images = OrderImages.objects.filter(order=instance)
  401. for image in images:
  402. upload = Upload.objects.filter(id=image.image.id)
  403. upload.del_images()
  404. images.delete()
  405. super(OrderViewSet, self).destroy(request, *args, **kwargs)
  406. except CustomError as e:
  407. return response_error(e.get_error_msg())
  408. except Exception as e:
  409. return response_error(str(e))
  410. return response_ok()