MasterWorkerTeamLogic.php 8.7 KB

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