OwnerPriceDirectLogisticService.php 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. <?php
  2. namespace App\Services;
  3. use App\Owner;
  4. use App\OwnerPriceDirectLogistic;
  5. use App\OwnerPriceDirectLogisticCar;
  6. use Illuminate\Database\Eloquent\Builder;
  7. use Illuminate\Support\Facades\DB;
  8. use App\Traits\ServiceAppAop;
  9. class OwnerPriceDirectLogisticService
  10. {
  11. use ServiceAppAop;
  12. protected $modelClass=OwnerPriceDirectLogistic::class;
  13. public function paginate($id = null)
  14. {
  15. $query = OwnerPriceDirectLogistic::query()->with("owners");
  16. if($id)$query->where("id",$id);
  17. return $query->paginate(50);
  18. }
  19. public function create(array $params)
  20. {
  21. return OwnerPriceDirectLogistic::query()->create($params);
  22. }
  23. public function destroy($id)
  24. {
  25. OwnerPriceDirectLogisticCar::query()->where("owner_price_direct_logistic_id",$id)->delete();
  26. DB::table("owner_price_direct_logistic_owner")->where("owner_price_direct_logistic_id",$id)->delete();
  27. return OwnerPriceDirectLogistic::destroy($id);
  28. }
  29. public function find($id)
  30. {
  31. return OwnerPriceDirectLogistic::query()->find($id);
  32. }
  33. public function update(array $params, array $values)
  34. {
  35. $query = OwnerPriceDirectLogistic::query();
  36. foreach ($params as $column=>$param){
  37. $query->where($column,$param);
  38. }
  39. return $query->update($values);
  40. }
  41. public function updateDetail(array $params, array $values)
  42. {
  43. $query = OwnerPriceDirectLogisticCar::query();
  44. foreach ($params as $column => $param){
  45. $query->where($column,$param);
  46. }
  47. return $query->update($values);
  48. }
  49. public function isExistDetail(array $params)
  50. {
  51. $query = OwnerPriceDirectLogisticCar::query();
  52. foreach ($params as $column => $param){
  53. $query->where($column,$param);
  54. }
  55. return $query->count();
  56. }
  57. public function createDetail(array $params)
  58. {
  59. return OwnerPriceDirectLogisticCar::query()->create($params);
  60. }
  61. public function destroyDetail($id)
  62. {
  63. return OwnerPriceDirectLogisticCar::destroy($id);
  64. }
  65. public function getExistOwnerName($owner_id, $id) :array
  66. {
  67. if (!is_array($owner_id))$owner_id = [$owner_id];
  68. $owners = Owner::query()->withCount(["ownerPriceDirectLogistics"=>function($query)use($id){
  69. if ($id)$query->where("id","!=",$id);
  70. }])->whereIn("id",$owner_id)->get();
  71. $arr = [];
  72. foreach ($owners as $owner){
  73. if ($owner->owner_price_direct_logistics_count > 0)$arr[] = $owner->name;
  74. }
  75. return $arr;
  76. }
  77. /**
  78. * CODE: -1:未找到计费模型
  79. *
  80. * @param double $amount
  81. * @param integer $owner_id
  82. * @param integer $car_id
  83. * @return double
  84. */
  85. public function matching($amount, $owner_id, $car_id)
  86. {
  87. $model = OwnerPriceDirectLogistic::query()->with(["details"=>function($query)use($car_id){
  88. /** @var Builder $query */
  89. $query->where("car_type_id",$car_id);
  90. }])->whereHas("owners",function ($query)use($owner_id){
  91. /** @var Builder $query */
  92. $query->where("id",$owner_id);
  93. })->first();
  94. if (!$model || !$model->details)return -1;
  95. if ($amount < $model->base_km)$amount = $model->base_km;
  96. $initialMoney = $model->details[0]->base_fee;
  97. $amount -= $model->base_km;
  98. return ($amount*$model->details[0]->additional_fee)+$initialMoney;
  99. }
  100. }