MenuApi.php 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250
  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 getMenuIdsByCodes(array $codes) {
  46. $where = [];
  47. $where[] = ["code", "in", $codes];
  48. $where[] = ["status", "=", 1];
  49. $where[] = ["delete", "=", 0];
  50. return Menu::where($where)->column("id");
  51. }
  52. public static function save($params) {
  53. $data["name"] = $params["name"];
  54. $data["new_url"] = $params["url"];
  55. $data["code"] = $params["code"];
  56. $data["num"] = $params["num"];
  57. $data["icon"] = $params["icon"];
  58. $data["ismenu"] = $params["ismenu"];
  59. $data["status"] = $params["status"] ?: 1;
  60. $tmp = [];
  61. $parent = self::getOne($params["pcode"]);
  62. $data["pcode"] = $parent["code"] ?: 0;
  63. $_pcodes = array_filter(explode(",", $parent["pcodes"]));
  64. $_pcodes[] = "[" . $data["pcode"] . "]";
  65. $data["pcodes"] = implode(",", $_pcodes);
  66. $data["levels"] = count($_pcodes);
  67. if ($params["id"]) {
  68. $data["id"] = $params["id"];
  69. return Menu::update($data);
  70. }
  71. return Menu::insert($data);
  72. }
  73. public static function delete($id) {
  74. $data["id"] = $id;
  75. $data["delete"] = 1;
  76. return Menu::update($data);
  77. }
  78. public static function getAllMenus($fields = "*") {
  79. $where[] = ["status", "=", 1];
  80. $where[] = ["delete", "=", 0];
  81. $menus = Menu::where($where)->field($fields)->order("levels asc,num asc")->select()->toArray();
  82. $menus = self::buildMenu($menus);
  83. return $menus;
  84. }
  85. public static function getMenuListByRoleid($roleid) {
  86. $roleids = explode(",", $roleid);
  87. $tmpArray = [];
  88. foreach ($roleids as $roleid) {
  89. $role = Role::find($roleid);
  90. $menu_ids = $role->sysRelation->column("menuid");
  91. $tmpArray = array_merge((array) $tmpArray, (array) $menu_ids);
  92. }
  93. $tmp = [];
  94. if ($tmpArray) {
  95. $where[] = ["status", "=", 1];
  96. $where[] = ["delete", "=", 0];
  97. $where[] = ["ismenu", "=", 1];
  98. $where[] = ["new_url", "<>", ""];
  99. $where[] = ["id", "in", $tmpArray];
  100. $whr[] = ["levels", "=", 1];
  101. $menus = Menu::whereOr([$where, $whr])->order("levels asc,num asc")->select()->toArray();
  102. $menus = self::buildMenu($menus);
  103. for ($i = 0; $i < count($menus); $i++) {
  104. $menu_items_count = count($menus[$i]["children"]);
  105. $empty_url_count = 0;
  106. for ($n = 0; $n < $menu_items_count; $n++) {
  107. if ($menus[$i]["children"][$n]["new_url"] == null)
  108. $empty_url_count++;
  109. }
  110. if ($empty_url_count != $menu_items_count)
  111. $tmp[] = $menus[$i];
  112. }
  113. }
  114. return $tmp;
  115. }
  116. public static function getCodesByRoleId($roleid) {
  117. $roleids = explode(",", $roleid);
  118. $tmpArray = [];
  119. foreach ($roleids as $roleid) {
  120. $role = Role::find($roleid);
  121. $menu_ids = $role->sysRelation->column("menuid");
  122. $tmpArray = array_merge((array) $tmpArray, (array) $menu_ids);
  123. }
  124. $codes = [];
  125. if ($tmpArray) {
  126. $where[] = ["status", "=", 1];
  127. $where[] = ["delete", "=", 0];
  128. $where[] = ["id", "in", array_unique($tmpArray)];
  129. $codes = Menu::where($where)->column("code");
  130. }
  131. return $codes;
  132. }
  133. public static function getPrivilagesByRoleid($roleid) {
  134. $role = Role::find($roleid);
  135. $menu_ids = $role->sysRelation->column("menuid");
  136. $where[] = ["status", '=', 1];
  137. $where[] = ["delete", '=', 0];
  138. $menus = Menu::where($where)->order("levels asc,num asc")->select()->toArray();
  139. $codeToPid = [];
  140. foreach ($menus as &$menu) {
  141. $codeToPid[$menu["code"]] = $menu["id"];
  142. $menu["checked"] = in_array($menu["id"], $menu_ids) ? true : false;
  143. $menu["pid"] = isset($codeToPid[$menu["pcode"]]) ? $codeToPid[$menu["pcode"]] : 0;
  144. }unset($menu);
  145. return $menus;
  146. }
  147. /**
  148. * 递归获取多级菜单集合
  149. * @param type $menus
  150. * @param type $pcode
  151. * @return type
  152. */
  153. private static function buildMenu($menus, $pcode = "0") {
  154. $result = [];
  155. foreach ($menus as $key => $menu) {
  156. if ($pcode == $menu["pcode"]) {
  157. unset($menus[$key]);
  158. $menu["children"] = self::buildMenu($menus, $menu["code"]);
  159. if ($menu["pcode"] == 0) {
  160. $result[] = $menu;
  161. }
  162. }
  163. }
  164. return $result;
  165. }
  166. /**
  167. * 权限检查
  168. * @param type $url 新权限url
  169. * @param type $old_url 旧系统权限url
  170. * @return boolean
  171. */
  172. public static function chkPermission($url, $old_url) {
  173. $url = strtolower($url);
  174. $old_url = strtolower($old_url);
  175. $menu = Menu::whereRaw("`status`=1 and (new_url=:new_url or `url`=:url)", ["new_url" => $url, "url" => $old_url])->findOrEmpty()->toArray();
  176. if (!$menu)
  177. return true;
  178. $menuid = $menu["id"];
  179. $roleids = explode(",", session("user")["roleid"]);
  180. $tmpArray = [];
  181. foreach ($roleids as $roleid) {
  182. $role = Role::find($roleid);
  183. $menu_ids = $role->sysRelation->column("menuid");
  184. $tmpArray = array_merge((array) $tmpArray, (array) $menu_ids);
  185. }
  186. return in_array($menuid, $tmpArray);
  187. }
  188. public static function getEnterpriseMenuByType($type) {
  189. $menus = [];
  190. $menus[] = ["type" => [1, 2, 3], "code" => "qyzx", "pcode" => "0", "name" => "机构用户中心", "url" => "/enterprise/index/centerPage", "icon" => "fa-user", "status" => 1];
  191. $menus[] = ["type" => [1, 2], "code" => "yhfk", "pcode" => "0", "name" => "用户反馈", "url" => "", "icon" => "fa-bug", "status" => 1];
  192. $menus[] = ["type" => [1, 2], "code" => "rcrd", "pcode" => "0", "name" => "人才认定", "url" => "#", "icon" => "fa-pencil-square-o", "status" => 1];
  193. //$menus[] = ["type" => [1, 2], "code" => "jctjsb", "pcode" => "rcrd", "name" => "基础条件申报", "url" => "/enterprise/base", "icon" => "fa-thumbs-o-up", "status" => 1];
  194. //$menus[] = ["type" => [1, 2], "code" => "rcrdsb", "pcode" => "rcrd", "name" => "人才认定申报", "url" => "/enterprise/talent", "icon" => "fa-thumbs-up", "status" => 1];
  195. $menus[] = ["type" => [1, 2], "code" => "rcrdsbnew", "pcode" => "rcrd", "name" => "人才认定申报(新)", "url" => "/enterprise/talent/index/isMix/1", "icon" => "fa-thumbs-up", "status" => 1];
  196. //$menus[] = ["type" => [1, 2], "code" => "rczrzlbc", "pcode" => "rcrd", "name" => "人才直认资料补充", "url" => "/enterprise/talent/zrIndex", "icon" => "fa-thumbs-up", "status" => 1];
  197. $menus[] = ["type" => [2], "code" => "jfsb", "pcode" => "rcrd", "name" => "积分申报", "url" => "/enterprise/integral/index", "icon" => "fa-credit-card", "status" => 1];
  198. $menus[] = ["type" => [1, 2], "code" => "yxrck", "pcode" => "rcrd", "name" => "优秀人才库", "url" => "", "icon" => "fa-thumbs-up", "status" => 1];
  199. $menus[] = ["type" => [1, 2], "code" => "lzsb", "pcode" => "rcrd", "name" => "离职申报", "url" => "", "icon" => "fa-thumbs-up", "status" => 1];
  200. $menus[] = ["type" => [1, 2], "code" => "gzdwbg", "pcode" => "rcrd", "name" => "工作单位变更", "url" => "", "icon" => "fa-thumbs-up", "status" => 1];
  201. $menus[] = ["type" => [1, 2], "code" => "yhzhbg", "pcode" => "rcrd", "name" => "银行账号变更", "url" => "", "icon" => "fa-thumbs-up", "status" => 1];
  202. $menus[] = ["type" => [1, 2], "code" => "rcccbg", "pcode" => "rcrd", "name" => "人才层次变更", "url" => "", "icon" => "fa-thumbs-up", "status" => 1];
  203. $menus[] = ["type" => [1, 2], "code" => "jcxxbg", "pcode" => "rcrd", "name" => "基础信息变更", "url" => "", "icon" => "fa-thumbs-up", "status" => 1];
  204. $menus[] = ["type" => [1, 2], "code" => "jbtmanage", "pcode" => "0", "name" => "津补贴申报", "url" => "", "icon" => "fa-money", "status" => 0];
  205. $menus[] = ["type" => [1, 2], "code" => "jbtsb", "pcode" => "jbtmanage", "name" => "津补贴申报", "url" => "", "icon" => "fa-thumbs-up", "status" => 1];
  206. $menus[] = ["type" => [1, 2], "code" => "gfbt", "pcode" => "0", "name" => "购房补贴", "url" => "", "icon" => "fa-university", "status" => 0];
  207. $menus[] = ["type" => [1, 2], "code" => "gfbtsb", "pcode" => "gfbt", "name" => "购房补贴申报", "url" => "", "icon" => "fa-thumbs-up", "status" => 1];
  208. $menus[] = ["type" => [2], "code" => "pxbtmanage", "pcode" => "0", "name" => "培训补贴", "url" => "", "icon" => "fa-building", "status" => 1];
  209. $menus[] = ["type" => [2], "code" => "pxbt", "pcode" => "pxbtmanage", "name" => "培训补贴", "url" => "", "icon" => "fa-thumbs-up", "status" => 1];
  210. $menus[] = ["type" => [2], "code" => "zdzxmanage", "pcode" => "0", "name" => "重大专项", "url" => "", "icon" => "fa-life-ring", "status" => 1];
  211. $menus[] = ["type" => [2], "code" => "zdzx", "pcode" => "zdzxmanage", "name" => "重大专项", "url" => "", "icon" => "fa-thumbs-up", "status" => 1];
  212. $menus[] = ["type" => [2], "code" => "znjy", "pcode" => "0", "name" => "子女教育", "url" => "", "icon" => "fa-graduation-cap", "status" => 1];
  213. $menus[] = ["type" => [2], "code" => "xzfbz", "pcode" => "znjy", "name" => "学杂费补助", "url" => "", "icon" => "fa-thumbs-up", "status" => 1];
  214. $menus[] = ["type" => [2], "code" => "ylbzmanage", "pcode" => "0", "name" => "医疗补助", "url" => "", "icon" => "fa-hospital-o", "status" => 1];
  215. $menus[] = ["type" => [2], "code" => "ylbz", "pcode" => "ylbzmanage", "name" => "医疗补助", "url" => "", "icon" => "fa-thumbs-up", "status" => 1];
  216. $menus[] = ["type" => [2], "code" => "zfbz", "pcode" => "0", "name" => "住房保障", "url" => "", "icon" => "fa-home", "status" => 1];
  217. $menus[] = ["type" => [2], "code" => "zfsq", "pcode" => "zfbz", "name" => "租房申请", "url" => "", "icon" => "fa-home", "status" => 1];
  218. $menus[] = ["type" => [2], "code" => "fzbz", "pcode" => "zfbz", "name" => "房租补助", "url" => "", "icon" => "fa-money", "status" => 1];
  219. $menus[] = ["type" => [2], "code" => "gfsq", "pcode" => "zfbz", "name" => "购房申请", "url" => "", "icon" => "fa-envira", "status" => 1];
  220. $menus[] = ["type" => [2], "code" => "gfbz", "pcode" => "zfbz", "name" => "购房补助", "url" => "", "icon" => "fa-envira", "status" => 1];
  221. $menus[] = ["type" => [1], "code" => "sbrc", "pcode" => "0", "name" => "硕博人才", "url" => "", "icon" => "fa-graduation-cap", "status" => 0];
  222. $menus[] = ["type" => [1], "code" => "shbt", "pcode" => "sbrc", "name" => "生活补贴", "url" => "", "icon" => "fa-graduation-cap", "status" => 1];
  223. $menus[] = ["type" => [3], "code" => "hxjh", "pcode" => "0", "name" => "海峡计划", "url" => "", "icon" => "fa-plane", "status" => 1];
  224. $menus[] = ["type" => [3], "code" => "hxjhsb", "pcode" => "hxjh", "name" => "海峡计划申报", "url" => "", "icon" => "fa-pencil", "status" => 1];
  225. foreach ($menus as $key => $menu) {
  226. if (!in_array($type, $menu["type"]) || ($menu["pcode"]) != "0" && $menu["url"] == "" || $menu["status"] == 0)
  227. unset($menus[$key]);
  228. }
  229. return self::buildMenu($menus);
  230. }
  231. }