CustomerBaseController.php 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  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. $params = $request->input();
  31. return response()->view('customer.customer.index',compact("customers","owners","tags","params"));
  32. }
  33. /**
  34. * Show the form for creating a new resource.
  35. *
  36. * @return Response
  37. */
  38. public function create()
  39. {
  40. if(!Gate::allows('客户-录入')){ return redirect('denied'); }
  41. return response()->view('customer.customer.create');
  42. }
  43. /**
  44. * Store a newly created resource in storage.
  45. *
  46. * @param Request $request
  47. * @return Response
  48. * @throws
  49. */
  50. public function store(Request $request)
  51. {
  52. if(!Gate::allows('客户-录入')){ return redirect('denied'); }
  53. $this->validator($request->input())->validate();
  54. app('CustomerService')->create([
  55. "code"=>$request->input("code"),
  56. "name"=>$request->input("name"),
  57. "company_name"=>$request->input("company_name"),
  58. "invoice_address"=>$request->input("invoice_address"),
  59. "contact_man"=>$request->input("contact_man"),
  60. "phone"=>$request->input("phone"),
  61. "remark"=>$request->input("remark"),
  62. ]);
  63. LogService::log(__METHOD__,"录入客户",json_encode($request->input(),JSON_UNESCAPED_UNICODE));
  64. return response()->redirectTo("customer/customer")->with("successTip","成功创建客户“".$request->input("name")."”");
  65. }
  66. /**
  67. * Show the form for editing the specified resource.
  68. *
  69. * @param int $id
  70. * @return Response
  71. */
  72. public function edit($id)
  73. {
  74. if(!Gate::allows('客户-编辑')){ return redirect('denied'); }
  75. $customer = app('CustomerService')->find($id);
  76. return response()->view('customer.customer.create',compact("customer"));
  77. }
  78. /**
  79. * Update the specified resource in storage.
  80. *
  81. * @param Request $request
  82. * @param int $id
  83. * @return Response
  84. * @throws
  85. */
  86. public function update(Request $request, $id)
  87. {
  88. if(!Gate::allows('客户-编辑')){ return redirect('denied'); }
  89. $this->validator($request->input(),$id)->validate();
  90. $result = app('CustomerService')->update(["id"=>$id],[
  91. "code"=>$request->input("code"),
  92. "name"=>$request->input("name"),
  93. "company_name"=>$request->input("company_name"),
  94. "invoice_address"=>$request->input("invoice_address"),
  95. "contact_man"=>$request->input("contact_man"),
  96. "phone"=>$request->input("phone"),
  97. "remark"=>$request->input("remark"),
  98. ]);
  99. if ($result == 1){
  100. LogService::log(__METHOD__,"修改客户",json_encode($request->input(),JSON_UNESCAPED_UNICODE));
  101. return response()->redirectTo("customer/customer")->with("successTip","成功修改客户“".$request->input("name")."”的信息");
  102. }
  103. return response()->view("exception.default",["code"=>"509"]);
  104. }
  105. /**
  106. * Remove the specified resource from storage.
  107. *
  108. * @param int $id
  109. * @return array
  110. */
  111. public function destroy($id)
  112. {
  113. if(!Gate::allows('客户-删除')){ return ["success"=>false,"data"=>"无权操作!"]; }
  114. $result = app('CustomerService')->destroy($id);
  115. if ($result == 1){
  116. LogService::log(__METHOD__,"删除客户",$id);
  117. return ["success"=>true];
  118. }
  119. return ["success"=>false,"data"=>"删除了“".$result."”行"];
  120. }
  121. private function validator(array $params, $id = null)
  122. {
  123. return Validator::make($params,[
  124. 'code'=>['required',$id?"unique:customers,code,$id":'unique:customers,code','max:20'],
  125. 'name'=>['required','max:20'],
  126. 'company_name'=>['required'],
  127. ],[
  128. 'required'=>':attribute 为必填项',
  129. 'max'=>':attribute 字符过多或输入值过大',
  130. 'unique'=>':attribute 已存在',
  131. ],[
  132. 'code'=>'客户代码',
  133. 'name'=>'客户名称',
  134. 'company_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. }