PartyController.php 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use App\Http\Requests\PartyCreateRequest;
  4. use App\Http\Requests\PartyUpdateRequest;
  5. use App\Models\Party;
  6. use Illuminate\Http\Request;
  7. use App\Http\Controllers\Controller;
  8. use App\Models\Role;
  9. class PartyController extends Controller
  10. {
  11. /**
  12. * Display a listing of the resource.
  13. *
  14. * @return \Illuminate\Http\Response
  15. */
  16. public function index()
  17. {
  18. return view('admin.party.index');
  19. }
  20. public function data(Request $request)
  21. {
  22. $res = Party::paginate($request->get('limit', 30))->toArray();
  23. $data = [
  24. 'code' => 0,
  25. 'msg' => '正在请求中...',
  26. 'count' => $res['total'],
  27. 'data' => $res['data']
  28. ];
  29. return response()->json($data);
  30. }
  31. /**
  32. * Show the form for creating a new resource.
  33. *
  34. * @return \Illuminate\Http\Response
  35. */
  36. public function create()
  37. {
  38. return view('admin.party.create')->with(['party'=>array()]);
  39. }
  40. /**
  41. * Store a newly created resource in storage.
  42. *
  43. * @param \Illuminate\Http\Request $request
  44. * @return \Illuminate\Http\Response
  45. */
  46. public function store(PartyCreateRequest $request)
  47. {
  48. $data = $request->all();
  49. var_dump($data);die;
  50. if (Party::create($data)){
  51. return redirect()->to(route('admin.party'))->with(['status'=>'添加成功']);
  52. }
  53. return redirect()->to(route('admin.party'))->withErrors('系统错误');
  54. }
  55. /**
  56. * Display the specified resource.
  57. *
  58. * @param int $id
  59. * @return \Illuminate\Http\Response
  60. */
  61. public function show($id)
  62. {
  63. //
  64. }
  65. /**
  66. * Show the form for editing the specified resource.
  67. *
  68. * @param int $id
  69. * @return \Illuminate\Http\Response
  70. */
  71. public function edit($id)
  72. {
  73. $party = Party::where('id', $id)->first();
  74. return view('admin.party.edit',compact('party'));
  75. }
  76. /**
  77. * Update the specified resource in storage.
  78. *
  79. * @param \Illuminate\Http\Request $request
  80. * @param int $id
  81. * @return \Illuminate\Http\Response
  82. */
  83. public function update(PartyUpdateRequest $request, $id)
  84. {
  85. // $party = Party::findOrFail($id);
  86. $data = $request->all();
  87. if(empty($data['key'])){
  88. unset($data['key']);
  89. }
  90. if(empty($data['secret'])){
  91. unset($data['secret']);
  92. }
  93. $party = Party::findOrFail($id);
  94. if ($party->update($data)){
  95. return redirect()->to(route('admin.party'))->with(['status'=>'更新成功']);
  96. }
  97. return redirect()->to(route('admin.party'))->withErrors('系统错误');
  98. }
  99. /**
  100. * Remove the specified resource from storage.
  101. *
  102. * @param int $id
  103. * @return \Illuminate\Http\Response
  104. */
  105. public function destroy(Request $request)
  106. {
  107. $ids = $request->get('ids');
  108. if (empty($ids)){
  109. return response()->json(['code'=>1,'msg'=>'请选择删除项']);
  110. }
  111. if (Party::destroy($ids)){
  112. return response()->json(['code'=>0,'msg'=>'删除成功']);
  113. }
  114. return response()->json(['code'=>1,'msg'=>'删除失败']);
  115. }
  116. /**
  117. * 分配角色
  118. */
  119. public function role(Request $request,$id)
  120. {
  121. $party = Party::findOrFail($id);
  122. $roles = Role::get();
  123. $hasRoles = $party->roles();
  124. foreach ($roles as $role){
  125. $role->own = $party->hasRole($role) ? true : false;
  126. }
  127. return view('admin.party.role',compact('roles','party'));
  128. }
  129. /**
  130. * 更新分配角色
  131. */
  132. public function assignRole(Request $request,$id)
  133. {
  134. $party = Party::findOrFail($id);
  135. $roles = $request->get('roles',[]);
  136. if ($party->syncRoles($roles)){
  137. return redirect()->to(route('admin.party'))->with(['status'=>'更新用户角色成功']);
  138. }
  139. return redirect()->to(route('admin.party'))->withErrors('系统错误');
  140. }
  141. /**
  142. * 分配权限
  143. */
  144. public function permission(Request $request,$id)
  145. {
  146. $party = Party::findOrFail($id);
  147. $permissions = $this->tree();
  148. foreach ($permissions as $key1 => $item1){
  149. $permissions[$key1]['own'] = $party->hasDirectPermission($item1['id']) ? 'checked' : false ;
  150. if (isset($item1['_child'])){
  151. foreach ($item1['_child'] as $key2 => $item2){
  152. $permissions[$key1]['_child'][$key2]['own'] = $party->hasDirectPermission($item2['id']) ? 'checked' : false ;
  153. if (isset($item2['_child'])){
  154. foreach ($item2['_child'] as $key3 => $item3){
  155. $permissions[$key1]['_child'][$key2]['_child'][$key3]['own'] = $party->hasDirectPermission($item3['id']) ? 'checked' : false ;
  156. }
  157. }
  158. }
  159. }
  160. }
  161. return view('admin.party.permission',compact('party','permissions'));
  162. }
  163. /**
  164. * 存储权限
  165. */
  166. public function assignPermission(Request $request,$id)
  167. {
  168. $party = Party::findOrFail($id);
  169. $permissions = $request->get('permissions');
  170. if (empty($permissions)){
  171. $party->permissions()->detach();
  172. return redirect()->to(route('admin.party'))->with(['status'=>'已更新用户直接权限']);
  173. }
  174. $party->syncPermissions($permissions);
  175. return redirect()->to(route('admin.party'))->with(['status'=>'已更新用户直接权限']);
  176. }
  177. }