UseScopeBaseModel.php 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724
  1. <?php
  2. namespace App\Model;
  3. use App\Service\RangeService;
  4. use Illuminate\Database\Eloquent\Model;
  5. class UseScopeBaseModel extends Model
  6. {
  7. //可见范围
  8. const range_function = '';
  9. const is_check_function = '';
  10. public function __construct(array $attributes = [])
  11. {
  12. parent::__construct($attributes);
  13. }
  14. //顶级部门过滤
  15. public function scopeTopClear($query, $user, $search)
  16. {
  17. //是否所有部门
  18. $is_all_depart = $user['is_all_depart'] ?? 0;
  19. //权限范围内的部门
  20. $depart_range = $user['depart_range'] ?? [];
  21. //顶级部门
  22. $search_depart_id = $search['top_depart_id'] ?? 0;
  23. if(empty($search_depart_id)){
  24. //默认进来 自身顶级公司
  25. $top_depart_id = $user['depart_top'][0] ?? [];
  26. $top_depart_id = $top_depart_id['depart_id'] ?? 0;
  27. }else{
  28. //查询 顶级公司
  29. $top_depart_id = $search_depart_id;
  30. }
  31. if($is_all_depart){
  32. //所有部门
  33. if(empty($search_depart_id)){
  34. //全部
  35. $query->whereIn('top_depart_id', $depart_range);
  36. }else{
  37. //查看某个分社
  38. $query->where('top_depart_id', $top_depart_id);
  39. }
  40. }else{
  41. //某个分社全部
  42. $query->where('top_depart_id', $top_depart_id);
  43. }
  44. //获取当前门店下
  45. if(! empty($search['get_my_top_depart_data'])){
  46. $depart = ! empty($user['depart_top'][0]) ? $user['depart_top'][0]: [];
  47. $depart_id = $depart['depart_id'] ?? 0;
  48. $query->where('top_depart_id', $depart_id);
  49. }
  50. return $query;
  51. }
  52. //部门和顶级部门(公司)过滤
  53. public function scopeClear($query, $user, $search)
  54. {
  55. //是否所有部门
  56. $is_all_depart = $user['is_all_depart'] ?? 0;
  57. //权限范围内的部门
  58. $depart_range = $user['depart_range'] ?? [];
  59. //我可见的
  60. if(isset($search['is_see'])){
  61. if($search['is_see']){
  62. $is_see = 1;
  63. }else{
  64. $is_see = 0;
  65. }
  66. }else{
  67. $is_see = 0;
  68. }
  69. //全部 待审 待我审核
  70. if(isset($search['is_check'])){
  71. if($search['is_check']){
  72. $is_check = $search['is_check'];
  73. }else{
  74. $is_check = 0;
  75. }
  76. }else{
  77. $is_check = 0;
  78. }
  79. $model = $query->getModel(); // 获取模型的实例
  80. $className = get_class($model); // 获取模型类名
  81. //可见范围方法
  82. $range_function = "";
  83. if (defined($className . '::range_function')) $range_function = $className::range_function;
  84. $function_range_bool = $this->hasMethod(new RangeService(),$range_function);
  85. //全部 待审 已审
  86. $is_check_function = "";
  87. if (defined($className . '::is_check_function')) $is_check_function = $className::is_check_function;
  88. $is_check_function_bool = $this->hasMethod(new RangeService(),$is_check_function);
  89. //顶级部门
  90. $search_depart_id = $search['top_depart_id'] ?? 0; //顶级公司
  91. if(empty($search_depart_id)){
  92. //默认进来 自身顶级公司
  93. $top_depart_id = $user['depart_top'][0] ?? [];
  94. $top_depart_id = $top_depart_id['depart_id'] ?? 0;
  95. }else{
  96. //查询 顶级公司
  97. $top_depart_id = $search_depart_id;
  98. }
  99. $id = [];
  100. //可见范围 以及单据里面填写人员 (状态类 是全部时检索)
  101. if($function_range_bool) $id = RangeService::$range_function($user,$search);
  102. //全部0 待审1 已审2 (状态类 是全部时检索)
  103. $check_search = "";
  104. if($is_check_function_bool && $is_check) $check_search = RangeService::$is_check_function($user,$search);
  105. //个人部门所有
  106. $auth_type = $this->getQx($search,$user);
  107. if($is_all_depart){
  108. //所有权限
  109. if(empty($search_depart_id)){
  110. if($is_see){
  111. //可见
  112. $query->whereIn('id', $id);
  113. }elseif ($is_check){
  114. if(! $auth_type){
  115. //全部
  116. $query->whereIn('depart_id', $depart_range)
  117. ->when(! empty($check_search), function ($query) use ($check_search) {
  118. return $query->whereRaw($check_search);
  119. });
  120. }else{
  121. if($auth_type == 1) { //我创建的 且加上可见
  122. $query->where('crt_id',$user['id'])
  123. ->when(! empty($check_search), function ($query) use ($check_search) {
  124. return $query->whereRaw($check_search);
  125. })
  126. ->when(! empty($id), function ($query) use ($id) {
  127. return $query->orWhereIn('id', $id);
  128. });
  129. }elseif ($auth_type == 2 || $auth_type == 3){
  130. //自己权限范围内的部门 或 所有
  131. $query->whereIn('depart_id', $depart_range)
  132. ->when(! empty($check_search), function ($query) use ($check_search) {
  133. return $query->whereRaw($check_search);
  134. });
  135. }
  136. }
  137. }else{
  138. if(! $auth_type){
  139. //全部
  140. $query->whereIn('depart_id', $depart_range);
  141. }else{
  142. if($auth_type == 1) { //我创建的 且加上可见
  143. $query->where('crt_id',$user['id'])
  144. ->when(! empty($id), function ($query) use ($id) {
  145. return $query->orWhereIn('id', $id);
  146. });
  147. }elseif ($auth_type == 2 || $auth_type == 3){
  148. //自己权限范围内的部门 或 所有
  149. $query->whereIn('depart_id', $depart_range);
  150. }
  151. }
  152. }
  153. }else{
  154. if($is_see){
  155. //查看指定公司 且 我可见
  156. $query->whereIn('id', $id);
  157. }elseif ($is_check){
  158. if(! $auth_type){
  159. //查看指定公司
  160. $query->where('top_depart_id', $top_depart_id)
  161. ->when(! empty($check_search), function ($query) use ($check_search) {
  162. return $query->whereRaw($check_search);
  163. });
  164. }else{
  165. if($auth_type == 1) { //指定公司下 且 我创建的 且加上可见
  166. $query->where('top_depart_id', $top_depart_id)
  167. ->where('crt_id',$user['id'])
  168. ->when(! empty($check_search), function ($query) use ($check_search) {
  169. return $query->whereRaw($check_search);
  170. })
  171. ->when(! empty($id), function ($query) use ($id) {
  172. return $query->orWhereIn('id', $id);
  173. });
  174. }elseif ($auth_type == 2 || $auth_type == 3){
  175. // (指定公司下的 且 自己权限范围内的部门 或 所有) 且加上可见
  176. $query->where('top_depart_id', $top_depart_id)
  177. ->whereIn('depart_id', $depart_range)
  178. ->when(! empty($check_search), function ($query) use ($check_search) {
  179. return $query->whereRaw($check_search);
  180. })
  181. ->when(! empty($id), function ($query) use ($id) {
  182. return $query->orWhereIn('id', $id);
  183. });
  184. }
  185. }
  186. }else{
  187. if(! $auth_type){
  188. //查看指定公司
  189. $query->where('top_depart_id', $top_depart_id);
  190. }else{
  191. if($auth_type == 1) { //指定公司下 且 我创建的 且加上可见
  192. $query->where('top_depart_id', $top_depart_id)
  193. ->where('crt_id',$user['id'])
  194. ->when(! empty($id), function ($query) use ($id) {
  195. return $query->orWhereIn('id', $id);
  196. });
  197. }elseif ($auth_type == 2 || $auth_type == 3){
  198. // (指定公司下的 且 自己权限范围内的部门 或 所有) 且加上可见
  199. $query->where('top_depart_id', $top_depart_id)
  200. ->whereIn('depart_id', $depart_range)
  201. ->when(! empty($id), function ($query) use ($id) {
  202. return $query->orWhereIn('id', $id);
  203. });
  204. }
  205. }
  206. }
  207. }
  208. }else{
  209. //非所有权限
  210. if($is_see){
  211. //某个分社可见
  212. $query->whereIn('id', $id);
  213. }elseif ($is_check){
  214. if(! $auth_type){
  215. //指定公司下全部 且加上可见
  216. $query->where('top_depart_id', $top_depart_id)
  217. // ->whereIn('depart_id', $depart_range)
  218. ->when(! empty($check_search), function ($query) use ($check_search) {
  219. return $query->whereRaw($check_search);
  220. })
  221. ->when(! empty($id), function ($query) use ($id) {
  222. return $query->orWhereIn('id', $id);
  223. });
  224. }else{
  225. if($auth_type == 1) {
  226. //指定公司下 且 我创建的 且加上可见
  227. $query->where('top_depart_id', $top_depart_id)
  228. ->where('crt_id',$user['id'])
  229. ->when(! empty($check_search), function ($query) use ($check_search) {
  230. return $query->whereRaw($check_search);
  231. })
  232. ->when(! empty($id), function ($query) use ($id) {
  233. return $query->orWhereIn('id', $id);
  234. });
  235. }elseif ($auth_type == 2) {
  236. //指定公司下 且 自己权限范围内的部门 且加上可见
  237. $query->where('top_depart_id', $top_depart_id)
  238. ->whereIn('depart_id', $depart_range)
  239. ->when(! empty($check_search), function ($query) use ($check_search) {
  240. return $query->whereRaw($check_search);
  241. })
  242. ->when(! empty($id), function ($query) use ($id) {
  243. return $query->orWhereIn('id', $id);
  244. });
  245. }elseif ($auth_type == 3) {
  246. // 指定公司下所有 且加上可见
  247. $query->where('top_depart_id', $top_depart_id)
  248. ->when(! empty($check_search), function ($query) use ($check_search) {
  249. return $query->whereRaw($check_search);
  250. })
  251. ->when(! empty($id), function ($query) use ($id) {
  252. return $query->orWhereIn('id', $id);
  253. });
  254. }
  255. }
  256. }else{
  257. if(! $auth_type){
  258. //指定公司下全部 且加上可见
  259. $query->where('top_depart_id', $top_depart_id)
  260. // ->whereIn('depart_id', $depart_range)
  261. ->when(! empty($id), function ($query) use ($id) {
  262. return $query->orWhereIn('id', $id);
  263. });
  264. }else{
  265. if($auth_type == 1) {
  266. //指定公司下 且 我创建的 且加上可见
  267. $query->where('top_depart_id', $top_depart_id)
  268. ->where('crt_id',$user['id'])
  269. ->when(! empty($id), function ($query) use ($id) {
  270. return $query->orWhereIn('id', $id);
  271. });
  272. }elseif ($auth_type == 2) {
  273. //指定公司下 且 自己权限范围内的部门 且加上可见
  274. $query->where('top_depart_id', $top_depart_id)
  275. ->whereIn('depart_id', $depart_range)
  276. ->when(! empty($id), function ($query) use ($id) {
  277. return $query->orWhereIn('id', $id);
  278. });
  279. }elseif ($auth_type == 3) {
  280. // 指定公司下所有 且加上可见
  281. $query->where('top_depart_id', $top_depart_id)
  282. ->when(! empty($id), function ($query) use ($id) {
  283. return $query->orWhereIn('id', $id);
  284. });
  285. }
  286. }
  287. }
  288. }
  289. if(! empty($search['get_my_top_depart_data'])){
  290. $depart = ! empty($user['depart_top'][0]) ? $user['depart_top'][0]: [];
  291. $depart_id = $depart['depart_id'] ?? 0;
  292. $query->where('top_depart_id', $depart_id);
  293. }
  294. }
  295. //部门和顶级部门(公司)过滤 取别名a
  296. public function scopeAClear($query, $user, $search)
  297. {
  298. //是否所有部门
  299. $is_all_depart = $user['is_all_depart'] ?? 0;
  300. //权限范围内的部门
  301. $depart_range = $user['depart_range'] ?? [];
  302. //我可见的
  303. $is_see = $search['is_see'] ?? 0;
  304. //可见范围方法
  305. $model = $query->getModel(); // 获取模型的实例
  306. $range_function = $model::range_function ?? ""; // 访问静态属性
  307. $is_function_range = $this->hasMethod(new RangeService(),$range_function);
  308. //顶级部门
  309. $search_depart_id = $search['top_depart_id'] ?? 0; //顶级公司
  310. if(empty($search_depart_id)){
  311. //默认进来 自身顶级公司
  312. $top_depart_id = $user['depart_top'][0] ?? [];
  313. $top_depart_id = $top_depart_id['depart_id'] ?? 0;
  314. }else{
  315. //查询 顶级公司
  316. $top_depart_id = $search_depart_id;
  317. }
  318. $id = [];
  319. //可见范围 以及单据里面填写人员
  320. if($is_function_range) $id = RangeService::$range_function($user,$search);
  321. //个人部门所有
  322. $auth_type = $this->getQx($search,$user);
  323. if($is_all_depart){
  324. //所有权限
  325. if(empty($search_depart_id)){
  326. if(! $is_see){
  327. if(! $auth_type){
  328. //全部
  329. $query->whereIn('a.depart_id', $depart_range);
  330. }else{
  331. if($auth_type == 1) { //我创建的 且加上可见
  332. $query->where('a.crt_id',$user['id'])
  333. ->orWhereIn('a.id', $id);
  334. }elseif ($auth_type == 2 || $auth_type == 3){
  335. //自己权限范围内的部门 或 所有
  336. $query->whereIn('a.depart_id', $depart_range);
  337. }
  338. }
  339. }else{
  340. //可见
  341. $query->whereIn('a.id', $id);
  342. }
  343. }else{
  344. if(! $is_see){
  345. if(! $auth_type){
  346. //查看指定公司
  347. $query->where('a.top_depart_id', $top_depart_id);
  348. }else{
  349. if($auth_type == 1) { //指定公司下 且 我创建的 且加上可见
  350. $query->where('a.top_depart_id', $top_depart_id)
  351. ->where('a.crt_id',$user['id'])
  352. ->orWhereIn('a.id', $id);
  353. }elseif ($auth_type == 2 || $auth_type == 3){
  354. // (指定公司下的 且 自己权限范围内的部门 或 所有) 且加上可见
  355. $query->where('a.top_depart_id', $top_depart_id)
  356. ->whereIn('a.depart_id', $depart_range)
  357. ->orWhereIn('a.id', $id);
  358. }
  359. }
  360. }else{
  361. //查看指定公司 且 我可见
  362. $query->whereIn('a.id', $id);
  363. }
  364. }
  365. }else{
  366. //非所有权限
  367. if(! $is_see){
  368. if(! $auth_type){
  369. //指定公司下全部 且加上可见
  370. $query->where('a.top_depart_id', $top_depart_id)
  371. ->whereIn('a.depart_id', $depart_range)
  372. ->orWhereIn('a.id', $id);
  373. }else{
  374. if($auth_type == 1) {
  375. //指定公司下 且 我创建的 且加上可见
  376. $query->where('a.top_depart_id', $top_depart_id)
  377. ->where('a.crt_id',$user['id'])
  378. ->orWhereIn('a.id', $id);
  379. }elseif ($auth_type == 2) {
  380. //指定公司下 且 自己权限范围内的部门 且加上可见
  381. $query->where('a.top_depart_id', $top_depart_id)
  382. ->whereIn('a.depart_id', $depart_range)
  383. ->orWhereIn('a.id', $id);
  384. }elseif ($auth_type == 3) {
  385. // 指定公司下所有 且加上可见
  386. $query->where('a.top_depart_id', $top_depart_id)
  387. ->orWhereIn('a.id', $id);
  388. }
  389. }
  390. }else{
  391. //某个分社可见
  392. $query->whereIn('a.id', $id);
  393. }
  394. }
  395. }
  396. //部门和顶级部门(公司)过滤 Old
  397. public function scopeClear1($query, $user, $search)
  398. {
  399. //是否所有部门
  400. $is_all_depart = $user['is_all_depart'] ?? 0;
  401. //权限范围内的部门
  402. $depart_range = $user['depart_range'] ?? [];
  403. //我可见的
  404. $is_see = $search['is_see'] ?? 0;
  405. //可见范围方法
  406. $model = $query->getModel(); // 获取模型的实例
  407. $range_function = $model::range_function ?? ""; // 访问静态属性
  408. $is_function_range = $this->hasMethod(new RangeService(),$range_function);
  409. //顶级部门
  410. $search_depart_id = $search['top_depart_id'] ?? 0; //顶级公司
  411. if(empty($search_depart_id)){
  412. //默认进来 自身顶级公司
  413. $top_depart_id = $user['depart_top'][0] ?? [];
  414. $top_depart_id = $top_depart_id['depart_id'] ?? 0;
  415. }else{
  416. //查询 顶级公司
  417. $top_depart_id = $search_depart_id;
  418. }
  419. $id = [];
  420. //可见范围 以及单据里面填写人员
  421. if($is_function_range) $id = RangeService::$range_function($user,$search);
  422. if($is_all_depart){
  423. //所有部门
  424. if(empty($search_depart_id)){
  425. if(! $is_see){
  426. //全部
  427. $query->whereIn('depart_id', $depart_range);
  428. }else{
  429. //可见
  430. $query->whereIn('id', $id);
  431. }
  432. }else{
  433. if(! $is_see){
  434. //查看某个分社
  435. $query->where('top_depart_id', $top_depart_id);
  436. }else{
  437. //查看某个分社可见
  438. $query->whereIn('id', $id);
  439. }
  440. }
  441. }else{
  442. //某个分社
  443. if(! $is_see){
  444. //某个分社全部
  445. $query->where('top_depart_id', $top_depart_id)
  446. ->whereIn('depart_id', $depart_range)
  447. ->orWhereIn('id', $id);
  448. }else{
  449. //某个分社可见
  450. $query->whereIn('id', $id);
  451. }
  452. }
  453. }
  454. //顶级部门过滤 取别名a
  455. public function scopeATopClear($query, $user, $search)
  456. {
  457. //是否所有部门
  458. $is_all_depart = $user['is_all_depart'] ?? 0;
  459. //权限范围内的部门
  460. $depart_range = $user['depart_range'] ?? [];
  461. //顶级部门
  462. $search_depart_id = $search['top_depart_id'] ?? 0;
  463. if(empty($search_depart_id)){
  464. //默认进来 自身顶级公司
  465. $top_depart_id = $user['depart_top'][0] ?? [];
  466. $top_depart_id = $top_depart_id['depart_id'] ?? 0;
  467. }else{
  468. //查询 顶级公司
  469. $top_depart_id = $search_depart_id;
  470. }
  471. if($is_all_depart){
  472. //所有部门
  473. if(empty($search_depart_id)){
  474. //全部
  475. $query->whereIn('a.top_depart_id', $depart_range);
  476. }else{
  477. //查看某个分社
  478. $query->where('a.top_depart_id', $top_depart_id);
  479. }
  480. }else{
  481. //某个分社全部
  482. $query->where('a.top_depart_id', $top_depart_id);
  483. }
  484. return $query;
  485. }
  486. //产品不可见 部门和顶级部门(公司)过滤
  487. public function scopeProductClear($query, $user, $search)
  488. {
  489. //是否所有部门
  490. $is_all_depart = $user['is_all_depart'] ?? 0;
  491. //权限范围内的部门
  492. $depart_range = $user['depart_range'] ?? [];
  493. //总社id
  494. $top_depart_id = $user['head'] ?? [];
  495. $top_depart = $top_depart_id['id'] ?? 0;
  496. //可见范围方法
  497. $model = $query->getModel(); // 获取模型的实例
  498. $range_function = $model::range_function ?? ""; // 访问静态属性
  499. $is_function_range = $this->hasMethod(new RangeService(),$range_function);
  500. //顶级部门
  501. $search_depart_id = $search['top_depart_id'] ?? 0; //顶级公司
  502. if(empty($search_depart_id)){
  503. //默认进来 自身顶级公司
  504. $top_depart_id = $user['depart_top'][0] ?? [];
  505. $top_depart_id = $top_depart_id['depart_id'] ?? 0;
  506. }else{
  507. //查询 顶级公司
  508. $top_depart_id = $search_depart_id;
  509. }
  510. $id = [];
  511. //产品 不可见范围
  512. if($is_function_range) $id = RangeService::$range_function($user,$search);
  513. if($is_all_depart){
  514. //所有部门
  515. if(empty($search_depart_id)){
  516. //全部
  517. $query->whereIn('depart_id', $depart_range);
  518. }else{
  519. //查看某个分社
  520. $query->where('top_depart_id', $top_depart_id);
  521. }
  522. }else{
  523. //某个分社全部 去掉不可见数
  524. $query->where('top_depart_id', $top_depart_id)
  525. ->whereIn('depart_id', $depart_range)
  526. ->orWhere('top_depart_id',$top_depart)
  527. ->whereNotIn('id', $id);
  528. }
  529. }
  530. //产品不可见 部门和顶级部门(公司)过滤
  531. public function scopeProductClear2($query, $user, $search)
  532. {
  533. //是否所有部门
  534. $is_all_depart = $user['is_all_depart'] ?? 0;
  535. //权限范围内的部门
  536. $depart_range = $user['depart_range'] ?? [];
  537. //总社id
  538. $top_depart_id = $user['head'] ?? [];
  539. $top_depart = $top_depart_id['id'] ?? 0;
  540. //可见范围方法
  541. $model = $query->getModel(); // 获取模型的实例
  542. $range_function = $model::range_function ?? ""; // 访问静态属性
  543. $is_function_range = $this->hasMethod(new RangeService(),$range_function);
  544. //顶级部门
  545. $search_depart_id = $search['top_depart_id'] ?? 0; //顶级公司
  546. if(empty($search_depart_id)){
  547. //默认进来 自身顶级公司
  548. $top_depart_id = $user['depart_top'][0] ?? [];
  549. $top_depart_id = $top_depart_id['depart_id'] ?? 0;
  550. }else{
  551. //查询 顶级公司
  552. $top_depart_id = $search_depart_id;
  553. }
  554. $id = [];
  555. //产品 不可见范围
  556. if($is_function_range) $id = RangeService::$range_function($user,$search);
  557. if($is_all_depart){
  558. //所有部门
  559. if(empty($search_depart_id)){
  560. //全部
  561. $query->whereIn('depart_id', $depart_range);
  562. }else{
  563. //查看某个分社
  564. $query->where('top_depart_id', $top_depart_id)
  565. ->orWhere('top_depart_id',$top_depart);
  566. }
  567. }else{
  568. //某个分社全部 去掉不可见数
  569. $query->where('top_depart_id', $top_depart_id)
  570. ->whereIn('depart_id', $depart_range)
  571. ->orWhere('top_depart_id',$top_depart)
  572. ->whereNotIn('id', $id);
  573. }
  574. }
  575. //活动包 部门和顶级部门(公司)过滤
  576. public function scopeSportsBagClear($query, $user, $search)
  577. {
  578. //是否所有部门
  579. $is_all_depart = $user['is_all_depart'] ?? 0;
  580. //权限范围内的部门
  581. $depart_range = $user['depart_range'] ?? [];
  582. //总社id
  583. $top_depart_id = $user['head'] ?? [];
  584. $top_depart = $top_depart_id['id'] ?? 0;
  585. //可见范围方法
  586. $model = $query->getModel(); // 获取模型的实例
  587. $range_function = $model::range_function ?? ""; // 访问静态属性
  588. $is_function_range = $this->hasMethod(new RangeService(),$range_function);
  589. $model = $query->getModel(); // 获取模型的实例
  590. $className = get_class($model); // 获取模型类名
  591. //全部 待审 待我审核
  592. if(isset($search['is_check'])){
  593. if($search['is_check']){
  594. $is_check = $search['is_check'];
  595. }else{
  596. $is_check = 0;
  597. }
  598. }else{
  599. $is_check = 0;
  600. }
  601. //全部 待审 已审
  602. $is_check_function = "";
  603. if (defined($className . '::is_check_function')) $is_check_function = $className::is_check_function;
  604. $is_check_function_bool = $this->hasMethod(new RangeService(),$is_check_function);
  605. //全部0 待审1 已审2 (状态类 是全部时检索)
  606. $check_search = "";
  607. if($is_check_function_bool && $is_check) $check_search = RangeService::$is_check_function($user,$search);
  608. //顶级部门
  609. $search_depart_id = $search['top_depart_id'] ?? 0; //顶级公司
  610. if(empty($search_depart_id)){
  611. //默认进来 自身顶级公司
  612. $top_depart_id = $user['depart_top'][0] ?? [];
  613. $top_depart_id = $top_depart_id['depart_id'] ?? 0;
  614. }else{
  615. //查询 顶级公司
  616. $top_depart_id = $search_depart_id;
  617. }
  618. $id = [];
  619. //不可见范围
  620. if($is_function_range) $id = RangeService::$range_function($user,$search);
  621. if($is_all_depart){
  622. //所有部门
  623. if(empty($search_depart_id)){
  624. //全部
  625. $query->whereIn('depart_id', $depart_range)
  626. ->when(! empty($check_search), function ($query) use ($check_search) {
  627. return $query->whereRaw($check_search);
  628. });
  629. }else{
  630. //查看某个分社
  631. $query->where('top_depart_id', $top_depart_id)
  632. ->when(! empty($check_search), function ($query) use ($check_search) {
  633. return $query->whereRaw($check_search);
  634. });
  635. }
  636. }else{
  637. if($check_search){
  638. $check_search2 = "(" . $check_search . " And top_depart_id = {$top_depart})";
  639. } else{
  640. $check_search2 = "(top_depart_id = {$top_depart})";
  641. }
  642. //某个分社全部 去掉不可见数
  643. $query->where('top_depart_id', $top_depart_id)
  644. ->when(! empty($check_search), function ($query) use ($check_search) {
  645. return $query->whereRaw($check_search);
  646. })
  647. ->whereIn('depart_id', $depart_range)
  648. ->whereNotIn('id', $id)
  649. ->OrWhereRaw($check_search2);
  650. }
  651. }
  652. public function getQx($data, $user){
  653. if(empty($data['menu_id'])) return 0;
  654. if($user['id'] == Employee::SPECIAL_ADMIN) return 0;
  655. if(! empty($user['role_authority'][$data['menu_id']])) {
  656. //指定菜单 显示对应权限
  657. return $user['role_authority'][$data['menu_id']];
  658. }else{
  659. return 0;
  660. }
  661. }
  662. function hasMethod($class, $methodName)
  663. {
  664. $reflection = new \ReflectionClass($class);
  665. return $reflection->hasMethod($methodName);
  666. }
  667. }