CustomerBaseController.php 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Components\SyncResponse;
  4. use App\Customer;
  5. use App\CustomerLog;
  6. use App\CustomerTag;
  7. use App\Owner;
  8. use App\Services\LogService;
  9. use Illuminate\Database\Eloquent\Builder;
  10. use Illuminate\Http\Request;
  11. use Illuminate\Http\Response;
  12. use Illuminate\Support\Facades\DB;
  13. use Illuminate\Support\Facades\Gate;
  14. use Illuminate\Support\Facades\Validator;
  15. class CustomerBaseController extends Controller
  16. {
  17. use SyncResponse;
  18. /**
  19. * Display a listing of the resource.
  20. *
  21. * @param Request $request
  22. * @return Response
  23. */
  24. public function index(Request $request)
  25. {
  26. $this->gate("客户-查询");
  27. $customers = app('CustomerService')->paginate($request->input(),["owners.contracts.files","tags:id,name","customerLogs"=>function($query){
  28. /** @var Builder $query */
  29. $query->with(["status:id,name,created_at","user:id,name"])->orderByDesc('id');
  30. }]);
  31. $owners = app("OwnerService")->getIntersectPermitting(['id','name','customer_id']);
  32. $tags = CustomerTag::query()->orderByDesc('count')->get(["id","name"]);
  33. return response()->view('customer.customer.index',compact("customers","owners","tags"));
  34. }
  35. /**
  36. * Show the form for creating a new resource.
  37. *
  38. * @return Response
  39. */
  40. public function create()
  41. {
  42. if(!Gate::allows('客户-录入')){ return redirect('denied'); }
  43. return response()->view('customer.customer.create');
  44. }
  45. /**
  46. * Store a newly created resource in storage.
  47. *
  48. * @param Request $request
  49. * @return Response
  50. * @throws
  51. */
  52. public function store(Request $request)
  53. {
  54. if(!Gate::allows('客户-录入')){ return redirect('denied'); }
  55. $this->validator($request->input())->validate();
  56. app('CustomerService')->create([
  57. "code"=>$request->input("code"),
  58. "name"=>$request->input("name"),
  59. "company_name"=>$request->input("company_name"),
  60. "invoice_address"=>$request->input("invoice_address"),
  61. "contact_man"=>$request->input("contact_man"),
  62. "phone"=>$request->input("phone"),
  63. "remark"=>$request->input("remark"),
  64. ]);
  65. LogService::log(__METHOD__,"录入客户",json_encode($request->input(),JSON_UNESCAPED_UNICODE));
  66. return response()->redirectTo("customer/customer")->with("successTip","成功创建客户“".$request->input("name")."”");
  67. }
  68. /**
  69. * Show the form for editing the specified resource.
  70. *
  71. * @param int $id
  72. * @return Response
  73. */
  74. public function edit($id)
  75. {
  76. if(!Gate::allows('客户-编辑')){ return redirect('denied'); }
  77. $customer = app('CustomerService')->find($id);
  78. return response()->view('customer.customer.create',compact("customer"));
  79. }
  80. /**
  81. * Update the specified resource in storage.
  82. *
  83. * @param Request $request
  84. * @param int $id
  85. * @return Response
  86. * @throws
  87. */
  88. public function update(Request $request, $id)
  89. {
  90. if(!Gate::allows('客户-编辑')){ return redirect('denied'); }
  91. $this->validator($request->input(),$id)->validate();
  92. $result = app('CustomerService')->update(["id"=>$id],[
  93. "code"=>$request->input("code"),
  94. "name"=>$request->input("name"),
  95. "company_name"=>$request->input("company_name"),
  96. "invoice_address"=>$request->input("invoice_address"),
  97. "contact_man"=>$request->input("contact_man"),
  98. "phone"=>$request->input("phone"),
  99. "remark"=>$request->input("remark"),
  100. ]);
  101. if ($result == 1){
  102. LogService::log(__METHOD__,"修改客户",json_encode($request->input(),JSON_UNESCAPED_UNICODE));
  103. return response()->redirectTo("customer/customer")->with("successTip","成功修改客户“".$request->input("name")."”的信息");
  104. }
  105. return response()->view("exception.default",["code"=>"509"]);
  106. }
  107. /**
  108. * Remove the specified resource from storage.
  109. *
  110. * @param int $id
  111. * @return array
  112. */
  113. public function destroy($id)
  114. {
  115. if(!Gate::allows('客户-删除')){ return ["success"=>false,"data"=>"无权操作!"]; }
  116. $result = app('CustomerService')->destroy($id);
  117. if ($result == 1){
  118. LogService::log(__METHOD__,"删除客户",$id);
  119. return ["success"=>true];
  120. }
  121. return ["success"=>false,"data"=>"删除了“".$result."”行"];
  122. }
  123. private function validator(array $params, $id = null)
  124. {
  125. return Validator::make($params,[
  126. 'code'=>['required',$id?"unique:customers,code,$id":'unique:customers,code','max:20'],
  127. 'name'=>['required','max:20'],
  128. ],[
  129. 'required'=>':attribute 为必填项',
  130. 'max'=>':attribute 字符过多或输入值过大',
  131. 'unique'=>':attribute 已存在',
  132. ],[
  133. 'code'=>'客户代码',
  134. 'name'=>'客户名称',
  135. ]);
  136. }
  137. public function relatedOwner(Request $request)
  138. {
  139. $ids = $request->input("ids") ?? [];
  140. $id = $request->input("customer_id");
  141. $row = Owner::query()->whereIn("id",$ids)->update(["customer_id"=>$id]);
  142. if ($row==count($ids))return ["success"=>true];
  143. return ["success"=>false,"data"=>"修改错误,影响了“".$row."”个项目"];
  144. }
  145. public function addTag(Request $request)
  146. {
  147. $tag = $request->input("tag");
  148. $id = $request->input("id");
  149. DB::transaction(function ()use ($id,$tag){
  150. DB::insert(DB::raw("INSERT INTO customer_tag_customer VALUES (?,?)"),[$id,$tag]);
  151. CustomerTag::query()->where("id",$tag)->increment("count");
  152. DB::commit();
  153. });
  154. return ["success"=>true];
  155. }
  156. public function delTag(Request $request)
  157. {
  158. $tag = $request->input("tag");
  159. $id = $request->input("id");
  160. DB::delete(DB::raw("DELETE FROM customer_tag_customer WHERE customer_id = ? AND customer_tag_id = ?"),[$id,$tag]);
  161. return ["success"=>true];
  162. }
  163. public function destroyLog(Request $request)
  164. {
  165. CustomerLog::destroy($request->input("id"));
  166. return ["success"=>true];
  167. }
  168. }