OwnerController.php 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210
  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. $authority = new Authority([
  56. 'name' => "_{$owner['id']}",
  57. 'alias_name' => "(货主:{$owner['name']})",
  58. 'remark' => "(key: _{$owner['id']})",
  59. ]);
  60. $authority->save();
  61. app('LogService')->log(__METHOD__, __FUNCTION__, json_encode($request->toArray()), Auth::user()['id']);
  62. return redirect('maintenance/owner/create')->with('successTip', $request->input('name') ?? '');
  63. }
  64. public function apiStore()
  65. {
  66. $this->gate("货主-录入");
  67. if (request("id"))$errors = $this->validatorUpdate(request()->input(),request("id"))->errors();
  68. else $errors = $this->validatorCreate(request()->input())->errors();
  69. if (count($errors)>0)$this->success(["errors"=>$errors]);
  70. if (request("id")){
  71. $owner = app("OwnerService")->find(request("id"));
  72. if (!$owner)$this->error("项目已被删除");
  73. if ($owner->name == request("name") && $owner->code == request("code"))
  74. $this->success($owner);
  75. $owner = app("OwnerService")->update($owner,[
  76. "name" => request("name"),
  77. "code" => request("code"),
  78. ]);
  79. }else $owner = app("OwnerService")->create([
  80. "name" => request("name"),
  81. "code" => request("code"),
  82. ]);
  83. $this->success($owner);
  84. }
  85. protected function validatorCreate(array $data)
  86. {
  87. return Validator::make($data, [
  88. 'code' => ['required', 'string', 'max:50', "unique:owners,code"],
  89. 'name' => ['required', 'string', 'max:50'],
  90. ],[],[
  91. "code" => "货主代码",
  92. "name" => "货主名称",
  93. ]);
  94. }
  95. protected function validatorUpdate(array $data, $id)
  96. {
  97. return Validator::make($data, [
  98. 'name' => ['required', 'string', 'max:50'],
  99. 'code' => ['required', 'string', 'max:50', "unique:owners,code,$id"]
  100. ],[],[
  101. "code" => "货主代码",
  102. "name" => "货主名称",
  103. ]);
  104. }
  105. public function getOwners()
  106. {
  107. $owners = app('OwnerService')->getIntersectPermitting(['id', 'code', 'name']);
  108. return $owners;
  109. }
  110. /**
  111. * Show the form for editing the specified resource.
  112. *
  113. * @param Owner $owner
  114. * @return Response
  115. */
  116. public function edit(Owner $owner)
  117. {
  118. if (!Gate::allows('货主-编辑')) {
  119. return redirect(url('/'));
  120. }
  121. return view('maintenance.owner.edit', ['owner' => $owner]);
  122. }
  123. /**
  124. * Update the specified resource in storage.
  125. *
  126. * @param Request $request
  127. * @param Owner $owner
  128. *
  129. * @return Response
  130. *
  131. * @throws Exception
  132. */
  133. public function update(Request $request, Owner $owner)
  134. {
  135. if (!Gate::allows('货主-编辑')) {
  136. return redirect(url('/'));
  137. }
  138. $this->validatorUpdate($request->all(), $owner->id)->validate();
  139. $owner->fill($request->all());
  140. $owner->update();
  141. event(new CustomerStored($owner));
  142. app('LogService')->log(__METHOD__, __FUNCTION__, json_encode($request->toArray()), Auth::user()['id']);
  143. return redirect('maintenance/owner/')->with('successTip', "成功修改货主{$owner['name']}!");
  144. }
  145. /**
  146. * Remove the specified resource from storage.
  147. *
  148. * @param Owner $owner
  149. * @return array|Response
  150. * @throws Exception
  151. */
  152. public function destroy(Owner $owner)
  153. {
  154. if (!Gate::allows('货主-删除')) {
  155. return redirect(url('/'));
  156. }
  157. $re = $owner->update([
  158. "deleted_at" => date('Y-m-d H:i:s'),
  159. ]);
  160. app("OwnerService")->deleteAuthority($owner);
  161. app('LogService')->log(__METHOD__, __FUNCTION__, $owner->toJson(), Auth::user()['id']);
  162. return ['success' => $re];
  163. }
  164. public function recycle()
  165. {
  166. if (!Gate::allows('货主-删除')) {
  167. return redirect(url('/'));
  168. }
  169. $owners = Owner::query()->orderBy('id', 'desc')->whereNotNull('deleted_at')->paginate(25);
  170. return view('maintenance.owner.recycle', ['owners' => $owners]);
  171. }
  172. public function restoreSelected(Request $request)
  173. {
  174. if (!Gate::allows('货主-删除')) {
  175. return ['success' => 'false', 'fail_info' => "没有权限"];
  176. }
  177. $id = $request->input('id');
  178. $owner = Owner::query()->whereNotNull('deleted_at')->where('id', $id)->first();
  179. $owner->update(["deleted_at" => null]);
  180. app("OwnerService")->createAuthority($owner);
  181. app('LogService')->log(__METHOD__, __FUNCTION__, json_encode($request->toArray()), Auth::user()['id']);
  182. return ['success' => 'true', 'owner' => $owner];
  183. }
  184. public function get(Request $request)
  185. {
  186. $params = [];
  187. if ($request->has("customer_id"))$params["customer_id"] = $request->input("customer_id");
  188. return ["success"=>true,"data"=>app("OwnerService")->get($params,null,false)];
  189. }
  190. }