PackageService.php 3.1 KB

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