OwnerController.php 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Authority;
  4. use App\Components\AsyncResponse;
  5. use App\Events\CustomerStored;
  6. use App\Log;
  7. use App\Logistic;
  8. use App\Owner;
  9. use Exception;
  10. use Illuminate\Http\Request;
  11. use Illuminate\Http\Response;
  12. use Illuminate\Support\Facades\Auth;
  13. use Illuminate\Support\Facades\Gate;
  14. use Illuminate\Support\Facades\Validator;
  15. class OwnerController extends Controller
  16. {
  17. use AsyncResponse;
  18. /**
  19. * Display a listing of the resource.
  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. * @return Response
  131. */
  132. public function update(Request $request, Owner $owner)
  133. {
  134. if (!Gate::allows('货主-编辑')) {
  135. return redirect(url('/'));
  136. }
  137. $this->validatorUpdate($request->all(), $owner->id)->validate();
  138. $owner->fill($request->all());
  139. $owner->update();
  140. event(new CustomerStored($owner));
  141. app('LogService')->log(__METHOD__, __FUNCTION__, json_encode($request->toArray()), Auth::user()['id']);
  142. return redirect('maintenance/owner/')->with('successTip', "成功修改货主{$owner['name']}!");
  143. }
  144. /**
  145. * Remove the specified resource from storage.
  146. *
  147. * @param Owner $owner
  148. * @return array|Response
  149. * @throws Exception
  150. */
  151. public function destroy(Owner $owner)
  152. {
  153. if (!Gate::allows('货主-删除')) {
  154. return redirect(url('/'));
  155. }
  156. $re = $owner->update([
  157. "deleted_at" => date('Y-m-d H:i:s'),
  158. ]);
  159. app('LogService')->log(__METHOD__, __FUNCTION__, $owner->toJson(), Auth::user()['id']);
  160. return ['success' => $re];
  161. }
  162. public function recycle()
  163. {
  164. if (!Gate::allows('货主-删除')) {
  165. return redirect(url('/'));
  166. }
  167. $owners = Owner::query()->orderBy('id', 'desc')->whereNotNull('deleted_at')->paginate(25);
  168. return view('maintenance.owner.recycle', ['owners' => $owners]);
  169. }
  170. public function restoreSelected(Request $request)
  171. {
  172. if (!Gate::allows('货主-删除')) {
  173. return ['success' => 'false', 'fail_info' => "没有权限"];
  174. }
  175. $id = $request->input('id');
  176. $owner = Owner::query()->whereNotNull('deleted_at')->where('id', $id)->first();
  177. $owner->update(["deleted_at" => null]);
  178. app('LogService')->log(__METHOD__, __FUNCTION__, json_encode($request->toArray()), Auth::user()['id']);
  179. return ['success' => 'true', 'owner' => $owner];
  180. }
  181. public function get(Request $request)
  182. {
  183. $params = [];
  184. if ($request->has("customer_id"))$params["customer_id"] = $request->input("customer_id");
  185. return ["success"=>true,"data"=>app("OwnerService")->get($params,null,false)];
  186. }
  187. }