JobsRulesLogic.php 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226
  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. // 数组的开始位置添加一个数组
  121. array_unshift($result, [
  122. "id" => 'self',
  123. "name" => "管理员所属",
  124. "value" => "self",
  125. "type_value" => "data_table_provinces",
  126. ]);
  127. break;
  128. case 2:
  129. $result = TableDataLogic::citys($province_ids);
  130. // 数组的开始位置添加一个数组
  131. array_unshift($result, [
  132. "id" => 'self',
  133. "name" => "管理员所属",
  134. "value" => "self",
  135. "type_value" => "data_table_citys",
  136. ]);
  137. break;
  138. case 3:
  139. $result = TableDataLogic::saleGroup();
  140. break;
  141. case 4:
  142. $result = TableDataLogic::admins();
  143. // 数组的开始位置添加一个数组
  144. array_unshift($result, [
  145. "id" => 'self',
  146. "name" => "管理员所属",
  147. "value" => "self",
  148. "type_value" => "data_table_admins",
  149. ]);
  150. break;
  151. case 5:
  152. $result = TableDataLogic::propertyHead();
  153. break;
  154. case 6:
  155. $result = TableDataLogic::sale();
  156. break;
  157. }
  158. //provinces citys saleGroup admins propertyHead sale
  159. return $result?:[];
  160. }
  161. /**
  162. * 替换规则中的self为管理员所属的值
  163. * @param $adminId
  164. * @param $rules
  165. * @return array
  166. * @throws \think\db\exception\DataNotFoundException
  167. * @throws \think\db\exception\DbException
  168. * @throws \think\db\exception\ModelNotFoundException
  169. */
  170. public static function ruleSelfValue($adminId,$rules)
  171. {
  172. $admin = Admin::where('admin_id', $adminId)->where('root','=',0)->findOrEmpty();
  173. if($admin->isEmpty()){
  174. return [];
  175. }
  176. $admin = $admin->toArray();
  177. function replace_value($rule,$replace_value) {
  178. array_walk($rule,function (&$value,$key) use($replace_value) {
  179. if ($value == 'self'){
  180. $value = $replace_value;
  181. }
  182. });
  183. return $rule;
  184. }
  185. //[1=>[,,,,,],2=>[,,,,,]]
  186. //provinces citys saleGroup admins propertyHead sale
  187. foreach ($rules as $key => &$rule) {
  188. switch ($key) {
  189. case 1:
  190. $rule = replace_value($rule,$admin['province']);
  191. break;
  192. case 2:
  193. $rule = replace_value($rule,$admin['city']);
  194. break;
  195. case 4:
  196. $rule = replace_value($rule,$admin['id']);
  197. break;
  198. case 3:
  199. case 5:
  200. case 6:
  201. break;
  202. }
  203. }
  204. return $rules?:[];
  205. }
  206. }