filter.py 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  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. "category": ['exact', 'icontains'],
  52. }
  53. class ContainerDetailFilter(FilterSet):
  54. class Meta:
  55. model = ContainerDetailModel
  56. fields = {
  57. "id": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  58. "month": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  59. "container" : ['exact'],
  60. "batch": ['exact'],
  61. "goods_code": ['exact', 'icontains'],
  62. "goods_desc": ['exact', 'icontains'],
  63. "goods_qty": ['exact', 'icontains'],
  64. "goods_weight": ['exact', 'icontains'],
  65. "status": ['exact', 'lte','icontains'],
  66. "creater": ['exact', 'icontains'],
  67. "create_time": ['exact', 'gt', 'gte', 'lt', 'lte', 'range'],
  68. "update_time": ['exact', 'gt', 'gte', 'lt', 'lte', 'range'],
  69. }
  70. class ContainerOperationFilter(FilterSet):
  71. class Meta:
  72. model = ContainerOperationModel
  73. fields = {
  74. "id": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  75. "month": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  76. "container" : ['exact'],
  77. "operation_type": ['exact', 'icontains'],
  78. "batch": ['exact'],
  79. "goods_code" : ['exact', 'icontains'],
  80. "goods_desc": ['exact', 'icontains'],
  81. "goods_qty": ['exact', 'icontains'],
  82. "goods_weight": ['exact', 'icontains'],
  83. "operator": ['exact', 'icontains'],
  84. "timestamp": ['exact', 'gt', 'gte', 'lt', 'lte', 'range'],
  85. "from_location": ['exact', 'icontains'],
  86. "to_location": ['exact', 'icontains'],
  87. "memo": ['exact', 'icontains'],
  88. }
  89. class WCSTaskFilter(FilterSet):
  90. class Meta:
  91. model = ContainerWCSModel
  92. fields = {
  93. "id": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  94. "taskid": ['exact', 'icontains'],
  95. "batch": ['exact'],
  96. "batch_out": ['exact'],
  97. "bound_list": ['exact'],
  98. "batch_number": ['exact', 'icontains'],
  99. "sequence": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  100. "priority": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  101. "month": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  102. "tasktype": ['exact', 'icontains'],
  103. "tasknumber": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  104. "order_number": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  105. "container": ['exact', 'icontains'],
  106. "current_location": ['exact', 'icontains'],
  107. "target_location": ['exact', 'icontains'],
  108. "message": ['exact', 'icontains'],
  109. "working": ['exact', 'icontains','gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  110. "status": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  111. "create_time": ['exact', 'gt', 'gte', 'lt', 'lte', 'range'],
  112. "is_delete": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  113. }
  114. class TaskFilter(FilterSet):
  115. class Meta:
  116. model = TaskModel
  117. fields = {
  118. "id": ['exact', 'gt', 'gte', 'lt', 'lte', 'isnull', 'in', 'range'],
  119. "task_wcs" : ['exact'],
  120. "container_detail" : ['exact'],
  121. "batch_detail": ['exact'],
  122. "container_detail__goods_code": ['exact', 'icontains'],
  123. "container_detail__goods_desc": ['exact', 'icontains'],
  124. }