OwnerPriceDirectLogisticService.php 3.3 KB

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