filter.py 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. from django_filters import FilterSet, NumberFilter, CharFilter
  2. from .models import ContainerListModel,ContainerDetailModel,ContainerOperationModel,TaskModel,ContainerWCSModel,ContainerDetailLogModel,batchLogModel,WCSTaskLogModel
  3. from django_filters import rest_framework as filters
  4. class batchLogFilter(filters.FilterSet):
  5. batch_code__icontains = filters.CharFilter(field_name='batch__bound_number', lookup_expr='icontains')
  6. bound_code__icontains = filters.CharFilter(field_name='bound__bound_code', lookup_expr='icontains')
  7. class Meta:
  8. model = batchLogModel
  9. fields = {
  10. "id": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  11. "bound": ['exact'],
  12. "batch": ['exact'],
  13. "log_type": ['exact', 'icontains'],
  14. "goods_code": ['exact', 'icontains'],
  15. "goods_desc": ['exact', 'icontains'],
  16. "goods_in_qty": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  17. "goods_out_qty": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  18. "detail_logs": ['exact'],
  19. "create_time": ['exact', 'gt', 'gte', 'lt', 'lte', 'range'],
  20. }
  21. class ContainerDetailLogFilter(filters.FilterSet):
  22. goods_code = filters.CharFilter(field_name='container_detail__goods_code', lookup_expr='exact')
  23. goods_code__icontains = filters.CharFilter(field_name='container_detail__goods_code', lookup_expr='icontains')
  24. container_code = filters.CharFilter(field_name='container_detail__container__container_code', lookup_expr='exact')
  25. bound_number = filters.CharFilter(field_name='container_detail__batch__bound_number', lookup_expr='exact')
  26. batch = filters.CharFilter(field_name='container_detail__batch__bound_number', lookup_expr='exact')
  27. batch__icontains = filters.CharFilter(field_name='container_detail__batch__bound_number', lookup_expr='icontains')
  28. class Meta:
  29. model = ContainerDetailLogModel
  30. fields = {
  31. "id": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  32. "container_detail": ['exact'],
  33. "log_type": ['exact', 'icontains'],
  34. "old_goods_qty": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  35. "old_goods_out_qty": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  36. "old_status": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  37. "new_goods_qty": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  38. "new_goods_out_qty": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  39. "new_status": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  40. "creater": ['exact', 'icontains'],
  41. "create_time": ['exact', 'gt', 'gte', 'lt', 'lte', 'range'],
  42. }
  43. class ContainerListFilter(FilterSet):
  44. class Meta:
  45. model = ContainerListModel
  46. fields = {
  47. "id": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  48. "container_code": ['exact', 'icontains'],
  49. "current_location": ['exact', 'icontains'],
  50. "status": ['exact', 'icontains'],
  51. "last_operation": ['exact', 'icontains'],
  52. "category": ['exact', 'icontains'],
  53. }
  54. class ContainerDetailFilter(FilterSet):
  55. bound_number = filters.CharFilter(field_name='batch__bound_number', lookup_expr='exact')
  56. class Meta:
  57. model = ContainerDetailModel
  58. fields = {
  59. "id": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  60. "month": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  61. "container" : ['exact'],
  62. "batch": ['exact'],
  63. "goods_code": ['exact', 'icontains'],
  64. "goods_desc": ['exact', 'icontains'],
  65. "goods_qty": ['exact', 'icontains'],
  66. "goods_weight": ['exact', 'icontains'],
  67. "status": ['exact', 'lte','icontains'],
  68. "creater": ['exact', 'icontains'],
  69. "create_time": ['exact', 'gt', 'gte', 'lt', 'lte', 'range'],
  70. "update_time": ['exact', 'gt', 'gte', 'lt', 'lte', 'range'],
  71. "is_delete": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  72. }
  73. class ContainerOperationFilter(FilterSet):
  74. class Meta:
  75. model = ContainerOperationModel
  76. fields = {
  77. "id": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  78. "month": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  79. "container" : ['exact'],
  80. "operation_type": ['exact', 'icontains'],
  81. "batch": ['exact'],
  82. "goods_code" : ['exact', 'icontains'],
  83. "goods_desc": ['exact', 'icontains'],
  84. "goods_qty": ['exact', 'icontains'],
  85. "goods_weight": ['exact', 'icontains'],
  86. "operator": ['exact', 'icontains'],
  87. "timestamp": ['exact', 'gt', 'gte', 'lt', 'lte', 'range'],
  88. "from_location": ['exact', 'icontains'],
  89. "to_location": ['exact', 'icontains'],
  90. "memo": ['exact', 'icontains'],
  91. }
  92. class WCSTaskFilter(FilterSet):
  93. class Meta:
  94. model = ContainerWCSModel
  95. fields = {
  96. "id": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  97. "taskid": ['exact', 'icontains'],
  98. "batch": ['exact'],
  99. "batch_out": ['exact'],
  100. "bound_list": ['exact'],
  101. "batch_number": ['exact', 'icontains'],
  102. "sequence": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  103. "priority": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  104. "month": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  105. "tasktype": ['exact', 'icontains'],
  106. "tasknumber": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  107. "order_number": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  108. "container": ['exact', 'icontains'],
  109. "current_location": ['exact', 'icontains'],
  110. "target_location": ['exact', 'icontains'],
  111. "message": ['exact', 'icontains'],
  112. "working": ['exact', 'icontains','gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  113. "status": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  114. "create_time": ['exact', 'gt', 'gte', 'lt', 'lte', 'range'],
  115. "is_delete": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  116. "location_group_id": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  117. }
  118. class TaskFilter(FilterSet):
  119. class Meta:
  120. model = TaskModel
  121. fields = {
  122. "id": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  123. "task_wcs" : ['exact'],
  124. "container_detail" : ['exact'],
  125. "batch_detail": ['exact'],
  126. "container_detail__goods_code": ['exact', 'icontains'],
  127. "container_detail__goods_desc": ['exact', 'icontains'],
  128. }
  129. class WCSTaskLogFilter(FilterSet):
  130. taskNumber = filters.CharFilter(field_name='task_number', lookup_expr='icontains')
  131. class Meta:
  132. model = WCSTaskLogModel
  133. fields = {
  134. "id": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  135. "task_number": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  136. "container": ['exact', 'icontains'],
  137. "current_location": ['exact', 'icontains'],
  138. "target_location": ['exact', 'icontains'],
  139. "location_group_id": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  140. "left_priority": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  141. "right_priority": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  142. "task_type": ['exact', 'icontains'],
  143. "order_number": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  144. "sequence": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  145. "send_time": ['exact', 'gt', 'gte', 'lt', 'lte', 'range'],
  146. "floor": ['exact', 'icontains'],
  147. "log_type": ['exact', 'icontains'],
  148. "is_completed": ['exact'],
  149. }