CustomerBaseController.php 6.2 KB

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