views.py 15 KB

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