views.py 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570
  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, CreateAPIView
  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. def get(self, request):
  21. data = []
  22. queryset = Product.objects.filter(enable=True)
  23. for row in queryset:
  24. item = {
  25. 'id': row.id,
  26. 'name': row.name,
  27. 'month': row.month,
  28. }
  29. data.append(item)
  30. return response_ok(data)
  31. class DeleteProductImageView(APIView):
  32. permission_classes = [isLogin, ]
  33. def post(self, request, *args, **kwargs):
  34. # 商品图片 删除
  35. id = request.GET.get('id')
  36. try:
  37. instance = ProductImages.getById(id)
  38. image = Upload.objects.filter(id=instance.image_id).first()
  39. with transaction.atomic():
  40. instance.delete()
  41. image.del_images()
  42. except CustomError as e:
  43. return response_error(e.get_error_msg())
  44. except Exception as e:
  45. return response_error(str(e))
  46. return response_ok()
  47. class ProductViewSet(CustomModelViewSet):
  48. permission_classes = [isLogin, ]
  49. queryset = Product.objects.filter()
  50. serializer_class = ProductSerializer
  51. def filter_queryset(self, queryset):
  52. f = ProductFilter(self.request.GET, queryset=queryset)
  53. return f.qs
  54. @action(methods=['post'], detail=True)
  55. def upload_image(self, request, pk):
  56. banner_img = request.FILES.get('banner_img')
  57. try:
  58. with transaction.atomic():
  59. instance = self.get_object()
  60. upload = Upload.objects._addnew(banner_img, 'commodity_image/')
  61. if upload:
  62. if instance.main_image_id:
  63. img = Upload.objects.filter(id=instance.main_image_id).first()
  64. img.del_images()
  65. instance.main_image_id = upload.id
  66. instance.save()
  67. return response_ok(upload.id)
  68. return response_error('上传失败,请重新上传!')
  69. except CustomError as e:
  70. return response_error(e.get_error_msg())
  71. except Exception as e:
  72. return response_error(str(e))
  73. @action(methods=['post'], detail=True)
  74. def upload_detail_img(self, request, pk):
  75. # 上传详情、参数图片
  76. try:
  77. with transaction.atomic():
  78. instance = self.get_object()
  79. for i in range(10):
  80. file = request.data.get('file{}'.format(i))
  81. if file:
  82. upload = Upload.objects._addnew(file, 'commodity_image/')
  83. ProductImages.objects.create(product_id=instance.id,
  84. image_id=upload.id)
  85. if not upload:
  86. return response_error('上传失败,请重新上传!')
  87. except CustomError as e:
  88. return response_error(e.get_error_msg())
  89. except Exception as e:
  90. return response_error(str(e))
  91. return response_ok()
  92. @action(methods=['post'], detail=True)
  93. def query_detail_img(self, request, pk):
  94. # 查看 详情图片
  95. instance = self.get_object()
  96. data = []
  97. commodity_images = ProductImages.objects.filter(product_id=instance.id)
  98. for commodity_image in commodity_images:
  99. image = Upload.objects.filter(id=commodity_image.image_id).first()
  100. image_path = image.get_path()
  101. commodity_image_item = {
  102. 'id': commodity_image.id,
  103. 'name': commodity_image.name,
  104. 'src': image_path,
  105. }
  106. data.append(commodity_image_item)
  107. return response_ok(data)
  108. class ProductListView(ListAPIView):
  109. queryset = Product.objects.filter(enable=True, main_image__isnull=False)
  110. serializer_class = ProductListSerializer
  111. def filter_queryset(self, queryset, ):
  112. f = ProductFilter(self.request.GET, queryset=queryset)
  113. return f.qs
  114. class OrderListView(ListAPIView):
  115. permission_classes = [isLogin, ]
  116. queryset = Order.objects.filter()
  117. serializer_class = OrderListSerializer
  118. def filter_queryset(self, queryset, ):
  119. queryset = queryset.filter(Q(create_user_id__in=self.request.user.get_manager_users()) | Q(
  120. seller_id__in=self.request.user.get_manager_users()))
  121. f = OrderFilter(self.request.GET, queryset=queryset)
  122. return f.qs
  123. class OrderCreatView(CreateAPIView):
  124. # 匿名用户申报
  125. queryset = Order.objects.filter()
  126. serializer_class = OrderSerializer
  127. def post(self, request, *args, **kwargs):
  128. try:
  129. with transaction.atomic():
  130. serializer = self.get_serializer(data=request.data)
  131. if serializer.is_valid(raise_exception=True):
  132. instance = serializer.save()
  133. BizLog.objects.addnew(None, BizLog.INSERT,
  134. u'添加订单[%s],id=%d' % (instance.name, instance.id), request.data)
  135. return response_ok(instance.id)
  136. except CustomError as e:
  137. return response_error(e.get_error_msg())
  138. except Exception as e:
  139. return response_error(str(e))
  140. class OrderUploadView(CreateAPIView):
  141. # 匿名用户申报上传图片
  142. queryset = Order.objects.filter()
  143. serializer_class = OrderSerializer
  144. def post(self, request, *args, **kwargs):
  145. file = self.request.FILES.get('file')
  146. id = self.request.POST.get('id')
  147. type = self.request.POST.get('type')
  148. # 上传图片,order_id必填。更新图片时,upload_id必填
  149. # / order / 2 / upload_image /
  150. # post
  151. # file
  152. # type 0身份证, 1驾驶证, 2收入类, 3流水类, 4营业执照, 5挂靠协议
  153. # order_id 订单id
  154. # upload_id 图片id
  155. try:
  156. instance = Order.objects.filter(id=id).first()
  157. if not instance:
  158. raise CustomError('客户信息错误')
  159. if instance.status == order.ONE:
  160. raise CustomError('该客户信息已审核通过,禁止操作')
  161. elif instance.status == order.THREE:
  162. raise CustomError('该客户信息被拒绝审批,禁止操作')
  163. with transaction.atomic():
  164. if type:
  165. # 上传图片时,把不在使用的同类别图片删除。
  166. images = OrderImages.objects.filter(order=instance, type=type, enable=False)
  167. for image in images:
  168. image.image.del_images()
  169. image.delete()
  170. path = instance.get_path(type)
  171. upload = Upload.objects._addnew(file, path)
  172. if upload:
  173. OrderImages.objects.create(order=instance, type=type, image=upload, )
  174. edit = OrderDetailEdit.objects.filter(type=OrderDetailEdit.ONE, order=instance,
  175. value=type).first()
  176. if edit:
  177. edit.edit_time = datetime.datetime.now()
  178. edit.save()
  179. dict = {
  180. 'id': upload.id,
  181. 'path': upload.get_path(),
  182. }
  183. return response_ok(dict)
  184. return response_error('上传失败,请重新上传!')
  185. except CustomError as e:
  186. return response_error(e.get_error_msg())
  187. except Exception as e:
  188. return response_error(str(e))
  189. class OrderDeleteImgView(CreateAPIView):
  190. # 匿名用户申报上传图片
  191. queryset = Order.objects.filter()
  192. serializer_class = OrderSerializer
  193. def post(self, request, *args, **kwargs):
  194. order_id = request.POST.get('order_id')
  195. upload_id = request.POST.get('upload_id')
  196. try:
  197. instance = Order.objects.filter(id=order_id).first()
  198. if not instance:
  199. raise CustomError('客户信息错误')
  200. if instance.status == order.ONE:
  201. raise CustomError('该客户信息已审核通过,禁止操作')
  202. if instance.status == order.THREE:
  203. raise CustomError('该客户信息被拒绝审批,禁止操作')
  204. with transaction.atomic():
  205. if upload_id:
  206. upload = Upload.objects.filter(id=upload_id).first()
  207. if upload:
  208. OrderImages.objects.filter(order=instance, image_id=upload_id).delete()
  209. upload.del_images()
  210. return response_ok()
  211. return response_error('图片参数错误,删除失败')
  212. except CustomError as e:
  213. return response_error(e.get_error_msg())
  214. except Exception as e:
  215. return response_error(str(e))
  216. class GetNewView(APIView):
  217. # 获取新订单
  218. def get(self, request, *args, **kwargs):
  219. minutes = request.GET.get('minutes')
  220. time = datetime.datetime.now() - datetime.timedelta(minutes=int(minutes))
  221. orders = Order.objects.filter(create_time__gte=time, category=order.ONE)
  222. return response_ok(orders.count())
  223. class OrderViewSet(CustomModelViewSet):
  224. permission_classes = [isLogin, ]
  225. queryset = Order.objects.filter()
  226. serializer_class = OrderSerializer
  227. def filter_queryset(self, queryset, ):
  228. # 非管理者,只能查看自己的客户
  229. queryset = queryset.filter(Q(create_user_id__in=self.request.user.get_manager_users()) | Q(seller_id__in=self.request.user.get_manager_users()))
  230. f = OrderFilter(self.request.GET, queryset=queryset)
  231. return f.qs
  232. def retrieve(self, request, *args, **kwargs):
  233. # 小程序草稿箱、已上报修改,调用明细
  234. instance = self.get_object()
  235. serializer = self.get_serializer(instance)
  236. # 草稿的数据
  237. if instance.category == order.ZERO:
  238. edit_file2 = []
  239. images = OrderImages.objects.filter(order=instance)
  240. for image in images:
  241. item2 = {
  242. 'upload_id': image.image.id,
  243. 'url': image.image.get_path(),
  244. 'type': image.type,
  245. }
  246. edit_file2.append(item2)
  247. result = {
  248. 'data': serializer.data,
  249. 'edit_file2': edit_file2,
  250. }
  251. return response_ok(result)
  252. else:
  253. # 已上报修改,返回需要修改的字段列表
  254. edit_data = []
  255. edit_file = []
  256. edit_file2 = []
  257. edit_values = OrderDetailEdit.objects.filter(order=instance).values('value', 'reason', 'type')
  258. for r in edit_values:
  259. item = {
  260. 'name': r['value'],
  261. 'reason': r['reason'],
  262. }
  263. if r['type'] == OrderDetailEdit.ZERO:
  264. edit_data.append(item)
  265. else:
  266. edit_file.append(item)
  267. # 待审核,加载图片使用
  268. # if instance.status == order.ZERO:
  269. images = OrderImages.objects.filter(order=instance)
  270. for image in images:
  271. item2 = {
  272. 'upload_id': image.image.id,
  273. 'url': image.image.get_path(),
  274. 'type': image.type,
  275. }
  276. edit_file2.append(item2)
  277. result = {
  278. 'data': serializer.data,
  279. 'edit_values': edit_data,
  280. 'edit_file': edit_file,
  281. 'edit_file2': edit_file2,
  282. }
  283. return response_ok(result)
  284. def create(self, request, *args, **kwargs):
  285. try:
  286. with transaction.atomic():
  287. serializer = self.get_serializer(data=request.data)
  288. if serializer.is_valid(raise_exception=True):
  289. instance = serializer.save()
  290. BizLog.objects.addnew(self.request.user, BizLog.INSERT,
  291. u'添加订单[%s],id=%d' % (instance.name, instance.id), request.data)
  292. return response_ok(instance.id)
  293. except CustomError as e:
  294. return response_error(e.get_error_msg())
  295. except Exception as e:
  296. return response_error(str(e))
  297. def update(self, request, *args, **kwargs):
  298. data = request.POST
  299. try:
  300. instance = self.get_object()
  301. if instance.status == order.ONE:
  302. raise CustomError('该客户信息已审核通过,禁止操作')
  303. if instance.status == order.THREE:
  304. raise CustomError('该客户信息被拒绝审批,禁止操作')
  305. with transaction.atomic():
  306. serializer = self.get_serializer(instance, data=request.data)
  307. if serializer.is_valid(raise_exception=True):
  308. instance = serializer.save()
  309. instance.create_user = request.user
  310. instance.save()
  311. # 已上报的,修改,记录修改时间
  312. if instance.category == order.ONE:
  313. for key in data:
  314. edit = OrderDetailEdit.objects.filter(type=OrderDetailEdit.ZERO, order=instance,
  315. value=key).first()
  316. if edit:
  317. edit.edit_time = datetime.datetime.now()
  318. edit.save()
  319. instance.status = order.ZERO
  320. instance.create_time = datetime.datetime.now()
  321. instance.save()
  322. BizLog.objects.addnew(request.user, BizLog.INSERT,
  323. u'修改订单[%s],id=%d' % (instance.name, instance.id), request.data)
  324. return response_ok(instance.id)
  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=['post'], detail=True)
  330. def checkEdit(self, request, pk):
  331. data = request.POST.get('items')
  332. reason = request.POST.get('reason')
  333. status = request.GET.get('statu')
  334. try:
  335. if request.user.type != User.EMPLOYEE:
  336. raise CustomError('当前用户无权限,禁止操作')
  337. instance = self.get_object()
  338. if instance.category == order.ZERO:
  339. raise CustomError('草稿件,禁止操作')
  340. if instance.status == order.ONE:
  341. raise CustomError('该客户信息已审核通过,禁止操作')
  342. if instance.status == order.THREE:
  343. raise CustomError('该客户信息被拒绝审批,禁止操作')
  344. with transaction.atomic():
  345. if status == '1':
  346. # 审核通过, 删除修改信息
  347. instance.status = order.ONE
  348. OrderDetailEdit.objects.filter(order=instance).delete()
  349. elif status == '3':
  350. # 拒绝审批
  351. instance.status = order.THREE
  352. instance.cancel_reason = reason
  353. else:
  354. # 返回修改
  355. if not len(data):
  356. raise CustomError('请填写返回修改原因')
  357. # 删除已修改过的历史修改信息
  358. rowss = OrderDetailEdit.objects.filter(order=instance, edit_time__isnull=False)
  359. rowss.delete()
  360. for item in json.loads(data):
  361. edit = OrderDetailEdit.objects.filter(order=instance, value=item['name'], type=item['type'])
  362. if edit:
  363. edit.update(reason=item['reason'], edit_time=None)
  364. else:
  365. OrderDetailEdit.objects.create(order=instance, value=item['name'], reason=item['reason'],
  366. type=item['type'])
  367. if int(item['type']) == OrderDetailEdit.ONE:
  368. OrderImages.objects.filter(order=instance, type=item['name']).update(enable=False)
  369. instance.status = order.TOW
  370. instance.save()
  371. BizLog.objects.addnew(self.request.user, BizLog.INSERT,
  372. u'审批订单[%s],状态=%s,id=%d' % (instance.name, status, instance.id), request.data)
  373. return response_ok()
  374. except CustomError as e:
  375. return response_error(e.get_error_msg())
  376. except Exception as e:
  377. return response_error(str(e))
  378. @action(methods=['post'], detail=True)
  379. def upload_image(self, request, pk):
  380. file = self.request.FILES.get('file')
  381. type = self.request.POST.get('type')
  382. # 上传图片,order_id必填。更新图片时,upload_id必填
  383. # / order / 2 / upload_image /
  384. # post
  385. # file
  386. # type 0身份证, 1驾驶证, 2收入类, 3流水类, 4营业执照, 5挂靠协议
  387. # order_id 订单id
  388. # upload_id 图片id
  389. try:
  390. instance = self.get_object()
  391. if instance.status == order.ONE:
  392. raise CustomError('该客户信息已审核通过,禁止操作')
  393. if instance.status == order.THREE:
  394. raise CustomError('该客户信息被拒绝审批,禁止操作')
  395. with transaction.atomic():
  396. if type:
  397. # 上传图片时,把不在使用的同类别图片删除。
  398. images = OrderImages.objects.filter(order=instance, type=type, enable=False)
  399. for image in images:
  400. image.image.del_images()
  401. image.delete()
  402. path = instance.get_path(type)
  403. upload = Upload.objects._addnew(file, path)
  404. if upload:
  405. OrderImages.objects.create(order=instance, type=type, image=upload, )
  406. edit = OrderDetailEdit.objects.filter(type=OrderDetailEdit.ONE, order=instance,
  407. value=type).first()
  408. if edit:
  409. edit.edit_time = datetime.datetime.now()
  410. edit.save()
  411. dict = {
  412. 'id': upload.id,
  413. 'path': upload.get_path(),
  414. }
  415. return response_ok(dict)
  416. return response_error('上传失败,请重新上传!')
  417. except CustomError as e:
  418. return response_error(e.get_error_msg())
  419. except Exception as e:
  420. return response_error(str(e))
  421. @action(methods=['post'], detail=True)
  422. def deleteImage(self, request, pk):
  423. upload_id = request.POST.get('id')
  424. try:
  425. instance = self.get_object()
  426. if instance.status == order.ONE:
  427. raise CustomError('该客户信息已审核通过,禁止操作')
  428. if instance.status == order.THREE:
  429. raise CustomError('该客户信息被拒绝审批,禁止操作')
  430. with transaction.atomic():
  431. if upload_id:
  432. upload = Upload.objects.filter(id=upload_id).first()
  433. if upload:
  434. OrderImages.objects.filter(order=instance, image_id=upload_id).delete()
  435. upload.del_images()
  436. return response_ok()
  437. return response_error('图片参数错误,删除失败')
  438. except CustomError as e:
  439. return response_error(e.get_error_msg())
  440. except Exception as e:
  441. return response_error(str(e))
  442. @action(methods=['get'], detail=True)
  443. def get_detail(self, request, pk):
  444. # 后端审核业务,获取客户信息和部分字段修改时间
  445. instance = self.get_object()
  446. serializer = self.get_serializer(instance)
  447. # y已上报修改,返回需要修改的字段列表
  448. # 不显示字段
  449. show = [
  450. 'seller_text','vmodel', 'invioce', 'ptax', 'insurance', 'boutique', 'wextension', 'upkeep', 'dpratio', 'lamount',
  451. 'laompany_text', 'laompany_month', 'name', 'sex_text', 'bdate', 'rpr_text', 'nationality_text', 'ntype_text', 'inumber',
  452. 'dincome', 'mstatus_text',
  453. 'elevel_text', 'naddress', 'hptype_text', 'maddress_text', 'email', 'wx', 'phone', 'tel', 'wname', 'wphone',
  454. 'waddress', 'itype_text', 'otype_text', 'position', 'wbst_text', 'bstname', 'bstcode', 'bsttel',
  455. 'bstaddress',
  456. 'cname', 'ctel', 'relation_text', 'caddress', 'ctname', 'cttel', 'thesame_text', 'tsname', 'tsbdate',
  457. 'tsitype_text', 'tsinumber', 'tstel', 'tsrelation_text', 'tsnaddress', 'tsmaddress_text', 'tsemail', 'tswx',
  458. 'tswname', 'tswphone', 'tswaddress', 'tsmincome', 'notes',
  459. ]
  460. result = []
  461. for s in show:
  462. key = serializer[s]
  463. edit_values = OrderDetailEdit.objects.filter(order=instance, type=OrderDetailEdit.ZERO,
  464. value=key.name).first()
  465. edit_time = reason = ''
  466. if edit_values:
  467. edit_time = edit_values.edit_time and strftime(edit_values.edit_time) or ''
  468. reason = edit_values.reason
  469. item = {
  470. 'name': key.name, # tel
  471. 'label': key.label, # 电话
  472. 'value': key.value, # 13566
  473. 'edit_time': edit_time,
  474. 'reason': reason,
  475. 'type': '0',
  476. }
  477. result.append(item)
  478. files = []
  479. types = OrderImages.TYPE_CHOICE
  480. for t in types:
  481. edit_values = OrderDetailEdit.objects.filter(order=instance, type=OrderDetailEdit.ONE,
  482. value=t[0]).first()
  483. edit_time = reason = ''
  484. if edit_values:
  485. edit_time = edit_values.edit_time and strftime(edit_values.edit_time) or ''
  486. reason = edit_values.reason
  487. item = {
  488. 'name': t[0], # 身份证
  489. 'label': t[1], # 身份证
  490. 'images': [], # 1
  491. 'edit_time': edit_time,
  492. 'reason': reason,
  493. 'type': '1',
  494. }
  495. images = OrderImages.objects.filter(order=instance, type=t[0])
  496. for image in images:
  497. item['images'].append(image.image.get_path())
  498. files.append(item)
  499. edit_dict = {
  500. 'order_info': result,
  501. 'image_info': files,
  502. }
  503. return response_ok(edit_dict)
  504. def destroy(self, request, *args, **kwargs):
  505. try:
  506. instance = self.get_object()
  507. if instance.category == order.ONE:
  508. raise CustomError('已上报信息,禁止删除!')
  509. if instance.status == order.THREE:
  510. raise CustomError('该客户信息被拒绝审批,禁止操作')
  511. with transaction.atomic():
  512. OrderDetailEdit.objects.filter(order=instance).delete()
  513. images = OrderImages.objects.filter(order=instance)
  514. for image in images:
  515. upload = Upload.objects.filter(id=image.image.id).first()
  516. upload.del_images()
  517. images.delete()
  518. super(OrderViewSet, self).destroy(request, *args, **kwargs)
  519. except CustomError as e:
  520. return response_error(e.get_error_msg())
  521. except Exception as e:
  522. return response_error(str(e))
  523. return response_ok()