MasterWorkerLogic.php 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354
  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\master_worker;
  15. use app\common\model\master_worker\MasterWorker;
  16. use app\common\logic\BaseLogic;
  17. use app\common\model\master_worker\MasterWorkerScore;
  18. use app\common\model\master_worker\MasterWorkerRetentionMoneyLog;
  19. use app\common\model\master_worker_credential\MasterWorkerCredentialImages;
  20. use app\common\model\service_area\ServiceArea;
  21. use app\common\model\master_worker\MasterWorkerStop;
  22. use think\db\Query;
  23. use think\facade\Config;
  24. use think\facade\Db;
  25. /**
  26. * MasterWorker逻辑
  27. * Class MasterWorkerLogic
  28. * @package app\adminapi\logic\master_worker
  29. */
  30. class MasterWorkerLogic extends BaseLogic
  31. {
  32. /**
  33. * @notes 添加
  34. * @param array $params
  35. * @return bool
  36. * @author likeadmin
  37. * @date 2024/07/10 18:17
  38. */
  39. public static function add(array $params): bool
  40. {
  41. Db::startTrans();
  42. try {
  43. $service_area_id = ServiceArea::serviceAreaId(['lon' => $params['lon'], 'lat' => $params['lat']]);
  44. if (!empty($params['lon']) && !empty($params['lat']) && !$service_area_id) {
  45. self::setError('您所选的位置已超出服务区域!');
  46. return false;
  47. }
  48. $data = [
  49. 'sn' => $params['sn'],
  50. 'avatar' => $params['avatar'],
  51. 'real_avatar' => $params['real_avatar'],
  52. 'real_name' => $params['real_name'],
  53. 'nickname' => $params['nickname'],
  54. 'account' => $params['account'],
  55. 'password' => $params['password'],
  56. 'mobile' => $params['mobile'],
  57. 'sex' => $params['sex'],
  58. 'channel' => $params['channel'],
  59. 'is_disable' => $params['is_disable'],
  60. 'login_ip' => $params['login_ip'],
  61. 'login_time' => $params['login_time'],
  62. 'is_new_user' => $params['is_new_user'],
  63. 'estimate_money' => $params['estimate_money'],
  64. 'user_money' => $params['user_money'],
  65. 'earnest_money' => $params['earnest_money'],
  66. 'exp' => $params['exp'],
  67. 'lon' => $params['lon'],
  68. 'lat' => $params['lat'],
  69. 'distance' => $params['distance'],
  70. 'province' => $params['province'],
  71. 'city' => $params['city'],
  72. 'service_area_id' => $service_area_id,
  73. 'area_name' => $params['area_name'],
  74. 'cooperation' => $params['cooperation']??0,
  75. 'time_period' => $params['time_period']??'',
  76. 'work_status' => $params['work_status']??0,
  77. 'recruiting_behalf' => $params['recruiting_behalf']??'',
  78. 'settlement_type' => $params['settlement_type']??2,
  79. 'labels' => (isset($params['labels']) && $params['labels'])?implode(',',$params['labels']):'',
  80. 'remark' => $params['remark']??'',
  81. 'is_wecall' => $params['is_wecall']??0,
  82. ];
  83. if (isset($params['type']) && $params['type'] == 2) {
  84. $data['type'] = 2;
  85. $data['promotion_level'] = 6; //A1级工程师
  86. $data['title_promotion'] = 1; //普通工程师
  87. }
  88. $masterWorker = MasterWorker::create($data);
  89. //添加工程师汇总评分数据
  90. MasterWorkerScore::create([
  91. 'worker_id' => $masterWorker->id
  92. ]);
  93. Db::commit();
  94. return true;
  95. } catch (\Exception $e) {
  96. Db::rollback();
  97. self::setError($e->getMessage());
  98. return false;
  99. }
  100. }
  101. /**
  102. * @notes 编辑
  103. * @param array $params
  104. * @return bool
  105. * @author likeadmin
  106. * @date 2024/07/10 18:17
  107. */
  108. public static function edit(array $params): bool
  109. {
  110. if($params['category_ids']){
  111. foreach ($params['category_ids'] as $val){
  112. is_array($val)?($ids[] = end($val)):($ids[] = $val);
  113. }
  114. //$params['category_ids'] = ["goods_category_ids"=>$params['category_ids'],"ids"=>$ids];
  115. $params['category_ids'] = implode(',',$ids);
  116. }
  117. /*if($params['tenant_id']){
  118. // 绑定租户 绑定团队-组员
  119. $team_id = MasterWorkerTeam::where('tenant_id',$params['tenant_id'])->value('id');
  120. }*/
  121. Db::startTrans();
  122. try {
  123. $detail = MasterWorker::where('id', $params['id'])->field('id,lon,lat,address,service_area_id,type')->findOrEmpty()->toArray();
  124. $address = $params['address']??'';
  125. if ($detail['address'] != $address && !empty($address)) {
  126. $lon_lat = get_address_lat_lng($address);
  127. $params['lon'] = $lon_lat['lon'];
  128. $params['lat'] = $lon_lat['lat'];
  129. $service_area_id = ServiceArea::serviceAreaId(['lon' => $params['lon'], 'lat' => $params['lat']]);
  130. if (!empty($params['lon']) && !empty($params['lat']) && !$service_area_id) {
  131. self::setError('您所选的位置已超出服务区域!');
  132. return false;
  133. }
  134. } else {
  135. $params['lon'] = $detail['lon'];
  136. $params['lat'] = $detail['lat'];
  137. $service_area_id = $detail['service_area_id'];
  138. if (empty($address)) {
  139. $address = getAddressByLatLng($params['lon'], $params['lat']);
  140. }
  141. }
  142. $update = [
  143. 'sn' => $params['sn'],
  144. 'avatar' => $params['avatar'],
  145. 'real_avatar' => $params['real_avatar'],
  146. 'real_name' => $params['real_name'],
  147. 'nickname' => $params['nickname'],
  148. 'account' => $params['account'],
  149. 'password' => $params['password'],
  150. 'mobile' => $params['mobile'],
  151. 'sex' => $params['sex'],
  152. 'channel' => $params['channel'],
  153. 'is_disable' => $params['is_disable'],
  154. 'login_ip' => $params['login_ip'],
  155. 'login_time' => $params['login_time'],
  156. 'is_new_user' => $params['is_new_user'],
  157. 'estimate_money' => $params['estimate_money'],
  158. 'user_money' => $params['user_money'],
  159. 'exp' => $params['exp'],
  160. 'address' => $address,
  161. 'lon' => $params['lon'],
  162. 'lat' => $params['lat'],
  163. 'distance' => $params['distance'],
  164. 'province' => $params['province'],
  165. 'city' => $params['city'],
  166. 'service_area_id' => $service_area_id,
  167. 'area_name' => $params['area_name'],
  168. 'earnest_money' => $params['earnest_money'],
  169. 'earnest_money_usable' => $params['earnest_money_usable'],
  170. 'earnest_money_freeze' => $params['earnest_money_freeze'],
  171. 'installment_ratio' => $params['installment_ratio'],
  172. 'retention_pay_status' => $params['retention_pay_status'],
  173. 'retention_money_status' => $params['retention_money_status'],
  174. 'category_ids' => $params['category_ids']??'',
  175. 'cooperation' => $params['cooperation']??0,
  176. 'time_period' => $params['time_period']?implode(',',$params['time_period']):'',
  177. 'work_status' => $params['work_status']??0,
  178. 'recruiting_behalf' => $params['recruiting_behalf']??'',
  179. 'settlement_type' => $params['settlement_type']??2,
  180. 'labels' => (isset($params['labels']) && $params['labels'])?implode(',',$params['labels']):'',
  181. 'remark' => $params['remark']??'',
  182. 'is_wecall' => $params['is_wecall']??0,
  183. 'type' => $params['type']??1,
  184. 'title_promotion' => $params['title_promotion']??0,
  185. ];
  186. if (isset($params['type']) && $detail['type'] != $params['type']) {
  187. if ($params['type'] == 2) {
  188. $update['promotion_level'] = 6; //A1级工程师
  189. $update['title_promotion'] = 1; //普通工程师
  190. } else {
  191. $update['promotion_level'] = 0;
  192. $update['title_promotion'] = 0;
  193. }
  194. }
  195. //'tenant_id' => $params['tenant_id']??0,
  196. MasterWorker::where('id', $params['id'])->update($update);
  197. if (is_numeric($params['score']['weight_score'])) {
  198. $exists = MasterWorkerScore::where('worker_id', $params['id'])->value('id');
  199. if ($exists) {
  200. MasterWorkerScore::where('worker_id',$params['id'])->update(['weight_score' => $params['score']['weight_score']]);
  201. } else {
  202. MasterWorkerScore::create([
  203. 'worker_id' => $params['id'],
  204. 'weight_score' => $params['score']['weight_score'],
  205. ]);
  206. }
  207. }
  208. Db::commit();
  209. return true;
  210. } catch (\Exception $e) {
  211. Db::rollback();
  212. self::setError($e->getMessage());
  213. return false;
  214. }
  215. }
  216. /**
  217. * @notes 删除
  218. * @param array $params
  219. * @return bool
  220. * @author likeadmin
  221. * @date 2024/07/10 18:17
  222. */
  223. public static function delete(array $params): bool
  224. {
  225. return MasterWorker::destroy($params['id']);
  226. }
  227. /**
  228. * @notes 获取详情
  229. * @param $params
  230. * @return array
  231. * @author likeadmin
  232. * @date 2024/07/10 18:17
  233. */
  234. public static function detail($params): array
  235. {
  236. $info = MasterWorker::with(['workerInfo'=>function(Query $query){
  237. $query->field('worker_id,real_name,id_card,id_card_front_img,id_card_opposite_img,mobile,address');
  238. },'workerRegister'=>function(Query $query){
  239. $query->field('id as worker_register_id,worker_id,maintain_exp_type,other_exp_type,city,vehicle_type,name,age,mobile')->append(['maintain_exp_type_text','other_exp_type_text','vehicle_type_text','city_text']);
  240. }])
  241. ->append(['time_period'])
  242. ->findOrEmpty($params['id'])->toArray();
  243. if(!empty($info['category_ids'])){
  244. $info['category_ids'] = explode(',',$info['category_ids']);
  245. $info['category_ids'] = array_map('intval', $info['category_ids']);
  246. }
  247. $info['is_up_retention_pay'] = 0;
  248. if(MasterWorkerRetentionMoneyLog::where(['worker_id' => $params['id'],'action' => 1])->count('id') > 0){
  249. $info['is_up_retention_pay'] = 1;
  250. }
  251. $info['score'] = MasterWorkerScore::where(['worker_id' => $params['id']])->field('comprehensive_score,weight_score')->findOrEmpty()->toArray();
  252. $images = MasterWorkerCredentialImages::where(['worker_register_id' => $info['workerRegister']['worker_register_id']??-1])->select()->toArray();
  253. $info['credential_info'] = $images;
  254. return $info;
  255. }
  256. /**
  257. * 获取加盐密码
  258. * @param $params
  259. * @return false|string
  260. */
  261. public static function saltToPassword($params){
  262. try{
  263. $passwordSalt = Config::get('project.unique_identification');
  264. $password = create_password($params['password'], $passwordSalt);
  265. return ['password' => $password];
  266. } catch (\Exception $e){
  267. self::setError($e->getMessage());
  268. return false;
  269. }
  270. }
  271. /**
  272. * 获取所有工程师选项列表
  273. * @param $params
  274. * @return array
  275. */
  276. public static function getAllWorkers($params){
  277. try{
  278. return MasterWorker::where(['is_disable'=>0])->column('id,id as value,worker_number as name,real_name,account,mobile');
  279. } catch (\Exception $e){
  280. self::setError($e->getMessage());
  281. return [];
  282. }
  283. }
  284. /**
  285. * 长期合作工程师停单
  286. * @param $params
  287. * @return bool
  288. */
  289. public static function stop($params, $userInfo){
  290. try{
  291. Db::startTrans();
  292. $worker = MasterWorker::where(['id' => $params['id']])->findOrEmpty();
  293. if($worker->isEmpty()){
  294. self::setError('工程师不存在');
  295. return false;
  296. }
  297. $start_time = strtotime($params['start_time']. " 00:00:00");
  298. $end_time = strtotime($params['end_time']. " 23:59:59");
  299. //校验停单日期是否重复
  300. $exists = MasterWorkerStop::where(['worker_id' => $params['id'] ])
  301. ->where(function($query) use ($start_time, $end_time) {
  302. $query->where('start_time', 'between', [$start_time, $end_time])
  303. ->whereOr('end_time', 'between', [$start_time, $end_time]);
  304. })
  305. ->count('id');
  306. if($exists > 0){
  307. self::setError('该日期已存在停单记录');
  308. return false;
  309. }
  310. if ($params['start_time'] == date('Y-m-d')) {
  311. $worker->accept_order_status = 0;
  312. }
  313. $worker->save();
  314. MasterWorkerStop::create([
  315. 'worker_id' => $params['id'],
  316. 'start_time' => $start_time,
  317. 'end_time' => $end_time,
  318. 'admin_id' => $userInfo['admin_id'],
  319. ]);
  320. Db::commit();
  321. return true;
  322. } catch (\Exception $e){
  323. Db::rollback();
  324. self::setError($e->getMessage());
  325. return false;
  326. }
  327. }
  328. }