JobsRulesLogic.php 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | likeadmin快速开发前后端分离管理后台(PHP版)
  4. // +----------------------------------------------------------------------
  5. // | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
  6. // | 开源版本可自由商用,可去除界面版权logo
  7. // | gitee下载:https://gitee.com/likeshop_gitee/likeadmin
  8. // | github下载:https://github.com/likeshop-github/likeadmin
  9. // | 访问官网:https://www.likeadmin.cn
  10. // | likeadmin团队 版权所有 拥有最终解释权
  11. // +----------------------------------------------------------------------
  12. // | author: likeadminTeam
  13. // +----------------------------------------------------------------------
  14. namespace app\adminapi\logic\jobs_rules;
  15. use app\common\logic\TableDataLogic;
  16. use app\common\model\auth\Admin;
  17. use app\common\model\jobs_rules\JobsRules;
  18. use app\common\logic\BaseLogic;
  19. use think\facade\Db;
  20. /**
  21. * JobsRules逻辑
  22. * Class JobsRulesLogic
  23. * @package app\adminapi\logic
  24. */
  25. class JobsRulesLogic extends BaseLogic
  26. {
  27. /**
  28. * @notes 添加
  29. * @param array $params
  30. * @return bool
  31. * @author likeadmin
  32. * @date 2024/12/31 13:50
  33. */
  34. public static function add(array $params): bool
  35. {
  36. Db::startTrans();
  37. try {
  38. JobsRules::create([
  39. 'rule_name' => $params['rule_name'],
  40. 'code' => generateRandomString(8,2),
  41. 'rule_term' => $params['rule_term'],
  42. //'rule_value' => $params['rule_value'],
  43. 'remark' => $params['remark'],
  44. ]);
  45. Db::commit();
  46. return true;
  47. } catch (\Exception $e) {
  48. Db::rollback();
  49. self::setError($e->getMessage());
  50. return false;
  51. }
  52. }
  53. /**
  54. * @notes 编辑
  55. * @param array $params
  56. * @return bool
  57. * @author likeadmin
  58. * @date 2024/12/31 13:50
  59. */
  60. public static function edit(array $params): bool
  61. {
  62. Db::startTrans();
  63. try {
  64. JobsRules::where('id', $params['id'])->update([
  65. 'rule_name' => $params['rule_name'],
  66. 'rule_term' => $params['rule_term'],
  67. //'rule_value' => $params['rule_value'],
  68. 'remark' => $params['remark'],
  69. ]);
  70. Db::commit();
  71. return true;
  72. } catch (\Exception $e) {
  73. Db::rollback();
  74. self::setError($e->getMessage());
  75. return false;
  76. }
  77. }
  78. /**
  79. * @notes 删除
  80. * @param array $params
  81. * @return bool
  82. * @author likeadmin
  83. * @date 2024/12/31 13:50
  84. */
  85. public static function delete(array $params): bool
  86. {
  87. return JobsRules::destroy($params['id']);
  88. }
  89. /**
  90. * @notes 获取详情
  91. * @param $params
  92. * @return array
  93. * @author likeadmin
  94. * @date 2024/12/31 13:50
  95. */
  96. public static function detail($params): array
  97. {
  98. return JobsRules::findOrEmpty($params['id'])->toArray();
  99. }
  100. /**
  101. * @notes 获取规则数据
  102. * @param $params
  103. * @return array
  104. * @date 2024/12/31 13:50
  105. */
  106. public static function ruleData($params)
  107. {
  108. $result = [];
  109. /*1 省
  110. 2 市
  111. 3 销售组
  112. 4 后台管理员
  113. 5 代理人
  114. 6 销售*/
  115. $province_ids = array_column($params['rules_data'], 'rule_value', 'rule_id');
  116. $province_ids = $province_ids[1]??[];
  117. switch ($params['id']) {
  118. case 1:
  119. $result = TableDataLogic::provinces();
  120. break;
  121. case 2:
  122. $result = TableDataLogic::citys($province_ids);
  123. break;
  124. case 3:
  125. $result = TableDataLogic::saleGroup();
  126. break;
  127. case 4:
  128. $result = TableDataLogic::admins();
  129. break;
  130. case 5:
  131. $result = TableDataLogic::propertyHead();
  132. break;
  133. case 6:
  134. $result = TableDataLogic::sale();
  135. break;
  136. }
  137. //provinces citys saleGroup admins propertyHead sale
  138. return $result?:[];
  139. }
  140. /**
  141. * 替换规则中的self为管理员所属的值
  142. * @param $adminId
  143. * @param $rules
  144. * @return array
  145. * @throws \think\db\exception\DataNotFoundException
  146. * @throws \think\db\exception\DbException
  147. * @throws \think\db\exception\ModelNotFoundException
  148. */
  149. public static function ruleSelfValue($adminId,$rules)
  150. {
  151. $admin = Admin::where('admin_id', $adminId)->where('root','=',0)->findOrEmpty();
  152. if($admin->isEmpty()){
  153. return [];
  154. }
  155. $admin = $admin->toArray();
  156. function replace_value($rule,$replace_value) {
  157. array_walk($rule,function (&$value,$key) use($replace_value) {
  158. if ($value == 'self'){
  159. $value = $replace_value;
  160. }
  161. });
  162. return $rule;
  163. }
  164. //[1=>[,,,,,],2=>[,,,,,]]
  165. //provinces citys saleGroup admins propertyHead sale
  166. foreach ($rules as $key => &$rule) {
  167. switch ($key) {
  168. case 1:
  169. $rule = replace_value($rule,$admin['province']);
  170. break;
  171. case 2:
  172. $rule = replace_value($rule,$admin['city']);
  173. break;
  174. case 4:
  175. $rule = replace_value($rule,$admin['id']);
  176. break;
  177. case 3:
  178. case 5:
  179. case 6:
  180. break;
  181. }
  182. }
  183. return $rules?:[];
  184. }
  185. }