Menu.php 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. <?php
  2. /**
  3. * User: nickbai
  4. * Date: 2017/10/23 13:33
  5. * Email: 1902822973@qq.com
  6. */
  7. namespace app\admin\controller;
  8. class Menu extends Base
  9. {
  10. // 菜单列表
  11. public function index()
  12. {
  13. // $token = 'NzgyNTUwIyRAJSFeKi8xNTYxNTQwMzQzLzE=';
  14. // $res = model('Admins')->checktoken($token);
  15. // if($res == -1){
  16. // return $res;
  17. // }
  18. // $admin_id = explode('/',base64_decode($token))['2'];
  19. // $adminInfo = db('admins')->where('id', $admin_id)->find();
  20. if (request()->isAjax()) {
  21. $param = input('param.');
  22. $limit = $param['pageSize'];
  23. $offset = ($param['pageNumber'] - 1) * $limit;
  24. $result = db('menu')->limit($offset, $limit)->select();
  25. //一级菜单
  26. $pmenu = db('menu')->where('p_id',0)->select();
  27. foreach ($result as $key => $vo) {
  28. //$vo['p_menu'] == '11';
  29. for($i=0;$i<count($pmenu);$i++){
  30. if($result[$key]['p_id'] == $pmenu[$i]['id']){
  31. $result[$key]['p_menu'] = $pmenu[$i]['name_cn'];
  32. }
  33. }
  34. // 生成操作按钮
  35. if (0 != $vo['id']) {
  36. $result[$key]['operate'] = $this->makeBtn($vo['id']);
  37. }
  38. }
  39. $return['total'] = db('menu')->count(); //总数据
  40. $return['rows'] = $result;
  41. return json($return);
  42. }
  43. return $this->fetch();
  44. }
  45. // 添加菜单
  46. public function add()
  47. {
  48. if (request()->isPost()) {
  49. $param = input('post.');
  50. $has = db('menu')->where('name_cn', $param['name'])->find();
  51. if (!empty($has)) {
  52. return json(['code' => -1, 'data' => '', 'msg' => '该菜单已经存在']);
  53. }
  54. if($param['p_id'] == -1){
  55. return json(['code' => -2, 'data' => '', 'msg' => '请选择父级菜单']);
  56. }
  57. $info = array();
  58. $info['name_cn'] = $param['name'];
  59. $info['p_id'] = $param['p_id'];
  60. $info['sort'] = $param['sort'];
  61. if($param['p_id'] == 0){
  62. $info['ico'] = $param['ico'];
  63. }else{
  64. $info['url'] = $param['url'];
  65. }
  66. try {
  67. db('menu')->insert($info);
  68. } catch (\Exception $e) {
  69. return json(['code' => -3, 'data' => '', 'msg' => $e->getMessage()]);
  70. }
  71. return json(['code' => 1, 'data' => '', 'msg' => '添加菜单成功']);
  72. }
  73. $pmenu = db('menu')->where('p_id',0)->select();
  74. $this->assign([
  75. 'pmenu' => $pmenu,
  76. 'status' => config('kf_status')
  77. ]);
  78. return $this->fetch();
  79. }
  80. // 编辑菜单
  81. public function edit()
  82. {
  83. // 菜单id
  84. $id = input('param.id/d');
  85. if (request()->isAjax()) {
  86. $param = input('post.');
  87. $param['name_cn'] = $param['name'];
  88. $info = array();
  89. $info['name_cn'] = $param['name'];
  90. if(!empty($param['p_id'])){
  91. $info['p_id'] = $param['p_id'];
  92. }
  93. if(!empty($param['url'])){
  94. $info['url'] = $param['url'];
  95. }
  96. if(!empty($param['ico'])){
  97. $info['ico'] = $param['ico'];
  98. }
  99. $info['sort'] = $param['sort'];
  100. try {
  101. db('menu')->where('id', $param['id'])->update($info);
  102. } catch (\Exception $e) {
  103. return json(['code' => -2, 'data' => '', 'msg' => $e->getMessage()]);
  104. }
  105. return json(['code' => 1, 'data' => '', 'msg' => '编辑菜单成功']);
  106. }
  107. $menu = db('menu')->where('id',$id)->find();
  108. $pmenu = db('menu')->where('p_id',0)->select();
  109. $this->assign([
  110. 'menu' => $menu,
  111. 'pmenu' => $pmenu,
  112. 'id' => $id,
  113. 'status' => config('kf_status')
  114. ]);
  115. return $this->fetch();
  116. }
  117. // 删除菜单
  118. public function delMenu()
  119. {
  120. if (request()->isAjax()) {
  121. //菜单id
  122. $id = input('param.id/d');
  123. $menu = db('menu')->where('id', $id)->find();
  124. try {
  125. if($menu['p_id'] == 0){
  126. //父级菜单下的子集菜单id
  127. $menus = db('menu')->where('p_id', $id)->select();
  128. for($i=0;$i<count($menus);$i++){
  129. $ids[] = $menus[$i]['id'];
  130. }
  131. $ids = implode(",",$ids) ;
  132. //删除父级菜单下的子集菜单
  133. db('menu')->where('p_id', $id)->delete();
  134. db('admingrouppower')->where('menu_id', $ids)->delete();
  135. }
  136. db('menu')->where('id', $id)->delete();
  137. db('admingrouppower')->where('menu_id', $id)->delete();
  138. } catch (\Exception $e) {
  139. return json(['code' => -1, 'data' => '', 'msg' => $e->getMessage()]);
  140. }
  141. return json(['code' => 1, 'data' => '', 'msg' => '删除菜单成功']);
  142. }
  143. }
  144. // 生成菜单操作按钮
  145. private function makeBtn($id)
  146. {
  147. $operate = '<a href="' . url('menu/edit', ['id' => $id]) . '">';
  148. $operate .= '<button type="button" class="btn btn-primary btn-sm"><i class="fa fa-paste"></i> 编辑</button></a> ';
  149. $operate .= '<a href="javascript:menuDel(' . $id . ')"><button type="button" class="btn btn-danger btn-sm">';
  150. $operate .= '<i class="fa fa-trash-o"></i> 删除</button></a> ';
  151. return $operate;
  152. }
  153. }