1
0

MasterWorkerTeamLogic.php 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. <?php
  2. namespace app\workerapi\logic;
  3. use app\adminapi\logic\master_worker_register\MasterWorkerRegisterLogic;
  4. use app\common\enum\worker\WorkerAccountLogEnum;
  5. use app\common\enum\YesNoEnum;
  6. use app\common\logic\BaseLogic;
  7. use app\common\model\bank_account\BankAccount;
  8. use app\common\model\goods_category\GoodsCategory;
  9. use app\common\model\master_worker\MasterWorker;
  10. use app\common\model\master_worker\MasterWorkerAccountLog;
  11. use app\common\model\master_worker\MasterWorkerAgree;
  12. use app\common\model\master_worker\MasterWorkerInfo;
  13. use app\common\model\master_worker\MasterWorkerTeam;
  14. use app\common\model\works\ServiceWork;
  15. use app\common\service\FileService;
  16. use app\workerapi\lists\MasterWorkerLists;
  17. use app\workerapi\lists\ServiceWorkLists;
  18. use think\Exception;
  19. use think\facade\Config;
  20. use think\facade\Db;
  21. /**
  22. * @author 林海涛
  23. * @date 2024/7/10 下午1:45
  24. */
  25. class MasterWorkerTeamLogic extends BaseLogic
  26. {
  27. public static function getDetail(int $masterWorkerId)
  28. {
  29. try {
  30. $team = MasterWorkerTeam::where('master_worker_id',$masterWorkerId)->findOrEmpty();
  31. if ($team->isEmpty()) {
  32. throw new \Exception('团队不存在');
  33. }
  34. $team = $team->toArray();
  35. $team['count_num'] = MasterWorker::where('team_id',$team['id'])->where('team_role',2)->count();
  36. // 团队负责人分类 ID 59,54,55,56,57,58
  37. $category_ids = MasterWorker::where('id',$team['master_worker_id'])->value('category_ids');
  38. if(!empty($category_ids)){
  39. $category_ids = array_map('intval', explode(',',$category_ids));
  40. $team['tree_data'] = getSuperiorCategoryTree($category_ids);
  41. }else{
  42. $team['tree_data'] = [];
  43. }
  44. return $team;
  45. } catch (\Exception $e) {
  46. self::setError($e->getMessage());
  47. return [];
  48. }
  49. }
  50. public static function addTeamMember(array $params,int $masterWorkerId)
  51. {
  52. try {
  53. $team = MasterWorkerTeam::where('master_worker_id',$masterWorkerId)->findOrEmpty();
  54. if ($team->isEmpty()) {
  55. throw new \Exception('团队不存在');
  56. }
  57. $masterWorker = \app\common\model\master_worker\MasterWorker::where('mobile',$params['mobile'])->findOrEmpty();
  58. if (!$masterWorker->isEmpty()) {
  59. throw new \Exception('该手机号已占用');
  60. }
  61. if(isset($params['category_ids']) && !empty($params['category_ids']) && is_array($params['category_ids'])){
  62. $params['category_ids'] = implode(',',$params['category_ids']);
  63. }
  64. // 新增工程师 - 所属团队、租户
  65. $mwId = MasterWorkerRegisterLogic::createMasterWorker([
  66. 'mobile' => $params['mobile'],
  67. 'real_name' => $params['real_name'],
  68. 'lon' => isset($params['lon'])?$params['lon']:0,
  69. 'lat' => isset($params['lat'])?$params['lat']:0,
  70. 'tenant_id'=>$team->tenant_id,
  71. 'category_ids' => $params['category_ids']??'',
  72. ]);
  73. MasterWorker::where('id',$mwId)->update(['team_id'=>$team->id,'team_role'=>2]);
  74. return true;
  75. } catch (\Exception $e) {
  76. self::setError($e->getMessage());
  77. return false;
  78. }
  79. }
  80. public static function upTeamMember(array $params,int $masterWorkerId,int $userId = 0)
  81. {
  82. try {
  83. $team = MasterWorkerTeam::where('master_worker_id',$userId)->findOrEmpty();
  84. if ($team->isEmpty()) {
  85. throw new \Exception('团队不存在');
  86. }
  87. // $masterWorkerId 当前要修改的工程师ID
  88. // 若非自己的其他工程师存在则不允许修改
  89. $masterWorker = MasterWorker::where('id','<>',$masterWorkerId)->where('mobile',$params['mobile'])->findOrEmpty();
  90. if (!$masterWorker->isEmpty()) {
  91. throw new \Exception('该手机号已占用');
  92. }
  93. if(isset($params['category_ids']) && !empty($params['category_ids']) && is_array($params['category_ids'])){
  94. $params['category_ids'] = implode(',',$params['category_ids']);
  95. }
  96. MasterWorker::where('team_id',$team->id)->where('team_role',2)->where('id',$masterWorkerId)->update(['real_name'=>$params['real_name'],'account'=>$params['mobile'],'mobile'=>$params['mobile'],'category_ids'=>$params['category_ids']??'']);
  97. return true;
  98. } catch (\Exception $e) {
  99. self::setError($e->getMessage());
  100. return false;
  101. }
  102. }
  103. public static function getMemberList(int $masterWorkerId)
  104. {
  105. try {
  106. $team = MasterWorkerTeam::where('master_worker_id',$masterWorkerId)->findOrEmpty();
  107. if ($team->isEmpty()) {
  108. throw new \Exception('团队不存在');
  109. }
  110. return MasterWorker::where('team_id',$team['id'])->where('team_role',2)->field(['id','nickname','avatar','mobile','real_name','team_role'])->select()->toArray();
  111. } catch (\Exception $e) {
  112. self::setError($e->getMessage());
  113. return [];
  114. }
  115. }
  116. /**
  117. * 分配给团队成员
  118. * @param int $teamId
  119. * @param int $masterWorkerId
  120. * @return array
  121. */
  122. public static function allocation($params,$userInfo){
  123. Db::startTrans();
  124. try {
  125. $work = ServiceWork::findOrEmpty($params['work_id']);
  126. if($work->isEmpty()){
  127. throw new Exception('工单不存在');
  128. }
  129. if($work->work_status != 1 ){
  130. throw new \Exception('工单已被领取,不可分配');
  131. }
  132. if($work->master_worker_id == $params['master_worker_id']){
  133. throw new \Exception('分配的工程师相同');
  134. }
  135. $worker = MasterWorker::where(['id'=>$params['master_worker_id'],'team_id' =>$userInfo['team_id'],'team_role' =>2,'is_disable' =>0])->findOrEmpty();
  136. if($worker->isEmpty()){
  137. throw new \Exception('成员工程师不存在或被禁用');
  138. }
  139. if($worker->master_worker_id){
  140. MasterWorker::setWorktotal('dec',$worker->master_worker_id);
  141. }
  142. $work->master_worker_id = $params['master_worker_id'];
  143. $work->work_status = 1;
  144. $work->dispatch_time = time();
  145. MasterWorker::setWorktotal('inc',$params['master_worker_id']);
  146. $work->save();
  147. $work_log = [
  148. 'work_id'=>$work->id,
  149. 'master_worker_id'=>$work->master_worker_id,
  150. 'opera_log'=>'团队负责人['.$userInfo['user_id'].']'.$userInfo['real_name'].'于'.date('Y-m-d H:i:s',time()).'分配了工程师成员'.'编号['.$worker->worker_number.']'.$worker->real_name
  151. ];
  152. ServiceWorkerAllocateWorkerLogic::add($work_log);
  153. Db::commit();
  154. return true;
  155. }catch(\Exception $e){
  156. Db::rollback();
  157. self::setError($e->getMessage());
  158. return false;
  159. }
  160. }
  161. /**
  162. * 团队成员工单统计
  163. * @param int $teamId
  164. * @param int $masterWorkerId
  165. * @return array
  166. */
  167. public static function MemberWorkStatistics($userInfo){
  168. $lists = ServiceWork::whereIn('master_worker_id',
  169. MasterWorker::where('team_id', $userInfo['team_id'])->where('team_role', 2)->column('id')
  170. )->group('work_status')
  171. ->field('work_status, COUNT(id) as count_num')
  172. ->order('work_status asc')
  173. ->select()->toArray();
  174. $lists = array_column($lists,'count_num','work_status');
  175. $work_status_txt = array_slice(ServiceWork::WORK_STATUS_TXT, 1, 8,true);
  176. $res = [];
  177. foreach ($work_status_txt as $work_status => $name) {
  178. $res[] = [
  179. 'work_status' => $work_status,
  180. 'work_status_text' => $name,
  181. 'count_num' => $lists[$work_status]??0,
  182. ];
  183. }
  184. return $res;
  185. }
  186. /**
  187. * 团队工单统计- 当天日期的前x天范围
  188. * @param int $teamId
  189. * @param int $masterWorkerId
  190. * @return array
  191. */
  192. public static function TeamOrderStatistics($userInfo,$day_num = 7,$month = ''){
  193. if(!empty($day_num)){
  194. $start_time = strtotime(date('Y-m-d', time() - $day_num * 86400));
  195. $end_time = time();
  196. }
  197. if(!empty($month)){
  198. $start_time = strtotime($month.'-01');
  199. $end_time = $start_time + 31 * 86400;
  200. }
  201. // 临时测试数据UI 测试数据,正式上线去掉这段代码
  202. $lists = ServiceWork::field('DATE(FROM_UNIXTIME(create_time)) as days, COUNT(id) as count_num')
  203. ->where('create_time','between',[$start_time,$end_time])
  204. ->group('DATE(FROM_UNIXTIME(create_time))')
  205. ->order('create_time desc')
  206. ->select()->toArray();
  207. /*$lists = ServiceWork::whereIn('master_worker_id',
  208. MasterWorker::where('team_id', $userInfo['team_id'])->where('team_role', 2)->column('id')
  209. )->group('DATE(FROM_UNIXTIME(create_time))')
  210. ->field('DATE(FROM_UNIXTIME(create_time)) as days, COUNT(id) as count_num')
  211. ->where('create_time','between',[$start_time,$end_time])
  212. ->order('create_time desc')
  213. ->select()->toArray();*/
  214. return array_column($lists,'count_num','days');
  215. }
  216. }