views.py 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406
  1. from rest_framework import viewsets
  2. from utils.page import MyPageNumberPagination
  3. from utils.md5 import Md5
  4. from rest_framework.filters import OrderingFilter
  5. from django_filters.rest_framework import DjangoFilterBackend
  6. from rest_framework.response import Response
  7. from rest_framework.exceptions import APIException
  8. from django.http import StreamingHttpResponse
  9. from rest_framework.settings import api_settings
  10. from django.db import transaction
  11. from rest_framework import status
  12. from reportcenter.models import flowModel as flowlist
  13. from . import serializers
  14. from .filter import FlowFilter, MaterialChangeHistoryFilter, batchLogFilter, ContainerDetailLogFilter
  15. from .files import FileFlowListRenderCN, MaterialChangeHistoryRenderCN, batchLogRenderCN, ContainerDetailLogRenderCN
  16. from container.models import MaterialChangeHistory,batchLogModel,ContainerDetailLogModel
  17. """
  18. path(r'MaterialChangeHistory/', views.MaterialChangeHistoryViewSet.as_view({"get": "list", }), name="management"),
  19. path(r'MaterialChangeHistory/file/', views.MaterialChangeHistoryDownloadView.as_view({"get": "list"}), name="flowfile"),
  20. path(r'batchLog/', views.batchLogViewSet.as_view({"get": "list", }), name="management"),
  21. path(r'batchLog/file/', views.batchLogDownloadView.as_view({"get": "list"}), name="flowfile"),
  22. path(r'ContainerDetailLog/', views.ContainerDetailLogViewSet.as_view({"get": "list", }), name="management"),
  23. path(r'ContainerDetailLog/file/', views.ContainerDetailLogDownloadView.as_view({"get": "list"}), name="flowfile"),
  24. """
  25. class MaterialChangeHistoryViewSet(viewsets.ModelViewSet):
  26. filter_backends = [DjangoFilterBackend, OrderingFilter, ]
  27. ordering_fields = ['id', "change_time", "create_time", "update_time", ]
  28. filter_class = MaterialChangeHistoryFilter
  29. pagination_class = MyPageNumberPagination
  30. def get_queryset(self):
  31. return MaterialChangeHistory.objects.all()
  32. def get_serializer_class(self):
  33. if self.action in ['list', 'create']:
  34. return serializers.MaterialChangeHistorySerializer
  35. else:
  36. return self.http_method_not_allowed(request=self.request)
  37. class MaterialChangeHistoryDownloadView(viewsets.ModelViewSet):
  38. renderer_classes = (MaterialChangeHistoryRenderCN, ) + tuple(api_settings.DEFAULT_RENDERER_CLASSES)
  39. filter_backends = [DjangoFilterBackend, OrderingFilter, ]
  40. ordering_fields = ['id', "change_time", "create_time", "update_time", ]
  41. filter_class = MaterialChangeHistoryFilter
  42. def get_project(self):
  43. try:
  44. id = self.kwargs.get('pk')
  45. return id
  46. except:
  47. return None
  48. def get_queryset(self):
  49. id = self.get_project()
  50. if self.request.user:
  51. if id is None:
  52. return MaterialChangeHistory.objects.filter()
  53. else:
  54. return MaterialChangeHistory.objects.filter(id=id)
  55. else:
  56. return MaterialChangeHistory.objects.none()
  57. def get_serializer_class(self):
  58. if self.action in ['list']:
  59. return serializers.MaterialChangeHistorySerializer
  60. else:
  61. return self.http_method_not_allowed(request=self.request)
  62. def get_render(self, data):
  63. # lang = self.request.META.get('HTTP_LANGUAGE')
  64. # if lang:
  65. # if lang == 'zh-hans':
  66. # return FileListRenderCN().render(data)
  67. # else:
  68. # return FileListRenderEN().render(data)
  69. # else:
  70. # return FileListRenderEN().render(data)
  71. return MaterialChangeHistoryRenderCN().render(data)
  72. def list(self, request, *args, **kwargs):
  73. from datetime import datetime
  74. dt = datetime.now()
  75. data = (
  76. serializers.MaterialChangeHistorySerializer(instance).data
  77. for instance in self.filter_queryset(self.get_queryset())
  78. )
  79. renderer = self.get_render(data)
  80. response = StreamingHttpResponse(
  81. renderer,
  82. content_type="text/csv"
  83. )
  84. response['Content-Disposition'] = "attachment; filename='MaterialChangeHistory_{}.csv'".format(str(dt.strftime('%Y%m%d%H%M%S%f')))
  85. return response
  86. class batchLogViewSet(viewsets.ModelViewSet):
  87. filter_backends = [DjangoFilterBackend, OrderingFilter, ]
  88. ordering_fields = ['id', "create_time", "update_time", ]
  89. filter_class = batchLogFilter
  90. pagination_class = MyPageNumberPagination
  91. def get_queryset(self):
  92. return batchLogModel.objects.all()
  93. def get_serializer_class(self):
  94. if self.action in ['list', 'create']:
  95. return serializers.batchLogSerializer
  96. else:
  97. return self.http_method_not_allowed(request=self.request)
  98. class batchLogDownloadView(viewsets.ModelViewSet):
  99. renderer_classes = (batchLogRenderCN, ) + tuple(api_settings.DEFAULT_RENDERER_CLASSES)
  100. filter_backends = [DjangoFilterBackend, OrderingFilter, ]
  101. ordering_fields = ['id', "create_time", "update_time", ]
  102. filter_class = batchLogFilter
  103. def get_project(self):
  104. try:
  105. id = self.kwargs.get('pk')
  106. return id
  107. except:
  108. return None
  109. def get_queryset(self):
  110. id = self.get_project()
  111. if self.request.user:
  112. if id is None:
  113. return batchLogModel.objects.filter()
  114. else:
  115. return batchLogModel.objects.filter(id=id)
  116. else:
  117. return batchLogModel.objects.none()
  118. def get_serializer_class(self):
  119. if self.action in ['list']:
  120. return serializers.batchLogSerializer
  121. else:
  122. return self.http_method_not_allowed(request=self.request)
  123. def get_render(self, data):
  124. # lang = self.request.META.get('HTTP_LANGUAGE')
  125. # if lang:
  126. # if lang == 'zh-hans':
  127. # return FileListRenderCN().render(data)
  128. # else:
  129. # return FileListRenderEN().render(data)
  130. # else:
  131. # return FileListRenderEN().render(data)
  132. return batchLogRenderCN().render(data)
  133. def list(self, request, *args, **kwargs):
  134. from datetime import datetime
  135. dt = datetime.now()
  136. data = (
  137. serializers.batchLogSerializer(instance).data
  138. for instance in self.filter_queryset(self.get_queryset()))
  139. renderer = self.get_render(data)
  140. response = StreamingHttpResponse(
  141. renderer,
  142. content_type="text/csv"
  143. )
  144. response['Content-Disposition'] = "attachment; filename='batchLog_{}.csv'".format(str(dt.strftime('%Y%m%d%H%M%S%f')))
  145. return response
  146. class ContainerDetailLogViewSet(viewsets.ModelViewSet):
  147. filter_backends = [DjangoFilterBackend, OrderingFilter, ]
  148. ordering_fields = ['id', "create_time", "update_time", ]
  149. filter_class = ContainerDetailLogFilter
  150. pagination_class = MyPageNumberPagination
  151. def get_queryset(self):
  152. return ContainerDetailLogModel.objects.all()
  153. def get_serializer_class(self):
  154. if self.action in ['list', 'create']:
  155. return serializers.ContainerDetailLogSerializer
  156. else:
  157. return self.http_method_not_allowed(request=self.request)
  158. class ContainerDetailLogDownloadView(viewsets.ModelViewSet):
  159. renderer_classes = (ContainerDetailLogRenderCN, ) + tuple(api_settings.DEFAULT_RENDERER_CLASSES)
  160. filter_backends = [DjangoFilterBackend, OrderingFilter, ]
  161. ordering_fields = ['id', "create_time", "update_time", ]
  162. filter_class = ContainerDetailLogFilter
  163. def get_project(self):
  164. try:
  165. id = self.kwargs.get('pk')
  166. return id
  167. except:
  168. return None
  169. def get_queryset(self):
  170. id = self.get_project()
  171. if self.request.user:
  172. if id is None:
  173. return ContainerDetailLogModel.objects.filter()
  174. else:
  175. return ContainerDetailLogModel.objects.filter(id=id)
  176. else:
  177. return ContainerDetailLogModel.objects.none()
  178. def get_serializer_class(self):
  179. if self.action in ['list']:
  180. return serializers.ContainerDetailLogSerializer
  181. else:
  182. return self.http_method_not_allowed(request=self.request)
  183. def get_render(self, data):
  184. # lang = self.request.META.get('HTTP_LANGUAGE')
  185. # if lang:
  186. # if lang == 'zh-hans':
  187. # return FileListRenderCN().render(data)
  188. # else:
  189. # return FileListRenderEN().render(data)
  190. # else:
  191. # return FileListRenderEN().render(data)
  192. return ContainerDetailLogRenderCN().render(data)
  193. def list(self, request, *args, **kwargs):
  194. from datetime import datetime
  195. dt = datetime.now()
  196. data = (
  197. serializers.ContainerDetailLogSerializer(instance).data
  198. for instance in self.filter_queryset(self.get_queryset()))
  199. renderer = self.get_render(data)
  200. response = StreamingHttpResponse(
  201. renderer,
  202. content_type="text/csv"
  203. )
  204. response['Content-Disposition'] = "attachment; filename='ContainerDetailLog_{}.csv'".format(str(dt.strftime('%Y%m%d%H%M%S%f')))
  205. return response
  206. class FileListDownloadView(viewsets.ModelViewSet):
  207. renderer_classes = (FileFlowListRenderCN, ) + tuple(api_settings.DEFAULT_RENDERER_CLASSES)
  208. filter_backends = [DjangoFilterBackend, OrderingFilter, ]
  209. ordering_fields = ['id', "document_date" ]
  210. filter_class = FlowFilter
  211. def get_project(self):
  212. try:
  213. id = self.kwargs.get('pk')
  214. return id
  215. except:
  216. return None
  217. def get_queryset(self):
  218. id = self.get_project()
  219. if self.request.user:
  220. if id is None:
  221. return flowlist.objects.filter()
  222. else:
  223. return flowlist.objects.filter(id=id)
  224. else:
  225. return flowlist.objects.none()
  226. def get_serializer_class(self):
  227. if self.action in ['list']:
  228. return serializers.flowSerializer
  229. else:
  230. return self.http_method_not_allowed(request=self.request)
  231. def get_render(self, data):
  232. # lang = self.request.META.get('HTTP_LANGUAGE')
  233. # if lang:
  234. # if lang == 'zh-hans':
  235. # return FileListRenderCN().render(data)
  236. # else:
  237. # return FileListRenderEN().render(data)
  238. # else:
  239. # return FileListRenderEN().render(data)
  240. return FileFlowListRenderCN().render(data)
  241. def list(self, request, *args, **kwargs):
  242. from datetime import datetime
  243. dt = datetime.now()
  244. data = (
  245. serializers.flowSerializer(instance).data
  246. for instance in self.filter_queryset(self.get_queryset())
  247. )
  248. renderer = self.get_render(data)
  249. response = StreamingHttpResponse(
  250. renderer,
  251. content_type="text/csv"
  252. )
  253. response['Content-Disposition'] = "attachment; filename='stocklist_{}.csv'".format(str(dt.strftime('%Y%m%d%H%M%S%f')))
  254. return response
  255. class FlowsStatsViewSet(viewsets.ModelViewSet):
  256. filter_backends = [DjangoFilterBackend, OrderingFilter, ]
  257. ordering_fields = ['id', "create_time", "update_time", ]
  258. filter_class = FlowFilter
  259. pagination_class = MyPageNumberPagination
  260. """
  261. list:
  262. Response a data list(all)
  263. post:
  264. Create a new data(create)
  265. """
  266. def get_project(self):
  267. try:
  268. id = self.kwargs.get('pk')
  269. return id
  270. except:
  271. return None
  272. def get_queryset(self):
  273. id = self.get_project()
  274. if self.request.user:
  275. if id is None:
  276. return flowlist.objects.filter()
  277. else:
  278. return flowlist.objects.filter(id=id)
  279. else:
  280. return flowlist.objects.none()
  281. def get_serializer_class(self):
  282. if self.action in ['list', 'create', ]:
  283. return serializers.flowSerializer
  284. # elif self.action in ['retrieve','update',]:
  285. # return serializers.stocklistpartialSerializer
  286. else:
  287. return self.http_method_not_allowed(request=self.request)
  288. # def create(self, request, *args, **kwargs):
  289. # data = request.data.copy()
  290. # warehouse_code = data.get('warehouse_code')
  291. # warehouse_name = data.get('warehouse_name')
  292. # shelf_type = data.get('shelf_type')
  293. # shelf_name = data.get('shelf_name')
  294. # rows = int(data.get('rows', 0))
  295. # cols = int(data.get('cols', 0))
  296. # layers = int(data.get('layers', 0))
  297. # existing_positions = flowlist.get_existing_positions(warehouse_code,shelf_name, rows, cols, layers)
  298. # # 生成所有可能的坐标
  299. # instances = []
  300. # for r in range(1, rows+1):
  301. # for c in range(1, cols+1):
  302. # for l in range(1, layers+1):
  303. # if (r, c, l) not in existing_positions :
  304. # instances.append(flowlist(
  305. # warehouse_code=warehouse_code,
  306. # warehouse_name=warehouse_name,
  307. # shelf_type=shelf_type,
  308. # shelf_name=shelf_name,
  309. # row=r,
  310. # col=c,
  311. # layer=l,
  312. # ))
  313. # try:
  314. # with transaction.atomic():
  315. # flowlist.objects.bulk_create(instances, batch_size=1000)
  316. # except Exception as e:
  317. # return Response(
  318. # {"error": str(e)},
  319. # status=status.HTTP_500_INTERNAL_SERVER_ERROR
  320. # )
  321. # return Response({
  322. # "created": len(instances),
  323. # "skipped": (rows*cols*layers) - len(instances)
  324. # }, status=status.HTTP_201_CREATED)
  325. # def update(self, request, pk):
  326. # qs = self.get_object()
  327. # print(qs.id)
  328. # # return Response({"detail": "暂不支持修改"}, status=status.HTTP_400_BAD_REQUEST)
  329. # data = self.request.data
  330. # print(data)
  331. # serializer = self.get_serializer(qs, data=data)
  332. # serializer.is_valid(raise_exception=True)
  333. # serializer.save()
  334. # headers = self.get_success_headers(serializer.data)
  335. # return Response(serializer.data, status=200, headers=headers)
  336. # def retrieve(self, request, pk):
  337. # qs = self.get_object()
  338. # serializer = self.get_serializer(qs)
  339. # return Response(serializer.data)