MenuApi.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213
  1. <?php
  2. namespace app\common\api;
  3. use app\admin\model\Role;
  4. use app\admin\model\SysRelation;
  5. use app\admin\model\Menu;
  6. /**
  7. * Description of MenuApi
  8. *
  9. * @author sgq
  10. */
  11. class MenuApi {
  12. public static function getOne($id) {
  13. $where = [];
  14. $where[] = ["t1.id", "=", $id];
  15. $where[] = ["t1.delete", "=", 0];
  16. $menu = Menu::alias("t1")->leftJoin("sys_menu t2", "t1.pcode=t2.code")->field("t1.*,if(t2.code is null,'顶级',t2.name) as pcodeName,t2.id as pid")->where($where)->findOrEmpty();
  17. return $menu;
  18. }
  19. public static function getOneByCode($code) {
  20. $where = [];
  21. $where[] = ["code", "=", $code];
  22. $where[] = ["delete", "=", 0];
  23. $menu = Menu::where($where)->findOrEmpty();
  24. return $menu;
  25. }
  26. public static function getList($params = []) {
  27. $where = [];
  28. $where[] = ["delete", "=", 0];
  29. if ($params["menuName"]) {
  30. $where[] = ["name", "like", "%" . $params["menuName"] . "%"];
  31. }
  32. if ($params["level"]) {
  33. $where[] = ["levels", "=", $params["level"]];
  34. }
  35. $list = Menu::where($where)->order("num asc")->select()->toArray();
  36. return $list;
  37. }
  38. public static function getMenuIdsByNewUrls(array $urls) {
  39. $where = [];
  40. $where[] = ["new_url", "in", $urls];
  41. $where[] = ["status", "=", 1];
  42. $where[] = ["delete", "=", 0];
  43. return Menu::where($where)->column("id");
  44. }
  45. public static function save($params) {
  46. $data["name"] = $params["name"];
  47. $data["new_url"] = $params["url"];
  48. $data["code"] = $params["code"];
  49. $data["num"] = $params["num"];
  50. $data["icon"] = $params["icon"];
  51. $data["ismenu"] = $params["ismenu"];
  52. $data["status"] = $params["status"] ?: 1;
  53. $tmp = [];
  54. $parent = self::getOne($params["pcode"]);
  55. $data["pcode"] = $parent["code"] ?: 0;
  56. $_pcodes = array_filter(explode(",", $parent["pcodes"]));
  57. $_pcodes[] = "[" . $data["pcode"] . "]";
  58. $data["pcodes"] = implode(",", $_pcodes);
  59. $data["levels"] = count($_pcodes);
  60. if ($params["id"]) {
  61. $data["id"] = $params["id"];
  62. return Menu::update($data);
  63. }
  64. return Menu::insert($data);
  65. }
  66. public static function delete($id) {
  67. $data["id"] = $id;
  68. $data["delete"] = 1;
  69. return Menu::update($data);
  70. }
  71. public static function getAllMenus($fields = "*") {
  72. $where[] = ["status", "=", 1];
  73. $where[] = ["delete", "=", 0];
  74. $menus = Menu::where($where)->field($fields)->order("levels asc,num asc")->select()->toArray();
  75. $menus = self::buildMenu($menus);
  76. return $menus;
  77. }
  78. public static function getMenuListByRoleid($roleid) {
  79. $role = Role::find($roleid);
  80. $tmp = [];
  81. if ($role) {
  82. $menu_ids = $role->sysRelation->column("menuid");
  83. $where[] = ["status", "=", 1];
  84. $where[] = ["delete", "=", 0];
  85. $where[] = ["ismenu", "=", 1];
  86. $where[] = ["new_url", "<>", ""];
  87. $where[] = ["id", "in", $menu_ids];
  88. $whr[] = ["levels", "=", 1];
  89. $menus = Menu::whereOr([$where, $whr])->order("levels asc,num asc")->select()->toArray();
  90. $menus = self::buildMenu($menus);
  91. for ($i = 0; $i < count($menus); $i++) {
  92. $menu_items_count = count($menus[$i]["children"]);
  93. $empty_url_count = 0;
  94. for ($n = 0; $n < $menu_items_count; $n++) {
  95. if ($menus[$i]["children"][$n]["new_url"] == null)
  96. $empty_url_count++;
  97. }
  98. if ($empty_url_count != $menu_items_count)
  99. $tmp[] = $menus[$i];
  100. }
  101. }
  102. return $tmp;
  103. }
  104. public static function getPrivilagesByRoleid($roleid) {
  105. $role = Role::find($roleid);
  106. $menu_ids = $role->sysRelation->column("menuid");
  107. $where[] = ["status", '=', 1];
  108. $where[] = ["delete", '=', 0];
  109. $menus = Menu::where($where)->order("levels asc,num asc")->select()->toArray();
  110. $codeToPid = [];
  111. foreach ($menus as &$menu) {
  112. $codeToPid[$menu["code"]] = $menu["id"];
  113. $menu["checked"] = in_array($menu["id"], $menu_ids) ? true : false;
  114. $menu["pid"] = isset($codeToPid[$menu["pcode"]]) ? $codeToPid[$menu["pcode"]] : 0;
  115. }unset($menu);
  116. return $menus;
  117. }
  118. /**
  119. * 递归获取多级菜单集合
  120. * @param type $menus
  121. * @param type $pcode
  122. * @return type
  123. */
  124. private static function buildMenu($menus, $pcode = "0") {
  125. $result = [];
  126. foreach ($menus as $key => $menu) {
  127. if ($pcode == $menu["pcode"]) {
  128. unset($menus[$key]);
  129. $menu["children"] = self::buildMenu($menus, $menu["code"]);
  130. if ($menu["pcode"] == 0) {
  131. $result[] = $menu;
  132. }
  133. }
  134. }
  135. return $result;
  136. }
  137. /**
  138. * 权限检查
  139. * @param type $url 新权限url
  140. * @param type $old_url 旧系统权限url
  141. * @return boolean
  142. */
  143. public static function chkPermission($url, $old_url) {
  144. $url = strtolower($url);
  145. $old_url = strtolower($old_url);
  146. $menu = Menu::whereRaw("`status`=1 and (new_url=:new_url or `url`=:url)", ["new_url" => $url, "url" => $old_url])->findOrEmpty()->toArray();
  147. if (!$menu)
  148. return true;
  149. $menuid = $menu["id"];
  150. $roleid = session("user")["roleid"];
  151. $role = Role::find($roleid);
  152. $menu_ids = $role->sysRelation->column("menuid");
  153. return in_array($menuid, $menu_ids);
  154. }
  155. public static function getEnterpriseMenuByType($type) {
  156. $menus = [];
  157. $menus[] = ["type" => [1, 2, 3], "code" => "qyzx", "pcode" => "0", "name" => "机构用户中心", "url" => "/enterprise/index/centerPage", "icon" => "fa-user", "status" => 1];
  158. $menus[] = ["type" => [1, 2], "code" => "yhfk", "pcode" => "0", "name" => "用户反馈", "url" => "", "icon" => "fa-bug", "status" => 1];
  159. $menus[] = ["type" => [1, 2], "code" => "rcrd", "pcode" => "0", "name" => "人才认定", "url" => "#", "icon" => "fa-thumbs-o-up", "status" => 1];
  160. //$menus[] = ["type" => [1, 2], "code" => "jctjsb", "pcode" => "rcrd", "name" => "基础条件申报", "url" => "/enterprise/base", "icon" => "fa-thumbs-o-up", "status" => 1];
  161. //$menus[] = ["type" => [1, 2], "code" => "rcrdsb", "pcode" => "rcrd", "name" => "人才认定申报", "url" => "/enterprise/talent", "icon" => "fa-thumbs-up", "status" => 1];
  162. $menus[] = ["type" => [1, 2], "code" => "rcrdsbnew", "pcode" => "rcrd", "name" => "人才认定申报(新)", "url" => "/enterprise/talent/index/isMix/1", "icon" => "fa-thumbs-up", "status" => 1];
  163. //$menus[] = ["type" => [1, 2], "code" => "rczrzlbc", "pcode" => "rcrd", "name" => "人才直认资料补充", "url" => "/enterprise/talent/zrIndex", "icon" => "fa-thumbs-up", "status" => 1];
  164. $menus[] = ["type" => [1, 2], "code" => "yxrck", "pcode" => "rcrd", "name" => "优秀人才库", "url" => "", "icon" => "fa-thumbs-up", "status" => 1];
  165. $menus[] = ["type" => [1, 2], "code" => "lzsb", "pcode" => "rcrd", "name" => "离职申报", "url" => "", "icon" => "fa-thumbs-up", "status" => 1];
  166. $menus[] = ["type" => [1, 2], "code" => "gzdwbg", "pcode" => "rcrd", "name" => "工作单位变更", "url" => "", "icon" => "fa-thumbs-up", "status" => 1];
  167. $menus[] = ["type" => [1, 2], "code" => "yhzhbg", "pcode" => "rcrd", "name" => "银行账号变更", "url" => "", "icon" => "fa-thumbs-up", "status" => 1];
  168. $menus[] = ["type" => [1, 2], "code" => "rcccbg", "pcode" => "rcrd", "name" => "人才层次变更", "url" => "", "icon" => "fa-thumbs-up", "status" => 1];
  169. $menus[] = ["type" => [1, 2], "code" => "jcxxbg", "pcode" => "rcrd", "name" => "基础信息变更", "url" => "", "icon" => "fa-thumbs-up", "status" => 1];
  170. $menus[] = ["type" => [1, 2], "code" => "jbtmanage", "pcode" => "0", "name" => "津补贴申报", "url" => "", "icon" => "fa-money", "status" => 0];
  171. $menus[] = ["type" => [1, 2], "code" => "jbtsb", "pcode" => "jbtmanage", "name" => "津补贴申报", "url" => "", "icon" => "fa-thumbs-up", "status" => 1];
  172. $menus[] = ["type" => [1, 2], "code" => "gfbt", "pcode" => "0", "name" => "购房补贴", "url" => "", "icon" => "fa-university", "status" => 0];
  173. $menus[] = ["type" => [1, 2], "code" => "gfbtsb", "pcode" => "gfbt", "name" => "购房补贴申报", "url" => "", "icon" => "fa-thumbs-up", "status" => 1];
  174. $menus[] = ["type" => [2], "code" => "pxbtmanage", "pcode" => "0", "name" => "培训补贴", "url" => "", "icon" => "fa-building", "status" => 1];
  175. $menus[] = ["type" => [2], "code" => "pxbt", "pcode" => "pxbtmanage", "name" => "培训补贴", "url" => "", "icon" => "fa-thumbs-up", "status" => 1];
  176. $menus[] = ["type" => [2], "code" => "zdzxmanage", "pcode" => "0", "name" => "重大专项", "url" => "", "icon" => "fa-life-ring", "status" => 1];
  177. $menus[] = ["type" => [2], "code" => "zdzx", "pcode" => "zdzxmanage", "name" => "重大专项", "url" => "", "icon" => "fa-thumbs-up", "status" => 1];
  178. $menus[] = ["type" => [2], "code" => "znjy", "pcode" => "0", "name" => "子女教育", "url" => "", "icon" => "fa-graduation-cap", "status" => 1];
  179. $menus[] = ["type" => [2], "code" => "xzfbz", "pcode" => "znjy", "name" => "学杂费补助", "url" => "", "icon" => "fa-thumbs-up", "status" => 1];
  180. $menus[] = ["type" => [2], "code" => "ylbzmanage", "pcode" => "0", "name" => "医疗补助", "url" => "", "icon" => "fa-hospital-o", "status" => 1];
  181. $menus[] = ["type" => [2], "code" => "ylbz", "pcode" => "ylbzmanage", "name" => "医疗补助", "url" => "", "icon" => "fa-thumbs-up", "status" => 1];
  182. $menus[] = ["type" => [2], "code" => "zfbz", "pcode" => "0", "name" => "住房保障", "url" => "", "icon" => "fa-home", "status" => 1];
  183. $menus[] = ["type" => [2], "code" => "zfsq", "pcode" => "zfbz", "name" => "租房申请", "url" => "", "icon" => "fa-home", "status" => 1];
  184. $menus[] = ["type" => [2], "code" => "fzbz", "pcode" => "zfbz", "name" => "房租补助", "url" => "", "icon" => "fa-money", "status" => 1];
  185. $menus[] = ["type" => [2], "code" => "gfsq", "pcode" => "zfbz", "name" => "购房申请", "url" => "", "icon" => "fa-envira", "status" => 1];
  186. $menus[] = ["type" => [2], "code" => "gfbz", "pcode" => "zfbz", "name" => "购房补助", "url" => "", "icon" => "fa-envira", "status" => 1];
  187. $menus[] = ["type" => [1], "code" => "sbrc", "pcode" => "0", "name" => "硕博人才", "url" => "", "icon" => "fa-graduation-cap", "status" => 0];
  188. $menus[] = ["type" => [1], "code" => "shbt", "pcode" => "sbrc", "name" => "生活补贴", "url" => "", "icon" => "fa-graduation-cap", "status" => 1];
  189. $menus[] = ["type" => [3], "code" => "hxjh", "pcode" => "0", "name" => "海峡计划", "url" => "", "icon" => "fa-plane", "status" => 1];
  190. $menus[] = ["type" => [3], "code" => "hxjhsb", "pcode" => "hxjh", "name" => "海峡计划申报", "url" => "", "icon" => "fa-pencil", "status" => 1];
  191. foreach ($menus as $key => $menu) {
  192. if (!in_array($type, $menu["type"]) || ($menu["pcode"]) != "0" && $menu["url"] == "" || $menu["status"] == 0)
  193. unset($menus[$key]);
  194. }
  195. return self::buildMenu($menus);
  196. }
  197. }