OwnerController.php 7.1 KB

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