ConfigPickupNodeRepository.php 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. <?php
  2. namespace App\Repositories;
  3. use Symfony\Component\HttpKernel\Exception\HttpException;
  4. use App\Models\ConfigPickupNode;
  5. use Dingo\Api\Http\Response;
  6. use Illuminate\Support\Facades\DB;
  7. use Illuminate\Database\QueryException;
  8. class ConfigPickupNodeRepository {
  9. public function __construct(ConfigPickupNode $configPickupNode) {
  10. $this->configPickupNode = $configPickupNode;
  11. }
  12. //列表
  13. public function index($request)
  14. {
  15. $perPage = isset($request['per_page']) ? $request['per_page'] : env('PER_PAGE');
  16. $where = [];
  17. if(isset($request['id'])){
  18. $where[] = ['id', '=', $request['id']];
  19. }
  20. if(isset($request['name'])){
  21. $where[] = ['name', '=', $request['name']];
  22. }
  23. if(isset($request['city_id'])){
  24. $where[] = ['city_id', '=', $request['city_id']];
  25. }
  26. if(isset($request['status'])){
  27. $where[] = ['status', '=', $request['status']];
  28. }
  29. return $this->configPickupNode->where($where)->paginate($perPage);
  30. }
  31. /**
  32. * 添加自提点
  33. */
  34. public function create($request)
  35. {
  36. if($this->configPickupNode->where('name', trim($request['name']))->exists()){
  37. throw new HttpException(500, '该自提点已经存在');
  38. }
  39. $data = [
  40. 'name' => $request['name'],
  41. 'city_id' => $request['city_id'],
  42. 'city_name' => $request['city_name'],
  43. 'address' => $request['address'],
  44. 'work_time' => $request['work_time'],
  45. 'manager_name' => $request['manager_name']??'',
  46. 'manager_mobile' => $request['manager_mobile'],
  47. 'receive_type' => $request['receive_type'],
  48. 'longitude' => $request['longitude'],
  49. 'latitude' => $request['latitude'],
  50. 'store_ids' => $request['store_ids'],
  51. 'pickup_group_id' => $request['pickup_group_id'],
  52. 'pickup_code' => $request['pickup_code'],
  53. 'status' => $request['status']?$request['status']:0
  54. ];
  55. if (!$this->configPickupNode->create($data)) {
  56. throw new HttpException(500, '添加失败');
  57. }
  58. }
  59. public function edit($request)
  60. {
  61. $pickupNode = $this->configPickupNode->where('id', $request['id'])->first();
  62. $pickupNode->name = $request['name'];
  63. $pickupNode->city_id = $request['city_id'];
  64. $pickupNode->city_name = $request['city_name'];
  65. $pickupNode->address = $request['address'];
  66. $pickupNode->work_time = $request['work_time'];
  67. $pickupNode->manager_name = $request['manager_name']??'';
  68. $pickupNode->manager_mobile = $request['manager_mobile'];
  69. $pickupNode->receive_type = $request['receive_type'];
  70. $pickupNode->longitude = $request['longitude'];
  71. $pickupNode->latitude = $request['latitude'];
  72. $pickupNode->store_ids = $request['store_ids'];
  73. $pickupNode->pickup_group_id = $request['pickup_group_id'];
  74. $pickupNode->status = $request['status']?$request['status']:0;
  75. DB::beginTransaction();
  76. try{
  77. $res = $pickupNode->save();
  78. if($res){
  79. DB::commit();
  80. return Response::create();
  81. }
  82. DB::rollBack();
  83. return Response::create([
  84. 'message' => '编辑失败,请重试',
  85. 'status_code' => 500
  86. ]);
  87. }catch (QueryException $exception){
  88. DB::rollBack();
  89. return Response::create([
  90. 'message' => '编辑失败,请重试',
  91. 'error' => $exception->getMessage(),
  92. 'status_code' => 500
  93. ]);
  94. }
  95. }
  96. }