| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152 |
- <?php
- namespace App\Services;
- use App\OrderPackage;
- use App\Services\common\QueryService;
- use Illuminate\Http\Request;
- const TABLE = "order_packages.";
- Class PackageService
- {
- private function conditionQuery($params){
- $packages = OrderPackage::query()->with(['order'=>function($query){
- $query->with('owner','logistic');
- },'paperBox','measuringMachine'])->orderBy(TABLE.'id','DESC');
- $columnQueryRules=[
- 'logistic_number' => ['like' => ''],
- 'batch_number' => ['like' => ''],
- 'created_at_start' => ['alias' => 'created_at','startDate' => " 00:00:00"],
- 'created_at_end' => ['alias' => 'created_at','endDate' => " 23:59:59"],
- 'id' => ['multi' => ','],
- ];
- $packages = app(QueryService::class)->query($params,$packages,$columnQueryRules,"order_packages");
- return $packages;
- }
- public function paginate(Request $request){
- $packages = $this->conditionQuery($request->input());
- return $packages->paginate($request->paginate ?? 50);
- }
- public function get(Request $request){
- $packages = $this->conditionQuery($request->input());
- return $packages->get();
- }
- public function getSql($params){
- return $this->conditionQuery($params)->selectRaw(TABLE.'*')
- ->leftJoin('orders',TABLE.'order_id','orders.id')
- ->LeftJoin('owners','orders.owner_id','owners.id')
- ->selectRaw('owners.name owner_name')
- ->LeftJoin('logistics','orders.logistic_id','logistics.id')
- ->selectRaw('logistics.name logistic_name')
- ->LeftJoin('paper_boxes',TABLE.'paper_box_id','paper_boxes.id')
- ->selectRaw('paper_boxes.model paper_box_name')
- ->LeftJoin('measuring_machines',TABLE.'measuring_machine_id','measuring_machines.id')
- ->selectRaw('measuring_machines.name measuring_machine_name')
- ->sql();
- }
- }
|