PackageService.php 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. <?php
  2. namespace App\Services;
  3. use App\OrderPackage;
  4. use App\Services\common\QueryService;
  5. use Illuminate\Http\Request;
  6. const TABLE = "order_packages.";
  7. Class PackageService
  8. {
  9. private function conditionQuery($params){
  10. $packages = OrderPackage::query()->with(['order'=>function($query){
  11. $query->with('owner','logistic');
  12. },'paperBox','measuringMachine'])->orderBy(TABLE.'id','DESC');
  13. if ($params['owner_id'] ?? false){
  14. $owner_id = explode(',',$params['owner_id']);
  15. $packages->whereHas('order',function ($query)use($owner_id){
  16. $query->whereIn('owner_id',$owner_id);
  17. });
  18. unset($params['owner_id']);
  19. }
  20. $columnQueryRules=[
  21. 'logistic_number' => ['like' => ''],
  22. 'batch_number' => ['like' => ''],
  23. 'created_at_start' => ['alias' => 'created_at','startDate' => " 00:00:00"],
  24. 'created_at_end' => ['alias' => 'created_at','endDate' => " 23:59:59"],
  25. 'id' => ['multi' => ','],
  26. ];
  27. $packages = app(QueryService::class)->query($params,$packages,$columnQueryRules,"order_packages");
  28. return $packages;
  29. }
  30. public function paginate(Request $request){
  31. $packages = $this->conditionQuery($request->input());
  32. return $packages->paginate($request->paginate ?? 50);
  33. }
  34. public function get(Request $request){
  35. $packages = $this->conditionQuery($request->input());
  36. return $packages->get();
  37. }
  38. public function getSql($params){
  39. return $this->conditionQuery($params)->selectRaw(TABLE.'*')
  40. ->leftJoin('orders',TABLE.'order_id','orders.id')
  41. ->LeftJoin('owners','orders.owner_id','owners.id')
  42. ->selectRaw('owners.name owner_name')
  43. ->LeftJoin('logistics','orders.logistic_id','logistics.id')
  44. ->selectRaw('logistics.name logistic_name')
  45. ->LeftJoin('paper_boxes',TABLE.'paper_box_id','paper_boxes.id')
  46. ->selectRaw('paper_boxes.model paper_box_name')
  47. ->LeftJoin('measuring_machines',TABLE.'measuring_machine_id','measuring_machines.id')
  48. ->selectRaw('measuring_machines.name measuring_machine_name')
  49. ->sql();
  50. }
  51. }