filter.py 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. from django_filters import FilterSet, NumberFilter, CharFilter
  2. from .models import ContainerListModel,ContainerDetailModel,ContainerOperationModel,TaskModel,ContainerWCSModel,ContainerDetailLogModel,batchLogModel
  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. batch = filters.CharFilter(field_name='container_detail__batch__bound_number', lookup_expr='exact')
  26. batch__icontains = filters.CharFilter(field_name='container_detail__batch__bound_number', lookup_expr='icontains')
  27. class Meta:
  28. model = ContainerDetailLogModel
  29. fields = {
  30. "id": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  31. "container_detail": ['exact'],
  32. "log_type": ['exact', 'icontains'],
  33. "old_goods_qty": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  34. "old_goods_out_qty": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  35. "old_status": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  36. "new_goods_qty": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  37. "new_goods_out_qty": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  38. "new_status": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  39. "creater": ['exact', 'icontains'],
  40. "create_time": ['exact', 'gt', 'gte', 'lt', 'lte', 'range'],
  41. }
  42. class ContainerListFilter(FilterSet):
  43. class Meta:
  44. model = ContainerListModel
  45. fields = {
  46. "id": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  47. "container_code": ['exact', 'icontains'],
  48. "current_location": ['exact', 'icontains'],
  49. "status": ['exact', 'icontains'],
  50. "last_operation": ['exact', 'icontains'],
  51. }
  52. class ContainerDetailFilter(FilterSet):
  53. class Meta:
  54. model = ContainerDetailModel
  55. fields = {
  56. "id": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  57. "month": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  58. "container" : ['exact'],
  59. "batch": ['exact'],
  60. "goods_code": ['exact', 'icontains'],
  61. "goods_desc": ['exact', 'icontains'],
  62. "goods_qty": ['exact', 'icontains'],
  63. "goods_weight": ['exact', 'icontains'],
  64. "status": ['exact', 'lte','icontains'],
  65. "creater": ['exact', 'icontains'],
  66. "create_time": ['exact', 'gt', 'gte', 'lt', 'lte', 'range'],
  67. "update_time": ['exact', 'gt', 'gte', 'lt', 'lte', 'range'],
  68. }
  69. class ContainerOperationFilter(FilterSet):
  70. class Meta:
  71. model = ContainerOperationModel
  72. fields = {
  73. "id": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  74. "month": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  75. "container" : ['exact'],
  76. "operation_type": ['exact', 'icontains'],
  77. "batch": ['exact'],
  78. "goods_code" : ['exact', 'icontains'],
  79. "goods_desc": ['exact', 'icontains'],
  80. "goods_qty": ['exact', 'icontains'],
  81. "goods_weight": ['exact', 'icontains'],
  82. "operator": ['exact', 'icontains'],
  83. "timestamp": ['exact', 'gt', 'gte', 'lt', 'lte', 'range'],
  84. "from_location": ['exact', 'icontains'],
  85. "to_location": ['exact', 'icontains'],
  86. "memo": ['exact', 'icontains'],
  87. }
  88. class WCSTaskFilter(FilterSet):
  89. class Meta:
  90. model = ContainerWCSModel
  91. fields = {
  92. "id": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  93. "taskid": ['exact', 'icontains'],
  94. "batch": ['exact'],
  95. "batch_out": ['exact'],
  96. "bound_list": ['exact'],
  97. "batch_number": ['exact', 'icontains'],
  98. "sequence": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  99. "priority": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  100. "month": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  101. "tasktype": ['exact', 'icontains'],
  102. "tasknumber": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  103. "order_number": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  104. "container": ['exact', 'icontains'],
  105. "current_location": ['exact', 'icontains'],
  106. "target_location": ['exact', 'icontains'],
  107. "message": ['exact', 'icontains'],
  108. "working": ['exact', 'icontains','gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  109. "status": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  110. "create_time": ['exact', 'gt', 'gte', 'lt', 'lte', 'range'],
  111. "is_delete": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  112. }
  113. class TaskFilter(FilterSet):
  114. class Meta:
  115. model = TaskModel
  116. fields = {
  117. "id": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  118. "task_wcs" : ['exact'],
  119. "container_detail" : ['exact'],
  120. "batch_detail": ['exact'],
  121. "container_detail__goods_code": ['exact', 'icontains'],
  122. "container_detail__goods_desc": ['exact', 'icontains'],
  123. }