MasterWorkerLogic.php 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508
  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 app\common\model\master_worker\MasterWorkerRetentionMoneyOrder;
  23. use app\common\model\dict\DictConfig;
  24. use think\db\Query;
  25. use think\facade\Config;
  26. use think\facade\Db;
  27. /**
  28. * MasterWorker逻辑
  29. * Class MasterWorkerLogic
  30. * @package app\adminapi\logic\master_worker
  31. */
  32. class MasterWorkerLogic extends BaseLogic
  33. {
  34. /**
  35. * @notes 添加
  36. * @param array $params
  37. * @return bool
  38. * @author likeadmin
  39. * @date 2024/07/10 18:17
  40. */
  41. public static function add(array $params): bool
  42. {
  43. Db::startTrans();
  44. try {
  45. $service_area_id = ServiceArea::serviceAreaId(['lon' => $params['lon'], 'lat' => $params['lat']]);
  46. if (!empty($params['lon']) && !empty($params['lat']) && !$service_area_id) {
  47. self::setError('您所选的位置已超出服务区域!');
  48. return false;
  49. }
  50. $data = [
  51. 'sn' => $params['sn'],
  52. 'avatar' => $params['avatar'],
  53. 'real_avatar' => $params['real_avatar'],
  54. 'real_name' => $params['real_name'],
  55. 'nickname' => $params['nickname'],
  56. 'account' => $params['account'],
  57. 'password' => $params['password'],
  58. 'mobile' => $params['mobile'],
  59. 'sex' => $params['sex'],
  60. 'channel' => $params['channel'],
  61. 'is_disable' => $params['is_disable'],
  62. 'login_ip' => $params['login_ip'],
  63. 'login_time' => $params['login_time'],
  64. 'is_new_user' => $params['is_new_user'],
  65. 'estimate_money' => $params['estimate_money'],
  66. 'user_money' => $params['user_money'],
  67. 'earnest_money' => $params['earnest_money'],
  68. 'exp' => $params['exp'],
  69. 'lon' => $params['lon'],
  70. 'lat' => $params['lat'],
  71. 'distance' => $params['distance'],
  72. 'province' => $params['province'],
  73. 'city' => $params['city'],
  74. 'service_area_id' => $service_area_id,
  75. 'area_name' => $params['area_name'],
  76. 'cooperation' => $params['cooperation']??0,
  77. 'time_period' => $params['time_period']??'',
  78. 'work_status' => $params['work_status']??0,
  79. 'recruiting_behalf' => $params['recruiting_behalf']??'',
  80. 'settlement_type' => $params['settlement_type']??2,
  81. 'labels' => (isset($params['labels']) && $params['labels'])?implode(',',$params['labels']):'',
  82. 'remark' => $params['remark']??'',
  83. 'is_wecall' => $params['is_wecall']??0,
  84. ];
  85. if (isset($params['type']) && $params['type'] == 2) {
  86. $data['type'] = 2;
  87. $data['promotion_level'] = 6; //A1级工程师
  88. $data['title_promotion'] = 1; //普通工程师
  89. }
  90. $masterWorker = MasterWorker::create($data);
  91. //添加工程师汇总评分数据
  92. MasterWorkerScore::create([
  93. 'worker_id' => $masterWorker->id
  94. ]);
  95. Db::commit();
  96. return true;
  97. } catch (\Exception $e) {
  98. Db::rollback();
  99. self::setError($e->getMessage());
  100. return false;
  101. }
  102. }
  103. /**
  104. * @notes 编辑
  105. * @param array $params
  106. * @return bool
  107. * @author likeadmin
  108. * @date 2024/07/10 18:17
  109. */
  110. public static function edit(array $params): bool
  111. {
  112. if($params['category_ids']){
  113. foreach ($params['category_ids'] as $val){
  114. is_array($val)?($ids[] = end($val)):($ids[] = $val);
  115. }
  116. //$params['category_ids'] = ["goods_category_ids"=>$params['category_ids'],"ids"=>$ids];
  117. $params['category_ids'] = implode(',',$ids);
  118. }
  119. /*if($params['tenant_id']){
  120. // 绑定租户 绑定团队-组员
  121. $team_id = MasterWorkerTeam::where('tenant_id',$params['tenant_id'])->value('id');
  122. }*/
  123. Db::startTrans();
  124. try {
  125. $detail = MasterWorker::where('id', $params['id'])->field('id,lon,lat,address,service_area_id,type')->findOrEmpty()->toArray();
  126. $address = $params['address']??'';
  127. if ($detail['address'] != $address && !empty($address)) {
  128. $lon_lat = get_address_lat_lng($address);
  129. $params['lon'] = $lon_lat['lon'];
  130. $params['lat'] = $lon_lat['lat'];
  131. $service_area_id = ServiceArea::serviceAreaId(['lon' => $params['lon'], 'lat' => $params['lat']]);
  132. if (!empty($params['lon']) && !empty($params['lat']) && !$service_area_id) {
  133. self::setError('您所选的位置已超出服务区域!');
  134. return false;
  135. }
  136. } else {
  137. $params['lon'] = $detail['lon'];
  138. $params['lat'] = $detail['lat'];
  139. $service_area_id = $detail['service_area_id'];
  140. if (empty($address)) {
  141. $address = getAddressByLatLng($params['lon'], $params['lat']);
  142. }
  143. }
  144. $update = [
  145. 'sn' => $params['sn'],
  146. 'avatar' => $params['avatar'],
  147. 'real_avatar' => $params['real_avatar'],
  148. 'real_name' => $params['real_name'],
  149. 'nickname' => $params['nickname'],
  150. 'account' => $params['account'],
  151. 'password' => $params['password'],
  152. 'mobile' => $params['mobile'],
  153. 'sex' => $params['sex'],
  154. 'channel' => $params['channel'],
  155. 'is_disable' => $params['is_disable'],
  156. 'login_ip' => $params['login_ip'],
  157. 'login_time' => $params['login_time'],
  158. 'is_new_user' => $params['is_new_user'],
  159. 'estimate_money' => $params['estimate_money'],
  160. 'user_money' => $params['user_money'],
  161. 'exp' => $params['exp'],
  162. 'address' => $address,
  163. 'lon' => $params['lon'],
  164. 'lat' => $params['lat'],
  165. 'distance' => $params['distance'],
  166. 'province' => $params['province'],
  167. 'city' => $params['city'],
  168. 'service_area_id' => $service_area_id,
  169. 'area_name' => $params['area_name'],
  170. 'earnest_money' => $params['earnest_money'],
  171. 'earnest_money_usable' => $params['earnest_money_usable'],
  172. 'earnest_money_freeze' => $params['earnest_money_freeze'],
  173. 'installment_ratio' => $params['installment_ratio'],
  174. 'retention_pay_status' => $params['retention_pay_status'],
  175. 'retention_money_status' => $params['retention_money_status'],
  176. 'category_ids' => $params['category_ids']??'',
  177. 'cooperation' => $params['cooperation']??0,
  178. 'time_period' => $params['time_period']?implode(',',$params['time_period']):'',
  179. 'work_status' => $params['work_status']??0,
  180. 'recruiting_behalf' => $params['recruiting_behalf']??'',
  181. 'settlement_type' => $params['settlement_type']??2,
  182. 'labels' => (isset($params['labels']) && $params['labels'])?implode(',',$params['labels']):'',
  183. 'remark' => $params['remark']??'',
  184. 'is_wecall' => $params['is_wecall']??0,
  185. 'type' => $params['type']??1,
  186. 'title_promotion' => $params['title_promotion']??0,
  187. ];
  188. if (isset($params['type']) && $detail['type'] != $params['type']) {
  189. if ($params['type'] == 2) {
  190. $update['promotion_level'] = 6; //A1级工程师
  191. $update['title_promotion'] = 1; //普通工程师
  192. } else {
  193. $update['promotion_level'] = 0;
  194. $update['title_promotion'] = 0;
  195. }
  196. }
  197. //'tenant_id' => $params['tenant_id']??0,
  198. MasterWorker::where('id', $params['id'])->update($update);
  199. if (is_numeric($params['score']['weight_score'])) {
  200. $exists = MasterWorkerScore::where('worker_id', $params['id'])->value('id');
  201. if ($exists) {
  202. MasterWorkerScore::where('worker_id',$params['id'])->update(['weight_score' => $params['score']['weight_score']]);
  203. } else {
  204. MasterWorkerScore::create([
  205. 'worker_id' => $params['id'],
  206. 'weight_score' => $params['score']['weight_score'],
  207. ]);
  208. }
  209. }
  210. Db::commit();
  211. return true;
  212. } catch (\Exception $e) {
  213. Db::rollback();
  214. self::setError($e->getMessage());
  215. return false;
  216. }
  217. }
  218. /**
  219. * @notes 删除
  220. * @param array $params
  221. * @return bool
  222. * @author likeadmin
  223. * @date 2024/07/10 18:17
  224. */
  225. public static function delete(array $params): bool
  226. {
  227. return MasterWorker::destroy($params['id']);
  228. }
  229. /**
  230. * @notes 获取详情
  231. * @param $params
  232. * @return array
  233. * @author likeadmin
  234. * @date 2024/07/10 18:17
  235. */
  236. public static function detail($params): array
  237. {
  238. $info = MasterWorker::with(['workerInfo'=>function(Query $query){
  239. $query->field('worker_id,real_name,id_card,id_card_front_img,id_card_opposite_img,mobile,address');
  240. },'workerRegister'=>function(Query $query){
  241. $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']);
  242. }])
  243. ->append(['time_period'])
  244. ->findOrEmpty($params['id'])->toArray();
  245. if(!empty($info['category_ids'])){
  246. $info['category_ids'] = explode(',',$info['category_ids']);
  247. $info['category_ids'] = array_map('intval', $info['category_ids']);
  248. }
  249. $info['is_up_retention_pay'] = 0;
  250. if(MasterWorkerRetentionMoneyLog::where(['worker_id' => $params['id'],'action' => 1])->count('id') > 0){
  251. $info['is_up_retention_pay'] = 1;
  252. }
  253. $info['score'] = MasterWorkerScore::where(['worker_id' => $params['id']])->field('comprehensive_score,weight_score')->findOrEmpty()->toArray();
  254. $images = MasterWorkerCredentialImages::where(['worker_register_id' => $info['workerRegister']['worker_register_id']??-1])->select()->toArray();
  255. $info['credential_info'] = $images;
  256. return $info;
  257. }
  258. /**
  259. * 获取加盐密码
  260. * @param $params
  261. * @return false|string
  262. */
  263. public static function saltToPassword($params){
  264. try{
  265. $passwordSalt = Config::get('project.unique_identification');
  266. $password = create_password($params['password'], $passwordSalt);
  267. return ['password' => $password];
  268. } catch (\Exception $e){
  269. self::setError($e->getMessage());
  270. return false;
  271. }
  272. }
  273. /**
  274. * 获取所有工程师选项列表
  275. * @param $params
  276. * @return array
  277. */
  278. public static function getAllWorkers($params){
  279. try{
  280. return MasterWorker::where(['is_disable'=>0])->column('id,id as value,worker_number as name,real_name,account,mobile');
  281. } catch (\Exception $e){
  282. self::setError($e->getMessage());
  283. return [];
  284. }
  285. }
  286. /**
  287. * 长期合作工程师停单
  288. * @param $params
  289. * @return bool
  290. */
  291. public static function stop($params, $userInfo){
  292. try{
  293. Db::startTrans();
  294. $worker = MasterWorker::where(['id' => $params['id']])->findOrEmpty();
  295. if($worker->isEmpty()){
  296. self::setError('工程师不存在');
  297. return false;
  298. }
  299. $start_time = strtotime($params['start_time']. " 00:00:00");
  300. $end_time = strtotime($params['end_time']. " 23:59:59");
  301. //校验停单日期是否重复
  302. $exists = MasterWorkerStop::where(['worker_id' => $params['id'] ])
  303. ->where(function($query) use ($start_time, $end_time) {
  304. $query->where('start_time', 'between', [$start_time, $end_time])
  305. ->whereOr('end_time', 'between', [$start_time, $end_time]);
  306. })
  307. ->count('id');
  308. if($exists > 0){
  309. self::setError('该日期已存在停单记录');
  310. return false;
  311. }
  312. if ($params['start_time'] == date('Y-m-d')) {
  313. $worker->accept_order_status = 0;
  314. }
  315. $worker->save();
  316. MasterWorkerStop::create([
  317. 'worker_id' => $params['id'],
  318. 'start_time' => $start_time,
  319. 'end_time' => $end_time,
  320. 'admin_id' => $userInfo['admin_id'],
  321. ]);
  322. Db::commit();
  323. return true;
  324. } catch (\Exception $e){
  325. Db::rollback();
  326. self::setError($e->getMessage());
  327. return false;
  328. }
  329. }
  330. /**
  331. * 设置工程师备注
  332. * @param $params
  333. * @return false|string
  334. */
  335. public static function setRemark($params){
  336. try{
  337. MasterWorker::where('id', $params['id'])->update(['remark' => $params['remark']]);
  338. return true;
  339. } catch (\Exception $e){
  340. self::setError($e->getMessage());
  341. return false;
  342. }
  343. }
  344. /**
  345. * 设置工程师特殊技能
  346. * @param $params
  347. * @return false|string
  348. */
  349. public static function setSkill($params){
  350. try{
  351. MasterWorker::where('id', $params['id'])->update(['skill' => $params['skill']]);
  352. return true;
  353. } catch (\Exception $e){
  354. self::setError($e->getMessage());
  355. return false;
  356. }
  357. }
  358. /**
  359. * 工程师质保金缴费二维码
  360. * @param $params
  361. * @return array|false|string
  362. * @throws \Exception
  363. */
  364. public static function retentionMoneyOrder($params, $is_reg = 0){
  365. // 创建分享单Id
  366. $is_share = true;
  367. //系统配置的质保金缴费金额
  368. if ($is_reg == 1 && empty($params['amount']) ) {
  369. $content = DictConfig::where('value', 'retention_money')->value('content');
  370. $content = json_decode($content,true);
  371. $order_amount = $content[0]['value'];
  372. } else {
  373. $order_amount = (float)$params['amount'] ?? 0;
  374. }
  375. $order = $is_reg == 0 ? 'desc' : 'asc';
  376. $order = MasterWorkerRetentionMoneyOrder::where(['worker_id'=>$params['worker_id']])->order('id',$order)->findOrEmpty();
  377. if($order->isEmpty() || ($is_reg == 0 && $order->order_status === 2)){
  378. $sn = generate_sn(MasterWorkerRetentionMoneyOrder::class, 'sn');
  379. $order = MasterWorkerRetentionMoneyOrder::create(['sn' => $sn, 'order_status'=>1,'worker_id'=>$params['worker_id'],'order_amount'=>$order_amount]);
  380. }else{
  381. if($order->order_status === 1 && empty($order->openid) && $order_amount > 0){ // 可以改价
  382. $order->order_amount = $order_amount;
  383. $order->save();
  384. $is_share = $order->order_amount > 0 ? true : false;
  385. }else{ // 已结束 - 不用分享二维码
  386. if((float)$order->order_amount>0 && empty($params['amount'])) $is_share = true;
  387. else $is_share = false;
  388. }
  389. }
  390. $masterWorker = MasterWorker::where(['id' => $params['worker_id']])->field('id,real_name,mobile')->findOrEmpty()->toArray();
  391. $order->real_name = $masterWorker['real_name'];
  392. $order->mobile = $masterWorker['mobile'];
  393. $share_url = $is_share?(env('project.share_retention_money_host','').'?id='.$order->id):'';
  394. return ['info' => $order->toArray(),'share_url' => $share_url];
  395. }
  396. /**
  397. * 工程师质保金缴费订单详情
  398. * @param $params
  399. * @return array|false|string
  400. * @throws \Exception
  401. */
  402. public static function retentionMoneyOrderDetail($order_id){
  403. $order = MasterWorkerRetentionMoneyOrder::where(['id'=>$order_id])->field('id,worker_id,sn,order_status,order_amount,paid_amount')->findOrEmpty()->toArray();
  404. if($order){
  405. $masterWorker = MasterWorker::where(['id' => $order['worker_id']])->field('id,real_name,mobile')->findOrEmpty()->toArray();
  406. $order['real_name'] = $masterWorker['real_name'];
  407. $order['mobile'] = $masterWorker['mobile'];
  408. }
  409. return $order;
  410. }
  411. /**
  412. * 工程师质保金退费申请
  413. * @param $params
  414. * @return array|false|string
  415. * @throws \Exception
  416. */
  417. public static function retentionMoneyRefund($params){
  418. $params['amount'] = (float)$params['amount']??0;
  419. $log = MasterWorkerRetentionMoneyLog::where(['worker_id'=>$params['worker_id'], 'action' => 2, 'source' => 2])->where('status',0)->order('id','desc')->findOrEmpty();
  420. if($log->isEmpty()){
  421. $sn = generate_sn(MasterWorkerRetentionMoneyLog::class, 'sn');
  422. $log = MasterWorkerRetentionMoneyLog::create([
  423. 'sn' => $sn,
  424. 'status'=>0,
  425. 'worker_id'=>$params['worker_id'],
  426. 'amount'=>$params['amount']??0,
  427. 'action' => 2, // 退款
  428. 'remark' => $params['remark']??'',
  429. 'source' => 2, // 后台
  430. ]);
  431. } elseif($params['amount']>0){ // 可以改价
  432. $log->amount= $params['amount']??0;
  433. $log->remark= $params['remark']??0;
  434. $log->save();
  435. }
  436. return $log->toArray();
  437. }
  438. /**
  439. * 工程师质保金退费申请
  440. * @param $params
  441. * @return array|false|string
  442. * @throws \Exception
  443. */
  444. public static function retentionMoneyAudit($params){
  445. $status = $params['status']??0;
  446. Db::startTrans();
  447. try {
  448. $log = MasterWorkerRetentionMoneyLog::where('id',$params['id'])->findOrEmpty();
  449. if($log->isEmpty()){
  450. self::setError('退费记录不存在');
  451. return false;
  452. } else{
  453. if ($status == 1) {
  454. //审核通过
  455. $earnest_money_usable = MasterWorker::where('id', $log->worker_id)->value('earnest_money_usable');
  456. MasterWorker::where('id', $log->worker_id)->dec('earnest_money_usable', $log->amount)->save();
  457. $log->remark .= ' 退费前余额:'.$earnest_money_usable.'元,退费后余额:'.($earnest_money_usable-$log->amount).'元';
  458. }
  459. $log->status = $status;
  460. $log->save();
  461. }
  462. Db::commit();
  463. return true;
  464. } catch (\Exception $e) {
  465. Db::rollback();
  466. self::setError($e->getMessage());
  467. return false;
  468. }
  469. }
  470. }