MasterWorkerLogic.php 17 KB

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