OwnerController.php 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Authority;
  4. use App\Components\AsyncResponse;
  5. use App\Events\CustomerStored;
  6. use App\Owner;
  7. use Exception;
  8. use Illuminate\Http\Request;
  9. use Illuminate\Http\Response;
  10. use Illuminate\Support\Facades\Auth;
  11. use Illuminate\Support\Facades\Gate;
  12. use Illuminate\Support\Facades\Validator;
  13. class OwnerController extends Controller
  14. {
  15. use AsyncResponse;
  16. /**
  17. * Display a listing of the resource.
  18. *
  19. * @param Request $request
  20. *
  21. * @return Response
  22. */
  23. public function index(Request $request)
  24. {
  25. if (!Gate::allows('货主-查询')) {
  26. return redirect(url('/'));
  27. }
  28. $query = Owner::query()
  29. ->orderBy('id', 'desc')
  30. ->whereNull('deleted_at');
  31. if ($request->has('name')) {
  32. $query->where('name', 'like', $request->name . '%');
  33. }
  34. if ($request->has('code')) {
  35. $query->where('code', 'like', $request->code . '%');
  36. }
  37. $owners = $query->paginate($request->paginate);
  38. return view('maintenance.owner.index', ['owners' => $owners]);
  39. }
  40. public function create()
  41. {
  42. if (!Gate::allows('货主-录入')) {
  43. return redirect(url('/'));
  44. }
  45. return view('maintenance.owner.create');
  46. }
  47. public function store(Request $request)
  48. {
  49. if (!Gate::allows('货主-录入')) {
  50. return redirect(url('/'));
  51. }
  52. $this->validatorCreate($request->all())->validate();
  53. $owner = new Owner($request->all());
  54. $owner->save();
  55. // event(new CustomerStoreEvent($owner));
  56. event(new CustomerStored($owner));
  57. $authority = new Authority([
  58. 'name' => "_{$owner['id']}",
  59. 'alias_name' => "(货主:{$owner['name']})",
  60. 'remark' => "(key: _{$owner['id']})",
  61. ]);
  62. $authority->save();
  63. app('LogService')->log(__METHOD__, __FUNCTION__, json_encode($request->toArray()), Auth::user()['id']);
  64. return redirect('maintenance/owner/create')->with('successTip', $request->input('name') ?? '');
  65. }
  66. public function apiStore()
  67. {
  68. $this->gate("货主-录入");
  69. if (request("id"))$errors = $this->validatorUpdate(request()->input(),request("id"))->errors();
  70. else $errors = $this->validatorCreate(request()->input())->errors();
  71. if (count($errors)>0)$this->success(["errors"=>$errors]);
  72. if (request("id")){
  73. $owner = app("OwnerService")->find(request("id"));
  74. if (!$owner)$this->error("项目已被删除");
  75. if ($owner->name == request("name") && $owner->code == request("code"))
  76. $this->success($owner);
  77. $owner = app("OwnerService")->update($owner,[
  78. "name" => request("name"),
  79. "code" => request("code"),
  80. ]);
  81. }else $owner = app("OwnerService")->create([
  82. "name" => request("name"),
  83. "code" => request("code"),
  84. ]);
  85. $this->success($owner);
  86. }
  87. protected function validatorCreate(array $data)
  88. {
  89. return Validator::make($data, [
  90. 'code' => ['required', 'string', 'max:50', "unique:owners,code"],
  91. 'name' => ['required', 'string', 'max:50'],
  92. ],[],[
  93. "code" => "货主代码",
  94. "name" => "货主名称",
  95. ]);
  96. }
  97. protected function validatorUpdate(array $data, $id)
  98. {
  99. return Validator::make($data, [
  100. 'name' => ['required', 'string', 'max:50'],
  101. 'code' => ['required', 'string', 'max:50', "unique:owners,code,$id"]
  102. ],[],[
  103. "code" => "货主代码",
  104. "name" => "货主名称",
  105. ]);
  106. }
  107. public function getOwners()
  108. {
  109. $owners = app('OwnerService')->getIntersectPermitting(['id', 'code', 'name']);
  110. return $owners;
  111. }
  112. /**
  113. * Show the form for editing the specified resource.
  114. *
  115. * @param Owner $owner
  116. * @return Response
  117. */
  118. public function edit(Owner $owner)
  119. {
  120. if (!Gate::allows('货主-编辑')) {
  121. return redirect(url('/'));
  122. }
  123. return view('maintenance.owner.edit', ['owner' => $owner]);
  124. }
  125. /**
  126. * Update the specified resource in storage.
  127. *
  128. * @param Request $request
  129. * @param Owner $owner
  130. *
  131. * @return Response
  132. *
  133. * @throws Exception
  134. */
  135. public function update(Request $request, Owner $owner)
  136. {
  137. if (!Gate::allows('货主-编辑')) {
  138. return redirect(url('/'));
  139. }
  140. $this->validatorUpdate($request->all(), $owner->id)->validate();
  141. $owner->fill($request->all());
  142. $owner->update();
  143. event(new CustomerStored($owner));
  144. app('LogService')->log(__METHOD__, __FUNCTION__, json_encode($request->toArray()), Auth::user()['id']);
  145. return redirect('maintenance/owner/')->with('successTip', "成功修改货主{$owner['name']}!");
  146. }
  147. /**
  148. * Remove the specified resource from storage.
  149. *
  150. * @param Owner $owner
  151. * @return array|Response
  152. * @throws Exception
  153. */
  154. public function destroy(Owner $owner)
  155. {
  156. if (!Gate::allows('货主-删除')) {
  157. return redirect(url('/'));
  158. }
  159. $re = $owner->update([
  160. "deleted_at" => date('Y-m-d H:i:s'),
  161. ]);
  162. app("OwnerService")->deleteAuthority($owner);
  163. app('LogService')->log(__METHOD__, __FUNCTION__, $owner->toJson(), Auth::user()['id']);
  164. return ['success' => $re];
  165. }
  166. public function recycle()
  167. {
  168. if (!Gate::allows('货主-删除')) {
  169. return redirect(url('/'));
  170. }
  171. $owners = Owner::query()->orderBy('id', 'desc')->whereNotNull('deleted_at')->paginate(25);
  172. return view('maintenance.owner.recycle', ['owners' => $owners]);
  173. }
  174. public function restoreSelected(Request $request)
  175. {
  176. if (!Gate::allows('货主-删除')) {
  177. return ['success' => 'false', 'fail_info' => "没有权限"];
  178. }
  179. $id = $request->input('id');
  180. $owner = Owner::query()->whereNotNull('deleted_at')->where('id', $id)->first();
  181. $owner->update(["deleted_at" => null]);
  182. app("OwnerService")->createAuthority($owner);
  183. app('LogService')->log(__METHOD__, __FUNCTION__, json_encode($request->toArray()), Auth::user()['id']);
  184. return ['success' => 'true', 'owner' => $owner];
  185. }
  186. public function get(Request $request)
  187. {
  188. $params = [];
  189. if ($request->has("customer_id"))$params["customer_id"] = $request->input("customer_id");
  190. return ["success"=>true,"data"=>app("OwnerService")->get($params,null,false)];
  191. }
  192. }