OrderPackageFilters.php 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. <?php
  2. namespace App\Filters;
  3. use App\Order;
  4. use App\Services\UserService;
  5. use Illuminate\Http\Request;
  6. use phpDocumentor\Reflection\Types\Boolean;
  7. class OrderPackageFilters
  8. {
  9. protected $request;
  10. protected $queryBuilder;
  11. protected $filters = ['logistic_number', 'status', 'received_at_start',
  12. 'received_at_end', 'is_weighed', 'logistic_id', 'owner_id', 'sent_at_start', 'sent_at_end', 'is_exception','exception_type','default_date'];
  13. public function __construct(Request $request)
  14. {
  15. $this->request = $request;
  16. }
  17. public function apply($builder)
  18. {
  19. $this->queryBuilder = $builder;
  20. $filters = array_filter($this->request->only($this->filters));
  21. foreach ($filters as $filter => $value) {
  22. if (method_exists($this, $filter)) {
  23. $this->$filter($value, $this->queryBuilder);
  24. }
  25. }
  26. return $this->queryBuilder;
  27. }
  28. private function logistic_number($logistic_number)
  29. {
  30. if (strpos($logistic_number, ',') || strpos($logistic_number, ',') || strpos($logistic_number, ' ')) {
  31. $arr = array_filter(preg_split('/[,, ]+/is', $logistic_number));
  32. $this->queryBuilder->whereIn('logistic_number',$arr);
  33. } else {
  34. $this->queryBuilder->where('logistic_number','like',$logistic_number."%");
  35. }
  36. }
  37. private function exception_type($exception_type)
  38. {
  39. $this->queryBuilder->where('exception_type', $exception_type);
  40. }
  41. private function status($status)
  42. {
  43. $this->queryBuilder->where('status', $status);
  44. }
  45. private function received_at_start($received_at_start)
  46. {
  47. $this->queryBuilder->where('received_at', '>=', $received_at_start);
  48. }
  49. private function received_at_end($received_at_end)
  50. {
  51. $this->queryBuilder->where('received_at', '<=', $received_at_end);
  52. }
  53. private function is_weighed($is_weighed)
  54. {
  55. if ($is_weighed == 'true') {
  56. $this->queryBuilder->whereNotNull('weighed_at');
  57. } else {
  58. $this->queryBuilder->whereNull('weighed_at');
  59. }
  60. }
  61. private function logistic_id($logistic_id)
  62. {
  63. $logistic_ids = array_filter(preg_split('/[,, ]+/is', $logistic_id));
  64. $this->queryBuilder->whereIn('order_id',function($query)use($logistic_ids){
  65. $query->from('orders')->select('id')->whereIn('logistic_id',$logistic_ids);
  66. });
  67. }
  68. private function owner_id($owner_id)
  69. {
  70. $owner_ids = array_filter(preg_split('/[,, ]+/is', $owner_id));
  71. $this->queryBuilder->whereIn('owner_id', $owner_ids);
  72. }
  73. private function sent_at_start($sent_at_start)
  74. {
  75. $this->queryBuilder->where('sent_at', '>=', $sent_at_start);
  76. }
  77. private function sent_at_end($sent_at_end)
  78. {
  79. $this->queryBuilder->where('sent_at', '<=', $sent_at_end);
  80. }
  81. private function is_exception($is_exception)
  82. {
  83. $this->queryBuilder->where('exception', $is_exception);
  84. }
  85. public function default_date()
  86. {
  87. $this->queryBuilder->where('sent_at', '>=',now()->startOfDay() ->subDays(15))->where('sent_at', '<',now()->startOfDay()->addDay());
  88. }
  89. }