PackageService.php 3.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. <?php
  2. namespace App\Services;
  3. use App\OrderPackage;
  4. use App\Package;
  5. use App\Services\common\QueryService;
  6. use Illuminate\Database\Eloquent\Builder;
  7. use Illuminate\Http\Request;
  8. use Illuminate\Support\Arr;
  9. use Illuminate\Support\Facades\Auth;
  10. const TABLE = "order_packages.";
  11. use App\Traits\ServiceAppAop;
  12. class PackageService
  13. {
  14. use ServiceAppAop;
  15. protected $modelClass=Package::class;
  16. private function conditionQuery($params){
  17. $ownerIds=app('UserService')->getPermittingOwnerIds(Auth::user());
  18. $packages = OrderPackage::query()->with(['order'=>function($query){
  19. return $query->with(['owner','logistic','batch']);
  20. },'paperBox','measuringMachine'])
  21. ->whereIn('order_packages.owner_id',$ownerIds)->orderBy(TABLE.'id','DESC');
  22. if ($params['owner'] ?? false){
  23. $owner_id = explode(',',$params['owner']);
  24. $packages->whereIn('order_packages.owner_id',$owner_id);
  25. unset($params['owner']);
  26. }
  27. if ($params['logistic_number'] ?? false){
  28. $packages->whereIn('logistic_number',array_values(array_filter(preg_split('/[,, ]+/is', $params['logistic_number']))));
  29. unset($params["logistic_number"]);
  30. }
  31. if ($params['is_weighed']?? false) {
  32. $packages->whereNotNull('weighed_at');
  33. Arr::forget($params, 'is_weighed');
  34. }
  35. if ($params["batch_number"] ?? false){
  36. $codes = preg_split('/[,, ]+/is', $params["batch_number"]);
  37. $packages->whereHas("order",function ($query)use($codes){
  38. /** @var Builder $query */
  39. $query->whereHas("batch",function ($query)use($codes){
  40. /** @var Builder $query */
  41. $query->whereIn("code",$codes);
  42. });
  43. });
  44. unset($params["batch_number"]);
  45. }
  46. $columnQueryRules=[
  47. 'batch_number' => ['batch' => ''],
  48. 'weighed_at_start' => ['alias' => 'weighed_at', 'startDate' => ':00'],
  49. 'weighed_at_end' => ['alias' => 'weighed_at','endDate' => ":59"],
  50. 'id' => ['multi' => ','],
  51. ];
  52. $packages = app(QueryService::class)->query($params,$packages,$columnQueryRules,"order_packages");
  53. return $packages;
  54. }
  55. public function paginate(Request $request){
  56. $packages = $this->conditionQuery($request->input());
  57. return $packages->paginate($request->paginate ?? 50);
  58. }
  59. public function get(Request $request){
  60. $packages = $this->conditionQuery($request->input());
  61. return $packages->get();
  62. }
  63. public function getSql($params){
  64. return $this->conditionQuery($params)->selectRaw(TABLE.'*')
  65. ->leftJoin('orders',TABLE.'order_id','orders.id')
  66. ->selectRaw('orders.code order_code,orders.consignee_name order_consignee_name,orders.consignee_phone order_consignee_phone')
  67. ->LeftJoin('owners','orders.owner_id','owners.id')
  68. ->selectRaw('owners.name owner_name')
  69. ->LeftJoin('logistics','orders.logistic_id','logistics.id')
  70. ->selectRaw('logistics.name logistic_name')
  71. ->LeftJoin('paper_boxes',TABLE.'paper_box_id','paper_boxes.id')
  72. ->selectRaw('paper_boxes.model paper_box_name')
  73. ->LeftJoin('measuring_machines',TABLE.'measuring_machine_id','measuring_machines.id')
  74. ->selectRaw('measuring_machines.name measuring_machine_name')
  75. ->sql();
  76. }
  77. }